mirror of
https://github.com/pevans/erc-c.git
synced 2025-01-17 19:30:13 +00:00
We should check only the first byte for zero
We need to accept values for result that are greater than a byte so that we can determine if carry is set, but this causes an issue when an app uses addition to force an overflow that would set the zero bit. Masking result for only the LSB fixes that problem.
This commit is contained in:
parent
08b0e2e648
commit
e415b3e490
@ -271,7 +271,7 @@ mos6502_modify_status(mos6502 *cpu, vm_8bit status, int orig, int result)
|
||||
|
||||
if (status & MOS_ZERO) {
|
||||
cpu->P &= ~MOS_ZERO;
|
||||
if (result == 0) {
|
||||
if ((result & 0xff) == 0) {
|
||||
cpu->P |= MOS_ZERO;
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user