Tong Tang 你好。请教你有关6747MCASP接口配置问题,照说这种低级问题不应该麻烦你的,但是俺确实没招了。
所以才向你请教,以前没有做过涉及到音频处理的项目,所以对这个接口比较陌生。具体情况就是DSP6747的
MCASP0.AXR0[3]发不出数据。程序卡在while ( ! ( MCASP0_SRCTL3 & 0x10 ) );
时钟信号,帧同步信号,已经送给DSP了
软件环境:CCS3.3 仿真器是合达众的560plus 片子型号:6747
MCASP管脚配置
PINMUX9 = 0x11111100; // McASP0
PINMUX10 = 0x00111110; // McASP0
void C6747_MCASP_open()
{
// Configure AIC3168
Int16 msec, sec;
Int16 sample;
C6747_I2C_write( AIC3168_I2C_ADDR, AIC3168DA_RESET1, 6 );
C6747_I2C_write( AIC3168_I2C_ADDR, AIC3168DA_RESET2, 6 );
C6747_I2C_write( AIC3168_I2C_ADDR, AIC3168AD_RESET1, 7 );
C6747_I2C_write( AIC3168_I2C_ADDR, AIC3168AD_RESET2, 7 );/*以上是PCM3168A codec的设置,具体情况如下:
1、3168A为主设备(接收与发送),6747为从设备(接收与发送)
2、mcasp收发信号格式为 24-bit left-justified mode TDM format
3、3168A初始化后,工作正常,显示波能看出时钟信号(收发),帧同步信号(收发),以及数据(发送)
*/
// Initialize MCASP0
mcasp = &MCASP_MODULE_0;
mcasp->regs->GBLCTL = 0; // Reset
mcasp->regs->RGBLCTL = 0; // Reset RX
mcasp->regs->XGBLCTL = 0; // Reset TX
mcasp->regs->PWRDEMU = 1; // Free-running
// RX
mcasp->regs->RMASK = 0xffffffff; // No padding used
mcasp->regs->RFMT = 0x000280B8; // MSB 24bit, 2-delay, no pad, CFGBus DMA recevice
mcasp->regs->AFSRCTL = 0x00000310; // 6 TDM, Rising, Externally FS, word
mcasp->regs->ACLKRCTL = 0x00000080; // Rising , External CLKmcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
mcasp->regs->RTDM = 0x00000006; // Slots 110
mcasp->regs->RINTCTL = 0x00000000; // Not used
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
// TX
mcasp->regs->XMASK = 0xffffffff; // No padding used
mcasp->regs->XFMT = 0x000280B8; // MSB 24bit, 2-delay, no pad, CFGBus DMA sent
mcasp->regs->AFSXCTL = 0x00000310; // 6 TDM, Rising edge INTERNAL FS, word
mcasp->regs->ACLKXCTL = 0x00000040; // Rising ,External CLK ,Separate clock and frame sync used by transmitand receive sections
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
mcasp->regs->XTDM = 0x00000006; // Slots 110
mcasp->regs->XINTCTL = 0x00000000; // Not used
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256
mcasp->regs->SRCTL3 = 0x000D; // MCASP0.AXR0[3] –> DINmcasp->regs->SRCTL4 = 0x000D; // MCASP0.AXR0[4] –> DIN
mcasp->regs->SRCTL0 = 0x000E; // MCASP0.AXR0[0] <– DOUTmcasp->regs->SRCTL1 = 0x000E; // MCASP0.AXR0[1] <– DOUT
mcasp->regs->SRCTL2 = 0x000E; // MCASP0.AXR0[2] <– DOUT
mcasp->regs->PFUNC = 0x00000000; // All MCASPs Pin functions as McASP pin
mcasp->regs->PDIR = 0x00000018; // All inputs except AXR0[4], AXR0[3]
mcasp->regs->DITCTL = 0x00000000; // TDM mode
mcasp->regs->DLBCTL = 0x00000000; // Loopback mode is disabled.
mcasp->regs->AMUTE = 0x00000000; // AMUTE mode is disabled
// Starting sections of the McASP
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON; // HS Clkwhile ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON; // HS Clk
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );
mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON; // Clk
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON; // Clk
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );
mcasp->regs->XSTAT = 0x0000ffff; // Clear all
mcasp->regs->RSTAT = 0x0000ffff; // Clear all
mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON; // Serialize
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON; // Serialize
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSRCLR_ON ) != GBLCTL_RSRCLR_ON );
// Write a 0, so that no underrun occurs after releasing the state machine
mcasp->regs->RBUF0 = 0;
mcasp->regs->RBUF1 = 0;
mcasp->regs->RBUF2 = 0;
mcasp->regs->XBUF3 = 0;
mcasp->regs->XBUF4 = 0;
mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON; // State Machine
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON; // State Machine
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );
mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON; // Frame Sync
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON; // Frame Sync
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
/* Start by sending a dummy write */
while( ! ( MCASP0_SRCTL3 & 0x10 ) ); // Check for Tx ready
MCASP0_XBUF3_32BIT = 0;
/* Play Tone */
for ( sec = 0 ; sec < 5 ; sec++ )
{
for ( msec = 0 ; msec < 1000 ; msec++ )
{
for ( sample = 0 ; sample < 48 ; sample++ )
{
while ( ! ( MCASP0_SRCTL3 & 0x10 ) );//程序卡在这里了,数据发不出来。寄存器XSTAT=0X171
//Causes a transmit interrupt (XINT),//if this bit is set and XUNDRN in XINTCTL is set
//但是初始化的时候没开中断,mcasp->regs->XINTCTL = 0x00000000; // Not used
MCASP0_XBUF3_32BIT = (sinetable[sample] << 15);
while ( ! ( MCASP0_SRCTL3 & 0x10 ) );
MCASP0_XBUF3_32BIT = (sinetable[sample] << 15);
}
}
}
}
具体电路连接如下:
-
PCM3168A 6747 MCASP0
LRCKAD ——- AFSR0
BCKAD ——- ACLKR0
DOUT1 ——- AXR0[0]
LRCKDA ——- AFSX0
BCKDA ——- ACLKX0
DIN1 ——- AXR0[3]
LRCKAD:Audio data word clock input/output for ADC
BCKAD:Audio data bit clock input/output for ADC
DOUT1:Audio data digital output for ADC1 and ADC2
LRCKDA:Audio data word clock input/output for DAC
BCKDA:Audio data bit clock input/output for DAC
DIN1:Audio data input for DAC1 and DAC2
其中MCASP0的AHCLKR0与AHCLKX0我没有连接,收发信号PCM3168A 均为主设备,MCASP0为从设备,
信号形式24bit TDM ,收发采用独立的时钟与帧同步信号,且都由PCM3168A输出 ,
Tony Tang:
把原文件发上来吧。不是说修改一下配置的吗,怎么还是跟上次一样的?
Jiang YanJun:
回复 Tony Tang:
tong tang
你好。是这样的,这贴子是和上次一起发,我以为你只是负责OMAP这一块,所以我就在你又发了一遍。原文件我已经传上了,按照你说的,也改了配置还是不行,tong tang.真是没法子,只好麻烦你了。
Tony Tang:
回复 Jiang YanJun:
Yan Jun,
有几个问题确认一下。
#1. 使能了PCM3168的几个通道?6进8出?还是只是部分?是把所有通道的数据都放到一根数据线上以TDM模式收发吗?
#2. 实际当中接收/发送全部通道,还是部分通道?请明确。不明白RTDM=6是何用意。
#3. 代码中没有对PINMUX,PSC进行配置,你测试时是如何使能的?通过gel文件配置的?
#4. 实际当中,你测到的PCM3168送过来的波形的FS是figure 40的第一行,还是第二行?
Jiang YanJun:
回复 Tony Tang:
tong tang
你好。先回答你提的问题。
#1. 使能了PCM3168的几个通道?6进8出?还是只是部分?是把所有通道的数据都放到一根数据线上以TDM模式收发吗?
目前我只需要6进2出,但也可能用到6进6出,是的,所有通道的数据都在一根数据线上TDM模式。
#2. 实际当中接收/发送全部通道,还是部分通道?请明确。不明白RTDM=6是何用意。
RTDM=6,是我写错了,不好意思。当时注意力都集中在那几个时钟寄存器上面了。
#3. 代码中没有对PINMUX,PSC进行配置,你测试时是如何使能的?通过gel文件配置的?
已经配置了,在初始化的时候就配置了。
#4. 实际当中,你测到的PCM3168送过来的波形的FS是figure 40的第一行,还是第二行?
是第一行的波形,具体波形就请附件。
今天按照你的要求,测试了一下。正常开启6个通道输出没有问题,但8个通道输出程序会跑一段就死了,
/* Send a sample to the channel 1 */ while ( ! ( MCASP0_SRCTL3 & 0x10 ) );
不知道什么原因。不过目前我用不到8通道输出。用示波器看了一下,就是数据输出与帧同步好像延迟了好几个时钟周期(请看附件),估计是这原因引起的。另外,CODEC输出的数据与帧是同步的,没有延时。不知道这样会不会对CODEC接收数据有影响?
另外,谢谢你这几天抽出时间为我解答,看到你的解答,以及你在代码的修改还特意加了注解,真的让我很感动。谢谢!你可以将你的联系方式传到我邮箱不?jyjun9876@126.com这是结帖前的最后小小愿意,希望你能帮俺实现 。呵呵
Tony Tang:
回复 Jiang YanJun:
YanJun,
#1. 从波形看,输出像是错了一个slot,请确认XTDM的设置,6通道应该是0x3F. AFSXCTL里也是配置为6通道。
#2. 从PCM送出的数据波形看,感觉像是Figure 40里的I2S mode,数据是右对齐的。但是输出数据是左对齐的。如果PCM配置的是左对齐,那么发送的数据就可以不做移位操作,接收部分的RFMT也不用配置right rotate。
33. 在做8通道时,因为时钟是PCM送过来的,需要确认一帧内确定是8个slot的clock。
Jiang YanJun:
回复 Tony Tang:
谢谢你,tong tang。现在基本问题不是很大,我得仔细看看,也不能不动脑袋光问你的,只有没法子了,才能向你请教。有信号输出就好办多了。PCM送过来的不是I2S mode,我重新设置CODEC,用示波器看过了,两都几乎没什么变化。可以将你的联系方便发给我不?jyjun9876@126.com祝 你国庆愉快!
dahai:
回复 Jiang YanJun:
Jiang YanJun:
您好,请问您的问题解决了么?我是用的是C6747,也碰到了类似的问题。根据Tongtang的帮助和提示,问题初步得到了解决:即全速运行、且不断写输出数据时,能输出数据,SRCTL&0x10!=0能通过;一断停止(如设置中断)后,上述语句就通不过了,清除XSTAT的XUNDRN也不行。
Jiang YanJun:
回复 dahai:
你好。
你说的问题我目前还没遇到,中断出错是有可能的,如果一帧数据没发送完成,肯定会出错的,应用是采用DMA中断吧,这个你要问Tong Tang了。我也是初学者,不好意思。