Mercurial > libavcodec.hg
changeset 5385:bc14cca988aa libavcodec
don't need to synchronize in the decoder. the parser does that already.
author | jbr |
---|---|
date | Sat, 21 Jul 2007 13:56:04 +0000 |
parents | 3721d0042e5a |
children | d6347c3cb329 |
files | ac3dec.c |
diffstat | 1 files changed, 1 insertions(+), 28 deletions(-) [+] |
line wrap: on
line diff
--- a/ac3dec.c Sat Jul 21 11:54:19 2007 +0000 +++ b/ac3dec.c Sat Jul 21 13:56:04 2007 +0000 @@ -320,24 +320,6 @@ } /*********** END INIT FUNCTIONS ***********/ -/* Synchronize to ac3 bitstream. - * This function searches for the syncword '0xb77'. - * - * @param buf Pointer to "probable" ac3 bitstream buffer - * @param buf_size Size of buffer - * @return Returns the position where syncword is found, -1 if no syncword is found - */ -static int ac3_synchronize(uint8_t *buf, int buf_size) -{ - int i; - - for (i = 0; i < buf_size - 1; i++) - if (buf[i] == 0x0b && buf[i + 1] == 0x77) - return i; - - return -1; -} - /* Parse the 'sync_info' from the ac3 bitstream. * This function extracts the sync_info from ac3 bitstream. * GetBitContext within AC3DecodeContext must point to @@ -1645,7 +1627,6 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size, uint8_t *buf, int buf_size) { AC3DecodeContext *ctx = (AC3DecodeContext *)avctx->priv_data; - int frame_start; int16_t *out_samples = (int16_t *)data; int i, j, k, start; int32_t *int_ptr[6]; @@ -1653,16 +1634,8 @@ for (i = 0; i < 6; i++) int_ptr[i] = (int32_t *)(&ctx->output[i]); - //Synchronize the frame. - frame_start = ac3_synchronize(buf, buf_size); - if (frame_start == -1) { - av_log(avctx, AV_LOG_ERROR, "frame is not synchronized\n"); - *data_size = 0; - return buf_size; - } - //Initialize the GetBitContext with the start of valid AC3 Frame. - init_get_bits(&(ctx->gb), buf + frame_start, (buf_size - frame_start) * 8); + init_get_bits(&ctx->gb, buf, buf_size * 8); //Parse the syncinfo. //If 'fscod' or 'bsid' is not valid the decoder shall mute as per the standard.