野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 9065|回复: 3

GPIO的BSRR和BRR寄存器的看法

[复制链接]
发表于 2018-5-24 10:48:11 | 显示全部楼层 |阅读模式
BSRR的低16bit用于对端口位置1,而高16bit用于对端口位置0,也就是说GPIO如果要全置1就赋值BSRR为0x00FF,如果要全置0就赋值BSRR为0xFF00。
那么,BRR做什么用呢?BRR的高16bit保留不用,低16bit 用于对GPIO清除,这点和BSRR的高16bit作用一样啊。
可不可以认为其实BRR只是BSRR高16位的另一种使用,为的是让对GPIO设置的时候只使用16bit数据类型,也就是不论置1还是置0都统一使用UINT16_T,
比如全清除不用使用0xFF00,而是0xFF。
回复

使用道具 举报

发表于 2018-5-24 14:33:45 | 显示全部楼层
是的,其实它就是设计冗余,两个寄存器实现同样的功能
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-24 15:00:27 | 显示全部楼层
贡慧丽 发表于 2018-5-24 14:33
是的,其实它就是设计冗余,两个寄存器实现同样的功能

谢谢回复!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-24 15:08:04 | 显示全部楼层
明白了,除了冗余外其实还方便了对引脚的宏定义。只需定义一种引脚宏就可以用于SetBits和ResetBits函数内作参数。
回复 支持 反对

使用道具 举报

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

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-11-24 03:21 , Processed in 0.028738 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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