F2802x串口FIFO收发中断问题

2019-08-08 23:16发布

发现发中断函数不停的在调用,估计是SCI配置问题,但对手册研究了半天,没发现问题。TI的手册很费神。
(1)不发数据的时候,Sci_sendTimer1的值不停的在变,加断点也发现不停的在调用发中断函数。这个实在太奇怪了。。
(2)屏蔽掉SciaRegs.SCIFFTX.bit.TXFFINTCLR = 1;  // Clear SCI Interrupt flag ,发中断函数完全不触发,我在while中发一次数据,也不会触发中断。
        有这行代码,就不停的在触发发中断函数,实际没有发任何数据出来。
(3)FIFO中断收,没有问题。

请TI工程师,帮我看一下。debug在RAM里运行的。

发中断函数
interrupt void SCITXINTA_ISR(void)     // SCI-A
{
  // Insert ISR Code here
  Sci_sendTimer1++;

  SciaRegs.SCIFFTX.bit.TXFFINTCLR = 1;  // Clear SCI Interrupt flag

  // To receive more interrupts from this PIE group, acknowledge this interrupt
   PieCtrlRegs.PIEACK.all = PIEACK_GROUP9;
}

串口初始化函数:
void InitSci(void)
{
  // Initialize SCI-A:
  SciaRegs.SCICCR.all = 0x0007;   // 1 stop bit,  No loopback
                                  // No parity,8 char bits,
                                  // async mode, idle-line protocol
  SciaRegs.SCICTL1.all = 0x0003;  // enable TX, RX, internal SCICLK,
                                  // Disable RX ERR, SLEEP, TXWAKE
  // Baud config 38400bps
  SciaRegs.SCIHBAUD = 0x0000;
  SciaRegs.SCILBAUD = SCI_PRD;

  // FIFO configure enable FIFO
  SciaRegs.SCIFFTX.all = 0xC020;
  SciaRegs.SCIFFRX.all = 0x0021;
  SciaRegs.SCIFFCT.all = 0x00;

  SciaRegs.SCICTL1.all = 0x0023;     // Relinquish SCI from Reset
  SciaRegs.SCIFFTX.bit.TXFIFOXRESET = 1;
  SciaRegs.SCIFFRX.bit.RXFIFORESET  = 1;
}


这个是基于eeworld版主的例程上改的。
下面这个例子基于controlSUITE的例程
测试发现,例程:scia_loopback_interrupts
C: icontrolSUITEdevelopment_kitsC2000_LaunchPadf2802x_examplesscia_loopback_interrupts

关掉loopback模式后,发送中断函数还是不停在调用,这就很奇怪了??不发数据,为啥FIFO发中断会不停触发,大家可以试一下

修改代码:
void scia_init()

屏蔽掉//SCI_enableLoopBack(mySci);
或改成:SCI_disableLoopBack(mySci);
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
6条回答
shenmu2012
2019-08-09 15:02
elkite 发表于 2013-9-22 20:50
FIFO发送中断问题已经解决,大家以后再碰到这个问题,请参考这里。

TMS320x2802x, 2803x Piccolo Serial C ...

楼上讲解很详细的,我这跟着学习的了啊

一周热门 更多>