TAS5711 Slave 模式如何設定2.1聲道程序
时间:10-02
整理:3721RD
点击:
請問一下,我目前用了一個DSP+5711的方案,以DSP為Matser,5711為slave模式,看了Design Guide內容的部分,依照參數下去,聲音都沒有輸出,附上我的程式碼檔案,能否告知是哪個環節出了問題,謝謝
你好:
1.你的原理图连接是否正确?可以对照我们的EVM板检查连接。
2.没有声音输出的时候,看一下电感前面是不是50%占空比的PWM波形,开关频率是不是384Khz。
3. 2.1的软件设置主要是0x05寄存器改成0x84或0x8C.
兄弟 你的问题解决了吗 我用的tas5508 也是没出声 可以讨论下吗Q273203365
我是依照你們EVB板的原理圖去製作的,我現在遇到的問題是2.1模式程式不知道修改什麼地方,我附件中的程序在2.0 BD模式是有聲音輸出的,如你所說,我是只要去修改0x05這邊就好了嗎?還是還有什麼地方也需要修改,煩請告知
我的5508在 2.0也是出声了 现在研究 怎么 分频 让左右声道各输出高低音 初涉音频 感觉好难
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 I2cmRead1Byte i2cm_rd
#define TAS57XX_GAIN_TBL_NO 31
unsigned 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 bits
unsigned 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 Trim
i2cm_wr(TAS57XX_ID,0x03,0xa0); // System Control Register 1
i2cm_wr(TAS57XX_ID,0x04,0x05); // Serial Data Interface Register
i2cm_wr(TAS57XX_ID,0x06,0x00); // Soft Mute Register
i2cm_wr(TAS57XX_ID,0x07,0x2a); // Master Volume Register (0xFF = Mute)
i2cm_wr(TAS57XX_ID,0x08,0x30); // Channel 1 Volume
i2cm_wr(TAS57XX_ID,0x09,0x30); // Channel 2 Volume
i2cm_wr(TAS57XX_ID,0x0a,0x30); // SubChannel Volume
i2cm_wr(TAS57XX_ID,0x0e,0x91); // Micro Register
i2cm_wr(TAS57XX_ID,0x10,0x02); // Modulation Limit
i2cm_wr(TAS57XX_ID,0x19,0x30); // Shutdown Group Resister
i2cm_wr(TAS57XX_ID,0x1a,0x95); // Split Capacitor Charge Period
i2cm_wr(TAS57XX_ID,0x1c,0x02); // Back-end Error Register
i2cm_wr32(TAS57XX_ID,0x20,0x00897772); // 2.1 output mode
i2cm_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 1
i2cm_wr(TAS57XX_ID,0x12,0x54); // Inter-Channel Delay Channel 2
i2cm_wr(TAS57XX_ID,0x13,0xac); // Inter-Channel Delay Channel 3
i2cm_wr(TAS57XX_ID,0x14,0x54); // Inter-Channel Delay Channel 4
i2cm_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=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,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,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_ON
i2cm_wr32(TAS57XX_ID,0x50,0x10101090);//eq control,all 48K,EQ ON,wr L--> copt to R,no auto bank switch
i2cm_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~2f
for(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
//---------------------------------------------------------------------------
//enable
i2cm_wrN(TAS57XX_ID,0x29,sta57xx_bass[2],20);
i2cm_wr(TAS57XX_ID,0x05,0x00);//sub-ch class-bd
}
#endif
void 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 tmp
i2cm_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 tmp
i2cm_wr(TAS57XX_ID,0x07,STATE_TVOL);//tas57xx_dgain_tbl[STATE_VOL]);
}
else
{
STATE_TVOL=tas57xx_dgain_tbl[STATE_VOL];//STATE_TVOL is tmp
i2cm_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
}
