微机原理实验报告mips.docVIP

  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文档。上传文档
查看更多
微机原理实验报告mips

微机原理与接口技术实验 实验一 MIPS汇编程序设计 学号 U201413416 姓名 陆仪文 班级 电信1406班 二、实验分析 本次实验分为两个部分。 编译部分,即将c程序转化为Mips汇编程序 调试部分,包括修正程序及在QtSpim中显示程序数据的内存映像 ①编译部分(算法): 相关指令分析: 数据段:伪指令(‘z’数组空间分配及‘str’的定义与赋值) ====初始化、分配空间 代码段:主函数中 宏指令(la取址, li+寄存器立即数初始化)=====设置K,Y值,Z的起始地址 自定义循环函数中 数据寻址(小于常数设置slti)==========================条件语句 指令寻址(相等转移beq,直接跳转j)=========条件跳转、无条件跳转 算术运算指令(addi、sub)==================条件成立,跳转后运算 逻辑运算指令(sll、srl)==================================同上 数据传送指令(sw)================================数组值存储 系统功能调用(li+功能号、li+入口参数、syscall结束退)========调用函数 宏指令(la取址)====================================显示数据 最终Mips源代码及注释 .data #data segment数据段 z: .space 200 #int z[50],占4*500=200个字节 str: .asciiz \n #输出应有回车换行,定义str为换行符二进制码 .text #code segment代码段 main: #main program entry li $s0,0 #给$s0赋值0 li $t0,56 #给$t0赋值56 la $s1,z #z(k)的地址为s1 loop: #for循环 slti $s7,$s0,50 #k50,设置$s7为1,否则为0 beq $s7,$0,L #若$s7为0,说明k≥50,跳到L srl $s6,$s0,2 #$s6=k/4=$s02 addi $s6,$s6,210 #$s6=$s6+210 sll $s6,$s6,4 #$s6=16*(k/4+210)=$s64 sub $s6,$t0,$s6 #$s6=y-16*(k/4+210)=$t0-$s6 sw $s6,0($s1) #保存z(k)=$s6 li $v0,1 #调用系统函数:显示整数 addi $a0,$s6,0 #显示$a0=$s6=z(k) syscall #退出函数 li $v0,4 #调用系统函数:显示字符串直到字符串结束符0 la $a0,str #取换行符地址并显示 syscall #退出函数 addi $s1,$s1,4 #PC=PC+4 addi $s0,$s0,1 #k++ j loop #for条件满足,则继续循环 L: #k≥50,for循环条件不满足时 li $v0,10 #退出 syscall #exit program ②调试部分(程序运行过程): 4. 第二次更改,修正了存储范围问题(即不使用中间变量s5,s4,s3) 但是console窗口仍为空 5.第三次修改(左段)没有console输出结果,第四次修改(右段)输出格式很乱 6.正确的代码、注释及输出结果如下: 变量名(z[]) 地址 数据(16进制) 定义值 0ff -3304 ff f3 18 1ff -3304 ff f3 18 2ff -3304 f

文档评论(0)

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

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

1亿VIP精品文档

相关文档