diff options
author | Paul B Mahol <onemda@gmail.com> | 2013-02-13 12:06:40 +0000 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2013-02-13 12:33:48 +0000 |
commit | 9145818ecd511854fc7578eb62730d4eec81c8d5 (patch) | |
tree | 36318c922950f1117b71455143d58c6a06a9c962 /libavcodec | |
parent | 845fa2f5c9643a2f80b29614351609f1f1d3994d (diff) | |
download | ffmpeg-9145818ecd511854fc7578eb62730d4eec81c8d5.tar.gz |
vima: decode directly to the user-provided AVFrame
Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/vima.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/libavcodec/vima.c b/libavcodec/vima.c index 9019535083..604e0ce110 100644 --- a/libavcodec/vima.c +++ b/libavcodec/vima.c @@ -26,7 +26,6 @@ #include "adpcm_data.h" typedef struct { - AVFrame frame; uint16_t predict_table[5786 * 2]; } VimaContext; @@ -125,8 +124,6 @@ static av_cold int decode_init(AVCodecContext *avctx) } } - avcodec_get_frame_defaults(&vima->frame); - avctx->coded_frame = &vima->frame; avctx->sample_fmt = AV_SAMPLE_FMT_S16; return 0; @@ -137,6 +134,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, { GetBitContext gb; VimaContext *vima = avctx->priv_data; + AVFrame *frame = data; int16_t pcm_data[2]; uint32_t samples; int8_t channel_hint[2]; @@ -171,14 +169,14 @@ static int decode_frame(AVCodecContext *avctx, void *data, pcm_data[1] = get_sbits(&gb, 16); } - vima->frame.nb_samples = samples; - if ((ret = ff_get_buffer(avctx, &vima->frame)) < 0) { + frame->nb_samples = samples; + if ((ret = ff_get_buffer(avctx, frame)) < 0) { av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); return ret; } for (chan = 0; chan < channels; chan++) { - uint16_t *dest = (uint16_t*)vima->frame.data[0] + chan; + uint16_t *dest = (uint16_t*)frame->data[0] + chan; int step_index = channel_hint[chan]; int output = pcm_data[chan]; int sample; @@ -221,7 +219,6 @@ static int decode_frame(AVCodecContext *avctx, void *data, } *got_frame_ptr = 1; - *(AVFrame *)data = vima->frame; return pkt->size; } |