1、。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位
2、不变,假设新的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)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;