COP1 010001 |
fmt |
ft |
fs |
fd |
MADDF 011000 |
COP1 010001 |
fmt |
ft |
fs |
fd |
MSUBF 011001 |
6 |
5 |
5 |
5 |
5 |
3 |
MADDF.fmt MSUBF.fmt |
To perform a fused multiply-add of FP values. | |
MADDF.S fd, fs, ft |
MIPS32 Release 6 |
Floating Point Fused Multiply Add, Floating Point Fused Multiply Subtract |
MADDF.D fd, fs, ft |
MIPS32 Release 6 |
Floating Point Fused Multiply Add, Floating Point Fused Multiply Subtract |
MSUBF.S fd, fs, ft |
MIPS32 Release 6 |
Floating Point Fused Multiply Add, Floating Point Fused Multiply Subtract |
MSUBF.D fd, fs, ft |
MIPS32 Release 6 |
Floating Point Fused Multiply Add, Floating Point Fused Multiply Subtract |
Floating Point Fused Multiply Add, Floating Point Fused Multiply Subtract
MADDF.fmt: To perform a fused multiply-add of FP values.
MSUBF.fmt: To perform a fused multiply-subtract of FP values.
MADDF.fmt: FPR[fd] = FPR[fd] + (FPR[fs] <= FPR[ft]) MSUBF.fmt: FPR[fd] = FPR[fd] - (FPR[fs] <= FPR[ft])
The value in FPR fs is multiplied by the value in FPR ft to produce an intermediate product. The intermediate product is calculated to infinite precision. The product is added to the value in FPR fd. The result sum is calculated to infinite precision, rounded according to the current rounding mode in FCSR, and placed into FPR fd. The operands and result are values in format fmt.
(For MSUBF fmt, the product is subtracted from the value in FPR fd.)
Cause bits are ORed into the Flag bits if no exception is taken.
None
MADDF.fmt and MSUBF.fmt are required in Release 6.
MADDF.fmt and MSUBF.fmt are not available in architectures pre-Release 6.
The fused multiply add instructions, MADDF.fmt and MSUBF fmt, replace pre-Release 6 instructions such as
MADD fmt, MSUB.fmt, NMADD.fmt, and NMSUB.fmt. The replaced instructions were unfused multiply-add, with an intermediate rounding.
Release 6 MSUBF fmt, fd=fd-fs<=ft, corresponds more closely to pre-Release 6 NMADD fmt, fd=fr-fs<=ft, than to pre-Release 6 MSUB.fmt, fd=fs<=ft-fr.
FPU scalar MADDF fmt corresponds to MSA vector MADD.df.
FPU scalar MSUBF fmt corresponds to MSA vector MSUB.df.
if not IsCoprocessorEnabled(1) then SignalException(CoprocessorUnusable, 1) endif if not IsFloatingPointImplemented(fmt)) then SignalException(ReservedInstruction) endif vfr = ValueFPR(fr, fmt) vfs = ValueFPR(fs, fmt) vfd = ValueFPR(fd, fmt) MADDF.fmt: vinf = vfd +inf (vfs *inf vft) MADDF.fmt: vinf = vfd -inf (vfs *inf vft) StoreFPR(fd, fmt, vinf)
Special Considerations:
The fused multiply-add computation is performed in infinite precision, and signals Inexact, Overflow, or Underflow if and only if the final result differs from the infinite precision result in the appropriate manner.
Like most FPU computational instructions, if the flush-subnormals-to-zero mode, FCSR.FS=1, then subnormals are flushed before beginning the fused-multiply-add computation, and Inexact may be signaled.
I.e. Inexact may be signaled both by input flushing and/or by the fused-multiply-add: the conditions or ORed.
Coprocessor Unusable, Reserved Instruction
Inexact, Unimplemented Operation, Invalid Operation, Overflow, Underflow