[FFmpeg-devel] [PATCH v4 10/13] ffmpeg: pass first video AVFrame's side data to encoder

James Almer jamrial at gmail.com
Sat Sep 2 19:10:33 EEST 2023


On 9/1/2023 5:38 PM, Jan Ekström wrote:
> This enables further configuration of output based on the results
> of input decoding and filtering in a similar manner as the color
> information.
> ---
>   fftools/ffmpeg_enc.c | 13 +++++++++++++
>   1 file changed, 13 insertions(+)
> 
> diff --git a/fftools/ffmpeg_enc.c b/fftools/ffmpeg_enc.c
> index f28884e50c..0d022700cf 100644
> --- a/fftools/ffmpeg_enc.c
> +++ b/fftools/ffmpeg_enc.c
> @@ -356,6 +356,19 @@ int enc_open(OutputStream *ost, AVFrame *frame)
>           enc_ctx->colorspace             = frame->colorspace;
>           enc_ctx->chroma_sample_location = frame->chroma_location;
>   
> +        ret = av_frame_side_data_set_extend(
> +            &enc_ctx->frame_sd_set,
> +            (const AVFrameSideDataSet){
> +                .sd    = frame->side_data,
> +                .nb_sd = frame->nb_side_data
> +            },
> +            AV_FRAME_SIDE_DATA_SET_FLAG_NO_DUPLICATES);
> +        if (ret < 0) {
> +            av_log(NULL, AV_LOG_ERROR, "failed to configure video encoder: %s!\n",
> +                   av_err2str(ret));
> +            return ret;
> +        }

Following what i suggested in my last email, this would instead be a 
loop adding all the frame->side_data entries.

> +
>           // Field order: autodetection
>           if (enc_ctx->flags & (AV_CODEC_FLAG_INTERLACED_DCT | AV_CODEC_FLAG_INTERLACED_ME) &&
>               ost->top_field_first >= 0)


More information about the ffmpeg-devel mailing list