计算机指令的流水线执行与流水线冒险

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

流水线方式的洗衣房可以以并行的方式提高性能

计算机执行指令,同样可以以流水线的方式并行

MIPS 流水化的数据通路

流水线冒险

下一周期不能按时执行下一条指令

结构冒险

数据冒险

一条指令依赖于前面某条执行的计算结果

add s0, t0, t1 sub t2, s0, t3

下一条指令需要气泡停顿等待前面计算出结果

前推/旁路(forwarding/bypassing)

不要等待计算结果保存到目的寄存器,增加一条额外数据通路,将计算的结果直接传给下一条指令计算的输入

但是并非所有冒险都能通过前推来避免气泡停顿

lw s0, 20(t1)
sub t2, s0, $t3

前推+阻塞

在需要使用前一个指令的结果时,前一个指令还没有拿到结果,此时需要停顿一下

还可以通过调整指令的顺序来避免阻塞等待

控制冒险

分支预测

更有效的分析预测

相关推荐
不会就选b几秒前
Linux之make,makefile
linux·运维·服务器
腾讯蓝鲸智云1 分钟前
【运维自动化-监控平台】初识蓝鲸监控
运维·自动化·云计算·sass·paas
日取其半万世不竭3 分钟前
新服务器买完 24 小时内要做什么?安全加固清单
运维·服务器·安全
code monkey.5 分钟前
【Linux之旅】HTTP 协议解析:从请求格式到构建 Web 服务器
linux·服务器·网络·http
LoserChaser9 分钟前
Flask 文件上传服务器 - 知识点总结
服务器·python·flask
tiannian122010 分钟前
资产管理从手工到智能:三种技术路径的优劣与适用场景
运维·rfid·资产管理系统
_codemonster14 分钟前
传统模式 vs DevOps 模式
运维·devops
難釋懷21 分钟前
Nginx对上游服务器使用keepalive
服务器·nginx·github
vortex522 分钟前
Linux 传统设计哲学:通过调用名区分行为的艺术
linux·运维·网络
Gong-Yu33 分钟前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化