我相信很多朋友在学习单片机之前都学习过51单片机,假设在51单片机的P1.1的IO口上挂了一个LED,那么你单独对LED的操作就是P1.1 = 0或P1.1 = 1,这样你就可以单独的对P1端的第一个IO口进行上下拉操作,然而对于STM32,是没有这种操作的,那么为了像51单片机一样能够单独的对某个端的某一个IO单独操作,就引入了__位带操作__,简而言之,就是为了去单独操作STM32里面PA的第1个IO口,所以才有了位带这样的操作机制。
1 什么是位带操作
在讲解位带操作之前,首先要搞清楚什么是位带操作。我们知道,32位的处理器的32位地址总线提供了4G的地址空间,几乎所有的嵌入式产品是足够用的。 Cortex-M就利用了额外的空间实现了称为位带(Bit-Banding)操作的硬件属性,该技术使用地址空间的两个不同区域来指向同一物理地址 。在主位带区域,每个地址对应一个字节的数据,在“位带别名”区域中,每个地址对应同一个数据的一个位。
如下图所示。在CM3的寄存器映射图中有1MB的 bit band区,这里被称为位带区,与之对应的是32MB的bit band别名区,这里被称为位带别名区。
STM32的位带别名区会把位带区中的每一位膨胀成一个32位的字,所以相应的别名区的内存也会是位带区的32倍。从上图可以看出,位带操作同时支持SRAM和片上外设,支持位带操作的两个内存区域范围如下:
SRAM区:0x20000000 ~ 0x200FFFFF,最低1M的范围;
片上外设区: 0x40000000 ~ 0x400FFFFF,最低1M的范围;
位带操作就是把位带区中一个地址的8个位分别映射到位带别名区的8个地址(LSB有效,即最低位有效),通过操作相应地址的方式实现操作某个位。以SRAM为例,位带区和位带别名区的映射如下图所示: