第1二次习题.pptVIP

  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文档。上传文档
查看更多
第1二次习题

第一二次习题 1.14.3 MIPS = Clock rate × 10-6/CPI MIPS(P1) = 4 × 109 × 10–6/1.25 = 3200 MIPS(P2) = 3 × 109 × 10–6/0.75 = 4000 MIPS(P1) MIPS(P2) MIPS大的处理器有最高性能的说法是错误的,不过这题给的数据看不出来。 MIPS没有考虑指令的能力。不能用MIPS比较不同指令集的处理器。 不同程序有不同CPI,所以会有不同的MIPS。不能用MIPS比较不同程序的性能。 1.14.4 MFLOPS = Numf / Tf / 106 = Numf / (Numf * CPIf / ClkRate) / 106 = ClkRate / CPIf / 106 MFLOPSa = 3 * 109 / 1 / 106 = 3 * 103 MFLOPSb = 3 * 109 / 0.7 / 106 = 4.29 * 103 2.21.1 假设栈和静态数据段都是空的且栈指针和全局指针一次指向地址0x7fff fffc 和0x1000 8000 。调用习惯如图2-11。函数的输入使用寄存器$a0,返回值使用$v0。假定页函数仅可以使用保留寄存器。试回答下面问题。 这题严重依赖编译器实现,不同编译器会有不同的栈行为。 2.21.1 2.21.1 关于帧指针 如果在函数中会动态改变$sp那么我们需要用$fp来存储$sp的值,为局部变量的寻址提供一个固定的基址寄存器。作用等价于x86中的bp寄存器。 我们可以通过避免在函数中修改$sp来避免使用$fp,在书上例子中,$sp在过程的入口和出口需要调整。 $fp的方便性在与对过程中所有栈内的变量应用都有相同的偏移。然而,$fp指针并不是必须的。GNU MIPS C 编译器使用帧指针,而来自MIPS的C编译器则没有使用,他将$fp作为另一个保留寄存器使用。 如使用$fp,函数调用的栈情况 程序a的mips-linux-gcc反汇编代码解析 $ra $fp ...局部变量,以及预留空间 $a0 $ra $fp ...局部变量,以及预留空间 递归... 如果不使用$fp,则栈中不保存$fp 程序a的mips-linux-gcc反汇编代码解析 $ra $fp ...局部变量,以及预留空间 $a1 $a0 $fp ...局部变量,以及预留空间 递归... 如果不使用$fp,则栈中不保存$fp

文档评论(0)

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

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

1亿VIP精品文档

相关文档