设定发送数据如下:

串口发送函数:

串口打印结果:

可以看到,明明TxBuff的大小为10个字节,但是只输出了后9位数据,第一位0x31没有输出;
更改代码如下:

串口打印结果如下:

可以看到TxBuff[0]被正常输出了。
查询STM32F4xx参考手册关于TC标志位有这样一段话,

里面提到TC标志位是由软件序列清零的,也就是执行一条读状态寄存器SR,然后在写入数据寄存器DR来实现的发送完成标志位清零,也就是我们代码中
for( len = 0;len < (sizeof(TxBuff));len++)
{
USART_SendData(USART1,TxBuff[len]);
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待发送结束
}
1.执行USART_GetFlagStatus(USART1,USART_FLAG_TC);就相当于读取USART_SR寄存器;
2.执行USART_SendData(USART1,TxBuff[len]);就相当于向数据寄存器USART_DR写入数据;
所以上述代码相当于每次从第二个数据开始才实现的TC清零序列,由此可以看出第一个数据TxBuff[0]加载到数据寄存器USART_DR后随机执行while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);如果USART_SR->TC一开始就是置1的状态,就会随即执行USART_SendData(USART1,TxBuff[1]);将数据TxBuff[1]写入USART_DR寄存器取代了之前数据寄存器中TxBuff[0]的值,并实现了一个TC软件清零序列,等待发送TxBuff[1]后,TC置1,后面依次发送TxBuff[2],TxBuff[3]…
问题就出现在这里,在发送第一个数据之前加入一条USART_ClearFlag(USART1,USART_FLAG_TC);软件清零TC的指令之后实现了串口打印输出的正常,查看USART_SR寄存器可以发现TC位的复位值为1,从而导致串口发送的第一个数据被第二个数据覆盖。


本文详细解析了STM32串口发送数据时出现首个数据丢失的问题,通过分析STM32F4xx参考手册,揭示了TC标志位清零机制与数据发送之间的关系,并给出了解决方案。
6693

被折叠的 条评论
为什么被折叠?



