mirror of
https://github.com/pevans/erc-c.git
synced 2025-01-21 14:30:39 +00:00
It turns out we don't use carry for addr modes.
This fix actually corrects a rather irritating bug where the Apple ][ logo was displaying one-off--e.g., as "pple ][D".
This commit is contained in:
parent
4509f61be6
commit
ca5276cb6b
@ -106,14 +106,13 @@ DEFINE_ADDR(abs)
|
|||||||
/*
|
/*
|
||||||
* The absolute x-indexed address mode is a slight modification of the
|
* The absolute x-indexed address mode is a slight modification of the
|
||||||
* absolute mode. Here, we consume two bytes, but add the X register
|
* absolute mode. Here, we consume two bytes, but add the X register
|
||||||
* value to what we read -- plus one if we have the carry bit set. This
|
* value to what we read. This is a mode you would use if you were
|
||||||
* is a mode you would use if you were scanning a table, for instance.
|
* scanning a table, for instance.
|
||||||
*/
|
*/
|
||||||
DEFINE_ADDR(abx)
|
DEFINE_ADDR(abx)
|
||||||
{
|
{
|
||||||
ADDR_HILO(cpu);
|
ADDR_HILO(cpu);
|
||||||
MOS_CARRY_BIT();
|
EFF_ADDR(addr + cpu->X);
|
||||||
EFF_ADDR(addr + cpu->X + carry);
|
|
||||||
|
|
||||||
return mos6502_get(cpu, eff_addr);
|
return mos6502_get(cpu, eff_addr);
|
||||||
}
|
}
|
||||||
@ -125,8 +124,7 @@ DEFINE_ADDR(abx)
|
|||||||
DEFINE_ADDR(aby)
|
DEFINE_ADDR(aby)
|
||||||
{
|
{
|
||||||
ADDR_HILO(cpu);
|
ADDR_HILO(cpu);
|
||||||
MOS_CARRY_BIT();
|
EFF_ADDR(addr + cpu->Y);
|
||||||
EFF_ADDR(addr + cpu->Y + carry);
|
|
||||||
|
|
||||||
return mos6502_get(cpu, eff_addr);
|
return mos6502_get(cpu, eff_addr);
|
||||||
}
|
}
|
||||||
@ -166,8 +164,7 @@ DEFINE_ADDR(ind)
|
|||||||
* The indirect x-indexed address mode, as well as the y-indexed mode,
|
* The indirect x-indexed address mode, as well as the y-indexed mode,
|
||||||
* are a bit complicated. The single, next byte we read is a zero-page
|
* are a bit complicated. The single, next byte we read is a zero-page
|
||||||
* address to the base of _another_ zero-page address in memory; we add
|
* address to the base of _another_ zero-page address in memory; we add
|
||||||
* X to it, which is the address of what we next dereference. Carry does
|
* X to it, which is the address of what we next dereference.
|
||||||
* not factor into the arithmetic.
|
|
||||||
*/
|
*/
|
||||||
DEFINE_ADDR(idx)
|
DEFINE_ADDR(idx)
|
||||||
{
|
{
|
||||||
@ -183,13 +180,12 @@ DEFINE_ADDR(idx)
|
|||||||
* In significant contrast, the y-indexed indirect mode will read a
|
* In significant contrast, the y-indexed indirect mode will read a
|
||||||
* zero-page address from the next byte, and dereference it immediately.
|
* zero-page address from the next byte, and dereference it immediately.
|
||||||
* The ensuing address will then have Y added to it, and then
|
* The ensuing address will then have Y added to it, and then
|
||||||
* dereferenced for the final time. Carry _is_ factored in here.
|
* dereferenced for the final time.
|
||||||
*/
|
*/
|
||||||
DEFINE_ADDR(idy)
|
DEFINE_ADDR(idy)
|
||||||
{
|
{
|
||||||
ADDR_LO(cpu);
|
ADDR_LO(cpu);
|
||||||
MOS_CARRY_BIT();
|
EFF_ADDR(mos6502_get(cpu, addr) + cpu->Y);
|
||||||
EFF_ADDR(mos6502_get(cpu, addr) + cpu->Y + carry);
|
|
||||||
|
|
||||||
return mos6502_get(cpu, eff_addr);
|
return mos6502_get(cpu, eff_addr);
|
||||||
}
|
}
|
||||||
@ -235,7 +231,7 @@ DEFINE_ADDR(zpg)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* In zero-page x-indexed mode, we read the next byte; add X to that;
|
* In zero-page x-indexed mode, we read the next byte; add X to that;
|
||||||
* and dereference the result. Carry is not a factor here.
|
* and dereference the result.
|
||||||
*/
|
*/
|
||||||
DEFINE_ADDR(zpx)
|
DEFINE_ADDR(zpx)
|
||||||
{
|
{
|
||||||
@ -247,8 +243,7 @@ DEFINE_ADDR(zpx)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* This is, as with absolute y-indexed mode, the mirror opposite of the
|
* This is, as with absolute y-indexed mode, the mirror opposite of the
|
||||||
* zero-page x-indexed mode. We simply use the Y register and not the X,
|
* zero-page x-indexed mode. We simply use the Y register and not the X.
|
||||||
* and here as well, we do not factor in the carry bit.
|
|
||||||
*/
|
*/
|
||||||
DEFINE_ADDR(zpy)
|
DEFINE_ADDR(zpy)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user