
The 8051 Instruction Set
1-55 Atmel 8051 Microcontrollers Hardware Manual
4316E–8051–01/07
1.14.39 RET
1.14.40 RETI
Function: Return from subroutine
Description: RET pops the high- and low-order bytes of the PC successively from the stack, decrementing the Stack Pointer
by two. Program execution continues at the resulting address, generally the instruction immediately following an
ACALL or LCALL. No flags are affected.
Example: The Stack Pointer originally contains the value 0BH. Internal RAM locations 0AH and 0BH contain the values
23H and 01H, respectively. The following instruction,
RET
leaves the Stack Pointer equal to the value 09H. Program execution continues at location 0123H.
Bytes: 1
Cycles: 2
Encoding: 0 0 1 0 0 0 1 0
Operation: RET
(PC
15-8
) ← ((SP))
(SP) ← (SP) - 1
(PC
7-0
) ← ((SP))
(SP) ← (SP) - 1
Function: Return from interrupt
Description: RETI pops the high- and low-order bytes of the PC successively from the stack and restores the interrupt logic to
accept additional interrupts at the same priority level as the one just processed. The Stack Pointer is left
decremented by two. No other registers are affected; the PSW is not automatically restored to its pre-interrupt
status. Program execution continues at the resulting address, which is generally the instruction immediately after
the point at which the interrupt request was detected. If a lower- or same-level interrupt was pending when the
RETI instruction is executed, that one instruction is executed before the pending interrupt is processed.
Example: The Stack Pointer originally contains the value 0BH. An interrupt was detected during the instruction ending at
location 0122H. Internal RAM locations 0AH and 0BH contain the values 23H and 01H, respectively. The
following instruction,
RETI
leaves the Stack Pointer equal to 09H and returns program execution to location 0123H.
Bytes: 1
Cycles: 2
Encoding: 0 0 1 1 0 0 1 0
Operation: RETI
(PC
15-8
) ← ((SP))
(SP) ← (SP) - 1
(PC
7-0
) ← ((SP))
(SP) ← (SP) - 1
Kommentare zu diesen Handbüchern