欢迎来到天天文库
浏览记录
ID:50136228
大小:19.28 KB
页数:5页
时间:2020-03-04
《STM32串口首字节和尾字节少.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、STM32串口首字节和尾字节少STM32串口发送必须先检测状态,否则第一个字节无法发出,发送完毕,必须检测发送状态是否完成,否则,发送不成功,使用stm32f10x调试串口通讯时,发现一个出错的现象,硬件复位重启之后,发送测试数据0x010x020x030x04..接收端收到的数据为:0x020x030x04,第一个数据丢失。换成发送别的数值的数据,如0x060x0ff,则接收到0x0ff,0x06丢失。错误依旧。故障排除过程:1、刚开始怀疑是接收端的错误,我是使用电脑串口,运行串口辅助调试工具接收,换成其他软件后,发现故障依旧,而且电脑软件一直是开启状态,不像和电脑软件有关。2、使用单步调
2、试,单步运行各个发送指令,都正常。能收到0x010x020x030x04的数据。间接的排除了不是电脑软件的问题,而是其他的错误。3、单步调试运行虽然正常了,但连续运行时,错误依旧。现在有点摸不到头绪了,单步运行正常,看起来编程没有出错,那故障在哪里呢?测试程序如下USART_SendData(USART2,0x01);//Awhile(USART_GetFlagStatus(USART2,USART_FLAG_TC)==RESET);//BUSART_SendData(USART2,0x02);//Cwhile(USART_GetFlagStatus(USART2,USART_FLAG_TC
3、)==RESET);USART_SendData(USART2,0x03);while(USART_GetFlagStatus(USART2,USART_FLAG_TC)==RESET);USART_SendData(USART2,0x04);while(USART_GetFlagStatus(USART2,USART_FLAG_TC)==RESET);4、猜测,也许是因为某个特殊原因,使第二个数据覆盖了首个数据,使得首个数据丢失。假设:在执行B指令时,USART的TC状态位==SET,那么就会紧接着执行C指令,也就有可能发生数据的覆盖。于是,在A指令前,加入如下指令:USART_Clear
4、Flag(USART2,USART_FLAG_TC);5、加入上一条指令后,运行,错误消失了。说明上一个假设,应该是成立的。6、查阅stm32f10x参考手册,找到这样一句话:TC:发送完成当包含有数据的一帧发送完成后,由硬件将该位置位。如果USART_CR1中的TCIE为1,则产生中断。由软件序列清除该位(先读USART_SR,然后写入USART_DR)。TC位也可以通过写入0来清除,只有在多缓存通讯中才推荐这种清除程序。0:发送还未完成;1:发送完成。7、注意到这一句:由软件序列清除该位(先读USART_SR,然后写入USART_DR)。也就是说,要先readUSART_SR,然后wri
5、teUSART_DR,才能完成TC状态位的清除。而硬件复位后,串口发送的首个数据之前没有readSR的操作,是直接writeDR,也就是说,TC没有被清除掉。说明第4步的猜测是对的。8、那么,应该把指令A前面加的USART_ClearFlag(USART2,USART_FLAG_TC);改为USART_GetFlagStatus(USART2,USART_FLAG_TC);,应该也能消除错误。测试后证实,确实如此,在发送首个数据之前,先读取一下USART_SR,那么就不会出现首个数据丢失的情况了。9、总结:硬件复位后,串口发送首个数据之前,先读取一下USART_SR,则能够保证首个数据发送时
6、,不出现覆盖的情况。当然,也有别的方法,比如先清除TC状态位,或是,在writeUSART_DR之后,加入一个小延时,让数据发送完毕,应该也能间接排除这个错误。STM32的USART发送数据时如何使用TXE和TC标志在USART的发送端有2个寄存器,一个是程序可以看到的USART_DR寄存器(下图中阴影部分的TDR),另一个是程序看不到的移位寄存器(下图中阴影部分TransmitShiftRegister)。对应USART数据发送有两个标志,一个是TXE=发送数据寄存器空,另一个是TC=发送结束;对照下图,当TDR中的数据传送到移位寄存器后,TXE被设置,此时移位寄存器开始向TX信号线按位传
7、输数据,但因为TDR已经变空,程序可以把下一个要发送的字节(操作USART_DR)写入TDR中,而不必等到移位寄存器中所有位发送结束,所有位发送结束时(送出停止位后)硬件会设置TC标志。另一方面,在刚刚初始化好USART还没有发送任何数据时,也会有TXE标志,因为这时发送数据寄存器是空的。TXEIE和TCIE的意义很简单,TXEIE允许在TXE标志为'1'时产生中断,而TCIE允许在TC标志为'1'时产生中断
此文档下载收益归作者所有