Commit 82850f6c authored by conrad's avatar conrad

vp3: Don't leak buffers on errors

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@22358 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 8cb7ffa1
...@@ -1812,7 +1812,7 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1812,7 +1812,7 @@ static int vp3_decode_frame(AVCodecContext *avctx,
s->current_frame.reference = 3; s->current_frame.reference = 3;
if (avctx->get_buffer(avctx, &s->current_frame) < 0) { if (avctx->get_buffer(avctx, &s->current_frame) < 0) {
av_log(s->avctx, AV_LOG_ERROR, "get_buffer() failed\n"); av_log(s->avctx, AV_LOG_ERROR, "get_buffer() failed\n");
return -1; goto error;
} }
if (s->keyframe) { if (s->keyframe) {
...@@ -1836,8 +1836,7 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1836,8 +1836,7 @@ static int vp3_decode_frame(AVCodecContext *avctx,
} else { } else {
if (!s->golden_frame.data[0]) { if (!s->golden_frame.data[0]) {
av_log(s->avctx, AV_LOG_ERROR, "vp3: first frame not a keyframe\n"); av_log(s->avctx, AV_LOG_ERROR, "vp3: first frame not a keyframe\n");
avctx->release_buffer(avctx, &s->current_frame); goto error;
return -1;
} }
} }
...@@ -1848,23 +1847,23 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1848,23 +1847,23 @@ static int vp3_decode_frame(AVCodecContext *avctx,
if (unpack_superblocks(s, &gb)){ if (unpack_superblocks(s, &gb)){
av_log(s->avctx, AV_LOG_ERROR, "error in unpack_superblocks\n"); av_log(s->avctx, AV_LOG_ERROR, "error in unpack_superblocks\n");
return -1; goto error;
} }
if (unpack_modes(s, &gb)){ if (unpack_modes(s, &gb)){
av_log(s->avctx, AV_LOG_ERROR, "error in unpack_modes\n"); av_log(s->avctx, AV_LOG_ERROR, "error in unpack_modes\n");
return -1; goto error;
} }
if (unpack_vectors(s, &gb)){ if (unpack_vectors(s, &gb)){
av_log(s->avctx, AV_LOG_ERROR, "error in unpack_vectors\n"); av_log(s->avctx, AV_LOG_ERROR, "error in unpack_vectors\n");
return -1; goto error;
} }
if (unpack_block_qpis(s, &gb)){ if (unpack_block_qpis(s, &gb)){
av_log(s->avctx, AV_LOG_ERROR, "error in unpack_block_qpis\n"); av_log(s->avctx, AV_LOG_ERROR, "error in unpack_block_qpis\n");
return -1; goto error;
} }
if (unpack_dct_coeffs(s, &gb)){ if (unpack_dct_coeffs(s, &gb)){
av_log(s->avctx, AV_LOG_ERROR, "error in unpack_dct_coeffs\n"); av_log(s->avctx, AV_LOG_ERROR, "error in unpack_dct_coeffs\n");
return -1; goto error;
} }
for (i = 0; i < 3; i++) { for (i = 0; i < 3; i++) {
...@@ -1906,6 +1905,11 @@ static int vp3_decode_frame(AVCodecContext *avctx, ...@@ -1906,6 +1905,11 @@ static int vp3_decode_frame(AVCodecContext *avctx,
s->current_frame.data[0]= NULL; /* ensure that we catch any access to this released frame */ s->current_frame.data[0]= NULL; /* ensure that we catch any access to this released frame */
return buf_size; return buf_size;
error:
if (s->current_frame.data[0])
avctx->release_buffer(avctx, &s->current_frame);
return -1;
} }
/* /*
......
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