Datasheet
 2011 Microchip Technology Inc.   DS39931D-page 477
PIC18F46J50 FAMILY
28.2 Extended Instruction Set
In addition to the standard 75 instructions of the PIC18
instruction set, the PIC18F46J50 family of devices also
provide an optional extension to the core CPU function-
ality. The added features include eight additional
instructions that augment Indirect and Indexed
Addressing operations and the implementation of
Indexed Literal Offset Addressing for many of the
standard PIC18 instructions.
The additional features of the extended instruction
set are enabled by default on unprogrammed
devices. Users must properly set or clear the XINST
Configuration bit during programming to enable or
disable these features.
The instructions in the extended set can all be
classified as literal operations, which either manipulate
the File Select Registers (FSR), or use them for
Indexed Addressing. Two of the instructions, ADDFSR
and SUBFSR, each have an additional special instanti-
ation for using FSR2. These versions (ADDULNK and
SUBULNK) allow for automatic return after execution.
The extended instructions are specifically implemented
to optimize re-entrant program code (that is, code that
is recursive or that uses a software stack) written in
high-level languages, particularly C. Among other
things, they allow users working in high-level
languages to perform certain operations on data
structures more efficiently. These include:
• Dynamic allocation and deallocation of software 
stack space when entering and leaving 
subroutines
• Function Pointer invocation
• Software Stack Pointer manipulation
• Manipulation of variables located in a software 
stack
A summary of the instructions in the extended instruc-
tion set is provided in Tab l e 2 8 - 3 . Detailed descriptions
are provided in Section 28.2.2 “Extended Instruction
Set”. The opcode field descriptions in Table 28-1
(page 436) apply to both the standard and extended
PIC18 instruction sets.
28.2.1 EXTENDED INSTRUCTION SYNTAX
Most of the extended instructions use indexed argu-
ments, using one of the FSRs and some offset to specify
a source or destination register. When an argument for
an instruction serves as part of Indexed Addressing, it is
enclosed in square brackets (“[ ]”). This is done to indi-
cate that the argument is used as an index or offset. The
MPASM™ Assembler will flag an error if it determines
that an index or offset value is not bracketed.
When the extended instruction set is enabled, brackets
are also used to indicate index arguments in
byte-oriented and bit-oriented instructions. This is in
addition to other changes in their syntax. For more
details, see Section 28.2.3.1 “Extended Instruction
Syntax with Standard PIC18 Commands”.
TABLE 28-3: EXTENSIONS TO THE PIC18 INSTRUCTION SET
Note: The instruction set extension and the
Indexed Literal Offset Addressing mode
were designed for optimizing applications
written in C; the user may likely never use
these instructions directly in assembler.
The syntax for these commands is
provided as a reference for users who
may be reviewing code that has been
generated by a compiler.
Note: In the past, square brackets have been
used to denote optional arguments in the
PIC18 and earlier instruction sets. In this
text and going forward, optional
arguments are denoted by braces (“{ }”).
Mnemonic,
Operands
Description Cycles
16-Bit Instruction Word
Status
Affected
MSb LSb
ADDFSR
ADDULNK
CALLW
MOVSF
MOVSS
PUSHL
SUBFSR
SUBULNK
f, k
k
z
s
, f
d
z
s
, z
d
k
f, k
k
Add Literal to FSR
Add Literal to FSR2 and Return
Call Subroutine using WREG
Move z
s 
(source) to 1st word
f
d
 (destination) 2nd word
Move z
s
 (source) to 1st word
z
d
 (destination) 2nd word
Store Literal at FSR2, 
 Decrement FSR2
Subtract Literal from FSR
Subtract Literal from FSR2 and
 Return
1
2
2
2
2
1
1
2
1110
1110
0000
1110
1111
1110
1111
1110
1110
1110
1000
1000
0000
1011
ffff
1011
xxxx
1010
1001
1001
 ffkk
 11kk
 0001
0zzz
ffff
1zzz
xzzz
kkkk
ffkk
11kk
kkkk
kkkk
0100
zzzz
ffff
zzzz
zzzz
kkkk
kkkk
kkkk
None
None
None
None
—
None
—
None
—
None
None










