diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2012-12-23 20:11:36 -0500 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2013-02-12 12:22:39 -0500 |
commit | ee6ca11b657515ad736ec0d2b8635e098d0a2680 (patch) | |
tree | 6e8f840c7ec840092743210585db0d378725789b | |
parent | f80f8dd4c25a1762a24c9f28dc3f07aad1ff3594 (diff) | |
download | ffmpeg-ee6ca11b657515ad736ec0d2b8635e098d0a2680.tar.gz |
vorbis: decode directly to the user-provided AVFrame
-rw-r--r-- | libavcodec/vorbisdec.c | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/libavcodec/vorbisdec.c b/libavcodec/vorbisdec.c index 791314e9fc..158bd6f57c 100644 --- a/libavcodec/vorbisdec.c +++ b/libavcodec/vorbisdec.c @@ -123,7 +123,6 @@ typedef struct { typedef struct vorbis_context_s { AVCodecContext *avccontext; - AVFrame frame; GetBitContext gb; VorbisDSPContext dsp; AVFloatDSPContext fdsp; @@ -1030,9 +1029,6 @@ static av_cold int vorbis_decode_init(AVCodecContext *avccontext) avccontext->channels = vc->audio_channels; avccontext->sample_rate = vc->audio_samplerate; - avcodec_get_frame_defaults(&vc->frame); - avccontext->coded_frame = &vc->frame; - return 0; } @@ -1643,6 +1639,7 @@ static int vorbis_decode_frame(AVCodecContext *avccontext, void *data, const uint8_t *buf = avpkt->data; int buf_size = avpkt->size; vorbis_context *vc = avccontext->priv_data; + AVFrame *frame = data; GetBitContext *gb = &vc->gb; float *channel_ptrs[255]; int i, len, ret; @@ -1650,19 +1647,19 @@ static int vorbis_decode_frame(AVCodecContext *avccontext, void *data, av_dlog(NULL, "packet length %d \n", buf_size); /* get output buffer */ - vc->frame.nb_samples = vc->blocksize[1] / 2; - if ((ret = ff_get_buffer(avccontext, &vc->frame)) < 0) { + frame->nb_samples = vc->blocksize[1] / 2; + if ((ret = ff_get_buffer(avccontext, frame)) < 0) { av_log(avccontext, AV_LOG_ERROR, "get_buffer() failed\n"); return ret; } if (vc->audio_channels > 8) { for (i = 0; i < vc->audio_channels; i++) - channel_ptrs[i] = (float *)vc->frame.extended_data[i]; + channel_ptrs[i] = (float *)frame->extended_data[i]; } else { for (i = 0; i < vc->audio_channels; i++) { int ch = ff_vorbis_channel_layout_offsets[vc->audio_channels - 1][i]; - channel_ptrs[ch] = (float *)vc->frame.extended_data[i]; + channel_ptrs[ch] = (float *)frame->extended_data[i]; } } @@ -1680,9 +1677,8 @@ static int vorbis_decode_frame(AVCodecContext *avccontext, void *data, av_dlog(NULL, "parsed %d bytes %d bits, returned %d samples (*ch*bits) \n", get_bits_count(gb) / 8, get_bits_count(gb) % 8, len); - vc->frame.nb_samples = len; - *got_frame_ptr = 1; - *(AVFrame *)data = vc->frame; + frame->nb_samples = len; + *got_frame_ptr = 1; return buf_size; } |