Commit 7281c9fd authored by rtognimp's avatar rtognimp

Dual mono stereo strems sound ok now, added sanity checks and removed

some unused variables and redundant memsets.
Patch by Benjamin Larsson


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4816 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent b2533a47
...@@ -113,10 +113,11 @@ typedef struct { ...@@ -113,10 +113,11 @@ typedef struct {
/* gain buffers */ /* gain buffers */
COOKgain* gain_now_ptr; COOKgain* gain_now_ptr;
COOKgain* gain_previous_ptr; COOKgain* gain_previous_ptr;
COOKgain gain_copy;
COOKgain gain_current; COOKgain gain_current;
COOKgain gain_now; COOKgain gain_now;
COOKgain gain_previous; COOKgain gain_previous;
COOKgain gain_channel1[2];
COOKgain gain_channel2[2];
/* VLC data */ /* VLC data */
int js_vlc_bits; int js_vlc_bits;
...@@ -138,6 +139,7 @@ typedef struct { ...@@ -138,6 +139,7 @@ typedef struct {
float mono_previous_buffer1[1024]; float mono_previous_buffer1[1024];
float mono_previous_buffer2[1024]; float mono_previous_buffer2[1024];
float* decode_buf_ptr[4]; float* decode_buf_ptr[4];
float* decode_buf_ptr2[2];
float decode_buffer_1[1024]; float decode_buffer_1[1024];
float decode_buffer_2[1024]; float decode_buffer_2[1024];
float decode_buffer_3[1024]; float decode_buffer_3[1024];
...@@ -206,10 +208,6 @@ static void init_gain_table(COOKContext *q) { ...@@ -206,10 +208,6 @@ static void init_gain_table(COOKContext *q) {
q->gain_table[i] = pow((double)q->pow2tab[i+52] , q->gain_table[i] = pow((double)q->pow2tab[i+52] ,
(1.0/(double)q->gain_size_factor)); (1.0/(double)q->gain_size_factor));
} }
memset(&q->gain_copy, 0, sizeof(COOKgain));
memset(&q->gain_current, 0, sizeof(COOKgain));
memset(&q->gain_now, 0, sizeof(COOKgain));
memset(&q->gain_previous, 0, sizeof(COOKgain));
} }
...@@ -975,7 +973,6 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer, ...@@ -975,7 +973,6 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer,
decode_bytes(inbuffer, q->decoded_bytes_buffer, sub_packet_size); decode_bytes(inbuffer, q->decoded_bytes_buffer, sub_packet_size);
init_get_bits(&q->gb, q->decoded_bytes_buffer, sub_packet_size*8); init_get_bits(&q->gb, q->decoded_bytes_buffer, sub_packet_size*8);
decode_gain_info(&q->gb, &q->gain_current); decode_gain_info(&q->gb, &q->gain_current);
memcpy(&q->gain_copy, &q->gain_current ,sizeof(COOKgain)); //This copy does not seem to be used. FIXME
if(q->nb_channels==2 && q->joint_stereo==1){ if(q->nb_channels==2 && q->joint_stereo==1){
joint_decode(q, q->decode_buf_ptr[0], q->decode_buf_ptr[2]); joint_decode(q, q->decode_buf_ptr[0], q->decode_buf_ptr[2]);
...@@ -1017,24 +1014,22 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer, ...@@ -1017,24 +1014,22 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer,
} else if (q->nb_channels==2 && q->joint_stereo==0) { } else if (q->nb_channels==2 && q->joint_stereo==0) {
/* channel 0 */ /* channel 0 */
mono_decode(q, q->decode_buf_ptr[0]); mono_decode(q, q->decode_buf_ptr2[0]);
tmp_ptr = q->decode_buf_ptr[0]; tmp_ptr = q->decode_buf_ptr2[0];
q->decode_buf_ptr[0] = q->decode_buf_ptr[1]; q->decode_buf_ptr2[0] = q->decode_buf_ptr2[1];
q->decode_buf_ptr[1] = q->decode_buf_ptr[2]; q->decode_buf_ptr2[1] = tmp_ptr;
q->decode_buf_ptr[2] = q->decode_buf_ptr[3];
q->decode_buf_ptr[3] = tmp_ptr;
q->gain_now_ptr = &q->gain_now; memcpy(&q->gain_channel1[0], &q->gain_current ,sizeof(COOKgain));
q->gain_previous_ptr = &q->gain_previous; q->gain_now_ptr = &q->gain_channel1[0];
q->gain_previous_ptr = &q->gain_channel1[1];
cook_imlt(q, q->decode_buf_ptr[0], q->mono_mdct_output,q->mlt_tmp); cook_imlt(q, q->decode_buf_ptr2[0], q->mono_mdct_output,q->mlt_tmp);
gain_compensate(q, q->mono_mdct_output, q->gain_now_ptr, gain_compensate(q, q->mono_mdct_output, q->gain_now_ptr,
q->gain_previous_ptr, q->previous_buffer_ptr[0]); q->gain_previous_ptr, q->mono_previous_buffer1);
/* Swap out the previous buffer. */
tmp_ptr = q->previous_buffer_ptr[0]; memcpy(&q->gain_channel1[1], &q->gain_channel1[0],sizeof(COOKgain));
q->previous_buffer_ptr[0] = q->previous_buffer_ptr[1];
q->previous_buffer_ptr[1] = tmp_ptr;
for (j=0 ; j<q->samples_per_frame ; j++){ for (j=0 ; j<q->samples_per_frame ; j++){
value = lrintf(q->mono_mdct_output[j]); value = lrintf(q->mono_mdct_output[j]);
...@@ -1046,25 +1041,28 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer, ...@@ -1046,25 +1041,28 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer,
/* channel 1 */ /* channel 1 */
//av_log(NULL,AV_LOG_ERROR,"bits = %d\n",get_bits_count(&q->gb)); //av_log(NULL,AV_LOG_ERROR,"bits = %d\n",get_bits_count(&q->gb));
init_get_bits(&q->gb, q->decoded_bytes_buffer, sub_packet_size*8+q->bits_per_subpacket); init_get_bits(&q->gb, q->decoded_bytes_buffer, sub_packet_size*8+q->bits_per_subpacket);
decode_gain_info(&q->gb, &q->gain_current);
//memcpy(&q->gain_copy, &q->gain_current ,sizeof(COOKgain)); q->gain_now_ptr = &q->gain_channel2[0];
q->gain_previous_ptr = &q->gain_channel2[1];
decode_gain_info(&q->gb, &q->gain_channel2[0]);
mono_decode(q, q->decode_buf_ptr[0]); mono_decode(q, q->decode_buf_ptr[0]);
tmp_ptr = q->decode_buf_ptr[0];
q->decode_buf_ptr[1] = q->decode_buf_ptr[2];
q->decode_buf_ptr[2] = q->decode_buf_ptr[3];
q->decode_buf_ptr[3] = tmp_ptr;
q->gain_now_ptr = &q->gain_now; tmp_ptr = q->decode_buf_ptr[0];
q->gain_previous_ptr = &q->gain_previous; q->decode_buf_ptr[0] = q->decode_buf_ptr[1];
q->decode_buf_ptr[1] = tmp_ptr;
cook_imlt(q, q->decode_buf_ptr[0], q->mono_mdct_output,q->mlt_tmp); cook_imlt(q, q->decode_buf_ptr[0], q->mono_mdct_output,q->mlt_tmp);
gain_compensate(q, q->mono_mdct_output, q->gain_now_ptr, q->gain_previous_ptr, q->previous_buffer_ptr[0]); gain_compensate(q, q->mono_mdct_output, q->gain_now_ptr,
q->gain_previous_ptr, q->mono_previous_buffer2);
/* Swap out the previous buffer. */ /* Swap out the previous buffer. */
tmp_ptr = q->previous_buffer_ptr[0]; tmp_ptr = q->previous_buffer_ptr[0];
q->previous_buffer_ptr[0] = q->previous_buffer_ptr[1]; q->previous_buffer_ptr[0] = q->previous_buffer_ptr[1];
q->previous_buffer_ptr[1] = tmp_ptr; q->previous_buffer_ptr[1] = tmp_ptr;
memcpy(&q->gain_channel2[1], &q->gain_channel2[0] ,sizeof(COOKgain));
for (j=0 ; j<q->samples_per_frame ; j++){ for (j=0 ; j<q->samples_per_frame ; j++){
value = lrintf(q->mono_mdct_output[j]); value = lrintf(q->mono_mdct_output[j]);
if(value < -32768) value = -32768; if(value < -32768) value = -32768;
...@@ -1072,11 +1070,6 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer, ...@@ -1072,11 +1070,6 @@ static int decode_subpacket(COOKContext *q, uint8_t *inbuffer,
outbuffer[2*j] = value; outbuffer[2*j] = value;
} }
/* Swap out the previous buffer. */
memcpy(&q->gain_now, &q->gain_previous, sizeof(COOKgain));
memcpy(&q->gain_previous, &q->gain_current, sizeof(COOKgain));
} else { } else {
mono_decode(q, q->decode_buf_ptr[0]); mono_decode(q, q->decode_buf_ptr[0]);
...@@ -1214,9 +1207,7 @@ static int cook_decode_init(AVCodecContext *avctx) ...@@ -1214,9 +1207,7 @@ static int cook_decode_init(AVCodecContext *avctx)
case MONO_COOK2: case MONO_COOK2:
if (q->nb_channels != 1) { if (q->nb_channels != 1) {
q->joint_stereo = 0; q->joint_stereo = 0;
av_log(NULL,AV_LOG_ERROR,"Non-joint-stereo files are decoded with wrong gain at the moment!\n");
q->bits_per_subpacket = q->bits_per_subpacket/2; q->bits_per_subpacket = q->bits_per_subpacket/2;
} }
av_log(NULL,AV_LOG_DEBUG,"MONO_COOK2\n"); av_log(NULL,AV_LOG_DEBUG,"MONO_COOK2\n");
break; break;
...@@ -1271,17 +1262,30 @@ static int cook_decode_init(AVCodecContext *avctx) ...@@ -1271,17 +1262,30 @@ static int cook_decode_init(AVCodecContext *avctx)
q->decode_buf_ptr[2] = q->decode_buffer_3; q->decode_buf_ptr[2] = q->decode_buffer_3;
q->decode_buf_ptr[3] = q->decode_buffer_4; q->decode_buf_ptr[3] = q->decode_buffer_4;
q->decode_buf_ptr2[0] = q->decode_buffer_3;
q->decode_buf_ptr2[1] = q->decode_buffer_4;
q->previous_buffer_ptr[0] = q->mono_previous_buffer1; q->previous_buffer_ptr[0] = q->mono_previous_buffer1;
q->previous_buffer_ptr[1] = q->mono_previous_buffer2; q->previous_buffer_ptr[1] = q->mono_previous_buffer2;
memset(q->decode_buffer_1,0,1024*sizeof(float));
memset(q->decode_buffer_2,0,1024*sizeof(float));
memset(q->decode_buffer_3,0,1024*sizeof(float));
memset(q->decode_buffer_4,0,1024*sizeof(float));
/* Initialize transform. */ /* Initialize transform. */
if ( init_cook_mlt(q) == 0 ) if ( init_cook_mlt(q) == 0 )
return -1; return -1;
/* Try to catch some obviously faulty streams, othervise it might be exploitable */
if (q->total_subbands > 53) {
av_log(NULL,AV_LOG_ERROR,"total_subbands > 53, report sample!\n");
return -1;
}
if (((q->subbands > 34) || (q->js_subband_start > 19)) && (q->joint_stereo)) {
av_log(NULL,AV_LOG_ERROR,"subbands > 34 or js_subband_start > 19, report sample!\n");
return -1;
}
if (q->subbands > 50) {
av_log(NULL,AV_LOG_ERROR,"subbands > 50, report sample!\n");
return -1;
}
#ifdef COOKDEBUG #ifdef COOKDEBUG
dump_cook_context(q,e); dump_cook_context(q,e);
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment