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