40 #define SAMPLES_PER_BAND 36
41 #define MPC_FRAME_SIZE (BANDS * SAMPLES_PER_BAND)
47 0, 512, 1024, 1536, 2052, 2564, 3076, 3588, 4100, 4612, 5124,
48 5636, 6164, 6676, 7224
58 static int vlc_initialized = 0;
63 static VLC_TYPE quant_tables[7224][2];
101 if(vlc_initialized)
return 0;
103 scfi_vlc.
table = scfi_table;
111 dscf_vlc.
table = dscf_table;
119 hdr_vlc.
table = hdr_table;
128 for(j = 0; j < 2; j++){
130 quant_vlc[i][j].
table_allocated = quant_offsets[i*2 + j + 1] - quant_offsets[i*2 + j];
161 for(i = 0; i < SAMPLES_PER_BAND/3; i++){
162 t =
get_vlc2(gb, quant_vlc[0][i1].table, 9, 2);
170 for(i = 0; i < SAMPLES_PER_BAND/2; i++){
171 t =
get_vlc2(gb, quant_vlc[1][i1].table, 9, 2);
176 case 3:
case 4:
case 5:
case 6:
case 7:
181 case 8:
case 9:
case 10:
case 11:
case 12:
182 case 13:
case 14:
case 15:
case 16:
case 17:
183 t = (1 << (idx - 2)) - 1;
197 return av_clip_uintp2(ref + t, 7);
201 int *got_frame_ptr,
AVPacket *avpkt)
203 const uint8_t *buf = avpkt->
data;
204 int buf_size = avpkt->
size;
212 int bits_used, bits_avail;
214 memset(bands, 0,
sizeof(*bands) * (c->
maxbands + 1));
228 c->
dsp.
bswap_buf((uint32_t*)bits, (
const uint32_t*)(buf + 4), (buf_size - 4) >> 2);
234 for(ch = 0; ch < 2; ch++){
238 else bands[i].
res[ch] = av_clip(bands[i-1].res[ch] + t, 0, 17);
241 if(bands[i].res[0] || bands[i].res[1]){
247 for(i = 0; i <= mb; i++)
248 for(ch = 0; ch < 2; ch++)
251 for(i = 0; i <= mb; i++){
252 for(ch = 0; ch < 2; ch++){
253 if(bands[i].res[ch]){
256 switch(bands[i].scfi[ch]){
278 memset(c->
Q, 0,
sizeof(c->
Q));
281 for(ch = 0; ch < 2; ch++)
289 bits_avail = (buf_size - 4) * 8;
290 if(!buf[1] && ((bits_avail < bits_used) || (bits_used + 32 <= bits_avail))){
291 av_log(
NULL,0,
"Error decoding frame: used %i of %i bits\n", bits_used, bits_avail);