OpenEdv-开源电子网

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

GPIO配置为输入上下拉时为什么需要设置BSRR和BRR?

[复制链接]

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
发表于 2018-5-25 15:52:55 | 显示全部楼层 |阅读模式
1金钱
看到GPIO_Init()函数,其中对端口配置成输入上拉或下拉时除了正常配置CRL、CRH的相应数据为1000外,还需要操作BSRR和BRR。
当输入上拉时设置BSRR相应位为1,当输入下拉时设置BRR相应位为1,这在原理上是为什么?

最佳答案

查看完整内容[请看2#楼]

BSRR也好,BRR也好,都是和ODR一样的效果。 stm32f103系列,就是靠ODR的值来决定上下拉的。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-5-25 15:52:56 | 显示全部楼层
BSRR也好,BRR也好,都是和ODR一样的效果。 stm32f103系列,就是靠ODR的值来决定上下拉的。
回复

使用道具 举报

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
 楼主| 发表于 2018-5-28 08:09:16 来自手机 | 显示全部楼层
可以这样认为吗:一个端口设置成上拉输入的话就需要设置输出相关寄存器BSRR,否则就不能起到上拉输入作用。输入输出一起设置有些错觉。
回复

使用道具 举报

20

主题

450

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4904
金钱
4904
注册时间
2017-7-6
在线时间
720 小时
发表于 2018-5-28 10:04:44 | 显示全部楼层
看数据手册,设置输入下拉上拉,你就必须有区别是上拉还是下拉,所以STM32公司就用这个ODRx寄存器区别是上拉还是下拉了。
1527472991(1).jpg
我是小白,很白很白的小白!!!
回复

使用道具 举报

29

主题

338

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1181
金钱
1181
注册时间
2018-4-13
在线时间
170 小时
 楼主| 发表于 2018-5-31 09:27:16 | 显示全部楼层
程功之道 发表于 2018-5-28 10:04
看数据手册,设置输入下拉上拉,你就必须有区别是上拉还是下拉,所以STM32公司就用这个ODRx寄存器区别是上 ...

谢谢!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-2 20:14

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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