diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2013-06-11 09:23:11 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2013-06-11 09:27:04 +0200 |
commit | 5d199c3ad985eab4500cbfd2d1146ac70197ceac (patch) | |
tree | 0fb37bf75b69b3c0d5660d80c2b9f6f9c5266273 /libavcodec | |
parent | 045e371cf1f002cf75e9ef7b3e072723473f0c83 (diff) | |
parent | 799f57ac96f9891d1a0f7d6c4b218ed536e8aca5 (diff) | |
download | ffmpeg-5d199c3ad985eab4500cbfd2d1146ac70197ceac.tar.gz |
Merge commit '799f57ac96f9891d1a0f7d6c4b218ed536e8aca5'
* commit '799f57ac96f9891d1a0f7d6c4b218ed536e8aca5':
lavc: use AVFrame API properly in pad_last_frame().
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/utils.c | 24 |
1 files changed, 9 insertions, 15 deletions
diff --git a/libavcodec/utils.c b/libavcodec/utils.c index 15ef713217..88805024b0 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -1447,26 +1447,23 @@ int ff_alloc_packet(AVPacket *avpkt, int size) static int pad_last_frame(AVCodecContext *s, AVFrame **dst, const AVFrame *src) { AVFrame *frame = NULL; - uint8_t *buf = NULL; int ret; if (!(frame = avcodec_alloc_frame())) return AVERROR(ENOMEM); - *frame = *src; - if ((ret = av_samples_get_buffer_size(&frame->linesize[0], s->channels, - s->frame_size, s->sample_fmt, 0)) < 0) + frame->format = src->format; + frame->channel_layout = src->channel_layout; + av_frame_set_channels(frame, av_frame_get_channels(src)); + frame->nb_samples = s->frame_size; + ret = av_frame_get_buffer(frame, 32); + if (ret < 0) goto fail; - if (!(buf = av_malloc(ret))) { - ret = AVERROR(ENOMEM); + ret = av_frame_copy_props(frame, src); + if (ret < 0) goto fail; - } - frame->nb_samples = s->frame_size; - if ((ret = avcodec_fill_audio_frame(frame, s->channels, s->sample_fmt, - buf, ret, 0)) < 0) - goto fail; if ((ret = av_samples_copy(frame->extended_data, src->extended_data, 0, 0, src->nb_samples, s->channels, s->sample_fmt)) < 0) goto fail; @@ -1480,10 +1477,7 @@ static int pad_last_frame(AVCodecContext *s, AVFrame **dst, const AVFrame *src) return 0; fail: - if (frame->extended_data != frame->data) - av_freep(&frame->extended_data); - av_freep(&buf); - av_freep(&frame); + av_frame_free(&frame); return ret; } |