diff options
author | Paul B Mahol <onemda@gmail.com> | 2013-05-02 12:09:28 +0000 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2013-05-02 12:22:18 +0000 |
commit | 990b13806d38f51201afb4e5048c61bf3e1c576e (patch) | |
tree | 9cbb28a912808170e96b2a04c6bf208aef79819d | |
parent | 89b5039ff265e0519261b07aa9bdd3ed7df6090c (diff) | |
download | ffmpeg-990b13806d38f51201afb4e5048c61bf3e1c576e.tar.gz |
lavfi/blend: use correct way to check number of planes
This fix crash with gray, as its marked as pseudopal,
and thus have extra plane.
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r-- | libavfilter/vf_blend.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libavfilter/vf_blend.c b/libavfilter/vf_blend.c index 93b68bef3d..17b168d8ca 100644 --- a/libavfilter/vf_blend.c +++ b/libavfilter/vf_blend.c @@ -80,6 +80,7 @@ typedef struct { struct FFBufQueue queue_top; struct FFBufQueue queue_bottom; int hsub, vsub; ///< chroma subsampling values + int nb_planes; int frame_requested; char *all_expr; enum BlendMode all_mode; @@ -330,6 +331,7 @@ static int config_input_top(AVFilterLink *inlink) b->hsub = pix_desc->log2_chroma_w; b->vsub = pix_desc->log2_chroma_h; + b->nb_planes = av_pix_fmt_count_planes(inlink->format); return 0; } @@ -371,7 +373,7 @@ static void blend_frame(AVFilterContext *ctx, FilterParams *param; int plane; - for (plane = 0; dst_buf->data[plane]; plane++) { + for (plane = 0; plane < b->nb_planes; plane++) { int hsub = plane == 1 || plane == 2 ? b->hsub : 0; int vsub = plane == 1 || plane == 2 ? b->vsub : 0; int outw = dst_buf->width >> hsub; @@ -422,7 +424,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf) b->frame_requested = 0; blend_frame(ctx, top_buf, bottom_buf, out_buf); - ret = ff_filter_frame(ctx->outputs[0], out_buf); + ret = ff_filter_frame(outlink, out_buf); av_frame_free(&top_buf); av_frame_free(&bottom_buf); } |