大学毕业论文__模拟器与汇编程序设计.docVIP

大学毕业论文__模拟器与汇编程序设计.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文档。上传文档
查看更多
华中科技大学计算机科学与技术学院 C语言课程设计报告 题目: 模拟器与汇编程序设计 目 录 一、系统需求分析 1 二、总体设计 6 三、数据结构设计 8 四、详细设计 10 五、系统实现 14 六、运行测试与结果分析 47 七、总结 49 八、参考文献 50 九、指导教师评语 51 系统需求分析 本系统根据给出的指令集架构ISA编程实现一个模拟器和汇编程序,能够使用汇编程序将由给定指令集和指令格式编写的汇编源程序翻译成目标程序,并能够在模拟器上运行汇编后的目标程序,得到正确结果。 系统还包含两个汇编源程序,供汇编程序翻译成目标代码,即机器码。汇编源程序1的功能是求出1+2+3+…+100,并且正确输出运算结果。汇编源程序2的功能是将字符串“Simulator and Assembler”拷贝到另一个字符串中,并且输出另一个字符串,源程序可以自动判断字符串尾部并结束拷贝以及结束输出而不用考虑字符串长度的设定。 具体内容如下: 1. 用C语言编制汇编程序,将此简单计算机的汇编源程序翻译成目标代码,即机器码。为了测试所编制汇编程序的正确性,需用以上介绍的指令集编写两个汇编源程序,汇编源程序的功能要求为: ( 求1+2+3+…+100,并输出运算结果。 ② 求将“Simulator and Assembler”拷贝复制到新串并输出运算结果。 串并输出运算结果。 其中,32条指令以及伪指令和它们的功能如下: (1) 停机指令:HLT 功能:终止程序运行。 (2) 无条件转移指令:JMP label 功能:将控制转移至标号label处,执行标号label后的指令。 (3) 比较运算转移指令:CJMP label 功能:如果程序状态字中比较标志位c的值为1(即关系运算的结果为真),则将控制转移至标号label处,执行标号label后的指令;否则,顺序往下执行。 (4) 溢出转移指令:OJMP 功能:如果程序状态字中比较标志位o的值为1(即算术运算的结果发生溢出),则将控制转移至标号label处,执行标号label后的指令;否则,顺序往下执行。 (5) 调用子程序指令:CALL label 功能:将通用寄存器A~G、程序状态字PSW、程序计数器PC中的值保存到ES,然后调用以标号label开始的子程序,将控制转移至标号label处,执行标号label后的指令。 (6) 子程序返回指令:RET 功能:将ES中保存的通用寄存器A~Z、程序状态字PSW和程序字数器PC的值恢复,控制转移到子程序被调用的地方,执行调用指令的下一条指令。 (7) 入栈指令:PUSH reg0 功能:将通用寄存器reg0的值压入堆栈SS,reg0可以是A~G和Z八个通用寄存器之一。 (8) 出栈指令:POP reg0 功能:从堆栈SS中将数据出栈到寄存器reg0,reg0可以是A~G七个通用寄存器之一,但不能是通用寄存器Z。 (9) 取字节数据指令:LOADB reg0 symbol 功能:从字节数据或字节数据块symbol中取一个字节的数据存入寄存器reg0,所取的字节数据在数据块symbol中的位置由寄存器G的值决定。用C的语法可将此指令的功能描述为: reg0 = symbol[G] 例如,假设用伪指令定义了以下字节数据块num: BYTE num[10] = {5,3,2,8,6,9,1,7,4,0} 如果要将字节数据块num中第5个单元的值(即下标为4的元素)取到寄存器C,指令如下: LOADI G 5 LOADB C num 后面的指令LOADW、STOREB和STOREW在操作上与此指令类似。 (10) 取双字节数据指令:LOADW reg0 symbol 功能:从双字节数据或双字节数据块symbol中取一个双字节的数据存入寄存器reg0,所取的双字节数据在数据块symbol中的位置由寄存器G的值决定。 (11) 存字节数据指令:STOREB reg0 symbol 功能:将寄存器reg0的值存入字节数据或字节数据块symbol中的某个单元,存入单元的位置由寄存器G的值决定。用C的语法可将此指令的功能描述为: symbol[G] = reg0 (12) 存双字节数据指令:STOREW reg0 symbol 功能:将寄存器reg0的值存入双字节数据或双字节数据块symbol中的某个单

文档评论(0)

李天佑 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档