Floating Add [Single]

A-Form

  • fadds FRT,FRA,FRB (Rc=0)
  • fadds. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPADD32(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Add [Double]

A-Form

  • fadd FRT,FRA,FRB (Rc=0)
  • fadd. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPADD64(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Subtract [Single]

A-Form

  • fsubs FRT,FRA,FRB (Rc=0)
  • fsubs. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPSUB32(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Subtract [Double]

A-Form

  • fsub FRT,FRA,FRB (Rc=0)
  • fsub. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPSUB64(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Multiply [Single]

A-Form

  • fmuls FRT,FRA,FRC (Rc=0)
  • fmuls. FRT,FRA,FRC (Rc=1)

Pseudo-code:

FRT <- FPMUL32(FRA, FRC)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Multiply [Double]

A-Form

  • fmul FRT,FRA,FRC (Rc=0)
  • fmul. FRT,FRA,FRC (Rc=1)

Pseudo-code:

FRT <- FPMUL64(FRA, FRC)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Divide [Single]

A-Form

  • fdivs FRT,FRA,FRB (Rc=0)
  • fdivs. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPDIV32(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Divide [Double]

A-Form

  • fdiv FRT,FRA,FRB (Rc=0)
  • fdiv. FRT,FRA,FRB (Rc=1)

Pseudo-code:

FRT <- FPDIV64(FRA, FRB)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI
CR1          (if Rc=1)

Floating Multiply-Add [Single]

A-Form

  • fmadds FRT,FRA,FRC,FRB (Rc=0)
  • fmadds. FRT,FRA,FRC,FRB (Rc=1)

Pseudo-code:

FRT <- FPMULADD32(FRA, FRC, FRB, 1, 1)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI VXIMZ
CR1          (if Rc=1)

Floating Multiply-Sub [Single]

A-Form

  • fmsubs FRT,FRA,FRC,FRB (Rc=0)
  • fmsubs. FRT,FRA,FRC,FRB (Rc=1)

Pseudo-code:

FRT <- FPMULADD32(FRA, FRC, FRB, 1, -1)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI VXIMZ
CR1          (if Rc=1)

Floating Negative Multiply-Add [Single]

A-Form

  • fnmadds FRT,FRA,FRC,FRB (Rc=0)
  • fnmadds. FRT,FRA,FRC,FRB (Rc=1)

Pseudo-code:

FRT <- FPMULADD32(FRA, FRC, FRB, -1, -1)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI VXIMZ
CR1          (if Rc=1)

Floating Negative Multiply-Sub [Single]

A-Form

  • fnmsubs FRT,FRA,FRC,FRB (Rc=0)
  • fnmsubs. FRT,FRA,FRC,FRB (Rc=1)

Pseudo-code:

FRT <- FPMULADD32(FRA, FRC, FRB, -1, 1)

Special Registers Altered:

FPRF FR FI
FX OX UX XX
VXSNAN VXISI VXIMZ
CR1          (if Rc=1)