[CPU] Add stub OE handling implementation for addex and negx
This commit is contained in:
parent
04c9c02270
commit
75ed343e72
|
@ -87,15 +87,16 @@ int InstrEmit_addex(PPCHIRBuilder& f, const InstrData& i) {
|
||||||
Value* rb = f.LoadGPR(i.XO.RB);
|
Value* rb = f.LoadGPR(i.XO.RB);
|
||||||
Value* v = f.AddWithCarry(ra, rb, f.LoadCA());
|
Value* v = f.AddWithCarry(ra, rb, f.LoadCA());
|
||||||
f.StoreGPR(i.XO.RT, v);
|
f.StoreGPR(i.XO.RT, v);
|
||||||
if (i.XO.OE) {
|
f.StoreCA(AddWithCarryDidCarry(f, ra, rb, f.LoadCA()));
|
||||||
XEINSTRNOTIMPLEMENTED();
|
|
||||||
// e.update_xer_with_overflow(EFLAGS OF?);
|
|
||||||
} else {
|
|
||||||
f.StoreCA(AddWithCarryDidCarry(f, ra, rb, f.LoadCA()));
|
|
||||||
}
|
|
||||||
if (i.XO.Rc) {
|
if (i.XO.Rc) {
|
||||||
f.UpdateCR(0, v);
|
f.UpdateCR(0, v);
|
||||||
}
|
}
|
||||||
|
if (i.XO.OE) {
|
||||||
|
// Stub implementation.
|
||||||
|
// TODO: Handle overflow flag.
|
||||||
|
// NOTE: 535507D4 (Raiden Fighters Aces) never seems to rely on this
|
||||||
|
// behavior either, despite OE being set.
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -416,34 +417,21 @@ int InstrEmit_mullwx(PPCHIRBuilder& f, const InstrData& i) {
|
||||||
int InstrEmit_negx(PPCHIRBuilder& f, const InstrData& i) {
|
int InstrEmit_negx(PPCHIRBuilder& f, const InstrData& i) {
|
||||||
// RT <- ¬(RA) + 1
|
// RT <- ¬(RA) + 1
|
||||||
if (i.XO.OE) {
|
if (i.XO.OE) {
|
||||||
// With XER update.
|
// Stub implementation.
|
||||||
// This is a different codepath as we need to use llvm.ssub.with.overflow.
|
// TODO: Handle overflow flag for XER.
|
||||||
|
// NOTE: 535507D4 (Raiden Fighters Aces) never seems to rely on this
|
||||||
// if RA == 0x8000000000000000 then no-op and set OV=1
|
// behavior, despite having OE set.
|
||||||
// This may just magically do that...
|
Value* v = f.LoadGPR(i.XO.RA);
|
||||||
|
if (v->AsUint64() == 0x8000000000000000) {
|
||||||
XEINSTRNOTIMPLEMENTED();
|
f.StoreGPR(i.XO.RT, v);
|
||||||
return 1;
|
return 0;
|
||||||
// Function* ssub_with_overflow = Intrinsic::getDeclaration(
|
|
||||||
// e.gen_module(), Intrinsic::ssub_with_overflow, jit_type_nint);
|
|
||||||
// jit_value_t v = b.CreateCall2(ssub_with_overflow,
|
|
||||||
// e.get_int64(0), f.LoadGPR(i.XO.RA));
|
|
||||||
// jit_value_t v0 = b.CreateExtractValue(v, 0);
|
|
||||||
// f.StoreGPR(i.XO.RT, v0);
|
|
||||||
// e.update_xer_with_overflow(b.CreateExtractValue(v, 1));
|
|
||||||
|
|
||||||
// if (i.XO.Rc) {
|
|
||||||
// // With cr0 update.
|
|
||||||
// f.UpdateCR(0, v0, e.get_int64(0), true);
|
|
||||||
//}
|
|
||||||
} else {
|
|
||||||
// No OE bit setting.
|
|
||||||
Value* v = f.Neg(f.LoadGPR(i.XO.RA));
|
|
||||||
f.StoreGPR(i.XO.RT, v);
|
|
||||||
if (i.XO.Rc) {
|
|
||||||
f.UpdateCR(0, v);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Value* v = f.Neg(f.LoadGPR(i.XO.RA));
|
||||||
|
f.StoreGPR(i.XO.RT, v);
|
||||||
|
if (i.XO.Rc) {
|
||||||
|
f.UpdateCR(0, v);
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue