Datasheet
PIC18F2331/2431/4331/4431
DS39616D-page 314    2010 Microchip Technology Inc.
RETFIE Return from Interrupt
Syntax: [ label ]  RETFIE  [s]
Operands: s  [0,1]
Operation: (TOS)  PC,
1  GIE/GIEH or PEIE/GIEL;
if s = 1:
(WS)  W,
(STATUSS)  STATUS,
(BSRS)  BSR,
PCLATU, PCLATH are unchanged
Status Affected: GIE/GIEH, PEIE/GIEL.
Encoding: 0000 0000 0001 000s
Description: Return from interrupt. Stack is popped 
and Top-of-Stack (TOS) is loaded into 
the PC. Interrupts are enabled by 
setting either the high or low-priority 
global interrupt enable bit. If ‘s’ = 1, the 
contents of the shadow registers, WS, 
STATUSS and BSRS, are loaded into 
their corresponding registers, W, 
STATUS and BSR. If ‘s’ = 0, no update 
of these registers occurs.
Words: 1
Cycles: 2
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode No 
operation
No 
operation
POP PC 
from stack
Set GIEH or 
GIEL
No 
operation
No 
operation
No 
operation
No 
operation
Example:
RETFIE 1
After Interrupt
PC = TOS
W=WS
BSR = BSRS
STATUS = STATUSS
GIE/GIEH, PEIE/GIEL = 1
RETLW Return Literal to W
Syntax: [ label ]  RETLW k
Operands: 0  k  255
Operation: k  W,
(TOS)  PC,
PCLATU, PCLATH are unchanged
Status Affected: None
Encoding: 0000 1100 kkkk kkkk
Description: W is loaded with the 8-bit literal, ‘k’. The 
program counter is loaded from the top 
of the stack (the return address). The 
high address latch (PCLATH) remains 
unchanged. 
Words: 1
Cycles: 2
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read
literal ‘k’
Process 
Data
POP PC 
from stack, 
Write to W
No 
operation
No 
operation
No 
operation
No 
operation
Example:
  CALL TABLE ; W contains table
  ; offset value
  ; W now has 
  ; table value
 :
TABLE
ADDWF PCL ; W = offset
RETLW k0 ; Begin table
RETLW k1 ;
 :
 :
RETLW kn ; End of table
Before Instruction
W = 0x07
After Instruction
W = value of kn










