ensure vp56_decode_frame always return unchanged buf_size

Originally committed as revision 13083 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Aurelien Jacobs 17 years ago
parent 53a1e82bd2
commit 5210529e2d
  1. 7
      libavcodec/vp56.c

@ -499,11 +499,12 @@ int vp56_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
{ {
vp56_context_t *s = avctx->priv_data; vp56_context_t *s = avctx->priv_data;
AVFrame *const p = s->framep[VP56_FRAME_CURRENT]; AVFrame *const p = s->framep[VP56_FRAME_CURRENT];
int remaining_buf_size = buf_size;
int is_alpha, alpha_offset; int is_alpha, alpha_offset;
if (s->has_alpha) { if (s->has_alpha) {
alpha_offset = bytestream_get_be24(&buf); alpha_offset = bytestream_get_be24(&buf);
buf_size -= 3; remaining_buf_size -= 3;
} }
for (is_alpha=0; is_alpha < 1+s->has_alpha; is_alpha++) { for (is_alpha=0; is_alpha < 1+s->has_alpha; is_alpha++) {
@ -514,7 +515,7 @@ int vp56_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
s->modelp = &s->models[is_alpha]; s->modelp = &s->models[is_alpha];
res = s->parse_header(s, buf, buf_size, &golden_frame); res = s->parse_header(s, buf, remaining_buf_size, &golden_frame);
if (!res) if (!res)
return -1; return -1;
@ -619,7 +620,7 @@ int vp56_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
FFSWAP(AVFrame *, s->framep[VP56_FRAME_GOLDEN], FFSWAP(AVFrame *, s->framep[VP56_FRAME_GOLDEN],
s->framep[VP56_FRAME_GOLDEN2]); s->framep[VP56_FRAME_GOLDEN2]);
buf += alpha_offset; buf += alpha_offset;
buf_size -= alpha_offset; remaining_buf_size -= alpha_offset;
} }
} }

Loading…
Cancel
Save