請問一下,我目前用了一個DSP+5711的方案,以DSP為Matser,5711為slave模式,看了Design Guide內容的部分,依照參數下去,聲音都沒有輸出,附上我的程式碼檔案,能否告知是哪個環節出了問題,謝謝
Flora Wang:
你好:
1.你的原理图连接是否正确?可以对照我们的EVM板检查连接。
2.没有声音输出的时候,看一下电感前面是不是50%占空比的PWM波形,开关频率是不是384Khz。
3. 2.1的软件设置主要是0x05寄存器改成0x84或0x8C.
YJ zhang:
兄弟 你的问题解决了吗 我用的tas5508 也是没出声 可以讨论下吗Q273203365
david Lin1:
回复 Flora Wang:
我是依照你們EVB板的原理圖去製作的,我現在遇到的問題是2.1模式程式不知道修改什麼地方,我附件中的程序在2.0 BD模式是有聲音輸出的,如你所說,我是只要去修改0x05這邊就好了嗎?還是還有什麼地方也需要修改,煩請告知
YJ zhang:
回复 david Lin1:
我的5508在 2.0也是出声了 现在研究 怎么 分频 让左右声道各输出高低音 初涉音频 感觉好难
david Lin1:
回复 Flora Wang:
Hi Flora;
現在聲音都出來了,不過我有發現另一個問題,就是我在線路上預留的2.0與2.1的切換,可是目前我的軟件寫的是2.1模式,但是怎麼我的4個輸出接口都會有聲音輸出,另外下列是我的代碼,現在發現2.1模式狀態下,低音的效果都沒出來,是不是我哪邊有沒寫到或是寫錯,麻煩請幫我確認下
#include "define.h" #include "tas57xx.h" #include "i2c.h" #include "tim4.h" #include "vm20xx.h" #define I2cmWrite1Byte i2cm_wr #define I2cmRead1Bytei2cm_rd #define TAS57XX_GAIN_TBL_NO 31unsigned char const tas57xx_dgain_tbl[]={ 255,//0,dgain=-120.0 106+8, //1+8,dgain=-29.0 103+8, //2+8,dgain=-27.7 101+8, //3+8,dgain=-26.3 98+8,//4+8,dgain=-25.0 95+8,//5+8,dgain=-23.6 93+8,//6+8,dgain=-22.3 90+8,//7+8,dgain=-20.9 87+8,//8+8,dgain=-19.6 84+8,//9+8,dgain=-18.2 82+8,//10+8,dgain=-16.9 79+8,//11+8,dgain=-15.6 76+8,//12+8,dgain=-14.2 74+8,//13+8,dgain=-12.9 71+8,//14+8,dgain=-11.5 68+8,//15+8,dgain=-10.2 66+8,//16+8,dgain=-8.8 63+8,//17+8,dgain=-7.5 60+8,//18+8,dgain=-6.1 58+8,//19+8,dgain=+8.8 55+8,//20+8,dgain=-3.4 52+8,//21+8,dgain=-2.1 50+8,//22+8,dgain=-0.8 47+8,//23+8,dgain=0.6 44+8,//24+8,dgain=1.9 41+8,//25+8,dgain=3.3 39+8,//26+8,dgain=4.6 36+8,//27+8,dgain=6.0 33+8,//28+8,dgain=7.3 31+8,//29+8,dgain=8.7 28+8,//30+8,dgain=10.0 };unsigned char const sta57xx_BQ1a[]={ 0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 }; unsigned char const sta57xx_BQ1b[]={ 0x00,0x80,0x3E,0x83,0x0F,0x00,0xD8,0x83,0x00,0x7E,0xEB,0xB7,0x00,0xFF,0x27,0x7D,0x0F,0x80,0xD5,0xC5 }; //Type:eq;fc:60hz;Gain4db;BW:50hz //0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 //}; //Type:eq;fc:60hz;Gain4db;BW:50hz unsigned char const sta57xx_BQ1[][20]={ {0x00,0x7F,0xEF,0x61,0x0F,0x00,0xA2,0x1B,0x00,0x7F,0x6F,0x04,0x00,0xFF,0x5D,0xE5,0x0F,0x80,0xA1,0x9A}, //Type:eq;fc:30hz;Gain-2db;BW:30hz {0x00,0x81,0x3E,0xA0,0x0F,0x00,0xD7,0xC9,0x00,0x7D,0xEB,0x9A,0x00,0xFF,0x28,0x37,0x0F,0x80,0xD5,0xC5}, //Type:eq;fc:60hz;Gain12db ;BW:50hz {0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}, //Type:eq;fc:125hz ;Gain:-6db;BW:100hz {0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}, //Type:eq;fc:250hz ;Gain:-4db;BW:1500hz {0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}//Type:eq;fc:5000hz ;Gain:5db;BW:15000hz }; unsigned char const sta57xx_BQ1d[][20]={ {0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00}, {0x00,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00} }; unsigned char const sta57xx_bass[][20]={ {0x00,0x80,0x00,0x00,0x0F,0x03,0x54,0x5F,0x00,0x7C,0xB1,0x2C,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 0 db;BW:200hz {0x00,0x80,0x6D,0xA1,0x0F,0x03,0x54,0x5F,0x00,0x7C,0x43,0x8A,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 2 db;BW:200hz {0x00,0x80,0xF7,0xA6,0x0F,0x03,0x54,0x5F,0x00,0x7B,0xB9,0x85,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 4 db;BW:200hz {0x00,0x81,0xA5,0x68,0x0F,0x03,0x54,0x5F,0x00,0x7B,0x0B,0xC3,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 6 db;BW:200hz {0x00,0x82,0x80,0x27,0x0F,0x03,0x54,0x5F,0x00,0x7A,0x31,0x04,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 8 db;BW:200hz {0x00,0x83,0x93,0x89,0x0F,0x03,0x54,0x5F,0x00,0x79,0x1D,0xA2,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 10 db;BW:200hz {0x00,0x84,0xEE,0x3A,0x0F,0x03,0x54,0x5F,0x00,0x77,0xC2,0xF2,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 12 db;BW:200hz {0x00,0x86,0xA2,0xAE,0x0F,0x03,0x54,0x5F,0x00,0x76,0x0E,0x7D,0x00,0xFC,0xAB,0xA1,0x0F,0x83,0x4E,0xD4}, //Type:eq;fc:100hz;Gain 14 db;BW:200hz };#define DRC//turn on compressor #define EQ_ON //turn on eq//--------------------------------------------------------------------- // initialize sta339 //--------------------------------------------------------------------- #ifdef PAMP_TAS5711 void tas57xx_init(void) { unsigned long tmp;//becaue STM8 's long is 32bit, int is 16 bitsunsigned char i;//unsigned char *rdats;//time delay for BD mode,according to spec //--------------------------------------------------------------------- // 2.0 Both BD Mode //--------------------------------------------------------------------- //i2cm_wr(TAS57XX_ID,0x1b,0x00);//i2cm_wr32(TAS57XX_ID,0x20,0x00897772);//both bd mode // i2cm_wr32(TAS57XX_ID,0x25,0x01021345);//both bd mode // i2cm_wr(TAS57XX_ID,0x11,0xb8); //i2cm_wr(TAS57XX_ID,0x12,0x60); //i2cm_wr(TAS57XX_ID,0x13,0xa0); //i2cm_wr(TAS57XX_ID,0x14,0x48); //--------------------------------------------------------------------- // 2.1 BD Mode Output For David Add //---------------------------------------------------------------------i2cm_wr(TAS57XX_ID,0x1b,0x00);// Oscillator Trimi2cm_wr(TAS57XX_ID,0x03,0xa0);// System Control Register 1i2cm_wr(TAS57XX_ID,0x04,0x05);// Serial Data Interface Registeri2cm_wr(TAS57XX_ID,0x06,0x00);// Soft Mute Registeri2cm_wr(TAS57XX_ID,0x07,0x2a);// Master Volume Register (0xFF = Mute)i2cm_wr(TAS57XX_ID,0x08,0x30);// Channel 1 Volumei2cm_wr(TAS57XX_ID,0x09,0x30);// Channel 2 Volumei2cm_wr(TAS57XX_ID,0x0a,0x30);// SubChannel Volumei2cm_wr(TAS57XX_ID,0x0e,0x91);// Micro Registeri2cm_wr(TAS57XX_ID,0x10,0x02);// Modulation Limiti2cm_wr(TAS57XX_ID,0x19,0x30);// Shutdown Group Resisteri2cm_wr(TAS57XX_ID,0x1a,0x95);// Split Capacitor Charge Periodi2cm_wr(TAS57XX_ID,0x1c,0x02);// Back-end Error Registeri2cm_wr32(TAS57XX_ID,0x20,0x00897772); // 2.1 output modei2cm_wr32(TAS57XX_ID,0x21,0x00004203);i2cm_wr32(TAS57XX_ID,0x25,0x01013245); //PWM Output MUX Register, OUT_A=PWM1(L+),OUT_B=PWM3(R-),OUT_C=PWM2(SUB+),OUT_D=PWM4(SUB-)i2cm_wr(TAS57XX_ID,0x11,0xac);// Inter-Channel Delay Channel 1i2cm_wr(TAS57XX_ID,0x12,0x54);// Inter-Channel Delay Channel 2i2cm_wr(TAS57XX_ID,0x13,0xac);// Inter-Channel Delay Channel 3i2cm_wr(TAS57XX_ID,0x14,0x54);// Inter-Channel Delay Channel 4i2cm_wr(TAS57XX_ID,0x17,0x00);// Offset Register (Absolute Delay)i2cm_wr(TAS57XX_ID,0x05,0x84);// System Control Register 2 (active)//woofer//i2cm_wr_eq(TAS57XX_ID,0x29, (unsigned long *)sta57xx_s_lpf1);#ifdef DRC#ifdef DRC// //------------------------------------------------------// i2cm_wr64(TAS57XX_ID,0x3a,0x000006d3,0x007FF92c);//energe filter=100ms// i2cm_wr64(TAS57XX_ID,0x3b,0x00000DA6,0x007FF259);//attack filter=50ms// i2cm_wr64(TAS57XX_ID,0x3c,0x0000015D,0x007FFEA2);//decay filter=500ms// i2cm_wr32(TAS57XX_ID,0x40,0xFC98537A);//thresh hold=-17db// i2cm_wr32(TAS57XX_ID,0x41,0x0FAAAAAB);//ratio=3// i2cm_wr32(TAS57XX_ID,0x42,0x00107A1C);//offset(makeup gain)=6// i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc////------------------------------------------------------//i2cm_wr64(TAS57XX_ID,0x3a,0x0000883f,0x007F77c0);//energe filter=5ms//i2cm_wr64(TAS57XX_ID,0x3b,0x00004432,0x007Fbbcd);//attack filter=10ms//i2cm_wr64(TAS57XX_ID,0x3c,0x000006d3,0x007FF92c);//decay filter=100ms//i2cm_wr32(TAS57XX_ID,0x40,0xFC98537A);//thresh hold=-17db//i2cm_wr32(TAS57XX_ID,0x41,0x0FAAAAAB);//ratio=3//i2cm_wr32(TAS57XX_ID,0x42,0x00107A1C);//offset(makeup gain)=6//i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc//------------------------------------------------------//i2cm_wr64(TAS57XX_ID,0x3a,0x00000DA6,0x007FF259);//attack filter=50ms 0707 change//i2cm_wr64(TAS57XX_ID,0x3b,0x00004432,0x007Fbbcd);//attack filter=10ms 0707 change//i2cm_wr64(TAS57XX_ID,0x3c,0x000006d3,0x007FF92c);//decay filter=100ms 0707 change//i2cm_wr32(TAS57XX_ID,0x40,0xFC98537A);//thresh hold=-17db 0707 change//i2cm_wr32(TAS57XX_ID,0x41,0x0FAAAAAB);//ratio=3 0707 change//i2cm_wr32(TAS57XX_ID,0x42,0x00107A1C);//offset(makeup gain)=6 0707 change//i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc 0707 change// //------------------------------------------------------i2cm_wr64(TAS57XX_ID,0x3a,0x0000883f,0x007F77c0); //energe filter=5msi2cm_wr64(TAS57XX_ID,0x3b,0x0002A39A,0x007D5C65); //attack filter=1msi2cm_wr64(TAS57XX_ID,0x3c,0x00004432,0x007FBBCD); //decay filter=10msi2cm_wr32(TAS57XX_ID,0x40,0xFC98537A);//thresh hold=-17dbi2cm_wr32(TAS57XX_ID,0x41,0x0FAAAAAB);//ratio=3i2cm_wr32(TAS57XX_ID,0x42,0x00107A1C);//offset(makeup gain)=6i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc//------------------------------------------------------//i2cm_wr64(TAS57XX_ID,0x3a,0x0000883f,0x007F77c0);//energe filter=5ms//i2cm_wr64(TAS57XX_ID,0x3b,0x0002A39A,0x007D5C65);//attack filter=1ms//i2cm_wr64(TAS57XX_ID,0x3c,0x00004432,0x007FBBCD);//decay filter=10ms//i2cm_wr32(TAS57XX_ID,0x40,0xFC588B89);//thresh hold=-20db//i2cm_wr32(TAS57XX_ID,0x41,0x0FC00000);//ratio=2//i2cm_wr32(TAS57XX_ID,0x42,0x000BAA32);//offset(makeup gain)=3//i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc//-----------------------------------------------------#endif//i2cm_wr32(TAS57XX_ID,0x46,0x1);//enable drc//filter//-----------------------------------L---------------------------------------#ifdef EQ_ONi2cm_wr32(TAS57XX_ID,0x50,0x10101090);//eq control,all 48K,EQ ON,wr L--> copt toR,no auto bank switchi2cm_wrN(TAS57XX_ID,0x29,sta57xx_BQ1a,20);i2cm_wrN(TAS57XX_ID,0x2a,sta57xx_BQ1b,20);for(i=0;i<5;i++)i2cm_wrN(TAS57XX_ID,0x2b+i,sta57xx_BQ1[i],20);//0x2b~2ffor(i=0;i<2;i++)i2cm_wrN(TAS57XX_ID,0x58+i,sta57xx_BQ1d[i],20);#endif//-----------------------------------R---------------------------------------//i2cm_wrN(TAS57XX_ID,0x30,sta57xx_BQ2a,20);//BQ2a//i2cm_wrN(TAS57XX_ID,0x31,sta57xx_BQ2b,20);//BQ2b//for(i=0;i<5;i++)//i2cm_wrN(TAS57XX_ID,0x32+i,sta57xx_BQ2[i],20);//BQ2,*GUI adr is wrong. act0x32~0x36.important//for(i=0;i<5;i++)//i2cm_wrN(TAS57XX_ID,0x5c+i,sta57xx_BQ2d[i],20);//BQ2d//---------------------------------------------------------------------------//enablei2cm_wrN(TAS57XX_ID,0x29,sta57xx_bass[2],20);i2cm_wr(TAS57XX_ID,0x05,0x00);//sub-ch class-bd } #endifvoid tas57xx_vol(signed char inc) //not complete. gain table for S {STATE_VOL+=inc;if(STATE_VOL>=(TAS57XX_GAIN_TBL_NO-1))STATE_VOL=(TAS57XX_GAIN_TBL_NO-1);else if(STATE_VOL<=0)STATE_VOL=0;STATE_TVOL=tas57xx_dgain_tbl[STATE_VOL];//STATE_TVOL is tmpi2cm_wr(TAS57XX_ID,0x07,STATE_TVOL);//tas57xx_dgain_tbl[STATE_VOL]);//vm20xx_mbass(STATE_TVOL); }void tas57xx_mute(unsigned char tas57xx_mute) // {if(tas57xx_mute){STATE_TVOL=tas57xx_dgain_tbl[0];//STATE_TVOL is tmpi2cm_wr(TAS57XX_ID,0x07,STATE_TVOL);//tas57xx_dgain_tbl[STATE_VOL]);}else{STATE_TVOL=tas57xx_dgain_tbl[STATE_VOL];//STATE_TVOL is tmpi2cm_wr(TAS57XX_ID,0x07,STATE_TVOL);//tas57xx_dgain_tbl[STATE_VOL]);} }void tas57xx_pwm_off(void) // {i2cm_wr(TAS57XX_ID,0x05,0x40);//all ch pwdn}