This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

音频信号通过McASP发送中断方式输出



TI购买的OMAPL137开发板,我想实现McASP发送中断方式控制音频信号,在轮询的例程基础上改的,轮询程序可以实现,但是中断一直实现不了,也找不到错误,求大神帮忙!下边是主要程序:
main文件:
interrupt void interrupt4(void)
{
Uint32 sample;

sample = input_sample(); // read L + R samples from ADC
output_sample(sample); // write L + R samples to DAC
return;
}

int main( void )
{

/* Initialize BSL */
EVMC6747_init( );
/* Call evmc6747_intr function */
aic3106_init( );
while(1);
}

aic3106_init文件的一部分,McASP配置部分,采用内部时钟,I2S方式,同步传输。音频芯片的配置应该没问题
/* Initialize MCASP1 */
mcasp = &MCASP_MODULE_1;
mcasp->regs->GBLCTL = 0; // Reset
mcasp->regs->RGBLCTL = 0; // Reset RX
mcasp->regs->XGBLCTL = 0; // Reset TX
mcasp->regs->PWRDEMU = 1; // Free-running
// configure McASP0 receive registers
mcasp->regs->RMASK = 0xFFFFFFFF; // No padding used
mcasp->regs->RFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
mcasp->regs->AFSRCTL = 0x00000112; // 2TDM, 1bit Falling, External FS, word
mcasp->regs->ACLKRCTL = 0x000000AF; // Rising INTERNAL CLK,(from tx side)
mcasp->regs->AHCLKRCTL = 0x00000000; // INT CLK (from tx side)
mcasp->regs->RTDM = 0x00000003; // Slots 0,1
mcasp->regs->RINTCTL = 0x00000000; // Not used
mcasp->regs->RCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256

mcasp->regs->XMASK = 0xFFFFFFFF; // No padding used
mcasp->regs->XFMT = 0x00018078; // MSB 16bit, 0-delay, no pad, CFGBus
mcasp->regs->AFSXCTL = 0x00000112; // 2TDM, 1bit Rising edge INTERNAL FS, word
mcasp->regs->ACLKXCTL = 0x000000AF; // ASYNC, Rising INTERNAL CLK, div-by-16
mcasp->regs->AHCLKXCTL = 0x00000000; // EXT CLK
mcasp->regs->XTDM = 0x00000003; // Slots 0,1
mcasp->regs->XINTCTL = 0x00000020; // interrupt on transmit
mcasp->regs->XCLKCHK = 0x00FF0008; // 255-MAX 0-MIN, div-by-256

mcasp->regs->SRCTL5 = 0x000D; // MCASP1.AXR1[5] --> DIN
mcasp->regs->SRCTL0 = 0x000E; // MCASP1.AXR1[0] <-- DOUT
mcasp->regs->PFUNC = 0; // All MCASPs
mcasp->regs->PDIR = 0x14000020; // All inputs except AXR0[5], ACLKX1, AFSX1

mcasp->regs->DITCTL = 0x00000000; // Not used
mcasp->regs->DLBCTL = 0x00000000; // Not used
mcasp->regs->AMUTE = 0x00000000; // Not used
/* Starting sections of the McASP*/
mcasp->regs->XGBLCTL |= GBLCTL_XHCLKRST_ON;
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XHCLKRST_ON ) != GBLCTL_XHCLKRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RHCLKRST_ON;
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RHCLKRST_ON ) != GBLCTL_RHCLKRST_ON );

mcasp->regs->XGBLCTL |= GBLCTL_XCLKRST_ON;
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XCLKRST_ON ) != GBLCTL_XCLKRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RCLKRST_ON;
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RCLKRST_ON ) != GBLCTL_RCLKRST_ON );

mcasp->regs->XSTAT = 0x0000ffff;
mcasp->regs->RSTAT = 0x0000ffff;

mcasp->regs->XGBLCTL |= GBLCTL_XSRCLR_ON;
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSRCLR_ON ) != GBLCTL_XSRCLR_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RSRCLR_ON;
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->XBUF5 = 0;
mcasp->regs->RBUF0 = 0;

mcasp->regs->XGBLCTL |= GBLCTL_XSMRST_ON;
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XSMRST_ON ) != GBLCTL_XSMRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RSMRST_ON;
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RSMRST_ON ) != GBLCTL_RSMRST_ON );

mcasp->regs->XGBLCTL |= GBLCTL_XFRST_ON;
while ( ( mcasp->regs->XGBLCTL & GBLCTL_XFRST_ON ) != GBLCTL_XFRST_ON );
mcasp->regs->RGBLCTL |= GBLCTL_RFRST_ON;
while ( ( mcasp->regs->RGBLCTL & GBLCTL_RFRST_ON ) != GBLCTL_RFRST_ON );
CSR = 0x0000;
INTC_INTMUX1 = 0x3d;
ISTP = (unsigned int)vectors;
ICR = 0xFFF0;
IER |= 0x12;
CSR |= 0x01;

还有就是两个输入输出函数:
void output_sample(Int32 out_data)
{
AIC31_data.uint = out_data;
MCASP1_XBUF5_32BIT = AIC31_data.uint;
}

Int32 input_sample(void)
{
AIC31_data.uint = MCASP1_RBUF0_32BIT;
return (AIC31_data.uint);
}

  • 看一下IFR.4位是否置1了?

  • Shine Zhang 说:

    看一下IFR.4位是否置1了?

    您好,谢谢您的回答。

    我在中断程序中设置了一个断点,然后可以看到程序进入了中断了

    这时IFR等其他寄存器如图,可以看出来中断是都开了,而且程序里McASP发送中断也使能了,不知道为啥不行呢?

    还有就是我看技术文档这里,

    这个意思是仿真的过程中不能有中断发生吗?仿真过程中不能去看寄存器的值?谢谢您!

  • 这段话的意思是,如果在CCS中查看XRBUF,仿真器会是RDATA位清0, 如果在CCS里直接写XRBUF,则会使XDATA位清0.

    进不了中断,程序跑有没有跑飞?在中断向量表的中断子程序入口地址那里设个断点,看是否能进?

  • Shine Zhang 说:

    这段话的意思是,如果在CCS中查看XRBUF,仿真器会是RDATA位清0, 如果在CCS里直接写XRBUF,则会使XDATA位清0.

    进不了中断,程序跑有没有跑飞?在中断向量表的中断子程序入口地址那里设个断点,看是否能进?

    问题解决了,犯了一个很二的错误,我VECS段是从SHAREDRAM段分出来的一块,但是CMD文件中却把.text等都分配到了SHRAEDRAM了。非常感谢TI工程师!

  • 谢谢分享!