计算机系统结构实验报告
班级 姓名 实验名称 实 验 目 的 、 要 求 及 器 材 实 验 内 容 、 步 骤 及 结 果 计算机 2班 实验日期 学号 2015.03.09 实验成绩 流水线及流水线中的冲突 2.1 实验目的 1. 加深对计算机流水线基本概念的理解。 2. 理解MIPS结构如何用5段流水线来实现,理解各段的功能以及基本操作 3. 加深对数据冲突、结构冲突的理解,理解这两类冲突对CPU性能的影响;; 4. 进一步理解解决数据冲突的方法,掌握如何应用定向技术来减少数据冲突引起的停顿。 2.2 实验平台 实验平台采用指令级和流水线操作级模拟器MIPSsim 2.3 实验内容和步骤 首先要掌握MIPSsim模拟器的使用方法。 1. 启动MIPSsim 2. 根据预备知识中关于流水线各段操作的描述,进一步理解流水线窗口中各段的功能,掌握各流水寄存器的含义。(用鼠标双击各段,就可以看到各流水寄存器的内容) 3.参照使用说明,熟悉MIPSsim模拟器的操作和使用方法。 可以先载入一个样例程序,然后分别以单步执行一条指令、执行多条指令、连续执行、设置断点等的方式运行程序,观察程序的执行情况,观察CPU中寄存器和存储器的内容的变化,特别是流水寄存器内容的变化。 4. 选择“配置”→“流水方式”选项,使模拟器工作在流水方式下。 5. 观察程序在流水线中的执行情况,步骤如下: (1) 选择MIPSsim “文件” →“载入程序”选项,加载pipeline.s。 (2) 关闭定向功能。这是通过“配置” →“定向”(使该项前面没有√号)来实现的。 (3) 用单步执行一个周期的方式(在“执行”菜单中)或按F7键执行程序,观察每一个周期中,各段流水寄存器内容的变化、指令的执行情况(“代码”窗口)以及时钟周期图。 (4) 当执行到第13个时钟周期时,各段分别正在处理的指令是: IF: LW $r4, 60, ($r6) ID: ADDI $r3, $r0, 25 EX: ADDI $r1, $r1, -1 MEM: ADDI $r6, $r0,8 WB: ADD $r2,$r1,$r0 画出这时的时钟周期图。如下图所示: 6. 这时各流水寄存器中的内容为: IF/ ID.IR: 2361655356 IF/ ID.NPC: 48 ID/ EX.A: 0 ID/ EX.B: 0 ID/ EX.Imm: 25 ID/ EX.IR: 537067545 EX /MEM.ALUo: 4 EX /MEM.IR: 539099135 MEM /WB.LMD: 0 MEM /WB. ALUo: 8 MEM /WB.IR: 537136 7. 观察和分析结构冲突对CPU的影响,步骤如下: (1) 加载structure_hz.s (2) 执行该程序,找出存在结构冲突的指令以及导致结构冲突的部件。 答: ADD.D $f2,$f0,$f1 ADD.D $f5,$f0,$f1 存储器&加法器 (3) 记录由结构冲突引起的停顿时钟周期数,计算停顿时钟周期数占总执行周期数的百分比。 答: 35/52=67.30769% (4) 把浮点加法器的个数改为4个。 (5) 再次重复步骤(1)-(3)的工作。 (6) 分析结构冲突对CPU性能的影响,讨论解决结构冲突的办法。 答:结构冲突对CPU性能的影响:当发生冲突时,流水线会出现停顿,从而降低了CPU的性能。 解决方法:设置相互的指令寄存器和数据寄存器,增加导致结构冲突的部件。 8. 观察数据冲突并用定向技术来减少停顿,步骤如下: (1) 全部复位 (2) 加载data_hz.s (3) 关闭定向功能。这是通过“配置” →“定向”(使该项前面没有√号)来实现的。 (4) 用单步执行一个周期的方式(F7)执行该程序,同时查看时钟周期图,列出在什么时刻发生了RAW(先写后读)冲突。 答:以下周期发生RAW: 3 5 6 8 9 12 13 16 17 19 20 24 25 27 28 31 32 35 36 38 39 43 46 50 51 54 55 57 58 (5) 记录由数据冲突引起的停顿时钟周期数以及程序执行的总时钟周期数,计算停顿时钟周期数占总执行周期数的百分比。 答:31/65=47.69231% (6) 复位CPU。 (7) 打开定向功能。这是通过“配置” →“定向”(使该项前面有√号)来实现的。 (8) 用单步执行一个周期的方式(F7)执行该程序,同时查看时钟周期图,列出在什么时刻发生了RAW(先写后读)冲突,并与步骤(3)的结果进行比较。 答: 以下周期发生RAW:4 9 12 17 21 24 29 33 36 9/42=20.93023% (9) 记录由数据冲突引起的停顿时钟周期数以及程序执行的总时钟周期数,计算采用定向技术后的性能是原来的几倍。 答:RAW停顿时钟周期数为:9 总时钟周期数为:43 RAW停顿时钟周期数占总执行周期数的百分比:20.93023% 采用定向技术后性能是原来的2.2786倍。 总 结 当发生结构冲突时,流水线会出现停顿,从而降低了CPU的性能。 要避免结构冲突就要在流水线处理机中设置相互的指令存储器和数据存储器。 当发生数据冲突时,程序执行并定向时的总停顿周期比没有定向功能的时候少,说明要降低数据冲突的方法是对CPU复位并定向。 通过本次实验,我对流水线的工作原理、流水线的冲突以及解决方法都有了更深入直观的了解,对5段RISC流水线的的理解和掌握更深刻了,对于的运算执行部件例如fadd替换EX时指令的执行轨迹形象的描述出来。通过观察时钟周期图能够辨别冲突类型及冲突原因,对结构冲突和数据冲突有了更好的认识 附 录