• STM32串口发送中断


    今日进行串口数据通信时,使用DMA串口485发送完成中断进行485发送至接收的状态转换时发现,当DMA传输完成时,串口发送寄存器中的数据还未通过发送端口传输完成,在中断中需等待查询串口发送的状态,while((USART_GetFlagStatus(USART1,USART_FLAG_TC) != SET)); 造成中断程序程序的阻塞,以5Mbit/s的波特率的计算的话阻塞约3us。 对控制程序仍有很大影响,以简化中断处理时间的原则,

    采用以下改正方法:

    1、使用485自动收发电路,(存在的问题是:成本较高,波特率可能达不到,接收状态时同样需要信号输出引脚端置为低电平,若切换时有中断进来,延长发送状态会对总线的数据造成影响。 (电路参考485通讯电路总结http://www.cnblogs.com/my-trees/p/8028960.html))所以不可取。

    2、改用发送完成中断进行485发收状态的切换,(用DMA串口空闲中断进行收据的接收)。这样在串口传输完成后即可进行485接收状态的切换,避免程序阻塞,减少了中断的执行时间,降低了对控制程序的影响。

    在采用方法2进行处理时,在程序中对中断类型进行判断,发现在使用串口1中断后,程序会频繁进入串口中断,断开通讯、关闭接受空闲中断同样也会进入,

    原因是在发送完成中断使能后,使能串口USART_Cmd(USART1, ENABLE)时触发串口中断;通过仿真看到。CR寄存器发送中断标志第6位发送完成中断位置位,触发发送完成中断。 所以在使能发送完成中断状态时,当使能串口时USART_Cmd(USART1, ENABLE);程序会进入一次发送完成中断程序(这与MODBUS发数据协议中介绍的相同,当使能串口发送中断时STM32会自动发送一个空闲帧触发中断描述相同 )。

    循环进入中断是因为在发送完成中断中转换485为接受状态后,重新配置了串口接收DMA,重新使能了串口,造成串口发送完成中断循环进入。

  • 相关阅读:
    万字攻略,详解腾讯面试
    百度广告产品系统级测试技术演进
    TAR部署MYSQL(1)
    RPM部署MYSQL
    大数据学习之Linux(3)
    大数据学习之linux(2)
    大数据学习之linux(1)
    pycharm安装与破解
    Dijkstra—校园景点游览问题
    哈夫曼编译码器
  • 原文地址:https://www.cnblogs.com/my-trees/p/8490617.html
Copyright © 2020-2023  润新知