免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3221 | 回复: 7
打印 上一主题 下一主题

[其它] arm有几个地址空间? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-07-17 19:22 |只看该作者 |倒序浏览
我知道有些单片机,会有两个地址空间。

那么arm架构的处理器呢?

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
2 [报告]
发表于 2014-07-18 09:22 |只看该作者
弱问,单片机有哪两个地址空间?

论坛徽章:
0
3 [报告]
发表于 2014-07-18 16:02 |只看该作者
回复 2# amarant


程序地址空间和数据地址空间

说简单点  0x10020,  
1)   mov  r0,10020H
2)   movc r0,10020H

1)和2)读出来的数是不一样的

因为,他们一个在DATA空间(变量和I/O),另一个在CODE空间(代码和静态数据)。

所以,我要问的是,对arm架构来说,是用一个还是两个地址空间?


   

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
4 [报告]
发表于 2014-07-18 17:04 |只看该作者
回复 3# yxchugo


    哦  arm是一致的。

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
5 [报告]
发表于 2014-07-20 12:39 |只看该作者
arm只是在内部才是哈弗结构,而在外部是冯诺依曼结构,所以读写程序内存和数据内存都是使用相同的指令

论坛徽章:
0
6 [报告]
发表于 2014-07-21 19:29 |只看该作者
哦   谢谢两位了

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
7 [报告]
发表于 2014-07-22 08:52 |只看该作者
arm-linux-gcc 发表于 2014-07-20 12:39
arm只是在内部才是哈弗结构,而在外部是冯诺依曼结构,所以读写程序内存和数据内存都是使用相同的指令


对于哈佛结构,我的理解是是cache分成icache和dcache,以让机器能在一个时钟周期同时拿到指令和数据。不知道是不是你说的内部使用哈佛结构

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
8 [报告]
发表于 2014-07-22 09:58 |只看该作者
本帖最后由 arm-linux-gcc 于 2014-07-22 10:03 编辑

回复 7# amarant


    ARM的内部哈弗结构就是这种,只是分为了icache和dcache,而在从ddr取指令或数据时,icache和dcache是共享同一条数据总线的

如果那种外部也是哈弗结构的架构,那么代码和数据就需要不同的两片内存,对这两片内存有各自的访问指令(mov和movc),这两个空间是各自分别编址的(即代码地址和数据地址可能是一样的),icache和dcache各自有自己的数据总线分别连到各自的ddr上,这种结构从ddr中取指令和取数据可以完全并行


评分

参与人数 1可用积分 +10 收起 理由
amarant + 10 很给力!

查看全部评分

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

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP