mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-19 13:08:27 +00:00
Set CF correctly on BLSR/BLSMSK patch (#724)
* Set CF correctly on BLSR patch * Set CF correctly on BLSMSK patch
This commit is contained in:
parent
d48836d5ae
commit
42ab101908
|
@ -345,9 +345,26 @@ static void GenerateBLSMSK(const ZydisDecodedOperand* operands, Xbyak::CodeGener
|
||||||
|
|
||||||
SaveRegisters(c, {scratch});
|
SaveRegisters(c, {scratch});
|
||||||
|
|
||||||
|
Xbyak::Label set_carry, clear_carry, end;
|
||||||
|
|
||||||
|
// BLSMSK sets CF to zero if source is NOT zero, otherwise it sets CF to one.
|
||||||
c.mov(scratch, *src);
|
c.mov(scratch, *src);
|
||||||
|
c.test(scratch, scratch);
|
||||||
|
c.jz(set_carry);
|
||||||
|
c.jmp(clear_carry);
|
||||||
|
|
||||||
|
c.L(set_carry);
|
||||||
c.dec(scratch);
|
c.dec(scratch);
|
||||||
c.xor_(scratch, *src);
|
c.xor_(scratch, *src);
|
||||||
|
c.stc();
|
||||||
|
c.jmp(end);
|
||||||
|
|
||||||
|
c.L(clear_carry);
|
||||||
|
c.dec(scratch);
|
||||||
|
c.xor_(scratch, *src);
|
||||||
|
// We don't need to clear carry here since XOR does that for us
|
||||||
|
|
||||||
|
c.L(end);
|
||||||
c.mov(dst, scratch);
|
c.mov(dst, scratch);
|
||||||
|
|
||||||
RestoreRegisters(c, {scratch});
|
RestoreRegisters(c, {scratch});
|
||||||
|
@ -361,9 +378,26 @@ static void GenerateBLSR(const ZydisDecodedOperand* operands, Xbyak::CodeGenerat
|
||||||
|
|
||||||
SaveRegisters(c, {scratch});
|
SaveRegisters(c, {scratch});
|
||||||
|
|
||||||
|
Xbyak::Label set_carry, clear_carry, end;
|
||||||
|
|
||||||
|
// BLSR sets CF to zero if source is NOT zero, otherwise it sets CF to one.
|
||||||
c.mov(scratch, *src);
|
c.mov(scratch, *src);
|
||||||
|
c.test(scratch, scratch);
|
||||||
|
c.jz(set_carry);
|
||||||
|
c.jmp(clear_carry);
|
||||||
|
|
||||||
|
c.L(set_carry);
|
||||||
c.dec(scratch);
|
c.dec(scratch);
|
||||||
c.and_(scratch, *src);
|
c.and_(scratch, *src);
|
||||||
|
c.stc();
|
||||||
|
c.jmp(end);
|
||||||
|
|
||||||
|
c.L(clear_carry);
|
||||||
|
c.dec(scratch);
|
||||||
|
c.and_(scratch, *src);
|
||||||
|
// We don't need to clear carry here since AND does that for us
|
||||||
|
|
||||||
|
c.L(end);
|
||||||
c.mov(dst, scratch);
|
c.mov(dst, scratch);
|
||||||
|
|
||||||
RestoreRegisters(c, {scratch});
|
RestoreRegisters(c, {scratch});
|
||||||
|
|
Loading…
Reference in a new issue