diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2011-12-03 02:43:58 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2011-12-03 03:00:49 +0100 |
commit | eac5987c4f662ab272f6788b5edc233a9525f844 (patch) | |
tree | 019e20a9f26c1df48af0cc0c3c9f984cf7396756 | |
parent | 7db5ff79966a7c278a121f502f1f4bbdea1c7c16 (diff) | |
download | ffmpeg-eac5987c4f662ab272f6788b5edc233a9525f844.tar.gz |
g723_1dec: update to new API
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | libavcodec/g723_1.c | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/libavcodec/g723_1.c b/libavcodec/g723_1.c index e1dc431d0e..bb9856d2ee 100644 --- a/libavcodec/g723_1.c +++ b/libavcodec/g723_1.c @@ -36,6 +36,7 @@ #include "g723_1_data.h" typedef struct g723_1_context { + AVFrame frame; G723_1_Subframe subframe[4]; FrameType cur_frame_type; FrameType past_frame_type; @@ -80,6 +81,9 @@ static av_cold int g723_1_decode_init(AVCodecContext *avctx) p->pf_gain = 1 << 12; memcpy(p->prev_lsp, dc_lsp, LPC_ORDER * sizeof(int16_t)); + avcodec_get_frame_defaults(&p->frame); + avctx->coded_frame = &p->frame; + return 0; } @@ -950,12 +954,12 @@ static void formant_postfilter(G723_1_Context *p, int16_t *lpc, int16_t *buf) } static int g723_1_decode_frame(AVCodecContext *avctx, void *data, - int *data_size, AVPacket *avpkt) + int *got_frame_ptr, AVPacket *avpkt) { G723_1_Context *p = avctx->priv_data; const uint8_t *buf = avpkt->data; int buf_size = avpkt->size; - int16_t *out = data; + int16_t *out; int dec_mode = buf[0] & 3; PPFParam ppf[SUBFRAMES]; @@ -963,10 +967,10 @@ static int g723_1_decode_frame(AVCodecContext *avctx, void *data, int16_t lpc[SUBFRAMES * LPC_ORDER]; int16_t acb_vector[SUBFRAME_LEN]; int16_t *vector_ptr; - int bad_frame = 0, i, j; + int bad_frame = 0, i, j, ret; if (!buf_size || buf_size < frame_size[dec_mode]) { - *data_size = 0; + *got_frame_ptr = 0; return buf_size; } @@ -976,7 +980,14 @@ static int g723_1_decode_frame(AVCodecContext *avctx, void *data, ActiveFrame : UntransmittedFrame; } - *data_size = FRAME_LEN * sizeof(int16_t); + p->frame.nb_samples = FRAME_LEN + LPC_ORDER; + if ((ret = avctx->get_buffer(avctx, &p->frame)) < 0) { + av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); + return ret; + } + out= p->frame.data[0]; + + if(p->cur_frame_type == ActiveFrame) { if (!bad_frame) { p->erased_frames = 0; @@ -1051,7 +1062,7 @@ static int g723_1_decode_frame(AVCodecContext *avctx, void *data, memcpy(p->prev_excitation, p->excitation + FRAME_LEN, PITCH_MAX * sizeof(int16_t)); } else { - memset(out, 0, *data_size); + memset(out, 0, sizeof(int16_t)*FRAME_LEN); av_log(avctx, AV_LOG_WARNING, "G.723.1: Comfort noise generation not supported yet\n"); return frame_size[dec_mode]; @@ -1068,7 +1079,10 @@ static int g723_1_decode_frame(AVCodecContext *avctx, void *data, formant_postfilter(p, lpc, out); - memmove(out, out + LPC_ORDER, *data_size); + memmove(out, out + LPC_ORDER, sizeof(int16_t)*FRAME_LEN); + p->frame.nb_samples = FRAME_LEN; + *(AVFrame*)data = p->frame; + *got_frame_ptr = 1; return frame_size[dec_mode]; } |