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

目录

计算机指令流水线

流水线冒险

结构冒险

数据冒险

控制冒险


计算机指令流水线

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

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

MIPS 流水化的数据通路

流水线冒险

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

结构冒险

数据冒险

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

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

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

前推/旁路(forwarding/bypassing)

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

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

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

前推+阻塞

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

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

控制冒险

分支预测

更有效的分析预测

相关推荐
屿行屿行几秒前
【Linux】浅析Linux内存管理机制
linux
潘晓可9 分钟前
Docker部署Bookstack
运维·docker·容器
Serverless社区11 分钟前
阿里云新发的AgentRun 有哪些“大招”,一文详解来了
运维·阿里云·云原生·serverless
誰能久伴不乏14 分钟前
深入理解 `poll` 函数:详细解析与实际应用
linux·服务器·c语言·c++·unix
倔强的石头10625 分钟前
Linux 进程深度解析(二):进程状态、fork 创建与特殊进程(僵尸 与 孤儿)
linux·运维·服务器
小李小李无与伦比38 分钟前
使用Simiki,部署.md文档
linux·运维·服务器
做人不要太理性42 分钟前
【Linux系统】ELF 文件格式的硬核揭秘
java·linux·服务器
草根站起来1 小时前
局域网内网IP能不能申请SSL证书
服务器·tcp/ip·ssl
怀旧,1 小时前
【Linux系统编程】12. 基础IO(下)
linux·运维·服务器
网络小白不怕黑1 小时前
Docker Compose与私有仓库
运维·docker·容器