记录一次刨根问底,关于usart.c的移植。

2019-10-11 16:29发布

首先感谢原子哥和 小陀螺爱炒蛋 前辈,本人没有编程语言基础,在摸索把F1例程移植到F0的过程中发现编译错误。
具体见http://www.openedv.com/forum.php ... mp;page=1#pid544125


昨晚下载到了两个CPU的中文手册,找到usart介绍部分,发现如下:

F0的CR1寄存器描述.png

F0的停止位描述.png

F1的CR1寄存器描述.png

F1的停止位描述.png

这才知道while((USART1->SR&0X40)==0)是判断usart数据发送完毕标志是否为1的语句。这个运算语句是判断SR寄存器的bit6是否为1的,个人解译为当USART1中的SR寄存器和0x40(bin码就是0100 0000)与运算后恒等于0时,往下执行。


所以在F0中,while((USART1->SR&0X40)==0)应改为while((USART1->CR1&0X40)==0)


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。