历史上的今天
今天是:2024年09月12日(星期四)
2019年09月12日 | 秉火429笔记之七位带操作
2019-09-12 来源:eefocus
位带概况
位操作,简单的理解,可以单独的对一个比特位读和写,51单片机非常常见。类如,51单片机通过关键字sbit来实现位定义,STM32并没有这个关键字,而是通过访问位带别名区(Bit band alias)来实现的。
通过查看《M4内核参考手册》3.4 system address map 可知下图:

M4中2个区域实现了位带,其一为SRAM的最低1MB空间,其二为外设区域的最低1MB空间。
参考3.7 Bit-banding 可知,位带区的一个比特经过膨胀后,虽然变大到4个字节,但是还是LSB才有效。有人会问这不是浪费空间吗,要知道F429的系统总线是32位的,按照4个字节访问的时候是最快的,所以膨胀成4个字节来访问是最高效的。通过指针的形式访问位带别名区地址从而达到操作位带区比特位的效果。
// 把“位带地址+位序号”转换成别名地址的宏
#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x02000000+((addr & 0x000FFFFF)<<5)+(bitnum<<2))
// 把一个地址转换成一个指针
#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
// 把位带别名区地址转换成指针
#define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
上一篇:秉火429笔记之五控制RGB彩灯
下一篇:秉火429笔记之四启动文件分析
史海拾趣
|
pc机的emulator中编译成功的程序怎么在WinCE系统中运行呢? 我在PC机上用eVC写了一段程序,并且在Win32{WCE emulator} Debug中运行通过,怎么才能让这段程序在一个ARM9的WinCE系统下运行呢? 小弟初学eVC,求各位给个详细点儿的过程吧,在线等,感激不尽...… 查看全部问答> |
|
在注册表里面把NAND Flash文件夹的名称全部修改后,打开资源管理器发现NAND Flash的名字并没有有改,不通过修改bsp可以修改名称吗?… 查看全部问答> |
|
有人做过 wince bsp的开发吗? 我想在PC104上 定制wince内核 可是 厂家没有提供 BSP 这个比较头疼 有大侠 做过 BSP 定制吗? 小弟 MSN : yh052720@163.com QQ : 10648820 … 查看全部问答> |
|
高手帮忙!xxx_Init 初始化的结构体 到xxx_Open 怎么好多成员变了阿 还请高手帮帮忙,郁闷死我了。。。 我的设备结构体如下, typedef struct { CHANEL chA; //A通道 CHANEL chB; //B通道 DWORD Xtal; //晶振频率 &nbs ...… 查看全部问答> |
|
请大虾们帮我看看阿 我的中断怎么老进不去阿: 我用的是LPC2119芯片 用于检测频率信号 可是中断老是进不去 请大家帮我看看 是不是那地方配置有问题呢? #include \"config.h\" uint16 Fdiv; uint8 p; uint8 flag_ri; uint32 T1temp0,T1temp ...… 查看全部问答> |
|
大家好,刚接触LM3S,有几个问题想请教大家: 看fengzhang2002的帖子加仿真器是什么意思,没有明白?我原以为把JTAG的脚引出,然后直接接ULINK2来调试和编程,不知道这样行不行?这样是不是只需要7根线就行了? 另外,像按钮这些,是不是可以通过 ...… 查看全部问答> |
|
厨房部分的功能全部调试完毕,只差无线调试和串口调试了!烟雾部分:模拟开关:温湿度部分:步进电机部分:整体:各部分心得会逐步分享,请大家指正!… 查看全部问答> |




