STM32位带解析
本人最近根据正点原子的视频自学STM32,在学习STM32的的位带操作操作时,只是介绍到了位带别名区把位带区的每一个比特位膨胀成32位的字,即位带区的每一个比特位对应位带别名区中一个4个字节大小的地址。下图示例SRAM区中的最低1MB的位带区与位带别名区的膨胀对应关系:
转换公式
对于我这种初学者来说,我会想知道具体怎么去计算,但是又对位操作比较陌生,所以特地的去查了一下怎么去做计算,并记录下来,希望能给同样是初学者带来帮助,以0x200FFFFF为例:
1.A = 0x200FFFFF
2.A - 0x20000000 = 0xFFFFF
3.(A - 0x20000000) * 32 = 0xFFFFF *32 = 0x1FFFFE0
由于32 = 2^5; 所以相当于0xFFFFF向左移5位,即为0x1FFFFE0;
4.假设
n = 0;
AliasAddr = 0x22000000 + 0x1FFFE0 + 0x00 = 0x23FFFFE0
n = 1;
AliasAddr = 0x22000000 + 0x1FFFE0 + 0x04 = 0x23FFFFE4
…
…
n = 7; (4*7 = 28 = 0x1C)
AliasAddr = 0x22000000 + 0x1FFFE0 + 0x1C = 0x23FFFFFC
注:
0xFFFFF = 1111 1111 1111 1111 1111 左移5位得到
0001 1111 1111 1111 1111 1110 0000 = 0x1FFFFE0