mirror of
https://github.com/rkujawa/rk65c02.git
synced 2025-01-10 18:29:53 +00:00
Handle accessing bus in zero page relative mode just as in zero page.
It should make things less awkward and still work fine, as the only instructions using this mode are BBS and BBR. These only use first operand as the address in zero page to read data from.
This commit is contained in:
parent
0cbbce4eeb
commit
8de5574aab
@ -252,6 +252,7 @@ instruction_data_write_1(rk65c02emu_t *e, instrdef_t *id, instruction_t *i, uint
|
|||||||
|
|
||||||
switch (id->mode) {
|
switch (id->mode) {
|
||||||
case ZP:
|
case ZP:
|
||||||
|
case ZPR:
|
||||||
bus_write_1(e->bus, i->op1, val);
|
bus_write_1(e->bus, i->op1, val);
|
||||||
break;
|
break;
|
||||||
case ZPX:
|
case ZPX:
|
||||||
@ -290,13 +291,6 @@ instruction_data_write_1(rk65c02emu_t *e, instrdef_t *id, instruction_t *i, uint
|
|||||||
case ACCUMULATOR:
|
case ACCUMULATOR:
|
||||||
e->regs.A = val;
|
e->regs.A = val;
|
||||||
break;
|
break;
|
||||||
case ZPR:
|
|
||||||
/*
|
|
||||||
* This mode is special as both operands have separate meaning.
|
|
||||||
* Handled withing emulation, as it is used only by BBS and BBR.
|
|
||||||
*/
|
|
||||||
assert(false);
|
|
||||||
break;
|
|
||||||
case IMMEDIATE:
|
case IMMEDIATE:
|
||||||
case RELATIVE:
|
case RELATIVE:
|
||||||
case IABSOLUTE:
|
case IABSOLUTE:
|
||||||
@ -329,6 +323,7 @@ instruction_data_read_1(rk65c02emu_t *e, instrdef_t *id, instruction_t *i)
|
|||||||
rv = i->op1;
|
rv = i->op1;
|
||||||
break;
|
break;
|
||||||
case ZP:
|
case ZP:
|
||||||
|
case ZPR:
|
||||||
rv = bus_read_1(e->bus, i->op1);
|
rv = bus_read_1(e->bus, i->op1);
|
||||||
break;
|
break;
|
||||||
case ZPX:
|
case ZPX:
|
||||||
@ -364,13 +359,6 @@ instruction_data_read_1(rk65c02emu_t *e, instrdef_t *id, instruction_t *i)
|
|||||||
case ABSOLUTEY:
|
case ABSOLUTEY:
|
||||||
rv = bus_read_1(e->bus, (i->op1 + (i->op2 << 8)) + e->regs.Y);
|
rv = bus_read_1(e->bus, (i->op1 + (i->op2 << 8)) + e->regs.Y);
|
||||||
break;
|
break;
|
||||||
case ZPR:
|
|
||||||
/*
|
|
||||||
* This mode is special as both operands have separate meaning.
|
|
||||||
* Handled withing emulation, as it is used only by BBS and BBR.
|
|
||||||
*/
|
|
||||||
assert(false);
|
|
||||||
break;
|
|
||||||
case IABSOLUTE:
|
case IABSOLUTE:
|
||||||
case IABSOLUTEX:
|
case IABSOLUTEX:
|
||||||
case RELATIVE:
|
case RELATIVE:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user