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