aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorLuca Barbato <lu_zero@gentoo.org>2013-06-05 20:30:48 +0200
committerLuca Barbato <lu_zero@gentoo.org>2013-06-12 14:45:46 +0200
commit50ec1db62d977b6e864f315a53c1c580a6d7efa4 (patch)
treea7a470977619785dd458484dcf1a379bbcb01c39 /libavcodec
parent42d73f7f6bea0ee0f64a3ad4882860ce5b923a11 (diff)
downloadffmpeg-50ec1db62d977b6e864f315a53c1c580a6d7efa4.tar.gz
4xm: fold last_picture lazy allocation in decode_p_frame
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/4xm.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/libavcodec/4xm.c b/libavcodec/4xm.c
index 1002762396..b09d19ff5f 100644
--- a/libavcodec/4xm.c
+++ b/libavcodec/4xm.c
@@ -394,6 +394,17 @@ static int decode_p_frame(FourXContext *f, AVFrame *frame,
uint16_t *src;
unsigned int bitstream_size, bytestream_size, wordstream_size, extra,
bytestream_offset, wordstream_offset;
+ int ret;
+
+ if (!f->last_picture->data[0]) {
+ if ((ret = ff_get_buffer(f->avctx, f->last_picture,
+ AV_GET_BUFFER_FLAG_REF)) < 0) {
+ av_log(f->avctx, AV_LOG_ERROR, "get_buffer() failed\n");
+ return ret;
+ }
+ memset(f->last_picture->data[0], 0,
+ f->avctx->height * FFABS(f->last_picture->linesize[0]));
+ }
src = (uint16_t *)f->last_picture->data[0];
@@ -842,15 +853,6 @@ static int decode_frame(AVCodecContext *avctx, void *data,
if ((ret = decode_i_frame(f, picture, buf, frame_size)) < 0)
return ret;
} else if (frame_4cc == AV_RL32("pfrm") || frame_4cc == AV_RL32("pfr2")) {
- if (!f->last_picture->data[0]) {
- if ((ret = ff_get_buffer(avctx, f->last_picture,
- AV_GET_BUFFER_FLAG_REF)) < 0) {
- av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
- return ret;
- }
- memset(f->last_picture->data[0], 0, avctx->height * FFABS(f->last_picture->linesize[0]));
- }
-
picture->pict_type = AV_PICTURE_TYPE_P;
if ((ret = decode_p_frame(f, picture, buf, frame_size)) < 0)
return ret;