Revert "Optimized CONVERT_I64_TO_F64 with neat overflow trick"

This reverts commit 3ad80810b5.

Fixes broken statue animation is 454108CF
This commit is contained in:
Gliniak 2024-05-09 20:00:03 +02:00
parent 5ca173cd4f
commit 2ca752ce07
1 changed files with 19 additions and 8 deletions

View File

@ -348,21 +348,32 @@ struct CONVERT_I64_F64
: Sequence<CONVERT_I64_F64, I<OPCODE_CONVERT, I64Op, F64Op>> { : Sequence<CONVERT_I64_F64, I<OPCODE_CONVERT, I64Op, F64Op>> {
static void Emit(X64Emitter& e, const EmitArgType& i) { static void Emit(X64Emitter& e, const EmitArgType& i) {
e.ChangeMxcsrMode(MXCSRMode::Fpu); e.ChangeMxcsrMode(MXCSRMode::Fpu);
e.xor_(e.eax, e.eax);
Xmm src1 = GetInputRegOrConstant(e, i.src1, e.xmm0); Xmm src1 = GetInputRegOrConstant(e, i.src1, e.xmm0);
// Copy src1.
e.movq(e.rcx, src1);
e.vcomisd(src1, e.GetXmmConstPtr(XmmConst::XMMZero)); // TODO(benvanik): saturation check? cvtt* (trunc?)
if (i.instr->flags == ROUND_TO_ZERO) { if (i.instr->flags == ROUND_TO_ZERO) {
e.vcvttsd2si(i.dest, src1); e.vcvttsd2si(i.dest, src1);
} else { } else {
e.vcvtsd2si(i.dest, src1); e.vcvtsd2si(i.dest, src1);
} }
// cf set if less than
e.setnc(e.cl); // 0x8000000000000000
e.cmp(i.dest, -1LL); e.mov(e.rax, 0x1);
// if dest == 0x80000000 and not inp < 0 then dest = 0x7FFFFFFF e.shl(e.rax, 63);
e.seto(e.al);
e.and_(e.al, e.cl); // Saturate positive overflow
// TODO(DrChat): Find a shorter equivalent sequence.
// if (result ind. && src1 >= 0)
// result = 0x7FFFFFFFFFFFFFFF;
e.cmp(e.rax, i.dest);
e.sete(e.al);
e.movzx(e.rax, e.al);
e.shr(e.rcx, 63);
e.xor_(e.rcx, 0x01);
e.and_(e.rax, e.rcx);
e.sub(i.dest, e.rax); e.sub(i.dest, e.rax);
} }
}; };