Adding disassemblers for the fpu instructions.

This commit is contained in:
Ben Vanik 2013-05-26 00:13:46 -07:00
parent 4073028188
commit ab762e0009
3 changed files with 201 additions and 67 deletions

View File

@ -30,7 +30,7 @@ XEDISASMR(addx, 0x7C000214, XO )(InstrData& i, InstrDisasm& d) {
} }
XEDISASMR(addcx, 0x7C000014, XO )(InstrData& i, InstrDisasm& d) { XEDISASMR(addcx, 0x7C000014, XO )(InstrData& i, InstrDisasm& d) {
d.Init("addcx", "Add Carrying", d.Init("addc", "Add Carrying",
(i.XO.OE ? InstrDisasm::kOE : 0) | (i.XO.Rc ? InstrDisasm::kRc : 0) | (i.XO.OE ? InstrDisasm::kOE : 0) | (i.XO.Rc ? InstrDisasm::kRc : 0) |
InstrDisasm::kCA); InstrDisasm::kCA);
d.AddRegOperand(InstrRegister::kGPR, i.XO.RT, InstrRegister::kWrite); d.AddRegOperand(InstrRegister::kGPR, i.XO.RT, InstrRegister::kWrite);

View File

@ -21,160 +21,272 @@ namespace ppc {
// Floating-point arithmetic (A-8) // Floating-point arithmetic (A-8)
XEDISASMR(faddx, 0xFC00002A, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(faddx, 0xFC00002A, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fadd", "Floating Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(faddsx, 0xEC00002A, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(faddsx, 0xEC00002A, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fadds", "Floating Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fdivx, 0xFC000024, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fdivx, 0xFC000024, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fdiv", "Floating Divide [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fdivsx, 0xEC000024, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fdivsx, 0xEC000024, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fdivs", "Floating Divide [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmulx, 0xFC000032, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmulx, 0xFC000032, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmul", "Floating Multiply [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmulsx, 0xEC000032, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmulsx, 0xEC000032, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmuls", "Floating Multiply [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fresx, 0xEC000030, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fresx, 0xEC000030, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fres", "Floating Reciprocal Estimate [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(frsqrtex, 0xFC000034, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(frsqrtex, 0xFC000034, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("frsqrte", "Floating Reciprocal Square Root Estimate [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fsubx, 0xFC000028, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fsubx, 0xFC000028, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fsub", "Floating Subtract [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fsubsx, 0xEC000028, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fsubsx, 0xEC000028, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fsubs", "Floating Subtract [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fselx, 0xFC00002E, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fselx, 0xFC00002E, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fsel", "Floating Select",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fsqrtx, 0xFC00002C, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fsqrtx, 0xFC00002C, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fsqrt", "Floating Square Root [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fsqrtsx, 0xEC00002C, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fsqrtsx, 0xEC00002C, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fsqrts", "Floating Square Root [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
return d.Finish();
} }
// Floating-point multiply-add (A-9) // Floating-point multiply-add (A-9)
XEDISASMR(fmaddx, 0xFC00003A, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmaddx, 0xFC00003A, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmadd", "Floating Multiply-Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmaddsx, 0xEC00003A, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmaddsx, 0xEC00003A, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmadds", "Floating Multiply-Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmsubx, 0xFC000038, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmsubx, 0xFC000038, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmsub", "Floating Multiply-Subtract[Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmsubsx, 0xEC000038, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmsubsx, 0xEC000038, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmsubs", "Floating Multiply-Subtract [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnmaddx, 0xFC00003E, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnmaddx, 0xFC00003E, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fnmadd", "Floating Negative Multiply-Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnmaddsx, 0xEC00003E, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnmaddsx, 0xEC00003E, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fnmadds", "Floating Negative Multiply-Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnmsubx, 0xFC00003C, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnmsubx, 0xFC00003C, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fnmsub", "Floating Negative Multiply-Subtract [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnmsubsx, 0xEC00003C, A )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnmsubsx, 0xEC00003C, A )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fnmsubs", "Floating Negative Multiply-Add [Single]",
return 1; InstrDisasm::kFP | (i.A.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.A.FRT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRB, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.A.FRC, InstrRegister::kRead);
return d.Finish();
} }
// Floating-point rounding and conversion (A-10) // Floating-point rounding and conversion (A-10)
XEDISASMR(fcfidx, 0xFC00069C, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fcfidx, 0xFC00069C, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fcfid", "Floating Convert From Integer Doubleword",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fctidx, 0xFC00065C, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fctidx, 0xFC00065C, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fctid", "Floating Convert To Integer Doubleword",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fctidzx, 0xFC00065E, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fctidzx, 0xFC00065E, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fctidz",
return 1; "Floating Convert To Integer Doubleword with round toward Zero",
InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fctiwx, 0xFC00001C, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fctiwx, 0xFC00001C, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fctiw", "Floating Convert To Integer Word",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fctiwzx, 0xFC00001E, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fctiwzx, 0xFC00001E, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fctiwz", "Floating Convert To Integer Word with round toward Zero",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(frspx, 0xFC000018, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(frspx, 0xFC000018, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("frsp", "Floating Round to Single-Precision",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
// Floating-point compare (A-11) // Floating-point compare (A-11)
XEDISASMR(fcmpo, 0xFC000040, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fcmpo, 0xFC000040, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fcmpo", "Floating Compare Ordered", 0);
return 1; d.AddCR(i.X.RT >> 2, InstrRegister::kWrite);
d.AddUImmOperand(i.X.RT >> 2, 1);
d.AddRegOperand(InstrRegister::kFPR, i.X.RA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fcmpu, 0xFC000000, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fcmpu, 0xFC000000, X )(InstrData& i, InstrDisasm& d) {
d.Init("fcmpu", "Floating Compare Unordered", 0); d.Init("fcmpu", "Floating Compare Unordered", 0);
d.AddCR(i.X.RT >> 2, InstrRegister::kWrite); d.AddCR(i.X.RT >> 2, InstrRegister::kWrite);
d.AddUImmOperand(i.X.RT >> 2, 1); d.AddUImmOperand(i.X.RT >> 2, 1);
d.AddRegOperand(InstrRegister::kGPR, i.X.RA, InstrRegister::kRead); d.AddRegOperand(InstrRegister::kFPR, i.X.RA, InstrRegister::kRead);
d.AddRegOperand(InstrRegister::kGPR, i.X.RB, InstrRegister::kRead); d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish(); return d.Finish();
} }
@ -215,23 +327,35 @@ XEDISASMR(mtfsfix, 0xFC00010C, X )(InstrData& i, InstrDisasm& d) {
// Floating-point move (A-21) // Floating-point move (A-21)
XEDISASMR(fabsx, 0xFC000210, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fabsx, 0xFC000210, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fabs", "Floating Absolute Value",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fmrx, 0xFC000090, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fmrx, 0xFC000090, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fmr", "Floating Move Register",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnabsx, 0xFC000110, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnabsx, 0xFC000110, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fnabs", "Floating Negative Absolute Value",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }
XEDISASMR(fnegx, 0xFC000050, X )(InstrData& i, InstrDisasm& d) { XEDISASMR(fnegx, 0xFC000050, X )(InstrData& i, InstrDisasm& d) {
XEINSTRNOTIMPLEMENTED(); d.Init("fneg", "Floating Negate",
return 1; InstrDisasm::kFP | (i.X.Rc ? InstrDisasm::kRc : 0));
d.AddRegOperand(InstrRegister::kFPR, i.X.RT, InstrRegister::kWrite);
d.AddRegOperand(InstrRegister::kFPR, i.X.RB, InstrRegister::kRead);
return d.Finish();
} }

View File

@ -170,6 +170,15 @@ typedef struct {
uint32_t : 6; uint32_t : 6;
} XO; } XO;
// kXEPPCInstrFormatA // kXEPPCInstrFormatA
struct {
uint32_t Rc : 1;
uint32_t XO : 5;
uint32_t FRC : 5;
uint32_t FRB : 5;
uint32_t FRA : 5;
uint32_t FRT : 5;
uint32_t : 6;
} A;
// kXEPPCInstrFormatM // kXEPPCInstrFormatM
struct { struct {
uint32_t Rc : 1; uint32_t Rc : 1;
@ -281,6 +290,7 @@ public:
kRc = 1 << 1, kRc = 1 << 1,
kCA = 1 << 2, kCA = 1 << 2,
kLR = 1 << 4, kLR = 1 << 4,
kFP = 1 << 5,
}; };
const char* name; const char* name;