Merge commit '6064f697a321174232a3fad351afb21150c3e9e5'
* commit '6064f697a321174232a3fad351afb21150c3e9e5': lavc: Enable side data only packets by default Merged-by: Hendrik Leppkes <h.leppkes@gmail.com>
This commit is contained in:
		
						commit
						580c4fc98a
					
				
							
								
								
									
										1
									
								
								ffmpeg.c
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								ffmpeg.c
									
									
									
									
									
								
							| @ -2596,7 +2596,6 @@ static int init_output_stream(OutputStream *ost, char *error, int error_len) | |||||||
|         } |         } | ||||||
|         if (!av_dict_get(ost->encoder_opts, "threads", NULL, 0)) |         if (!av_dict_get(ost->encoder_opts, "threads", NULL, 0)) | ||||||
|             av_dict_set(&ost->encoder_opts, "threads", "auto", 0); |             av_dict_set(&ost->encoder_opts, "threads", "auto", 0); | ||||||
|         av_dict_set(&ost->encoder_opts, "side_data_only_packets", "1", 0); |  | ||||||
|         if (ost->enc->type == AVMEDIA_TYPE_AUDIO && |         if (ost->enc->type == AVMEDIA_TYPE_AUDIO && | ||||||
|             !codec->defaults && |             !codec->defaults && | ||||||
|             !av_dict_get(ost->encoder_opts, "b", NULL, 0) && |             !av_dict_get(ost->encoder_opts, "b", NULL, 0) && | ||||||
|  | |||||||
| @ -1352,7 +1352,9 @@ typedef struct AVPacketSideData { | |||||||
|  * then passed to muxers. |  * then passed to muxers. | ||||||
|  * |  * | ||||||
|  * For video, it should typically contain one compressed frame. For audio it may |  * For video, it should typically contain one compressed frame. For audio it may | ||||||
|  * contain several compressed frames. |  * contain several compressed frames. Encoders are allowed to output empty | ||||||
|  |  * packets, with no compressed data, containing only side data | ||||||
|  |  * (e.g. to update some stream parameters at the end of encoding). | ||||||
|  * |  * | ||||||
|  * AVPacket is one of the few structs in FFmpeg, whose size is a part of public |  * AVPacket is one of the few structs in FFmpeg, whose size is a part of public | ||||||
|  * ABI. Thus it may be allocated on stack and no new fields can be added to it |  * ABI. Thus it may be allocated on stack and no new fields can be added to it | ||||||
| @ -3105,20 +3107,20 @@ typedef struct AVCodecContext { | |||||||
|      */ |      */ | ||||||
|     uint64_t vbv_delay; |     uint64_t vbv_delay; | ||||||
| 
 | 
 | ||||||
|  | #if FF_API_SIDEDATA_ONLY_PKT | ||||||
|     /**
 |     /**
 | ||||||
|      * Encoding only. Allow encoders to output packets that do not contain any |      * Encoding only and set by default. Allow encoders to output packets | ||||||
|      * encoded data, only side data. |      * that do not contain any encoded data, only side data. | ||||||
|      * |      * | ||||||
|      * Some encoders need to output such packets, e.g. to update some stream |      * Some encoders need to output such packets, e.g. to update some stream | ||||||
|      * parameters at the end of encoding. |      * parameters at the end of encoding. | ||||||
|      * |      * | ||||||
|      * All callers are strongly recommended to set this option to 1 and update |      * @deprecated this field disables the default behaviour and | ||||||
|      * their code to deal with such packets, since this behaviour may become |      *             it is kept only for compatibility. | ||||||
|      * always enabled in the future (then this option will be deprecated and |  | ||||||
|      * later removed). To avoid ABI issues when this happens, the callers should |  | ||||||
|      * use AVOptions to set this field. |  | ||||||
|      */ |      */ | ||||||
|  |     attribute_deprecated | ||||||
|     int side_data_only_packets; |     int side_data_only_packets; | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
|     /**
 |     /**
 | ||||||
|      * Audio only. The number of "priming" samples (padding) inserted by the |      * Audio only. The number of "priming" samples (padding) inserted by the | ||||||
|  | |||||||
| @ -1346,7 +1346,13 @@ static int flac_encode_frame(AVCodecContext *avctx, AVPacket *avpkt, | |||||||
|         av_md5_final(s->md5ctx, s->md5sum); |         av_md5_final(s->md5ctx, s->md5sum); | ||||||
|         write_streaminfo(s, avctx->extradata); |         write_streaminfo(s, avctx->extradata); | ||||||
| 
 | 
 | ||||||
|  | #if FF_API_SIDEDATA_ONLY_PKT | ||||||
|  | FF_DISABLE_DEPRECATION_WARNINGS | ||||||
|         if (avctx->side_data_only_packets && !s->flushed) { |         if (avctx->side_data_only_packets && !s->flushed) { | ||||||
|  | FF_ENABLE_DEPRECATION_WARNINGS | ||||||
|  | #else | ||||||
|  |         if (!s->flushed) { | ||||||
|  | #endif | ||||||
|             uint8_t *side_data = av_packet_new_side_data(avpkt, AV_PKT_DATA_NEW_EXTRADATA, |             uint8_t *side_data = av_packet_new_side_data(avpkt, AV_PKT_DATA_NEW_EXTRADATA, | ||||||
|                                                          avctx->extradata_size); |                                                          avctx->extradata_size); | ||||||
|             if (!side_data) |             if (!side_data) | ||||||
|  | |||||||
| @ -490,7 +490,9 @@ static const AVOption avcodec_options[] = { | |||||||
| {"auto",        NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_SUB_CHARENC_MODE_AUTOMATIC},   INT_MIN, INT_MAX, S|D, "sub_charenc_mode"}, | {"auto",        NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_SUB_CHARENC_MODE_AUTOMATIC},   INT_MIN, INT_MAX, S|D, "sub_charenc_mode"}, | ||||||
| {"pre_decoder", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_SUB_CHARENC_MODE_PRE_DECODER}, INT_MIN, INT_MAX, S|D, "sub_charenc_mode"}, | {"pre_decoder", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_SUB_CHARENC_MODE_PRE_DECODER}, INT_MIN, INT_MAX, S|D, "sub_charenc_mode"}, | ||||||
| {"refcounted_frames", NULL, OFFSET(refcounted_frames), AV_OPT_TYPE_INT, {.i64 = 0}, 0, 1, A|V|D }, | {"refcounted_frames", NULL, OFFSET(refcounted_frames), AV_OPT_TYPE_INT, {.i64 = 0}, 0, 1, A|V|D }, | ||||||
| {"side_data_only_packets", NULL, OFFSET(side_data_only_packets), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1, A|V|E }, | #if FF_API_SIDEDATA_ONLY_PKT | ||||||
|  | {"side_data_only_packets", NULL, OFFSET(side_data_only_packets), AV_OPT_TYPE_INT, { .i64 = 1 }, 0, 1, A|V|E }, | ||||||
|  | #endif | ||||||
| {"skip_alpha", "Skip processing alpha", OFFSET(skip_alpha), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 1, V|D }, | {"skip_alpha", "Skip processing alpha", OFFSET(skip_alpha), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 1, V|D }, | ||||||
| {"field_order", "Field order", OFFSET(field_order), AV_OPT_TYPE_INT, {.i64 = AV_FIELD_UNKNOWN }, 0, 5, V|D|E, "field_order" }, | {"field_order", "Field order", OFFSET(field_order), AV_OPT_TYPE_INT, {.i64 = AV_FIELD_UNKNOWN }, 0, 5, V|D|E, "field_order" }, | ||||||
| {"progressive", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = AV_FIELD_PROGRESSIVE }, 0, 0, V|D|E, "field_order" }, | {"progressive", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = AV_FIELD_PROGRESSIVE }, 0, 0, V|D|E, "field_order" }, | ||||||
|  | |||||||
| @ -179,5 +179,8 @@ | |||||||
| #ifndef FF_API_WITHOUT_PREFIX | #ifndef FF_API_WITHOUT_PREFIX | ||||||
| #define FF_API_WITHOUT_PREFIX    (LIBAVCODEC_VERSION_MAJOR < 59) | #define FF_API_WITHOUT_PREFIX    (LIBAVCODEC_VERSION_MAJOR < 59) | ||||||
| #endif | #endif | ||||||
|  | #ifndef FF_API_SIDEDATA_ONLY_PKT | ||||||
|  | #define FF_API_SIDEDATA_ONLY_PKT (LIBAVCODEC_VERSION_MAJOR < 59) | ||||||
|  | #endif | ||||||
| 
 | 
 | ||||||
| #endif /* AVCODEC_VERSION_H */ | #endif /* AVCODEC_VERSION_H */ | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user