AUI 001111 |
rs |
rt |
immediate |
DAUI 011101 |
rs != 00000 |
rt |
immediate |
REGIMM 000001 |
rs |
DAHI 00110 |
immediate |
REGIMM 000001 |
rs |
DATI 11110 |
immediate |
6 |
5 |
5 |
16 |
AUI DAUI DAHI DATI |
Add Upper Immediate | |
AUI rt, rs immediate |
MIPS32 Release 6 |
Add Upper Immediate |
DAUI rt, rs immediate |
MIPS64 Release 6 |
Doubleword Add Upper Immediate |
DAHI rs, rs immediate |
MIPS64 Release 6 |
Doubleword Add Higher Immediate |
DATI rs, rs immediate |
MIPS64 Release 6 |
Doubleword Add Top Immediate |
Add Immediate to Upper Bits
AUI: Add Upper Immediate
DAUI: Doubleword Add Upper Immediate
DAHI: Doubleword Add Higher Immediate
DATI: Doubleword Add Top Immediate
AUI: GPR[rt] = sign_extend.32( GPR[rs] + sign_extend(immediate << 16) ) DAUI: GPR[rt] = GPR[rs] + sign_extend(immediate << 16) DAHI: GPR[rs] = GPR[rs] + sign_extend(immediate << 32) DATI: GPR[rs] = GPR[rs] + sign_extend(immediate << 48)
AUI: The 16 bit immediate is shifted left 16 bits, sign-extended, and added to the register rs, storing the result in rt.
AUI is a 32-bit compatible instruction, so on a 64-bit CPU the result is sign extended as if a 32-bits signed address.
DAHI: The 16 bit immediate is shifted left 32 bits, sign-extended, and added to the register rs, overwriting rs with the result.
DATI: The 16 bit immediate is shifted left 48bits, sign-extended, and added to the register rs, overwriting rs with the result.
DAUI: The 16-bit immediate is shifted left 16 bits, sign-extended, and added to the register rs; the results are stored in rt.
In Release 6, LUI is an assembly idiom for AUI with rs=0.
DAUI: rs cannot be r0, the zero register. The encoding may be used for other instructions or must signal a Reserved
Instruction exception.
DAUI, DAHI, DATI: Reserved Instruction exception if 64-bit instructions are not enabled.
AUI is introduced by and required as of Release 6.
DAUI is introduced by and required as of MIPS64 Release 6.
DAUI reuses the primary opcode of JALX. DAUI cannot be trapped (and possibly emulated) on pre-Release 6 systems, while JALX cannot be trapped (and possibly emulated) on Release 6 systems.
DAHI is introduced by and required as of MIPS64 Release 6.
DATI is introduced by and required as of MIPS64 Release 6.
AUI: GPR[rt] = sign_extend.32( GPR[rs] + sign_extend(immediate << 16) ) DAUI: GPR[rt] = GPR[rs] + sign_extend(immediate << 16) DAHI: GPR[rs] = GPR[rs] + sign_extend(immediate << 32) DATI: GPR[rs] = GPR[rs] + sign_extend(immediate << 48)
AUI: None.
DAUI, DAHI, DATI: Reserved Instruction
AUI (and DAUI, DAHI and DATI on MIPS64 Release 6) can be used to synthesize large constants in situations where it is not convenient to load a large constant from memory. To simplify hardware that may recognize sequences of instructions as generating large constants, AUI/DAUI/DAHI/DATI should be used in a stylized manner.
To create an integer:
LUI rd, imm_low(rtmp) ORI rd, rd, imm_upper DAHI rd, imm_high DATI rd, imm_top
To create a large offset for a memory access whose address is of the form rbase+large_offset:
AUI rtmp, rbase, imm_upper DAHI rtmp, imm_high DATI rtmp, imm_top LW rd, (rtmp)imm_low
To create a large constant operand for an instruction of the form rd:=rs+large_immediate or rd:=rs-large_immediate:
32-bits:
AUI rtmp, rs, imm_upper ADDIU rd, rtmp, imm_low
64-bits:
AUI rtmp, rs, imm_upper DAHI rtmp, imm_high DATI rtmp, imm_top DADDUI rd, rtmp,imm_low