关于cpu的流水线,为何写寄存器在时钟周期的前半段,而读寄存器在后半段

善良的小伙伴 2015-07-28 03:30:00
《计算机组成与设计 硬件/软件 接口 (原书第四版)》

这里面讲流水线的时候,把指令执行 分成5个步骤(假设一条指令一个时钟周期):
1,通过PC(程序计数器)读取指令;
2,分解指令,读取寄存器;
3,ALU计算
4,访问数据存储器(即是内存)
5,写回寄存器

但是它又说对寄存器堆的写操作发生在时钟周期的前半段,对寄存器的读操作发生在时钟周期的后半段。

按上面步骤不是应该先读再写吗??
...全文
1355 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
magickou 2015-12-18
  • 打赏
  • 举报
回复
因为必须先存入上一个指令的值,然后才可以读从寄存器文件中读取下一个指令的值
赵4老师 2015-07-28
  • 打赏
  • 举报
回复
那就不能上条指令写完后再开始本条指令读吗?

70,020

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧