Cortex m3支持了位带操作,有两个区中实现了位带。其中一个是 SRAM 区的最低 1MB 范围,第二个则是片内外设区的最低 1MB 范围。这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。
//SRAM位带区域: 0x2000 0000~0x200F 0000
//SRAM位带别名区域: 0x2200 0000~0x23FF FFFF
//外设位带区域: 0X4000 0000~0X400F FFFF
//外设位带别名区域: 0X4200 0000~0X43FF FFFF
#define BITBAND(addrerss, bitnum) ((addrerss & 0xF0000000)+0x02000000+((addrerss & 0x000FFFFF)<<5)+(bitnum<<2))
#define MEM_ADDRESS(addrerss) ( *((volatile unsigned long *)(addrerss)))
#define BIT_ADDRESS(addrerss, bitnum) MEM_ADDRESS(BITBAND(addrerss, bitnum))