mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-12 06:29:58 +00:00
WARNING : changes test to accommodate CPU implementation
- TODO : check the Apple //e Bible for this ... - Calculates 2-byte branch instructions (Bxx +OFF)--that sit right at page boundary (at 0x..fe 0x..ff)--as 3 cycles rather than 4, since PC has already advanced to the new page (matches logic currently in x86/cpu.S
This commit is contained in:
parent
15dd90902c
commit
d8ae71ddb0
@ -1137,13 +1137,12 @@ TEST test_BCC(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fC : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (!flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1183,13 +1182,12 @@ TEST test_BCS(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fC : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (!flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1229,13 +1227,12 @@ TEST test_BEQ(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fZ : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (!flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1275,13 +1272,12 @@ TEST test_BNE(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fZ : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (!flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1321,13 +1317,12 @@ TEST test_BMI(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fN : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (!flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1367,13 +1362,12 @@ TEST test_BPL(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fN : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (!flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1413,8 +1407,10 @@ TEST test_BRA(volatile int8_t off, volatile bool flag, volatile uint16_t addrs)
|
||||
flags |= flag ? fN : 0;
|
||||
|
||||
uint8_t cycle_count = 3;
|
||||
uint16_t newpc = addrs+2+off;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
uint16_t newpc = addrs+2;
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
|
||||
@ -1453,13 +1449,12 @@ TEST test_BVC(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fV : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (!flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
@ -1499,13 +1494,12 @@ TEST test_BVS(int8_t off, bool flag, uint16_t addrs) {
|
||||
flags |= flag ? fV : 0;
|
||||
|
||||
uint8_t cycle_count = 2;
|
||||
uint16_t newpc = 0xffff;
|
||||
if (!flag) {
|
||||
newpc = addrs+2;
|
||||
} else {
|
||||
newpc = addrs+2+off;
|
||||
uint16_t newpc = addrs+2;
|
||||
if (flag) {
|
||||
uint16_t prebranch = newpc;
|
||||
newpc += off;
|
||||
++cycle_count;
|
||||
if ((newpc&0xFF00) != (addrs&0xFF00)) {
|
||||
if ((newpc&0xFF00) != (prebranch&0xFF00)) {
|
||||
++cycle_count;
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user