OpenEdv-开源电子网

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

针对M3内核的位带寻址的问题疑惑?

[复制链接]

35

主题

154

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
362
金钱
362
注册时间
2014-7-30
在线时间
49 小时
发表于 2016-3-21 16:34:55 | 显示全部楼层 |阅读模式
1金钱
有一个疑问,正如M3权威指南书上介绍的,片上SRAM 的32M的位带别名区地址范围是0x2200 0000~0x23ff ffff,我们知道0x2200 0000 别名是0X2000 0000位带地址的第0位,然而,0x2200 0000 本身这个地址就只有表示这个位的意思了么。就不能表示另外的一个字节的地址了么?我的意思就是只要用到0x2200 0000这个地址,就单单指对应的一个位的地址么?

最佳答案

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

ARM当初划定这个框架,赌的就是你芯片厂商不会把RAM或者外设做的那么大! 举例来说,RAM规定是从0x2000-0000开始的,要想达到0x2200-0000,那么RAM至少做到了32MB那么大了,在Cortex-M内核定位的应用场景里,绝对不需要这么大的RAM, 所以那片地址只用于位带操作,不会有别的功能。
我就是我,是颜色不一样的烟火。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

1097

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3571
金钱
3571
注册时间
2014-12-2
在线时间
365 小时
发表于 2016-3-21 16:34:56 | 显示全部楼层
ARM当初划定这个框架,赌的就是你芯片厂商不会把RAM或者外设做的那么大!

举例来说,RAM规定是从0x2000-0000开始的,要想达到0x2200-0000,那么RAM至少做到了32MB那么大了,在Cortex-M内核定位的应用场景里,绝对不需要这么大的RAM,

所以那片地址只用于位带操作,不会有别的功能。
坚决不用寄存器,拒绝重复造轮子。
回复

使用道具 举报

35

主题

154

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
362
金钱
362
注册时间
2014-7-30
在线时间
49 小时
 楼主| 发表于 2016-3-21 17:01:03 | 显示全部楼层
在 CM3 中,有两个区中实现了位带。其中一个是 SRAM 区的最低 1MB 范围,第二个则是片内外设区的最低 1MB范围。这两个区中的地址除了可以像普通的 RAM 一样使用外,它们还都有自己的“位带别名区,难道位带别名区32M的寻址范围只能当做位的别名,不能做普通的SRAM来用了么?况且位带别名区还是每隔四个字节的地址才对应一个位区的一个位?
回复

使用道具 举报

35

主题

154

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
362
金钱
362
注册时间
2014-7-30
在线时间
49 小时
 楼主| 发表于 2016-3-23 08:49:03 | 显示全部楼层
xkwy 发表于 2016-3-21 16:34
ARM当初划定这个框架,赌的就是你芯片厂商不会把RAM或者外设做的那么大!

举例来说,RAM规定是从0x2000- ...

大哥你说的“那片地址”是指位带别名区??
我就是我,是颜色不一样的烟火。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-19 17:51

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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