搜索
bottom↓
回复: 3

F2812 SCI-A FIFO模式下中断问题

[复制链接]

出0入0汤圆

发表于 2013-3-16 09:03:32 | 显示全部楼层 |阅读模式
本帖最后由 bruce_helen 于 2013-3-16 09:47 编辑

F2812 SCI-A FIFO中断问题。

FIFO模式配置:接收到一个字符产生接收中断,读取字符。发送中断没有打开,发送时只是查看FIFO TXFFST寄存器,如果少于0x10就写入SCITXBUF,否则while循环等待。

问题:RX引脚会被外部拉低一段时间(外部有RS232电平转换芯片,串口睡眠时,RX会被强制拉低。这个跟一般的情况有区别,请注意。自己测试时可以直接将RX引脚接地一下),此时2812能检测到BREAK Condition,SciaRegs.SCIRXST.bit.RXERROR = 1,并能正确产生中断。
按照文档(TMS320F28x DSP Serial Communication Interface (SCI) Reference Guide)上在中断中清SciaRegs.SCICTL1.bit.SWRESET = 0,并将SCI-A重新初始化。
一段时间后RX引脚被拉高(准备开始通信),并且RX有数据传输,但是F2812再也没有任何中断产生。DSP发送数据的功能正常。
初始化SCI-A的寄存器我已经对过几遍了,有些位不是太明白。大家帮我看看,是不是什么位没设置对。

PS: 如果不使用FIFO模式,在普通模式下,在RX错误中断里直接初始化就没问题。

// SCI-A初始化函数
void InitSci(void)
{
        // Initialize SCI-A:
        EALLOW;
        GpioMuxRegs.GPFMUX.bit.SCITXDA_GPIOF4 = 1;
        GpioMuxRegs.GPFMUX.bit.SCIRXDA_GPIOF5 = 1;
        EDIS;
        // 8 bit, 1 stop
        SciaRegs.SCICCR.all  = 0x0007;

        SciaRegs.SCICTL1.all = 0x0043;
        SciaRegs.SCICTL2.all = 0x0002;

        SciaRegs.SCIHBAUD    = 0x0000;
        SciaRegs.SCILBAUD    = 0x00F3;   //00f3:19200  01e7:9600

        SciaRegs.SCIFFTX.all = 0xe000;
        SciaRegs.SCIFFRX.all = 0x6061;

        SciaRegs.SCIFFCT.all = 0x0000;

        // Relinquish SCI from Reset
        SciaRegs.SCICTL1.all = 0x0063;
}

//RX接收中断
interrupt void scia_rx_fifo_isr(void)
{
        Uint16 ReceivedChar;

        /* We need to RESET SCI module if error happens */
        if (SciaRegs.SCIRXST.bit.BRKDT   == 1 ||
                SciaRegs.SCIRXST.bit.RXERROR == 1)
        {
                SciaRegs.SCIFFRX.bit.RXFFINTCLR = 1;
                //按照手册上2-5上对SW RESET的说明,这里需要清0
                SciaRegs.SCICTL1.bit.SWRESET    = 0;

                // Issue PIE ack
                PieCtrlRegs.PIEACK.all |= PIEACK_GROUP9;

                //在这里我还需要做什么?
                //我尝试过直接调用InitSci(),结果还是一样。中断再也来不了。
        }
        else
        {
                ReceivedChar = SciaRegs.SCIRXBUF.bit.RXDT & 0x00ff;
                if(en_queue(&g_sci_rx_queue, ReceivedChar) == 0)
                {
                        /* error, light LED for debug */
                        //*LedReg = LedCode[0];
                }

                g_sci_data_flag = 1;

                SciaRegs.SCIFFRX.bit.RXFFOVRCLR = 1;         // Clear Overflow flag
                SciaRegs.SCIFFRX.bit.RXFFINTCLR = 1;         // Clear Interrupt flag

                SciaRegs.SCIFFRX.bit.RXFIFORESET = 0;         // Reset the FIFO receive stack
                SciaRegs.SCIFFRX.bit.RXFIFORESET = 1;         // Enable the FIFO receive operation
                PieCtrlRegs.PIEACK.all |= PIEACK_GROUP9;
        }
}

// Transmit a character from the SCI
void scia_xmit(Uint16 a)
{
    /* We need to wait if FIFO is full(16 words) */
    while (SciaRegs.SCIFFTX.bit.TXFFST == 0x10);
    SciaRegs.SCITXBUF = a;
}


F2812 spec



我的调试板,绿线是TX,黄色的是RX,黑色的是地线,红色的是正极。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

 楼主| 发表于 2013-3-16 12:40:44 | 显示全部楼层
怎么没人呢,交流交流哈。新手郁闷中。。。

出0入0汤圆

 楼主| 发表于 2013-3-16 18:28:21 | 显示全部楼层
刚试了,上面的代码可以使用。不知道之前一直为什么不行,很纳闷。

出0入0汤圆

发表于 2013-3-16 20:22:46 | 显示全部楼层
多练习吧
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-19 00:08

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表