disasm for mfmsr, mtmsr, mtmsrd
This commit is contained in:
parent
82159b2b9d
commit
1b3351b1e2
|
@ -216,6 +216,26 @@ XEDISASMR(mtspr, 0x7C0003A6, XFX)(InstrData& i, InstrDisasm& d) {
|
||||||
return d.Finish();
|
return d.Finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
XEDISASMR(mfmsr, 0x7C0000A6, X)(InstrData& i, InstrDisasm& d) {
|
||||||
|
d.Init("mfmsr", "Move From Machine State Register", 0);
|
||||||
|
d.AddRegOperand(InstrRegister::kGPR, i.X.RT, InstrRegister::kWrite);
|
||||||
|
return d.Finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
XEDISASMR(mtmsr, 0x7C000124, X)(InstrData& i, InstrDisasm& d) {
|
||||||
|
d.Init("mtmsr", "Move To Machine State Register", 0);
|
||||||
|
d.AddRegOperand(InstrRegister::kGPR, i.X.RT, InstrRegister::kRead);
|
||||||
|
d.AddSImmOperand((i.X.RA & 16 != 0) ? 1 : 0, 1);
|
||||||
|
return d.Finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
XEDISASMR(mtmsrd, 0x7C000164, X)(InstrData& i, InstrDisasm& d) {
|
||||||
|
d.Init("mtmsrd", "Move To Machine State Register Doubleword", 0);
|
||||||
|
d.AddRegOperand(InstrRegister::kGPR, i.X.RT, InstrRegister::kRead);
|
||||||
|
d.AddSImmOperand((i.X.RA & 16 != 0) != 0 ? 1 : 0, 1);
|
||||||
|
return d.Finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void RegisterDisasmCategoryControl() {
|
void RegisterDisasmCategoryControl() {
|
||||||
XEREGISTERINSTR(bx, 0x48000000);
|
XEREGISTERINSTR(bx, 0x48000000);
|
||||||
|
@ -241,6 +261,9 @@ void RegisterDisasmCategoryControl() {
|
||||||
XEREGISTERINSTR(mftb, 0x7C0002E6);
|
XEREGISTERINSTR(mftb, 0x7C0002E6);
|
||||||
XEREGISTERINSTR(mtcrf, 0x7C000120);
|
XEREGISTERINSTR(mtcrf, 0x7C000120);
|
||||||
XEREGISTERINSTR(mtspr, 0x7C0003A6);
|
XEREGISTERINSTR(mtspr, 0x7C0003A6);
|
||||||
|
XEREGISTERINSTR(mfmsr, 0x7C0000A6);
|
||||||
|
XEREGISTERINSTR(mtmsr, 0x7C000124);
|
||||||
|
XEREGISTERINSTR(mtmsrd, 0x7C000164);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -115,6 +115,7 @@ static InstrType instr_table_31_unprep[] = {
|
||||||
INSTRUCTION(lvewx, 0x7C00008E, X , General , 0),
|
INSTRUCTION(lvewx, 0x7C00008E, X , General , 0),
|
||||||
INSTRUCTION(mulhdx, 0x7C000092, XO , General , 0),
|
INSTRUCTION(mulhdx, 0x7C000092, XO , General , 0),
|
||||||
INSTRUCTION(mulhwx, 0x7C000096, XO , General , 0),
|
INSTRUCTION(mulhwx, 0x7C000096, XO , General , 0),
|
||||||
|
INSTRUCTION(mfmsr, 0x7C0000A6, X , General , 0),
|
||||||
INSTRUCTION(ldarx, 0x7C0000A8, X , General , 0),
|
INSTRUCTION(ldarx, 0x7C0000A8, X , General , 0),
|
||||||
INSTRUCTION(dcbf, 0x7C0000AC, X , General , 0),
|
INSTRUCTION(dcbf, 0x7C0000AC, X , General , 0),
|
||||||
INSTRUCTION(lbzx, 0x7C0000AE, X , General , 0),
|
INSTRUCTION(lbzx, 0x7C0000AE, X , General , 0),
|
||||||
|
@ -126,10 +127,12 @@ static InstrType instr_table_31_unprep[] = {
|
||||||
INSTRUCTION(subfex, 0x7C000110, XO , General , 0),
|
INSTRUCTION(subfex, 0x7C000110, XO , General , 0),
|
||||||
INSTRUCTION(addex, 0x7C000114, XO , General , 0),
|
INSTRUCTION(addex, 0x7C000114, XO , General , 0),
|
||||||
INSTRUCTION(mtcrf, 0x7C000120, XFX, General , 0),
|
INSTRUCTION(mtcrf, 0x7C000120, XFX, General , 0),
|
||||||
|
INSTRUCTION(mtmsr, 0x7C000124, X , General , 0),
|
||||||
INSTRUCTION(stdx, 0x7C00012A, X , General , 0),
|
INSTRUCTION(stdx, 0x7C00012A, X , General , 0),
|
||||||
INSTRUCTION(stwcx, 0x7C00012D, X , General , 0),
|
INSTRUCTION(stwcx, 0x7C00012D, X , General , 0),
|
||||||
INSTRUCTION(stwx, 0x7C00012E, X , General , 0),
|
INSTRUCTION(stwx, 0x7C00012E, X , General , 0),
|
||||||
INSTRUCTION(stvehx, 0x7C00014E, X , General , 0),
|
INSTRUCTION(stvehx, 0x7C00014E, X , General , 0),
|
||||||
|
INSTRUCTION(mtmsrd, 0x7C000164, X , General , 0),
|
||||||
INSTRUCTION(stdux, 0x7C00016A, X , General , 0),
|
INSTRUCTION(stdux, 0x7C00016A, X , General , 0),
|
||||||
INSTRUCTION(stwux, 0x7C00016E, X , General , 0),
|
INSTRUCTION(stwux, 0x7C00016E, X , General , 0),
|
||||||
INSTRUCTION(stvewx, 0x7C00018E, X , General , 0),
|
INSTRUCTION(stvewx, 0x7C00018E, X , General , 0),
|
||||||
|
|
Loading…
Reference in New Issue