1
0
mirror of https://github.com/pevans/erc-c.git synced 2025-01-17 19:30:13 +00:00

Clarify behavior of pop_stack

This commit is contained in:
Peter Evans 2018-04-13 16:22:58 -05:00
parent ebb5f068fd
commit 3887f52119

View File

@ -211,18 +211,15 @@ mos6502_push_stack(mos6502 *cpu, vm_8bit addr)
} }
/* /*
* Pop an address from the stack and return that. * Increment the stack register and return the value that is pointed at
* by the new offset. Because the S register is 8-bit, the following
* (correct) behavior is exhibited: when S overflows beyond 0xFF, it
* rolls over to 0x00.
*/ */
vm_8bit vm_8bit
mos6502_pop_stack(mos6502 *cpu) mos6502_pop_stack(mos6502 *cpu)
{ {
// The first thing we want to do here is to decrement S by 2, since
// the value we want to return is two positions back.
cpu->S++; cpu->S++;
// We need to use a bitwise-or operation to combine the hi and lo
// bytes we retrieve from the stack into the actual position we
// would use for the PC register.
return mos6502_get(cpu, 0x0100 + cpu->S); return mos6502_get(cpu, 0x0100 + cpu->S);
} }