X86: Fix the sar carry flag.
This commit is contained in:
parent
860f0f8350
commit
c087b60af3
1 changed files with 5 additions and 1 deletions
|
@ -711,8 +711,12 @@ let {{
|
||||||
//worry about setting them.
|
//worry about setting them.
|
||||||
ccFlagBits = ccFlagBits & ~(ext & (CFBit | ECFBit | OFBit));
|
ccFlagBits = ccFlagBits & ~(ext & (CFBit | ECFBit | OFBit));
|
||||||
//If some combination of the CF bits need to be set, set them.
|
//If some combination of the CF bits need to be set, set them.
|
||||||
if ((ext & (CFBit | ECFBit)) && bits(SrcReg1, shiftAmt - 1))
|
uint8_t effectiveShift =
|
||||||
|
(shiftAmt <= dataSize * 8) ? shiftAmt : (dataSize * 8);
|
||||||
|
if ((ext & (CFBit | ECFBit)) &&
|
||||||
|
bits(SrcReg1, effectiveShift - 1)) {
|
||||||
ccFlagBits = ccFlagBits | (ext & (CFBit | ECFBit));
|
ccFlagBits = ccFlagBits | (ext & (CFBit | ECFBit));
|
||||||
|
}
|
||||||
//Use the regular mechanisms to calculate the other flags.
|
//Use the regular mechanisms to calculate the other flags.
|
||||||
ccFlagBits = genFlags(ccFlagBits, ext & ~(CFBit | ECFBit | OFBit),
|
ccFlagBits = genFlags(ccFlagBits, ext & ~(CFBit | ECFBit | OFBit),
|
||||||
DestReg, psrc1, op2);
|
DestReg, psrc1, op2);
|
||||||
|
|
Loading…
Reference in a new issue