summaryrefslogtreecommitdiff
path: root/libavcodec/eamad.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2013-03-12 15:44:15 +0100
committerMichael Niedermayer <michaelni@gmx.at>2013-03-12 15:44:15 +0100
commit0cfbfaaa12e10dbd2d6cdcf9ed618b9bab91ed04 (patch)
tree041202962161e4fb791cbd9f8ddb98cf90fc9613 /libavcodec/eamad.c
parenta75f01d7e0bf166a0b443eb15621753619bb8d88 (diff)
parent7b89cd20d844cbe763ca34e63e99d110043cf241 (diff)
Merge commit '7b89cd20d844cbe763ca34e63e99d110043cf241'
* commit '7b89cd20d844cbe763ca34e63e99d110043cf241': eamad: allocate a dummy reference frame when the real one is missing Replace remaining includes of audioconvert.h with channel_layout.h Replace some forgotten instances of PIX_FMT_* with AV_PIX_FMT_*. Conflicts: libavcodec/h264.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/eamad.c')
-rw-r--r--libavcodec/eamad.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/libavcodec/eamad.c b/libavcodec/eamad.c
index 1e8d395ae9..c193d81294 100644
--- a/libavcodec/eamad.c
+++ b/libavcodec/eamad.c
@@ -271,6 +271,19 @@ static int decode_frame(AVCodecContext *avctx,
return ret;
}
+ if (inter && !s->last_frame.data[0]) {
+ av_log(avctx, AV_LOG_WARNING, "Missing reference frame.\n");
+ ret = ff_get_buffer(avctx, &s->last_frame, AV_GET_BUFFER_FLAG_REF);
+ if (ret < 0)
+ return ret;
+ memset(s->last_frame.data[0], 0, s->last_frame.height *
+ s->last_frame.linesize[0]);
+ memset(s->last_frame.data[1], 0x80, s->last_frame.height / 2 *
+ s->last_frame.linesize[1]);
+ memset(s->last_frame.data[2], 0x80, s->last_frame.height / 2 *
+ s->last_frame.linesize[2]);
+ }
+
av_fast_padded_malloc(&s->bitstream_buf, &s->bitstream_buf_size,
buf_end - buf);
if (!s->bitstream_buf)