计算机系统结构winDLX流水线实验报告精要.docVIP

计算机系统结构winDLX流水线实验报告精要.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机系统结构winDLX流水线实验报告精要

计算机科学与技术学院 课程 学 号: 级:专 业: 学生姓名: 年 月 实 验 报 告 学生姓名: 学 号: 时间: 地点: 实验课程名称:计算机体系结构 一、实验名称:流水线中的相关-求n个数的方差 二、实验原理: 1、WinDLX WinDLX模拟器是一个图形化、交互式的DLX流水线模拟器,能够演示DLX流水线是如何工作的。该模拟器可以装载DLX汇编语言程序(后缀为“.s”的文件),然后单步、设断点或是连续执行该程序。CPU的寄存器、流水线、I/O和存储器都可以用图形表示出来,以形象生动的方式描述DLX流水线的工作过程。模拟器还提供了对流水线操作的统计功能,便于对流水线进行性能分析。 2、流水线执行过程: 指令执行的5个阶段 (1)取指令周期 (2)指令译码/读寄存器周期 (3)执行/有效地址计算周期 (4)存储器访问/分支完成周期 (5)写回周期 3、流水线中的相关: (1)结构相关:当某一条机器指令需要访问物理器件时,如加法器,此时加法器正被另一条机器指令使用,从而产生结构相关; (2)数据相关:当某一条指令需要访问某个寄存器时,此时这个寄存器正被另一条指令所使用,从而产生数据相关; (3)控制相关:当程序执行到某个分支语句时,顺序执行的下一条语句将被跳过而去执行分支语句中满足条件的那条指令,从而产生控制相关。 三、实验目的: 1、通过该模拟实验,进一步掌握和巩固流水线的基本知识; 2、初步掌握在特定体系结构下的汇编代码的编写和优化; 3、培养运用所学知识解决实际问题的能力 4、对流水线性能分析 5、了解影响流水线效率的因素 6、了解各类相关及解决方法 四、实验内容: 使用WinDLX模拟器,对Variance.s做如下分析: 分析Variance.s和Input.s输入顺序不同时产生的影响。 分析Variance.s中汇编语言含义,同时分析程序执行流程。 观察程序中出现的数据/控制/结构相关。指出程序中出现上述现象的指令组合。 考察增加运算部件对性能的影响。 考察增加forward部件对性能的影响。 观察转移指令在转移成功和转移不成功时候的流水线开销。 注意:除(4)以外,加、乘、除部件都只有一个,本问题中所有部件延迟设置为:加法:2个延迟周期;乘法:5个延迟周期;除法19个延迟周期。 五、实验器材(设备、元器件): IBM PC兼容机 Windows 3.0以上的操作系统 1、双击WinDLX图标运行WinDLX。装入测试程序之前,先初始化WinDLX模拟器:点击File 菜单中的 Reset all 菜单项,弹出一个“Reset DLX”对话框。然后点击窗口中的“确认”按钮即可。 2、选择File / Load Code or Data,按如下步骤操作,可将Variance.s和nput.s这两个程序装入主存: 点击Variance.s点击select按钮 点击nput.s 点击select按钮 点击load按钮 3、按F7键程序顺序执行观察6个子窗口的情况 七、实验数据及结果分析: 1、先装入Variance.s再转入nput.s时,因为程序顺序执行,地址顺序符合程序执行顺序,程序能够正确执行;顺序相反时,因为nput.s的地址高,而程序顺序执行到nput.s时将没有正确的输入窗口,程序执行到输出结果时,也不会出现结果 2、程序中出现数据相关:下面两条指令,第二条指令要读而执行到此操作时指令仍对r进行操作,lbu r3,0(r2) seqi r5,r3,10 下面两条指令,指令要读而执行到此操作时指令仍对r进行操作, multu r1,r1,r4 add r1,r1,r3 图1 数据相关 (2)控制相关:下面两条指令,第条指令出现跳转指令时,指令,所以出现控制相关 jal InputUnsigned sw PrintfValue(r3),r1 图2 控制相关 (3)结构相关:下面两条指令,第条指令时,,所以出现相关 图3 结构相关 3、Variance.s的代码 .data ;.data标识下面的数据放在数据区中 ;输入语句,指示你输入要求 Prompt: .asciiz Please input An integer which is arrays size value0: ;输入语句,指示你输入要求 PromptLast: .asciiz Please input the integer : ;输出格式,表示求出的按什么格式输出 PrintfFormat: .asciiz the Variance is : %g

文档评论(0)

6663144 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档