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