STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx

上传人:b****1 文档编号:13162410 上传时间:2022-10-07 格式:DOCX 页数:2 大小:10.04KB
下载 相关 举报
STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx_第1页
第1页 / 共2页
STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx

《STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx》由会员分享,可在线阅读,更多相关《STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx(2页珍藏版)》请在冰豆网上搜索。

STM使用BSRR和BRR寄存器快速操作GPIO端口方法说明Word下载.docx

GPIOx_BSRR的高16位中每一位对应端口x的每个位,对高16位中的某位置'

则端口x的对应位被清'

寄存器中的位置'

,则对它对应的位不起作用。

GPIOx_BSRR的低16位中每一位也对应端口x的每个位,对低16位中的某位置'

则它对应的端口位被置'

,则对它对应的端口不起作用。

简单地说GPIOx_BSRR的高16位称作清除寄存器,而GPIOx_BSRR的低16位称作设置寄存器。

另一个寄存器GPIOx_BRR只有低16位有效,与GPIOx_BSRR的高16位具有相同功能。

举个例子说明如何使用这两个寄存器和所体现的优势。

例如GPIOE的16个IO都被设置成输出,而每次操作仅需要改变低8位的数据而保持高8位不变,假设新的8位数据在变量Newdata中,

这个要求可以通过操作这两个寄存器实现,STM32的固件库中有两个函数GPIO_SetBits()和GPIO_ResetBits()使用了这两个寄存器操作端口。

上述要求可以这样实现:

GPIO_SetBits(GPIOE,Newdata&

0xff);

GPIO_ResetBits(GPIOE,(~Newdata&

0xff));

也可以直接操作这两个寄存器:

GPIOE->

BSRR=Newdata&

0xff;

BRR=~Newdata&

当然还可以一次完成对8位的操作:

BSRR=(Newdata&

0xff)|(~Newdata&

0xff)<

<

16;

从最后这个操作可以看出使用BSRR寄存器,可以实现8个端口位的同时修改操作。

如果不是用BRR和BSRR寄存器,则上述要求就需要这样实现:

ODR=GPIOE->

ODR&

0xff00|Newdata;

使用BRR和BSRR寄存器可以方便地快速地实现对端口某些特定位的操作,而不影响其它位的状态。

比如希望快速地对GPIOE的位7进行翻转,则可以:

BSRR=0x80;

//置'

BRR=0x80;

如果使用常规'

读-改-写'

的方法:

ODR|0x80;

0xFF7F;

有人问是否BSRR的高16位是多余的,请看下面这个例子:

假如你想在一个操作中对GPIOE的位7置'

,位6置'

,则使用BSRR非常方便:

GPIOE->

BSRR=0x4080;

如果没有BSRR的高16位,则要分2次操作,结果造成位7和位6的变化不同步!

BRR=0x40;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试认证 > 财会金融考试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1