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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
cui_ruicheng2 分钟前
Linux入门(一):起源、生态与基础使用
linux·运维·服务器
米糕闯编程2 分钟前
xshell使用CentOS10 root用户登录,权限问题
java·linux
安科士andxe4 分钟前
实操指南|安科士EPON OLT光模块选型、部署与运维全流程解析
运维·服务器·网络
s090713615 分钟前
Zynq-7000 PetaLinux 千兆网卡 Link UP 但无法 Ping 通的终极排查与解决(以 KSZ9031 为例)
linux·skew·zynq·ksz9031·ping不通
Joker 00744 分钟前
Ubuntu上安装FreeSurfer的详细流程
linux·深度学习·ubuntu
默默前行的虫虫1 小时前
声音触发器。用于自动化场景检测器
运维·自动化
okra-1 小时前
什么是接口?
服务器·前端·网络
想你依然心痛2 小时前
从零开始:Mac/Windows/Linux 三系统开发环境配置完全指南
linux·windows·macos
陳10302 小时前
Linux:第一个系统程序--进度条
linux·运维·服务器
克莱因3582 小时前
Linux 进程(2)服务管理指令
java·linux·服务器