STM32F103固件库编程(2)—位带操作

STM32F103固件库编程(2)—位带操作

与51单片机对比

STM32F103的位带操作相当于51单片机的sbit。因为STM32F103每次操作都是4个字节(32位),所以我们要把一个位变成32位,其中膨胀后的最后一位就是原来的位。
这样之后,通过赋值0或1,就能控制最后一位(即原来的位)。

STM32F103的位带区

在这里插入图片描述

位带区和位带别名区地址转换

一个位膨胀成四个字节,这样便于STM32以4个字节的方式操作。

1.外设位带别名区地址

所在字节的地址为 A,位序号为 n(0<=n<=7)
AliasAddr= =0x42000000+ ((A-0x40000000)x8+n)*4

其中 (A-0x40000000)代表着地址偏移,(A-0x40000000)*8之后代表着位偏移,最后,一个地址里有8位,((A-0x40000000)x8+n)代表着总的位偏移,一个位要膨胀成四个字节,最后位偏移要×4代表着地址偏移的数。

2.SRAM位带别名区地址

所在字节的地址为 A,位序号为 n(0<=n<=7)
AliasAddr= =0x22000000+ (A-0x20000000)x8x4 +n*4

分析同上

3.统一公式

((addr & 0xF0000000)+0x02000000+((addr & 0x00FFFFFF)<<5)+(bitnum<<2))
统一公式就是给计算机理解用的,记住公式就行,上述分析已经让你知道了位带是怎么实现的,如果想具体了解这个公式,可以自行百度了解。

所以C语言的宏实现如下:

#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x02000000+((addr&0x00FFFFFF)<<5)+(bitnum<<2)) 

举个例子:(控制GPIOC第二个IO口)

在这里插入图片描述找到GPIOC的基地址:0x4001 1000
GPIOC_ODR的地址: 0x4001100C(基地址+地址偏移)
我们要控制第二个IO口,所以bitnum数值为2

#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x02000000+((addr&0x00FFFFFF)<<5)+(bitnum<<2)) 

BIATAND(0x4001100C,2) //为位带别名区的地址
地址强制转化成指针,
赋值1表示最后一位为1,原来的位是1,GPIOC第二个IO口输出高电平
赋值0表示最后一位为0,原来的位是0,GPIOC第二个IO口输出低电平
发布了2 篇原创文章 · 获赞 1 · 访问量 306

猜你喜欢

转载自blog.csdn.net/qq_42589654/article/details/104121394