STM32 BIT_BAND 位帶別名區(qū)使用入門支持了位帶操作(bit_band),有兩個(gè)區(qū)中實(shí)現(xiàn)了位帶。其中一個(gè)是SRAM 區(qū)的最低1MB 范圍,第二個(gè)則是片內(nèi)外設(shè) // 區(qū)的最低1MB 范圍。這兩個(gè)區(qū)中的地址除了可以像普通的RAM 一樣使用外,它們還都有自 // 己的“位帶別名區(qū)”,位帶別名區(qū)把每個(gè)比特膨脹成一個(gè)32 位的字 // // 每個(gè)比特膨脹成一個(gè)32 位的字,就是把 1M 擴(kuò)展為 32M , // // 于是;RAM地址 0X200000000(一個(gè)字節(jié))擴(kuò)展到8個(gè)32 位的字,它們是: // 0X220000000 ,0X220000004,0X220000008,0X22000000C,0X220000010,0X220000014, 0X220000018,0X22000001C // 支持位帶操作的兩個(gè)內(nèi)存區(qū)的范圍是: // 0x2000_0000‐0x200F_FFFF(SRAM 區(qū)中的 // 0x4000_0000‐0x400F_FFFF(片上外設(shè)區(qū)中的最低1MB) /* 對(duì)SRAM 位帶區(qū)的某個(gè)比特,記它所在字節(jié)地址為A,位序號(hào) 在別名區(qū)的地址為: AliasAddr= 0x22000000 +((A‐0x20000000)*8+n)*4 =0x22000000+ (A‐0x20000000)*32 + n*4 對(duì)于片上外設(shè)位帶區(qū)的某個(gè)比特,記它所在字節(jié)的地址為A,位序號(hào)為n(0<=n<=7),則該比特 在別名區(qū)的地址為: AliasAddr= 0x42000000+((A‐0x40000000)*8+n)*4 =0x42000000+ (A‐0x40000000)*32 + n*4 上式中,“*4”表示一個(gè)字為4 個(gè)字節(jié),“*8”表示一個(gè)字節(jié)中有8 個(gè)比特。 */ // 把“位帶地址+位序號(hào)”轉(zhuǎn)換別名地址宏 #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2)) //把該地址轉(zhuǎn)換成一個(gè)指針 #define MEM_ADDR(addr) *((volatile unsigned long *)(addr)) // MEM_ADDR(BITBAND( (u32)&CRCValue,1)) = 0x1; 例如點(diǎn)亮LED // 使用STM32庫(kù) GPIO_ResetBits(GPIOC, GPIO_Pin_4); //關(guān)LED5 GPIO_SetBits(GPIOC, GPIO_Pin_7); //開LED2 // 一般讀操作 STM32_Gpioc_Regs->bsrr.bit.BR4 =1;// 1:清除對(duì)應(yīng)的ODRy位為0 STM32_Gpioc_Regs->bsrr.bit.BS7 =1;// 1:設(shè)置對(duì)應(yīng)的ODRy位為1 //如果使用 位帶別名區(qū)操作 STM32_BB_Gpioc_Regs->BSRR.BR[4] =1;// 1:清除對(duì)應(yīng)的ODRy位為0 STM32_BB_Gpioc_Regs->BSRR.BS[7] =1;// 1:設(shè)置對(duì)應(yīng)的ODRy位為1 代碼比STM32庫(kù) 高效 十倍 !
|
|
|