STM32中的位带(bit-band)操作.doc

上传人:白大夫 文档编号:3273579 上传时间:2019-08-07 格式:DOC 页数:3 大小:19KB
返回 下载 相关 举报
STM32中的位带(bit-band)操作.doc_第1页
第1页 / 共3页
亲,该文档总共3页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《STM32中的位带(bit-band)操作.doc》由会员分享,可在线阅读,更多相关《STM32中的位带(bit-band)操作.doc(3页珍藏版)》请在三一文库上搜索。

1、STM32中的位带(bit-band)操作支持了位带操作后,可以使用普通的加载/存储指令来对单一的比特进行读写。在 CM3 中,有两个区中实现了位带。其中一个是 SRAM 区的最低 1MB 范围,第二个则是片内外设区的最低 1MB范围。这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区”,位带别名区把每个比特膨胀成一个 32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。位带操作的概念其实 30 年前就有了,那还是8051 单片机开创的先河,如今,CM3 将此能力进化,这里的位带操作是 8051 位寻址区的威力大幅加强版。CM3 使用如下

2、术语来表示位带存储的相关地址:位带区:支持位带操作的地址区位带别名:对别名地址的访问最终作用到位带区的访问上(这中途有一个地址映射过程)在位带区中,每个比特都映射到别名地址区的一个字这是只有 LSB 有效的字。当一个别名地址被访问时,会先把该地址变换成位带地址。对于读操作,读取位带地址中的一个字,再把需要的位右移到 LSB,并把 LSB 返回。对于写操作,把需要写的位左移至对应的位序号处,然后执行一个原子的“读-改-写”过程。支持位带操作的两个内存区的范围是:0x2000_00000x200F_FFFF(SRAM 区中的最低 1MB)0x4000_00000x400F_FFFF(片上外设区中的

3、最低 1MB)对 SRAM 位带区的某个比特,记它所在字节地址为 A,位序号为 n(0ain copy/位带操作,实现51类似的GPIO控制功能/具体实现思想,参考第五章(87页92页)./IO口操作宏定义#define BITBAND(addr, bitnum) (addr #define MEM_ADDR(addr) *(volatile unsigned long *)(addr)#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum)/IO口地址映射#define GPIOA_ODR_Addr (GPIOA_BASE+1

4、2) /0x4001080C#define GPIOB_ODR_Addr (GPIOB_BASE+12) /0x40010C0C#define GPIOC_ODR_Addr (GPIOC_BASE+12) /0x4001100C#define GPIOD_ODR_Addr (GPIOD_BASE+12) /0x4001140C#define GPIOE_ODR_Addr (GPIOE_BASE+12) /0x4001180C#define GPIOF_ODR_Addr (GPIOF_BASE+12) /0x40011A0C#define GPIOG_ODR_Addr (GPIOG_BASE+1

5、2) /0x40011E0C#define GPIOA_IDR_Addr (GPIOA_BASE+8) /0x40010808#define GPIOB_IDR_Addr (GPIOB_BASE+8) /0x40010C08#define GPIOC_IDR_Addr (GPIOC_BASE+8) /0x40011008#define GPIOD_IDR_Addr (GPIOD_BASE+8) /0x40011408#define GPIOE_IDR_Addr (GPIOE_BASE+8) /0x40011808#define GPIOF_IDR_Addr (GPIOF_BASE+8) /0x

6、40011A08#define GPIOG_IDR_Addr (GPIOG_BASE+8) /0x40011E08/IO口操作,只对单一的IO口!/确保n的值小于16!#define PAout(n) BIT_ADDR(GPIOA_ODR_Addr,n) /输出#define PAin(n) BIT_ADDR(GPIOA_IDR_Addr,n) /输入#define PBout(n) BIT_ADDR(GPIOB_ODR_Addr,n) /输出#define PBin(n) BIT_ADDR(GPIOB_IDR_Addr,n) /输入#define PCout(n) BIT_ADDR(GPIO

7、C_ODR_Addr,n) /输出#define PCin(n) BIT_ADDR(GPIOC_IDR_Addr,n) /输入#define PDout(n) BIT_ADDR(GPIOD_ODR_Addr,n) /输出#define PDin(n) BIT_ADDR(GPIOD_IDR_Addr,n) /输入#define PEout(n) BIT_ADDR(GPIOE_ODR_Addr,n) /输出#define PEin(n) BIT_ADDR(GPIOE_IDR_Addr,n) /输入#define PFout(n) BIT_ADDR(GPIOF_ODR_Addr,n) /输出#define PFin(n) BIT_ADDR(GPIOF_IDR_Addr,n) /输入#define PGout(n) BIT_ADDR(GPIOG_ODR_Addr,n) /输出#define PGin(n) BIT_ADDR(GPIOG_IDR_Addr,n) /输入

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1