mirror of
https://github.com/andrew-jacobs/emu816.git
synced 2024-06-15 21:29:31 +00:00
Fixed carry generation in CMP, CPX and CPY
This commit is contained in:
parent
340d19d8e9
commit
aba1cc1521
12
emu816.h
12
emu816.h
|
@ -769,7 +769,7 @@ private:
|
||||||
|
|
||||||
if (e || p.f_m) {
|
if (e || p.f_m) {
|
||||||
Byte data = getByte(ea);
|
Byte data = getByte(ea);
|
||||||
Word temp = data - a.b;
|
Word temp = data - a.b - 1;
|
||||||
|
|
||||||
setc(temp & 0x100);
|
setc(temp & 0x100);
|
||||||
setnz_b(lo(temp));
|
setnz_b(lo(temp));
|
||||||
|
@ -777,7 +777,7 @@ private:
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Word data = getWord(ea);
|
Word data = getWord(ea);
|
||||||
Addr temp = data - a.w;
|
Addr temp = data - a.w - 1;
|
||||||
|
|
||||||
setc(temp & 0x10000L);
|
setc(temp & 0x10000L);
|
||||||
setnz_w((Word)temp);
|
setnz_w((Word)temp);
|
||||||
|
@ -820,7 +820,7 @@ private:
|
||||||
|
|
||||||
if (e || p.f_x) {
|
if (e || p.f_x) {
|
||||||
Byte data = getByte(ea);
|
Byte data = getByte(ea);
|
||||||
Word temp = data - x.b;
|
Word temp = data - x.b - 1;
|
||||||
|
|
||||||
setc(temp & 0x100);
|
setc(temp & 0x100);
|
||||||
setnz_b(lo(temp));
|
setnz_b(lo(temp));
|
||||||
|
@ -828,7 +828,7 @@ private:
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Word data = getWord(ea);
|
Word data = getWord(ea);
|
||||||
Addr temp = data - x.w;
|
Addr temp = data - x.w - 1;
|
||||||
|
|
||||||
setc(temp & 0x10000);
|
setc(temp & 0x10000);
|
||||||
setnz_w((Word) temp);
|
setnz_w((Word) temp);
|
||||||
|
@ -842,7 +842,7 @@ private:
|
||||||
|
|
||||||
if (e || p.f_x) {
|
if (e || p.f_x) {
|
||||||
Byte data = getByte(ea);
|
Byte data = getByte(ea);
|
||||||
Word temp = data - y.b;
|
Word temp = data - y.b - 1;
|
||||||
|
|
||||||
setc(temp & 0x100);
|
setc(temp & 0x100);
|
||||||
setnz_b(lo(temp));
|
setnz_b(lo(temp));
|
||||||
|
@ -850,7 +850,7 @@ private:
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Word data = getWord(ea);
|
Word data = getWord(ea);
|
||||||
Addr temp = data - y.w;
|
Addr temp = data - y.w - 1;
|
||||||
|
|
||||||
setc(temp & 0x10000);
|
setc(temp & 0x10000);
|
||||||
setnz_w((Word) temp);
|
setnz_w((Word) temp);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user