GPIOx_BSRR的高16位中每一位对应端口x的每个位,对高16位中的某位置'1'则端口x的对应位被清'0';寄存器中的位置'0',则对它对应的位不起作用。
GPIOx_BSRR的低16位中每一位也对应端口x的每个位,对低16位中的某位置'1'则它对应的端口位被置'1';寄存器中的位置'0',则对它对应的端口不起作用。
简单地说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;
GPIOE->BRR = ~Newdata & 0xff;
当然还可以一次完成对8位的操作:
GPIOE->BSRR = (Newdata & 0xff) | (~Newdata & 0xff)<<16;
从最后这个操作可以看出使用BSRR寄存器,可以实现8个端口位的同时修改操作。
如果不是用BRR和BSRR寄存器,则上述要求就需要这样实现:
GPIOE->ODR = GPIOE->ODR & 0xff00 | Newdata;
使用BRR和BSRR寄存器可以方便地快速地实现对端口某些特定位的操作,而不影响其它位的状态。
比如希望快速地对GPIOE的位7进行翻转,则可以:
GPIOE->BSRR = 0x80; // 置'1'
GPIOE->BRR = 0x80; // 置'0'
如果使用常规'读-改-写'的方法:
GPIOE->ODR = GPIOE->ODR | 0x80; // 置'1'
GPIOE->ODR = GPIOE->ODR & 0xFF7F; // 置'0'
有人问是否BSRR的高16位是多余的,请看下面这个例子:
假如你想在一个操作中对GPIOE的位7置'1',位6置'0',则使用BSRR非常方便:
GPIOE->BSRR = 0x400080;
如果没有BSRR的高16位,则要分2次操作,结果造成位7和位6的变化不同步!
GPIOE->BSRR = 0x80;
GPIOE->BRR = 0x40;
上一篇:STM32 GPIO BRR和BSRR寄存器
下一篇:STM32的sd卡的IAP升级固件教程
- 热门资源推荐
- 热门放大器推荐
设计资源 培训 开发板 精华推荐
- 使用 Nuvoton Technology Corporation 的 ISD17210 的参考设计
- Sg1825C 用于振荡器同步的高速电流模式 PWM 的典型应用
- 使用 Analog Devices 的 LT1120ACN8 的参考设计
- 小白入门级体验自制键盘——Az40_百变怪_V3
- ESP32 VGA控制器 可运行FABGL库
- 按键&LED模块
- 世界线变动仪控制板
- Cree XLamp MT-G2 LED 3 英寸筒灯参考设计
- AP7335-EV,用于采用 DFN2020-6 封装的 AP7335 低压差线性稳压器的评估模块
- LTC1859CG 演示板、8 通道、16 位、100ksps SoftSpan ADC
- 【EEWORLD第三十七届】2012年04月社区明星人物揭晓!
- 直播:计算机视觉影像处理应用于智能驾驶的未来及挑战
- TI 嵌入式处理主题直播月|报名观看直播赢好礼【低功耗WiFi MCU、Sitara AM57X平台、机器学习】
- 如何用3个关键步骤,来确保下一代设计安全性,深入解读嵌入式设备DeepCover加密控制器,看视频答题赢好礼!
- 2024安路科技FPGA技术研讨会-广州站 火热报名中
- 抢先体验!世界首款LoRa Soc单片机STM32WL
- 带你零起点入门STM32(专为嵌入式应用而开发的内核)
- 下载MPS汽车电机控制技术干货,赢【Keep体脂秤、自动洗手机套装、小米保温杯】,开启汽车技术进阶之旅!
- 最后一周报名,STM32中国峰会暨粉丝狂欢节,5月12-13日深圳