diff options
author | Vitor Sessak <vitor1001@gmail.com> | 2008-06-30 19:30:27 +0000 |
---|---|---|
committer | Vitor Sessak <vitor1001@gmail.com> | 2008-06-30 19:30:27 +0000 |
commit | f38deb4452e89e397e6b6aeef9dda31c279857fd (patch) | |
tree | 05360f5a5b7e826ca8a1bf82f465e8fd1d9a6538 /libavcodec/ra288.c | |
parent | 6091357fc038553ecb836b58b2699470a0018074 (diff) | |
download | ffmpeg-f38deb4452e89e397e6b6aeef9dda31c279857fd.tar.gz |
Remove useless wrapper around ra288_decode_frame()
Originally committed as revision 14041 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/ra288.c')
-rw-r--r-- | libavcodec/ra288.c | 38 |
1 files changed, 14 insertions, 24 deletions
diff --git a/libavcodec/ra288.c b/libavcodec/ra288.c index 5e6a1aeba3..6c0d7815c8 100644 --- a/libavcodec/ra288.c +++ b/libavcodec/ra288.c @@ -205,14 +205,24 @@ static void update(Real288_internal *glob) colmult(glob->pr2, glob->st2, table2a, 10); } -static void * decode_block(AVCodecContext * avctx, const unsigned char *in, - signed short int *out, unsigned len) +/* Decode a block (celp) */ +static int ra288_decode_frame(AVCodecContext * avctx, void *data, + int *data_size, const uint8_t * buf, + int buf_size) { + int16_t *out = data; int x, y; Real288_internal *glob = avctx->priv_data; GetBitContext gb; - init_get_bits(&gb, in, len * 8); + if (buf_size < avctx->block_align) { + av_log(avctx, AV_LOG_ERROR, + "Error! Input buffer is too small [%d<%d]\n", + buf_size, avctx->block_align); + return 0; + } + + init_get_bits(&gb, buf, avctx->block_align * 8); for (x=0; x < 32; x++) { int amp_coef = get_bits(&gb, 3); @@ -226,27 +236,7 @@ static void * decode_block(AVCodecContext * avctx, const unsigned char *in, update(glob); } - return out; -} - -/* Decode a block (celp) */ -static int ra288_decode_frame(AVCodecContext * avctx, void *data, - int *data_size, const uint8_t * buf, - int buf_size) -{ - void *datao; - - if (buf_size < avctx->block_align) { - av_log(avctx, AV_LOG_ERROR, - "Error! Input buffer is too small [%d<%d]\n", - buf_size, avctx->block_align); - return 0; - } - - datao = data; - data = decode_block(avctx, buf, (signed short *)data, avctx->block_align); - - *data_size = (char *)data - (char *)datao; + *data_size = (char *)out - (char *)data; return avctx->block_align; } |