diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2012-12-23 17:53:06 -0500 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2013-02-12 12:21:22 -0500 |
commit | 036e9b045f14233fd39781d9afe4b7fb54151fba (patch) | |
tree | ba383585cd0b2b20abc13533e5fccdbb2be77fe8 /libavcodec | |
parent | b8e9c99ef19c21d20962e90237697722cbc96ff8 (diff) | |
download | ffmpeg-036e9b045f14233fd39781d9afe4b7fb54151fba.tar.gz |
g722: decode directly to the user-provided AVFrame
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/g722.h | 1 | ||||
-rw-r--r-- | libavcodec/g722dec.c | 13 |
2 files changed, 5 insertions, 9 deletions
diff --git a/libavcodec/g722.h b/libavcodec/g722.h index bab1da48cc..71d03fc5fa 100644 --- a/libavcodec/g722.h +++ b/libavcodec/g722.h @@ -32,7 +32,6 @@ typedef struct G722Context { const AVClass *class; - AVFrame frame; int bits_per_codeword; int16_t prev_samples[PREV_SAMPLES_BUF_SIZE]; ///< memory of past decoded samples int prev_samples_pos; ///< the number of values in prev_samples diff --git a/libavcodec/g722dec.c b/libavcodec/g722dec.c index 51d5721e8f..c100a90d34 100644 --- a/libavcodec/g722dec.c +++ b/libavcodec/g722dec.c @@ -67,9 +67,6 @@ static av_cold int g722_decode_init(AVCodecContext * avctx) c->band[1].scale_factor = 2; c->prev_samples_pos = 22; - avcodec_get_frame_defaults(&c->frame); - avctx->coded_frame = &c->frame; - return 0; } @@ -88,6 +85,7 @@ static int g722_decode_frame(AVCodecContext *avctx, void *data, int *got_frame_ptr, AVPacket *avpkt) { G722Context *c = avctx->priv_data; + AVFrame *frame = data; int16_t *out_buf; int j, ret; const int skip = 8 - c->bits_per_codeword; @@ -95,12 +93,12 @@ static int g722_decode_frame(AVCodecContext *avctx, void *data, GetBitContext gb; /* get output buffer */ - c->frame.nb_samples = avpkt->size * 2; - if ((ret = ff_get_buffer(avctx, &c->frame)) < 0) { + frame->nb_samples = avpkt->size * 2; + if ((ret = ff_get_buffer(avctx, frame)) < 0) { av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); return ret; } - out_buf = (int16_t *)c->frame.data[0]; + out_buf = (int16_t *)frame->data[0]; init_get_bits(&gb, avpkt->data, avpkt->size * 8); @@ -135,8 +133,7 @@ static int g722_decode_frame(AVCodecContext *avctx, void *data, } } - *got_frame_ptr = 1; - *(AVFrame *)data = c->frame; + *got_frame_ptr = 1; return avpkt->size; } |