We've just updated MediaWiki and its underlying software. If anything doesn't look or work quite right, please mention it to us. --RanAS

RTS

From SnesLab
Revision as of 20:00, 10 August 2024 by Xetheria (talk | contribs) (added image; sp incremented twice)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search
Basic Info
Addressing Mode Opcode Length Speed
Stack (RTS) 60 1 byte 6 cycles
Flags Affected
N V M X D I Z C
. . . . . . . .

RTS (Return from Subroutine) is a 65x instruction used to return control from a subroutine that was called from the same bank.

RTS pulls the return address from the stack, but increments the value by one before loading it into the program counter. In other words, RTS unwinds what JSR did to the stack. The stack pointer is incremented twice: during cycle 3 and cycle 4.

No flags are affected.

Syntax

RTS

rts.png

Forgetting to RTS can cause derailment as control falls through the end of the subroutine into the next one or garbage.

See Also

External Links