【MIPS汇编】ADDI,ADDIU,ADD,ADDU的区别、有符号无符号的谬误

ADDI、ADDIU:加立即数,区别在于是否检测溢出。

Format: ADDI rt, rs, immediate
To add a constant to a 32-bit integer. If overflow occurs, then trap.

Format: ADDIU rt, rs, immediate
To add a constant to a 32-bit integer

ADD、ADDU:加寄存器,区别在于是否检测溢出。

Format: ADD rd, rs, rt
To add 32-bit integers. If an overflow occurs, then trap.

Format: ADDU rd, rs, rt
To add 32-bit integers

可知,在忽略溢出的前提下,ADDI与ADDIU等价,ADD与ADDU等价。原因如下:

分析

1、忽略溢出,addi与addiu等价

addi是加立即数指令,支持溢出检测,具体表现为:遇到溢出时,溢出错误标志变为高电平,传送到控制器cu中,导致此时的寄存器写使能信号regwr无效,最终结果为不将运算结果写入目的寄存器。

addiu是加立即数指令,不受溢出限制,具体表现为:遇到溢出时,对溢出的结果进行32bit求模,将求模结果写入目的寄存器中,因而不受溢出限制。

在忽略溢出的前提下,addi和add

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值