手册中说:6 b* r8 R& M3 Q6 }0 n' a5 S) `0 [ In the STM32F20x and STM32F21x both the peripheral registers and the SRAM are mapped to a bit-band region, so that single bit-band write and read operations are allowed.' ~) u+ R# p0 s1 q) r 在这两个系列中外设和SRAM都有各自映射的位带区,以实现对位的单独操作。 The operations are only available for Cortex ® -M3 accesses, and not from other bus masters (e.g. DMA). 使用局限于M3内核。6 r! j8 Y5 M: e2 | A mapping formula shows how to reference each word in the alias region to a corresponding bit in the bit-band region. The mapping formula is: 地址映射公式如下 bit_word_addr = bit_band_base + ( byte_offset x 32) + ( bit_number × 4)! x8 S d* B% V! W where: – bit_word_addr is the address of the word in the alias memory region that maps to the targeted bit( k+ l. n3 c) |: B( t 一位扩展成了一个字。: m) s, z- `- L3 ? – bit_band_base is the starting address of the alias region& n& N! {5 T3 W2 H/ g; Y8 r8 g 位带基地址是对应位带的起始地址。) \( p$ t& J4 d4 w/ j – byte_offset is the number of the byte in the bit-band region that contains the targeted bit, L" ~. h5 f) p; n# p U 这里的偏移值为包含操作位的寄存器偏移值。 – bit_number is the bit position (0-7) of the targeted bit 1 H. \; C8 C. m 这里的位就是目标位。) N& o5 J4 S; ] & {: S. z& v% R; o% z9 ~, t) c 位带区在 SRAM上的地址范围:0x20000000 ~ 0x200FFFFF(SRAM区中最低1MB)7 g( ^/ A- b) s u7 \# I 位带识别区在SRAM上的地址范围: 0x22000000 ~ 0x220FFFFF 位带区在片上外设的地址范围:0x4000 0000-0x400F FFFF(片上外设区中的最低1MB), 位带识别区在片上外设的地址范围:0x4200 0000~0x42FF FFFF; 对应关系:位带区的每个bit位的值 对应 位带识别区1个 32位的地址的内容;; O# r/ L& o; {* x 所以位带操作是:当你通过位带别名区访问这些32位的地址的内容时,就可以达到访 问位带区对应的比特位。 5 |1 `8 Y8 o. ?0 P U 举例:; o9 K: J% q4 B# M8 Y+ E1 b 要给GPIO PC15做拉高拉低操作。5 b$ e/ E: J3 X, B0 n0 g( K 首先找到操作寄存器的地址: N: u2 i8 t( D GPIO为外设,故需用外设的基地址: PERIPH_BASE ((uint32_t)0x40000000) GPIOC在AH1外设上,故在之前基础上再做偏移:AHB1PERIPH_BASE (PERIPH_BASE + 0x00020000) 同时需要再加上GPIOC的偏移: GPIOC_BASE (AHB1PERIPH_BASE + 0x0800)9 e& l+ Q; i5 r0 G+ Z2 B 然后找到位设置寄存器: GPIOC_BSRR (GPIOC_BASE + 0x18)+ D" p/ Z# I6 f! X2 u / R) R! ?& W4 |9 R+ E2 ^% k 最终得到的地址为 :0x40020818 通常情况下向这个地址赋值即可实现指定位拉高拉低操作: *((volatile unsigned long *) 0x40020818) = 0x80000000 //!<拉高! O! m5 F+ L0 ]2 f V *((volatile unsigned long *) 0x40020818) = 0x00008000 //!<拉低 : v5 l8 c1 W+ n6 J U% F( N$ v 但通过位带,按照公式获取位带操作地址: /*这是拉高时寄存器地址*/: B( `% ~1 P# \1 h: q/ N6 C R AddrH = *((volatile unsigned long *)(( 0x40020818 & 0xF0000000)+0x2000000+(( 0x40020818 & 0xFFFFF)<<5)+(15 << 2))) AddrH = 1; //!<置1就拉高 6 V2 K8 B P7 y3 u /*这是拉低时寄存器地址*/ AddrL = *((volatile unsigned long *)(( 0x40020818 & 0xF0000000)+0x2000000+(( 0x40020818 & 0xFFFFF)<<5)+((15+16) << 2))) ) o6 u; _+ v7 R9 ?# q9 n% X AddrL = 1; //!<置1就拉低 ; V+ H: y! O5 k8 _ 使用宏定义,即:(Addr为 GPIOC_BSRR 拉高时 BitNum为15 拉低时 BitNum是(15+16) ) #define BitBand(Addr,BitNum) *((volatile unsigned long *)((Addr & 0xF0000000)+0x2000000+((Addr & 0xFFFFF)<<5)+(BitNum << 2))) 8 _( l" y" Z9 s' M1 `$ B 精简之后 ,位带操作 :/ _( u* f- g: X1 t" J, c1 f #define BitBand(Addr,BitNum) *((volatile unsigned long *)(PERIPH_BB_BASE|((Addr-PERIPH_BASE)<<5)|(BitNum << 2))) |
stm32f207/stm32f407擦除内部flash讲解
【经验分享】STM32F2 中 DMA 的 FIFO 模式
STM32F2x7 通过以太网实现在应用中编程 (IAP)
STM32F2xx 微控制器中的 EEPROM 模拟
在 STM32 F0、 F2、 F3、 F4 和 L1 系列MCU 中使用硬件实时时钟 (RTC)
STM32F1xx、STM32F2xx、STM32F4xx、STM32L1xx、STM32F30/31/37/38x 定时器概览
使用 STM32F2xx 和 STM32F4xx 微控制器时如何提高 ADC 测量精度
使用 STM32F2 和 STM32F4 DMA 控制器
STM32F2x7 通过以太网实现在应用中编程 (IAP)
STM32F2xx 微控制器中的 EEPROM 模拟