Datasheet
PIC18F87K90 FAMILY
DS39957D-page 464  2009-2011 Microchip Technology Inc.
BTFSC Bit Test File, Skip if Clear
Syntax: BTFSC f, b {,a}
Operands: 0 
 f  255
0 
 b  7
a 
[0,1]
Operation: skip if (f<b>) = 
0
Status Affected: None
Encoding:
1011 bbba ffff ffff
Description: If bit ‘b’ in register ‘f’ is ‘0’, then the next 
instruction is skipped. If bit ‘b’ is ‘
0’, then 
the next instruction fetched during the 
current instruction execution is discarded 
and a 
NOP is executed instead, making 
this a two-cycle instruction. 
If ‘a’ is ‘
0’, the Access Bank is selected. If 
‘a’ is ‘
1’, the BSR is used to select the 
GPR bank.
If ‘a’ is ‘
0’ and the extended instruction set 
is enabled, this instruction operates in 
Indexed Literal Offset Addressing mode 
whenever f 
95 (5Fh). See 
Section 29.2.3 “Byte-Oriented and 
Bit-Oriented Instructions in Indexed 
Literal Offset Mode”
 for details.
Words: 1
Cycles: 1(2)
Note: 3 cycles if skip and followed
by a 2-word instruction.
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read
register ‘f’
Process 
Data
No 
operation
If skip:
Q1 Q2 Q3 Q4
No 
operation
No 
operation
No 
operation
No 
operation
If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
Example:
HERE
FALSE
TRUE
BTFSC
:
:
FLAG, 1, 0
Before Instruction
PC = address (HERE)
After Instruction
If FLAG<1> = 
0;
PC = address
 (TRUE)
If FLAG<1> =  1;
PC = address
 (FALSE)
BTFSS Bit Test File, Skip if Set
Syntax: BTFSS f, b {,a}
Operands: 0 
 f  255
0 
 b < 7
a 
[0,1]
Operation: skip if (f<b>) = 
1
Status Affected: None
Encoding:
1010 bbba ffff ffff
Description: If bit ‘b’ in register ‘f’ is ‘1’, then the next 
instruction is skipped. If bit ‘b’ is ‘
1’, then 
the next instruction fetched during the 
current instruction execution is discarded 
and a 
NOP is executed instead, making 
this a two-cycle instruction. 
If ‘a’ is ‘
0’, the Access Bank is selected. If 
‘a’ is ‘
1’, the BSR is used to select the 
GPR bank.
If ‘a’ is ‘
0’ and the extended instruction 
set is enabled, this instruction operates in 
Indexed Literal Offset Addressing mode 
whenever f 
95 (5Fh). See 
Section 29.2.3 “Byte-Oriented and 
Bit-Oriented Instructions in Indexed 
Literal Offset Mode”
 for details.
Words: 1
Cycles: 1(2)
Note: 3 cycles if skip and followed
by a 2-word instruction.
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read
register ‘f’
Process 
Data
No 
operation
If skip:
Q1 Q2 Q3 Q4
No 
operation
No 
operation
No 
operation
No 
operation
If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
No 
operation
Example:
HERE
FALSE
TRUE
BTFSS
:
:
FLAG, 1, 0
Before Instruction
PC = address
 (HERE)
After Instruction
If FLAG<1> =  0;
PC = address
 (FALSE)
If FLAG<1> =  1;
PC = address  
(TRUE)










