OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4479|回复: 2

麻烦大家帮我解释下 下面这当个定义是什么意思,有什么作用,谢谢了

[复制链接]

6

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2014-3-21
在线时间
0 小时
发表于 2014-10-8 10:53:56 | 显示全部楼层 |阅读模式
5金钱
#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))
尽可能详细解释下,或者告知哪里有相关资料查看,再次感谢!

最佳答案

查看完整内容[请看2#楼]

这是M3的位带操作。 在《ARM Cortex-M3权威指南》里有详细解释。 以下摘自手册: 在CM3中,有两个区中实现了位带。其中一个是SRAM 区的最低1MB 范围(0X20000000~0X20100000),第二个则是片内外设 区的最低1MB 范围(0X22000000~0X23FFFFFF)。这两个区中的地址除了可以像普通的RAM 一样使用外,它们还都有自己的 “位带别名区”,位带别名区把每个比特膨胀成一个32 位的字。当你通过位带别名区访问这些字时,就可以 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

93

帖子

0

精华

初级会员

Rank: 2

积分
194
金钱
194
注册时间
2014-3-12
在线时间
9 小时
发表于 2014-10-8 10:53:57 | 显示全部楼层
这是M3的位带操作。
在《ARM Cortex-M3权威指南》里有详细解释。

以下摘自手册:
在CM3中,有两个区中实现了位带。其中一个是SRAM 区的最低1MB 范围(0X20000000~0X20100000),第二个则是片内外设
区的最低1MB 范围(0X22000000~0X23FFFFFF)。这两个区中的地址除了可以像普通的RAM 一样使用外,它们还都有自己的
“位带别名区”,位带别名区把每个比特膨胀成一个32 位的字。当你通过位带别名区访问这些字时,就可以达到访问原始比特的目的。


功夫再高、也怕羊刀
回复

使用道具 举报

65

主题

440

帖子

0

精华

高级会员

Rank: 4

积分
782
金钱
782
注册时间
2012-8-29
在线时间
17 小时
发表于 2014-10-8 15:41:42 | 显示全部楼层
通过位带的方式把物理地址抽象出来,
人生永远追逐着幻光,但谁把幻光看作幻光,谁便沉入无边的苦海
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-30 18:13

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表