STM32 串口 发送 有必要 先检测状况,不然 第一个 字节 无法 宣布,发送完毕,有必要检测发送状况是否完结,不然,发送不成功,
运用stm32f10x调试串口通讯时,发现一个犯错的现象,硬件复位重启之后,发送测验数据0x01 0x02 0x03 0x04..接纳端收到的数据为:0x02 0x03 0x04,第一个数据丢掉。换成发送其他数值的数据,如0x06 0x0ff,则接纳到0x0ff,0x06丢掉。过错仍旧。
毛病扫除进程:
1、刚开端怀疑是接纳端的过错,我是运用电脑串口,运转串口辅佐调试东西接纳,换成其他软件后,发现毛病仍旧,并且电脑软件一直是敞开状况,不像和电脑软件有关。
2、运用单步调试,单步运转各个发送指令,都正常。能收到0x01 0x02 0x03 0x04的数据。直接的扫除了不是电脑软件的问题,而是其他的过错。
3、单步调试运转尽管正常了,但接连运转时,过错仍旧。现在有点摸不到条理了,单步运转正常,看起来编程没有犯错,那毛病在哪里呢?测验程序如下
USART_SendData(USART2, 0x01); //A
while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == RESET); //B
USART_SendData(USART2, 0x02); //C
while(USART_GetFlagStatus(USART2, USART_FLAG_TC) == 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_ClearFlag(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)。 也就是说,要先read USART_SR,然后write USART_DR,才干完结TC状况位的铲除。而硬件复位后,串口发送的首个数据之前没有read SR的操作,是直接write DR,也就是说,TC没有被铲除去。 阐明第4步的猜想是对的。
8、那么,应该把指令A前面加的USART_ClearFlag(USART2,USART_FLAG_TC); 改为USART_GetFlagStatus(USART2, USART_FLAG_TC);,应该也能消除过错。测验后证明,的确如此,在发送首个数据之前,先读取一下USART_SR,那么就不会呈现首个数据丢掉的状况了。
9、总结:硬件复位后,串口发送首个数据之前,先读取一下USART_SR,则能够确保首个数据发送时,不呈现掩盖的状况。当然,也有其他办法,比方先铲除TC状况位,或是,在write USART_DR之后,参加一个小延时,让数据发送完毕,应该也能直接扫除这个过错。
STM32的USART发送数据时怎么运用TXE和TC标志
在USART的发送端有2个寄存器,一个是程序能够看到的USART_DR寄存器(下图中暗影部分的TDR),另一个是程序看不到的移位寄存器(下图中暗影部分Transmit Shift Register)。
对应USART数据发送有两个标志,一个是TXE=发送数据寄存器空,另一个是TC=发送完毕;对照下图,当TDR中的数据传送到移位寄存器后,TXE被设置,此刻移位寄存器开端向TX信号线按位传输数据,但由于TDR现已变空,程序能够把下一个要发送的字节(操作USART_DR)写入TDR中,而不用比及移位寄存器中一切位发送完毕,一切位发送完毕时(送出中止位后)硬件会设置TC标志。
另一方面,在刚刚初始化好USART还没有发送任何数据时,也会有TXE标志,由于这时发送数据寄存器是空的。
TXEIE和TCIE的含义很简单,TXEIE答应在TXE标志为1时发生中止,而TCIE答应在TC标志为1时发生中止。
至于什么时候运用哪个标志,需求依据你的需求自己决议。但我以为TXE答应程序有更富余的时刻填写TDR寄存器,确保发送的数据流不间断。TC能够让程序知道发送完毕的切当时刻,有利于程序控制外部数据流的时序。