summaryrefslogtreecommitdiff
path: root/libavcodec/bink.c
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2010-02-23 07:07:54 +0000
committerKostya Shishkov <kostya.shishkov@gmail.com>2010-02-23 07:07:54 +0000
commit4f974de6f6282d6ecfe4c976d07ee20b782d0be8 (patch)
tree484c1d4b55da25c0c2aa01ca23143a521ed7bc7f /libavcodec/bink.c
parentbf0d54a381f8c53fdf756bd477bf3b7f6acb7f71 (diff)
downloadffmpeg-4f974de6f6282d6ecfe4c976d07ee20b782d0be8.tar.gz
Decode alpha plane in Bink video
Originally committed as revision 21982 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/bink.c')
-rw-r--r--libavcodec/bink.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/libavcodec/bink.c b/libavcodec/bink.c
index 1d59ea3118..a4342faad4 100644
--- a/libavcodec/bink.c
+++ b/libavcodec/bink.c
@@ -911,12 +911,10 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPac
init_get_bits(&gb, pkt->data, bits_count);
if (c->has_alpha) {
- int aplane_bits = get_bits_long(&gb, 32) << 3;
- if (aplane_bits <= 32 || (aplane_bits & 0x1F)) {
- av_log(avctx, AV_LOG_ERROR, "Incorrect alpha plane size %d\n", aplane_bits);
+ if (c->version >= 'i')
+ skip_bits_long(&gb, 32);
+ if (bink_decode_plane(c, &gb, 3, 0) < 0)
return -1;
- }
- skip_bits_long(&gb, aplane_bits - 32);
}
if (c->version >= 'i')
skip_bits_long(&gb, 32);
@@ -977,7 +975,7 @@ static av_cold int decode_init(AVCodecContext *avctx)
return 1;
}
- avctx->pix_fmt = PIX_FMT_YUV420P;
+ avctx->pix_fmt = c->has_alpha ? PIX_FMT_YUVA420P : PIX_FMT_YUV420P;
avctx->idct_algo = FF_IDCT_BINK;
dsputil_init(&c->dsp, avctx);