|
1 定义 首先需要明确下,位段,位带和别名区这三个名词 名词定义 位段 STM32用户参考手册使用的名字 位带 CortexM3参考手册使用的 别名区 地址总线上用来位访问地址区域, 所以说,位段和位带是一个意思,是不同手册的不同叫法。 由上述的名词解释得知,位带功能并不是STM32独有的,是CortexM3的功能(CortexM4也有这样的功能)。MCS51有位操作,以一位(bit)为数据对象的操作,MCS51可以简单的将P1口的第2位独立操作:P1.2=0; P1.2=1 ;这样就把P1口的第三个脚(bit2)置0置1。而STM32的位段、位带别名区最重要的就为了实现这样的功能。 2 位带操作 2.1 范围 位带是有范围的,并不是CortexM3全部地址空间都支持的。在 CM3中,有两个区中实现了位带。其中一个是 SRAM 区的最低 1MB 范围,第二个则是片内外设区的最低 1MB 范围。这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。 支持位带操作的两个内存区的范围是: 0x2000_0000‐0x200F_FFFF(SRAM 区中最低1MB区域) 0x4000_0000‐0x400F_FFFF(片上外设区中的最低 1MB) 2.2 位带操作 对 SRAM 位带区的某个比特,记该比特所在字节的地址为A,位序号为 n (0<=n<=7),则它在别名区的地址为:
对于片上外设位带区的某个比特,记该比特所在字节的地址为A,位序号为 n (0<=n<=7),则该比特在别名区的地址为:
上式中,“*4”表示一个字为 4 个字节,“*8”表示一个字节中有 8 个比特。
2.3代码实现 把“位带地址+位序号”转换别名地址宏为:
把该地址转换成一个指针:
其中 addr的取值范围: 0x2000_0000‐0x200F_FFFF 0x4000_0000‐0x400F_FFFF 注意:addr取值要32位对齐 bitnum的取值范围: 0-31 解析: (addr & 0xf0000000) + 0x02000000: 区分SRAM还是外设,如果是外设,结果为4,再加0x2000000就等于0x4200000,0x42000000就是外设别名位带区。如果是SRAM,结果为2,再加上0x2000000就等于0x22000000,0x22000000就是SRAM别名位带区。 addr & 0x00ffffff: 屏蔽了最高2位,相当于减去0x20000000或者0x40000000。因为位带区的有效范围是1M,即0x100000,这样子就做到了低6位有效。 << 5: 等价于乘以32 << 2: 等价于乘以4 特别提醒 3 位段的优点 最容易想到的就是通过 GPIO 的管脚来单独控制每盏 LED 的点亮与熄灭。另一方面,也对操作串行接口器件提供了很大的方便(典型如 74HC165,CD4094)。位带操作可以把代码缩小, 速度更快,效率更高,更安全。总之位带操作对于硬件 I/O 密集型的底层程序最有用处了 位带操作还能用来化简跳转的判断。 当跳转依据是某个位时,以前必须这样做 1、读取整个寄存器 2、掩蔽不需要的位 3、比较并跳转 使用位带操作后 1、从未带别名区读取状态位 2、比较并跳转
当然,对于写入操作也从4步精简到3步
|
STM32
超强工具——STM32CubeMX 你会用吗?
集结出发! STM32全国研讨会系列之一:ST智能门铃中国首秀
关于STM32启动文件的几个小问题
【银杏科技ARM+FPGA双核心应用】STM32H7系列35——USB_VCP_FS
【银杏科技ARM+FPGA双核心应用】STM32H7系列28——USB_HID
粉丝分享 | 图说CRC原理应用及STM32硬件CRC外设
STM32L151进入低功耗,并由RTC唤醒的故事
[转]stm32控制NFC模块(PN532)源码(P2P,模拟卡,读写卡等
STM32G070RB+LVGL移植
微信公众号
手机版