Mercurial > libavcodec.hg
comparison wmaprodec.c @ 10165:b30c708ce76a libavcodec
reinit get_bits for every decode_packet call
author | faust3 |
---|---|
date | Fri, 11 Sep 2009 15:59:27 +0000 |
parents | de9335d4b6b1 |
children | 89cd870ca180 |
comparison
equal
deleted
inserted
replaced
10164:944071b6fcb4 | 10165:b30c708ce76a |
---|---|
188 int8_t sf_offsets[WMAPRO_BLOCK_SIZES][WMAPRO_BLOCK_SIZES][MAX_BANDS]; ///< scale factor resample matrix | 188 int8_t sf_offsets[WMAPRO_BLOCK_SIZES][WMAPRO_BLOCK_SIZES][MAX_BANDS]; ///< scale factor resample matrix |
189 int16_t subwoofer_cutoffs[WMAPRO_BLOCK_SIZES]; ///< subwoofer cutoff values | 189 int16_t subwoofer_cutoffs[WMAPRO_BLOCK_SIZES]; ///< subwoofer cutoff values |
190 | 190 |
191 /* packet decode state */ | 191 /* packet decode state */ |
192 GetBitContext pgb; ///< bitstream reader context for the packet | 192 GetBitContext pgb; ///< bitstream reader context for the packet |
193 uint8_t packet_offset; ///< frame offset in the packet | |
193 uint8_t packet_sequence_number; ///< current packet number | 194 uint8_t packet_sequence_number; ///< current packet number |
194 int num_saved_bits; ///< saved number of bits | 195 int num_saved_bits; ///< saved number of bits |
195 int frame_offset; ///< frame offset in the bit reservoir | 196 int frame_offset; ///< frame offset in the bit reservoir |
196 int subframe_offset; ///< subframe offset in the bit reservoir | 197 int subframe_offset; ///< subframe offset in the bit reservoir |
197 uint8_t packet_loss; ///< set in case of bitstream error | 198 uint8_t packet_loss; ///< set in case of bitstream error |
1500 | 1501 |
1501 s->packet_loss = 0; | 1502 s->packet_loss = 0; |
1502 | 1503 |
1503 } else { | 1504 } else { |
1504 int frame_size; | 1505 int frame_size; |
1506 s->buf_bit_size = avpkt->size << 3; | |
1507 init_get_bits(gb, avpkt->data, s->buf_bit_size); | |
1508 skip_bits(gb, s->packet_offset); | |
1505 if (remaining_bits(s, gb) > s->log2_frame_size && | 1509 if (remaining_bits(s, gb) > s->log2_frame_size && |
1506 (frame_size = show_bits(gb, s->log2_frame_size)) && | 1510 (frame_size = show_bits(gb, s->log2_frame_size)) && |
1507 frame_size <= remaining_bits(s, gb)) { | 1511 frame_size <= remaining_bits(s, gb)) { |
1508 save_bits(s, gb, frame_size, 0); | 1512 save_bits(s, gb, frame_size, 0); |
1509 s->packet_done = !decode_frame(s); | 1513 s->packet_done = !decode_frame(s); |
1517 with the next packet */ | 1521 with the next packet */ |
1518 save_bits(s, gb, remaining_bits(s, gb), 0); | 1522 save_bits(s, gb, remaining_bits(s, gb), 0); |
1519 } | 1523 } |
1520 | 1524 |
1521 *data_size = (int8_t *)s->samples - (int8_t *)data; | 1525 *data_size = (int8_t *)s->samples - (int8_t *)data; |
1522 | 1526 s->packet_offset = get_bits_count(gb) & 7; |
1523 return (!s->packet_done && !s->packet_loss)?0: avctx->block_align; | 1527 |
1528 return get_bits_count(gb) >> 3; | |
1524 } | 1529 } |
1525 | 1530 |
1526 /** | 1531 /** |
1527 *@brief Clear decoder buffers (for seeking). | 1532 *@brief Clear decoder buffers (for seeking). |
1528 *@param avctx codec context | 1533 *@param avctx codec context |