
MOTOROLA
5-16
INSTRUCTION SET
CPU16
REFERENCE MANUAL
–122 from the branch instruction. Maximum positive ($7FFE) and
negative ($8000) 16-bit offsets correspond to displacements of
32772 and –32762.
5.6.4 Jump Instruction
The CPU16 JMP instruction uses 20-bit addressing, so that control can be passed to
any address in the memory map. It should be noted that BRA and LBRA execute in
fewer cycles than the indexed forms of JMP.
5.6.5 Subroutine Instructions
Subroutines can be called by short (BSR) or long (LBSR) branches, or by a jump
(JSR). A single instruction, RTS returns control to the calling routine.
All three types of calling instructions stack return PC and CCR values prior to transfer-
ring control to a subroutine. Stacking the CCR also saves the PK extension field. Other
resources can be saved by means of the PSHM instruction, if necessary.
Note
Instruction pipelining affects the operation of BSR. When a subrou-
tine is called, PK
:
PC contain the address of the calling instruction
plus $0006. LBSR and JSR stack this value, but BSR must adjust it
prior to stacking.
Table 5-23 Jump Summary
Mnemonic
JMP
Function
Jump
Operation
20-bit Address
PK : PC
Table 5-24 Subroutine Summary
Mnemonic
BSR
Function
Operation
Branch to Subroutine
(PK
:
PC)
2
PK : PC
Push (PC)
(SK : SP) – 2
SK : SP
Push (CCR)
(SK : SP) – 2
SK : SP
(PK : PC) + Offset
PK : PC
Push (PC)
(SK : SP) – 2
SK : SP
Push (CCR)
(SK : SP) – 2
SK : SP
20-bit Address
PK : PC
Push (PC)
(SK : SP) – 2
SK : SP
Push (CCR)
(SK : SP) – 2
SK : SP
(PK : PC) + Offset
PK : PC
(SK : SP) + 2
SK : SP
Pull PK
(SK : SP) + 2
SK : SP
Pull PC
(PK : PC) – 2
PK : PC
JSR
Jump to Subroutine
LBSR
Long Branch to Subroutine
RTS
Return from Subroutine
F
Freescale Semiconductor, Inc.
For More Information On This Product,
Go to: www.freescale.com
n
.