mirror of https://git.ffmpeg.org/ffmpeg.git
ensure vp56_decode_frame always return unchanged buf_size
Originally committed as revision 13083 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
53a1e82bd2
commit
5210529e2d
|
@ -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…
Reference in New Issue