在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 4590|回复: 9

经典的5段流水线的第3级计算出的地址是物理地址吗?

[复制链接]
发表于 2012-11-9 15:44:25 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
一个经典的5段RISC流水线:
一条指令执行过程分为以下5个周期:1.取指令周期
2.指令译码/读寄存器周期
3.执行/有效地址计算周期
4.存储器访问/分支完成周期
5.写回周期

请问3.里面说的有效地址就是存储器的物理地址吗?
请指点。
发表于 2012-11-9 16:30:34 | 显示全部楼层
有效地址一般指的是虚拟地址。
 楼主| 发表于 2012-11-10 00:42:22 | 显示全部楼层
回复 2# hbhbts
谢谢您的回复,我还是不太明白。
先不说“有效地址”这个名词吧。就说流水线第三个周期计算出来的地址吧。这个地址是物理地址还是虚拟地址呢?
如果是虚拟地址又是在什么时候转化成物理地址,供第四周期的存储器访问呢?
发表于 2012-11-11 20:01:38 | 显示全部楼层
不懂lz想问什么...
讨论虚拟不虚拟没有什么意义吧。流水线是数据通路,虚拟地址在内存架构。
第三级流水线就是去读内存,如果你的内存架构里面支持虚拟地址,那么自然送出去的是虚拟地址。
发表于 2012-11-11 20:51:28 | 显示全部楼层
要看你的系统的cache是逻辑地址还是物理地址;
 楼主| 发表于 2012-11-11 22:10:13 | 显示全部楼层
回复 4# Jstalin
谢谢回复,明白了。如果没有mmu那么送出去的就是物理地址,如果有mmu,送出去的就是虚拟地址吧?
发表于 2012-11-11 22:49:18 | 显示全部楼层
应该是虚地址吧,这样才会是每个进程专用,如果是物理地址的话,那几个进程的地址就会混合了
虚地址在TLB中完成到实地址的转换,TLB是OS管理的,每次进程切换时OS都会加载相应进程的私有TLB

当然如果机器里只有一个进程,那么tlb就只有一个了,不需要每次更换
发表于 2012-11-21 13:57:15 | 显示全部楼层
mmu在cache的前面还是后面,建议看《cache与多核处理器》里面对这个问题讲的比较详细;
发表于 2012-11-24 09:40:30 | 显示全部楼层
回复 6# cqu2ustc


你可以这样理解
发表于 2012-11-26 10:04:02 | 显示全部楼层
回复 8# jm2000


  理解错了,CPU里跑的是逻辑地址(如果有MMU),CACHE里的索引根据MMU的位置分为逻辑CACHE和物理CACHE;
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-5-5 17:20 , Processed in 0.030867 second(s), 10 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表