您的位置 首页 资料

STM32 位带使用

Cortex-M3支持了位操作后,可以使用普通的加载/存储指令来对单一的比特进行读写。在CM3支持的位带中,有两个区中实现了位带。…

Cortex-M3 支撑了位操作后,能够运用一般的加载/存储指令来对单一的比特进行读写。

  在 CM3 支撑的位带中,有两个区中完成了位带。
  其间一个是 SRAM区的最低 1MB 规模, 0x20000000 ‐ 0x200FFFFF(SRAM 区中的最低 1MB);
  第二个则是片内外设区的最低 1MB规模, 0x40000000 ‐ 0x400FFFFF(片上外设区中的最低 1MB)。

这两个区中的地址除了能够像一般的 RAM 相同运用外,它们还都有自己的“位带别号区”,位带别号区把

每个bit胀大成一个 32 位的字。当你通过位带别号区拜访这些字时,就能够到达拜访原始比特的意图。

如RAM 地址0x20000000(一个字节)扩展到“位带别号区”的8个32位的字,分别是

0x20000000.0=0x22000000, 0x20000000.1=0x22000004,

0x20000000.2=0x22000008, 0x20000000.3=0x2200000C,
0x20000000.4=0x22000010, 0x20000000.5=0x22000014,

0x20000000.6=0x22000018, 0x20000000.7=0x2200001C,

CM3 运用如下术语来一共位带存储的相关地址
   * 位带区: 支撑位带操作的地址区
   * 位带别号: 对别号地址的拜访终究效果到位带区的拜访上(留意:这中心有一个地址映射进程)
  位带区中的每个比特都映射到别号地址区的一个字 —— 这是只要 LSB 有用的字(位带别号区的字只要最低位有意义)。

  关于SRAM中的某个比特,该比特在位带别号区的地址:
AliasAddr = 0x22000000 + ((A‐0x20000000)*8+n)*4 = 0x22000000 + (A‐0x20000000)*32 + n*4
关于片上外设位带区的某个比特, 该比特在位带别号区的地址:
AliasAddr = 0x42000000 + ((A‐0x40000000)*8+n)*4 = 0x42000000 + (A‐0x40000000)*32 + n*4
  其间 A 为该比特地点的字节的地址,0 <= n <= 7“*4”一共一个字为 4 个字节,“*8”一共一个字节中有 8 个比特。
当然,位带操作并不只限于以字为单位的传送。亦能够按半字和字节为单位传送。  

  位带操作有许多优点,其间重要的一项便是,在多使命体系中,用于完成共享资源在使命间的“互锁”拜访。多使命的共享资源有必要分量一次只要一个使命拜访它——亦即所谓的“原子操作”。

把“位带地址+位序号”转化别号地址宏
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
把该地址转化成一个指针
#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))

可进行位操作。
BIT_ADDR(PORTA, 2)=0;// GPIOA.2 = 0;
BIT_ADDR(PORTB, 3)=1;// GPIOB.3 = 4;

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/264813.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部