计算机组成与设计 硬件软件接口 第五版 流水线部分笔记
TODO1:为什么果壳不在 IDU 阶段读出寄存器?而要在后端?是跟超标量、乱序有关系吗?
TODO2: 修改PC难道比修改其它寄存器更快吗?
TODO3: 长流水线有什么缺点?
TODO4: 需要两个存储器吗?优缺点?
TODO5: 气泡指令是什么?为什么可以起到阻塞的作用?比起直接阻塞有什么优缺点?(4.8 会说明阻塞)
TODO6: 怎么阻塞?(比如在遇到分支指令后插入一个气泡)(4.8 会说明阻塞)
TODO7: 怎么flush ?
TODO8:4.8 会给出分支预测的细节,包括动态分支预测
TODO9: 什么是数据相关性(RAW等等)
很重要的一点:并不是所有指令都需要访问内存
----------------------------- 笔记开始 ----------------------------------
4.5 中的关键部分
冒险:流水线有这样一种情况,在下一个时钟周期中下一条指令不能执行。这种情况称为冒险(hazard)
1. 结构冒险:因缺乏硬件支持而导致的冒险。比如指令和数据在同一个存储器里,无法同时取指和读数据。(可以用 I-cache 来解决)
2. 数据冒险:也称为流水线数据冒险(pipeline data hazard),因无法提供指令执行所需的数据而导致的冒险
对于数据冒险来说,可以使用 前递(forwarding) 和 旁路(bypassing) 来解决
但即便使用了前递和旁路,在 取数-使用 型数据冒险(load-use data hazard) 中,依然得阻塞一个阶段 (4.7 会讲讲怎么处理这种复杂阶段)
3. 控制冒险(control hazard/ branch hazard): 由于jmp和branch指令的存在,指令地址的变化有时并不是流水线所预期的,如果取到了错误的指令,就会导致冒险
有两种办法可以处理控制冒险
1. 阻塞。遇到分支跳转指令时,立刻阻塞流水线,知道分支跳转指令的结果出来。
2. 加入更多硬件,在IDU阶段计算并更新 PC 的值(详见4.8)。不过即便如此,在遇到分支跳转指令判定失败的时候依然会阻塞一个时钟周期(但是判定成功的时候就不会阻塞了)
4.5 看完了,用来处理三种冒险的主要方法有:旁路、阻塞、分支预测
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?