A64: Implement CCMN (immediate)
This commit is contained in:
parent
a6c6539109
commit
ab4664de61
2 changed files with 14 additions and 1 deletions
|
@ -301,7 +301,7 @@ INST(SBCS, "SBCS", "z1111
|
||||||
// Data Processing - Register - Conditional compare
|
// Data Processing - Register - Conditional compare
|
||||||
INST(CCMN_reg, "CCMN (register)", "z0111010010mmmmmcccc00nnnnn0ffff")
|
INST(CCMN_reg, "CCMN (register)", "z0111010010mmmmmcccc00nnnnn0ffff")
|
||||||
INST(CCMP_reg, "CCMP (register)", "z1111010010mmmmmcccc00nnnnn0ffff")
|
INST(CCMP_reg, "CCMP (register)", "z1111010010mmmmmcccc00nnnnn0ffff")
|
||||||
//INST(CCMN_imm, "CCMN (immediate)", "z0111010010iiiiicccc10nnnnn0ffff")
|
INST(CCMN_imm, "CCMN (immediate)", "z0111010010iiiiicccc10nnnnn0ffff")
|
||||||
//INST(CCMP_imm, "CCMP (immediate)", "z1111010010iiiiicccc10nnnnn0ffff")
|
//INST(CCMP_imm, "CCMP (immediate)", "z1111010010iiiiicccc10nnnnn0ffff")
|
||||||
|
|
||||||
// Data Processing - Register - Conditional select
|
// Data Processing - Register - Conditional select
|
||||||
|
|
|
@ -34,4 +34,17 @@ bool TranslatorVisitor::CCMP_reg(bool sf, Reg Rm, Cond cond, Reg Rn, Imm<4> nzcv
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool TranslatorVisitor::CCMN_imm(bool sf, Imm<5> imm5, Cond cond, Reg Rn, Imm<4> nzcv) {
|
||||||
|
const size_t datasize = sf ? 64 : 32;
|
||||||
|
const u32 flags = nzcv.ZeroExtend<u32>() << 28;
|
||||||
|
|
||||||
|
const IR::U32U64 operand1 = X(datasize, Rn);
|
||||||
|
const IR::U32U64 operand2 = I(datasize, imm5.ZeroExtend<u32>());
|
||||||
|
|
||||||
|
const IR::NZCV then_flags = ir.NZCVFrom(ir.AddWithCarry(operand1, operand2, ir.Imm1(0)));
|
||||||
|
const IR::NZCV else_flags = ir.NZCVFromPackedFlags(ir.Imm32(flags));
|
||||||
|
ir.SetNZCV(ir.ConditionalSelect(cond, then_flags, else_flags));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Dynarmic::A64
|
} // namespace Dynarmic::A64
|
||||||
|
|
Loading…
Reference in a new issue