Commit ff558d7b authored by Stefano Sabatini's avatar Stefano Sabatini

bfi: store palette data in the context

Store palette data in the codec context, do not assume that the frame
allocated the first time by avctx->get_buffer will be returned again.

This requires to store the palette which comes with the first frame in
the context, and copy it to the following frames.

Fix trac issue #84.
Signed-off-by: 's avatarStefano Sabatini <stefano.sabatini-lala@poste.it>
parent 3788a3c0
...@@ -34,6 +34,7 @@ typedef struct BFIContext { ...@@ -34,6 +34,7 @@ typedef struct BFIContext {
AVCodecContext *avctx; AVCodecContext *avctx;
AVFrame frame; AVFrame frame;
uint8_t *dst; uint8_t *dst;
uint32_t pal[256];
} BFIContext; } BFIContext;
static av_cold int bfi_decode_init(AVCodecContext * avctx) static av_cold int bfi_decode_init(AVCodecContext * avctx)
...@@ -85,10 +86,13 @@ static int bfi_decode_frame(AVCodecContext * avctx, void *data, ...@@ -85,10 +86,13 @@ static int bfi_decode_frame(AVCodecContext * avctx, void *data,
(avctx->extradata[i * 3 + j] >> 4)) << shift; (avctx->extradata[i * 3 + j] >> 4)) << shift;
pal++; pal++;
} }
memcpy(bfi->pal, bfi->frame.data[1], sizeof(bfi->pal));
bfi->frame.palette_has_changed = 1; bfi->frame.palette_has_changed = 1;
} else { } else {
bfi->frame.pict_type = FF_P_TYPE; bfi->frame.pict_type = FF_P_TYPE;
bfi->frame.key_frame = 0; bfi->frame.key_frame = 0;
bfi->frame.palette_has_changed = 0;
memcpy(bfi->frame.data[1], bfi->pal, sizeof(bfi->pal));
} }
buf += 4; //Unpacked size, not required. buf += 4; //Unpacked size, not required.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment