OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2896|回复: 2

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

[复制链接]

7

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
71
金钱
71
注册时间
2016-8-18
在线时间
28 小时
发表于 2017-3-15 10:10:52 | 显示全部楼层 |阅读模式
首先感谢原子哥和 小陀螺爱炒蛋 前辈,本人没有编程语言基础,在摸索把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)


正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

7

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
71
金钱
71
注册时间
2016-8-18
在线时间
28 小时
 楼主| 发表于 2017-3-15 13:30:44 | 显示全部楼层
更新一下,因为对应的数据存储寄存器不同,最后用库函数实现了。

int fputc(int ch,FILE *f)
{
        USART_SendData(USART1,(u8)ch);
        while(USART_GetFlagStatus(USART1,USART_FLAG_TXE)==RESET);
        return ch;
}
回复 支持 反对

使用道具 举报

9

主题

57

帖子

0

精华

初级会员

Rank: 2

积分
50
金钱
50
注册时间
2017-1-6
在线时间
32 小时
发表于 2017-3-15 14:41:24 | 显示全部楼层
原理基本都一样,就是寄存器名称和第几位为标志位不一样,是吧
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-12 17:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表