diff options
author | Marton Balint <cus@passwd.hu> | 2012-10-28 02:00:52 +0200 |
---|---|---|
committer | Marton Balint <cus@passwd.hu> | 2012-11-01 15:46:18 +0100 |
commit | 8cb740245daf8a71904787b572d60715654db0b1 (patch) | |
tree | 32b6e872ceefb84ad2e62e4f4d793ca574ecfd80 /ffplay.c | |
parent | 09214f494b2cf7b89c70f4f91d98c60a8b7382fe (diff) | |
download | ffmpeg-8cb740245daf8a71904787b572d60715654db0b1.tar.gz |
ffplay: always free buffersink_params in configure_video_filters
Fixes Coverity CID 733792.
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'ffplay.c')
-rw-r--r-- | ffplay.c | 13 |
1 files changed, 7 insertions, 6 deletions
@@ -1714,31 +1714,32 @@ static int configure_video_filters(AVFilterGraph *graph, VideoState *is, const c avfilter_get_by_name("buffer"), "ffplay_buffer", buffersrc_args, NULL, graph)) < 0) - return ret; + goto fail; buffersink_params->pixel_fmts = pix_fmts; ret = avfilter_graph_create_filter(&filt_out, avfilter_get_by_name("ffbuffersink"), "ffplay_buffersink", NULL, buffersink_params, graph); - av_freep(&buffersink_params); if (ret < 0) - return ret; + goto fail; /* SDL YUV code is not handling odd width/height for some driver * combinations, therefore we crop the picture to an even width/height. */ if ((ret = avfilter_graph_create_filter(&filt_crop, avfilter_get_by_name("crop"), "ffplay_crop", "floor(in_w/2)*2:floor(in_h/2)*2", NULL, graph)) < 0) - return ret; + goto fail; if ((ret = avfilter_link(filt_crop, 0, filt_out, 0)) < 0) - return ret; + goto fail; if ((ret = configure_filtergraph(graph, vfilters, filt_src, filt_crop)) < 0) - return ret; + goto fail; is->in_video_filter = filt_src; is->out_video_filter = filt_out; +fail: + av_freep(&buffersink_params); return ret; } |