系统架构师--第1章计算机组成与体系结构-1.3流水线

1.3 流水线

流水线技术把一个任务分解为若干顺序执行的子任务,不同的子任务由不同的执行机构 负责执行,而这些机构可以同时并行工作。在任一时刻,任一任务只占用其中一个执行机构, 这样就可以实现多个任务的重叠执行,以提高工作效率。

1.3.1 流水线周期

流水线应用过程中,会将需要处理的工作分为 N 个阶段,最耗时的那一段所消耗的时 间为流水线周期。如:使用流水线技术执行100条指令,每条指令取指2ms,分析4ms,执 行1ms,则流水线周期为4ms。

1.3.2 计算流水线执行时间

延续上面的场景,将 1 个任务的执行过程可分成 N 个阶段,假设每个阶段完成时间 为 t,则完成该任务所需的时间即为 Nt。若以传统的方式,则完成 k 个任务所需的时间是 kNt;而使用流水线技术执行,且花费的时间是Nt+(k-1)t。也就是说,除了第 1 个任务需要 完整的时间外,其他都通过并行,节省下了大量的时间。所以流水线的执行时间可通俗的表 达为:

流水线执行时间=第1条指令的执行时间+(n-1)*流水线周期

注:n 代表需要处理的任务数量。

在考试时,又需要特别注意一个细节问题,流水线的执行时间计算,其实进一步可以分 理论情况与实践情况两种不同的处理方式。下面以实例进行说明。

例:某计算机系统,一条指令的执行需要经历取指(2ms)、分析(4ms)、执行(1ms) 三个阶段,现要执行 100 条指令,利用流水线技术需要多长时间?

理论上来说,1条指令的执行时间为:2ms+4ms+1ms=7ms。 所以:理论流水线执行时间=2ms+4ms+1ms+(100-1)*4=403ms。

而实际上,真正做流水线处理时,考虑到处理的复杂性,会将指令的每个执行阶段的时间都统一为流水线周期,即1条指令的执行时间为:4ms+4ms+4ms=12ms。 所以:实际流 水线执行时间=4ms+4ms+4ms+(100-1)*4=408ms。

提示:考试时80%以上的概率采用理论公式计算,所以考试时需要以理论 公式计算,若计算的结果无正确选项才考虑采用实际公式计算。

1.3.3 流水线的吞吐率

流水线的吞吐率(代表实际完成情况.ThoughPutrate,TP)是指在单位时间内流水线所 完成的任务数量或输出的结果数量。有些文献也称为平均吞吐率、实际吞吐率。计算流水线 吞吐率的最基本的公式如下:

流水线的吞吐率 代表实际完成情况

流水线最大吞吐率 代表最快速度 1/t

1.3.4 流水线的加速比

流水线的加速比>1

最大加速比 S=K

在流水线中,因为在同一时刻,有多个任务在重叠地执行,虽然完成一个任务的时间与 单独执行该任务相近(甚至由于分段的缘故,可能更多一些),但是从整体上看完成多个任 务所需的时间则大大减少。

完成同样一批任务,不使用流水线所用的时间与使用流水线所用的时间之比称为流水线 的加速比(speedupratio)。如果不使用流水线,即顺序执行所用的时间为 T0 ,使用流水 线的执行时间为 Tk ,则计算流水线加速比的基本公式如下:

如果流水线各个流水段的执行时间都相等(设为Dt),则一条k段流水线完成n个连续 任务所需要的时间为(k+n-1)Dt。如果不使用流水线,即顺序执行这n个任务,则所需要的时 间为nkDt。因此,各个流水段执行时间均相等的一条k 段流水线完成n个连续任务时的实 际加速比为:

  • 18
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值