SPECIAL 000000 |
rs |
rt |
0 00 0000 0000 |
DMULTU 011101 |
6 |
5 |
5 |
10 |
6 |
DMULTU rs, rt |
MIPS64, removed in Release 6 |
Doubleword Multiply Unsigned |
Doubleword Multiply Unsigned
To multiply 64-bit unsigned integers.
(LO, HI) = GPR[rs] <= GPR[rt]
The 64-bit doubleword value in GPR rt is multiplied by the 64-bit value in GPR rs, treating both operands as unsigned values, to produce a 128-bit result. The low-order 64-bit doubleword of the result is placed into special register LO, and the high-order 64-bit doubleword is placed into special register HI. No arithmetic exception occurs under any circumstances.
This instruction has been removed in Release 6.
prod = (0||GPR[rs]) <= (0||GPR[rt]) LO = prod63..0 HI = prod127..64
Reserved Instruction
In some processors the integer multiply operation may proceed asynchronously and allow other CPU instructions to execute before it is complete. An attempt to read LO or HI before the results are written interlocks until the results are ready. Asynchronous execution does not affect the program result, but offers an opportunity for performance improvement by scheduling the multiply so that other instructions can execute in parallel.
Programs that require overflow detection must check for it explicitly.
In MIPS III, if either of the two instructions preceding the divide is an MFHI or MFLO, the result of the MFHI or
MFLO is UNPREDICTABLE. Reads of the HI or LO special register must be separated from subsequent instructions that write to them by two or more instructions. This restriction was removed in MIPS IV and all subsequent levels of the architecture.