| @@ -33,9 +33,9 @@ | |||||
| #define BITSTREAM_READER_LE | #define BITSTREAM_READER_LE | ||||
| #include "avcodec.h" | #include "avcodec.h" | ||||
| #include "get_bits.h" | |||||
| #include "bitstream.h" | |||||
| #include "internal.h" | #include "internal.h" | ||||
| #include "unary_legacy.h" | |||||
| #include "unary.h" | |||||
| #define FORMAT_SIMPLE 1 | #define FORMAT_SIMPLE 1 | ||||
| #define FORMAT_ENCRYPTED 2 | #define FORMAT_ENCRYPTED 2 | ||||
| @@ -60,7 +60,7 @@ typedef struct TTAChannel { | |||||
| typedef struct TTAContext { | typedef struct TTAContext { | ||||
| AVCodecContext *avctx; | AVCodecContext *avctx; | ||||
| GetBitContext gb; | |||||
| BitstreamContext bc; | |||||
| const AVCRC *crc_table; | const AVCRC *crc_table; | ||||
| int format, channels, bps; | int format, channels, bps; | ||||
| @@ -197,18 +197,17 @@ static av_cold int tta_decode_init(AVCodecContext * avctx) | |||||
| if (avctx->extradata_size < 30) | if (avctx->extradata_size < 30) | ||||
| return -1; | return -1; | ||||
| init_get_bits(&s->gb, avctx->extradata, avctx->extradata_size * 8); | |||||
| if (show_bits_long(&s->gb, 32) == AV_RL32("TTA1")) | |||||
| { | |||||
| bitstream_init(&s->bc, avctx->extradata, avctx->extradata_size * 8); | |||||
| if (bitstream_peek(&s->bc, 32) == AV_RL32("TTA1")) { | |||||
| if (avctx->err_recognition & AV_EF_CRCCHECK) { | if (avctx->err_recognition & AV_EF_CRCCHECK) { | ||||
| s->crc_table = av_crc_get_table(AV_CRC_32_IEEE_LE); | s->crc_table = av_crc_get_table(AV_CRC_32_IEEE_LE); | ||||
| tta_check_crc(s, avctx->extradata, 18); | tta_check_crc(s, avctx->extradata, 18); | ||||
| } | } | ||||
| /* signature */ | /* signature */ | ||||
| skip_bits_long(&s->gb, 32); | |||||
| bitstream_skip(&s->bc, 32); | |||||
| s->format = get_bits(&s->gb, 16); | |||||
| s->format = bitstream_read(&s->bc, 16); | |||||
| if (s->format > 2) { | if (s->format > 2) { | ||||
| av_log(s->avctx, AV_LOG_ERROR, "Invalid format\n"); | av_log(s->avctx, AV_LOG_ERROR, "Invalid format\n"); | ||||
| return -1; | return -1; | ||||
| @@ -217,12 +216,13 @@ static av_cold int tta_decode_init(AVCodecContext * avctx) | |||||
| avpriv_report_missing_feature(s->avctx, "Encrypted TTA"); | avpriv_report_missing_feature(s->avctx, "Encrypted TTA"); | ||||
| return AVERROR_PATCHWELCOME; | return AVERROR_PATCHWELCOME; | ||||
| } | } | ||||
| avctx->channels = s->channels = get_bits(&s->gb, 16); | |||||
| avctx->bits_per_coded_sample = get_bits(&s->gb, 16); | |||||
| avctx->channels = | |||||
| s->channels = bitstream_read(&s->bc, 16); | |||||
| avctx->bits_per_coded_sample = bitstream_read(&s->bc, 16); | |||||
| s->bps = (avctx->bits_per_coded_sample + 7) / 8; | s->bps = (avctx->bits_per_coded_sample + 7) / 8; | ||||
| avctx->sample_rate = get_bits_long(&s->gb, 32); | |||||
| s->data_length = get_bits_long(&s->gb, 32); | |||||
| skip_bits_long(&s->gb, 32); // CRC32 of header | |||||
| avctx->sample_rate = bitstream_read(&s->bc, 32); | |||||
| s->data_length = bitstream_read(&s->bc, 32); | |||||
| bitstream_skip(&s->bc, 32); // CRC32 of header | |||||
| if (s->channels == 0) { | if (s->channels == 0) { | ||||
| av_log(s->avctx, AV_LOG_ERROR, "Invalid number of channels\n"); | av_log(s->avctx, AV_LOG_ERROR, "Invalid number of channels\n"); | ||||
| @@ -272,8 +272,8 @@ static av_cold int tta_decode_init(AVCodecContext * avctx) | |||||
| if (ret < 0 && avctx->err_recognition & AV_EF_EXPLODE) | if (ret < 0 && avctx->err_recognition & AV_EF_EXPLODE) | ||||
| return AVERROR_INVALIDDATA; | return AVERROR_INVALIDDATA; | ||||
| } | } | ||||
| skip_bits_long(&s->gb, 32 * total_frames); | |||||
| skip_bits_long(&s->gb, 32); // CRC32 of seektable | |||||
| bitstream_skip(&s->bc, 32 * total_frames); | |||||
| bitstream_skip(&s->bc, 32); // CRC32 of seektable | |||||
| if(s->frame_length >= UINT_MAX / (s->channels * sizeof(int32_t))){ | if(s->frame_length >= UINT_MAX / (s->channels * sizeof(int32_t))){ | ||||
| av_log(avctx, AV_LOG_ERROR, "frame_length too large\n"); | av_log(avctx, AV_LOG_ERROR, "frame_length too large\n"); | ||||
| @@ -315,7 +315,7 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data, | |||||
| return AVERROR_INVALIDDATA; | return AVERROR_INVALIDDATA; | ||||
| } | } | ||||
| init_get_bits(&s->gb, buf, buf_size*8); | |||||
| bitstream_init(&s->bc, buf, buf_size * 8); | |||||
| /* get output buffer */ | /* get output buffer */ | ||||
| frame->nb_samples = framelen; | frame->nb_samples = framelen; | ||||
| @@ -343,7 +343,7 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data, | |||||
| uint32_t unary, depth, k; | uint32_t unary, depth, k; | ||||
| int32_t value; | int32_t value; | ||||
| unary = get_unary(&s->gb, 0, get_bits_left(&s->gb)); | |||||
| unary = get_unary(&s->bc, 0, bitstream_bits_left(&s->bc)); | |||||
| if (unary == 0) { | if (unary == 0) { | ||||
| depth = 0; | depth = 0; | ||||
| @@ -354,7 +354,7 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data, | |||||
| unary--; | unary--; | ||||
| } | } | ||||
| if (get_bits_left(&s->gb) < k) { | |||||
| if (bitstream_bits_left(&s->bc) < k) { | |||||
| ret = AVERROR_INVALIDDATA; | ret = AVERROR_INVALIDDATA; | ||||
| goto error; | goto error; | ||||
| } | } | ||||
| @@ -364,7 +364,7 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data, | |||||
| ret = AVERROR_INVALIDDATA; | ret = AVERROR_INVALIDDATA; | ||||
| goto error; | goto error; | ||||
| } | } | ||||
| value = (unary << k) + get_bits(&s->gb, k); | |||||
| value = (unary << k) + bitstream_read(&s->bc, k); | |||||
| } else | } else | ||||
| value = unary; | value = unary; | ||||
| @@ -414,19 +414,19 @@ static int tta_decode_frame(AVCodecContext *avctx, void *data, | |||||
| cur_chan = 0; | cur_chan = 0; | ||||
| i++; | i++; | ||||
| // check for last frame | // check for last frame | ||||
| if (i == s->last_frame_length && get_bits_left(&s->gb) / 8 == 4) { | |||||
| if (i == s->last_frame_length && bitstream_bits_left(&s->bc) / 8 == 4) { | |||||
| frame->nb_samples = framelen = s->last_frame_length; | frame->nb_samples = framelen = s->last_frame_length; | ||||
| break; | break; | ||||
| } | } | ||||
| } | } | ||||
| } | } | ||||
| align_get_bits(&s->gb); | |||||
| if (get_bits_left(&s->gb) < 32) { | |||||
| bitstream_align(&s->bc); | |||||
| if (bitstream_bits_left(&s->bc) < 32) { | |||||
| ret = AVERROR_INVALIDDATA; | ret = AVERROR_INVALIDDATA; | ||||
| goto error; | goto error; | ||||
| } | } | ||||
| skip_bits_long(&s->gb, 32); // frame crc | |||||
| bitstream_skip(&s->bc, 32); // frame CRC | |||||
| // convert to output buffer | // convert to output buffer | ||||
| if (s->bps == 2) { | if (s->bps == 2) { | ||||