Encoding:

COP1X

010011

fr

ft

fs

fd

MSUB

101

fmt

6

5

5

5

5

3

3

Format:

MSUB.fmt 

Floating Point Multiply Subtract

MSUB.S fd, fr, fs, ft

MIPS64, MIPS32 Release 2, removed in Release 6

Floating Point Multiply Subtract

MSUB.D fd, fr, fs, ft

MIPS64, MIPS32 Release 2, removed in Release 6

Floating Point Multiply Subtract

MSUB.PS fd, fr, fs, ft

MIPS64, MIPS32 Release 2, removed in Release 6

Floating Point Multiply Subtract

Purpose:

Floating Point Multiply Subtract

To perform a combined multiply-then-subtract of FP values.

Description:

 FPR[fd] = (FPR[fs] x FPR[ft]) - FPR[fr]

The value in FPR fs is multiplied by the value in FPR ft to produce an intermediate product. The intermediate product is rounded according to the current rounding mode in FCSR. The subtraction result 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. The results and flags are as if separate floating-point multiply and subtract instructions were executed.

MSUB.PS multiplies then subtracts the upper and lower halves of FPR fr, FPR fs, and FPR ft independently, and ORs together any generated exceptional conditions.

The Cause bits are ORed into the Flag bits if no exception is taken.

Restrictions:

The fields fr, fs, ft, and fd must specify FPRs valid for operands of type fmt. If the fields are not valid, the result is

UNPREDICTABLE.

The operands must be values in format fmt; if they are not, the result is UNPREDICTABLE and the value of the operand FPRs becomes UNPREDICTABLE.

The result of MSUB.PS is UNPREDICTABLE if the processor is executing in the FR=0 32-bit FPU register model.

It is predictable if executing on a 64-bit FPU in the FR=1 mode, but not with FR=0, and not on a 32-bit FPU.

Availability and Compatibility:

MSUB.S and MSUB.D: Required in all versions of MIPS64 since MIPS64 Release 1. Not available in MIPS32

Release 1. Required in MIPS32 Release 2 and all subsequent versions of MIPS32. When required, these instructions are to be implemented if an FPU is present, either in a 32-bit or 64-bit FPU or in a 32-bit or 64-bit FP Register Mode

(FIRF64=0 or 1, StatusFR=0 or 1).

This instruction has been removed in Release 6 and has been replaced by the fused multiply-subtract instruction.

Refer to the fused multiply-subtract instruction 'MSUBF.fmt' in this manual for more information. Release 6 does not support Paired Single (PS).

Operation:

vfr = ValueFPR(fr, fmt)
vfs = ValueFPR(fs, fmt)
vft = ValueFPR(ft, fmt)
StoreFPR(fd, fmt, (vfs xfmt vft) -fmt vfr))

Exceptions:

Coprocessor Unusable, Reserved Instruction

Floating Point Exceptions:

Inexact, Unimplemented Operation, Invalid Operation, Overflow, Underflow