| @@ -371,11 +371,19 @@ static const uint8_t bink_rlelens[4] = { 4, 8, 12, 32 }; | |||||
| static int read_block_types(AVCodecContext *avctx, GetBitContext *gb, Bundle *b) | static int read_block_types(AVCodecContext *avctx, GetBitContext *gb, Bundle *b) | ||||
| { | { | ||||
| BinkContext * const c = avctx->priv_data; | |||||
| int t, v; | int t, v; | ||||
| int last = 0; | int last = 0; | ||||
| const uint8_t *dec_end; | const uint8_t *dec_end; | ||||
| CHECK_READ_VAL(gb, b, t); | CHECK_READ_VAL(gb, b, t); | ||||
| if (c->version == 'k') { | |||||
| t ^= 0xBBu; | |||||
| if (t == 0) { | |||||
| b->cur_dec = NULL; | |||||
| return 0; | |||||
| } | |||||
| } | |||||
| dec_end = b->cur_dec + t; | dec_end = b->cur_dec + t; | ||||
| if (dec_end > b->data_end) { | if (dec_end > b->data_end) { | ||||
| av_log(avctx, AV_LOG_ERROR, "Too many block type values\n"); | av_log(avctx, AV_LOG_ERROR, "Too many block type values\n"); | ||||
| @@ -994,6 +1002,17 @@ static int bink_decode_plane(BinkContext *c, AVFrame *frame, GetBitContext *gb, | |||||
| int bw = is_chroma ? (c->avctx->width + 15) >> 4 : (c->avctx->width + 7) >> 3; | int bw = is_chroma ? (c->avctx->width + 15) >> 4 : (c->avctx->width + 7) >> 3; | ||||
| int bh = is_chroma ? (c->avctx->height + 15) >> 4 : (c->avctx->height + 7) >> 3; | int bh = is_chroma ? (c->avctx->height + 15) >> 4 : (c->avctx->height + 7) >> 3; | ||||
| int width = c->avctx->width >> is_chroma; | int width = c->avctx->width >> is_chroma; | ||||
| int height = c->avctx->height >> is_chroma; | |||||
| if (c->version == 'k' && get_bits1(gb)) { | |||||
| int fill = get_bits(gb, 8); | |||||
| dst = frame->data[plane_idx]; | |||||
| for (i = 0; i < height; i++) | |||||
| memset(dst + i * stride, fill, width); | |||||
| goto end; | |||||
| } | |||||
| init_lengths(c, FFMAX(width, 8), bw); | init_lengths(c, FFMAX(width, 8), bw); | ||||
| for (i = 0; i < BINK_NB_SRC; i++) | for (i = 0; i < BINK_NB_SRC; i++) | ||||
| @@ -1190,6 +1209,8 @@ static int bink_decode_plane(BinkContext *c, AVFrame *frame, GetBitContext *gb, | |||||
| } | } | ||||
| } | } | ||||
| } | } | ||||
| end: | |||||
| if (get_bits_count(gb) & 0x1F) //next plane data starts at 32-bit boundary | if (get_bits_count(gb) & 0x1F) //next plane data starts at 32-bit boundary | ||||
| skip_bits_long(gb, 32 - (get_bits_count(gb) & 0x1F)); | skip_bits_long(gb, 32 - (get_bits_count(gb) & 0x1F)); | ||||