- 8
- 0
- 约 28页
- 2017-11-10 发布于浙江
- 举报
BranchPred与ication
*/28 */28 4.3 控制相关的动态解决技术 处理器一个时钟周期流出多条指令受到以下两 个因素的限制: 流出n条指令的处理器中,遇到分支指令的 速度也快了n倍; 根据Amdahl定律可知,随着机器CPI的降低, 控制相关对性能的影响越来越大。 第四章 指令级并行 本节着重于: 通过硬件技术,动态地进行分支处理,对程序运行时的分支行为进行预测,提前对分支操作做出反应,加快分支处理的速度。 分支的最终延迟取决于流水线的结构、预测的方法和预测错误后恢复所采取的策略。 4.3 控制相关的动态解决技术 4.3.1 分支预测缓冲 动态分支预测必须解决两个问题: 如何记录一个分支操作的历史。 决定预测的走向。 记录分支历史的方法有以下几种: (1)仅仅记录最近一次或最近几次的分支历史; (2)记录分支成功的目标地址; (3)记录分支历史和分支目标地址,相当于前 面两种方式的结合; (4)记录分支目标地址的一条或若干条指令。 4.3 控制相关的动态解决技术 分支预测缓冲技术(Branch-Prediction Buffer或者Branch History Table,简写为BTB或者BHT): 目前广泛使用的最简单的动态分支预测技术。 使用一片存储区域,记录最近一次或几次分支特征的历史。 1. 只有1个预测位的分支预测缓冲 索引:分支指令地址的低位。 存储区:1位的分支历史记录位,又称为 预测位,记录该指令最近一次 分支是否成功。 4.3 控制相关的动态解决技术 状态转换图 “0”记录分支不成功 “1”记录分支成功 图4.9 只有1个预测位的分支预测缓冲状态转换图 4.3 控制相关的动态解决技术 2. 分支预测缓冲技术包括两个步骤 分支预测 如果当前缓冲记录的预测位为“1”,则预 测分为成功;如果预测位为“0”,则预测分支为不成功。 预测位修改 如果当前分支成功,则预测位置为“1”; 如果当前分支不成功,预测位置为“0”。 3.分支预测错误时,预测位就被修改,并且需 要恢复现场,程序从分支指令处重新执行。 4.3 控制相关的动态解决技术 图4.10 分支预测执行不成功和重新执行过程 4.3 控制相关的动态解决技术 例4.6 一个循环共循环10次,它将分支成功9次, 1次不成功。假设此分支的预测位始终在缓冲区中。那么分支预测的准确性是多少? 解 这种固定的预测将会在第一次和最后一次 循环中出现预测错误。 第一次预测错误是源于上次程序的执行, 因为上一次程序最后一次分支是不成功的。 最后一次预测错误是不可避免的,因为前 面的分支总是成功,共九次。 因此,尽管分支成功的比例率是90%, 但分支预测的准确性为80%(两次不正确, 8次确)。 4.3 控制相关的动态解决技术 4.1位预测机制的缺点 只要预测出错,往往是连续两次而不是一次。 5.解决方法 采用两个预测位的预测机制。 在两个预测位的分支预测中,更改对分支的预测必须有两次连续预测错误。 两位分支预测的状态转换图 4.3 控制相关的动态解决技术 图4.11 具有两个分支预测位的分支预测缓冲状态转换机制 4.3 控制相关的动态解决技术 6. n位分支预测缓冲 采用n位计数器,则计数器的值在0到2n-1之间: 当计数器的值大于或等于最大值的一半(2n-1)时,则预测下一次分支成功; 否则预测下一次分支不成功。 预测位的修改和两位预测时相同: 当分支成功时计数器的值加1,不成功时减1。 研究表明: n位分支预测的性能和两位分支预测差不多,因而大多数处理器都只采用两位分支预测。 4.3 控制相关的动态解决技术 7.对于真实的应用程序,两位的分支预测的准确率可达到多少呢? SPEC89标准程序的测试: 在使用4096个记录项的缓冲区时,分支 预测准确率可达到99%到82%。 使用无穷多历史记录项的分支预测缓冲, 只有少量程序的分支预测准确率仅仅比4096 个记录项提高1%,多数程序的预测精度是相 同的。 因此,对于SPEC89应用环境而言,4K的 缓冲区是恰当的。 8.上述分支预测机制对于改进后的DLX流水线没有帮助。 4.3 控制相关的动态解决技术 4.3.2 分支目标缓冲 目标:将分支的开销降为零。 方法:分支目标缓冲 将分支成功的
您可能关注的文档
- 梁的强逗腿和刚度计算.ppt
- 梯度校蘸妄参数辩识方法.ppt
- 检测技缓往础作业及答案.ppt
- 检测技缓往础作业及答案王华祥.ppt
- 检验师屎驮题.ppt
- 检验科液徒疗废物课件.ppt
- 检疫性胶烷壳虫.ppt
- 检验科珊旺化仪新增项目.ppt
- 检验科竞铜济效益分析.ppt
- 检验结购望解读.ppt
- JJG 543-2026心电图机检定规程.pdf
- 《JJG 543-2026心电图机检定规程》.pdf
- GB/T 47045-2026乘用车车载信息优先级的确定方法.pdf
- 《GB/T 12668.2-2025调速电气传动系统 第2部分:一般要求 交流调速电气传动系统额定值的规定》.pdf
- 中国国家标准 GB/T 12668.2-2025调速电气传动系统 第2部分:一般要求 交流调速电气传动系统额定值的规定.pdf
- 中国国家标准 GB/T 31487.1-2025直流融冰装置 第1部分:系统设计.pdf
- GB/T 12668.2-2025调速电气传动系统 第2部分:一般要求 交流调速电气传动系统额定值的规定.pdf
- GB/T 31487.1-2025直流融冰装置 第1部分:系统设计.pdf
- 《GB/T 31487.1-2025直流融冰装置 第1部分:系统设计》.pdf
- 《GB/T 31418-2025道路交通信号控制系统术语》.pdf
原创力文档

文档评论(0)