[FFmpeg-devel] [PATCH 1/2] fftools/ffplay: fix missing hw_frames_ctx when config avfilter

Niklas Haas ffmpeg at haasn.xyz
Wed Jan 10 11:48:30 EET 2024


On Tue, 09 Jan 2024 23:41:00 +0800 Zhao Zhili <quinkblack at foxmail.com> wrote:
> From: Zhao Zhili <zhilizhao at tencent.com>
> 
> ---
>  fftools/ffplay.c | 9 +++++++++
>  1 file changed, 9 insertions(+)
> 
> diff --git a/fftools/ffplay.c b/fftools/ffplay.c
> index 17861e60be..3c378bca2c 100644
> --- a/fftools/ffplay.c
> +++ b/fftools/ffplay.c
> @@ -1858,6 +1858,10 @@ static int configure_video_filters(AVFilterGraph *graph, VideoState *is, const c
>      const AVDictionaryEntry *e = NULL;
>      int nb_pix_fmts = 0;
>      int i, j;
> +    AVBufferSrcParameters *par = av_buffersrc_parameters_alloc();
> +
> +    if (!par)
> +        return AVERROR(ENOMEM);
>  
>      for (i = 0; i < renderer_info.num_texture_formats; i++) {
>          for (j = 0; j < FF_ARRAY_ELEMS(sdl_texture_format_map) - 1; j++) {
> @@ -1893,6 +1897,10 @@ static int configure_video_filters(AVFilterGraph *graph, VideoState *is, const c
>                                              "ffplay_buffer", buffersrc_args, NULL,
>                                              graph)) < 0)
>          goto fail;
> +    par->hw_frames_ctx = frame->hw_frames_ctx;
> +    ret = av_buffersrc_parameters_set(filt_src, par);
> +    if (ret < 0)
> +        goto fail;
>  
>      ret = avfilter_graph_create_filter(&filt_out,
>                                         avfilter_get_by_name("buffersink"),
> @@ -1959,6 +1967,7 @@ static int configure_video_filters(AVFilterGraph *graph, VideoState *is, const c
>      is->out_video_filter = filt_out;
>  
>  fail:
> +    av_freep(&par);
>      return ret;
>  }
>  
> -- 
> 2.25.1

LGTM.


More information about the ffmpeg-devel mailing list