Pic 18 F 46 K 40

Download as pdf or txt
Download as pdf or txt
You are on page 1of 594

PIC18(L)F26/45/46K40

28/40/44-Pin, Low-Power, High-Performance


Microcontrollers with XLP Technology
Description
PIC18(L)F26/45/46K40 microcontrollers feature Analog, Core Independent Peripherals and Communication
Peripherals, combined with eXtreme Low-Power (XLP) technology for a wide range of general purpose and low-power
applications. These 28/40/44-pin devices are equipped with a 10-bit ADC with Computation (ADCC) automating
Capacitive Voltage Divider (CVD) techniques for advanced touch sensing, averaging, filtering, oversampling and
performing automatic threshold comparisons. They also offer a set of Core Independent Peripherals such as
Complementary Waveform Generator (CWG), Windowed Watchdog Timer (WWDT), Cyclic Redundancy Check (CRC)/
Memory Scan, Zero-Cross Detect (ZCD) and Peripheral Pin Select (PPS), providing for increased design flexibility and
lower system cost.
Core Features Power-Saving Operation Modes
C Compiler Optimized RISC Architecture Doze: CPU and Peripherals Running at Different
Only 83 Instructions Cycle Rates (typically CPU is lower)
Operating Speed: Idle: CPU Halted While Peripherals Operate
- DC 64 MHz clock input Sleep: Lowest Power Consumption
- 62.5 ns minimum instruction cycle Peripheral Module Disable (PMD):
Programmable 2-Level Interrupt Priority - Ability to selectively disable hardware module
31-Level Deep Hardware Stack to minimize active power consumption of
Three 8-Bit Timers (TMR2/4/6) with Hardware unused peripherals
Limit Timer (HLT) eXtreme Low-Power (XLP) Features
Four 16-Bit Timers (TMR0/1/3/5)
Low-Current Power-on Reset (POR) Sleep mode: 50 nA @ 1.8V, typical
Power-up Timer (PWRT) Windowed Watchdog Timer: 500 nA @ 1.8V,
Brown-out Reset (BOR) typical
Low-Power BOR (LPBOR) Option Secondary Oscillator: 500 nA @ 32 kHz
Programmable Code Protection Operating Current:
Windowed Watchdog Timer (WWDT): - 8 uA @ 32 kHz, 1.8V, typical
- Timer monitoring of overflow and underflow - 32 uA/MHz @ 1.8V, typical
events Digital Peripherals
- Variable prescaler selection
Complementary Waveform Generator (CWG):
- Variable window size selection
- Rising and falling edge dead-band control
- All sources configurable in hardware or
- Full-bridge, half-bridge, 1-channel drive
software
- Multiple signal sources
Memory Capture/Compare/PWM (CCP) modules:
Up to 64K bytes Program Flash Memory - Two CCPs
Up to 3728 Bytes Data SRAM Memory - 16-bit resolution for Capture/Compare modes
Up to 1024 Bytes Data EEPROM - 10-bit resolution for PWM mode
Direct, Indirect and Relative Addressing modes 10-Bit Pulse-Width Modulators (PWM):
- Two 10-bit PWMs
Operating Characteristics Serial Communications:
Operating Voltage Ranges: - Two Enhanced USART (EUSART) with Auto-
- 1.8V to 3.6V (PIC18LF2x/4xK40) Baud Detect, Auto-wake-up on Start.
- 2.3V to 5.5V (PIC18F2x/4xK40) RS-232, RS-485, LIN compatible
Temperature Range: - SPI
- Industrial: -40C to 85C - I2C, SMBus and PMBus compatible
- Extended: -40C to 125C Up to 35 I/O Pins and One Input Pin:
- Individually programmable pull-ups
- Slew rate control
- Interrupt-on-change on all pins
- Input level selection control

2016 Microchip Technology Inc. Preliminary DS40001816C-page 1


PIC18(L)F26/45/46K40
Digital Peripherals (Continued) Clocking Structure
Programmable CRC with Memory Scan: High-Precision Internal Oscillator Block (HFINTOSC):
- Reliable data/program memory monitoring for - Selectable frequency range up to 64 MHz
Fail-Safe operation (e.g., Class B) - 1% at calibration
- Calculate CRC over any portion of Flash or 32 kHz Low-Power Internal Oscillator (LFINTOSC)
EEPROM External 32 kHz Crystal Oscillator (SOSC)
- High-speed or background operation External Oscillator Block:
Hardware Limit Timer (TMR2/4/6+HLT): - Three crystal/resonator modes
- Hardware monitoring and Fault detection - 4x PLL with external sources
Peripheral Pin Select (PPS): Fail-Safe Clock Monitor:
- Enables pin mapping of digital I/O - Allows for safe shutdown if peripheral clock
Data Signal Modulator (DSM) stops
Oscillator Start-up Timer (OST)
Analog Peripherals
Programming/Debug Features
10-Bit Analog-to-Digital Converter with Computa-
tion (ADC2): In-Circuit Debug Integrated On-Chip
- 35 external channels In-Circuit Serial Programming (ICSP) via Two
- Conversion available during Sleep Pins
- Four internal analog channels In-Circuit Debug (ICD) with Three Breakpoints via
- Internal and external trigger options Two Pins
- Automated math functions on input signals:
- averaging, filter calculations, oversampling
and threshold comparison
Hardware Capacitive Voltage Divider (CVD)
Support:
- 8-bit precharge timer
- Adjustable sample and hold capacitor array
- Guard ring digital output drive
Zero-Cross Detect (ZCD):
- Detect when AC signal on pin crosses
ground
5-Bit Digital-to-Analog Converter (DAC):
- Output available externally
- Programmable 5-bit voltage (% of VDD)
- Internal connections to comparators, Fixed
Voltage Reference and ADC
Two Comparators (CMP):
- Four external inputs
- External output via PPS
Fixed Voltage Reference (FVR) module:
- 1.024V, 2.048V and 4.096V output levels

2016 Microchip Technology Inc. Preliminary DS40001816C-page 2


PIC18(L)F26/45/46K40
PIC18(L)F2x/4xK40 Family Types

Peripheral Module Disable


CRC with Memory Scan
Program Memory Flash

Temperature Indicator
Windowed Watchdog
8-bit TMR with HLT
Zero-Cross Detect
Computation (ch)
Data Sheet Index

10-bit ADC2 with

CCP/10-bit PWM
Data EEPROM

16-bit Timers

Comparators
Data SRAM

5-bit DAC

EUSART

Debug(1)
I/O Pins

I2C/SPI
(bytes)

(bytes)

(bytes)

Timer
CWG

PPS
Device

PIC18(L)F24K40 (1) 16k 1024 256 25 4 2 24 1 1 2/2 1 3 Y Y 1 1 Y Y Y I


PIC18(L)F25K40 (1) 32k 2048 256 25 4 2 24 1 1 2/2 1 3 Y Y 1 1 Y Y Y I
PIC18(L)F26K40 (2) 64k 3728 1024 25 4 2 24 1 1 2/2 1 3 Y Y 2 2 Y Y Y I
PIC18(L)F27K40 (3) 128k 3728 1024 25 4 2 24 1 1 2/2 1 3 Y Y 2 2 Y Y Y I
PIC18(L)F45K40 (2) 32k 2048 256 36 4 2 35 1 1 2/2 1 3 Y Y 2 2 Y Y Y I
PIC18(L)F46K40 (2) 64k 3728 1024 36 4 2 35 1 1 2/2 1 3 Y Y 2 2 Y Y Y I
PIC18(L)F47K40 (3) 128k 3728 1024 36 4 2 35 1 1 2/2 1 3 Y Y 2 2 Y Y Y I
Note 1: Debugging Methods: (I) Integrated on Chip.
Data Sheet Index: (Unshaded devices are described in this document.)
1. DS40001843 PIC18(L)F24/25K40 Data Sheet, 28-Pin, 8-bit Flash Microcontrollers
2. DS40001816 PIC18(L)F26/45/46K40 Data Sheet, 28/40/44-Pin, 8-bit Flash Microcontrollers
3. DS40001844 PIC18(L)F27/47K40 Data Sheet, 28/40/44-Pin, 8-bit Flash Microcontrollers

Note: For other small form-factor package availability and marking information, please visit
http://www.microchip.com/packaging or contact your local sales office.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 3


PIC18(L)F26/45/46K40
Pin Diagrams

28-pin SPDIP, SOIC, SSOP

VPP/MCLR/RE3 1 28 RB7/ICSPDAT
RA0 2 27 RB6/ICSPCLK
RA1 3 26 RB5
RA2 4 25 RB4
RA3 5 24 RB3

PIC18(L)F2xK40
RA4 6 23 RB2
RA5 7 22 RB1
VSS 8 21 RB0
RA7 9 20 VDD
RA6 10 19 VSS
RC0 11 18 RC7
RC1 12 17 RC6
RC2 13 16 RC5
RC3 14 15 RC4

Note: See Table 1 for location of all peripheral functions.

28-pin QFN (6x6x0.9mm), UQFN (4x4x0.5mm)


RE3/MCLR/VPP

RB6/ICSPCLK
RB7/ICSPDAT
RA0

RB5
RB4
RA1

28 27 26 25 24 23 22
RA2 1 21 RB3
RA3 2 20 RB2
RA4 3 19 RB1
RA5 4 PIC18(L)F2xK40 18 RB0
VSS 5 17 VDD
RA7 6 16 VSS
RA6 7 15 RC7
8 9 10 11 12 13 14
RC5
RC0

RC6
RC2
RC3
RC4
RC1

Note 1: See Table 1 for location of all peripheral functions.


2: It is recommended that the exposed bottom pad be connected to VSS, however it must not be the
only VSS connection to the device.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 4


PIC18(L)F26/45/46K40

40-pin PDIP
VPP/MCLR/RE3 1 40 RB7/ICSPDAT
RA0 2 39 RB6/ICSPCLK
RA1 3 38 RB5
RA2 4 37 RB4
RA3 5 36 RB3
RA4 6 35 RB2
RA5 7 34 RB1

PIC18(L)F4xK40
RE0 8 33 RB0
RE1 9 32 VDD
RE2 10 31 VSS
VDD 11 30 RD7
VSS 12 29 RD6
RA7 13 28 RD5
RA6 14 27 RD4
RC0 15 26 RC7
RC1 16 25 RC6
RC2 17 24 RC5
RC3 18 23 RC4
RD0 19 22 RD3
RD1 20 21 RD2

Note: See Table 2 for location of all peripheral functions.

40-pin UQFN (5x5x0.5mm)


RC5
RC6

RC4
RD3
RD2
RD1
RD0
RC3
RC2
RC1

40 39 38 37 36 35 34 33 32 31
RC7 1
RD4 2 30 RC0
RD5 3 29 RA6
RD6 4 28 RA7
RD7 5 27 VSS
VSS 6 PIC18(L)F4xK40 26 VDD
VDD 7 25 RE2
RB0 8 24 RE1
RB1 9 23 RE0
RB2 22 RA5
10
21 RA4
11 12 13 14 15 16 17 18 19 20
RB3

RA1
RA2
RA3
RB4
RB5

VPP/MCLR/RE3
RA0
ICSPCLK/RB6
ICSPDAT/RB7

Note 1: See Table 2 for location of all peripheral functions.


2: It is recommended that the exposed bottom pad be connected to VSS, however it must not be the only
VSS connection to the device.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 5


PIC18(L)F26/45/46K40

44-pin QFN (8x8x0.9mm)

RC6
RC5
RC4
RD3
RD2
RD1
RD0
RC3
RC2
RC1
RC0
43
42
41
40
39

37
36
35
34
44

38
RC7 1 33 RA6
RD4 2 32 RA7
RD5 3 31 NC
RD6 4 30 VSS
RD7 5 29 NC
VSS 6 PIC18(L)F4xK40 28 VDD
VDD 7 27 RE2
NC 8 26 RE1
RB0 9 25 RE0
RB1 10 24 RA5
RB2 11 23 RA4

22
21
12
13
14
15
16
17
18
19
20
ICSPCLK/RB6
RB3

RB4
RB5

RA0
RA2
ICSPDAT/RB7
VPP/MCLR/RE3
RA1
NC

RA3
Note 1: See Table 2 for location of all peripheral functions.
2: It is recommended that the exposed bottom pad be connected to VSS, however it must not be the
only VSS connection to the device.

44-pin TQFP
RC5
RC6

RC4
RD3
RD2
RD1
RD0
RC3
RC2
RC1
NC

44 43 42 41 40 39 38 37 36 35 34
RC7 1 33 NC
RD4 2 32 RC0
RD5 3 31 RA6
4 30 RA7
RD6
RD7 5 29 VSS
6 PIC18(L)F4xK40 28 VDD
VSS
VDD 7 27 RE2
RB0 8 26 RE1
RB1 9 25 RE0
RB2 10 24 RA5
23 RA4
RB3 11
12 13 14 15 16 17 18 19 20 21 22
RA2
RA3
RB4
RB5

ICSPDAT/RB7
VPP/MCLR/RE3
AN0/RA0
ICSPCLK/RB6

AN1/RA1
NC
NC

Note: See Table 2 for location of all peripheral functions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 6


Pin Allocation Tables
2016 Microchip Technology Inc.

TABLE 1: 28-Pin SPDIP, SOIC, SSOP 28-PIN ALLOCATION TABLE (PIC18(L)F26K40)

28-Pin (U)QFN

Comparator
Reference

Interrupt

EUSART

Pull-up
Timers

MSSP

Basic
CWG

DSM
CCP

ZCD
A/D
I/O(2)

RA0 2 27 ANA0 C1IN0- IOCA0 Y


C2IN0-
RA1 3 28 ANA1 C1IN1- IOCA1 Y
C2IN1-
RA2 4 1 ANA2 DAC1OUT1 C1IN0+ IOCA2 Y
VREF- (DAC) C2IN0+
VREF- (ADC)
Preliminary

RA3 5 2 ANA3 VREF+ (DAC) C1IN1+ IOCA3 MDCIN1(1) Y


VREF+ (ADC)
RA4 6 3 ANA4 T0CKI(1) IOCA4 MDCIN2(1) Y
RA5 7 4 ANA5 IOCA5 MDMIN(1) SS1(1) Y

PIC18(L)F26/45/46K40

RA6 10 7 ANA6 IOCA6 Y CLKOUT
OSC2
RA7 9 6 ANA7 IOCA7 Y OSC1
CLKIN
RB0 21 18 ANB0 C2IN1+ CWG1(1) ZCDIN IOCB0 SS2(1) Y
INT0(1)
RB1 22 19 ANB1 C1IN3- IOCB1 SCK2(1) Y
C2IN3- INT1(1) SCL2(3,4)
RB2 23 20 ANB2 IOCB2 SDI2(1) Y
INT2(1) SDA2(3,4)
RB3 24 21 ANB3 C1IN2- IOCB3 Y
C2IN2-
RB4 25 22 ANB4 T5G(1) IOCB4 Y
(1)
RB5 26 23 ANB5 T1G IOCB5 Y
DS40001816C-page 7

RB6 27 24 ANB6 IOCB6 CK2(1) Y ICSPCLK


RB7 28 25 ANB7 DAC1OUT2 T6AIN(1) IOCB7 RX2/DT2(1) Y ICSPDAT
Note 1: Default peripheral input. Input can be moved to any other pin with the PPS input selection registers (Register 17-1).
2: All pin outputs default to PORT latch data. Any pin can be selected as a peripheral digital output with the PPS output selection registers.
3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.
4: These pins are configured for I2C logic levels; The SCLx/SDAx signals may be assigned to any of these pins. PPS assignments to the other pins (e.g., RB1) will operate, but input logic levels will be
standard TTL/ST as selected by the INLVL register, instead of the I2C specific or SMBus input buffer thresholds.
TABLE 1: 28-PIN ALLOCATION TABLE (PIC18(L)F26K40) (CONTINUED)
2016 Microchip Technology Inc.

28-Pin SPDIP, SOIC, SSOP

28-Pin (U)QFN

Comparator
Reference

Interrupt

EUSART

Pull-up
Timers

MSSP

Basic
CWG

DSM
CCP

ZCD
A/D
I/O(2)

RC0 11 8 ANC0 T1CKI(1) IOCC0 Y SOSCO


T3CKI(1)
T3G(1)
RC1 12 9 ANC1 CCP2(1) IOCC1 Y SOSCIN
SOSCI
RC2 13 10 ANC2 T5CKI(1) CCP1(1) IOCC2 Y
RC3 14 11 ANC3 T2AIN(1) IOCC3 SCK1(1) Y
SCL1(3,4)
RC4 15 12 ANC4 IOCC4 SDI1(1) Y
SDA1(3,4)
Preliminary

RC5 16 13 ANC5 T4AIN(1) IOCC5 Y


RC6 17 14 ANC6 IOCC6 CK1(1) Y
RC7 18 15 ANC7 IOCC7 RX1/DT1(1) Y

PIC18(L)F26/45/46K40
RE3 1 26 IOCE3 Y VPP/MCLR
VSS 19 16 VSS
VDD 20 17 VDD
VSS 8 5 VSS
OUT(2) ADGRDA C1OUT TMR0 CCP1 CWG1A TX1/CK1(3) DSM SDO1
ADGRDB C2OUT CCP2 CWG1B DT1(3) SCK1
PWM3 CWG1C TX2/CK2(3) SDO2
PWM4 CWG1D DT2(3) SCK2
Note 1: Default peripheral input. Input can be moved to any other pin with the PPS input selection registers (Register 17-1).
2: All pin outputs default to PORT latch data. Any pin can be selected as a peripheral digital output with the PPS output selection registers.
3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.
4: These pins are configured for I2C logic levels; The SCLx/SDAx signals may be assigned to any of these pins. PPS assignments to the other pins (e.g., RB1) will operate, but input logic levels will be
standard TTL/ST as selected by the INLVL register, instead of the I2C specific or SMBus input buffer thresholds.
DS40001816C-page 8
2016 Microchip Technology Inc.

TABLE 2: 40/44-PIN ALLOCATION TABLE (PIC18(L)F45/46K40)

40-Pin UQFN

44-Pin TQFP

Comparator
40-Pin PDIP

44-Pin QFN

Reference

Interrupt

EUSART

Pull-up
Timers

MSSP

Basic
CWG

DSM
CCP

ZCD
A/D
I/O(2)

RA0 2 17 19 19 ANA0 C1INO- IOCA0 Y


C2IN0-
RA1 3 18 20 20 ANA1 C1IN1- IOCA1 Y
C2IN1-
RA2 4 19 21 21 ANA2 DAC1OUT1 C1IN0+ IOCA2 Y
VREF- (DAC5) C2IN0+
VREF- (ADC)
RA3 5 20 22 22 ANA3 VREF+ (DAC5) C1IN1+ IOCA3 MDCIN1(1) Y
VREF+ (ADC)
RA4 6 21 23 23 ANA4 T0CKI(1) IOCA4 MDCIN2(1) Y
RA5 7 22 24 24 ANA5 IOCA5 MDMIN(1) SS1(1) Y
RA6 14 29 33 31 ANA6 IOCA6 Y CLKOUT
OSC2
Preliminary

RA7 13 28 32 30 ANA7 IOCA7 Y OSC1


CLKIN
RB0 33 8 9 8 ANB0 C2IN1+ CWG1(1) ZCDIN IOCB0 SS2(1) Y
INT0(1)

PIC18(L)F26/45/46K40
RB1 34 9 10 9 ANB1 C1IN3- IOCB1 SCK2(1) Y
C2IN3- INT1(1) SCL2(3,4)
RB2 35 10 11 10 ANB2 IOCB2 SDI2(1) Y
INT2(1) SDA2(3,4)
RB3 36 11 12 11 ANB3 C1IN2- IOCB3 Y
C2IN2-
RB4 37 12 14 14 ANB4 T5G(1) IOCB4 Y
RB5 38 13 15 15 ANB5 T1G(1) IOCB5 Y
RB6 39 14 16 16 ANB6 IOCB6 CK2(1) Y ICSPCLK
RB7 40 15 17 17 ANB7 DAC1OUT2 T6AIN(1) IOCB7 RX2/DT2(1) Y ICSPDAT
RC0 15 30 34 32 ANC0 T1CKI(1) IOCC0 Y SOSCO
T3CKI(1)
(1)
T3G
DS40001816C-page 9

RC1 16 31 35 35 ANC1 CCP2(1) IOCC1 Y SOSCIN


SOSCI
Note 1: Default peripheral input. Input can be moved to any other pin with the PPS input selection registers (Register 17-1).
2: All pin outputs default to PORT latch data. Any pin can be selected as a peripheral digital output with the PPS output selection registers.
3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.
4: These pins are configured for I2C logic levels; The SCLx/SDAx signals may be assigned to any of these pins. PPS assignments to the other pins (e.g., RB1) will operate, but input logic levels will be
standard TTL/ST as selected by the INLVL register, instead of the I2C specific or SMBus input buffer thresholds.
TABLE 2: 40/44-PIN ALLOCATION TABLE (PIC18(L)F45/46K40) (CONTINUED)
2016 Microchip Technology Inc.

40-Pin UQFN

44-Pin TQFP

Comparator
40-Pin PDIP

44-Pin QFN

Reference

Interrupt

EUSART

Pull-up
Timers

MSSP

Basic
CWG

DSM
CCP

ZCD
A/D
I/O(2)

RC2 17 32 36 36 ANC2 T5CKI(1) CCP1(1) IOCC2 Y


(1)
RC3 18 33 37 37 ANC3 T2AIN IOCC3 SCK1(1) Y
SCL1(3,4)
RC4 23 38 42 42 ANC4 IOCC4 SDI1(1)
SDA1(3,4)
RC5 24 39 43 43 ANC5 T4AIN(1) IOCC5 Y
RC6 25 40 44 44 ANC6 IOCC6 CK1(1) Y
RC7 26 1 1 1 ANC7 IOCC7 RX1/DT1(1) Y
RD0 19 34 38 38 AND0 IOCD0 Y
RD1 20 35 39 39 AND1 IOCD1 Y
RD2 21 36 40 40 AND2 IOCD2 Y
RD3 22 37 41 41 AND3 IOCD3 Y
RD4 27 2 2 2 AND4 IOCD4 Y
Preliminary

RD5 28 3 3 3 AND5 IOCD5 Y


RD6 29 4 4 4 AND6 IOCD6 Y
RD7 30 5 5 5 AND7 IOCD7 Y

PIC18(L)F26/45/46K40
RE0 8 23 25 25 ANE0 Y
RE1 9 24 26 26 ANE1 Y
RE2 10 25 27 27 ANE2 Y
RE3 1 16 18 18 IOCE3 Y VPP/MCLR
VSS 12 6 6 6 VSS
VDD 11 7 7 7 VDD
VDD 32 26 28 28 VDD
VSS 31 27 30 29 VSS
OUT(2) ADGRDA C1OUT TMR0 CCP1 CWG1A TX1/ DSM SDO1 OUT(2)
ADGRDB C2OUT CCP2 CWG1B CK1(3) SCK1
PWM3 CWG1C DT1(3) SDO2
PWM4 CWG1D TX2/ SCK2
CK2(3)
DT2(3)
DS40001816C-page 10

Note 1: Default peripheral input. Input can be moved to any other pin with the PPS input selection registers (Register 17-1).
2: All pin outputs default to PORT latch data. Any pin can be selected as a peripheral digital output with the PPS output selection registers.
3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.
4: These pins are configured for I2C logic levels; The SCLx/SDAx signals may be assigned to any of these pins. PPS assignments to the other pins (e.g., RB1) will operate, but input logic levels will be
standard TTL/ST as selected by the INLVL register, instead of the I2C specific or SMBus input buffer thresholds.
PIC18(L)F26/45/46K40
Table of Contents
1.0 Device Overview ........................................................................................................................................................................ 13
2.0 Guidelines for Getting Started with PIC18(L)F26/45/46K40 Microcontrollers ............................................................................ 18
3.0 Device Configuration .................................................................................................................................................................. 21
4.0 Oscillator Module (with Fail-Safe Clock Monitor) ....................................................................................................................... 34
5.0 Reference Clock Output Module ................................................................................................................................................ 53
6.0 Power-Saving Operation Modes ................................................................................................................................................ 58
7.0 Peripheral Module Disable (PMD).............................................................................................................................................. 66
8.0 Resets ........................................................................................................................................................................................ 73
9.0 Windowed Watchdog Timer (WWDT) ........................................................................................................................................ 82
10.0 Memory Organization ................................................................................................................................................................. 91
11.0 Nonvolatile Memory (NVM) Control.......................................................................................................................................... 123
12.0 8x8 Hardware Multiplier............................................................................................................................................................ 147
13.0 Cyclic Redundancy Check (CRC) Module with Memory Scanner............................................................................................ 149
14.0 Interrupts .................................................................................................................................................................................. 166
15.0 I/O Ports ................................................................................................................................................................................... 196
16.0 Interrupt-on-Change ................................................................................................................................................................. 208
17.0 Peripheral Pin Select (PPS) Module ........................................................................................................................................ 212
18.0 Timer0 Module ......................................................................................................................................................................... 220
19.0 Timer1/3/5 Module with Gate Control....................................................................................................................................... 226
20.0 Timer2/4/6 Module ................................................................................................................................................................... 242
21.0 Capture/Compare/PWM Module .............................................................................................................................................. 263
22.0 Pulse-Width Modulation (PWM ) .............................................................................................................................................. 277
23.0 Zero-Cross Detection (ZCD) Module........................................................................................................................................ 285
24.0 Complementary Waveform Generator (CWG) Module ............................................................................................................ 291
25.0 Data Signal Modulator (DSM) Module...................................................................................................................................... 318
26.0 Master Synchronous Serial Port Module ................................................................................................................................. 329
27.0 Enhanced Universal Synchronous Asynchronous Receiver Transmitter (EUSART) ............................................................... 386
28.0 Fixed Voltage Reference (FVR) .............................................................................................................................................. 417
29.0 Temperature Indicator Module ................................................................................................................................................. 419
30.0 5-Bit Digital-to-Analog Converter (DAC) Module...................................................................................................................... 421
31.0 Analog-to-Digital Converter with Computation (ADC2) Module ............................................................................................... 425
32.0 Comparator Module.................................................................................................................................................................. 461
33.0 High/Low-Voltage Detect (HLVD)............................................................................................................................................. 471
34.0 In-Circuit Serial Programming (ICSP) ............................................................................................................................... 478
35.0 Instruction Set Summary .......................................................................................................................................................... 480
36.0 Development Support............................................................................................................................................................... 530
37.0 Electrical Specifications............................................................................................................................................................ 534
38.0 DC and AC Characteristics Graphs and Tables....................................................................................................................... 564
39.0 Packaging Information.............................................................................................................................................................. 565
Appendix A: Revision History............................................................................................................................................................. 589
Appendix B: Device Differences ........................................................................................................................................................ 590
The Microchip Website ...................................................................................................................................................................... 591
Customer Change Notification Service .............................................................................................................................................. 591
Customer Support .............................................................................................................................................................................. 591
Product Identification System ............................................................................................................................................................ 592

2016 Microchip Technology Inc. Preliminary DS40001816C-page 11


PIC18(L)F26/45/46K40

TO OUR VALUED CUSTOMERS


It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip
products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and
enhanced as new volumes and updates are introduced.
If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via
E-mail at docerrors@microchip.com. We welcome your feedback.

Most Current Data Sheet


To obtain the most up-to-date version of this data sheet, please register at our Worldwide Website at:
http://www.microchip.com
You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page.
The last character of the literature number is the version number, (e.g., DS30000000A is version A of document DS30000000).

Errata
An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current
devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision
of silicon and revision of document to which it applies.
To determine if an errata sheet exists for a particular device, please check with one of the following:
Microchips Worldwide Website; http://www.microchip.com
Your local Microchip sales office (see last page)
When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are
using.

Customer Notification System


Register on our website at www.microchip.com to receive the most current information on all of our products.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 12


PIC18(L)F26/45/46K40
1.0 DEVICE OVERVIEW 1.1.2 MULTIPLE OSCILLATOR OPTIONS
AND FEATURES
This document contains device specific information for
the following devices: All of the devices in the PIC18(L)F2x/4xK40 family offer
several different oscillator options. The PIC18(L)F2x/
PIC18F26K40 PIC18LF26K40 4xK40 family can be clocked from several different
PIC18F45K40 PIC18LF45K40 sources:
PIC18F46K40 PIC18LF46K40 HFINTOSC
- 1-16 MHz precision digitally controlled inter-
This family offers the advantages of all PIC18
nal oscillator
microcontrollers namely, high computational perfor-
LFINTOSC
mance at an economical price with the addition of
- 31 kHz internal oscillator
high-endurance, Program Flash Memory. In addition to
EXTOSC
these features, the PIC18(L)F2x/4xK40 family intro-
- External clock (EC)
duces design enhancements that make these micro-
- Low-power oscillator (LP)
controllers a logical choice for many high-performance,
- Medium power oscillator (XT)
power sensitive applications.
- High-power oscillator (HS)
1.1 New Core Features SOSC
- Secondary oscillator circuit operating at
1.1.1 XLP TECHNOLOGY 31 kHz
A Phase Lock Loop (PLL) frequency multiplier
All of the devices in the PIC18(L)F2x/4xK40 family (4x) is available to both the External and Internal
incorporate a range of features that can significantly Oscillator modes enabling clock speeds of up to
reduce power consumption during operation. Key 64 MHz
items include:
Besides its availability as a clock source, the internal
Alternate Run Modes: By clocking the controller oscillator block provides a stable reference source that
from the secondary oscillator or the internal gives the family additional features for robust
oscillator block, power consumption during code operation:
execution can be reduced by as much as 90%.
Fail-Safe Clock Monitor: This option constantly
Multiple Idle Modes: The controller can also run
monitors the main clock source against a
with its CPU core disabled but the peripherals still
reference signal provided by the LFINTOSC. If a
active. In these states, power consumption can be
clock failure occurs, the controller is switched to
reduced even further, to as little as 4% of normal
the internal oscillator block, allowing for continued
operation requirements.
operation or a safe application shutdown.
On-the-fly Mode Switching: The power-
Two-Speed Start-up: This option allows the
managed modes are invoked by user code during
internal oscillator to serve as the clock source
operation, allowing the user to incorporate
from Power-on Reset, or wake-up from Sleep
power-saving ideas into their applications
mode, until the primary clock source is available.
software design.
Peripheral Module Disable: Modules that are
not being used in the code can be selectively
disabled using the PMD module. This further
reduces the power consumption.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 13


PIC18(L)F26/45/46K40
1.2 Other Special Features 1.3 Details on Individual Family
Memory Endurance: The Flash cells for both
Members
program memory and data EEPROM are rated to Devices in the PIC18(L)F2x/4xK40 family are available
last for many thousands of erase/write cycles up in 28-pin and 40/44-pin packages. The block diagram
to 10K for program memory and 100K for for this device is shown in Figure 1-1.
EEPROM. Data retention without refresh is
The devices have the following differences:
conservatively estimated to be greater than 40
years. 1. Program Flash Memory
Self-programmability: These devices can write 2. Data Memory SRAM
to their own program memory spaces under 3. Data Memory EEPROM
internal software control. By using a boot loader 4. A/D channels
routine located in the protected Boot Block at the
5. I/O ports
top of program memory, it becomes possible to
create an application that can update itself in the 6. Enhanced USART
field. 7. Input Voltage Range/Power Consumption
Extended Instruction Set: The PIC18(L)F2x/ All other features for devices in this family are identical.
4xK40 family introduces an optional extension to These are summarized in Table 1-1.
the PIC18 instruction set, which adds eight new The pinouts for all devices are listed in the pin summary
instructions and an Indexed Addressing mode. tables (Table 1 and Table 2).
This extension, enabled as a device configuration
option, has been specifically designed to optimize
re-entrant application code originally developed in
high-level languages, such as C.
Enhanced Peripheral Pin Select: The
Peripheral Pin Select (PPS) module connects
peripheral inputs and outputs to the device I/O
pins. Only digital signals are included in the
selections. All analog inputs and outputs remain
fixed to their assigned pins.
Enhanced Addressable EUSART: This serial
communication module is capable of standard
RS-232 operation and provides support for the
LIN bus protocol. Other enhancements include
automatic baud rate detection and a 16-bit Baud
Rate Generator for improved resolution. When the
microcontroller is using the internal oscillator
block, the EUSART provides stable operation for
applications that talk to the outside world without
using an external crystal (or its accompanying
power requirement).
10-bit A/D Converter with Computation: This
module incorporates programmable acquisition
time, allowing for a channel to be selected and a
conversion to be initiated without waiting for a
sampling period and thus, reduce code overhead.
It has a new module called ADC2 with
computation features, which provides a digital
filter and threshold interrupt functions.
Windowed Watchdog Timer (WWDT):
- Timer monitoring of overflow and underflow
events
- Variable prescaler selection
- Variable window size selection
- All sources configurable in hardware or
software

2016 Microchip Technology Inc. Preliminary DS40001816C-page 14


PIC18(L)F26/45/46K40

TABLE 1-1: DEVICE FEATURES


Features PIC18(L)F26K40 PIC18(L)F45K40 PIC18(L)F46K40
Program Memory (Bytes) 65536 32768 65536
Program Memory (Instructions) 32768 16384 32768
Data Memory (Bytes) 3720 2048 3720
Data EEPROM Memory (Bytes) 1024 256 1024
(1)
I/O Ports A,B,C,E A,B,C,D,E A,B,C,D,E
Capture/Compare/PWM Modules (CCP) 2 2 2
10-Bit Pulse-Width Modulator (PWM) 2 2 2
10-Bit Analog-to-Digital Module (ADC2) 4 internal 4 internal 4 internal
with Computation Accelerator 24 external 35 external 35 external
28-pin SPDIP
40-pin PDIP 40-pin PDIP
28-pin SOIC
40-pin UQFN 40-pin UQFN
Packages 28-pin SSOP
44-pin QFN 44-pin QFN
28-pin QFN
44-pin TQFP 44-pin TQFP
28-pin UQFN
Interrupt Sources 36
Timers (16-/8-bit) 4/3
2 MSSP,
Serial Communications
2 EUSART
Enhanced Complementary Waveform
1
Generator (ECWG)
Zero-Cross Detect (ZCD) 1
Data Signal Modulator (DSM) 1
Peripheral Pin Select (PPS) Yes
Peripheral Module Disable (PMD) Yes
16-bit CRC with NVMSCAN Yes
Programmable High/Low-Voltage Detect
Yes
(HLVD)
Programmable Brown-out Reset (BOR) Yes
POR, BOR,
RESET Instruction,
Stack Overflow,
Resets (and Delays)
Stack Underflow
(PWRT, OST),
MCLR, WDT
75 Instructions;
Instruction Set
83 with Extended Instruction Set enabled
Operating Frequency DC 64 MHz

Note 1: PORTE contains the single RE3 read-only bit.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 15


PIC18(L)F26/45/46K40
FIGURE 1-1: PIC18(L)F2X/4XK40 FAMILY BLOCK DIAGRAM

Data Bus<8>
Table Pointer<21>

8 8 Data Latch
inc/dec logic
Data Memory
21 PCLATU PCLATH
20 Address Latch PORTA
PCU PCH PCL RA<7:0>
Program Counter 12
Data Address<12>
31-Level Stack
Address Latch 4 12 4
BSR FSR0 Access
Program Memory STKPTR Bank
(8/16/32/64 Kbytes) FSR1
PORTB
FSR2 12
Data Latch RB<7:0>

inc/dec
8 logic
Table Latch

ROM Latch Address


Instruction Bus <16> Decode
PORTC
IR RC<7:0>

8
Instruction State machine
Decode and control signals
Control
PRODH PRODL
PORTD
8x8 Multiply RD<7:0>
3 8

BITOP W
8 8 8

OSC1(2) Internal
Oscillator Power-up
Timer 8 8
Block PORTE
OSC2(2) Oscillator ALU<8>
LFINTOSC Start-up Timer RE<2:0>
SOSCI Oscillator Power-on 8 RE3(1)
Reset
64 MHz
SOSCO Oscillator Watchdog
Timer
Precision FVR
Single-Supply Brown-out Band Gap
MCLR(1) Reset
Programming Reference
In-Circuit Fail-Safe
Debugger Clock Monitor

BOR Data Timer1 Timer2


Timer0 Timer3 Timer4 ZCD CRC-Scan DAC
HLVD EEPROM
Timer5 Timer6

FVR
Comparators CCP1 PWM3 MSSP1 EUSART1 ADC FVR
ECWG DSM PMD
DAC C1/C2 CCP2 PWM4 MSSP2 EUSART2 10-bit

Note 1: RE3 is only available when MCLR functionality is disabled.


2: OSC1/CLKIN and OSC2/CLKOUT are only available in select oscillator modes and when these pins are not being used as digital I/O.
Refer to Section 4.0 Oscillator Module (with Fail-Safe Clock Monitor) for additional information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 16


PIC18(L)F26/45/46K40
1.4 Register and Bit naming 1.4.2.3 Bit Fields
conventions Bit fields are two or more adjacent bits in the same
register. Bit fields adhere only to the short bit naming
1.4.1 REGISTER NAMES convention. For example, the three Least Significant
When there are multiple instances of the same bits of the COG1CON0 register contain the mode
peripheral in a device, the peripheral control registers control bits. The short name for this field is MD. There
will be depicted as the concatenation of a peripheral is no long bit name variant. Bit field access is only
identifier, peripheral instance, and control identifier. possible in C programs. The following example
The control registers section will show just one demonstrates a C program instruction for setting the
instance of all the register names with an x in the place COG1 to the Push-Pull mode:
of the peripheral instance number. This naming COG1CON0bits.MD = 0x5;
convention may also be applied to peripherals when
Individual bits in a bit field can also be accessed with
there is only one instance of that peripheral in the
long and short bit names. Each bit is the field name
device to maintain compatibility with other devices in
appended with the number of the bit position within the
the family that contain more than one.
field. For example, the Most Significant mode bit has
1.4.2 BIT NAMES the short bit name MD2 and the long bit name is
G1MD2. The following two examples demonstrate
There are two variants for bit names: assembly program sequences for setting the COG1 to
Short name: Bit function abbreviation Push-Pull mode:
Long name: Peripheral abbreviation + short name Example 1:
MOVLW ~(1<<G1MD1)
1.4.2.1 Short Bit Names ANDWF COG1CON0,F
Short bit names are an abbreviation for the bit function. MOVLW 1<<G1MD2 | 1<<G1MD0
For example, some peripherals are enabled with the IORWF COG1CON0,F
EN bit. The bit names shown in the registers are the Example 2:
short name variant.
BSF COG1CON0,G1MD2
Short bit names are useful when accessing bits in C BCF COG1CON0,G1MD1
programs. The general format for accessing bits by the BSF COG1CON0,G1MD0
short name is RegisterNamebits.ShortName. For
example, the enable bit, EN, in the COG1CON0 regis- 1.4.3 REGISTER AND BIT NAMING
ter can be set in C programs with the instruction EXCEPTIONS
COG1CON0bits.EN = 1.
1.4.3.1 Status, Interrupt, and Mirror Bits
Short names are generally not useful in assembly
programs because the same name may be used by Status, interrupt enables, interrupt flags, and mirror bits
different peripherals in different bit positions. When this are contained in registers that span more than one
occurs, during the include file generation, all instances peripheral. In these cases, the bit name shown is
of that short bit name are appended with an underscore unique so there is no prefix or short name variant.
plus the name of the register in which the bit resides to
avoid naming contentions. 1.4.3.2 Legacy Peripherals
There are some peripherals that do not strictly adhere
1.4.2.2 Long Bit Names to these naming conventions. Peripherals that have
Long bit names are constructed by adding a peripheral existed for many years and are present in almost every
abbreviation prefix to the short name. The prefix is device are the exceptions. These exceptions were
unique to the peripheral thereby making every long bit necessary to limit the adverse impact of the new
name unique. The long bit name for the COG1 enable conventions on legacy code. Peripherals that do
bit is the COG1 prefix, G1, appended with the enable adhere to the new convention will include a table in the
bit short name, EN, resulting in the unique bit name registers section indicating the long name prefix for
G1EN. each peripheral instance. Peripherals that fall into the
exception category will not have this table. These
Long bit names are useful in both C and assembly pro-
peripherals include, but are not limited to, the following:
grams. For example, in C the COG1CON0 enable bit
can be set with the G1EN = 1 instruction. In assembly, EUSART
this bit can be set with the BSF COG1CON0,G1EN MSSP
instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 17


PIC18(L)F26/45/46K40
2.0 GUIDELINES FOR GETTING 2.2 Power Supply Pins
STARTED WITH
2.2.1 DECOUPLING CAPACITORS
PIC18(L)F26/45/46K40
The use of decoupling capacitors on every pair of
MICROCONTROLLERS power supply pins (VDD and VSS) is required.
Consider the following criteria when using decoupling
2.1 Basic Connection Requirements
capacitors:
Getting started with the PIC18(L)F26/45/46K40 family Value and type of capacitor: A 0.1 F (100 nF),
of 8-bit microcontrollers requires attention to a minimal 10-20V capacitor is recommended. The capacitor
set of device pin connections before proceeding with should be a low-ESR device, with a resonance
development. frequency in the range of 200 MHz and higher.
The following pins must always be connected: Ceramic capacitors are recommended.
All VDD and VSS pins (see Section 2.2 Power Placement on the printed circuit board: The
Supply Pins) decoupling capacitors should be placed as close
to the pins as possible. It is recommended to
MCLR pin (see Section 2.3 Master Clear (MCLR)
place the capacitors on the same side of the
Pin)
board as the device. If space is constricted, the
These pins must also be connected if they are being capacitor can be placed on another layer on the
used in the end application: PCB using a via; however, ensure that the trace
PGC/PGD pins used for In-Circuit Serial length from the pin to the capacitor is no greater
Programming (ICSP) and debugging purposes than 0.25 inch (6 mm).
(see Section 2.4 ICSP Pins) Handling high-frequency noise: If the board is
OSCI and OSCO pins when an external oscillator experiencing high-frequency noise (upward of
source is used (see Section 2.5 External tens of MHz), add a second ceramic type capaci-
Oscillator Pins) tor in parallel to the above described decoupling
capacitor. The value of the second capacitor can
Additionally, the following pins may be required:
be in the range of 0.01 F to 0.001 F. Place this
VREF+/VREF- pins are used when external voltage second capacitor next to each primary decoupling
reference for analog modules is implemented capacitor. In high-speed circuit designs, consider
The minimum mandatory connections are shown in implementing a decade pair of capacitances as
Figure 2-1. close to the power and ground pins as possible
(e.g., 0.1 F in parallel with 0.001 F).
FIGURE 2-1: RECOMMENDED Maximizing performance: On the board layout
MINIMUM CONNECTIONS from the power supply circuit, run the power and
return traces to the decoupling capacitors first,
Rev. 10-000249A
9/1/2015 and then to the device pins. This ensures that the
VDD C2 decoupling capacitors are first in the power chain.
Equally important is to keep the trace length
R1 between the capacitor and the power pins to a
VDD

Vss

R2
MCLR minimum, thereby reducing PCB trace
C1 inductance.

PIC18(L)Fxxxxx 2.2.2 TANK CAPACITORS


Vss On boards with power traces running longer than
six inches in length, it is suggested to use a tank capac-
itor for integrated circuits, including microcontrollers, to
Key (all values are recommendations):
supply a local power source. The value of the tank
C1 and C2 : 0.1 PF, 20V ceramic capacitor should be determined based on the trace
R1: 10 k resistance that connects the power supply source to
R2: 100 to 470 the device, and the maximum current drawn by the
device in the application. In other words, select the tank
capacitor so that it meets the acceptable voltage sag at
the device. Typical values range from 4.7 F to 47 F.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 18


PIC18(L)F26/45/46K40
2.3 Master Clear (MCLR) Pin 2.4 ICSP Pins
The MCLR pin provides two specific device The PGC and PGD pins are used for In-Circuit Serial
functions: Device Reset, and Device Programming Programming (ICSP) and debugging purposes. It
and Debugging. If programming and debugging are is recommended to keep the trace length between the
not required in the end application, a direct ICSP connector and the ICSP pins on the device as
connection to VDD may be all that is required. The short as possible. If the ICSP connector is expected to
addition of other components, to help increase the experience an ESD event, a series resistor is recom-
applications resistance to spurious Resets from mended, with the value in the range of a few tens of
voltage sags, may be beneficial. A typical ohms, not to exceed 100.
configuration is shown in Figure 2-1. Other circuit Pull-up resistors, series diodes and capacitors on the
designs may be implemented, depending on the PGC and PGD pins are not recommended as they will
applications requirements. interfere with the programmer/debugger communica-
During programming and debugging, the resistance tions to the device. If such discrete components are an
and capacitance that can be added to the pin must application requirement, they should be removed from
be considered. Device programmers and debuggers the circuit during programming and debugging. Alter-
drive the MCLR pin. Consequently, specific voltage natively, refer to the AC/DC characteristics and timing
levels (VIH and VIL) and fast signal transitions must requirements information in the respective device
not be adversely affected. Therefore, specific values Flash programming specification for information on
of R1 and C1 will need to be adjusted based on the capacitive loading limits, and pin input voltage high
application and PCB requirements. For example, it is (VIH) and input low (VIL) requirements.
recommended that the capacitor, C1, be isolated For device emulation, ensure that the Communication
from the MCLR pin during programming and Channel Select (i.e., PGCx/PGDx pins), programmed
debugging operations by using a jumper (Figure 2-2). into the device, matches the physical connections for
The jumper is replaced for normal run-time the ICSP to the Microchip debugger/emulator tool.
operations.
For more information on available Microchip
Any components associated with the MCLR pin development tools connection requirements, refer to
should be placed within 0.25 inch (6 mm) of the pin. Section 36.0 Development Support.

FIGURE 2-2: EXAMPLE OF MCLR PIN


CONNECTIONS
VDD

R1
R2
MCLR
PIC18(L)F2x/4xK40
JP
C1

Note 1: R1 10 k is recommended. A suggested


starting value is 10 k. Ensure that the
MCLR pin VIH and VIL specifications are met.
2: R2 470 will limit any current flowing into
MCLR from the external capacitor, C1, in the
event of MCLR pin breakdown, due to
Electrostatic Discharge (ESD) or Electrical
Overstress (EOS). Ensure that the MCLR pin
VIH and VIL specifications are met.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 19


PIC18(L)F26/45/46K40
2.5 External Oscillator Pins 2.6 Unused I/Os
Many microcontrollers have options for at least two Unused I/O pins should be configured as outputs and
oscillators: a high-frequency primary oscillator and a driven to a logic low state. Alternatively, connect a 1 k
low-frequency secondary oscillator (refer to Section to 10 k resistor to VSS on unused pins and drive the
4.0 Oscillator Module (with Fail-Safe Clock output to logic low.
Monitor) for details).
The oscillator circuit should be placed on the same FIGURE 2-3: SUGGESTED
side of the board as the device. Place the oscillator PLACEMENT OF THE
circuit close to the respective oscillator pins with no OSCILLATOR CIRCUIT
more than 0.5 inch (12 mm) between the circuit
Single-Sided and In-Line Layouts:
components and the pins. The load capacitors should
be placed next to the oscillator itself, on the same side Copper Pour Primary Oscillator
of the board. (tied to ground) Crystal

Use a grounded copper pour around the oscillator cir- DEVICE PINS
cuit to isolate it from surrounding circuits. The
grounded copper pour should be routed directly to the
MCU ground. Do not run any signal traces or power
Primary OSC1
traces inside the ground pour. Also, if using a two-sided Oscillator
board, avoid any traces on the other side of the board C1 ` OSC2
where the crystal is placed.
C2 GND
Layout suggestions are shown in Figure 2-3. In-line `
packages may be handled with a single-sided layout
SOSCO
that completely encompasses the oscillator pins. With
fine-pitch packages, it is not always possible to com- SOSCI
Secondary Oscillator
pletely surround the pins and components. A suitable (SOSC)
solution is to tie the broken guard sections to a mirrored Crystal `
ground layer. In all cases, the guard trace(s) must be
returned to ground.
SOSC: C1 SOSC: C2
In planning the applications routing and I/O assign-
ments, ensure that adjacent port pins, and other
signals in close proximity to the oscillator, are benign
(i.e., free of high frequencies, short rise and fall times, Fine-Pitch (Dual-Sided) Layouts:
and other similar noise). Top Layer Copper Pour
(tied to ground)
For additional information and design guidance on
oscillator circuits, please refer to these Microchip
Application Notes, available at the corporate website Bottom Layer
Copper Pour
(www.microchip.com): (tied to ground)
AN826, Crystal Oscillator Basics and Crystal
Selection for rfPIC and PICmicro Devices OSCO

AN849, Basic PICmicro Oscillator Design


C2
AN943, Practical PICmicro Oscillator Analysis
Oscillator
and Design GND Crystal
AN949, Making Your Oscillator Work
C1

OSCI

DEVICE PINS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 20


PIC18(L)F26/45/46K40
3.0 DEVICE CONFIGURATION
Device configuration consists of Configuration Words,
Code Protection, Device ID and Rev ID.

3.1 Configuration Words


There are six Configuration Word bits that allow the
user to setup the device with several choices of
oscillators, Resets and memory protection options.
These are implemented as Configuration Word 1
through Configuration Word 6 at 300000h through
30000Bh.
Note: The DEBUG bit in Configuration Words is
managed automatically by device
development tools including debuggers
and programmers. For normal device
operation, this bit should be maintained as
a 1.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 21


PIC18(L)F26/45/46K40
3.2 Register Definitions: Configuration Words

REGISTER 3-1: Configuration Word 1L (30 0000h): Oscillators


U-1 R/W-1 R/W-1 R/W-1 U-1 R/W-1 R/W-1 R/W-1
RSTOSC<2:0> FEXTOSC<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 Unimplemented: Read as 1


bit 6-4 RSTOSC<2:0>: Power-up Default Value for COSC bits
This value is the Reset default value for COSC and selects the oscillator first used by user software.
Refer to COSC operation.
111 = EXTOSC operating per FEXTOSC bits (device manufacturing default)
110 = HFINTOSC with HFFRQ = 4 MHz (Register 4-5) and CDIV = 4:1 (Register 4-2)
101 = LFINTOSC
100 = SOSC
011 = Reserved
010 = EXTOSC with 4x PLL, with EXTOSC operating per FEXTOSC bits
001 = Reserved
000 = HFINTOSC with HFFRQ = 64 MHz (Register 4-5) and CDIV = 1:1 (Register 4-2). Resets
COSC/NOSC to 3b110.
bit 3 Unimplemented: Read as 1
bit 2-0 FEXTOSC<2:0>: FEXTOSC External Oscillator Mode Selection bits
111 = EC (external clock) above 8 MHz; PFM set to high power (device manufacturing default)
110 = EC (external clock) for 500 kHz to 8 MHz; PFM set to medium power
101 = EC (external clock) below 500 kHz; PFM set to low power
100 = Oscillator not enabled
011 = Reserved (do not use)
010 = HS (crystal oscillator) above 8 MHz; PFM set to high power
001 = XT (crystal oscillator) above 500 kHz, below 8 MHz; PFM set to medium power
000 = LP (crystal oscillator) optimized for 32.768 kHz; PFM set to low power

2016 Microchip Technology Inc. Preliminary DS40001816C-page 22


PIC18(L)F26/45/46K40

REGISTER 3-2: Configuration Word 1H (30 0001h): Oscillators


U-1 U-1 R/W-1 U-1 R/W-1 U-1 U-1 R/W-1
FCMEN CSWEN CLKOUTEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 1


bit 5 FCMEN: Fail-Safe Clock Monitor Enable bit
1 = FSCM timer enabled
0 = FSCM timer disabled
bit 4 Unimplemented: Read as 1
bit 3 CSWEN: Clock Switch Enable bit
1 = Writing to NOSC and NDIV is allowed
0 = The NOSC and NDIV bits cannot be changed by user software
bit 2-1 Unimplemented: Read as 1
bit 0 CLKOUTEN: Clock Out Enable bit
If FEXTOSC = HS, XT, LP, then this bit is ignored
Otherwise:
1 = CLKOUT function is disabled; I/O or oscillator function on OSC2
0 = CLKOUT function is enabled; FOSC/4 clock appears at OSC2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 23


PIC18(L)F26/45/46K40

REGISTER 3-3: Configuration Word 2L (30 0002h): Supervisor


R/W-1 R/W-1 R/W-1 U-1 U-1 U-1 R/W-1 R/W-1
BOREN<1:0> LPBOREN PWRTE MCLRE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 BOREN<1:0>: Brown-out Reset Enable bits


When enabled, Brown-out Reset Voltage (VBOR) is set by BORV bit
11 = Brown-out Reset enabled, SBOREN bit is ignored
10 = Brown-out Reset enabled while running, disabled in Sleep; SBOREN is ignored
01 = Brown-out Reset enabled according to SBOREN
00 = Brown-out Reset disabled
bit 5 LPBOREN: Low-Power BOR Enable bit
1 = Low-Power Brown-out Reset is disabled
0 = Low-Power Brown-out Reset is enabled
bit 4-2 Unimplemented: Read as 1
bit 1 PWRTE: Power-up Timer Enable bit
1 = PWRT disabled
0 = PWRT enabled
bit 0 MCLRE: Master Clear (MCLR) Enable bit
If LVP = 1
RE3 pin function is MCLR
If LVP = 0
1 = MCLR pin is MCLR
0 = MCLR pin function is port defined function

2016 Microchip Technology Inc. Preliminary DS40001816C-page 24


PIC18(L)F26/45/46K40

REGISTER 3-4: Configuration Word 2H (30 0003h): Supervisor


R/W-1 U-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
XINST DEBUG STVREN PPS1WAY ZCD BORV<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 XINST: Extended Instruction Set Enable bit


1 = Extended Instruction Set and Indexed Addressing mode disabled (Legacy mode)
0 = Extended Instruction Set and Indexed Addressing mode enabled
bit 6 Unimplemented: Read as 1
bit 5 DEBUG: Debugger Enable bit
1 = Background debugger disabled
0 = Background debugger enabled
bit 4 STVREN: Stack Overflow/Underflow Reset Enable bit
1 = Stack Overflow or Underflow will cause a Reset
0 = Stack Overflow or Underflow will not cause a Reset
bit 3 PPS1WAY: PPSLOCKED bit One-Way Set Enable bit
1 = The PPSLOCKED bit can only be set once after an unlocking sequence is executed; once
PPSLOCK is set, all future changes to PPS registers are prevented
0 = The PPSLOCKED bit can be set and cleared as needed (provided an unlocking sequence is
executed)
bit 2 ZCD: ZCD Disable bit
1 = ZCD disabled. ZCD can be enabled by setting the ZCDSEN bit of ZCDCON
0 = ZCD always enabled, ZCDMD bit is ignored
bit 1-0 BORV<1:0>: Brown-out Reset Voltage Selection bit(1)
PIC18F2x/4xK40 device:
11 = Brown-out Reset Voltage (VBOR) set to 2.45V
10 = Brown-out Reset Voltage (VBOR) set to 2.45V
01 = Brown-out Reset Voltage (VBOR) set to 2.7V
00 = Brown-out Reset Voltage (VBOR) set to 2.85V

PIC18LF2x/4xK40 device:
11 = Brown-out Reset Voltage (VBOR) set to 1.90V
10 = Brown-out Reset Voltage (VBOR) set to 2.45V
01 = Brown-out Reset Voltage (VBOR) set to 2.7V
00 = Brown-out Reset Voltage (VBOR) set to 2.85V

Note 1: The higher voltage setting is recommended for operation at or above 16 MHz.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 25


PIC18(L)F26/45/46K40

REGISTER 3-5: CONFIGURATION WORD 3L (30 0004h): WINDOWED WATCHDOG TIMER


U-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
WDTE<1:0> WDTCPS<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 Unimplemented: Read as 1


bit 6-5 WDTE<1:0>: WDT Operating Mode bits
11 = WDT enabled regardless of Sleep; SEN bit in WDTCON0 is ignored
10 = WDT enabled while Sleep = 0, suspended when Sleep = 1; SEN bit in WDTCON0 is ignored
01 = WDT enabled/disabled by SEN bit in WDTCON0
00 = WDT disabled, SEN bit in WDTCON0 is ignored
bit 4-0 WDTCPS<4:0>: WDT Period Select bits

WDTPS at POR
Software Control
WDTCPS Typical Time Out
Value Divider Ratio of WDTPS?
(FIN = 31 kHz)
11111 01011 1:65536 216 2s Yes
10011 10011
... ... 1:32 25 1 ms No
11110 11110
10010 10010 1:8388608 223 256s
10001 10001 1:4194304 222 128s
21
10000 10000 1:2097152 2 64s
01111 01111 1:1048576 220 32s
01110 01110 1:524299 219 16s
01101 01101 1:262144 218 8s
01100 01100 1:131072 217 4s
01011 01011 1:65536 216 2s
15
01010 01010 1:32768 2 1s
01001 01001 1:16384 214 512 ms No
01000 01000 1:8192 213 256 ms
00111 00111 1:4096 212 128 ms
11
00110 00110 1:2048 2 64 ms
00101 00101 1:1024 210 32 ms
9
00100 00100 1:512 2 16 ms
00011 00011 1:256 28 8 ms
00010 00010 1:128 27 4 ms
00001 00001 1:64 26 2 ms
5
00000 00000 1:32 2 1 ms

2016 Microchip Technology Inc. Preliminary DS40001816C-page 26


PIC18(L)F26/45/46K40

REGISTER 3-6: CONFIGURATION WORD 3H (30 0005h): WINDOWED WATCHDOG TIMER


U-1 U-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
WDTCCS<2:0> WDTCWS<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 1


bit 5-3 WDTCCS<2:0>: WDT Input Clock Selector bits
If WDTE<1:0> fuses = 2b00
This bit is ignored.
Otherwise:
111 = Software Control
110 = Reserved (Default to LFINTOSC)
.
.
.
010 = Reserved (Default to LFINTOSC)
001 = WDT reference clock is the 31.25 kHz HFINTOSC (MFINTOSC)
000 = WDT reference clock is the 31.0 kHz LFINTOSC (default value)
bit 2-0 WDTCWS<2:0>: WDT Window Select bits

WINDOW at POR Software Keyed


WDTCWS Window delay Window opening control of access
Value WINDOW required?
Percent of time Percent of time
111 111 n/a 100 Yes No
110 111 n/a 100
101 101 25 75
100 100 37.5 62.5
011 011 50 50 No Yes
010 010 62.5 37.5
001 001 75 25
000 000 87.5 12.5

2016 Microchip Technology Inc. Preliminary DS40001816C-page 27


PIC18(L)F26/45/46K40

Register 3-7: Configuration Word 4L (30 0006h): Memory Write Protection


R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
WRT7 WRT6 WRT5 WRT4 WRT3 WRT2 WRT1 WRT0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-0 WRT<7:0>: User NVM Self-Write Protection bits(1)


1 = Corresponding Memory Block NOT write-protected
0 = Corresponding Memory Block write-protected

Note 1: Refer to Table 10-2 for details on implementation of the individual WRT bits.

Register 3-8: Configuration Word 4H (30 0007h): Memory Write Protection


U-1 U-1 R/W-1 R/W-1 U-1 R/W-1 R/W-1 R/W-1
LVP SCANE WRTD WRTB WRTC
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 1


bit 5 LVP: Low-Voltage Programming Enable bit
1 = Low-voltage programming enabled. MCLR/VPP pin function is MCLR. MCLRE Configuration bit
is ignored.
The LVP bit cannot be written (to zero) while operating from the LVP programming interface. The
purpose of this rule is to prevent the user from dropping out of LVP mode while programming
from LVP mode, or accidentally eliminating LVP mode from the Configuration state.
0 = HV on MCLR/VPP must be used for programming
bit 4 SCANE: Scanner Enable bit
1 = Scanner module is available for use, SCANMD bit enables the module
0 = Scanner module is NOT available for use, SCANMD bit is ignored
bit 3 Unimplemented: Read as 1
bit 2 WRTD: Data EEPROM Write Protection bit
1 = Data EEPROM NOT write-protected
0 = Data EEPROM write-protected
bit 1 WRTB: Boot Block Write Protection bit
1 = Boot Block NOT write-protected
0 = Boot Block write-protected
bit 0 WRTC: Configuration Register Write Protection bit
1 = Configuration Register NOT write-protected
0 = Configuration Register write-protected

2016 Microchip Technology Inc. Preliminary DS40001816C-page 28


PIC18(L)F26/45/46K40

REGISTER 3-9: Configuration Word 5L (30 0008h): Code Protection


U-1 U-1 U-1 U-1 U-1 U-1 R/W-1 R/W-1
CPD CP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 1


bit 1 CPD: Data NVM Memory Code Protection bit
1 = Data NVM code protection disabled
0 = Data NVM code protection enabled
bit 0 CP: User NVM Program Memory Code Protection bit
1 = User NVM code protection disabled
0 = User NVM code protection enabled

REGISTER 3-10: Configuration Word 6L (30 000Ah): Memory Read Protection


R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
EBTR7 EBTR6 EBTR5 EBTR4 EBTR3 EBTR2 EBTR1 EBTR0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-0 EBTR<7:0>: Table Read Protection bits(1)


1 = Corresponding Memory Block NOT protected from table reads executed in other blocks
0 = Corresponding Memory Block protected from table reads executed in other blocks

Note 1: Refer to Table 10-2 for details on implementation of the individual EBTR bits.

REGISTER 3-11: Configuration Word 6H (30 000Bh): Memory Read Protection


U-1 U-1 U-1 U-1 U-1 U-1 R/W-1 U-1
EBTRB
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 1
-n = Value for blank device 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 1


bit 1 EBTRB: Table Read Protection bit
1 = Memory Boot Block NOT protected from table reads executed in other blocks
0 = Memory Boot Block protected from table reads executed in other blocks
bit 0 Unimplemented: Read as 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 29


TABLE 3-1: SUMMARY OF CONFIGURATION WORDS
2016 Microchip Technology Inc.

Default/
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Unprogrammed
Value
30 0000h CONFIG1L RSTOSC2 RSTOSC1 RSTOSC0 FEXTOSC2 FEXTOSC1 FEXTOSC0 1111 1111
30 0001h CONFIG1H FCMEN CSWEN CLKOUTEN 1111 1111
30 0002h CONFIG2L BOREN1 BOREN0 LPBOREN PWRTE MCLRE 1111 1111
30 0003h CONFIG2H XINST DEBUG STVREN PPS1WAY ZCD BORV1 BORV0 1111 1111
30 0004h CONFIG3L WDTE<1:0> WDTCPS<4:0> 1111 1111
30 0005h CONFIG3H WDTCCS<2:0> WDTCWS<2:0> 1111 1111
30 0006h CONFIG4L WRT7 WRT6 WRT5 WRT4 WRT3 WRT2 WRT1 WRT0 1111 1111
30 0007h CONFIG4H LVP SCANE WRTD WRTB WRTC 1111 1111
30 0008h CONFIG5L CPD CP 1111 1111
30 000Ah CONFIG6L EBTR7 EBTR6 EBTR5 EBTR4 EBTR3 EBTR2 EBTR1 EBTR0 1111 1111
30 000Bh CONFIG6H EBTRB 1111 1111
Preliminary

PIC18(L)F26/45/46K40
DS40001816C-page 30
PIC18(L)F26/45/46K40
3.3 Code Protection
Code protection allows the device to be protected from
unauthorized access. Program memory protection and
data memory are controlled independently. Internal
access to the program memory is unaffected by any
code protection setting.

3.3.1 PROGRAM MEMORY PROTECTION


The entire program memory space is protected from
external reads and writes by the CP bit in Configuration
Words. When CP = 0, external reads and writes of
program memory are inhibited and a read will return all
0s. The CPU can continue to read program memory,
regardless of the protection bit settings. Self-writing the
program memory is dependent upon the write
protection setting. See Section 3.4 Write
Protection for more information.

3.3.2 DATA MEMORY PROTECTION


The entire Data EEPROM Memory space is protected
from external reads and writes by the CPD bit in the
Configuration Words. When CPD = 0, external reads
and writes of Data EEPROM Memory are inhibited and
a read will return all 0s. The CPU can continue to read
Data EEPROM Memory regardless of the protection bit
settings.

3.4 Write Protection


Write protection allows the device to be protected from
unintended self-writes. Applications, such as boot
loader software, can be protected while allowing other
regions of the program memory to be modified.
The WRT<1:0> bits in Configuration Words define the
size of the program memory block that is protected.

3.5 User ID
Eight words in the memory space (200000h-200000Fh)
are designated as ID locations where the user can
store checksum or other code identification numbers.
These locations are readable and writable during
normal execution. See Section 11.2 User ID, Device
ID and Configuration Word Access for more
information on accessing these memory locations. For
more information on checksum calculation, see the
PIC18(L)F2X/4XK40 Memory Programming
Specification (DS40001772).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 31


PIC18(L)F26/45/46K40
3.6 Device ID and Revision ID
The 16-bit device ID word is located at 3F FFFEh and
the 16-bit revision ID is located at 3F FFFCh. These
locations are read-only and cannot be erased or
modified.
Development tools, such as device programmers and
debuggers, may be used to read the Device ID,
Revision ID and Configuration Words. Refer to 11.0
Nonvolatile Memory (NVM) Control for more
information on accessing these locations.

3.7 Register Definitions: Device and Revision

REGISTER 3-12: DEVICE ID: DEVICE ID REGISTER


R R R R R R R R
DEV15 DEV14 DEV13 DEV12 DEV11 DEV10 DEV9 DEV8
bit 15 bit 8

R R R R R R R R
DEV7 DEV6 DEV5 DEV4 DEV3 DEV2 DEV1 DEV0
bit 7 bit 0

Legend:
R = Readable bit 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 15-0 DEV<15:0>: Device ID bits

Device Device ID
PIC18F26K40 6980h
PIC18F45K40 6940h
PIC18F46K40 6920h
PIC18LF26K40 6A60h
PIC18LF45K40 6A20h
PIC18LF46K40 6A00h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 32


PIC18(L)F26/45/46K40

REGISTER 3-13: REVISION ID: REVISION ID REGISTER


R R R R R R R R
1 0 1 0 MJRREV<5:2>
bit 15 bit 8

R R R R R R R R
MJRREV<1:0> MNRREV<5:0>
bit 7 bit 0

Legend:
R = Readable bit 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 15-12 Read as 1010


These bits are fixed with value 1010 for all devices in this family.
bit 11-6 MJRREV<5:0>: Major Revision ID bits
These bits are used to identify a major revision. A major revision is indicated by an all-layer revision
(A0, B0, C0, etc.).
Revision A = 6b00_0000
bit 5-0 MNRREV<5:0>: Minor Revision ID bits
These bits are used to identify a minor revision.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 33


PIC18(L)F26/45/46K40
4.0 OSCILLATOR MODULE (WITH The external oscillator module can be configured in one
of the following clock modes, by setting the
FAIL-SAFE CLOCK MONITOR)
FEXTOSC<2:0> bits of Configuration Word 1:

4.1 Overview 1. ECL External Clock Low-Power mode


(below 100 kHz)
The oscillator module has multiple clock sources and 2. ECM External Clock Medium Power mode
selection features that allow it to be used in a wide (100 kHz to 8 MHz)
range of applications while maximizing performance 3. ECH External Clock High-Power mode
and minimizing power consumption. Figure 4-1 (above 8 MHz)
illustrates a block diagram of the oscillator module.
4. LP 32 kHz Low-Power Crystal mode.
Clock sources can be supplied from external oscillators, 5. XT Medium Gain Crystal or Ceramic Resonator
quartz-crystal resonators and ceramic resonators. In Oscillator mode (between 100 kHz and 8 MHz)
addition, the system clock source can be supplied from
6. HS High Gain Crystal or Ceramic Resonator
one of two internal oscillators and PLL circuits, with a
mode (above 4 MHz)
choice of speeds selectable via software. Additional
clock features include: The ECH, ECM, and ECL Clock modes rely on an
external logic level signal as the device clock source.
Selectable system clock source between external
The LP, XT, and HS Clock modes require an external
or internal sources via software.
crystal or resonator to be connected to the device.
Fail-Safe Clock Monitor (FSCM) designed to Each mode is optimized for a different frequency range.
detect a failure of the external clock source (LP, The internal oscillator block produces low and
XT, HS, ECH, ECM, ECL) and switch high-frequency clock sources, designated LFINTOSC
automatically to the internal oscillator. and HFINTOSC. (see Internal Oscillator Block,
Oscillator Start-up Timer (OST) ensures stability Figure 4-1). Multiple device clock frequencies may be
of crystal oscillator sources. derived from these clock sources.
The RSTOSC bits of Configuration Word 1
(Register 3-1) determine the type of oscillator that will
be used when the device runs after Reset, including
when it is first powered up.
If an external clock source is selected, the FEXTOSC
bits of Configuration Word 1 must be used in
conjunction with the RSTOSC bits to select the
External Clock mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 34


FIGURE 4-1: SIMPLIFIED PIC MCU CLOCK SOURCE BLOCK DIAGRAM
2016 Microchip Technology Inc.

Rev. 10-000208D
5/10/2016

CLKIN/OSC1

External
Oscillator
(EXTOSC)

CLKOUT/OSC2
CDIV<4:0>
4x PLL
COSC<2:0>
SOSCIN/SOSCI

Secondary 512
Oscillator 1001
256
(SOSC) 111 1000
128 Sleep
SOSCO 010 0111 System Clock
64
100 0110

Post Divider
LFINTOSC
Preliminary

32
101 0101
31 kHz 16
110 0100 SYSCMD Peripheral Clock
Oscillator
8
Reserved 011 0011

PIC18(L)F26/45/46K40
4
Reserved 001 0010 Sleep
2
HFINTOSC Reserved 000 0001 Idle
1
0000
FRQ<3:0>
1,2,4,8,12,16,32,48,64
MHz
Oscillator
LFINTOSC is used to
FSCM
monitor system clock

MFINTOSC
To Peripherals
31.25 kHz and 500 kHz To Peripherals
DS40001816C-page 35

Oscillator To Peripherals
To Peripherals
PIC18(L)F26/45/46K40
4.2 Register Definitions: Oscillator Control
REGISTER 4-1: OSCCON1: OSCILLATOR CONTROL REGISTER1
U-0 R/W-f/f R/W-f/f R/W-f/f R/W-q/q R/W-q/q R/W-q/q R/W-q/q
NOSC<2:0> NDIV<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared f = determined by fuse setting
q = Reset value is determined by hardware

bit 7 Unimplemented: Read as 0


bit 6-4 NOSC<2:0>: New Oscillator Source Request bits(1,2,3)
The setting requests a source oscillator and PLL combination per Table 4-2.
POR value = RSTOSC (Register 3-1).
bit 3-0 NDIV<3:0>: New Divider Selection Request bits(2,3)
The setting determines the new postscaler division ratio per Table 4-2.

Note 1: The default value (f/f) is determined by the RSTOSC Configuration bits. See Table 4-1below.
2: If NOSC is written with a reserved value (Table 4-2), the operation is ignored and neither NOSC nor NDIV is
written.
3: When CSWEN = 0, this register is read-only and cannot be changed from the POR value.

TABLE 4-1: DEFAULT OSCILLATOR SETTINGS


SFR Reset Values
RSTOSC Initial FOSC Frequency
NOSC/COSC CDIV OSCFRQ
111 111 1:1 EXTOSC per FEXTOSC
110 110 4:1 FOSC = 1 MHz (4 MHz/4)
4 MHz
101 101 1:1 LFINTOSC
100 100 1:1 SOSC
011 Reserved
010 010 1:1 4 MHz EXTOSC + 4xPLL (1)
001 Reserved
000 110 1:1 64 MHz FOSC = 64 MHZ
Note 1: EXTOSC must meet the PLL specifications (Table 37-9).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 36


PIC18(L)F26/45/46K40

REGISTER 4-2: OSCCON2: OSCILLATOR CONTROL REGISTER 2


U-0 R-q/q R-q/q R-q/q R-q/q R-q/q R-q/q R-q/q
COSC<2:0> CDIV<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Reset value is determined by hardware

bit 7 Unimplemented: Read as 0


bit 6-4 COSC<2:0>: Current Oscillator Source Select bits (read-only)(1,2)
Indicates the current source oscillator and PLL combination per Table 4-2.
bit 3-0 CDIV<3:0>: Current Divider Select bits (read-only)(1,2)
Indicates the current postscaler division ratio per Table 4-2.

Note 1: The POR value is the value present when user code execution begins.
2: The Reset value (q/q) is the same as the NOSC/NDIV bits.

TABLE 4-2: NOSC/COSC AND NDIV/CDIV BIT SETTINGS


NOSC<2:0> NDIV<3:0>
Clock Source Clock Divider
COSC<2:0> CDIV<3:0>
111 EXTOSC(1) 1111-1010 Reserved
110 HFINTOSC(2) 1001 512
101 LFINTOSC 1000 256
100 SOSC 0111 128
011 Reserved 0110 64
(3)
010 EXTOSC + 4x PLL 0101 32
001 Reserved 0100 16
000 Reserved 0011 8
0010 4
0001 2
0000 1

Note 1: EXTOSC configured by the FEXTOSC bits of Configuration Word 1 (Register 3-1).
2: HFINTOSC frequency is set with the HFFRQ bits of the OSCFRQ register (Register 4-5).
3: EXTOSC must meet the PLL specifications (Table 37-9).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 37


PIC18(L)F26/45/46K40

REGISTER 4-3: OSCCON3: OSCILLATOR CONTROL REGISTER 3


R/W/HC-0/0 R/W-0/0 U-0 R-0/0 R-0/0 U-0 U-0 U-0
CSWHOLD SOSCPWR ORDY NOSCR
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 CSWHOLD: Clock Switch Hold bit


1 = Clock switch will hold (with interrupt) when the oscillator selected by NOSC is ready
0 = Clock switch may proceed when the oscillator selected by NOSC is ready; NOSCR
becomes 1, the switch will occur
bit 6 SOSCPWR: Secondary Oscillator Power Mode Select bit
1 = Secondary oscillator operating in High-Power mode
0 = Secondary oscillator operating in Low-Power mode
bit 5 Unimplemented: Read as 0
bit 4 ORDY: Oscillator Ready bit (read-only)
1 = OSCCON1 = OSCCON2; the current system clock is the clock specified by NOSC
0 = A clock switch is in progress
bit 3 NOSCR: New Oscillator is Ready bit (read-only)(1)
1 = A clock switch is in progress and the oscillator selected by NOSC indicates a ready condition
0 = A clock switch is not in progress, or the NOSC-selected oscillator is not yet ready
bit 2-0 Unimplemented: Read as 0

Note 1: If CSWHOLD = 0, the user may not see this bit set because, when the oscillator becomes ready there
may be a delay of one instruction clock before this bit is set. The clock switch occurs in the next instruction
cycle and this bit is cleared.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 38


PIC18(L)F26/45/46K40

REGISTER 4-4: OSCSTAT: OSCILLATOR STATUS REGISTER 1


R-q/q R-q/q R-q/q R-q/q R-q/q R-q/q U-0 R-q/q
EXTOR HFOR MFOR LFOR SOR ADOR PLLR
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Reset value is determined by hardware

bit 7 EXTOR: EXTOSC (external) Oscillator Ready bit


1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 6 HFOR: HFINTOSC Oscillator Ready bit
1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 5 MFOR: MFINTOSC Oscillator Ready
1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 4 LFOR: LFINTOSC Oscillator Ready bit
1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 3 SOR: Secondary (Timer1) Oscillator Ready bit
1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 2 ADOR: ADC Oscillator Ready bit
1 = The oscillator is ready to be used
0 = The oscillator is not enabled, or is not yet ready to be used
bit 1 Unimplemented: Read as 0
bit 0 PLLR: PLL is Ready bit
1 = The PLL is ready to be used
0 = The PLL is not enabled, the required input source is not ready, or the PLL is not locked.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 39


PIC18(L)F26/45/46K40
REGISTER 4-5: OSCFRQ: HFINTOSC FREQUENCY SELECTION REGISTER
U-0 U-0 U-0 U-0 R/W-q/q R/W-q/q R/W-q/q R/W-q/q
HFFRQ<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Reset value is determined by hardware

bit 7-4 Unimplemented: Read as 0


bit 3-0 HFFRQ<3:0>: HFINTOSC Frequency Selection bits

HFFRQ<3:0> Nominal Freq (MHz)


1001
1010
1111
1110 Reserved
1101
1100
1011
1000(3) 64
0111 48
0110 32
0101(4) 16
0100 12
0011 8
(1,2)
0010 4
0001 2
0000 1

Note 1: Refer to Table 4-1 for more information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 40


PIC18(L)F26/45/46K40
REGISTER 4-6: OSCTUNE: HFINTOSC TUNING REGISTER
U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
HFTUN<5:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5-0 HFTUN<5:0>: HFINTOSC Frequency Tuning bits
01 1111 = Maximum frequency



00 0000 = Center frequency. Oscillator module is running at the calibrated frequency
(default value).



10 0000 = Minimum frequency

2016 Microchip Technology Inc. Preliminary DS40001816C-page 41


PIC18(L)F26/45/46K40

REGISTER 4-7: OSCEN: OSCILLATOR MANUAL ENABLE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0
EXTOEN HFOEN MFOEN LFOEN SOSCEN ADOEN

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EXTOEN: External Oscillator Manual Request Enable bit


1 = EXTOSC is explicitly enabled, operating as specified by FEXTOSC
0 = EXTOSC could be enabled by requesting peripheral
bit 6 HFOEN: HFINTOSC Oscillator Manual Request Enable bit
1 = HFINTOSC is explicitly enabled, operating as specified by OSCFRQ (Register 4-5)
0 = HFINTOSC could be enabled by requesting peripheral
bit 5 MFOEN: MFINTOSC (500 kHz/31.25 kHz) Oscillator Manual Request Enable bit (Derived from
HFINTOSC)
1 = MFINTOSC is explicitly enabled
0 = MFINTOSC could be enabled by requesting peripheral
bit 4 LFOEN: LFINTOSC (31 kHz) Oscillator Manual Request Enable bit
1 = LFINTOSC is explicitly enabled
0 = LFINTOSC could be enabled by requesting peripheral
bit 3 SOSCEN: Secondary Oscillator Manual Request Enable bit
1 = Secondary Oscillator is explicitly enabled, operating as specified by SOSCPWR
0 = Secondary Oscillator could be enabled by requesting peripheral
bit 2 ADOEN: ADC Oscillator Manual Request Enable bit
1 = ADC oscillator is explicitly enabled
0 = ADC oscillator could be enabled by requesting peripheral
bit 1-0 Unimplemented: Read as 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 42


PIC18(L)F26/45/46K40
4.3 Clock Source Types EC mode has three power modes to select from through
Configuration Words:
Clock sources can be classified as external or internal.
ECH High power, above 8 MHz
External clock sources rely on external circuitry for the
ECM Medium power, 100 kHz-8 MHz
clock source to function. Examples are: oscillator
modules (ECH, ECM, ECL mode), quartz crystal ECL Low power, below 100 MHz
resonators or ceramic resonators (LP, XT and HS The Oscillator Start-up Timer (OST) is disabled when
modes). EC mode is selected. Therefore, there is no delay in
Internal clock sources are contained within the operation after a Power-on Reset (POR) or wake-up
oscillator module. The internal oscillator block has two from Sleep. Because the PIC MCU design is fully
internal oscillators that are used to generate internal static, stopping the external clock input will have the
system clock sources. The High-Frequency Internal effect of halting the device while leaving all data intact.
Oscillator (HFINTOSC) can produce 1, 2, 4, 8, 12, 16, Upon restarting the external clock, the device will
32, 48 and 64 MHz clock. The frequency can be resume operation as if no time had elapsed.
controlled through the OSCFRQ register
(Register 4-5). The Low-Frequency Internal Oscillator FIGURE 4-2: EXTERNAL CLOCK (EC)
(LFINTOSC) generates a fixed 31 kHz frequency. MODE OPERATION
A 4x PLL is provided that can be used in conjunction
with the external clock. When used with the HFINTOSC Clock from OSC1/CLKIN
the 4x PLL has input frequency limitations. See Ext. System
Section 4.3.1.4 4x PLL for more details. PIC MCU

The system clock can be selected between external or OSC2/CLKOUT


internal clock sources via the NOSC bits in the FOSC/4 or I/O(1)
OSCCON1 register. See Section 4.4 Clock
Switching for additional information. The system Note 1: Output depends upon CLKOUTEN bit of the
clock can be made available on the OSC2/CLKOUT pin Configuration Words (CONFIG1H).
for any of the modes that do not use the OSC2 pin. The
clock out functionality is governed by the CLKOUTEN
bit in the CONFIG1H register (Register 3-2). If enabled, 4.3.1.2 LP, XT, HS Modes
the clock out signal is always at a frequency of FOSC/4. The LP, XT and HS modes support the use of quartz
crystal resonators or ceramic resonators connected to
4.3.1 EXTERNAL CLOCK SOURCES OSC1 and OSC2 (Figure 4-3). The three modes select
An external clock source can be used as the device a low, medium or high gain setting of the internal
system clock by performing one of the following inverter-amplifier to support various resonator types
actions: and speed.
Program the RSTOSC<2:0> and FEXTOSC<2:0> LP Oscillator mode selects the lowest gain setting of the
bits in the Configuration Words to select an internal inverter-amplifier. LP mode current consumption
external clock source that will be used as the is the least of the three modes. This mode is designed to
default system clock upon a device Reset. drive only 32.768 kHz tuning-fork type crystals (watch
Write the NOSC<2:0> and NDIV<3:0> bits in the crystals).
OSCCON1 register to switch the system clock XT Oscillator mode selects the intermediate gain
source. setting of the internal inverter-amplifier. XT mode
See Section 4.4 Clock Switching for more current consumption is the medium of the three modes.
information. This mode is best suited to drive resonators with a
medium drive level specification (above
4.3.1.1 EC Mode 100 kHz - 8 MHz).

The External Clock (EC) mode allows an externally HS Oscillator mode selects the highest gain setting of the
generated logic level signal to be the system clock internal inverter-amplifier. HS mode current consumption
source. When operating in this mode, an external clock is the highest of the three modes. This mode is best
source is connected to the OSC1 input. suited for resonators that require a high drive setting
OSC2/CLKOUT is available for general purpose I/O or (above 8 MHz).
CLKOUT. Figure 4-2 shows the pin connections for EC Figure 4-3 and Figure 4-4 show typical circuits for
mode. quartz crystal and ceramic resonators, respectively.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 43


PIC18(L)F26/45/46K40
FIGURE 4-3: QUARTZ CRYSTAL 4.3.1.3 Oscillator Start-up Timer (OST)
OPERATION (LP, XT OR If the oscillator module is configured for LP, XT or HS
HS MODE) modes, the Oscillator Start-up Timer (OST) counts
1024 oscillations from OSC1. This occurs following a
PIC MCU Power-on Reset (POR), or a wake-up from Sleep. The
OST ensures that the oscillator circuit, using a quartz
OSC1/CLKIN crystal resonator or ceramic resonator, has started and
C1
is providing a stable system clock to the oscillator
To Internal
Logic module.
Quartz
RF(2) Sleep 4.3.1.4 4x PLL
Crystal
The oscillator module contains a 4x PLL that can be
used with the external clock sources to provide a
OSC2/CLKOUT
C2 RS(1) system clock source. The input frequency for the PLL
must fall within specifications. See the PLL Clock
Note 1: A series resistor (RS) may be required for Timing Specifications in Table 37-9.
quartz crystals with low drive level.
The PLL can be enabled for use by one of two
2: The value of RF varies with the Oscillator mode methods:
selected (typically between 2 M to 10 M.
1. Program the RSTOSC bits in the Configuration
Word 1 to 010 (enable EXTOSC with 4x PLL).
FIGURE 4-4: CERAMIC RESONATOR 2. Write the NOSC bits in the OSCCON1 register
OPERATION to 010 (enable EXTOSC with 4x PLL).
(XT OR HS MODE)

PIC MCU

OSC1/CLKIN

C1 To Internal
Logic

RP(3) RF(2) Sleep

C2 Ceramic RS(1) OSC2/CLKOUT


Resonator

Note 1: A series resistor (RS) may be required for


ceramic resonators with low drive level.
2: The value of RF varies with the Oscillator mode
selected (typically between 2 M to 10 M.
3: An additional parallel feedback resistor (RP)
may be required for proper ceramic resonator
operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 44


PIC18(L)F26/45/46K40
4.3.1.5 Secondary Oscillator 4.3.2 INTERNAL CLOCK SOURCES
The secondary oscillator is a separate oscillator block The device may be configured to use the internal
that can be used as an alternate system clock source. oscillator block as the system clock by performing one
The secondary oscillator is optimized for 32.768 kHz, of the following actions:
and can be used with an external crystal oscillator con- Program the RSTOSC<2:0> bits in Configuration
nected to the SOSCI and SOSCO device pins, or an Words to select the INTOSC clock source, which
external clock source connected to the SOSCIN pin. will be used as the default system clock upon a
The secondary oscillator can be selected during device Reset.
run-time using clock switching. Refer to Section
Write the NOSC<2:0> bits in the OSCCON1
4.4 Clock Switching for more information.
register to switch the system clock source to the
internal oscillator during run-time. See Section
FIGURE 4-5: QUARTZ CRYSTAL 4.4 Clock Switching for more information.
OPERATION
In INTOSC mode, OSC1/CLKIN is available for general
(SECONDARY
purpose I/O. OSC2/CLKOUT is available for general
OSCILLATOR)
purpose I/O or CLKOUT.
The function of the OSC2/CLKOUT pin is determined
PIC MCU by the CLKOUTEN bit in Configuration Words.
The internal oscillator block has two independent
SOSCI
oscillators that can produce two internal system clock
C1 To Internal sources.
Logic
32.768 kHz
1. The HFINTOSC (High-Frequency Internal
Quartz Oscillator) is factory-calibrated and operates
Crystal from 1 to 64 MHz. The frequency of HFINTOSC
can be selected through the OSCFRQ
C2 SOSCO Frequency Selection register, and fine-tuning
can be done via the OSCTUNE register.
2. The LFINTOSC (Low-Frequency Internal
Oscillator) is factory-calibrated and operates at
Note 1: Quartz crystal characteristics vary 31 kHz.
according to type, package and
manufacturer. The user should consult the
manufacturer data sheets for specifications
and recommended application.
2: Always verify oscillator performance over
the VDD and temperature range that is
expected for the application.
3: For oscillator design assistance, reference
the following Microchip Application Notes:
AN826, Crystal Oscillator Basics and
Crystal Selection for PIC and PIC
Devices (DS00826)
AN849, Basic PIC Oscillator Design
(DS00849)
AN943, Practical PIC Oscillator
Analysis and Design (DS00943)
AN949, Making Your Oscillator Work
(DS00949)
TB097, Interfacing a Micro Crystal
MS1V-T1K 32.768 kHz Tuning Fork
Crystal to a PIC16F690/SS (DS91097)
AN1288, Design Practices for
Low-Power External Oscillators
(DS01288)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 45


PIC18(L)F26/45/46K40
4.3.2.1 HFINTOSC 4.3.2.3 Internal Oscillator Frequency
The High-Frequency Internal Oscillator (HFINTOSC) is Adjustment
a precision digitally-controlled internal clock source The internal oscillator is factory-calibrated. This
that produces a stable clock up to 64 MHz. The internal oscillator can be adjusted in software by writing
HFINTOSC can be enabled through one of the to the OSCTUNE register (Register 4-3).
following methods:
The default value of the OSCTUNE register is 00h. The
Programming the RSTOSC<2:0> bits in value is a 6-bit twos complement number. A value of
Configuration Word 1 to 110 (FOSC = 1 MHz) or 1Fh will provide an adjustment to the maximum
000 (FOSC = 64 MHz) to set the oscillator upon frequency. A value of 20h will provide an adjustment to
device Power-up or Reset. the minimum frequency.
Write to the NOSC<2:0> bits of the OSCCON1 When the OSCTUNE register is modified, the oscillator
register during run-time. See Section 4.4 Clock frequency will begin shifting to the new frequency. Code
Switching for more information. execution continues during this shift. There is no
The HFINTOSC frequency can be selected by setting indication that the shift has occurred.
the HFFRQ<3:0> bits of the OSCFRQ register. OSCTUNE does not affect the LFINTOSC frequency.
The NDIV<3:0> bits of the OSCCON1 register allow for Operation of features that depend on the LFINTOSC
division of the HFINTOSC output from a range between clock source frequency, such as the Power-up Timer
1:1 and 1:512. (PWRT), WWDT, Fail-Safe Clock Monitor (FSCM) and
peripherals, are not affected by the change in frequency.
4.3.2.2 MFINTOSC
4.3.2.4 LFINTOSC
The module provides two (500 kHz and 31.25 kHz)
constant clock outputs. These clocks are digital The Low-Frequency Internal Oscillator (LFINTOSC) is
divisors of the HFINTOSC clock. Dynamic divider logic a factory-calibrated 31 kHz internal clock source.
is used to provide constant MFINTOSC clock rates for The LFINTOSC is the frequency for the Power-up Timer
all settings of HFINTOSC. (PWRT), Windowed Watchdog Timer (WWDT) and
The MFINTOSC cannot be used to drive the system Fail-Safe Clock Monitor (FSCM).
but it is used to clock certain modules such as the The LFINTOSC is enabled through one of the following
Timers and WWDT. methods:
Programming the RSTOSC<2:0> bits of
Configuration Word 1 to enable LFINTOSC.
Write to the NOSC<2:0> bits of the OSCCON1
register during run-time. See Section 4.4, Clock
Switching for more information.

4.3.2.5 ADCRC
The ADCRC is an oscillator dedicated to the ADC2
module. The ADCRC oscillator can be manually
enabled using the ADOEN bit of the OSCEN register.
The ADCRC runs at a fixed frequency of 600 kHz.
ADCRC is automatically enabled if it is selected as the
clock source for the ADC2 module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 46


PIC18(L)F26/45/46K40
4.3.2.6 Oscillator Status and Manual Enable When the new oscillator is ready, the New Oscillator
Ready (NOSCR) bit of OSCCON3 is set and also the
The Ready status of each oscillator (including the
Clock Switch Interrupt Flag (CSWIF) bit of PIR1 sets. If
ADCRC oscillator) is displayed in OSCSTAT
Clock Switch Interrupts are enabled (CSWIE = 1), an
(Register 4-4). The oscillators (but not the PLL) may be
interrupt will be generated at that time. The Oscillator
explicitly enabled through OSCEN (Register 4-7).
Ready (ORDY) bit of OSCCON3 can also be polled to
4.3.2.7 HFOR and MFOR Bits determine when the oscillator is ready in lieu of an
interrupt.
The HFOR and MFOR bits indicate that the HFINTOSC
and MFINTOSC is ready. These clocks are always
valid for use at all times, but only accurate after they are Note: The CSWIF interrupt will not wake the
ready. system from Sleep.
When a new value is loaded into the OSCFRQ register, If the Clock Switch Hold (CSWHOLD) bit of OSCCON3
the HFOR and MFOR bits will clear, and set again is clear, the oscillator switch will occur when the New
when the oscillator is ready. During pending OSCFRQ Oscillator is Ready bit (NOSCR) is set, and the
changes the MFINTOSC clock will stall at a high or a interrupt (if enabled) will be serviced at the new
low state, until the HFINTOSC resumes operation. oscillator setting.
If CSWHOLD is set, the oscillator switch is suspended,
4.4 Clock Switching while execution continues using the current (old) clock
source. When the NOSCR bit is set, software should:
The system clock source can be switched between
external and internal clock sources via software using Set CSWHOLD = 0 so the switch can complete,
the New Oscillator Source (NOSC) bits of the or
OSCCON1 register. The following clock sources can be Copy COSC into NOSC to abandon the switch.
selected using the following: If DOZE is in effect, the switch occurs on the next clock
External oscillator cycle, whether or not the CPU is operating during that
Internal Oscillator Block (INTOSC) cycle.
Changing the clock post-divider without changing the
clock source (i.e., changing FOSC from 1 MHz to
Note: The Clock Switch Enable bit in 2 MHz) is handled in the same manner as a clock
Configuration Word 1 can be used to source change, as described previously. The clock
enable or disable the clock switching source will already be active, so the switch is relatively
capability. When cleared, the NOSC and quick. CSWHOLD must be clear (CSWHOLD = 0) for
NDIV bits cannot be changed by user the switch to complete.
software. When set, writing to NOSC and
The current COSC and CDIV are indicated in the
NDIV is allowed and would switch the
OSCCON2 register up to the moment when the switch
clock frequency.
actually occurs, at which time OSCCON2 is updated
and ORDY is set. NOSCR is cleared by hardware to
4.4.1 NEW OSCILLATOR SOURCE
indicate that the switch is complete.
(NOSC) AND NEW DIVIDER
SELECTION REQUEST (NDIV) BITS 4.4.2 PLL INPUT SWITCH
The New Oscillator Source (NOSC) and New Divider Switching between the PLL and any non-PLL source is
Selection Request (NDIV) bits of the OSCCON1 managed as described above. The input to the PLL is
register select the system clock source and frequency established when NOSC selects the PLL, and
that are used for the CPU and peripherals. maintained by the COSC setting.
When new values of NOSC and NDIV are written to When NOSC and COSC select the PLL with different
OSCCON1, the current oscillator selection will input sources, the system continues to run using the
continue to operate while waiting for the new clock COSC setting, and the new source is enabled per
source to indicate that it is stable and ready. In some NOSC. When the new oscillator is ready (and
cases, the newly requested source may already be in CSWHOLD = 0), system operation is suspended while
use, and is ready immediately. In the case of a the PLL input is switched and the PLL acquires lock.
divider-only change, the new and old sources are the This provides a truly glitch-free clock switch operation.
same, so the old source will be ready immediately. The
device may enter Sleep while waiting for the switch as
described in Section 4.4.3 Clock Switch and Note: If the PLL fails to lock, the FSCM will
Sleep. trigger.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 47


PIC18(L)F26/45/46K40
4.4.3 CLOCK SWITCH AND SLEEP
If OSCCON1 is written with a new value and the device
is put to Sleep before the switch completes, the switch
will not take place and the device will enter Sleep
mode.
When the device wakes from Sleep and the
CSWHOLD bit is clear, the device will wake with the
new clock active, and the clock switch interrupt flag bit
(CSWIF) will be set.
When the device wakes from Sleep and the
CSWHOLD bit is set, the device will wake with the old
clock active and the new clock will be requested again.

FIGURE 4-6: CLOCK SWITCH (CSWHOLD = 0)


OSCCON1
WRITTEN

OSC #1 OSC #2

ORDY

NOTE 2
NOSCR

NOTE 1
CSWIF

USER
CSWHOLD CLEAR

Note 1: CSWIF is asserted coincident with NOSCR; interrupt is serviced at OSC#2 speed.
2: The assertion of NOSCR is hidden from the user because it appears only for the duration of the switch.

FIGURE 4-7: CLOCK SWITCH (CSWHOLD = 1)


OSCCON1
WRITTEN

OSC #1 OSC #2

ORDY

NOSCR

NOTE 1
CSWIF

USER
CSWHOLD CLEAR

Note 1: CSWIF is asserted coincident with NOSCR, and may be cleared before or after clearing CSWHOLD = 0.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 48


PIC18(L)F26/45/46K40
FIGURE 4-8: CLOCK SWITCH ABANDONED
OSCCON1 OSCCON1
WRITTEN WRITTEN

OSC #1

ORDY
NOTE 2

NOSCR

NOTE 1
CSWIF

CSWHOLD

Note 1: CSWIF may be cleared before or after rewriting OSCCON1; CSWIF is not automatically cleared.
2: ORDY = 0 if OSCCON1 does not match OSCCON2; a new switch will begin.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 49


PIC18(L)F26/45/46K40
4.5 Fail-Safe Clock Monitor 4.5.3 FAIL-SAFE CONDITION CLEARING
The Fail-Safe Clock Monitor (FSCM) allows the device The Fail-Safe condition is cleared after a Reset,
to continue operating should the external oscillator fail. executing a SLEEP instruction or changing the NOSC
The FSCM is enabled by setting the FCMEN bit in the and NDIV bits of the OSCCON1 register. When
Configuration Words. The FSCM is applicable to all switching to the external oscillator or PLL, the OST is
external Oscillator modes (LP, XT, HS, ECL/M/H and restarted. While the OST is running, the device
Secondary Oscillator). continues to operate from the INTOSC selected in
OSCCON1. When the OST times out, the Fail-Safe
condition is cleared after successfully switching to the
FIGURE 4-9: FSCM BLOCK DIAGRAM
external clock source. The OSCFIF bit should be
Clock Monitor cleared prior to switching to the external clock source.
Latch If the Fail-Safe condition still exists, the OSCFIF flag
External will again become set by hardware.
S Q
Clock

LFINTOSC
64 R Q
Oscillator

31 kHz 488 Hz
(~32 s) (~2 ms)

Sample Clock Clock


Failure
Detected

4.5.1 FAIL-SAFE DETECTION


The FSCM module detects a failed oscillator by
comparing the external oscillator to the FSCM sample
clock. The sample clock is generated by dividing the
LFINTOSC by 64. See Figure 4-9. Inside the fail
detector block is a latch. The external clock sets the
latch on each falling edge of the external clock. The
sample clock clears the latch on each rising edge of the
sample clock. A failure is detected when an entire
half-cycle of the sample clock elapses before the
external clock goes low.

4.5.2 FAIL-SAFE OPERATION


When the external clock fails, the FSCM overwrites the
COSC bits to select HFINTOSC (3'b110). The
frequency of HFINTOSC would be determined by the
previous state of the HFFRQ bits and the NDIV/CDIV
bits. The bit flag OSCFIF of the PIR1 register is set.
Setting this flag will generate an interrupt if the OSCFIE
bit of the PIE1 register is also set. The device firmware
can then take steps to mitigate the problems that may
arise from a failed clock. The system clock will continue
to be sourced from the internal clock source until the
device firmware successfully restarts the external
oscillator and switches back to external operation, by
writing to the NOSC and NDIV bits of the OSCCON1
register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 50


PIC18(L)F26/45/46K40
4.5.4 RESET OR WAKE-UP FROM SLEEP
The FSCM is designed to detect an oscillator failure
after the Oscillator Start-up Timer (OST) has expired.
The OST is used after waking up from Sleep and after
any type of Reset. The OST is not used with the EC
Clock modes so that the FSCM will be active as soon
as the Reset or wake-up has completed.

FIGURE 4-10: FSCM TIMING DIAGRAM

Sample Clock

System Oscillator
Clock Failure
Output

Clock Monitor Output


(Q)
Failure
Detected
OSCFIF

Test Test Test

Note: The system clock is normally at a much higher frequency than the sample clock. The relative frequencies in
this example have been chosen for clarity.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 51


PIC18(L)F26/45/46K40
TABLE 4-3: SUMMARY OF REGISTERS ASSOCIATED WITH CLOCK SOURCES
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
OSCCON1 NOSC<2:0> NDIV<3:0> 36
OSCCON2 COSC<2:0> CDIV<3:0> 37
OSCCON3 CSWHOLD SOSCPWR ORDY NOSCR 38
OSCSTAT EXTOR HFOR MFOR LFOR SOR ADOR PLLR 39
OSCTUNE HFTUN<5:0> 41
OSCFRQ HFFRQ<3:0> 40
OSCEN EXTOEN HFOEN MFOEN LFOEN SOSCEN ADOEN 42
PIE1 OSCFIE CSWIE ADTIE ADIE 179
PIR1 OSCFIF CSWIF ADTIF ADIF 171
IPR1 OSCFIP CSWIP ADTIP ADIP 187
Legend: = unimplemented location, read as 0. Shaded cells are not used by clock sources.

TABLE 4-4: SUMMARY OF CONFIGURATION WORD WITH CLOCK SOURCES


Register
Name Bits Bit -/7 Bit -/6 Bit 13/5 Bit 12/4 Bit 11/3 Bit 10/2 Bit 9/1 Bit 8/0
on Page

13:8 FCMEN CSWEN CLKOUTEN


CONFIG1 23
7:0 RSTOSC<2:0> FEXTOSC<2:0>
Legend: = unimplemented location, read as 0. Shaded cells are not used by clock sources.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 52


PIC18(L)F26/45/46K40
5.0 REFERENCE CLOCK OUTPUT
MODULE
The reference clock output module provides the ability
to send a clock signal to the clock reference output pin
(CLKR). The reference clock output can also be used
as a signal for other peripherals, such as the Data
Signal Modulator (DSM), Memory Scanner and Timer
module.
The reference clock output module has the following
features:
Selectable clock source using the CLKRCLK
register
Programmable clock divider
Selectable duty cycle

FIGURE 5-1: CLOCK REFERENCE BLOCK DIAGRAM

Rev. 10-000261B
5/11/2016

CLKRDIV<2:0>
CLKREN Counter Reset
128
Reference Clock Divider 111
See 64 CLKRDC<1:0>
110
CLKRCLK 32
Register 101
16 CLKR
100
8 Duty Cycle PPS
011
4
010
2
001 To Peripherals

CLKREN 000
CLKRCLK<3:0>

2016 Microchip Technology Inc. Preliminary DS40001816C-page 53


PIC18(L)F26/45/46K40
FIGURE 5-2: CLOCK REFERENCE TIMING

Rev. 10-000264B
5/25/2016

P1 P2

CLKRCLK

CLKREN

CLKR Output
CLKRDIV<2:0> = 001
CLKRDC<1:0> = 10
Duty Cycle
(50%)

CLKR Output CLKRCLK/2


CLKRDIV<2:0> = 001
CLKRDC<1:0> = 01
Duty Cycle
(25%)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 54


PIC18(L)F26/45/46K40
5.1 Clock Source 5.3 Selectable Duty Cycle
The input to the reference clock output can be selected The DC<1:0> bits of the CLKRCON register can be
using the CLKRCLK register. used to modify the duty cycle of the output clock. A duty
cycle of 25%, 50%, or 75% can be selected for all clock
5.1.1 CLOCK SYNCHRONIZATION rates, with the exception of the undivided base FOSC
Once the reference clock enable (EN) is set, the mod- value.
ule is ensured to be glitch-free at start-up. The duty cycle can be changed while the module is
When the reference clock output is disabled, the output enabled; however, in order to prevent glitches on the
signal will be disabled immediately. output, the DC<1:0> bits should only be changed when
the module is disabled (EN = 0).
Clock dividers and clock duty cycles can be changed
while the module is enabled, but glitches may occur on
the output. To avoid possible glitches, clock dividers Note: The DC1 bit is reset to 1. This makes the
and clock duty cycles should be changed only when the default duty cycle 50% and not 0%.
CLKREN is clear.
5.4 Operation in Sleep Mode
5.2 Programmable Clock Divider
The reference clock output module clock is based on
The module takes the clock input and divides it based the system clock. When the device goes to Sleep, the
on the value of the DIV<2:0> bits of the CLKRCON reg- module outputs will remain in their current state. This
ister (Register 5-1). will have a direct effect on peripherals using the
The following configurations can be made based on the reference clock output as an input signal. No change
DIV<2:0> bits: should occur in the module from entering or exiting
from Sleep.
Base FOSC value
FOSC divided by 2
FOSC divided by 4
FOSC divided by 8
FOSC divided by 16
FOSC divided by 32
FOSC divided by 64
FOSC divided by 128
The clock divider values can be changed while the
module is enabled; however, in order to prevent
glitches on the output, the DIV<2:0> bits should only be
changed when the module is disabled (EN = 0).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 55


PIC18(L)F26/45/46K40
5.5 Register Definitions: Reference Clock
Long bit name prefixes for the Reference Clock periph-
erals are shown in Table 5-1. Refer to Section
1.4.2.2 Long Bit Names for more information.
TABLE 5-1:
Peripheral Bit Name Prefix
CLKR CLKR

REGISTER 5-1: CLKRCON: REFERENCE CLOCK CONTROL REGISTER


R/W-0/0 U-0 U-0 R/W-1/1 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
EN DC<1:0> DIV<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EN: Reference Clock Module Enable bit


1 = Reference clock module enabled
0 = Reference clock module is disabled
bit 6-5 Unimplemented: Read as 0
bit 4-3 DC<1:0>: Reference Clock Duty Cycle bits(1)
11 = Clock outputs duty cycle of 75%
10 = Clock outputs duty cycle of 50%
01 = Clock outputs duty cycle of 25%
00 = Clock outputs duty cycle of 0%
bit 2-0 DIV<2:0>: Reference Clock Divider bits
111 = Base clock value divided by 128
110 = Base clock value divided by 64
101 = Base clock value divided by 32
100 = Base clock value divided by 16
011 = Base clock value divided by 8
010 = Base clock value divided by 4
001 = Base clock value divided by 2
000 = Base clock value

Note 1: Bits are valid for reference clock divider values of two or larger, the base clock cannot be further divided.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 56


PIC18(L)F26/45/46K40

REGISTER 5-2: CLKRCLK: CLOCK REFERENCE CLOCK SELECTION MUX


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
CLK<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-3 Unimplemented: Read as 0


bit 2-0 CLK<2:0>: CLKR Clock Selection bits
111 = Unimplemented
110 = Unimplemented
101 = Unimplemented
100 = SOSC
011 = MFINTOSC (500 kHz)
010 = LFINTOSC (31 kHz)
001 = HFINTOSC
000 = FOSC

TABLE 5-2: SUMMARY OF REGISTERS ASSOCIATED WITH CLOCK REFERENCE OUTPUT


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
CLKRCON EN DC<1:0> DIV<2:0> 56
CLKRCLK CLK<2:0> 57
PMD0 SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD 67
RxyPPS RxyPPS<4:0> 217
Legend: = unimplemented, read as 0. Shaded cells are not used by the CLKR module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 57


PIC18(L)F26/45/46K40
6.0 POWER-SAVING OPERATION When the Doze Enable (DOZEN) bit is set
(DOZEN = 1), the CPU executes only one instruction
MODES
cycle out of every N cycles as defined by the
The purpose of the Power-Down modes is to reduce DOZE<2:0> bits of the CPUDOZE register. For
power consumption. There are three Power-Down example, if DOZE<2:0> = 001, the instruction cycle
modes: ratio is 1:4. The CPU and memory execute for one
Doze mode instruction cycle and then lay idle for three instruction
cycles. During the unused cycles, the peripherals
Sleep mode
continue to operate at the system clock speed.
Idle mode
6.1.1 DOZE OPERATION
6.1 Doze Mode The Doze operation is illustrated in Figure 6-1. For this
Doze mode allows for power saving by reducing CPU example:
operation and program memory (PFM) access, without Doze enable (DOZEN) bit set (DOZEN = 1)
affecting peripheral operation. Doze mode differs from DOZE<2:0> = 001 (1:4) ratio
Sleep mode because the bandgap and system Recover-on-Interrupt (ROI) bit set (ROI = 1)
oscillators continue to operate, while only the CPU and
As with normal operation, the PFM fetches for the next
PFM are affected. The reduced execution saves power
instruction cycle. The Q-clocks to the peripherals
by eliminating unnecessary operations within the CPU
continue throughout.
and memory.

FIGURE 6-1: DOZE MODE OPERATION EXAMPLE (DOZE<2:0> = 001, 1:4)


System
Clock

1 1 1 1 1 1 1 1 1 1 1 1 1

2 2 2 2 2 2 2 2 2 2 2 2 2

/
W 3 3 3 3 3 3 3 3 3 3 3 3 3

4 4 4 4 4 4 4 4 4 4 4 4 4

1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4 1 2 3 4
CPU Clock

PFM Ops Fetch Fetch Push 0004h Fetch Fetch

CPU Ops Exec Exec Exec(1,2) NOP Exec Exec Exec

Interrupt
Here
(ROI = 1)
Note 1: Multi-cycle instructions are executed to completion before fetching 0004h.
2: If the pre-fetched instruction clears GIE, the ISR will not occur, but DOZEN is still cleared and the CPU will resume execution at full speed.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 58


PIC18(L)F26/45/46K40
6.1.2 INTERRUPTS DURING DOZE 6.2 Sleep Mode
If an interrupt occurs and the Recover-On-Interrupt bit Sleep mode is entered by executing the SLEEP
is clear (ROI = 0) at the time of the interrupt, the instruction, while the Idle Enable (IDLEN) bit of the
Interrupt Service Routine (ISR) continues to execute at CPUDOZE register is clear (IDLEN = 0).
the rate selected by DOZE<2:0>. Interrupt latency is
extended by the DOZE<2:0> ratio. Upon entering Sleep mode, the following conditions
exist:
If an interrupt occurs and the ROI bit is set (ROI = 1) at
the time of the interrupt, the DOZEN bit is cleared and 1. WDT will be cleared but keeps running if
the CPU executes at full speed. The prefetched instruc- enabled for operation during Sleep
tion is executed and then the interrupt vector sequence 2. The PD bit of the STATUS register is cleared
is executed. In Figure 6-1, the interrupt occurs during (Register 10-2)
the 2nd instruction cycle of the Doze period, and imme- 3. The TO bit of the STATUS register is set
diately brings the CPU out of Doze. If the Doze-On-Exit (Register 10-2)
(DOE) bit is set (DOE = 1) when the RETFIE operation 4. The CPU clock is disabled
is executed, DOZEN is set, and the CPU executes at 5. LFINTOSC, SOSC, HFINTOSC and ADCRC
the reduced rate based on the DOZE<2:0> ratio. are unaffected and peripherals using them may
continue operation in Sleep.
EXAMPLE 6-1: DOZE SOFTWARE 6. I/O ports maintain the status they had before
EXAMPLE Sleep was executed (driving high, low, or
high-impedance)
//Mainline operation
7. Resets other than WDT are not affected by
bool somethingToDo = FALSE:
void main()
Sleep mode
{ Refer to individual chapters for more details on
initializeSystem(); peripheral operation during Sleep.
// DOZE = 64:1 (for example)
// ROI = 1; To minimize current consumption, the following
GIE = 1; // enable interrupts conditions should be considered:
while (1) - I/O pins should not be floating
{
- External circuitry sinking current from I/O pins
// If ADC completed, process data
- Internal circuitry sourcing current from I/O
if (somethingToDo)
{
pins
doSomething(); - Current draw from pins with internal weak
DOZEN = 1; // resume low-power pull-ups
} - Modules using any oscillator
} I/O pins that are high-impedance inputs should be
}
pulled to VDD or VSS externally to avoid switching
// Data interrupt handler
currents caused by floating inputs.
void interrupt() Examples of internal circuitry that might be sourcing
{ current include modules such as the DAC and FVR
// DOZEN = 0 because ROI = 1 modules. See Section 30.0 5-Bit Digital-to-Analog
if (ADIF) Converter (DAC) Module and Section 28.0 Fixed
{
Voltage Reference (FVR) for more information on
somethingToDo = TRUE;
DOE = 0; // make main() go fast
these modules.
ADIF = 0;
}
// else check other interrupts...
if (TMR0IF)
{
timerTick++;
DOE = 1; // make main() go slow
TMR0IF = 0;
}
}

2016 Microchip Technology Inc. Preliminary DS40001816C-page 59


PIC18(L)F26/45/46K40
6.2.1 WAKE-UP FROM SLEEP 6.2.2 WAKE-UP USING INTERRUPTS
The device can wake-up from Sleep through one of the When global interrupts are disabled (GIE cleared) and
following events: any interrupt source, with the exception of the clock
1. External Reset input on MCLR pin, if enabled switch interrupt, has both its interrupt enable bit and
interrupt flag bit set, one of the following will occur:
2. BOR Reset, if enabled
3. Low-Power Brown-Out Reset (LPBOR), if If the interrupt occurs before the execution of a
enabled SLEEP instruction
4. POR Reset - SLEEP instruction will execute as a NOP
5. Windowed Watchdog Timer, if enabled - WDT and WDT prescaler will not be cleared
6. All interrupt sources except clock switch - TO bit of the STATUS register will not be set
interrupt can wake-up the part. - PD bit of the STATUS register will not be
cleared
The first five events will cause a device Reset. The last
one event is considered a continuation of program If the interrupt occurs during or after the
execution. To determine whether a device Reset or execution of a SLEEP instruction
wake-up event occurred, refer to Section - SLEEP instruction will be completely
8.13 Determining the Cause of a Reset. executed
When the SLEEP instruction is being executed, the next - Device will immediately wake-up from Sleep
instruction (PC + 2) is prefetched. For the device to - WDT and WDT prescaler will be cleared
wake-up through an interrupt event, the corresponding - TO bit of the STATUS register will be set
Interrupt Enable bit must be enabled, as well as the - PD bit of the STATUS register will be cleared
Peripheral Interrupt Enable bit (PEIE = 1), for every
Even if the flag bits were checked before executing a
interrupt not in PIR0. Wake-up will occur regardless of
SLEEP instruction, it may be possible for flag bits to
the state of the GIE bit. If the GIE bit is disabled, the
become set before the SLEEP instruction completes. To
device continues execution at the instruction after the
determine whether a SLEEP instruction executed, test
SLEEP instruction. If the GIE bit is enabled, the device
the PD bit. If the PD bit is set, the SLEEP instruction
executes the instruction after the SLEEP instruction, the
was executed as a NOP.
device will then call the Interrupt Service Routine. In
cases where the execution of the instruction following
SLEEP is not desirable, the user should have a NOP
after the SLEEP instruction.
The WDT is cleared when the device wakes-up from
Sleep, regardless of the source of wake-up.
Upon a wake from a Sleep event, the core will wait for
a combination of three conditions before beginning
execution. The conditions are:
PFM Ready
COSC-Selected Oscillator Ready
BOR Ready (unless BOR is disabled)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 60


PIC18(L)F26/45/46K40
FIGURE 6-2: WAKE-UP FROM SLEEP THROUGH INTERRUPT

Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
CLKIN(1)
CLKOUT(2) TOST(3)

Interrupt flag Interrupt Latency (4)

GIE bit
(INTCON reg.) Processor in
Sleep

Instruction Flow
PC PC PC + 1 PC + 2 PC + 2 PC + 2 0004h 0005h
Instruction Inst(PC + 1) Inst(PC + 2) Inst(0004h) Inst(0005h)
Fetched Inst(PC) = Sleep
Instruction Sleep Inst(PC + 1) Forced NOP Forced NOP
Executed Inst(PC - 1) Inst(0004h)

Note 1: External clock. High, Medium, Low mode assumed.


2: CLKOUT is shown here for timing reference.
3: TOST = 1024 TOSC. This delay does not apply to EC and INTOSC Oscillator modes.
4: GIE = 1 assumed. In this case after wake-up, the processor calls the ISR at 0004h. If GIE = 0, execution will continue in-line.

6.2.3 LOW-POWER SLEEP MODE 6.2.3.1 Sleep Current vs. Wake-up Time
The PIC18F2x/4xK40 device family contains an In the default operating mode, the LDO and reference
internal Low Dropout (LDO) voltage regulator, which circuitry remain in the normal configuration while in
allows the device I/O pins to operate at voltages up to Sleep. The device is able to exit Sleep mode quickly
5.5V while the internal device logic operates at a lower since all circuits remain active. In Low-Power Sleep
voltage. The LDO and its associated reference circuitry mode, when waking-up from Sleep, an extra delay time
must remain active when the device is in Sleep mode. is required for these circuits to return to the normal
The PIC18F2x/4xK40 devices allows the user to configuration and stabilize.
optimize the operating current in Sleep, depending on The Low-Power Sleep mode is beneficial for
the application requirements. applications that stay in Sleep mode for long periods of
time. The Normal mode is beneficial for applications
Low-Power Sleep mode can be selected by setting the
that need to wake from Sleep quickly and frequently.
VREGPM bit of the VREGCON register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 61


PIC18(L)F26/45/46K40
6.2.3.2 Peripheral Usage in Sleep 6.2.4.1 Idle and Interrupts
Some peripherals that can operate in Sleep mode will IDLE mode ends when an interrupt occurs (even if GIE
not operate properly with the Low-Power Sleep mode = 0), but IDLEN is not changed. The device can
selected. The Low-Power Sleep mode is intended for re-enter IDLE by executing the SLEEP instruction.
use with these peripherals: If Recover-On-Interrupt is enabled (ROI = 1), the
Brown-out Reset (BOR) interrupt that brings the device out of Idle also restores
Windowed Watchdog Timer (WWDT) full-speed CPU execution when doze is also enabled.
External interrupt pin/Interrupt-On-Change pins
Peripherals that run off external secondary clock 6.2.4.2 Idle and WWDT
source When in Idle, the WWDT Reset is blocked and will
It is the responsibility of the end user to determine what instead wake the device. The WWDT wake-up is not an
is acceptable for their application when setting the interrupt, therefore ROI does not apply.
VREGPM settings in order to ensure operation in
Sleep.
Note: The WDT can bring the device out of Idle,
in the same way it brings the device out of
Note: The PIC18LF2x/4xK40 devices do not Sleep. The DOZEN bit is not affected.
have a configurable Low-Power Sleep
mode. PIC18LF2x/4xK40 devices are 6.3 Peripheral Operation in Power
unregulated and are always in the lowest
Saving Modes
power state when in Sleep, with no
wake-up time penalty. These devices All selected clock sources and the peripherals running
have a lower maximum VDD and I/O volt- off them are active in both IDLE and DOZE mode. Only
age than the PIC18F2x/4xK40. See Sec- in Sleep mode, both the FOSC and FOSC/4 clocks are
tion 37.0 Electrical Specifications for unavailable. All the other clock sources are active, if
more information. enabled manually or through peripheral clock selection
before the part enters Sleep.
6.2.4 IDLE MODE
When IDLEN is set (IDLEN = 1), the SLEEP instruction
will put the device into Idle mode. In Idle mode, the
CPU and memory operations are halted, but the
peripheral clocks continue to run. This mode is similar
to Doze mode, except that in IDLE both the CPU and
PFM are shut off.

Note: If CLKOUTEN is enabled (CLKOUTEN = 0,


Configuration Word 1H), the output will con-
tinue operating while in Idle.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 62


PIC18(L)F26/45/46K40
6.4 Register Definitions: Voltage Regulator Control

REGISTER 6-1: VREGCON: VOLTAGE REGULATOR CONTROL REGISTER(1)


U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-1/1
VREGPM Reserved
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-2 Unimplemented: Read as 0


bit 1 VREGPM: Voltage Regulator Power Mode Selection bit
1 = Low-Power Sleep mode enabled in Sleep(2)
Draws lowest current in Sleep, slower wake-up
0 = Normal Power mode enabled in Sleep(2)
Draws higher current in Sleep, faster wake-up
bit 0 Reserved: Read as 1. Maintain this bit set.

Note 1: PIC18F2x/4xK40 only.


2: See Section 37.0 Electrical Specifications.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 63


PIC18(L)F26/45/46K40
REGISTER 6-2: CPUDOZE: DOZE AND IDLE REGISTER
R/W-0/u R/W/HC/HS-0/0 R/W-0/0 R/W-0/0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
IDLEN DOZEN ROI DOE DOZE<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other
Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 IDLEN: Idle Enable bit


1 = A SLEEP instruction inhibits the CPU clock, but not the peripheral clock(s)
0 = A SLEEP instruction places the device into full Sleep mode
bit 6 DOZEN: Doze Enable bit(1,2)
1 = The CPU executes instruction cycles according to DOZE setting
0 = The CPU executes all instruction cycles (fastest, highest power operation)
bit 5 ROI: Recover-On-Interrupt bit
1 = Entering the Interrupt Service Routine (ISR) makes DOZEN = 0 bit, bringing the CPU to full-speed
operation
0 = Interrupt entry does not change DOZEN
bit 4 DOE: Doze-On-Exit bit
1 = Executing RETFIE makes DOZEN = 1, bringing the CPU to reduced speed operation
0 = RETFIE does not change DOZEN
bit 3 Unimplemented: Read as 0
bit 2-0 DOZE<2:0>: Ratio of CPU Instruction Cycles to Peripheral Instruction Cycles
111 =1:256
110 =1:128
101 =1:64
100 =1:32
011 =1:16
010 =1:8
001 =1:4
000 =1:2

Note 1: When ROI = 1 or DOE = 1, DOZEN is changed by hardware interrupt entry and/or exit.
2: Entering ICD overrides DOZEN, returning the CPU to full execution speed; this bit is not affected.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 64


PIC18(L)F26/45/46K40
TABLE 6-1: SUMMARY OF REGISTERS ASSOCIATED WITH POWER-DOWN MODE
Register on
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Page

INTCON GIE PEIE INTEDG 169


PIE0 TMR0IE IOCIE INT2IE INT1IE INT0IE 178
PIE1 OSCFIE CSWIE ADTIE ADIE 179
PIE2 HLVDIE ZCDIE C2IE C1IE 180
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE 182
PIE5 TMR5GIE TMR3GIE TMR1GIE 183
PIE6 CCP2IE CCP1IE 184
PIE7 SCANIE CRCIE NVMIE CWG1IE 185
PIR0 TMR0IF IOCIF INT2IF INT1IF INT0IF 170
PIR1 OSCFIF CSWIF ADTIF ADIF 171
PIR2 HLVDIF ZCDIF(1) C2IF C1IF 172
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF 173
IOCAP IOCAP5 IOCAP4 IOCAP3 IOCAP2 IOCAP1 IOCAP0 210
IOCAN IOCAN5 IOCAN4 IOCAN3 IOCAN2 IOCAN1 IOCAN0 210
IOCAF IOCAF5 IOCAF4 IOCAF3 IOCAF2 IOCAF1 IOCAF0 210
(1)
IOCCP IOCCP5 IOCCP4 IOCCP3 IOCCP2 IOCCP1 IOCCP0 210
IOCCN(1) IOCCN5 IOCCN4 IOCCN3 IOCCN2 IOCCN1 IOCCN0 210
IOCCF(1) IOCCF5 IOCCF4 IOCCF3 IOCCF2 IOCCF1 IOCCF0 210
STATUS TO PD Z DC C 117
VREGCON VREGPM Reserved 63
CPUDOZE IDLEN DOZEN ROI DOE DOZE<2:0> 64
WDTCON0 WDTPS<4:0> SEN 84
WDTCON1 WDTPS<2:0> WINDOW<2:0> 85
Legend: = unimplemented location, read as 0. Shaded cells are not used in Power-Down mode.
Note 1: PIC18(L)F4xK40 only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 65


PIC18(L)F26/45/46K40
7.0 PERIPHERAL MODULE 7.3 Effects of a Reset
DISABLE (PMD) Following any Reset, each control bit is set to 0,
Sleep, Idle and Doze modes allow users to enabling all modules.
substantially reduce power consumption by slowing or
stopping the CPU clock. Even so, peripheral modules 7.4 System Clock Disable
still remain clocked, and thus, consume some amount
Setting SYSCMD (PMD0, Register 7-1) disables the
of power. There may be cases where the application
system clock (FOSC) distribution network to the
needs what these modes do not provide: the ability to
peripherals. Not all peripherals make use of SYSCLK,
allocate limited power resources to the CPU while
so not all peripherals are affected. Refer to the specific
eliminating power consumption from the peripherals.
peripheral description to see if it will be affected by this
The PIC18(L)F2x/4xK40 family addresses this bit.
requirement by allowing peripheral modules to be
selectively enabled or disabled, placing them into the
lowest possible power mode.
For legacy reasons, all modules are ON by default
following any Reset.

7.1 Disabling a Module


Disabling a module has the following effects:
All clock and control inputs to the module are
suspended; there are no logic transitions, and the
module will not function.
The module is held in Reset.
Any SFR becomes unimplemented
- Writing is disabled
- Reading returns 00h
I/O functionality is prioritized as per Section 15.1,
I/O Priorities
All associated Input Selection registers are also
disabled

7.2 Enabling a Module


When the PMD register bit is cleared, the module is
re-enabled and will be in its Reset state (Power-on
Reset). SFR data will reflect the POR Reset values.
Depending on the module, it may take up to one full
instruction cycle for the module to become active.
There should be no interaction with the module
(e.g., writing to registers) for at least one instruction
after it has been re-enabled.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 66


PIC18(L)F26/45/46K40
7.5 Register Definitions: Peripheral Module Disable

REGISTER 7-1: PMD0: PMD CONTROL REGISTER 0


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD
7 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 SYSCMD: Disable Peripheral System Clock Network bit(1)


See description in Section 7.4 System Clock Disable.
1 = System clock network disabled (FOSC)
0 = System clock network enabled
bit 6 FVRMD: Disable Fixed Voltage Reference bit
1 = FVR module disabled
0 = FVR module enabled
bit 5 HLVDMD: Disable Low-Voltage Detect bit
1 = HLVD module disabled
0 = HLVD module enabled
bit 4 CRCMD: Disable CRC Engine bit
1 = CRC module disabled
0 = CRC module enabled
bit 3 SCANMD: Disable NVM Memory Scanner bit(2)
1 = NVM Memory Scan module disabled
0 = NVM Memory Scan module enabled
bit 2 NVMMD: NVM Module Disable bit(3)
1 = All Memory reading and writing is disabled; NVMCON registers cannot be written
0 = NVM module enabled
bit 1 CLKRMD: Disable Clock Reference bit
1 = CLKR module disabled
0 = CLKR module enabled
bit 0 IOCMD: Disable Interrupt-on-Change bit, All Ports
1 = IOC module(s) disabled
0 = IOC module(s) enabled

Note 1: Clearing the SYSCMD bit disables the system clock (FOSC) to peripherals, however peripherals clocked
by FOSC/4 are not affected.
2: Subject to SCANE bit in CONFIG4H.
3: When enabling NVM, a delay of up to 1 s may be required before accessing data.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 67


PIC18(L)F26/45/46K40

REGISTER 7-2: PMD1: PMD CONTROL REGISTER 1


U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 Unimplemented: Read as 0


bit 6 TMR6MD: Disable Timer TMR6 bit
1 = TMR6 module disabled
0 = TMR6 module enabled
bit 5 TMR5MD: Disable Timer TMR5 bit
1 = TMR5 module disabled
0 = TMR5 module enabled
bit 4 TMR4MD: Disable Timer TMR4 bit
1 = TMR4 module disabled
0 = TMR4 module enabled
bit 3 TMR3MD: Disable Timer TMR3 bit
1 = TMR3 module disabled
0 = TMR3 module enabled
bit 2 TMR2MD: Disable Timer TMR2 bit
1 = TMR2 module disabled
0 = TMR2 module enabled
bit 1 TMR1MD: Disable Timer TMR1 bit
1 = TMR1 module disabled
0 = TMR1 module enabled
bit 0 TMR0MD: Disable Timer TMR0 bit
1 = TMR0 module disabled
0 = TMR0 module enabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 68


PIC18(L)F26/45/46K40

REGISTER 7-3: PMD2: PMD CONTROL REGISTER 2


U-0 R/W-0/0 R/W-0/0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
DACMD ADCMD CMP2MD CMP1MD ZCDMD(1)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 Unimplemented: Read as 0


bit 6 DACMD: Disable DAC bit
1 = DAC module disabled
0 = DAC module enabled
bit 5 ADCMD: Disable ADC bit
1 = ADC module disabled
0 = ADC module enabled
bit 4-3 Unimplemented: Read as 0
bit 2 CMP2MD: Disable Comparator CMP2 bit
1 = CMP2 module disabled
0 = CMP2 module enabled
bit 1 CMP1MD: Disable Comparator CMP1 bit
1 = CMP1 module disabled
0 = CMP1 module enabled
bit 0 ZCDMD: Disable Zero-Cross Detect module bit(1)
1 = ZCD module disabled
0 = ZCD module enabled

Note 1: Subject to ZCD bit in CONFIG2H.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 69


PIC18(L)F26/45/46K40

REGISTER 7-4: PMD3: PMD CONTROL REGISTER 3


U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
PWM4MD PWM3MD CCP2MD CCP1MD
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-4 Unimplemented: Read as 0


bit 3 PWM4MD: Disable Pulse-Width Modulator PWM4 bit
1 = PWM4 module disabled
0 = PWM4 module enabled
bit 2 PWM3MD: Disable Pulse-Width Modulator PWM3 bit
1 = PWM3 module disabled
0 = PWM3 module enabled
bit 1 CCP2MD: Disable Pulse-Width Modulator CCP2 bit
1 = CCP2 module disabled
0 = CCP2 module enabled
bit 0 CCP1MD: Disable Pulse-Width Modulator CCP1 bit
1 = CCP1 module disabled
0 = CCP1 module enabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 70


PIC18(L)F26/45/46K40

REGISTER 7-5: PMD4: PMD CONTROL REGISTER 4


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0 U-0 R/W-0/0
UART2MD UART1MD MSSP2MD MSSP1MD CWG1MD
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 UART2MD: Disable EUSART2 bit


1 = EUSART2 module disabled
0 = EUSART2 module enabled
bit 6 UART1MD: Disable EUSART1 bit
1 = EUSART1 module disabled
0 = EUSART1 module enabled
bit 5 MSSP2MD: Disable MSSP2 bit
1 = MSSP2 module disabled
0 = MSSP2 module enabled
bit 4 MSSP1MD: Disable MSSP1 bit
1 = MSSP1 module disabled
0 = MSSP1 module enabled
bit 3-1 Unimplemented: Read as 0
bit 0 CWG1MD: Disable CWG1 Module bit
1 = CWG1 module disabled
0 = CWG1 module enabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 71


PIC18(L)F26/45/46K40

REGISTER 7-6: PMD5: PMD CONTROL REGISTER 5


U-0 U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0
DSMMD
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-1 Unimplemented: Read as 0


bit 0 DSMMD: Disable Data Signal Modulator bit
1 = DSM module disabled
0 = DSM module enabled

TABLE 7-1: SUMMARY OF REGISTERS ASSOCIATED WITH PMD


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
PMD0 SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD 67
PMD1 TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD 68
PMD2 DACMD ADCMD CMP2MD CMP1MD ZCDMD 69
PMD3 PWM4MD PWM3MD CCP2MD CCP1MD 70
PMD4 UART2MD UART1MD MSSP2MD MSSP1MD CWG1MD 71
PMD5 DSMMD 72
Legend: = unimplemented, read as 0. Shaded cells are not used by the PMD.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 72


PIC18(L)F26/45/46K40
8.0 RESETS
There are multiple ways to reset this device:
Power-on Reset (POR)
Brown-out Reset (BOR)
Low-Power Brown-Out Reset (LPBOR)
MCLR Reset
WDT Reset
RESET instruction
Stack Overflow
Stack Underflow
Programming mode exit
To allow VDD to stabilize, an optional Power-up Timer
can be enabled to extend the Reset time after a BOR
or POR event.
A simplified block diagram of the On-Chip Reset Circuit
is shown in Figure 8-1.

FIGURE 8-1: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT


Rev. 10-000006E
5/11/2016

ICSP Programming Mode Exit


RESET Instruction

Stack Underflow
Stack Overflow

VPP/MCLR MCLRE

WWDT Time-out/
Window voilation Device
Reset

Power-on
Reset
VDD

Brown-out
R
Reset(1) Power-up
Timer
LFINTOSC PWRTE
LPBOR
Reset

Note 1: See Table 8-1 for BOR active conditions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 73


PIC18(L)F26/45/46K40
FIGURE 8-2: LPBOR, BOR, POR RELATIONSHIP

BOR
BOR Event

REARM POR
Event To PCON
indicator bit
POR
LPBOR
POR Event
LPBOR Event

Reset
logic

8.1 Register Definitions: BOR Control


REGISTER 8-1: BORCON: BROWN-OUT RESET CONTROL REGISTER
R/W-1/u U-0 U-0 U-0 U-0 U-0 U-0 R-q/u
SBOREN BORRDY
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 SBOREN: Software Brown-out Reset Enable bit


If BOREN 01:
SBOREN is read/write, but has no effect on the BOR.
If BOREN = 01:
1 = BOR Enabled
0 = BOR Disabled
bit 6-1 Unimplemented: Read as 0
bit 0 BORRDY: Brown-out Reset Circuit Ready Status bit
1 = The Brown-out Reset Circuit is active and armed
0 = The Brown-out Reset Circuit is disabled or is warming up

2016 Microchip Technology Inc. Preliminary DS40001816C-page 74


PIC18(L)F26/45/46K40
8.2 Register Definitions: Power Control

REGISTER 8-2: PCON0: POWER CONTROL REGISTER 0


R/W/HS-0/q R/W/HS-0/q R/W/HC-1/q R/W/HC-1/q R/W/HC-1/q R/W/HC-1/q R/W/HC-0/u R/W/HC-q/u
STKOVF STKUNF WDTWV RWDT RMCLR RI POR BOR
bit 7 bit 0

Legend:
HC = Bit is cleared by hardware HS = Bit is set by hardware
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -m/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 STKOVF: Stack Overflow Flag bit


1 = A Stack Overflow occurred (more CALLs than fit on the stack)
0 = A Stack Overflow has not occurred or set to 0 by firmware
bit 6 STKUNF: Stack Underflow Flag bit
1 = A Stack Underflow occurred (more RETURNs than CALLs)
0 = A Stack Underflow has not occurred or set to 0 by firmware
bit 5 WDTWV: Watchdog Window Violation bit
1 = A WDT window violation has not occurred or set to 1 by firmware
0 = A CLRWDT instruction was issued when the WDT Reset window was closed (set to 0 in hardware
when a WDT window violation Reset occurs)
bit 4 RWDT: WDT Reset Flag bit
1 = A WDT overflow/time-out Reset has not occurred or set to 1 by firmware
0 = A WDT overflow/time-out Reset has occurred (set to 0 in hardware when a WDT Reset occurs)
bit 3 RMCLR: MCLR Reset Flag bit
1 = A MCLR Reset has not occurred or set to 1 by firmware
0 = A MCLR Reset has occurred (set to 0 in hardware when a MCLR Reset occurs)
bit 2 RI: RESET Instruction Flag bit
1 = A RESET instruction has not been executed or set to 1 by firmware
0 = A RESET instruction has been executed (set to 0 in hardware upon executing a RESET
instruction)
bit 1 POR: Power-on Reset Status bit
1 = No Power-on Reset occurred or set to 1 by firmware
0 = A Power-on Reset occurred (set to 0 in hardware when a Power-on Reset occurs)
bit 0 BOR: Brown-out Reset Status bit
1 = No Brown-out Reset occurred or set to 1 by firmware
0 = A Brown-out Reset occurred (set to 0 in hardware when a Brown-out Reset occurs)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 75


PIC18(L)F26/45/46K40
8.3 Power-on Reset (POR) 8.4.3 BOR CONTROLLED BY SOFTWARE
The POR circuit holds the device in Reset until VDD has When the BOREN bits of Configuration Words are
reached an acceptable level for minimum operation. programmed to 01, the BOR is controlled by the
Slow rising VDD, fast operating speeds or analog SBOREN bit of the BORCON register. The device
performance may require greater than minimum VDD. start-up is not delayed by the BOR ready condition or
The PWRT, BOR or MCLR features can be used to the VDD level.
extend the start-up period until all device operation BOR protection begins as soon as the BOR circuit is
conditions have been met. ready. The status of the BOR circuit is reflected in the
BORRDY bit of the BORCON register.
8.4 Brown-out Reset (BOR) BOR protection is unchanged by Sleep.
The BOR circuit holds the device in Reset when VDD
8.4.4 BOR AND BULK ERASE
reaches a selectable minimum level. Between the
POR and BOR, complete voltage range coverage for BOR is forced ON during PFM Bulk Erase operations
execution protection can be implemented. to make sure that the system code protection cannot be
compromised by reducing VDD.
The Brown-out Reset module has four operating
modes controlled by the BOREN<1:0> bits in During Bulk Erase, the BOR is enabled at 2.45V for F
Configuration Words. The four operating modes are: and LF devices, even if it is configured to some other
value. If VDD falls, the erase cycle will be aborted, but
BOR is always on
the device will not be reset.
BOR is off when in Sleep
BOR is controlled by software
BOR is always off
Refer to Table 8-1 for more information.
The Brown-out Reset voltage level is selectable by
configuring the BORV<1:0> bits in Configuration
Words.
A VDD noise rejection filter prevents the BOR from
triggering on small events. If VDD falls below VBOR for
a duration greater than parameter TBORDC, the device
will reset. See Table 37-11 for more information.

8.4.1 BOR IS ALWAYS ON


When the BOREN bits of Configuration Words are
programmed to 11, the BOR is always on. The device
start-up will be delayed until the BOR is ready and VDD
is higher than the BOR threshold.
BOR protection is active during Sleep. The BOR does
not delay wake-up from Sleep.

8.4.2 BOR IS OFF IN SLEEP


When the BOREN bits of Configuration Words are
programmed to 10, the BOR is on, except in Sleep.
The device start-up will be delayed until the BOR is
ready and VDD is higher than the BOR threshold.
BOR protection is not active during Sleep. The device
wake-up will be delayed until the BOR is ready.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 76


PIC18(L)F26/45/46K40

TABLE 8-1: BOR OPERATING MODES


Instruction Execution upon:
BOREN<1:0> SBOREN Device Mode BOR Mode
Release of POR Wake-up from Sleep
Wait for release of BOR
11 X X Active Begins immediately
(BORRDY = 1)
Wait for release of BOR
Awake Active N/A
(BORRDY = 1)
10 X
Wait for release of BOR
Sleep Hibernate N/A
(BORRDY = 1)
1 X Active Wait for release of BOR
01 Begins immediately
0 X Hibernate (BORRDY = 1)
00 X X Disabled Begins immediately

FIGURE 8-3: BROWN-OUT SITUATIONS

VDD
VBOR

Internal
Reset TPWRT(1)

VDD
VBOR

Internal < TPWRT


Reset TPWRT(1)

VDD
VBOR

Internal
Reset TPWRT(1)

Note 1: TPWRT delay only if PWRTE bit is programmed to 0.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 77


PIC18(L)F26/45/46K40
8.5 Low-Power Brown-out Reset 8.7 Windowed Watchdog Timer
(LPBOR) (WWDT) Reset
The Low-Power Brown-out Reset (LPBOR) provides The Windowed Watchdog Timer generates a Reset if
an additional BOR circuit for low power operation. the firmware does not issue a CLRWDT instruction
Refer to Figure 8-2 to see how the BOR interacts with within the time-out period or window set. The TO and
other modules. PD bits in the STATUS register and the RWDT bit in the
The LPBOR is used to monitor the external VDD pin. PCON0 register are changed to indicate a WDT Reset.
When too low of a voltage is detected, the device is The WDTWV bit in the PCON0 register indicates if the
held in Reset. WDT Reset has occurred due to a time out or a window
violation. See Section 9.0 Windowed Watchdog
8.5.1 ENABLING LPBOR Timer (WWDT) for more information.
The LPBOR is controlled by the LPBOREN bit of
Configuration Word 2L. When the device is erased, the
8.8 RESET Instruction
LPBOR module defaults to disabled. A RESET instruction will cause a device Reset. The RI
bit in the PCON0 register will be set to 0. See Table 8-3
8.5.1.1 LPBOR Module Output for default conditions after a RESET instruction has
The output of the LPBOR module is a signal indicating occurred.
whether or not a Reset is to be asserted. This signal is
ORd together with the Reset signal of the BOR 8.9 Stack Overflow/Underflow Reset
module to provide the generic BOR signal, which goes
to the PCON0 register and to the power control block. The device can reset when the Stack Overflows or
Underflows. The STKOVF or STKUNF bits of the
PCON0 register indicate the Reset condition. These
8.6 MCLR
Resets are enabled by setting the STVREN bit in
The MCLR is an optional external input that can reset Configuration Words. See Section 10.2.1 Stack
the device. The MCLR function is controlled by the Overflow and Underflow Resets for more information.
MCLRE bit of Configuration Words and the LVP bit of
Configuration Words (Table 8-2). The RMCLR bit in the 8.10 Programming Mode Exit
PCON0 register will be set to 0 if a MCLR has
occurred. Upon exit of Programming mode, the device will
behave as if a POR had just occurred.

TABLE 8-2: MCLR CONFIGURATION 8.11 Power-up Timer (PWRT)


MCLRE LVP MCLR
The Power-up Timer provides a nominal 66 ms (2048
x 1 Enabled cycles of LFINTOSC) time out on POR or Brown-out
1 0 Enabled Reset.
0 0 Disabled The device is held in Reset as long as PWRT is active.
The PWRT delay allows additional time for the VDD to
8.6.1 MCLR ENABLED rise to an acceptable level. The Power-up Timer is
enabled by clearing the PWRTE bit in Configuration
When MCLR is enabled and the pin is held low, the
Words.
device is held in Reset. The MCLR pin is connected to
VDD through an internal weak pull-up. The Power-up Timer starts after the release of the POR
and BOR.
The device has a noise filter in the MCLR Reset path.
The filter will detect and ignore small pulses. For additional information, refer to Application Note
AN607, Power-up Trouble Shooting (DS00000607).
Note: An internal Reset event (RESET, instr,
BOR, WWDT, POR STK), does not drive
the MCLR pin low.

8.6.2 MCLR DISABLED


When MCLR is disabled, the MCLR becomes
input-only and pin functions such as internal weak
pull-ups are under software control. See Section 15.1
I/O Priorities for more information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 78


PIC18(L)F26/45/46K40
8.12 Start-up Sequence The total time out will vary based on oscillator
configuration and Power-up Timer configuration. See
Upon the release of a POR or BOR, the following must Section 4.0 Oscillator Module (with Fail-Safe
occur before the device will begin executing: Clock Monitor) for more information.
1. Power-up Timer runs to completion (if enabled). The Power-up Timer and oscillator start-up timer run
2. Oscillator start-up timer runs to completion (if independently of MCLR Reset. If MCLR is kept low
required for selected oscillator source). long enough, the Power-up Timer and oscillator
3. MCLR must be released (if enabled). Start-up Timer will expire. Upon bringing MCLR high,
the device will begin execution after 10 FOSC cycles
(see Figure 8-4). This is useful for testing purposes or
to synchronize more than one device operating in
parallel.

FIGURE 8-4: RESET START-UP SEQUENCE

VDD

Internal POR

TPWRT
Power-up Timer

MCLR

TMCLR
Internal RESET

Oscillator Modes
External Crystal
TOST
Oscillator Start-up Timer

Oscillator

FOSC

Internal Oscillator

Oscillator

FOSC

External Clock (EC)

CLKIN

FOSC

2016 Microchip Technology Inc. Preliminary DS40001816C-page 79


PIC18(L)F26/45/46K40
8.13 Determining the Cause of a Reset
Upon any Reset, multiple bits in the STATUS and
PCON0 registers are updated to indicate the cause of
the Reset. Table 8-3 shows the Reset conditions of
these registers.

TABLE 8-3: RESET CONDITION FOR SPECIAL REGISTERS


Program STATUS PCON0
Condition
Counter Register(2,3) Register
Power-on Reset 0 -110 0000 0011 110x
Brown-out Reset 0 -110 0000 0011 11u0
MCLR Reset during normal operation 0 -uuu uuuu uuuu 0uuu
MCLR Reset during Sleep 0 -10u uuuu uuuu 0uuu
WDT Time-out Reset 0 -0uu uuuu uuu0 uuuu
WDT Wake-up from Sleep PC + 2 -00u uuuu uuuu uuuu
WWDT Window Violation Reset 0 -uuu uuuu uu0u uuuu
(1)
Interrupt Wake-up from Sleep PC + 2 -10u 0uuu uuuu uuuu
RESET Instruction Executed 0 -uuu uuuu uuuu u0uu

Stack Overflow Reset (STVREN = 1) 0 -uuu uuuu 1uuu uuuu

Stack Underflow Reset (STVREN = 1) 0 -uuu uuuu u1uu uuuu


Legend: u = unchanged, x = unknown, = unimplemented bit, reads as 0.
Note 1: When the wake-up is due to an interrupt and Global Interrupt Enable bit (GIE) is set the return address is
pushed on the stack and PC is loaded with the corresponding interrupt vector (depending on source, high
or low priority) after execution of PC + 2.
2: If a Status bit is not implemented, that bit will be read as 0.
3: Status bits Z, C, DC are reset by POR/BOR (Register 10-2).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 80


PIC18(L)F26/45/46K40
8.14 Power Control (PCON0) Register
The Power Control (PCON0) register contains flag bits
to differentiate between a:
Brown-out Reset (BOR)
Power-on Reset (POR)
Reset Instruction Reset (RI)
MCLR Reset (RMCLR)
Watchdog Timer Reset (RWDT)
Watchdog Window Violation (WDTWV)
Stack Underflow Reset (STKUNF)
Stack Overflow Reset (STKOVF)
The PCON0 register bits are shown in Register 8-2.
Hardware will change the corresponding register bit
during the Reset process; if the Reset was not caused
by the condition, the bit remains unchanged
(Table 8-3).
Software should reset the bit to the inactive state after
restart (hardware will not reset the bit).
Software may also set any PCON0 bit to the active
state, so that user code may be tested, but no Reset
action will be generated.

TABLE 8-4: SUMMARY OF REGISTERS ASSOCIATED WITH RESETS


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BORCON SBOREN BORRDY 74
PCON0 STKOVF STKUNF WDTWV RWDT RMCLR RI POR BOR 75
STATUS TO PD N OV Z DC C 117
WDTCON0 WDTPS<4:0> SEN 84
WDTCON1 WDTCS<2:0> WINDOW<2:0> 85
Legend: = unimplemented location, read as 0. Shaded cells are not used by Resets.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 81


PIC18(L)F26/45/46K40
9.0 WINDOWED WATCHDOG
TIMER (WWDT)
The Watchdog Timer (WDT) is a system timer that
generates a Reset if the firmware does not issue a
CLRWDT instruction within the time-out period. The
Watchdog Timer is typically used to recover the system
from unexpected events. The Windowed Watchdog
Timer (WWDT) differs in that CLRWDT instructions are
only accepted when they are performed within a
specific window during the time-out period.
The WWDT has the following features:
Selectable clock source
Multiple operating modes
- WWDT is always on
- WWDT is off when in Sleep
- WWDT is controlled by software
- WWDT is always off
Configurable time-out period is from 1 ms to 256s
(nominal)
Configurable window size from 12.5% to 100% of
the time-out period
Multiple Reset conditions

2016 Microchip Technology Inc. Preliminary DS40001816C-page 82


PIC18(L)F26/45/46K40
FIGURE 9-1: WINDOWED WATCHDOG TIMER BLOCK DIAGRAM
Rev. 10-000 162A
1/2/201 4

WWDT
Armed
WDT
Window
Violation
Window Closed
Window
Comparator
CLRWDT Sizes

WINDOW

RESET

Reserved 111
Reserved 110
Reserved 101
R
Reserved 100 18-bit Prescale
Reserved 011 Counter
E
626& 010
MFINTOSC/16 001
LFINTOSC 000

CS

PS

R
5-bit Overflow
WDT Time-out
WDT Counter Latch

WDTE<1:0> = 01
SEN

WDTE<1:0> = 11

WDTE<1:0> = 10
Sleep

2016 Microchip Technology Inc. Preliminary DS40001816C-page 83


PIC18(L)F26/45/46K40
9.1 Register Definitions: Windowed Watchdog Timer Control

REGISTER 9-1: WDTCON0: WATCHDOG TIMER CONTROL REGISTER 0


U-0 U-0 R/W(3)-q/q(2) R/W(3)-q/q(2) R/W(3)-q/q(2) R/W(3)-q/q(2) R/W(3)-q/q(2) R/W-0/0
WDTPS<4:0> SEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-6 Unimplemented: Read as 0


bit 5-1 WDTPS<4:0>: Watchdog Timer Prescale Select bits(1)
Bit Value = Prescale Rate
11111 = Reserved. Results in minimum interval (1:32)



10011 = Reserved. Results in minimum interval (1:32)

10010 = 1:8388608 (223) (Interval 256s nominal)


10001 = 1:4194304 (222) (Interval 128s nominal)
10000 = 1:2097152 (221) (Interval 64s nominal)
01111 = 1:1048576 (220) (Interval 32s nominal)
01110 = 1:524288 (219) (Interval 16s nominal)
01101 = 1:262144 (218) (Interval 8s nominal)
01100 = 1:131072 (217) (Interval 4s nominal)
01011 = 1:65536 (Interval 2s nominal) (Reset value)
01010 = 1:32768 (Interval 1s nominal)
01001 = 1:16384 (Interval 512 ms nominal)
01000 = 1:8192 (Interval 256 ms nominal)
00111 = 1:4096 (Interval 128 ms nominal)
00110 = 1:2048 (Interval 64 ms nominal)
00101 = 1:1024 (Interval 32 ms nominal)
00100 = 1:512 (Interval 16 ms nominal)
00011 = 1:256 (Interval 8 ms nominal)
00010 = 1:128 (Interval 4 ms nominal)
00001 = 1:64 (Interval 2 ms nominal)
00000 = 1:32 (Interval 1 ms nominal)
bit 0 SEN: Software Enable/Disable for Watchdog Timer bit
If WDTE<1:0> = 1x:
This bit is ignored.
If WDTE<1:0> = 01:
1 = WDT is turned on
0 = WDT is turned off
If WDTE<1:0> = 00:
This bit is ignored.

Note 1: Times are approximate. WDT time is based on 31 kHz LFINTOSC.


2: When WDTCPS <4:0> in CONFIG3L = 11111, the Reset value of WDTPS<4:0> is 01011. Otherwise, the
Reset value of WDTPS<4:0> is equal to WDTCPS<4:0> in CONFIG3L.
3: When WDTCPS <4:0> in CONFIG3L 11111, these bits are read-only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 84


PIC18(L)F26/45/46K40

REGISTER 9-2: WDTCON1: WATCHDOG TIMER CONTROL REGISTER 1


U-0 R/W -q/q(1) R/W(3)-q/q(1) R/W(3)-q/q(1)
(3)
U-0 R/W(4)-q/q(2) R/W(4)-q/q(2) R/W(4)-q/q(2)

WDTCS<2:0> WINDOW<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 Unimplemented: Read as 0


bit 6-4 WDTCS<2:0>: Watchdog Timer Clock Select bits
111 = Reserved



010 = Reserved
001 = MFINTOSC 31.25 kHz
000 = LFINTOSC 31 kHz
bit 3 Unimplemented: Read as 0
bit 2-0 WINDOW<2:0>: Watchdog Timer Window Select bits

WINDOW Window delay Window opening


<2:0>
Percent of time Percent of time
111 N/A 100
110 12.5 87.5
101 25 75
100 37.5 62.5
011 50 50
010 62.5 37.5
001 75 25
000 87.5 12.5

Note 1: If WDTCCS <2:0> in CONFIG3H = 111, the Reset value of WDTCS<2:0> is 000.
2: The Reset value of WINDOW<2:0> is determined by the value of WDTCWS<2:0> in the CONFIG3H
register.
3: If WDTCCS<2:0> in CONFIG3H 111, these bits are read-only.
4: If WDTCWS<2:0> in CONFIG3H 111, these bits are read-only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 85


PIC18(L)F26/45/46K40

REGISTER 9-3: WDTPSL: WWDT PRESCALE SELECT LOW BYTE REGISTER (READ-ONLY)
R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0
PSCNT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 PSCNT<7:0>: Prescale Select Low Byte bits(1)

Note 1: The 18-bit WDT prescale value, PSCNT<17:0> includes the WDTPSL, WDTPSH and the lower bits of the
WDTTMR registers. PSCNT<17:0> is intended for debug operations and should be read during normal
operation.

REGISTER 9-4: WDTPSH: WWDT PRESCALE SELECT HIGH BYTE REGISTER (READ-ONLY)
R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0
PSCNT<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 PSCNT<15:8>: Prescale Select High Byte bits(1)

Note 1: The 18-bit WDT prescale value, PSCNT<17:0> includes the WDTPSL, WDTPSH and the lower bits of the
WDTTMR registers. PSCNT<17:0> is intended for debug operations and should be read during normal
operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 86


PIC18(L)F26/45/46K40

REGISTER 9-5: WDTTMR: WDT TIMER REGISTER (READ-ONLY)


R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0 R-0/0
WDTTMR<4:0> STATE PSCNT<17:16>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-3 WDTTMR<4:0>: Watchdog Window Value bits

WDT Window State


WINDOW Open Percent
Closed Open
111 N/A 00000-11111 100
110 00000-00011 00100-11111 87.5
101 00000-00111 01000-11111 75
100 00000-01011 01100-11111 62.5
011 00000-01111 10000-11111 50
010 00000-10011 10100-11111 37.5
001 00000-10111 11000-11111 25
000 00000-11011 11100-11111 12.5

bit 2 STATE: WDT Armed Status bit


1 = WDT is armed
0 = WDT is not armed
bit 1-0 PSCNT<17:16>: Prescale Select Upper Byte bits(1)

Note 1: The 18-bit WDT prescale value, PSCNT<17:0> includes the WDTPSL, WDTPSH and the lower bits of the
WDTTMR registers. PSCNT<17:0> is intended for debug operations and should be read during normal
operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 87


PIC18(L)F26/45/46K40
9.2 Independent Clock Source 9.4 Time-out Period
The WWDT can derive its time base from either the If the WDTCPS<4:0> Configuration bits default to
31 kHz LFINTOSC or 31.25 kHz MFINTOSC internal 5'b11111, then the WDTPS bits of the WDTCON0
oscillators, depending on the value of WDTE<1:0> register set the time-out period from 1 ms to
Configuration bits. 256 seconds (nominal). If any value other than the
If WDTE = 2'b1x, then the clock source will be default value is assigned to WDTCPS<4:0>
enabled depending on the WDTCCS<2:0> Configuration bits, then the timer period will be based
Configuration bits. on the WDTCPS<4:0> bits in the CONFIG3L register.
After a Reset, the default time-out period is 2s.
If WDTE = 2'b01, the SEN bit should be set by
software to enable WWDT, and the clock source is
9.5 Watchdog Window
enabled by the WDTCS bits in the WDTCON1 register.
Time intervals in this chapter are based on a minimum The Windowed Watchdog Timer has an optional
nominal interval of 1 ms. See Section 37.0 Electrical Windowed mode that is controlled by the
Specifications for LFINTOSC and MFINTOSC WDTCWS<2:0> Configuration bits and WINDOW<2:0>
tolerances. bits of the WDTCON1 register. In the Windowed mode,
the CLRWDT instruction must occur within the allowed
window of the WDT period. Any CLRWDT instruction that
9.3 WWDT Operating Modes
occurs outside of this window will trigger a window
The Windowed Watchdog Timer module has four violation and will cause a WWDT Reset, similar to a
operating modes controlled by the WDTE<1:0> bits in WWDT time out. See Figure 9-2 for an example.
Configuration Words. See Table 9-1. The window size is controlled by the WINDOW<2:0>
Configuration bits, or the WINDOW<2:0> bits of
9.3.1 WWDT IS ALWAYS ON WDTCON1, if WDTCWS<2:0> = 111.
When the WDTE bits of Configuration Words are set to The five Most Significant bits of the WDTTMR register
11, the WWDT is always on. are used to determine whether the window is open, as
WWDT protection is active during Sleep. defined by the WINDOW<2:0> bits of the WDTCON1
register.
9.3.2 WWDT IS OFF IN SLEEP
In the event of a window violation, a Reset will be
When the WDTE bits of Configuration Words are set to generated and the WDTWV bit of the PCON0 register
10, the WWDT is on, except in Sleep. will be cleared. This bit is set by a POR or can be set in
WWDT protection is not active during Sleep. firmware.

9.3.3 WWDT CONTROLLED BY 9.6 Clearing the WWDT


SOFTWARE
The WWDT is cleared when any of the following
When the WDTE bits of Configuration Words are set to conditions occur:
01, the WWDT is controlled by the SEN bit of the
Any Reset
WDTCON0 register.
Valid CLRWDT instruction is executed
WWDT protection is unchanged by Sleep. See
Device enters Sleep
Table 9-1 for more details.
Exit Sleep by Interrupt
WWDT is disabled
TABLE 9-1: WWDT OPERATING MODES
Oscillator Start-up Timer (OST) is running
Device WWDT Any write to the WDTCON0 or WDTCON1
WDTE<1:0> SEN
Mode Mode registers
11 X X Active
9.6.1 CLRWDT CONSIDERATIONS
Awake Active
10 X (WINDOWED MODE)
Sleep Disabled
When in Windowed mode, the WWDT must be armed
1 X Active before a CLRWDT instruction will clear the timer. This is
01
0 X Disabled performed by reading the WDTCON0 register.
00 X X Disabled Executing a CLRWDT instruction without performing
such an arming action will trigger a window violation
regardless of whether the window is open or not.
See Table 9-2 for more information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 88


PIC18(L)F26/45/46K40
9.7 Operation During Sleep
When the device enters Sleep, the WWDT is cleared.
If the WWDT is enabled during Sleep, the WWDT
resumes counting. When the device exits Sleep, the
WWDT is cleared again.
The WWDT remains clear until the Oscillator Start-up
Timer (OST) completes, if enabled. See Section
4.3.1.3 Oscillator Start-up Timer (OST) for more
information on the OST.
When a WWDT time-out occurs while the device is in
Sleep, no Reset is generated. Instead, the device
wakes up and resumes operation. The TO and PD bits
in the STATUS register are changed to indicate the
event. The RWDT bit in the PCON0 register can also be
used. See Section 10.0 Memory Organization for
more information.

TABLE 9-2: WWDT CLEARING CONDITIONS


Conditions WWDT
WDTE<1:0> = 00
WDTE<1:0> = 01 and SEN = 0
WDTE<1:0> = 10 and enter Sleep
Cleared
CLRWDT Command
Oscillator Fail Detected
Exit Sleep + System Clock = SOSC, EXTRC, INTOSC, EXTCLK
Exit Sleep + System Clock = XT, HS, LP Cleared until the end of OST
Change INTOSC divider (IRCF bits) Unaffected

FIGURE 9-2: WINDOW PERIOD AND DELAY

Rev. 10-000 163A


11/8/201 3

CLRWDT Instruction
(or other WDT reset)
Window Period

Window Closed Window Open

Window Delay Time-out Event


(window violation can occur)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 89


PIC18(L)F26/45/46K40

TABLE 9-3: SUMMARY OF REGISTERS ASSOCIATED WITH WINDOWED WATCHDOG TIMER


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page

PCON0 STKOVF STKUNF WDTWV RWDT RMCLR RI POR BOR 75


STATUS TO PD Z DC C 117
WDTCON0 WDTPS<4:0> SEN 84
WDTCON1 WDTCS<2:0> WINDOW<2:0> 85
WDTPSL PSCNT<7:0> 86
WDTPSH PSCNT<15:8> 86
WDTTMR WDTTMR<4:0> STATE PSCNT<17:16> 87
Legend: x = unknown, u = unchanged, = unimplemented locations read as 0. Shaded cells are not used by
Windowed Watchdog Timer.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 90


PIC18(L)F26/45/46K40
10.0 MEMORY ORGANIZATION 10.1 Program Memory Organization
There are three types of memory in PIC18 enhanced PIC18 microcontrollers implement a 21-bit program
microcontroller devices: counter, which is capable of addressing a 2 Mbyte
program memory space. Accessing a location between
Program Memory
the upper boundary of the physically implemented
Data RAM memory and the 2 Mbyte address will return all 0s (a
Data EEPROM NOP instruction).
As Harvard architecture devices, the data and program These devices contains the following:
memories use separate buses; this allows for
PIC18(L)F45K40: 32 K bytes of Flash memory, up
concurrent access of the two memory spaces. The data
to 16,384 single-word instructions
EEPROM, for practical purposes, can be regarded as
a peripheral device, since it is addressed and accessed PIC18(L)F26K40, PIC18(L)F46K40: 64 Kbytes of
through a set of control registers. Flash memory, up to 32,768 single-word
instructions
Additional detailed information on the operation of the
Program Flash Memory and Data EEPROM Memory is PIC18 devices have two interrupt vectors. The Reset
provided in Section 11.0 Nonvolatile Memory vector address is at 0000h and the interrupt vector
(NVM) Control. addresses are at 0008h and 0018h.

Note: For memory information on this family of


devices, see Table 10-1 and Table 10-2.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 91


PIC18(L)F26/45/46K40
TABLE 10-1: PROGRAM AND DATA MEMORY MAP

PIC18(L)F25K40 PIC18(L)F26K40 PIC18(L)F27K40


PIC18(L)F24K40
PIC18(L)F45K40 PIC18(L)F46K40 PIC18(L)F47K40
PC<21:0> PC<21:0> PC<21:0> PC<21:0>

Note 1 Stack (31 levels) Stack (31 levels) Stack (31 levels) Stack (31 levels) Note 1

00 0000h Reset Vector Reset Vector Reset Vector Reset Vector 00 0000h

00 0008h Interrupt Vector High Interrupt Vector High Interrupt Vector High Interrupt Vector High 00 0008h

00 0018h Interrupt Vector Low Interrupt Vector Low Interrupt Vector Low Interrupt Vector Low 00 0018h
00 001Ah 00 001Ah
User Flash Memory

(8KW)
00 3FFFh User Flash Memory 00 3FFFh
00 4000h (16KW) 00 4000h
User Flash Memory

(32KW)
00 7FFFh PFM Flash Memory 00 7FFFh
00 8000h (64KW) 00 8000h

00 FFFFh 00 FFFFh
Not present(1)
01 0000h 01 0000h
Not present(1)
01 FFFFh 01 FFFFh
Not present(1)
02 0000h 02 0000h
Not present(1)
1F FFFFh 1F FFFFh
20 0000h 20 0000h
User IDs (8 Words)
20 000Fh 20 000Fh
20 0010h 20 0010h
Reserved
2F FFFFh 2F FFFFh
30 0000h 30 0000h
Configuration Words (6 Words)
30 000Bh 30 000Bh
30 000Ch 30 000Ch
Reserved
30 FFFFh 30 FFFFh
31 0000h DataEEByte0 31 0000h
DataEEByte0

31 00FFh DataEEByte255

Unimplemented
DataEEByte1023
31 03FFh 31 03FFh
31 0400h 31 0400h
Reserved
3F FFFBh 3F FFFBh
3F FFFCh 3F FFFCh
Revision ID (1 Word)(2)
3F FFFDh 3F FFFDh
3F FFFEh 3F FFFEh
Device ID (1 Word)(2)
3F FFFFh 3F FFFFh
Note 1: The addresses do not roll over. The region is read as 0.
2: Device/Revision IDs are hard-coded in silicon.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 92


PIC18(L)F26/45/46K40
TABLE 10-2: MEMORY MAP AND CODE PROTECTION CONTROL
Device
Address
Reg. PIC18(L)F25K40 PIC18(L)F26K40 PIC18(L)F27K40
(from/to) PIC18(L)F24K40
PIC18(L)F45K40 PIC18(L)F46K40 PIC18(L)F47K40

00 0000h Boot Block 1 KW Boot Block 1 KW Boot Block 1 KW Boot Block 1 KW


00 07FFh CP, WRTB, EBTRB CP, WRTB, EBTRB CP WRTB, EBTRB CP WRTB, EBTRB
00 0800h Block 0 Block 0
3 KW 3 KW
00 1FFFh CP, WRT0, EBTR0 CP, WRT0, EBTR0 Block 0 Block 0
7 KW 7 KW
00 2000h Block 1 Block 1 CP, WRT0, EBTR0 CP, WRT0, EBTR0
4 KW 4 KW
00 3FFFh CP, WRT1, EBTR1 CP, WRT1, EBTR1

00 4000h Block 2
4 KW
00 5FFFh CP, WRT2, EBTR2 Block 1 Block 1
8 KW 8 KW
00 6000h Block 3 CP, WRT1, EBTR1 CP, WRT1, EBTR1
4 KW
00 7FFFh CP, WRT3, EBTR3

00 8000h Block 2 Block 2


8 KW 8 KW
PFM CP, WRT2, EBTR2 CP, WRT2, EBTR2
00 BFFFh
00 C000h Block 3 Block 3
8 KW 8 KW
00 FFFFh CP, WRT3, EBTR3 CP, WRT3, EBTR3
Not present
01 0000h Block 4
8 KW
01 3FFFh CP, WRT4, EBTR4
Not present
01 4000h Block 5
8 KW
01 7FFFh CP, WRT5, EBTR5
Not present
01 8000h Block 6
8 KW
01 BFFFh CP, WRT6, EBTR6

01 C000h Block 7
8 KW
01 FFFFh CP, WRT7, EBTR7

30 0000h

6 Words
CONFIG
WRTC

30 000Bh
31 0000h 256 Words
Data 31 00FFh CPD, WRTD 1 KW
EEPROM 31 0100h CPD, WRTD
Unimplemented
31 03FFh

2016 Microchip Technology Inc. Preliminary DS40001816C-page 93


PIC18(L)F26/45/46K40
10.1.1 PROGRAM COUNTER 10.1.2 RETURN ADDRESS STACK
The Program Counter (PC) specifies the address of the The return address stack allows any combination of up
instruction to fetch for execution. The PC is 21 bits wide to 31 program calls and interrupts to occur. The PC is
and is contained in three separate 8-bit registers. The pushed onto the stack when a CALL or RCALL
low byte, known as the PCL register, is both readable instruction is executed or an interrupt is Acknowledged.
and writable. The high byte, or PCH register, contains The PC value is pulled off the stack on a RETURN,
the PC<15:8> bits; it is not directly readable or writable. RETLW or a RETFIE instruction. PCLATU and PCLATH
Updates to the PCH register are performed through the are not affected by any of the RETURN or CALL
PCLATH register. The upper byte is called PCU. This instructions.
register contains the PC<20:16> bits; it is also not The stack operates as a 31-word by 21-bit RAM and a
directly readable or writable. Updates to the PCU 5-bit Stack Pointer, or as a 35-word by 21-bit RAM with
register are performed through the PCLATU register. a 6-bit Stack Pointer in ICD mode. The stack space is
The contents of PCLATH and PCLATU are transferred not part of either program or data space. The Stack
to the program counter by any operation that writes Pointer is readable and writable and the address on the
PCL. Similarly, the upper two bytes of the program top of the stack is readable and writable through the
counter are transferred to PCLATH and PCLATU by an Top-of-Stack (TOS) Special File registers. Data can
operation that reads PCL. This is useful for computed also be pushed to, or popped from the stack, using
offsets to the PC (see Section 10.2.3.1 Computed these registers.
GOTO). A CALL type instruction causes a push onto the stack;
The PC addresses bytes in the program memory. To the Stack Pointer is first incremented and the location
prevent the PC from becoming misaligned with word pointed to by the Stack Pointer is written with the
instructions, the Least Significant bit of PCL is fixed to contents of the PC (already pointing to the instruction
a value of 0. The PC increments by two to address following the CALL). A RETURN type instruction causes
sequential instructions in the program memory. a pop from the stack; the contents of the location
The CALL, RCALL, GOTO and program branch pointed to by the STKPTR are transferred to the PC
instructions write to the program counter directly. For and then the Stack Pointer is decremented.
these instructions, the contents of PCLATH and The Stack Pointer is initialized to 00000 after all
PCLATU are not transferred to the program counter. Resets. There is no RAM associated with the location
corresponding to a Stack Pointer value of 00000; this
is only a Reset value. Status bits in the PCON0 register
indicate if the stack is full or has overflowed or has
underflowed.

10.1.2.1 Top-of-Stack Access


Only the top of the return address stack (TOS) is readable
and writable. A set of three registers, TOSU:TOSH:TOSL,
hold the contents of the stack location pointed to by the
STKPTR register (Figure 10-1). This allows users to
implement a software stack if necessary. After a CALL,
RCALL or interrupt, the software can read the pushed
value by reading the TOSU:TOSH:TOSL registers. These
values can be placed on a user defined software stack. At
return time, the software can return these values to
TOSU:TOSH:TOSL and do a return.
The user must disable the Global Interrupt Enable (GIE)
bits while accessing the stack to prevent inadvertent
stack corruption.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 94


PIC18(L)F26/45/46K40
FIGURE 10-1: RETURN ADDRESS STACK AND ASSOCIATED REGISTERS
Return Address Stack <20:0>

11111
11110
Top-of-Stack Registers 11101 Stack Pointer

TOSU TOSH TOSL STKPTR<4:0>


00h 1Ah 34h 00010
00011
Top-of-Stack 001A34h 00010
000D58h 00001
00000

10.1.2.2 Return Stack Pointer (STKPTR) If STVREN is cleared, the STKUNF bit will be set, but
no Reset will occur.
The STKPTR register (Register 10-1) contains the
Stack Pointer value. The STKOVF (Stack Overflow) When STVREN = 0, STKUNF will be set but no Reset
Status bit and the STKUNF (Stack Underflow) Status bit will occur.
can be accessed using the PCON0 register. The value
of the Stack Pointer can be 0 through 31. On Reset, the
Stack Pointer value will be zero. The user may read and Note: Returning a value of zero to the PC on an
write the Stack Pointer value. This feature can be used underflow has the effect of vectoring the
by a Real-Time Operating System (RTOS) for stack program to the Reset vector, where the
maintenance. After the PC is pushed onto the stack 32 stack conditions can be verified and
times (without popping any values off the stack), the appropriate actions can be taken. This is
STKOVF bit is set. The STKOVF bit is cleared by soft- not the same as a Reset, as the contents
ware or by a POR. The action that takes place when the of the SFRs are not affected.
stack becomes full depends on the state of the
STVREN (Stack Overflow Reset Enable) Configuration 10.1.2.3 PUSH and POP Instructions
bit. (Refer to Section 3.1 Configuration Words for Since the Top-of-Stack is readable and writable, the
a description of the device Configuration bits.) ability to push values onto the stack and pull values off
If STVREN is set (default), a Reset will be generated the stack without disturbing normal program execution
and a Stack Overflow will be indicated by the STKOVF is a desirable feature. The PIC18 instruction set
bit when the 32nd push is initiated. This includes CALL includes two instructions, PUSH and POP, that permit
and CALLW instructions, as well as stacking the return the TOS to be manipulated under software control.
address during an interrupt response. The STKOVF bit TOSU, TOSH and TOSL can be modified to place data
will remain set and the Stack Pointer will be set to zero. or a return address on the stack.

If STVREN is cleared, the STKOVF bit will be set on the The PUSH instruction places the current PC value onto
32nd push and the Stack Pointer will remain at 31 but the stack. This increments the Stack Pointer and loads
no Reset will occur. Any additional pushes will the current PC value onto the stack.
overwrite the 31st push but the STKPTR will remain at The POP instruction discards the current TOS by
31. decrementing the Stack Pointer. The previous value
Setting STKOVF = 1 in software will change the bit, but pushed onto the stack then becomes the TOS value.
will not generate a Reset.
The STKUNF bit is set when a stack pop returns a
value of zero. The STKUNF bit is cleared by software
or by POR. The action that takes place when the stack
becomes full depends on the state of the STVREN
(Stack Overflow Reset Enable) Configuration bit.
(Refer to Section 3.1 Configuration Words for a
description of the device Configuration bits.)
If STVREN is set (default) and the stack has been
popped enough times to unload the stack, the next pop
will return a value of zero to the PC, it will set the
STKUNF bit and a Reset will be generated. This
condition can be generated by the RETURN, RETLW and
RETFIE instructions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 95


PIC18(L)F26/45/46K40
10.2 Register Definitions: Stack Pointer
REGISTER 10-1: STKPTR: STACK POINTER REGISTER
U-0 U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
STKPTR<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented C = Clearable only bit
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-5 Unimplemented: Read as 0


bit 4-0 STKPTR<4:0>: Stack Pointer Location bits

10.2.1 STACK OVERFLOW AND Example 10-1 shows a source code example that uses
UNDERFLOW RESETS the fast register stack during a subroutine call and
return.
Device Resets on Stack Overflow and Stack Underflow
conditions are enabled by setting the STVREN bit in
Configuration Register 4L. When STVREN is set, a Full EXAMPLE 10-1: FAST REGISTER STACK
or Underflow condition will set the appropriate STKOVF CODE EXAMPLE
or STKUNF bit and then cause a device Reset. When CALL SUB1, FAST ;STATUS, WREG, BSR
STVREN is cleared, a Full or Underflow condition will ;SAVED IN FAST REGISTER
set the appropriate STKOVF or STKUNF bit but not ;STACK
cause a device Reset. The STKOVF or STKUNF bits

are cleared by the user software or a Power-on Reset.
SUB1
10.2.2 FAST REGISTER STACK
A fast register stack is provided for the Status, WREG RETURN, FAST ;RESTORE VALUES SAVED
and BSR registers, to provide a fast return option for ;IN FAST REGISTER STACK
interrupts. The stack for each register is only one level
deep and is neither readable nor writable. It is loaded
with the current value of the corresponding register
when the processor vectors for an interrupt. All inter-
rupt sources will push values into the stack registers.
The values in the registers are then loaded back into
their associated registers if the RETFIE, FAST
instruction is used to return from the interrupt.
If both low and high priority interrupts are enabled, the
stack registers cannot be used reliably to return from
low priority interrupts. If a high priority interrupt occurs
while servicing a low priority interrupt, the stack register
values stored by the low priority interrupt will be
overwritten. In these cases, users must save the key
registers by software during a low priority interrupt.
If interrupt priority is not used, all interrupts may use the
fast register stack for returns from interrupt. If no
interrupts are used, the fast register stack can be used
to restore the STATUS, WREG and BSR registers at
the end of a subroutine call. To use the fast register
stack for a subroutine call, a CALL label, FAST
instruction must be executed to save the STATUS,
WREG and BSR registers to the fast register stack. A
RETURN, FAST instruction is then executed to restore
these registers from the fast register stack.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 96


PIC18(L)F26/45/46K40
10.2.3 LOOK-UP TABLES IN PROGRAM
MEMORY
There may be programming situations that require the
creation of data structures, or look-up tables, in
program memory. For PIC18 devices, look-up tables
can be implemented in two ways:
Computed GOTO
Table Reads

10.2.3.1 Computed GOTO


A computed GOTO is accomplished by adding an offset
to the program counter. An example is shown in
Example 10-2.
A look-up table can be formed with an ADDWF PCL
instruction and a group of RETLW nn instructions. The
W register is loaded with an offset into the table before
executing a call to that table. The first instruction of the
called routine is the ADDWF PCL instruction. The next
instruction executed will be one of the RETLW nn
instructions that returns the value nn to the calling
function.
The offset value (in WREG) specifies the number of
bytes that the program counter should advance and
should be multiples of two (LSb = 0).
In this method, only one data byte may be stored in
each instruction location and room on the return
address stack is required.

EXAMPLE 10-2: COMPUTED GOTO USING


AN OFFSET VALUE
MOVF OFFSET, W
CALL TABLE
ORG nn00h
TABLE ADDWF PCL
RETLW nnh
RETLW nnh
RETLW nnh
.
.
.

10.2.3.2 Table Reads and Table Writes


A better method of storing data in program memory
allows two bytes of data to be stored in each instruction
location.
Look-up table data may be stored two bytes per
program word by using table reads and writes. The
Table Pointer (TBLPTR) register specifies the byte
address and the Table Latch (TABLAT) register
contains the data that is read from or written to program
memory. Data is transferred to or from program
memory one byte at a time.
Table read and table write operations are discussed
further in Section 11.1.1 Table Reads and Table
Writes.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 97


PIC18(L)F26/45/46K40
10.3 PIC18 Instruction Cycle 10.3.2 INSTRUCTION FLOW/PIPELINING
An Instruction Cycle consists of four Q cycles: Q1
10.3.1 CLOCKING SCHEME through Q4. The instruction fetch and execute are
The microcontroller clock input, whether from an pipelined in such a manner that a fetch takes one
internal or external source, is internally divided by four instruction cycle, while the decode and execute take
to generate four non-overlapping quadrature clocks another instruction cycle. However, due to the
(Q1, Q2, Q3 and Q4). Internally, the program counter is pipelining, each instruction effectively executes in one
incremented on every Q1; the instruction is fetched cycle. If an instruction causes the program counter to
from the program memory and latched into the change (e.g., GOTO), then two cycles are required to
instruction register during Q4. The instruction is complete the instruction (Example 10-3).
decoded and executed during the following Q1 through A fetch cycle begins with the Program Counter (PC)
Q4. The clocks and instruction execution flow are incrementing in Q1.
shown in Figure 10-2.
In the execution cycle, the fetched instruction is latched
into the Instruction Register (IR) in cycle Q1. This
instruction is then decoded and executed during the
Q2, Q3 and Q4 cycles. Data memory is read during Q2
(operand read) and written during Q4 (destination
write).

FIGURE 10-2: CLOCK/INSTRUCTION CYCLE

Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
OSC1
Q1
Q2 Internal
Q3 Phase
Clock
Q4
PC PC PC + 2 PC + 4
OSC2/CLKOUT
(RC mode)
Execute INST (PC 2)
Fetch INST (PC) Execute INST (PC)
Fetch INST (PC + 2) Execute INST (PC + 2)
Fetch INST (PC + 4)

EXAMPLE 10-3: INSTRUCTION PIPELINE FLOW

TCY0 TCY1 TCY2 TCY3 TCY4 TCY5


1. MOVLW 55h Fetch 1 Execute 1
2. MOVWF PORTB Fetch 2 Execute 2
3. BRA SUB_1 Fetch 3 Execute 3
4. BSF PORTA, BIT3 (Forced NOP) Fetch 4 Flush (NOP)
5. Instruction @ address SUB_1 Fetch SUB_1 Execute SUB_1

All instructions are single cycle, except for any program branches. These take two cycles since the fetch instruction
is flushed from the pipeline while the new instruction is being fetched and then executed.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 98


PIC18(L)F26/45/46K40
10.3.3 INSTRUCTIONS IN PROGRAM 10.3.4 TWO-WORD INSTRUCTIONS
MEMORY The standard PIC18 instruction set has four two-word
The program memory is addressed in bytes. instructions: CALL, MOVFF, GOTO and LFSR. In all
Instructions are stored as either two bytes or four bytes cases, the second word of the instruction always has
in program memory. The Least Significant Byte of an 1111 as its four Most Significant bits; the other 12 bits
instruction word is always stored in a program memory are literal data, usually a data memory address.
location with an even address (LSb = 0). To maintain The use of 1111 in the 4 MSbs of an instruction
alignment with instruction boundaries, the PC specifies a special form of NOP. If the instruction is
increments in steps of two and the LSb will always read executed in proper sequence immediately after the
0 (see Section 10.1.1 Program Counter). first word the data in the second word is accessed
Figure 10-3 shows an example of how instruction and used by the instruction sequence. If the first word
words are stored in the program memory. is skipped for some reason and the second word is
executed by itself, a NOP is executed instead. This is
The CALL and GOTO instructions have the absolute
necessary for cases when the two-word instruction is
program memory address embedded into the
preceded by a conditional instruction that changes the
instruction. Since instructions are always stored on word
PC. Example 10-4 shows how this works.
boundaries, the data contained in the instruction is a
word address. The word address is written to PC<20:1>, Note: See Section 10.8 PIC18 Instruction
which accesses the desired byte address in program Execution and the Extended Instruc-
memory. Instruction #2 in Figure 10-3 shows how the tion Set for information on two-word
instruction GOTO 0006h is encoded in the program instructions in the extended instruction set.
memory. Program branch instructions, which encode a
relative address offset, operate in the same manner. The
offset value stored in a branch instruction represents the
number of single-word instructions that the PC will be
offset by. Section 35.0 Instruction Set Summary
provides further details of the instruction set.

FIGURE 10-3: INSTRUCTIONS IN PROGRAM MEMORY


Word Address
LSB = 1 LSB = 0
Program Memory 000000h
Byte Locations 000002h
000004h
000006h
Instruction 1: MOVLW 055h 0Fh 55h 000008h
Instruction 2: GOTO 0006h EFh 03h 00000Ah
F0h 00h 00000Ch
Instruction 3: MOVFF 123h, 456h C1h 23h 00000Eh
F4h 56h 000010h
000012h
000014h

EXAMPLE 10-4: TWO-WORD INSTRUCTIONS


CASE 1:
Object Code Source Code
0110 0110 0000 0000 TSTFSZ REG1 ; is RAM location 0?
1100 0001 0010 0011 MOVFF REG1, REG2 ; No, skip this word
1111 0100 0101 0110 ; Execute this word as a NOP
0010 0100 0000 0000 ADDWF REG3 ; continue code
CASE 2:
Object Code Source Code
0110 0110 0000 0000 TSTFSZ REG1 ; is RAM location 0?
1100 0001 0010 0011 MOVFF REG1, REG2 ; Yes, execute this word
1111 0100 0101 0110 ; 2nd word of instruction
0010 0100 0000 0000 ADDWF REG3 ; continue code

2016 Microchip Technology Inc. Preliminary DS40001816C-page 99


PIC18(L)F26/45/46K40
10.4 Data Memory Organization 10.4.1 BANK SELECT REGISTER (BSR)
Large areas of data memory require an efficient
Note: The operation of some aspects of data
addressing scheme to make rapid access to any
memory are changed when the PIC18
address possible. Ideally, this means that an entire
extended instruction set is enabled. See
address does not need to be provided for each read or
Section 10.7 Data Memory and the
write operation. For PIC18 devices, this is accom-
Extended Instruction Set for more
plished with a RAM banking scheme. This divides the
information.
memory space into 16 contiguous banks of 256 bytes.
The data memory in PIC18 devices is implemented as Depending on the instruction, each location can be
static RAM. Each register in the data memory has a addressed directly by its full 12-bit address, or an 8-bit
12-bit address, allowing up to 4096 bytes of data low-order address and a 4-bit Bank Pointer.
memory. The memory space is divided into as many as Most instructions in the PIC18 instruction set make use
16 banks that contain 256 bytes each. Figure 10-4 of the Bank Pointer, known as the Bank Select Register
shows the data memory organization for the (BSR). This SFR holds the four Most Significant bits of
PIC18(L)F2x/4xK40 devices. a locations address; the instruction itself includes the
The data memory contains Special Function Registers eight Least Significant bits. Only the four lower bits of
(SFRs) and General Purpose Registers (GPRs). The the BSR are implemented (BSR<3:0>). The upper four
SFRs are used for control and status of the controller bits are unused; they will always read 0 and cannot be
and peripheral functions, while GPRs are used for data written to. The BSR can be loaded directly by using the
storage and scratchpad operations in the users MOVLB instruction.
application. Any read of an unimplemented location will The value of the BSR indicates the bank in data
read as 0s. memory; the eight bits in the instruction show the
The instruction set and architecture allow operations location in the bank and can be thought of as an offset
across all banks. The entire data memory may be from the banks lower boundary. The relationship
accessed by Direct, Indirect or Indexed Addressing between the BSRs value and the bank division in data
modes. Addressing modes are discussed later in this memory is shown in Figure 10-4.
subsection. Since up to 16 registers may share the same low-order
To ensure that commonly used registers (SFRs and address, the user must always be careful to ensure that
select GPRs) can be accessed in a single cycle, PIC18 the proper bank is selected before performing a data
devices implement an Access Bank. This is a 256-byte read or write. For example, writing what should be
memory space that provides fast access to SFRs and program data to an 8-bit address of F9h while the BSR
the lower portion of GPR Bank 0 without using the Bank is 0Fh will end up resetting the program counter.
Select Register (BSR). Section 10.4.2 Access While any bank can be selected, only those banks that
Bank provides a detailed description of the Access are actually implemented can be read or written to.
RAM. Writes to unimplemented banks are ignored, while
reads from unimplemented banks will return 0s. Even
so, the STATUS register will still be affected as if the
operation was successful. The data memory maps in
Figure 10-4 indicate which banks are implemented.
In the core PIC18 instruction set, only the MOVFF
instruction fully specifies the 12-bit address of the
source and target registers. This instruction ignores the
BSR completely when it executes. All other instructions
include only the low-order address as an operand and
must use either the BSR or the Access Bank to locate
their target registers.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 100


2016 Microchip Technology Inc.

FIGURE 10-4: DATA MEMORY MAP FOR PIC18(L)F2X/4XK40 DEVICES

Bank BSR<3:0> addr<7:0> PIC18(L)F26K40 Address


PIC18(L)F25K40 PIC18(L)F27K40 addr<11:0>
PIC18(L)F24K40
PIC18(L)F45K40 PIC18(L)F46K40
PIC18(L)F47K40
00h Access RAM Access RAM Access RAM 000h
05Fh
Bank 0 0000
GPR GPR GPR 060h
FFh 0FFh
00h 100h
Bank 1 0001
FFh

00h
Bank 2 0010 GPR GPR GPR
FFh

00h
Bank 3 0011
FFh 3FFh
Preliminary

00h 400h
Virtual Bank
0100
Banks
GPR GPR Access RAM 00h
4 to 7
5Fh

PIC18(L)F26/45/46K40
0111
SFR 60h
FFh 7FFh
Unimplemented FFh
00h 800h

1000
Banks
Unimplemented GPR
8 to 13
1101

FFh DFFh
00h Unimplemented(1) Unimplemented(1) GPR(1) E00h
Bank 14 1110
FFh SFR(1) SFR(1) SFR(1) EFFh
00h F00h
F5Fh
Bank 15 1111 SFR SFR SFR
F60h
DS40001816C-page 101

FFh FFFh

Note 1: It depends on the number of SFRs. Refer to Table 10-3 and Table 10-4.
PIC18(L)F26/45/46K40
FIGURE 10-5: USE OF THE BANK SELECT REGISTER (DIRECT ADDRESSING)

BSR(1) Data Memory From Opcode(2)


7 0 000h 00h 7 0
0 0 0 0 0 0 1 0 Bank 0 1 1 1 1 1 1 1 1
FFh
100h 00h
Bank 1
Bank Select(2) 200h FFh
00h
Bank 2
300h FFh
00h

Bank 3
through
Bank 13

FFh
E00h
00h
Bank 14
F00h FFh
00h
Bank 15
FFFh FFh

Note 1: The Access RAM bit of the instruction can be used to force an override of the selected bank (BSR<3:0>) to
the registers of the Access Bank.
2: The MOVFF instruction embeds the entire 12-bit address in the instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 102


PIC18(L)F26/45/46K40
10.4.2 ACCESS BANK 10.4.3 GENERAL PURPOSE REGISTER
While the use of the BSR with an embedded 8-bit FILE
address allows users to address the entire range of PIC18 devices may have banked memory in the GPR
data memory, it also means that the user must always area. This is data RAM, which is available for use by all
ensure that the correct bank is selected. Otherwise, instructions. GPRs start at the bottom of Bank 0
data may be read from or written to the wrong location. (address 000h) and grow upwards towards the bottom of
This can be disastrous if a GPR is the intended target the SFR area. GPRs are not initialized by a Power-on
of an operation, but an SFR is written to instead. Reset and are unchanged on all other Resets.
Verifying and/or changing the BSR for each read or
write to data memory can become very inefficient. 10.4.4 SPECIAL FUNCTION REGISTERS
To streamline access for the most commonly used data The Special Function Registers (SFRs) are registers
memory locations, the data memory is configured with used by the CPU and peripheral modules for controlling
an Access Bank, which allows users to access a the desired operation of the device. These registers are
mapped block of memory without specifying a BSR. implemented as static RAM. SFRs start at the top of
The Access Bank consists of the first 96 bytes of mem- data memory (FFFh) and extend downward to occupy
ory (00h-5Fh) in Bank 0 and the last 160 bytes of mem- the top portion of Bank 15 (F38h to FFFh). A list of
ory (60h-FFh) in Block 15. The lower half is known as these registers is given in Table 10-3 and Table 10-4.
the Access RAM and is composed of GPRs. This The SFRs can be classified into two sets: those
upper half is also where the devices SFRs are associated with the core device functionality (ALU,
mapped. These two areas are mapped contiguously in Resets and interrupts) and those related to the
the Access Bank and can be addressed in a linear peripheral functions. The Reset and Interrupt registers
fashion by an 8-bit address (Figure 10-4). are described in their respective chapters, while the
The Access Bank is used by core PIC18 instructions ALUs STATUS register is described later in this
that include the Access RAM bit (the a parameter in section. Registers related to the operation of a
the instruction). When a is equal to 1, the instruction peripheral feature are described in the chapter for that
uses the BSR and the 8-bit address included in the peripheral.
opcode for the data memory address. When a is 0, The SFRs are typically distributed among the
however, the instruction is forced to use the Access peripherals whose functions they control. Unused SFR
Bank address map; the current value of the BSR is locations are unimplemented and read as 0s.
ignored entirely.
Using this forced addressing allows the instruction to
operate on a data address in a single cycle, without
updating the BSR first. For 8-bit addresses of 60h and
above, this means that users can evaluate and operate
on SFRs more efficiently. The Access RAM below 60h
is a good place for data values that the user might need
to access rapidly, such as immediate computational
results or common program variables. Access RAM
also allows for faster and more code efficient context
saving and switching of variables.
The mapping of the Access Bank is slightly different
when the extended instruction set is enabled (XINST
Configuration bit = 1). This is discussed in more detail
in Section 10.7.3 Mapping the Access Bank in
Indexed Literal Offset Mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 103


PIC18(L)F26/45/46K40

TABLE 10-3: SPECIAL FUNCTION REGISTER MAP FOR PIC18(L)F26/45/46K40 DEVICES


Address Name Address Name Address Name Address Name
FFFh TOSU FD7h PCON0 FAFh T6TMR F87h LATE(2)
FFEh TOSH FD6h T0CON1 FAEh CCPTMRS F86h LATD(2)
FFDh TOSL FD5h T0CON0 FADh CCP1CAP F85h LATC
FFCh STKPTR FD4h TMR0H FACh CCP1CON F84h LATB
FFBh PCLATU FD3h TMR0L FABh CCP1H F83h LATA
FFAh PCLATH FD2h T1CLK FAAh CCP1L F82h NVMCON2
FF9h PCL FD1h T1GATE FA9h CCP2CAP F81h NVMCON1
FF8h TBLPTRU FD0h T1GCON FA8h CCP2CON F80h NVMDAT
FF7h TBLPTRH FCFh T1CON FA7h CCP2H F7Fh NVMADRH(3)
FF6h TBLPTRL FCEh TMR1H FA6h CCP2L F7Eh NVMADRL
FF5h TABLAT FCDh TMR1L FA5h PWM3CON F7Dh CRCCON1
FF4h PRODH FCCh T3CLK FA4h PWM3DCH F7Ch CRCCON0
FF3h PRODL FCBh T3GATE FA3h PWM3DCL F7Bh CRCXORH
FF2h INTCON FCAh T3GCON FA2h PWM4CON F7Ah CRCXORL
FF1h FC9h T3CON FA1h PWM4DCH F79h CRCSHIFTH
FF0h FC8h TMR3H FA0h PWM4DCL F78h CRCSHIFTL
(1)
FEFh INDF0 FC7h TMR3L F9Fh BAUD1CON F77h CRCACCH
FEEh POSTINC0(1) FC6h T5CLK F9Eh TX1STA F76h CRCACCL
FEDh POSTDEC0(1) FC5h T5GATE F9Dh RC1STA F75h CRCDATH
FECh PREINC0(1) FC4h T5GCON F9Ch SP1BRGH F74h CRCDATL
FEBh PLUSW0(1) FC3h T5CON F9Bh SP1BRGL F73h ADFLTRH
FEAh FSR0H FC2h TMR5H F9Ah TX1REG F72h ADFLTRL
FE9h FSR0L FC1h TMR5L F99h RC1REG F71h ADACCH
FE8h WREG FC0h T2RST F98h SSP1CON3 F70h ADACCL
(1)
FE7h INDF1 FBFh T2CLKCON F97h SSP1CON2 F6Fh ADERRH
FE6h POSTINC1(1) FBEh T2HLT F96h SSP1CON1 F6Eh ADERRL
FE5h POSTDEC1(1) FBDh T2CON F95h SSP1STAT F6Dh ADUTHH
FE4h PREINC1(1) FBCh T2PR F94h SSP1MSK F6Ch ADUTHL
(1)
FE3h PLUSW1 FBBh T2TMR F93h SSP1ADD F6Bh ADLTHH
FE2h FSR1H FBAh T4RST F92h SSP1BUF F6Ah ADLTHL
FE1h FSR1L FB9h T4CLKCON F91h PORTE F69h ADSTPTH
FE0h BSR FB8h T4HLT F90h PORTD(2) F68h ADSTPTL
FDFh INDF2(1) FB7h T4CON F8Fh PORTC F67h ADCNT
FDEh POSTINC2(1) FB6h T4PR F8Eh PORTB F66h ADRPT
FDDh POSTDEC2(1) FB5h T4TMR F8Dh PORTA F65h ADSTAT
FDCh PREINC2 (1) FB4h T6RST F8Ch TRISE(2) F64h ADRESH
(1) (2)
FDBh PLUSW2 FB3h T6CLKCON F8Bh TRISD F63h ADRESL
FDAh FSR2H FB2h T6HLT F8Ah TRISC F62h ADPREVH
FD9h FSR2L FB1h T6CON F89h TRISB F61h ADPREVL
FD8h STATUS FB0h T6PR F88h TRISA F60h ADCON0
Note 1: This is not a physical register.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 104


PIC18(L)F26/45/46K40

TABLE 10-4: SPECIAL FUNCTION REGISTER MAP FOR PIC18(L)F26/45/46K40 DEVICES


Address Name Address Name Address Name Address Name Address Name
(1)
F5Fh ADPCH F31h FVRCON F03h RD4PPS ED5h WDTPSH EA7h T3CKIPPS
F5Eh ADPRE F30h HLVDCON1 F02h RD3PPS(1) ED4h WDTPSL EA6h T1GPPS
F5Dh ADCAP F2Fh HLVDCON0 F01h RD2PPS(1) ED3h WDTCON1 EA5h T1CKIPPS
F5Ch ADACQ F2Eh ANSELE(2) F00h RD1PPS(2) ED2h WDTCON0 EA4h T0CKIPPS
F5Bh ADCON3 F2Dh WPUE EFFh RD0PPS(2) ED1h PIR7 EA3h INT2PPS
F5Ah ADCON2 F2Ch ODCONE(2) EFEh RC7PPS ED0h PIR6 EA2h INT1PPS
F59h ADCON1 F2Bh SLRCONE(2) EFDh RC6PPS ECFh PIR5 EA1h INT0PPS
F58h ADREF F2Ah INLVLE EFCh RC5PPS ECEh PIR4 EA0h PPSLOCK
F57h ADCLK F29h IOCEP EFBh RC4PPS ECDh PIR3 E9Fh BAUD2CON
F56h ADACT F28h IOCEN EFAh RC3PPS ECCh PIR2 E9Eh TX2STA
F55h MDCARH F27h IOCEF EF9h RC2PPS ECBh PIR1 E9Dh RC2STA
F54h MDCARL F26h ANSELD(2) EF8h RC1PPS ECAh PIR0 E9Ch SP2BRGH
F53h MDSRC F25h WPUD(2) EF7h RC0PPS EC9h PIE7 E9Bh SP2BRGL
F52h MDCON1 F24h ODCOND(2) EF6h RB7PPS EC8h PIE6 E9Ah TX2REG
F51h MDCON0 F23h SLRCOND(2) EF5h RB6PPS EC7h PIE5 E99h RC2REG
F50h SCANDTRIG F22h INLVLD(2) EF4h RB5PPS EC6h PIE4 E98h SSP2CON3
F4Fh SCANCON0 F21h ANSELC EF3h RB4PPS EC5h PIE3 E97h SSP2CON2
F4Eh SCANHADRU F20h WPUC EF2h RB3PPS EC4h PIE2 E96h SSP2CON1
F4Dh SCANHADRH F1Fh ODCONC EF1h RB2PPS EC3h PIE1 E95h SSP2STAT
F4Ch SCANHADRL F1Eh SLRCONC EF0h RB1PPS EC2h PIE0 E94h SSP2MSK
F4Bh SCANLADRU F1Dh INLVLC EEFh RB0PPS EC1h IPR7 E93h SSP2ADD
F4Ah SCANLADRH F1Ch IOCCP EEEh RA7PPS EC0h IPR6 E92h SSP2BUF
F49h SCANLADRL F1Bh IOCCN EEDh RA6PPS EBFh IPR5 E91h SSP2SSPPS
F48h CWG1STR F1Ah IOCCF EECh RA5PPS EBEh IPR4 E90h SSP2DATPPS
F47h CWG1AS1 F19h ANSELB EEBh RA4PPS EBDh IPR3 E8Fh SSP2CLKPPS
F46h CWG1AS0 F18h WPUB EEAh RA3PPS EBCh IPR2 E8Eh TX2PPS
F45h CWG1CON1 F17h ODCONB EE9h RA2PPS EBBh IPR1 E8Dh RX2PPS
F44h CWG1CON0 F16h SLRCONB EE8h RA1PPS EBAh IPR0
F43h CWG1DBF F15h INLVLB EE7h RA0PPS EB9h SSP1SSPPS
F42h CWG1DBR F14h IOCBP EE6h PMD5 EB8h SSP1DATPPS
F41h CWG1ISM F13h IOCBN EE5h PMD4 EB7h SSP1CLKPPS
F40h CWG1CLKCON F12h IOCBF EE4h PMD3 EB6h TX1PPS
F3Fh CLKRCLK F11h ANSELA EE3h PMD2 EB5h RX1PPS
F3Eh CLKRCON F10h WPUA EE2h PMD1 EB4h MDSRCPPS
F3Dh CMOUT F0Fh ODCONA EE1h PMD0 EB3h MDCARHPPS
F3Ch CM1PCH F0Eh SLRCONA EE0h BORCON EB2h MDCARLPPS
F3Bh CM1NCH F0Dh INLVLA EDFh VREGCON(1) EB1h CWGINPPS
F3Ah CM1CON1 F0Ch IOCAP EDEh OSCFRQ EB0h CCP2PPS
F39h CM1CON0 F0Bh IOCAN EDDh OSCTUNE EAFh CCP1PPS
F38h CM2PCH F0Ah IOCAF EDCh OSCEN EAEh ADACTPPS
F37h CM2NCH F09h RE2PPS(2) EDBh OSCSTAT EADh T6INPPS
F36h CM2CON1 F08h RE1PPS(2) EDAh OSCCON3 EACh T4INPPS
F35h CM2CON0 F07h RE0PPS(2) ED9h OSCCON2 EABh T2INPPS
F34h DAC1CON1 F06h RD7PPS(2) ED8h OSCCON1 EAAh T5GPPS
F33h DAC1CON0 F05h RD6PPS(2) ED7h CPUDOZE EA9h T5CKIPPS
F32h ZCDCON F04h RD5PPS(2) ED6h WDTTMR EA8h T3GPPS
Note 1: Not available on LF parts
2: Not available on PIC18(L)F26K40 (28-pin variants).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 105


PIC18(L)F26/45/46K40

TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES


Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

FFFh TOSU Top of Stack Upper byte (TOS<20:16>) ---xxxxx

FFEh TOSH Top of Stack High byte (TOS<15:8>) xxxxxxxx

FFDh TOSL Top of Stack Low byte (TOS<7:0>) xxxxxxxx

FFCh STKPTR STKPTR<4:0> --000000

FFBh PCLATU Holding Register for PC<20:16> ---00000

FFAh PCLATH Holding Register for PC<15:8> 00000000

FF9h PCL PC Low byte (PC<7:0>) 00000000

FF8h TBLPTRU Program Memory Table Pointer (TBLPTR<21:16>) --000000

FF7h TBLPTRH Program Memory Table Pointer (TBLPTR<15:8>) 00000000

FF6h TBLPTRL Program Memory Table Pointer (TBLPTR<7:0>) 00000000

FF5h TABLAT TABLAT 00000000

FF4h PRODH Product Register High byte xxxxxxxx

FF3h PRODL Product Register Low byte xxxxxxxx

FF2h INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 000--111

FF1h Unimplemented

FF0h Unimplemented

FEFh INDF0 Uses contents of FSR0 to address data memory value of FSR0 not changed (not a physical register) --------

FEEh POSTINC0 Uses contents of FSR0 to address data memory value of FSR0 post-incremented (not a physical register) --------

FEDh POSTDEC0 Uses contents of FSR0 to address data memory value of FSR0 post-decremented (not a physical register) --------

FECh PREINC0 Uses contents of FSR0 to address data memory value of FSR0 pre-incremented (not a physical register) --------

FEBh PLUSW0 Uses contents of FSR0 to address data memory value of FSR0 pre-incremented (not a physical register) value of --------
FSR0 offset by W
FEAh FSR0H Indirect Data Memory Address Pointer 0 High ----xxxx

FE9h FSR0L Indirect Data Memory Address Pointer 0 Low xxxxxxxx

FE8h WREG Working Register xxxxxxxx

FE7h INDF1 Uses contents of FSR0 to address data memory value of FSR1 not changed (not a physical register) --------

FE6h POSTINC1 Uses contents of FSR0 to address data memory value of FSR1 post-incremented (not a physical register) --------

FE5h POSTDEC1 Uses contents of FSR0 to address data memory value of FSR1 post-decremented (not a physical register) --------

FE4h PREINC1 Uses contents of FSR0 to address data memory value of FSR1 pre-incremented (not a physical register) --------

FE3h PLUSW1 Uses contents of FSR0 to address data memory value of FSR1 pre-incremented (not a physical register) value of --------
FSR0 offset by W
Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition
Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 106


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

FE2h FSR1H Indirect Data Memory Address Pointer 1 High ----xxxx

FE1h FSR1L Indirect Data Memory Address Pointer 1 Low xxxxxxxx

FE0h BSR Bank Select Register ----0000

FDFh INDF2 Uses contents of FSR0 to address data memory value of FSR2 not changed (not a physical register) --------

FDEh POSTINC2 Uses contents of FSR0 to address data memory value of FSR2 post-incremented (not a physical register) --------

FDDh POSTDEC2 Uses contents of FSR0 to address data memory value of FSR2 post-decremented (not a physical register) --------

FDCh PREINC2 Uses contents of FSR0 to address data memory value of FSR2 pre-incremented (not a physical register) --------

FDBh PLUSW2 Uses contents of FSR0 to address data memory value of FSR2 pre-incremented (not a physical register) value of --------
FSR0 offset by W
FDAh FSR2H Indirect Data Memory Address Pointer 2 High ----xxxx

FD9h FSR2L Indirect Data Memory Address Pointer 2 Low xxxxxxxx

FD8h STATUS TO PD N OV Z DC C -1100000

FD7h PCON0 STKOVF STKUNF WDTWV RWDT RMCLR RI POR BOR 0011110q

FD6h T0CON1 T0CS<2:0> T0ASYNC T0CKPS<3:0> 00000000

FD5h T0CON0 T0EN T0OUT T016BIT T0OUTPS<3:0> 0-000000

FD4h TMR0H Holding Register for the Most Significant Byte of the 16-bit TMR0 Register 11111111

FD3h TMR0L Holding Register for the Least Significant Byte of the 16-bit TMR0 Register 00000000

FD2h T1CLK CS<3:0> ----0000

FD1h T1GATE GSS<3:0> ----0000

FD0h T1GCON GE GPOL GTM GSPM GO/DONE GVAL 00000x--

FCFh T1CON CKPS<1:0> SYNC RD16 ON --00-000

FCEh TMR1H Holding Register for the Most Significant Byte of the 16-bit TMR1 Register 00000000

FCDh TMR1L Holding Register for the Least Significant Byte of the 16-bit TMR1 Register 00000000

FCCh T3CLK CS<3:0> ----0000

FCBh T3GATE GSS<3:0> ----0000

FCAh T3GCON GE GPOL GTM GSPM GO/DONE GVAL 00000x--

FC9h T3CON CKPS<1:0> SYNC RD16 ON --00-000

FC8h TMR3H Holding Register for the Most Significant Byte of the 16-bit TMR3 Register 00000000

FC7h TMR3L Holding Register for the Least Significant Byte of the 16-bit TMR3 Register 00000000

FC6h TMR5CLK CS<3:0> ----0000

FC5h T5GATE GSS<3:0> ----0000

FC4h T5GCON GE GPOL GTM GSPM GO/DONE GVAL 00000x--

FC3h T5CON CKPS<1:0> SYNC RD16 ON --00-000

FC2h TMR5H Holding Register for the Most Significant Byte of the 16-bit TMR5 Register 00000000

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 107


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

FC1h TMR5L Holding Register for the Least Significant Byte of the 16-bit TMR5 Register 00000000

FC0h T2RST RSEL<3:0> ----0000

FBFh T2CLKCON CS<3:0> ----0000

FBEh T2HLT PSYNC CPOL CSYNC MODE<4:0> 00000000


FBDh T2CON ON CKPS<2:0> OUTPS<3:0> 00000000

FBCh T2PR TMR2 Period Register 11111111

FBBh T2TMR Holding Register for the 8-bit TMR2 Register 00000000

FBAh T4RST RSEL<3:0> ----0000

FB9h T4CLKCON CS<3:0> ----0000

FB8h T4HLT PSYNC CPOL CSYNC MODE<4:0> 00000000

FB7h T4CON ON CKPS<2:0> OUTPS<3:0> 00000000

FB6h T4PR TMR4 Period Register 11111111

FB5h T4TMR Holding Register for the 8-bit TMR4 Register 00000000

FB4h T6RST RSEL<3:0> ----0000

FB3h T6CLKCON CS<3:0> ----0000

FB2h T6HLT PSYNC CPOL CSYNC MODE<4:0> 00000000

FB1h T6CON ON CKPS<2:0> OUTPS<3:0> 00000000

FB0h T6PR TMR6 Period Register 11111111

FAFh T6TMR Holding Register for the 8-bit TMR6 Register 00000000

FAEh CCPTMRS P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0> 01010101

FADh CCP1CAP CTS<1:0> ------00

FACh CCP1CON EN OUT FMT MODE<3:0> 0-000000

FABh CCPR1H Capture/Compare/PWM Register 1 (MSB) xxxxxxxx

FAAh CCPR1L Capture/Compare/PWM Register 1 (LSB) xxxxxxxx

FA9h CCP2CAP CTS<1:0> ------00

FA8h CCP2CON EN OUT FMT MODE<3:0> 0-000000

FA7h CCPR2H Capture/Compare/PWM Register 2 (MSB) xxxxxxxx

FA6h CCPR2L Capture/Compare/PWM Register 2 (LSB) xxxxxxxx

FA5h PWM3CON EN OUT POL 0-00----

FA4h PWM3DCH DC<7:0> xxxxxxxx

FA3h PWM3DCL DC<9:8> xx------

FA2h PWM4CON EN OUT POL 0-00----

FA1h PWM4DCH DC7:0> xxxxxxxx

FA0h PWM4DCL DC<9:8> xx------

F9Fh BAUD1CON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 01-00-00

F9Eh TX1STA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 00000010

F9Dh RC1STA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 00000000

F9Ch SP1BRGH EUSART1 Baud Rate Generator, High Byte 00000000

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 108


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

F9Bh SP1BRGL EUSART1 Baud Rate Generator, Low Byte 00000000

F9Ah TX1REG EUSART1 Transmit Register 00000000

F99h RC1REG EUSART1 Receive Register 00000000

F98h SSP1CON3 ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN 00000000

F97h SSP1CON2 GCEN ACKSTAT ACKDT ACKEN RCEN PEN RSEN SEN 00000000

F96h SSP1CON1 WCOL SSPOV SSPEN CKP SSPM<3:0> 00000000

F95h SSP1STAT SMP CKE D/A P S R/W UA BF 00000000

F94h SSP1MSK MSK<7:0> 11111111

F93h SSP1ADD ADD<7:0> 00000000

F92h SSP1BUF BUF<7:0> xxxxxxxx


(2) (2) (2)
F91h PORTE RE0 RE2 RE1 RE1 ----xxxx

F90h PORTD(2) RD7 RD6 RD5 RD4 RD3 RD2 RD1 RD0 xxxxxxxx

F8Fh PORTC RC7 RC6 RC5 RC4 RC3 RC2 RC1 RC0 xxxxxxxx

F8Eh PORTB RB7 RB6 RB5 RB4 RB3 RB2 RB1 RB0 xxxxxxxx

F8Dh PORTA RA7 RA6 RA5 RA4 RA3 RA2 RA1 RA0 xxxxxxxx

F8Ch TRISE TRISE2(2) TRISE1(2) TRISE0 -----111

F8Bh TRISD(2) TRISD7 TRISD6 TRISD5 TRISD4 TRISD3 TRISD2 TRISD1 TRISD0 11111111

F8Ah TRISC TRISC7 TRISC6 TRISC5 TRISC4 TRISC3 TRISC2 TRISC1 TRISC0 11111111

F89h TRISB TRISB7 TRISB6 TRISB5 TRISB4 TRISB3 TRISB2 TRISB1 TRISB0 11111111

F88h TRISA TRISA7 TRISA6 TRISA5 TRISA4 TRISA3 TRISA2 TRISA1 TRISA0 11111111
(2) (2)
F87h LATE LATE2 LATE1 LATE0 -----xxx
(2)
F86h LATD LATD7 LATD6 LATD5 LATD4 LATD3 LATD2 LATD1 LATD0 xxxxxxxx

F85h LATC LATC7 LATC6 LATC5 LATC4 LATC3 LATC2 LATC1 LATC0 xxxxxxxx

F84h LATB LATB7 LATB6 LATB5 LATB4 LATB3 LATB2 LATB1 LATB0 xxxxxxxx

F83h LATA LATA7 LATA6 LATA5 LATA4 LATA3 LATA2 LATA1 LATA0 xxxxxxxx

F82h NVMCON2 NVMCON2<7:0> 00000000

F81h NVMCON1 NVMREG<1:0> FREE WRERR WREN WR RD 00-0x000

F80h NVMDAT NVMDAT<7:0> 00000000


(3)
F7Fh NVMADRH NVMADR<9:8> ------xx

F7Eh NVMADRL NVMADR<7:0> xxxxxxxx

F7Dh CRCCON1 DLEN<3:0> PLEN<3:0> 00000000

F7Ch CRCCON0 EN GO BUSY ACCM SHIFTM FULL 0000--00

F7Bh CRCXORH X<15:8> xxxxxxxx

F7Ah CRCXORL X<7:1> xxxxxxx0

F79h CRCSHIFTH SHIFT<15:8> 00000000

F78h CRCSHIFTL SHIFT<7:0> 00000000

F77h CRCACCH ACC<15:8> 00000000

F76h CRCACCL ACC<7:0> 00000000

F75h CRCDATH DATA<15:8> xxxxxxxx

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 109


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

F74h CRCDATL DATA<7:0> xxxxxxxx

F73h ADFLTRH ADFLTRH<15:8> xxxxxxxx

F72h ADFLTRL ADFLTRL<7:0> xxxxxxxx

F71h ADACCH ADACCH<15:8> xxxxxxxx

F70h ADACCL ADACCL<7:0> xxxxxxxx

F6Fh ADERRH ADERRH<15:8> 00000000

F6Eh ADERRL ADERRL<7:0> 00000000

F6Dh ADUTHH ADUTHH<15:8> 00000000

F6Ch ADUTHL ADUTHL<7:0> 00000000

F6Bh ADLTHH ADLTHH<15:8> 00000000

F6Ah ADLTHL ADLTHL<7:0> 00000000

F69h ADSTPTH ADSTPTH<15:8> 00000000

F68h ADSTPTL ADSTPTL<7:0> 00000000

F67h ADCNT ADCNT<7:0> 00000000

F66h ADRPT ADRPT<7:0> 00000000

F65h ADSTAT ADAOV ADUTHR ADLTHR ADMATH ADSTAT<2:0> 0000-000

F64h ADRESH ADRESH<7:0> 00000000

F63h ADRESL ADRESL<7:0> 00000000

F62h ADPREVH ADPREVH<15:8> 00000000

F61h ADPREVL ADPREVL<7:0> 00000000

F60h ADCON0 ADON ADCONT ADSC ADFM ADGO 00-000-0

F5Fh ADPCH ADPCH<5:0> --000000

F5Eh ADPRE ADPRE<7:0> 00000000

F5Dh ADCAP ADCAP<4:0> ---00000

F5Ch ADACQ ADACQ<7:0> 00000000

F5Bh ADCON3 ADCALC<2:0> ADSOI ADTMD<2:0> -0000000

F5Ah ADCON2 ADPSIS ADCRS<2:0> ADACLR ADMD<2:0> 00000000

F59h ADCON1 ADPPOL ADIPEN ADGPOL ADDSEN 000----0

F58h ADREF ADNREF ADPREF<1:0> ---0--00

F57h ADCLK ADCS<5:0> --000000

F56h ADACT ADACT<4:0> ---00000

F55h MDCARH CHS<2:0> -----000

F54h MDCARL CLS<2:0> -----000

F53h MDSRC SRCS<3:0> ----0000

F52h MDCON1 CHPOL CHSYNC CLPOL CLSYNC --00--00

F51h MDCON0 EN OUT OPOL MDBIT 0-00---0

F50h SCANTRIG TSEL<3:0> ----0000

F4Fh SCANCON0 SCANEN SCANGO BUSY INVALID INTM MODE<1:0> 00000-00

F4Eh SCANHADRU HADR<21:16> --111111

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 110


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

F4Dh SCANHADRH HADR<15:8> 11111111

F4Ch SCANHADRL HADR<7:0> 11111111

F4Bh SCANLADRU LADR<21:16> --000000

F4Ah SCANLADRH LADR<15:8> 00000000

F49h SCANLADRL LADR<7:0> 00000000

F48h CWG1STR OVRD OVRC OVRB OVRA STRD STRC STRB STRA 00000000

F47h CWG1AS1 AS5E AS4E AS3E AS2E AS1E AS0E --000000

F46h CWG1AS0 SHUTDOWN REN LSBD<1:0> LSAC<1:0> 000101--

F45h CWG1CON1 IN POLD POLC POLB POLA --x-0000

F44h CWG1CON0 EN LD MODE<2:0> 00---000

F43h CWG1DBF DBF<5:0> --000000

F42h CWG1DBR DBR<5:0> --000000

F41h CWG1ISM ISM<2:0> -----000

F40h CWG1CLKCON CS -------0

F3Fh CLKRCLK CLKRxCLK<2:0> -----000

F3Eh CLKRCON CLKREN CLKRDC<1:0> CLKRDIV<2:0> 0--10000

F3Dh CMOUT MC2OUT MC1OUT ------00

F3Ch CM1PCH PCH<2:0> -----000

F3Bh CM1NCH NCH<2:0> -----000

F3Ah CM1CON1 INTP INTN -----100

F39h CM1CON0 EN OUT POL HYS SYNC 00-0--00

F38h CM2PCH C2PCH<2:0> -----000

F37h CM2NCH C2NCH<2:0> -----000

F36h CM2CON1 INTP INTN -----100

F35h CM2CON0 EN OUT POL HYS SYNC 00-0--00

F34h DAC1CON1 DAC1R<4:0> ---xxxxx

F33h DAC1CON0 EN OE1 OE2 PSS<1:0> NSS 0-0000-0

F32h ZCDCON SEN OUT POL INTP INTN 0-x0--00

F31h FVRCON FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0> 0x000000

F30h HLVDCON1 HLVDSEL<3:0> ----0000

F2Fh HLVDCON0 EN OUT RDY INTH INTL 0-xx--00

F2Eh ANSELE(2) ANSELE2 ANSELE1 ANSELE0 -----111


(2) (2) (2)
F2Dh WPUE WPUE3 WPUE2 WPUE1 WPUE0 ----0000

F2Ch ODCONE(2) ODCE2 ODCE1 ODCE0 -----000

F2Bh SLRCONE(2) SLRE2 SLRE1 SLRE0 -----111

F2Ah INLVLE INLVLE3 INLVLE2(2) INLVLE1(2) INLVLE0(2) ----1111

F29h IOCEP IOCEP3 ----0---

F28h IOCEN IOCEN3 ----0---

F27h IOCEF IOCEF3 ----0---

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 111


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

F26h ANSELD(2) ANSELD7 ANSELD6 ANSELD5 ANSELD4 ANSELD3 ANSELD2 ANSELD1 ANSELD0 11111111
(2)
F25h WPUD WPUD7 WPUD6 WPUD5 WPUD4 WPUD3 WPUD2 WPUD1 WPUD0 00000000
(2)
F24h ODCOND ODCD7 ODCD6 ODCD5 ODCD4 ODCD3 ODCD2 ODCD1 ODCD0 00000000

F23h SLRCOND(2) SLRD7 SLRD6 SLRD5 SLRD4 SLRD3 SLRD2 SLRD1 SLRD0 11111111

F22h INLVLD(2) INLVLD7 INLVLD6 INLVLD5 INLVLD4 INLVLD3 INLVLD2 INLVLD1 INLVLD0 10000000

F21h ANSELC ANSELC7 ANSELC6 ANSELC5 ANSELC4 ANSELC3 ANSELC2 ANSELC1 ANSELC0 11111111

F20h WPUC WPUC7 WPUC6 WPUC5 WPUC4 WPUC3 WPUC2 WPUC1 WPUC0 00000000

F1Fh ODCONC ODCC7 ODCC6 ODCC5 ODCC4 ODCC3 ODCC2 ODCC1 ODCC0 00000000

F1Eh SLRCONC SLRC7 SLRC6 SLRC5 SLRC4 SLRC3 SLRC2 SLRC1 SLRC0 11111111

F1Dh INLVLC INLVLC7 INLVLC6 INLVLC5 INLVLC4 INLVLC3 INLVLC2 INLVLC1 INLVLC0 11111111

F1Ch IOCCP IOCCP7 IOCCP6 IOCCP5 IOCCP4 IOCCP3 IOCCP2 IOCCP1 IOCCP0 00000000

F1Bh IOCCN IOCCN7 IOCCN6 IOCCN5 IOCCN4 IOCCN3 IOCCN2 IOCCN1 IOCCN0 00000000

F1Ah IOCCF IOCCF7 IOCCF6 IOCCF5 IOCCF4 IOCCF3 IOCCF2 IOCCF1 IOCCF0 00000000

F19h ANSELB ANSELB7 ANSELB6 ANSELB5 ANSELB4 ANSELB3 ANSELB2 ANSELB1 ANSELB0 11111111

F18h WPUB WPUB7 WPUB6 WPUB5 WPUB4 WPUB3 WPUB2 WPUB1 WPUB0 00000000

F17h ODCONB ODCB7 ODCB6 ODCB5 ODCB4 ODCB3 ODCB2 ODCB1 ODCB0 00000000

F16h SLRCONB SLRB7 SLRB6 SLRB5 SLRB4 SLRB3 SLRB2 SLRB1 SLRB0 11111111

F15h INLVLB INLVLB7 INLVLB6 INLVLB5 INLVLB4 INLVLB3 INLVLB2 INLVLB1 INLVLB0 11111111

F14h IOCBP IOCBP7 IOCBP6 IOCBP5 IOCBP4 IOCBP3 IOCBP2 IOCBP1 IOCBP0 00000000

F13h IOCBN IOCBN7 IOCBN6 IOCBN5 IOCBN4 IOCBN3 IOCBN2 IOCBN1 IOCBN0 00000000

F12h IOCBF IOCBF7 IOCBF6 IOCBF5 IOCBF4 IOCBF3 IOCBF2 IOCBF1 IOCBF0 00000000

F11h ANSELA ANSELA7 ANSELA6 ANSELA5 ANSELA4 ANSELA3 ANSELA2 ANSELA1 ANSELA0 11111111

F10h WPUA WPUA7 WPUA6 WPUA5 WPUA4 WPUA3 WPUA2 WPUA1 WPUA0 00000000

F0Fh ODCONA ODCA7 ODCA6 ODCA5 ODCA4 ODCA3 ODCA2 ODCA1 ODCA0 00000000

F0Eh SLRCONA SLRA7 SLRA6 SLRA5 SLRA4 SLRA3 SLRA2 SLRA1 SLRA0 11111111

F0Dh INLVLA INLVLA7 INLVLA6 INLVLA5 INLVLA4 INLVLA3 INLVLA2 INLVLA1 INLVLA0 11111111

F0Ch IOCAP IOCAP7 IOCAP6 IOCAP5 IOCAP4 IOCAP3 IOCAP2 IOCAP1 IOCAP0 00000000

F0Bh IOCAN IOCAN7 IOCAN6 IOCAN5 IOCAN4 IOCAN3 IOCAN2 IOCAN1 IOCAN0 00000000

F0Ah IOCAF IOCAF7 IOCAF6 IOCAF5 IOCAF4 IOCAF3 IOCAF2 IOCAF1 IOCAF0 00000000
(2)
F09h RE2PPS RE2PPS<4:0> ---00000

F08h RE1PPS(2) RE1PPS<4:0> ---00000


(2)
F07h RE0PPS RE0PPS<4:0> ---00000

F06h RD7PPS(2) RD7PPS<4:0> ---00000


(2)
F05h RD6PPS RD6PPS<4:0> ---00000
(2)
F04h RD5PPS RD5PPS<4:0> ---00000

F03h RD4PPS(2) RD4PPS<4:0> ---00000

F02h RD3PPS(2) RD3PPS<4:0> ---00000


(2)
F01h RD2PPS RD2PPS<4:0> ---00000

F00h RD1PPS(2) RD1PPS<4:0> ---00000

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 112


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

EFFh RD0PPS(2) RD0PPS<4:0> ---00000

EFEh RC7PPS RC7PPS<4:0> ---00000

EFDh RC6PPS RC6PPS<4:0> ---00000

EFCh RC5PPS RC5PPS<4:0> ---00000

EFBh RC4PPS RC4PPS<4:0> ---00000

EFAh RC3PPS RC3PPS<4:0> ---00000

EF9h RC2PPS RC2PPS<4:0> ---00000

EF8h RC1PPS RC1PPS<4:0> ---00000

EF7h RC0PPS RC0PPS<4:0> ---00000

EF6h RB7PPS RB7PPS<4:0> ---00000

EF5h RB6PPS RB6PPS<4:0> ---00000

EF4h RB5PPS RB5PPS<4:0> ---00000

EF3h RB4PPS RB4PPS<4:0> ---00000

EF2h RB3PPS RB3PPS<4:0> ---00000

EF1h RB2PPS RB2PPS<4:0> ---00000

EF0h RB1PPS RB1PPS<4:0> ---00000

EEFh RB0PPS RB0PPS<4:0> ---00000

EEEh RA7PPS RA7PPS<4:0> ---00000

EEDh RA6PPS RA6PPS<4:0> ---00000

EECh RA5PPS RA5PPS<4:0> ---00000

EEBh RA4PPS RA4PPS<4:0> ---00000

EEAh RA3PPS RA3PPS<4:0> ---00000

EE9h RA2PPS RA2PPS<4:0> ---00000

EE8h RA1PPS RA1PPS<4:0> ---00000

EE7h RA0PPS RA0PPS<4:0> ---00000

EE6h PMD5 DSMMD -------0

EE5h PMD4 UART2MD UART1MD MSSP2MD MSSP1MD CWG1MD 0000---0

EE4h PMD3 PWM4MD PWM3MD CCP2MD CCP1MD ----0000

EE3h PMD2 DACMD ADCMD CMP2MD CMP1MD ZCDMD -00--000

EE2h PMD1 TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD -0000000

EE1h PMD0 SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD 00x00000

EE0h BORCON SBOREN BORRDY 1------q

EDFh VREGCON(1) VREGPM Reserved ------01

EDEh OSCFRQ HFFRQ<3:0> ----1111

EDDh OSCTUNE HFTUN<5:0> --100000

EDCh OSCEN EXTOEN HFOEN MFOEN LFOEN SOSCEN ADOEN 000000--

EDBh OSCSTAT EXTOR HFOR MFOR LFOR SOR ADOR PLLR qqqqqq-q

EDAh OSCCON3 CSWHOLD SOSCPWR ORDY NOSCR 00-00---

ED9h OSCCON2 COSC<2:0> CDIV<3:0> -qqqqqqq

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 113


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

ED8h OSCCON1 NOSC<2:0> NDIV<3:0> -qqqqqqq

ED7h CPUDOZE IDLEN DOZEN ROI DOE DOZE<2:0> 0000-000

ED6h WDTTMR WDTTMR<4:0> STATE PSCNT<17:16> xxxxx000

ED5h WDTPSH PSCNT<7:0> 00000000

ED4h WDTPSL PSCNT<15:8> 00000000

ED3h WDTCON1 WDTCS<2:0> WINDOW<2:0> -qqq-qqq

ED2h WDTCON0 WDTPS<4:0> SEN --qqqqq0

ED1h PIR7 SCANIF CRCIF NVMIF CWG1IF 000----0


ED0h PIR6 CCP2IF CCP1IF ------00

ECFh PIR5 TMR5GIF TMR3GIF TMR1GIF -----000

ECEh PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF --000000

ECDh PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 00000000

ECCh PIR2 HLVDIF ZCDIF C2IF C1IF 00----00

ECBh PIR1 OSCFIF CSWIF ADTIF ADIF 00----00

ECAh PIR0 TMR0IF IOCIF INT2IF INT1IF INT0IF --00-000

EC9h PIE7 SCANIE CRCIE NVMIE CWG1IE 000----0

EC8h PIE6 CCP2IE CCP1IE ------00

EC7h PIE5 TMR5GIE TMR3GIE TMR1GIE -----000

EC6h PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE --000000

EC5h PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 00000000

EC4h PIE2 HLVDIE ZCDIE C2IE C1IE 00----00

EC3h PIE1 OSCFIE CSWIE ADTIE ADIE 00----00

EC2h PIE0 TMR0IE IOCIE INT2IE INT1IE INT0IE --00-000

EC1h IPR7 SCANIP CRCIP NVMIP CWG1IP 111----1

EC0h IPR6 CCP2IP CCP1IP ------11

EBFh IPR5 TMR5GIP TMR3GIP TMR1GIP -----111

EBEh IPR4 TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP --111111

EBDh IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 11111111

EBCh IPR2 HLVDIP ZCDIP C2IP C1IP 11----11

EBBh IPR1 OSCFIP CSWIP ADTIP ADIP 11----11

EBAh IPR0 TMR0IP IOCIP INT2IP INT1IP INT0IP --11-111

EB9h SSP1SSPPS SSPSSPPS<4:0> ---00101

EB8h SSP1DATPPS SSPDATPPS<4:0> ---10100

EB7h SSP1CLKPPS SSPCLKPPS<4:0> ---10011

EB6h TX1PPS TXPPS<4:0> ---10110

EB5h RX1PPS RXPPS<4:0> ---10111

EB4h MDSRCPPS MDSRCPPS<4:0> ---00101

EB3h MDCARHPPS MDCARHPPS<4:0> ---00100

EB2h MDCARLPPS MDCARLPPS<4:0> ---00011

Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition


Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 114


PIC18(L)F26/45/46K40
TABLE 10-5: REGISTER FILE SUMMARY FOR PIC18(L)F26/45/46K40 DEVICES (CONTINUED)
Value on
Address Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
POR, BOR

EB1h CWGINPPS CWGINPPS<4:0> ---01000

EB0h CCP2PPS CCP2PPS<4:0> ---10001

EAFh CCP1PPS CCP1PPS<4:0> ---10010

EAEh ADACTPPS ADACTPPS<4:0> ---01100

EADh T6INPPS T6INPPS<4:0> ---01111

EACh T4INPPS T4INPPS<4:0> ---10101

EABh T2INPPS T2INPPS<4:0> ---10011

EAAh T5GPPS T5GPPS<4:0> ---01100

EA9h T5CKIPPS T5CKIPPS<4:0> ---10010

EA8h T3GPPS T3GPPS<4:0> ---10000

EA7h T3CKIPPS T3CKIPPS<4:0> ---10000

EA6h T1GPPS T1GPPS<4:0> ---01101

EA5h T1CKIPPS T1CKIPPS<4:0> ---10000

EA4h T0CKIPPS T0CKIPPS<4:0> ---00100

EA3h INT2PPS INT2PPS<4:0> ---01010

EA2h INT1PPS INT1PPS<4:0> ---01001

EA1h INT0PPS INT0PPS<4:0> ---01000

EA0h PPSLOCK PPSLOCKED -------0

E9Fh BAUD2CON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 01-00-00

E9Eh TX2STA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 00000010

E9Dh RC2STA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 00000000

E9Ch SP2BRGH EUSART2 Baud Rate Generator, High Byte 00000000

E9Bh SP2BRGL EUSART2 Baud Rate Generator, Low Byte 00000000

E9Ah TX2REG EUSART2 Transmit Register 00000000

E99h RC2REG EUSART2 Receive Register 00000000

E98h SSP2CON3 ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN 00000000

E97h SSP2CON2 GCEN ACKSTAT ACKDT ACKEN RCEN PEN RSEN SEN 00000000

E96h SSP2CON1 WCOL SSPOV SSPEN CKP SSPM<3:0> 00000000

E95h SSP2STAT SMP CKE D/A P S R/W UA BF 00000000

E94h SSP2MSK MSK<7:0> 11111111

E93h SSP2ADD ADD<7:0> 00000000

E92h SSP2BUF BUF<7:0> xxxxxxxx

E91h SSP2SSPPS SSPSSPPS<4:0> ---00101

E90h SSP2DATPPS SSPDATPPS<4:0> ---10100

E8Fh SSP2CLKPPS SSPCLKPPS<4:0> ---10011

E8Eh TX2PPS TXPPS<4:0> ---10110

E8Dh RX2PPS RXPPS<4:0> ---10111

E8Ch
Unimplemented
E7Eh
Legend: x = unknown, u = unchanged, = unimplemented, q = value depends on condition
Note 1: Not available on LF devices.
2: Not available on PIC18(L)F26K40 (28-pin variants).
3: Not available on PIC18(L)F45K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 115


PIC18(L)F26/45/46K40
10.4.5 STATUS REGISTER
The STATUS register, shown in Register 10-2, contains
the arithmetic status of the ALU. As with any other SFR,
it can be the operand for any instruction.
If the STATUS register is the destination for an instruc-
tion that affects the Z, DC, C, OV or N bits, the results
of the instruction are not written; instead, the STATUS
register is updated according to the instruction per-
formed. Therefore, the result of an instruction with the
STATUS register as its destination may be different
than intended. As an example, CLRF STATUS will set
the Z bit and leave the remaining Status bits
unchanged (000u u1uu).
It is recommended that only BCF, BSF, SWAPF, MOVFF
and MOVWF instructions are used to alter the STATUS
register, because these instructions do not affect the Z,
C, DC, OV or N bits in the STATUS register.
For other instructions that do not affect Status bits, see
the instruction set summaries in Section
35.0 Instruction Set Summary and Table 35-3.
Note: The C and DC bits operate as the borrow
and digit borrow bits, respectively, in
subtraction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 116


PIC18(L)F26/45/46K40
10.5 Register Definitions: Status
REGISTER 10-2: STATUS: STATUS REGISTER
U-0 R-1/q R-1/q R/W-0/u R/W-0/u R/W-0/u R/W-0/u R/W-0/u
TO PD N OV Z DC C
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 Unimplemented: Read as 0


bit 6 TO: Time-Out bit
1 = Set at power-up or by execution of CLRWDT or SLEEP instruction
0 = A WDT time-out occurred
bit 5 PD: Power-Down bit
1 = Set at power-up or by execution of CLRWDT instruction
0 = Set by execution of the SLEEP instruction
bit 4 N: Negative bit used for signed arithmetic (2s complement); indicates if the result is negative,
(ALU MSb = 1).
1 = The result is negative
0 = The result is positive
bit 3 OV: Overflow bit used for signed arithmetic (2s complement); indicates an overflow of the 7-bit
magnitude, which causes the sign bit (bit 7) to change state.
1 = Overflow occurred for current signed arithmetic operation
0 = No overflow occurred
bit 2 Z: Zero bit
1 = The result of an arithmetic or logic operation is zero
0 = The result of an arithmetic or logic operation is not zero
bit 1 DC: Digit Carry/Borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)(1)
1 = A carry-out from the 4th low-order bit of the result occurred
0 = No carry-out from the 4th low-order bit of the result
bit 0 C: Carry/Borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)(1,2)
1 = A carry-out from the Most Significant bit of the result occurred
0 = No carry-out from the Most Significant bit of the result occurred
Note 1: For Borrow, the polarity is reversed. A subtraction is executed by adding the twos complement of the
second operand.
2: For Rotate (RRF, RLF) instructions, this bit is loaded with either the high or low-order bit of the Source
register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 117


PIC18(L)F26/45/46K40
10.6 Data Addressing Modes The Access RAM bit a determines how the address is
interpreted. When a is 1, the contents of the BSR
Note: The execution of some instructions in the (Section 10.4.1 Bank Select Register (BSR)) are
core PIC18 instruction set are changed used with the address to determine the complete 12-bit
when the PIC18 extended instruction set is address of the register. When a is 0, the address is
enabled. See Section 10.7 Data Mem- interpreted as being a register in the Access Bank.
ory and the Extended Instruction Set Addressing that uses the Access RAM is sometimes
for more information. also known as Direct Forced Addressing mode.
While the program memory can be addressed in only A few instructions, such as MOVFF, include the entire
one way through the program counter information 12-bit address (either source or destination) in their
in the data memory space can be addressed in several opcodes. In these cases, the BSR is ignored entirely.
ways. For most instructions, the addressing mode is The destination of the operations results is determined
fixed. Other instructions may use up to three modes, by the destination bit d. When d is 1, the results are
depending on which operands are used and whether or stored back in the source register, overwriting its origi-
not the extended instruction set is enabled. nal contents. When d is 0, the results are stored in
The addressing modes are: the W register. Instructions without the d argument
have a destination that is implicit in the instruction; their
Inherent destination is either the target register being operated
Literal on or the W register.
Direct
Indirect 10.6.3 INDIRECT ADDRESSING
An additional addressing mode, Indexed Literal Offset, Indirect addressing allows the user to access a location
is available when the extended instruction set is in data memory without giving a fixed address in the
enabled (XINST Configuration bit = 1). Its operation is instruction. This is done by using File Select Registers
discussed in greater detail in Section 10.7.1 Indexed (FSRs) as pointers to the locations which are to be read
Addressing with Literal Offset. or written. Since the FSRs are themselves located in
RAM as Special File Registers, they can also be
10.6.1 INHERENT AND LITERAL directly manipulated under program control. This
ADDRESSING makes FSRs very useful in implementing data struc-
tures, such as tables and arrays in data memory.
Many PIC18 control instructions do not need any argu-
ment at all; they either perform an operation that glob- The registers for indirect addressing are also
ally affects the device or they operate implicitly on one implemented with Indirect File Operands (INDFs) that
register. This addressing mode is known as Inherent permit automatic manipulation of the pointer value with
Addressing. Examples include SLEEP, RESET and DAW. auto-incrementing, auto-decrementing or offsetting
with another value. This allows for efficient code, using
Other instructions work in a similar way but require an loops, such as the example of clearing an entire RAM
additional explicit argument in the opcode. This is bank in Example 10-5.
known as Literal Addressing mode because they
require some literal value as an argument. Examples
EXAMPLE 10-5: HOW TO CLEAR RAM
include ADDLW and MOVLW, which respectively, add or
move a literal value to the W register. Other examples (BANK 1) USING
include CALL and GOTO, which include a 20-bit INDIRECT ADDRESSING
program memory address. LFSRFSR0, 100h ;
NEXT CLRFPOSTINC0 ; Clear INDF
10.6.2 DIRECT ADDRESSING ; register then
; inc pointer
Direct addressing specifies all or part of the source BTFSS FSR0H, 1 ; All done with
and/or destination address of the operation within the ; Bank1?
opcode itself. The options are specified by the BRA NEXT ; NO, clear next
arguments accompanying the instruction. CONTINUE ; YES, continue
In the core PIC18 instruction set, bit-oriented and byte-
oriented instructions use some version of direct
addressing by default. All of these instructions include
some 8-bit literal address as their Least Significant
Byte. This address specifies either a register address in
one of the banks of data RAM (Section
10.4.3 General Purpose Register File) or a location
in the Access Bank (Section 10.4.2 Access Bank)
as the data source for the instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 118


PIC18(L)F26/45/46K40
10.6.3.1 FSR Registers and the INDF 10.6.3.2 FSR Registers and POSTINC,
Operand POSTDEC, PREINC and PLUSW
At the core of indirect addressing are three sets of reg- In addition to the INDF operand, each FSR register pair
isters: FSR0, FSR1 and FSR2. Each represents a pair also has four additional indirect operands. Like INDF,
of 8-bit registers, FSRnH and FSRnL. Each FSR pair these are virtual registers which cannot be directly
holds a 12-bit value, therefore, the four upper bits of the read or written. Accessing these registers actually
FSRnH register are not used. The 12-bit FSR value can accesses the location to which the associated FSR
address the entire range of the data memory in a linear register pair points, and also performs a specific action
fashion. The FSR register pairs, then, serve as pointers on the FSR value. They are:
to data memory locations. POSTDEC: accesses the location to which the
Indirect addressing is accomplished with a set of FSR points, then automatically decrements the
Indirect File Operands, INDF0 through INDF2. These FSR by 1 afterwards
can be thought of as virtual registers; they are POSTINC: accesses the location to which the
mapped in the SFR space but are not physically FSR points, then automatically increments the
implemented. Reading or writing to a particular INDF FSR by 1 afterwards
register actually accesses its corresponding FSR PREINC: automatically increments the FSR by
register pair. A read from INDF1, for example, reads one, then uses the location to which the FSR
the data at the address indicated by FSR1H:FSR1L. points in the operation
Instructions that use the INDF registers as operands
PLUSW: adds the signed value of the W register
actually use the contents of their corresponding FSR as
(range of -127 to 128) to that of the FSR and uses
a pointer to the instructions target. The INDF operand
the location to which the result points in the
is just a convenient way of using the pointer.
operation.
Because indirect addressing uses a full 12-bit address,
In this context, accessing an INDF register uses the
data RAM banking is not necessary. Thus, the current
value in the associated FSR register without changing
contents of the BSR and the Access RAM bit have no
it. Similarly, accessing a PLUSW register gives the
effect on determining the target address.
FSR value an offset by that in the W register; however,
neither W nor the FSR is actually changed in the
operation. Accessing the other virtual registers
changes the value of the FSR register.

FIGURE 10-6: INDIRECT ADDRESSING


000h
Using an instruction with one of the ADDWF, INDF1, 1 Bank 0
indirect addressing registers as the 100h
operand.... Bank 1
200h
Bank 2
300h
...uses the 12-bit address stored in FSR1H:FSR1L
the FSR pair associated with that
7 0 7 0
register.... Bank 3
x x x x 1 1 1 0 1 1 0 0 1 1 0 0 through
Bank 13

...to determine the data memory


location to be used in that operation.
In this case, the FSR1 pair contains E00h
ECCh. This means the contents of Bank 14
location ECCh will be added to that F00h
of the W register and stored back in Bank 15
ECCh. FFFh
Data Memory

2016 Microchip Technology Inc. Preliminary DS40001816C-page 119


PIC18(L)F26/45/46K40
Operations on the FSRs with POSTDEC, POSTINC 10.7.1 INDEXED ADDRESSING WITH
and PREINC affect the entire register pair; that is, roll- LITERAL OFFSET
overs of the FSRnL register from FFh to 00h carry over
Enabling the PIC18 extended instruction set changes
to the FSRnH register. On the other hand, results of
the behavior of indirect addressing using the FSR2
these operations do not change the value of any flags
register pair within Access RAM. Under the proper
in the STATUS register (e.g., Z, N, OV, etc.).
conditions, instructions that use the Access Bank that
The PLUSW register can be used to implement a form is, most bit-oriented and byte-oriented instructions
of indexed addressing in the data memory space. By can invoke a form of indexed addressing using an
manipulating the value in the W register, users can offset specified in the instruction. This special
reach addresses that are fixed offsets from pointer addressing mode is known as Indexed Addressing with
addresses. In some applications, this can be used to Literal Offset, or Indexed Literal Offset mode.
implement some powerful program control structure,
When using the extended instruction set, this
such as software stacks, inside of data memory.
addressing mode requires the following:
10.6.3.3 Operations by FSRs on FSRs The use of the Access Bank is forced (a = 0) and
Indirect addressing operations that target other FSRs The file address argument is less than or equal to
or virtual registers represent special cases. For 5Fh.
example, using an FSR to point to one of the virtual Under these conditions, the file address of the
registers will not result in successful operations. As a instruction is not interpreted as the lower byte of an
specific case, assume that FSR0H:FSR0L contains address (used with the BSR in direct addressing), or as
FE7h, the address of INDF1. Attempts to read the an 8-bit address in the Access Bank. Instead, the value
value of the INDF1 using INDF0 as an operand will is interpreted as an offset value to an Address Pointer,
return 00h. Attempts to write to INDF1 using INDF0 as specified by FSR2. The offset and the contents of
the operand will result in a NOP. FSR2 are added to obtain the target address of the
On the other hand, using the virtual registers to write to operation.
an FSR pair may not occur as planned. In these cases,
the value will be written to the FSR pair but without any 10.7.2 INSTRUCTIONS AFFECTED BY
incrementing or decrementing. Thus, writing to either INDEXED LITERAL OFFSET MODE
the INDF2 or POSTDEC2 register will write the same Any of the core PIC18 instructions that can use direct
value to the FSR2H:FSR2L. addressing are potentially affected by the Indexed
Since the FSRs are physical registers mapped in the Literal Offset Addressing mode. This includes all
SFR space, they can be manipulated through all direct byte-oriented and bit-oriented instructions, or almost
operations. Users should proceed cautiously when one-half of the standard PIC18 instruction set.
working on these registers, particularly if their code Instructions that only use Inherent or Literal Addressing
uses indirect addressing. modes are unaffected.
Similarly, operations by indirect addressing are generally Additionally, byte-oriented and bit-oriented instructions
permitted on all other SFRs. Users should exercise the are not affected if they do not use the Access Bank
appropriate caution that they do not inadvertently change (Access RAM bit is 1), or include a file address of 60h
settings that might affect the operation of the device. or above. Instructions meeting these criteria will
continue to execute as before. A comparison of the
10.7 Data Memory and the Extended different possible addressing modes when the
extended instruction set is enabled is shown in
Instruction Set Figure 10-7.
Enabling the PIC18 extended instruction set (XINST Those who desire to use byte-oriented or bit-oriented
Configuration bit = 1) significantly changes certain instructions in the Indexed Literal Offset mode should
aspects of data memory and its addressing. Specifi- note the changes to assembler syntax for this mode.
cally, the use of the Access Bank for many of the core This is described in more detail in Section
PIC18 instructions is different; this is due to the intro- 35.2.1 Extended Instruction Syntax.
duction of a new addressing mode for the data memory
space.
What does not change is just as important. The size of
the data memory space is unchanged, as well as its
linear addressing. The SFR map remains the same.
Core PIC18 instructions can still operate in both Direct
and Indirect Addressing mode; inherent and literal
instructions do not change at all. Indirect addressing
with FSR0 and FSR1 also remain unchanged.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 120


PIC18(L)F26/45/46K40
FIGURE 10-7: COMPARING ADDRESSING OPTIONS FOR BIT-ORIENTED AND
BYTE-ORIENTED INSTRUCTIONS (EXTENDED INSTRUCTION SET ENABLED)

EXAMPLE INSTRUCTION: ADDWF, f, d, a (Opcode: 0010 01da ffff ffff)

000h
When a = 0 and f 60h:
060h
The instruction executes in
Direct Forced mode. f is inter- Bank 0

preted as a location in the 100h


Access RAM between 060h 00h
Bank 1
and 0FFh. This is the same as through 60h
locations F60h to FFFh Bank 14
Valid range
(Bank 15) of data memory. for f
Locations below 60h are not FFh
F00h Access RAM
available in this addressing
Bank 15
mode.
F60h
SFRs
FFFh
Data Memory

When a = 0 and f5Fh: 000h


The instruction executes in
Indexed Literal Offset mode. f 060h
Bank 0
is interpreted as an offset to the
100h
address value in FSR2. The 001001da ffffffff
two are added together to Bank 1
obtain the address of the target through
Bank 14
register for the instruction. The
address can be anywhere in FSR2H FSR2L
the data memory space.
F00h
Note that in this mode, the Bank 15
correct syntax is now: F60h
ADDWF [k], d SFRs
where k is the same as f. FFFh
Data Memory

BSR
When a = 1 (all values of f): 000h 00000000

The instruction executes in


060h
Direct mode (also known as
Bank 0
Direct Long mode). f is inter- 100h
preted as a location in one of
the 16 banks of the data Bank 1 001001da ffffffff
memory space. The bank is through
Bank 14
designated by the Bank Select
Register (BSR). The address
can be in any implemented F00h
bank in the data memory Bank 15
space. F60h
SFRs
FFFh
Data Memory

2016 Microchip Technology Inc. Preliminary DS40001816C-page 121


PIC18(L)F26/45/46K40
10.7.3 MAPPING THE ACCESS BANK IN 10.8 PIC18 Instruction Execution and
INDEXED LITERAL OFFSET MODE the Extended Instruction Set
The use of Indexed Literal Offset Addressing mode Enabling the extended instruction set adds eight
effectively changes how the first 96 locations of Access additional commands to the existing PIC18 instruction
RAM (00h to 5Fh) are mapped. Rather than containing set. These instructions are executed as described in
just the contents of the bottom section of Bank 0, this Section 35.2 Extended Instruction Set.
mode maps the contents from a user defined window
that can be located anywhere in the data memory
space. The value of FSR2 establishes the lower bound-
ary of the addresses mapped into the window, while the
upper boundary is defined by FSR2 plus 95 (5Fh).
Addresses in the Access RAM above 5Fh are mapped
as previously described (see Section 10.4.2 Access
Bank). An example of Access Bank remapping in this
addressing mode is shown in Figure 10-8.
Remapping of the Access Bank applies only to opera-
tions using the Indexed Literal Offset mode. Operations
that use the BSR (Access RAM bit is 1) will continue
to use direct addressing as before.

FIGURE 10-8: REMAPPING THE ACCESS BANK WITH INDEXED LITERAL OFFSET
ADDRESSING
Example Situation:
ADDWF f, d, a 000h
FSR2H:FSR2L = 120h
Bank 0
Locations in the region
from the FSR2 pointer 100h
(120h) to the pointer plus Bank 1
120h
05Fh (17Fh) are mapped Window
17Fh 00h
to the bottom of the
Bank 1
Access RAM (000h-05Fh). 200h Bank 1 Window
Special File Registers at 5Fh
60h
F60h through FFFh are
mapped to 60h through Bank 2
FFh, as usual. SFRs
through
Bank 0 addresses below Bank 14
5Fh can still be addressed FFh
by using the BSR. Access Bank
F00h
Bank 15
F60h
SFRs
FFFh
Data Memory

2016 Microchip Technology Inc. Preliminary DS40001816C-page 122


PIC18(L)F26/45/46K40
11.0 NONVOLATILE MEMORY NVM can be protected in two ways, by either code
protection or write protection. Code protection (CP and
(NVM) CONTROL CPD bits in Configuration Word 5L) disables access,
Nonvolatile Memory (NVM) is separated into two types: reading and writing to both PFM and Data EEPROM
Program Flash Memory (PFM) and Data EEPROM Memory via external device programmers. Code
Memory. protection does not affect the self-write and erase
functionality. Code protection can only be reset by a
PFM, Data EEPROM, User IDs and Configuration bits
device programmer performing a Bulk Erase to the
can all be accessed using the NVMREG<1:0> bits of
device, clearing all nonvolatile memory, Configuration
the NVMCON1 register.
bits and User IDs.
The write time is controlled by an on-chip timer. The
Write protection prohibits self-write and erase to a
write/erase voltages are generated by an on-chip
portion or all of the PFM, as defined by the WRT bits of
charge pump rated to operate over the operating
Configuration Word 4H. Write protection does not affect
voltage range of the device.
a device programmers ability to read, write or erase
the device.

TABLE 11-1: NVM ORGANIZATION AND ACCESS INFORMATION


PC<20:0> Execution User Access
ICSP Addr<21:0>
Memory CPU
TBLPTR<21:0> NVMREG TABLAT NVMDAT
NVMADDR<9:0> Execution

00 0000h
User Flash Memory Read/
Read 10 (3)
(PFM) Write(1)
01 FFFFh
20 0000h
Read/
User IDs(2) No Access x1 (3)
Write
20 000Fh
20 0010h
Reserved No Access (3)
2F FFFFh
30 0000h
Read/
Configuration No Access x1 (3)
Write
30 000Bh
30 000Ch
Reserved No Access (3)
30 FFFFh
31 0000h
User Data Memory Read/
No Access 00 (3)
(Data EEPROM) Write
31 03FFh
32 0000h
Reserved No Access (3)
3F FFFBh
3F FFFCh
Revision ID/
No Access x1 Read (3)
Device ID
3F FFFFh

Note 1: Subject to Memory Write Protection settings.


2: User IDs are eight words ONLY. There is no code protection, table read protection or write protection
implemented for this region.
3: Reads as 0, writes clear the WR bit and WRERR bit is set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 123


PIC18(L)F26/45/46K40
11.1 Program Flash Memory rows. A row is the minimum size that can be erased by
user software. Refer to Table 11-3 for the row sizes for
The Program Flash Memory is readable, writable and the these devices.
erasable during normal operation over the entire VDD
range. After a row has been erased, all or a portion of this row
can be programmed. Data to be written into the
A read from program memory is executed one byte at program memory row is written to 6-bit wide data write
a time. A write to program memory or program memory latches. These latches are not directly accessible, but
erase is executed on blocks of n bytes at a time. Refer may be loaded via sequential writes to the TABLAT
to Table 11-3 for write and erase block sizes. A Bulk register.
Erase operation cannot be issued from user code.
Writing or erasing program memory will cease
instruction fetches until the operation is complete. The Note: To modify only a portion of a previously
program memory cannot be accessed during the write programmed row, then the contents of the
or erase, therefore, code cannot execute. An internal entire row must be read and saved in
programming timer terminates program memory writes RAM prior to the erase. Then, the new
and erases. data and retained data can be written into
the write latches to reprogram the row of
A value written to program memory does not need to be PFM. However, any unprogrammed
a valid instruction. Executing a program memory locations can be written without first
location that forms an invalid instruction results in a erasing the row. In this case, it is not
NOP. necessary to save and rewrite the other
It is important to understand the PFM memory structure previously programmed locations
for erase and programming operations. Program
memory word size is 16 bits wide. PFM is arranged in

TABLE 11-2: FLASH MEMORY ORGANIZATION BY DEVICE


Row Erase Size Write Latches Program Flash
Device Data Memory (Bytes)
(Words) (Bytes) Memory (Words)
PIC18(L)F45K40 16384 256
PIC18(L)F26K40 32 64
32768
PIC18(L)F46K40
1024
PIC18(L)F27K40
64 128 65536
PIC18(L)F47K40

2016 Microchip Technology Inc. Preliminary DS40001816C-page 124


PIC18(L)F26/45/46K40
11.1.1 TABLE READS AND TABLE WRITES The table write operation stores one byte of data from
the TABLAT register into a write block holding register.
In order to read and write program memory, there are
The procedure to write the contents of the holding
two operations that allow the processor to move bytes
registers into program memory is detailed in Section
between the program memory space and the data RAM:
11.1.6 Writing to Program Flash Memory.
Table Read (TBLRD) Figure 11-2 shows the operation of a table write with
Table Write (TBLWT) program memory and data RAM.
The program memory space is 16 bits wide, while the Table operations work with byte entities. Tables
data RAM space is eight bits wide. Table reads and containing data, rather than program instructions, are
table writes move data between these two memory not required to be word aligned. Therefore, a table can
spaces through an 8-bit register (TABLAT). start and end at any byte address. If a table write is being
The table read operation retrieves one byte of data used to write executable code into program memory,
directly from program memory and places it into the program instructions will need to be word aligned.
TABLAT register. Figure 11-1 shows the operation of a
table read.

FIGURE 11-1: TABLE READ OPERATION


Instruction: TBLRD*

Program Memory
Table Pointer(1)
Table Latch (8-bit)
TBLPTRU TBLPTRH TBLPTRL
TABLAT

Program Memory
(TBLPTR)

Note 1: Table Pointer register points to a byte in program memory.

FIGURE 11-2: TABLE WRITE OPERATION


Instruction: TBLWT*

Program Memory Holding Registers

Table Pointer(1) Table Latch (8-bit)


TBLPTRU TBLPTRH TBLPTRL TABLAT

Program Memory
(TBLPTR<MSBs>)

Note 1: During table writes the Table Pointer does not point directly to program memory. The LSBs of TBLPRTL
actually point to an address within the write block holding registers. The MSBs of the Table Pointer deter-
mine where the write block will eventually be written. The process for writing the holding registers to the
program memory array is discussed in Section 11.1.6 Writing to Program Flash Memory.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 125


PIC18(L)F26/45/46K40
11.1.2 CONTROL REGISTERS 11.1.2.3 TBLPTR Table Pointer Register
Several control registers are used in conjunction with The Table Pointer (TBLPTR) register addresses a byte
the TBLRD and TBLWT instructions. These include the within the program memory. The TBLPTR is comprised
following registers: of three SFR registers: Table Pointer Upper Byte, Table
NVMCON1 register Pointer High Byte and Table Pointer Low Byte
(TBLPTRU:TBLPTRH:TBLPTRL). These three
NVMCON2 register
registers join to form a 22-bit wide pointer. The low-
TABLAT register order 21 bits allow the device to address up to 2 Mbytes
TBLPTR registers of program memory space. The 22nd bit allows access
to the Device ID, the User ID and the Configuration bits.
11.1.2.1 NVMCON1 and NVMCON2
The Table Pointer register, TBLPTR, is used by the
Registers
TBLRD and TBLWT instructions. These instructions can
The NVMCON1 register (Register 11-1) is the control update the TBLPTR in one of four ways based on the
register for memory accesses. The NVMCON2 register table operation. These operations on the TBLPTR
is not a physical register; it is used exclusively in the affect only the low-order 21 bits.
memory write and erase sequences. Reading
NVMCON2 will read all 0s. 11.1.2.4 Table Pointer Boundaries
The NVMREG<1:0> control bits determine if the TBLPTR is used in reads, writes and erases of the
access will be to Data EEPROM Memory locations. Program Flash Memory.
PFM locations or User IDs, Configuration bits, Rev ID When a TBLRD is executed, all 22 bits of the TBLPTR
and Device ID. When NVMREG<1:0> = 00, any determine which byte is read from program memory
subsequent operations will operate on the Data directly into the TABLAT register.
EEPROM Memory. When NVMREG<1:0> = 10, any
subsequent operations will operate on the program When a TBLWT is executed the byte in the TABLAT
memory. When NVMREG<1:0> = x1, any subsequent register is written, not to Flash memory but, to a holding
operations will operate on the Configuration bits, User register in preparation for a program memory write. The
IDs, Rev ID and Device ID. holding registers constitute a write block which varies
depending on the device (see Table 11-3).The 3, 4, or
The FREE bit allows the program memory erase 5 LSbs of the TBLPTRL register determine which
operation. When the FREE bit is set, an erase specific address within the holding register block is
operation is initiated on the next WR command. When written to. The MSBs of the Table Pointer have no effect
FREE is clear, only writes are enabled. This bit is during TBLWT operations.
applicable only to the PFM and not to data EEPROM.
When a program memory write is executed the entire
When set, the WREN bit will allow a program/erase holding register block is written to the Flash memory at
operation. The WREN bit is cleared on power-up. the address determined by the MSbs of the TBLPTR.
The WRERR bit is set by hardware when the WR bit is The 3, 4, or 5 LSBs are ignored during Flash memory
set and cleared when the internal programming timer writes. For more detail, see Section 11.1.6 Writing to
expires and the write operation is successfully Program Flash Memory.
complete. Figure 11-3 describes the relevant boundaries of
The WR control bit initiates erase/write cycle operation TBLPTR based on Program Flash Memory operations.
when the NVMREG<1:0> bits point to the Data
EEPROM Memory location, and it initiates a write
operation when the NVMREG<1:0> bits point to the
PFM location. The WR bit cannot be cleared by
firmware; it can only be set by firmware. Then the WR
bit is cleared by hardware at the completion of the write
operation.

The NVMIF Interrupt Flag bit of the PIR7 register is set


when the write is complete. The NVMIF flag stays set
until cleared by firmware.

11.1.2.2 TABLAT Table Latch Register


The Table Latch (TABLAT) is an 8-bit register mapped
into the SFR space. The Table Latch register is used to
hold 8-bit data during data transfers between program
memory and data RAM.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 126


PIC18(L)F26/45/46K40

TABLE 11-3: TABLE POINTER OPERATIONS WITH TBLRD AND TBLWT INSTRUCTIONS
Example Operation on Table Pointer
TBLRD*
TBLPTR is not modified
TBLWT*
TBLRD*+
TBLPTR is incremented after the read/write
TBLWT*+
TBLRD*-
TBLPTR is decremented after the read/write
TBLWT*-
TBLRD+*
TBLPTR is incremented before the read/write
TBLWT+*

FIGURE 11-3: TABLE POINTER BOUNDARIES BASED ON OPERATION

21 TBLPTRU 16 15 TBLPTRH 8 7 TBLPTRL 0

TABLE ERASE/WRITE TABLE WRITE


TBLPTR<21:n+1>(1) TBLPTR<n:0>(1)

TABLE READ TBLPTR<21:0>

Note 1: Refer to Table 11-3 for the row size values.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 127


PIC18(L)F26/45/46K40
11.1.3 READING THE PROGRAM FLASH The CPU operation is suspended during the read, and
MEMORY it resumes immediately after. From the user point of
view, TABLAT is valid in the next instruction cycle.
The TBLRD instruction retrieves data from program
memory and places it into data RAM. Table reads from The internal program memory is typically organized by
program memory are performed one byte at a time. words. The Least Significant bit of the address selects
between the high and low bytes of the word. Figure 11-4
TBLPTR points to a byte address in program space.
shows the interface between the internal program
Executing TBLRD places the byte pointed to into
memory and the TABLAT.
TABLAT. In addition, TBLPTR can be modified
automatically for the next table read operation.

FIGURE 11-4: READS FROM PROGRAM FLASH MEMORY

Program Memory

(Even Byte Address) (Odd Byte Address)

TBLPTR = xxxxx1 TBLPTR = xxxxx0

Instruction Register TABLAT


FETCH TBLRD
(IR) Read Register

EXAMPLE 11-1: READING A PROGRAM FLASH MEMORY WORD


MOVLW CODE_ADDR_UPPER ; Load TBLPTR with the base
MOVWF TBLPTRU ; address of the word
MOVLW CODE_ADDR_HIGH
MOVWF TBLPTRH
MOVLW CODE_ADDR_LOW
MOVWF TBLPTRL
READ_WORD
TBLRD*+ ; read into TABLAT and increment
MOVF TABLAT, W ; get data
MOVWF WORD_EVEN
TBLRD*+ ; read into TABLAT and increment
MOVFW TABLAT, W ; get data
MOVF WORD_ODD

2016 Microchip Technology Inc. Preliminary DS40001816C-page 128


PIC18(L)F26/45/46K40
FIGURE 11-5: PROGRAM FLASH
MEMORY READ
FLOWCHART
Rev. 10-000046B
8/7/2015

Start
Read Operation

Select PFM
(NVMREG<1:0> = 0x10)

Select Word Address


(TBLPTR registers)

Initiate Read operation


(TBLRD)

Data read now in


TABLAT

End
Read Operation

2016 Microchip Technology Inc. Preliminary DS40001816C-page 129


PIC18(L)F26/45/46K40
11.1.4 NVM UNLOCK SEQUENCE FIGURE 11-6: NVM UNLOCK
The unlock sequence is a mechanism that protects the SEQUENCE FLOWCHART
NVM from unintended self-write programming or
erasing. The sequence must be executed and
Start Unlock Sequence
completed without interruption to successfully
complete any of the following operations:
PFM Row Erase
Write of PFM write latches to PFM memory
Write of PFM write latches to User IDs
Write 55h to NVMCON2
Write to Data EEPROM Memory
Write to Configuration Words
The unlock sequence consists of the following steps
and must be completed in order:
Write 55h to NVMCON2 Write AAh to NVMCON2
Write AAh to NMVCON2
Set the WR bit of NVMCON1
Once the WR bit is set, the processor will stall internal
operations until the operation is complete and then Initiate Write or Erase Operation
resume with the next instruction. (WR = 1)
Since the unlock sequence must not be interrupted,
global interrupts should be disabled prior to the unlock
sequence and re-enabled after the unlock sequence is
completed.
End Unlock Operation

EXAMPLE 11-2: NVM UNLOCK SEQUENCE


BCF INTCON,GIE ; Recommended so sequence is not interrupted
BANKSEL NVMCON1
BSF NVMCON1,WREN ; Enable write/erase
MOVLW 55h ; Load 55h

MOVWF NVMCON2 ; Step 1: Load 55h into NVMCON2


MOVLW AAh ; Step 2: Load W with AAh
MOVWF NVMCON2 ; Step 3: Load AAh into NVMCON2
BSF INTCON1,WR ; Step 4: Set WR bit to begin write/erase

BSF INTCON,GIE ; Re-enable interrupts

Note 1: Sequence begins when NVMCON2 is written; steps 1-4 must occur in the cycle-accurate order
shown. If the timing of the steps 1 to 4 is corrupted by an interrupt or a debugger Halt, the action
will not take place.
2: Opcodes shown are illustrative; any instruction that has the indicated effect may be used.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 130


PIC18(L)F26/45/46K40
11.1.5 ERASING PROGRAM FLASH 11.1.5.1 Program Flash Memory Erase
MEMORY Sequence
The minimum erase block is 32 or 64 words (refer to The sequence of events for erasing a block of internal
Table 11-3). Only through the use of an external program memory is:
programmer, or through ICSP control, can larger 1. NVMREG bits of the NVMCON1 register point to
blocks of program memory be bulk erased. Word erase PFM
in the Flash array is not supported.
2. Set the FREE and WREN bits of the NVMCON1
For example, when initiating an erase sequence from a register
microcontroller with erase row size of 32 words, a block 3. Perform the unlock sequence as described in
of 32 words (64 bytes) of program memory is erased. Section 11.1.4 NVM Unlock Sequence
The Most Significant 16 bits of the TBLPTR<21:6>
point to the block being erased. The TBLPTR<5:0> bits If the PFM address is write-protected, the WR bit will be
are ignored. cleared and the erase operation will not take place,
WRERR is signaled in this scenario.
The NVMCON1 register commands the erase
operation. The NVMREG<1:0> bits must be set to point The operation erases the memory row indicated by
to the Program Flash Memory. The WREN bit must be masking the LSBs of the current TBLPTR.
set to enable write operations. The FREE bit is set to While erasing PFM, CPU operation is suspended and
select an erase operation. it resumes when the operation is complete. Upon
The NVM unlock sequence described in Section completion the WR bit is cleared in hardware, the
11.1.4 NVM Unlock Sequence should be used to NVMIF is set and an interrupt will occur if the NVMIE bit
guard against accidental writes. This is sometimes is also set.
referred to as a long write. Write latch data is not affected by erase operations and
A long write is necessary for erasing the internal Flash. WREN will remain unchanged.
Instruction execution is halted during the long write
cycle. The long write is terminated by the internal
Note 1: If a write or erase operation is terminated
programming timer.
by an unexpected event, WRERR bit will
be set which the user can check to decide
whether a rewrite of the location(s) is
needed.
2: WRERR is set if WR is written to 1 while
TBLPTR points to a write-protected
address.
3: WRERR is set if WR is written to 1 while
TBLPTR points to an invalid address
location (Table 10-1 and Table 11-1).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 131


PIC18(L)F26/45/46K40
EXAMPLE 11-3: ERASING A PROGRAM FLASH MEMORY BLOCK
; This sample row erase routine assumes the following:
; 1. A valid address within the erase row is loaded in variables TBLPTR register
; 2. ADDRH and ADDRL are located in common RAM (locations 0x70 - 0x7F)

MOVLW CODE_ADDR_UPPER ; load TBLPTR with the base


MOVWF TBLPTRU ; address of the memory block
MOVLW CODE_ADDR_HIGH
MOVWF TBLPTRH
MOVLW CODE_ADDR_LOW
MOVWF TBLPTRL
ERASE_BLOCK
BCF NVMCON1, NVMREG0 ; point to Program Flash Memory
BSF NVMCON1, NVMREG1 ; access Program Flash Memory
BSF NVMCON1, WREN ; enable write to memory
BSF NVMCON1, FREE ; enable block Erase operation
BCF INTCON, GIE ; disable interrupts
Required MOVLW 55h
Sequence MOVWF NVMCON2 ; write 55h
MOVLW AAh
MOVWF NVMCON2 ; write AAh
BSF NVMCON1, WR ; start erase (CPU stalls)
BSF INTCON, GIE ; re-enable interrupts

2016 Microchip Technology Inc. Preliminary DS40001816C-page 132


PIC18(L)F26/45/46K40
FIGURE 11-7: PFM ROW ERASE 11.1.6 WRITING TO PROGRAM FLASH
FLOWCHART MEMORY
The programming write block size is described in
Start Erase Operation Table 11-3. Word or byte programming is not supported.
Table writes are used internally to load the holding
registers needed to program the Flash memory. There
Select Memory: are only as many holding registers as there are bytes in
PFM (NVMREGS<1:0> = 10) a write block. Refer to Table 11-3 for write latch size.
Since the table latch (TABLAT) is only a single byte, the
TBLWT instruction needs to be executed multiple times
Load Table Pointer register with for each programming operation. The write protection
address of the block being erased state is ignored for this operation. All of the table write
operations will essentially be short writes because only
the holding registers are written. NVMIF is not affected
Select Erase Operation while writing to the holding registers.
(FREE = 1)
After all the holding registers have been written, the
programming operation of that block of memory is
started by configuring the NVMCON1 register for a
Enable Write/Erase Operation
(WREN = 1)
program memory write and performing the long write
sequence.
If the PFM address in the TBLPTR is write-protected or
Disable Interrupts if TBLPTR points to an invalid location, the WR bit is
(GIE = 0) cleared without any effect and the WREER is signaled.
The long write is necessary for programming the
Unlock Sequence
internal Flash. CPU operation is suspended during a
long write cycle and resumes when the operation is
(Figure 11-6)
complete. The long write operation completes in one
instruction cycle. When complete, WR is cleared in
hardware and NVMIF is set and an interrupt will occur if
CPU stalls while Erase operation
completes (2 ms typical) NVMIE is also set. The latched data is reset to all 1s.
WREN is not changed.
The internal programming timer controls the write time.
Enable Interrupts The write/erase voltages are generated by an on-chip
(GIE = 1) charge pump, rated to operate over the voltage range of
the device.

Disable Write/Erase Operation


Note: The default value of the holding registers on
(WREN = 0) device Resets and after write operations is
FFh. A write of FFh to a holding register
does not modify that byte. This means that
individual bytes of program memory may
End Erase Operation
be modified, provided that the change does
not attempt to change any bit from a 0 to a
1. When modifying individual bytes, it is
not necessary to load all holding registers
before executing a long write operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 133


PIC18(L)F26/45/46K40
FIGURE 11-8: TABLE WRITES TO PROGRAM FLASH MEMORY

TABLAT
Write Register

8 8 8 8

TBLPTR = xxxx00 TBLPTR = xxxx01 TBLPTR = xxxx02 TBLPTR = xxxxYY(1)

Holding Register Holding Register Holding Register Holding Register

Program Memory

Note 1: Refer to Table 11-3 for number of holding registers (e.g., YY = 3F for 64 holding registers).

11.1.6.1 Program Flash Memory Write


Sequence
The sequence of events for programming an internal
program memory location should be:
1. Read appropriate number of bytes into RAM.
Refer to Table 11-2 for Write latch size.
2. Update data values in RAM as necessary.
3. Load Table Pointer register with address being
erased.
4. Execute the block erase procedure.
5. Load Table Pointer register with address of first
byte being written.
6. Write the n-byte block into the holding registers
with auto-increment. Refer to Table 11-2 for
Write latch size.
7. Set NVMREG<1:0> bits to point to program
memory.
8. Clear FREE bit and set WREN bit in NVMCON1
register.
9. Disable interrupts.
10. Execute the unlock sequence (see Section
11.1.4 NVM Unlock Sequence).
11. WR bit is set in NVMCON1 register.
12. The CPU will stall for the duration of the write
(about 2 ms using internal timer).
13. Re-enable interrupts.
14. Verify the memory (table read).
This procedure will require about 6 ms to update each
write block of memory. An example of the required code
is given in Example 11-4.
Note: Before setting the WR bit, the Table
Pointer address needs to be within the
intended address range of the bytes in the
holding registers.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 134


PIC18(L)F26/45/46K40
EXAMPLE 11-4: WRITING TO PROGRAM FLASH MEMORY
MOVLW D'64 ; number of bytes in erase block
MOVWF COUNTER
MOVLW BUFFER_ADDR_HIGH ; point to buffer
MOVWF FSR0H
MOVLW BUFFER_ADDR_LOW
MOVWF FSR0L
MOVLW CODE_ADDR_UPPER ; Load TBLPTR with the base
MOVWF TBLPTRU ; address of the memory block
MOVLW CODE_ADDR_HIGH
MOVWF TBLPTRH
MOVLW CODE_ADDR_LOW
MOVWF TBLPTRL
READ_BLOCK
TBLRD*+ ; read into TABLAT, and inc
MOVF TABLAT, W ; get data
MOVWF POSTINC0 ; store data
DECFSZ COUNTER ; done?
BRA READ_BLOCK ; repeat
MODIFY_WORD
MOVLW BUFFER_ADDR_HIGH ; point to buffer
MOVWF FSR0H
MOVLW BUFFER_ADDR_LOW
MOVWF FSR0L
MOVLW NEW_DATA_LOW ; update buffer word
MOVWF POSTINC0
MOVLW NEW_DATA_HIGH
MOVWF INDF0
ERASE_BLOCK
MOVLW CODE_ADDR_UPPER ; load TBLPTR with the base
MOVWF TBLPTRU ; address of the memory block
MOVLW CODE_ADDR_HIGH
MOVWF TBLPTRH
MOVLW CODE_ADDR_LOW
MOVWF TBLPTRL
BCF NVMCON1, NVMREG0 ; point to Program Flash Memory
BSF NVMCON1, NVMREG1 ; point to Program Flash Memory
BSF NVMCON1, WREN ; enable write to memory
BSF NVMCON1, FREE ; enable Erase operation
BCF INTCON, GIE ; disable interrupts
MOVLW 55h
Required MOVWF NVMCON2 ; write 55h
Sequence MOVLW AAh
MOVWF NVMCON2 ; write 0AAh
BSF NVMCON1, WR ; start erase (CPU stall)
BSF INTCON, GIE ; re-enable interrupts
TBLRD*- ; dummy read decrement
MOVLW BUFFER_ADDR_HIGH ; point to buffer
MOVWF FSR0H
MOVLW BUFFER_ADDR_LOW
MOVWF FSR0L
WRITE_BUFFER_BACK
MOVLW BlockSize ; number of bytes in holding register
MOVWF COUNTER
MOVLW D64/BlockSize ; number of write blocks in 64 bytes
MOVWF COUNTER2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 135


PIC18(L)F26/45/46K40
EXAMPLE 11-4: WRITING TO PROGRAM FLASH MEMORY (CONTINUED)
WRITE_BYTE_TO_HREGS
MOVF POSTINC0, W ; get low byte of buffer data
MOVWF TABLAT ; present data to table latch
TBLWT+* ; write data, perform a short write
; to internal TBLWT holding register.
DECFSZ COUNTER ; loop until holding registers are full
BRA WRITE_WORD_TO_HREGS
PROGRAM_MEMORY
BCF NVMCON1, NVMREG0 ; point to Program Flash Memory
BSF NVMCON1, NVMREG1 ; point to Program Flash Memory
BSF NVMCON1, WREN ; enable write to memory
BCF NVMCON1, FREE ; enable write to memory
BCF INTCON, GIE ; disable interrupts
MOVLW 55h
Required MOVWF NVMCON2 ; write 55h
Sequence MOVLW 0AAh
MOVWF NVMCON2 ; write 0AAh
BSF NVMCON1, WR ; start program (CPU stall)
DCFSZ COUNTER2 ; repeat for remaining write blocks
BRA WRITE_BYTE_TO_HREGS
BSF INTCON, GIE ; re-enable interrupts
BCF NVMCON1, WREN ; disable write to memory

2016 Microchip Technology Inc. Preliminary DS40001816C-page 136


PIC18(L)F26/45/46K40
FIGURE 11-9: PROGRAM FLASH MEMORY (PFM) WRITE FLOWCHART

Rev. 10-000049B
12/4/2015

Start
Write Operation

Determine number of
words to be written into Load the value to write
PFM. The number of TABLAT
words cannot exceed the
number of words per row
(word_cnt)

Update the word counter


Write Latches to PFM
(word_cnt--)

Select access to PFM


locations using
NVMREG<1:0> bits
Disable Interrupts
(GIE = 0)
Last word to Yes
write ?
Select Row Address
TBLPTR
No
Unlock Sequence(1)

Disable Interrupts
Select Write Operation (GIE = 0)
(FREE = 0)
CPU stalls while Write
operation completes
(2 ms typical)
Load Write Latches Only Unlock Sequence(1)

Enable Write/Erase
Operation (WREN = 1) No delay when writing to Re-enable Interrupts
PFM Latches (GIE = 1)

Disable Write/Erase
Operation (WREN = 0)

Re-enable Interrupts
(GIE = 1)

End
Write Operation

Increment Address
TBLPTR++

2016 Microchip Technology Inc. Preliminary DS40001816C-page 137


PIC18(L)F26/45/46K40
11.1.6.2 Write Verify 11.1.6.3 Unexpected Termination of Write
Depending on the application, good programming Operation
practice may dictate that the value written to the If a write is terminated by an unplanned event, such as
memory should be verified against the original value. loss of power or an unexpected Reset, the memory
This should be used in applications where excessive location just programmed should be verified and
writes can stress bits near the specification limit. Since reprogrammed if needed. If the write operation is
program memory is stored as a full page, the stored interrupted by a MCLR Reset or a WDT Time-out Reset
program memory contents are compared with the during normal operation, the WRERR bit will be set
intended data stored in RAM after the last write is which the user can check to decide whether a rewrite
complete. of the location(s) is needed.

FIGURE 11-10: PROGRAM FLASH 11.1.6.4 Protection Against Spurious Writes


MEMORY VERIFY A write sequence is valid only when both the following
FLOWCHART conditions are met, this prevents spurious writes which
Rev. 10-000051B
might lead to data corruption.
12/4/2015

1. The WR bit is gated through the WREN bit. It is


suggested to have the WREN bit cleared at all
times except during memory writes. This
Start prevents memory writes if the WR bit gets set
Verify Operation accidentally.
2. The NVM unlock sequence must be performed
each time before a write operation.
This routine assumes that the last
row of data written was from an 11.2 User ID, Device ID and
image saved on RAM. This image
will be used to verify the data Configuration Word Access
currently stored in PFM
When NVMREG<1:0> = 0x01 or 0x11 in the
NVMCON1 register, the User IDs, Device ID/
Revision ID and Configuration Words can be
accessed. Different access may exist for reads and
writes (see Table 11-3).
Read Operation(1)
11.2.1 Reading Access
The user can read from these blocks by setting the
NVMREG bits to 0x01 or 0x11. The user needs to load
the address into the TBLPTR registers. Executing a
TBLRD after that moves the byte pointed to the TAB-
NVMDAT = No
RAM image ? LAT register. The CPU operation is suspended during
the read and resumes after. When read access is initi-
ated on an address outside the parameters listed in
Yes
Fail Table 11-3, the TABLAT register is cleared, reading
Verify Operation back 0s.

11.2.2 Writing Access


No Last word ? The WREN bit in NVMCON1 must be set to enable
writes. This prevents accidental writes to the CONFIG
Yes
words due to errant (unexpected) code execution. The
WREN bit should be kept clear at all times, except
when updating the CONFIG words. The WREN bit is
not cleared by hardware. The WR bit will be inhibited
End
Verify Operation from being set unless the WREN bit is set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 138


PIC18(L)F26/45/46K40
The user needs to load the TBLPTR and TABLAT reg-
ister with the address and data byte respectively before
executing the write command. An unlock sequence
needs to be followed for writing to the USER IDs/
DEVICE IDs/CONFIG words (Section 11.1.4, NVM
Unlock Sequence). If WRTC = 0 or if TBLPTR points
an invalid address location (see Table 11-3), WR bit is
cleared without any effect and WRERR is set.
A single CONFIG word byte is written at once and the
operation includes an implicit erase cycle for that byte
(it is not necessary to set FREE). CPU execution is
stalled and at the completion of the write cycle, the WR
bit is cleared in hardware and the NVM Interrupt Flag
bit (NVMIF) is set. The new CONFIG value takes effect
when the CPU resumes operation.

TABLE 11-4: USER ID, DEV/REV ID AND CONFIGURATION WORD ACCESS (NVMREG<1:0> = X1)
Address Function Read Access Write Access
20 0000h-20 000Fh User IDs Yes Yes
3F FFFCh-3F FFFFh Revision ID/Device ID Yes No
30 0000h-30 000Bh Configuration Words 1-6 Yes Yes

2016 Microchip Technology Inc. Preliminary DS40001816C-page 139


PIC18(L)F26/45/46K40
11.3 Data EEPROM Memory 11.3.2 NVMCON1 AND NVMCON2
REGISTERS
The data EEPROM is a nonvolatile memory array,
separate from the data RAM and program memory, Access to the data EEPROM is controlled by two
which is used for long-term storage of program data. It registers: NVMCON1 and NVMCON2. These are the
is not directly mapped in either the register file or same registers which control access to the program
program memory space but is indirectly addressed memory and are used in a similar manner for the data
through the Special Function Registers (SFRs). The EEPROM.
EEPROM is readable and writable during normal The NVMCON1 register (Register 11-1) is the control
operation over the entire VDD range. register for data and program memory access. Control
Four SFRs are used to read and write to the data bits NVMREG<1:0> determine if the access will be to
EEPROM as well as the program memory. They are: program, Data EEPROM Memory or the User IDs,
Configuration bits, Revision ID and Device ID.
NVMCON1
NVMCON2 The WREN bit, when set, will allow a write operation.
On power-up, the WREN bit is clear.
NVMDAT
NVMADRL The WRERR bit is set by hardware when the WR bit is
set and cleared when the internal programming timer
NVMADRH(1)
expires and the write operation is complete.
Note 1: NVMADRH register is not implemented
on PIC18(L)F45K40. The WR control bit initiates write operations. The bit
can be set but not cleared by software. It is cleared only
The data EEPROM allows byte read and write. When by hardware at the completion of the write operation.
interfacing to the data memory block, NVMDAT holds
the 8-bit data for read/write and the The NVMIF interrupt flag bit of the PIR7 register is set
NVMADRH:NVMADRL register pair hold the address when the write is complete. It must be cleared by
of the EEPROM location being accessed. software.
The EEPROM data memory is rated for high erase/write Control bits, RD and WR, start read and erase/write
cycle endurance. A byte write automatically erases the operations, respectively. These bits are set by firmware
location and writes the new data (erase-before-write). and cleared by hardware at the completion of the
The write time is controlled by an internal programming operation.
timer; it will vary with voltage and temperature as well as
The RD bit cannot be set when accessing program
from chip-to-chip. Please refer to the Data EEPROM
memory (NVMREG<1:0> = 0x10). Program memory is
Memory parameters in Section 37.0 Electrical
read using table read instructions. See Section
Specifications for limits.
11.1.1 Table Reads and Table Writes regarding
table reads.
11.3.1 NVMADRL AND NVMADRH
REGISTERS
The NVMADRH:NVMADRL registers are used to
address the data EEPROM for read and write
operations.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 140


PIC18(L)F26/45/46K40
11.3.3 READING THE DATA EEPROM 11.3.4 WRITING TO THE DATA EEPROM
MEMORY MEMORY
To read a data memory location, the user must write the To write an EEPROM data location, the address must
address to the NVMADRL and NVMADRH register first be written to the NVMADRL and NVMADRH
pair, clear NVMREG<1:0> control bit in NVMCON1 register pair and the data written to the NVMDAT
register to access Data EEPROM locations and then register. The sequence in Example 11-6 must be
set control bit, RD. The data is available on the very followed to initiate the write cycle.
next instruction cycle; therefore, the NVMDAT register The write will not begin if NVM Unlock sequence,
can be read by the next instruction. NVMDAT will hold described in Section 11.1.4 NVM Unlock
this value until another read operation, or until it is Sequence, is not exactly followed for each byte. It is
written to by the user (during a write operation). strongly recommended that interrupts be disabled
The basic process is shown in Example 11-5. during this code segment.
Additionally, the WREN bit in NVMCON1 must be set to
FIGURE 11-11: PROGRAM FLASH enable writes. This mechanism prevents accidental
MEMORY READ writes to data EEPROM due to unexpected code
FLOWCHART execution (i.e., runaway programs). The WREN bit
should be kept clear at all times, except when updating
the EEPROM. The WREN bit is not cleared by
Start Read Operation hardware.
After a write sequence has been initiated, NVMCON1,
NVMADRL, NVMADRH and NVMDAT cannot be
Select Memory:
Program Flash Memory, EEPROM,
modified. The WR bit will be inhibited from being set
Config. Words, User ID (NVMREG) unless the WREN bit is set. Both WR and WREN
cannot be set with the same instruction.

Select Word Address


After a write sequence has been initiated, clearing the
(NVMADRH:NVMADRL) WREN bit will not affect this write cycle. A single Data
EEPROM word is written and the operation includes an
implicit erase cycle for that word (it is not necessary to
Initiate Read Operation
set FREE). CPU execution continues in parallel and at
(RD = 1) the completion of the write cycle, the WR bit is cleared
in hardware and the NVM Interrupt Flag bit (NVMIF) is
set. The user can either enable this interrupt or poll this
Data read now in bit. NVMIF must be cleared by software.
NVMDAT

End Read Operation

2016 Microchip Technology Inc. Preliminary DS40001816C-page 141


PIC18(L)F26/45/46K40
11.3.5 WRITE VERIFY
Depending on the application, good programming
practice may dictate that the value written to the
memory should be verified against the original value.
This should be used in applications where excessive
writes can stress bits near the specification limit.

EXAMPLE 11-5: DATA EEPROM READ


; Data Memory Address to read
BCF NVMCON1, NVMREG0 ; Setup Data EEPROM Access
BCF NVMCON1, NVMREG1 ; Setup Data EEPROM Access
MOVF EE_ADDRL, W ;
MOVWF NVMADRL ; Setup Address low byte
MOVF EE_ADDRH, W ;
MOVWF NVMADRH ; Setup Address high byte (if applicable)
BSF NVMCON1, RD ; Issue EE Read
MOVF NVMDAT, W ; W = EE_DATA

EXAMPLE 11-6: DATA EEPROM WRITE


; Data Memory Address to write
BCF NVMCON1, NVMREG0 ; Setup Data EEPROM access
BCF NVMCON1, NVMREG1 ; Setup Data EEPROM access
MOVF EE_ADDRL, W ;
MOVWF NVMADRL ; Setup Address low byte
MOVF EE_ADDRH, W ;
MOVWF NVMADRH ; Setup Address high byte (if applicable)
; Data Memory Value to write
MOVF EE_DATA, W ;
MOVWF NVMDAT ;
; Enable writes
BSF NVMCON1, WREN ;
; Disable interrupts
BCF INTCON, GIE ;
; Required unlock sequence
MOVLW 55h ;
MOVWF NVMCON2 ;
MOVLW AAh ;
MOVWF NVMCON2 ;
; Set WR bit to begin write
BSF NVMCON1, WR ;
; Wait for write to complete
BTFSC NVMCON1, WR
BRA $-2
; Enable INT
BSF INTCON, GIE ;
; Disable writes
BCF NVMCON1, WREN ;

2016 Microchip Technology Inc. Preliminary DS40001816C-page 142


PIC18(L)F26/45/46K40
11.3.6 OPERATION DURING CODE-
PROTECT
Data EEPROM Memory has its own code-protect bits in
Configuration Words. External read and write operations
are disabled if code protection is enabled.
If the Data EEPROM is write-protected or if NVMADR
points an invalid address location, the WR bit is cleared
without any effect. WRERR is signaled in this scenario.

11.3.7 PROTECTION AGAINST SPURIOUS


WRITE
There are conditions when the user may not want to
write to the Data EEPROM Memory. To protect against
spurious EEPROM writes, various mechanisms have
been implemented. On power-up, the WREN bit is
cleared. In addition, writes to the EEPROM are blocked
during the Power-up Timer period (TPWRT).
The unlock sequence and the WREN bit together help
prevent an accidental write during brown-out, power
glitch or software malfunction.

11.3.8 ERASING THE DATA EEPROM


MEMORY
Data EEPROM Memory can be erased by writing 0xFF
to all locations in the Data EEPROM Memory that
needs to be erased.

EXAMPLE 11-7: DATA EEPROM REFRESH ROUTINE


CLRF NVMADRL ; Clear address low byte register
CLRF NVMADRH ; Clear address high byte register (if applicable)
BCF NVMCON1, NVMREG0 ; Set access for EEPROM
BCF NVMCON1, NVMREG1 ; Set access for EEPROM
SETF NVMDAT ; Load 0xFF to data register
BCF INTCON, GIE ; Disable interrupts
BSF NVMCON1, WREN ; Enable writes
Loop ; Loop to refresh array
MOVLW 0x55 ; Initiate unlock sequence
MOVWF NVMCON2 ;
MOVLW 0xAA ;
MOVWF NVMCON2 ;
BSF NVMCON1, WR ; Set WR bit to begin write
BTFSC NVMCON1, WR ; Wait for write to complete
BRA $-2
INCFSZ NVMADRL, F ; Increment address low byte
BRA Loop ; Not zero, do it again

//The following 4 lines of code are not needed if the part doesn't have NVMADRH register
INCF NVMADRH, F ; Decrement address high byte
MOVLW 0x03 ; Move 0x03 to working register
CPFSGT NVMADRH ; Compare address high byte with working register
BRA Loop ; Skip if greater than working register
; Else go back to erase loop

BCF NVMCON1, WREN ; Disable writes


BSF INTCON, GIE ; Enable interrupts

2016 Microchip Technology Inc. Preliminary DS40001816C-page 143


PIC18(L)F26/45/46K40
11.4 Register Definitions: Nonvolatile Memory
REGISTER 11-1: NVMCON1: NONVOLATILE MEMORY CONTROL 1 REGISTER
R/W-0/0 R/W-0/0 U-0 R/S/HC-0/0 R/W/HS-x/q R/W-0/0 R/S/HC-0/0 R/S/HC-0/0
NVMREG<1:0> FREE WRERR WREN WR RD
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit HC = Bit is cleared by hardware
x = Bit is unknown -n = Value at POR S = Bit can be set by software, but not cleared
0 = Bit is cleared 1 = Bit is set U = Unimplemented bit, read as 0

bit 7-6 NVMREG<1:0>: NVM Region Selection bit


10 =Access PFM Locations
x1 = Access User IDs, Configuration Bits, Rev ID and Device ID
00 = Access Data EEPROM Memory Locations
bit 5 Unimplemented: Read as 0
bit 4 FREE: Program Flash Memory Erase Enable bit(1)
1 = Performs an erase operation on the next WR command
0 = The next WR command performs a write operation
bit 3 WRERR: Write-Reset Error Flag bit(2,3,4)
1 = A write operation was interrupted by a Reset (hardware set),
or WR was written to 1b1 when an invalid address is accessed (Table 10-1, Table 11-1)
or WR was written to 1b1 when NVMREG<1:0> and address do not point to the same region
or WR was written to 1b1 when a write-protected address is accessed (Table 10-2).
0 = All write operations have completed normally
bit 2 WREN: Program/Erase Enable bit
1 = Allows program/erase and refresh cycles
0 = Inhibits programming/erasing and user refresh of NVM
bit 1 WR: Write Control bit(5,6,7)
When NVMREG points to a Data EEPROM Memory location:
1 = Initiates an erase/program cycle at the corresponding Data EEPROM Memory location
When NVMREG points to a PFM location:
1 = Initiates the PFM write operation with data from the holding registers
0 = NVM program/erase operation is complete and inactive
bit 0 RD: Read Control bit(8)
1 = Initiates a read at address pointed by NVMREG and NVMADR, and loads data into NVMDAT
0 = NVM read operation is complete and inactive

Note 1: This can only be used with PFM.


2: This bit is set when WR = 1 and clears when the internal programming timer expires or the write is
completed successfully.
3: Bit must be cleared by the user; hardware will not clear this bit.
4: Bit may be written to 1 by the user in order to implement test sequences.
5: This bit can only be set by following the unlock sequence of Section 11.1.4 NVM Unlock Sequence.
6: Operations are self-timed and the WR bit is cleared by hardware when complete.
7: Once a write operation is initiated, setting this bit to zero will have no effect.
8: The bit can only be set in software. The bit is cleared by hardware when the operation is complete.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 144


PIC18(L)F26/45/46K40

REGISTER 11-2: NVMCON2: NONVOLATILE MEMORY CONTROL 2 REGISTER


R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
NVMCON2<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
x = Bit is unknown 0 = Bit is cleared 1 = Bit is set
-n = Value at POR

bit 7-0 NVMCON2<7:0>:


Refer to Section 11.1.4 NVM Unlock Sequence.

Note 1: This register always reads zeros, regardless of data written.

Register 11-3: NVMADRL: Data EEPROM Memory Address Low


R/W-x/0 R/W-x/0 R/W-x/0 R/W-x/0 R/W-x/0 R/W-x/0 R/W-x/0 R/W-x/0
NVMADR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
x = Bit is unknown 0 = Bit is cleared 1 = Bit is set
-n = Value at POR

bit 7-0 NVMADR<7:0>: EEPROM Read Address bits

REGISTER 11-4: NVMADRH: DATA EEPROM MEMORY ADDRESS HIGH(1)


U-0 U-0 U-0 U-0 U-0 U-0 R/W-x/u R/W-x/u
NVMADR<9:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
x = Bit is unknown 0 = Bit is cleared 1 = Bit is set
-n = Value at POR

bit 7-2 Unimplemented: Read as 0


bit 1-0 NVMADR<9:8>: EEPROM Read Address bits

Note 1: The NVMADRH register is not implemented on PIC18(L)F45K40.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 145


PIC18(L)F26/45/46K40

REGISTER 11-5: NVMDAT: DATA EEPROM MEMORY DATA


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
NVMDAT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
x = Bit is unknown 0 = Bit is cleared 1 = Bit is set
-n = Value at POR

bit 7-0 NVMDAT<7:0>: The value of the data memory word returned from NVMADR after a Read command,
or the data written by a Write command.

TABLE 11-5: SUMMARY OF REGISTERS ASSOCIATED WITH DATA EEPROM MEMORY


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
NVMCON1 NVMREG<1:0> FREE WRERR WREN WR RD 144
NVMCON2 Unlock Pattern 145
NVMADRL NVMADR<7:0> 145
NVMADRH(1) NVMADR<9:8> 145
NVMDAT NVMDAT<7:0> 146
TBLPTRU Program Memory Table Pointer (TBLPTR<21:16>) 126*
TBLPTRH Program Memory Table Pointer (TBLPTR<15:8>) 126*
TBLPTRL Program Memory Table Pointer (TBLPTR<7:0>) 126*
TABLAT TABLAT 125*
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE7 SCANIE CRCIE NVMIE CWG1IE 185
PIR7 SCANIF CRCIF NVMIF CWG1IF 177
IPR7 SCANIP CRCIP NVMIP CWG1IP 193
Legend: = unimplemented, read as 0. Shaded bits are not used during EEPROM access.
*Page provides register information.
Note 1: The NVMADRH register is not implemented on PIC18(L)F26/45/46K40.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 146


PIC18(L)F26/45/46K40
12.0 8x8 HARDWARE MULTIPLIER EXAMPLE 12-1: 8x8 UNSIGNED MULTIPLY
ROUTINE
12.1 Introduction MOVF ARG1, W ;
MULWF ARG2 ; ARG1 * ARG2 ->
All PIC18 devices include an 8x8 hardware multiplier ; PRODH:PRODL
as part of the ALU. The multiplier performs an unsigned
operation and yields a 16-bit result that is stored in the
product register pair, PRODH:PRODL. The multipliers EXAMPLE 12-2: 8x8 SIGNED MULTIPLY
operation does not affect any flags in the STATUS ROUTINE
register.
MOVF ARG1, W
Making multiplication a hardware operation allows it to MULWF ARG2 ; ARG1 * ARG2 ->
be completed in a single instruction cycle. This has the ; PRODH:PRODL
advantages of higher computational throughput and BTFSC ARG2, SB ; Test Sign Bit
reduced code size for multiplication algorithms and SUBWF PRODH, F ; PRODH = PRODH
allows the PIC18 devices to be used in many applica- ; - ARG1
tions previously reserved for digital signal processors. MOVF ARG2, W
BTFSC ARG1, SB ; Test Sign Bit
A comparison of various hardware and software
SUBWF PRODH, F ; PRODH = PRODH
multiply operations, along with the savings in memory ; - ARG2
and execution time, is shown in Table 12-1.

12.2 Operation
Example 12-1 shows the instruction sequence for an
8x8 unsigned multiplication. Only one instruction is
required when one of the arguments is already loaded in
the WREG register.
Example 12-2 shows the sequence to do an 8x8 signed
multiplication. To account for the sign bits of the
arguments, each arguments Most Significant bit (MSb)
is tested and the appropriate subtractions are done.

TABLE 12-1: PERFORMANCE COMPARISON FOR VARIOUS MULTIPLY OPERATIONS


Program Time
Cycles
Routine Multiply Method Memory
(Max) @ 64 MHz @ 40 MHz @ 10 MHz @ 4 MHz
(Words)
Without hardware multiply 13 69 4.3 s 6.9 s 27.6 s 69 s
8x8 unsigned
Hardware multiply 1 1 62.5 ns 100 ns 400 ns 1 s
Without hardware multiply 33 91 5.7 s 9.1 s 36.4 s 91 s
8x8 signed
Hardware multiply 6 6 375 ns 600 ns 2.4 s 6 s
Without hardware multiply 21 242 15.1 s 24.2 s 96.8 s 242 s
16x16 unsigned
Hardware multiply 28 28 1.8 s 2.8 s 11.2 s 28 s
Without hardware multiply 52 254 15.9 s 25.4 s 102.6 s 254 s
16x16 signed
Hardware multiply 35 40 2.5 s 4.0 s 16.0 s 40 s

2016 Microchip Technology Inc. Preliminary DS40001816C-page 147


PIC18(L)F26/45/46K40
Example 12-3 shows the sequence to do a 16 x 16 EXAMPLE 12-4: 16 x 16 SIGNED
unsigned multiplication. Equation 12-1 shows the MULTIPLY ROUTINE
algorithm that is used. The 32-bit result is stored in four MOVF ARG1L, W
registers (RES<3:0>). MULWF ARG2L ; ARG1L * ARG2L ->
; PRODH:PRODL
MOVFF PRODH, RES1 ;
EQUATION 12-1: 16 x 16 UNSIGNED MOVFF PRODL, RES0 ;
MULTIPLICATION ;
MOVF ARG1H, W
ALGORITHM MULWF ARG2H ; ARG1H * ARG2H ->
; PRODH:PRODL
RES3:RES0 = ARG1H:ARG1L ARG2H:ARG2L MOVFF PRODH, RES3 ;
= (ARG1H ARG2H 216) + MOVFF PRODL, RES2 ;
(ARG1H ARG2L 28) + ;
(ARG1L ARG2H 28) + MOVF ARG1L, W
MULWF ARG2H ; ARG1L * ARG2H ->
(ARG1L ARG2L) ; PRODH:PRODL
MOVF PRODL, W ;
ADDWF RES1, F ; Add cross
EXAMPLE 12-3: 16 x 16 UNSIGNED MOVF PRODH, W ; products
MULTIPLY ROUTINE ADDWFC
CLRF
RES2, F
WREG
;
;
MOVF ARG1L, W ADDWFC RES3, F ;
MULWF ARG2L ; ARG1L * ARG2L-> ;
; PRODH:PRODL MOVF ARG1H, W ;
MOVFF PRODH, RES1 ; MULWF ARG2L ; ARG1H * ARG2L ->
MOVFF PRODL, RES0 ; ; PRODH:PRODL
; MOVF PRODL, W ;
MOVF ARG1H, W ADDWF RES1, F ; Add cross
MULWF ARG2H ; ARG1H * ARG2H-> MOVF PRODH, W ; products
; PRODH:PRODL ADDWFC RES2, F ;
MOVFF PRODH, RES3 ; CLRF WREG ;
MOVFF PRODL, RES2 ; ADDWFC RES3, F ;
; ;
MOVF ARG1L, W BTFSS ARG2H, 7 ; ARG2H:ARG2L neg?
MULWF ARG2H ; ARG1L * ARG2H-> BRA SIGN_ARG1 ; no, check ARG1
; PRODH:PRODL MOVF ARG1L, W ;
MOVF PRODL, W ; SUBWF RES2 ;
ADDWF RES1, F ; Add cross MOVF ARG1H, W ;
MOVF PRODH, W ; products SUBWFB RES3
ADDWFC RES2, F ; ;
CLRF WREG ; SIGN_ARG1
ADDWFC RES3, F ; BTFSS ARG1H, 7 ; ARG1H:ARG1L neg?
; BRA CONT_CODE ; no, done
MOVF ARG1H, W ; MOVF ARG2L, W ;
MULWF ARG2L ; ARG1H * ARG2L-> SUBWF RES2 ;
; PRODH:PRODL MOVF ARG2H, W ;
MOVF PRODL, W ; SUBWFB RES3
ADDWF RES1, F ; Add cross ;
MOVF PRODH, W ; products CONT_CODE
ADDWFC RES2, F ; :
CLRF WREG ;
ADDWFC RES3, F ;

Example 12-4 shows the sequence to do a 16 x 16


signed multiply. Equation 12-2 shows the algorithm
used. The 32-bit result is stored in four registers
(RES<3:0>). To account for the sign bits of the argu-
ments, the MSb for each argument pair is tested and
the appropriate subtractions are done.

EQUATION 12-2: 16 x 16 SIGNED


MULTIPLICATION
ALGORITHM
RES3:RES0 = ARG1H:ARG1L ARG2H:ARG2L
= (ARG1H ARG2H 216) +
(ARG1H ARG2L 28) +
(ARG1L ARG2H 28) +
(ARG1L ARG2L) +
(-1 ARG2H<7> ARG1H:ARG1L 216) +
(-1 ARG1H<7> ARG2H:ARG2L 216)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 148


PIC18(L)F26/45/46K40
13.0 CYCLIC REDUNDANCY CHECK
(CRC) MODULE WITH MEMORY
SCANNER
The Cyclic Redundancy Check (CRC) module provides
a software-configurable hardware-implemented CRC
checksum generator. This module includes the following
features:
Any standard CRC up to 16 bits can be used
Configurable Polynomial
Any seed value up to 16 bits can be used
Standard and reversed bit order available
Augmented zeros can be added automatically or
by the user
Memory scanner for fast CRC calculations on
program memory user data
Software loadable data registers for
communication CRCs

13.1 CRC Module Overview


The CRC module provides a means for calculating a
check value of program memory. The CRC module is
coupled with a memory scanner for faster CRC
calculations. The memory scanner can automatically
provide data to the CRC module. The CRC module can
also be operated by directly writing data to SFRs,
without using a scanner.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 149


PIC18(L)F26/45/46K40
13.2 Register Definitions: CRC and Scanner Control
Long bit name prefixes for the CRC and Scanner periph-
erals are shown in Table 13-1. Refer to Section
1.4.2.2 Long Bit Names for more information.
TABLE 13-1:
Peripheral Bit Name Prefix
CRC CRC

REGISTER 13-1: CRCCON0: CRC CONTROL REGISTER 0


R/W-0/0 R/W-0/0 R-0 R/W-0/0 U-0 U-0 R/W-0/0 R-0
EN GO BUSY ACCM SHIFTM FULL
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EN: CRC Enable bit


1 = CRC module is released from Reset
0 = CRC is disabled and consumes no operating current
bit 6 GO: CRC Start bit
1 = Start CRC serial shifter
0 = CRC serial shifter turned off
bit 5 BUSY: CRC Busy bit
1 = Shifting in progress or pending
0 = All valid bits in shifter have been shifted into accumulator and EMPTY = 1
bit 4 ACCM: Accumulator Mode bit
1 = Data is augmented with zeros
0 = Data is not augmented with zeros
bit 3-2 Unimplemented: Read as 0
bit 1 SHIFTM: Shift Mode bit
1 = Shift right (LSb)
0 = Shift left (MSb)
bit 0 FULL: Data Path Full Indicator bit
1 = CRCDATH/L registers are full
0 = CRCDATH/L registers have shifted their data into the shifter

REGISTER 13-2: CRCCON1: CRC CONTROL REGISTER 1


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
DLEN<3:0> PLEN<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-4 DLEN<3:0>: Data Length bits


Denotes the length of the data word -1 (See Example 13-1)
bit 3-0 PLEN<3:0>: Polynomial Length bits
Denotes the length of the polynomial -1 (See Example 13-1)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 150


PIC18(L)F26/45/46K40

REGISTER 13-3: CRCDATH: CRC DATA HIGH BYTE REGISTER


R/W-xx R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
DATA<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 DATA<15:8>: CRC Input/Output Data bits

REGISTER 13-4: CRCDATL: CRC DATA LOW BYTE REGISTER


R/W-xx R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
DATA<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 DATA<7:0>: CRC Input/Output Data bits


Writing to this register fills the shifter.

REGISTER 13-5: CRCACCH: CRC ACCUMULATOR HIGH BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ACC<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ACC<15:8>: CRC Accumulator Register bits


Writing to this register writes to the CRC accumulator register. Reading from
this register reads the CRC accumulator.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 151


PIC18(L)F26/45/46K40

REGISTER 13-6: CRCACCL: CRC ACCUMULATOR LOW BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ACC<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ACC<7:0>: CRC Accumulator Register bits


Writing to this register writes to the CRC accumulator register through the CRC write bus. Reading
from this register reads the CRC accumulator.

REGISTER 13-7: CRCSHIFTH: CRC SHIFT HIGH BYTE REGISTER


R-0 R-0 R-0 R-0 R-0 R-0 R-0 R-0
SHIFT<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 SHIFT<15:8>: CRC Shifter Register bits


Reading from this register reads the CRC Shifter.

REGISTER 13-8: CRCSHIFTL: CRC SHIFT LOW BYTE REGISTER


R-0 R-0 R-0 R-0 R-0 R-0 R-0 R-0
SHIFT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 SHIFT<7:0>: CRC Shifter Register bits


Reading from this register reads the CRC Shifter.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 152


PIC18(L)F26/45/46K40

REGISTER 13-9: CRCXORH: CRC XOR HIGH BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
X<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 X<15:8>: XOR of Polynomial Term XN Enable bits

REGISTER 13-10: CRCXORL: CRC XOR LOW BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x U-1
X<7:1>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-1 X<7:1>: XOR of Polynomial Term XN Enable bits


bit 0 Unimplemented: Read as 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 153


PIC18(L)F26/45/46K40

REGISTER 13-11: SCANCON0: SCANNER ACCESS CONTROL REGISTER 0


R/W-0/0 R/W/HC-0/0 R-0 R-1 R/W-0/0 U-0 R/W-0/0 R/W-0/0
SCANEN SCANGO BUSY INVALID INTM MODE<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 SCANEN: Scanner Enable bit(1)


1 = Scanner is enabled
0 = Scanner is disabled, internal states are reset
bit 6 SCANGO: Scanner GO bit(2, 3)
1 = When the CRC sends a ready signal, NVM will be accessed according to MDx and data passed to
the client peripheral.
0 = Scanner operations will not occur
bit 5 BUSY: Scanner Busy Indicator bit(4)
1 = Scanner cycle is in process
0 = Scanner cycle is complete (or never started)
bit 4 INVALID: Scanner Abort Signal bit
1 = SCANLADRL/H/U has incremented to an invalid address(6) or the scanner was not setup correctly(7)
0 = SCANLADRL/H/U points to a valid address
bit 3 INTM: NVM Scanner Interrupt Management Mode Select bit
If MODE = 10:
This bit is ignored
If MODE = 01 (CPU is stalled until all data is transferred):
1 = SCANGO is overridden (to zero) during interrupt operation; scanner resumes after returning from
interrupt
0 = SCANGO is not affected by interrupts, the interrupt response will be affected
If MODE = 00 or 11:
1 = SCANGO is overridden (to zero) during interrupt operation; scan operations resume after returning
from interrupt
0 = Interrupts do not prevent NVM access
bit 2 Unimplemented: Read as 0
bit 1-0 MODE<1:0>: Memory Access Mode bits(5)
11 = Triggered mode
10 = Peek mode
01 = Burst mode
00 = Concurrent mode

Note 1: Setting SCANEN = 0 (SCANCON0 register) does not affect any other register content.
2: This bit is cleared when LADR > HADR (and a data cycle is not occurring).
3: If INTM = 1, this bit is overridden (to zero, but not cleared) during an interrupt response.
4: BUSY = 1 when the NVM is being accessed, or when the CRC sends a ready signal.
5: See Table 13-2 for more detailed information.
6: An invalid address can occur when the entire range of PFM is scanned and the value of LADR rolls over. An
invalid address can also occur if the value in the Scan Low address registers points to a location that is not
mapped in the memory map of the device.
7: CRCEN and CRCGO bits must be set before setting SCANGO bit. Refer to Section 13.9 Program Memory
Scan Configuration.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 154


PIC18(L)F26/45/46K40

REGISTER 13-12: SCANLADRU: SCAN LOW ADDRESS UPPER BYTE REGISTER


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
LADR<21:16> (1,2)

bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5-0 LADR<21:16>: Scan Start/Current Address bits(1,2)
Upper bits of the current address to be fetched from, value increments on each fetch of memory.

Note 1: Registers SCANLADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

REGISTER 13-13: SCANLADRH: SCAN LOW ADDRESS HIGH BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
LADR<15:8>(1, 2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 LADR<15:8>: Scan Start/Current Address bits(1, 2)


Most Significant bits of the current address to be fetched from, value increments on each fetch of
memory.
Note 1: Registers SCANLADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 155


PIC18(L)F26/45/46K40

REGISTER 13-14: SCANLADRL: SCAN LOW ADDRESS LOW BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
LADR<7:0>(1, 2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 LADR<7:0>: Scan Start/Current Address bits(1, 2)


Least Significant bits of the current address to be fetched from, value increments on each fetch of
memory
Note 1: Registers SCANLADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

REGISTER 13-15: SCANHADRU: SCAN HIGH ADDRESS UPPER BYTE REGISTER


U-0 U-0 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
HADR<21:16>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5-0 HADR<21:16>: Scan End Address bits(1, 2)
Upper bits of the address at the end of the designated scan

Note 1: Registers SCANHADRU/H/L form a 22-bit value but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 156


PIC18(L)F26/45/46K40

REGISTER 13-16: SCANHADRH: SCAN HIGH ADDRESS HIGH BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
HADR<15:8>(1, 2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 HADR<15:8>: Scan End Address bits(1, 2)


Most Significant bits of the address at the end of the designated scan
Note 1: Registers SCANHADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

REGISTER 13-17: SCANHADRL: SCAN HIGH ADDRESS LOW BYTE REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
HADR<7:0>(1, 2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 HADR<7:0>: Scan End Address bits(1, 2)


Least Significant bits of the address at the end of the designated scan
Note 1: Registers SCANHADRU/H/L form a 22-bit value, but are not guarded for atomic or asynchronous access;
registers should only be read or written while SCANGO = 0 (SCANCON0 register).
2: While SCANGO = 1 (SCANCON0 register), writing to this register is ignored.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 157


PIC18(L)F26/45/46K40

REGISTER 13-18: SCANTRIG: SCAN TRIGGER SELECTION REGISTER


U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TSEL<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-4 Unimplemented: Read as 0


bit 3-0 TSEL<3:0>: Scanner Data Trigger Input Selection bits

1111-1001 = Reserved
1000 = TMR6_postscaled
0111 = TMR5_output
0110 = TMR4_postscaled
0101 = TMR3_output
0100 = TMR2_postscaled
0011 = TMR1_output
0010 = TMR0_output
0001 = CLKREF_output
0000 = LFINTOSC

2016 Microchip Technology Inc. Preliminary DS40001816C-page 158


PIC18(L)F26/45/46K40
13.3 CRC Functional Overview
The CRC module can be used to detect bit errors in the
Flash memory using the built-in memory scanner or
through user input RAM memory. The CRC module can
accept up to a 16-bit polynomial with up to a 16-bit seed
value. A CRC calculated check value (or checksum)
will then be generated into the CRCACC<15:0>
registers for user storage. The CRC module uses an
XOR shift register implementation to perform the
polynomial division required for the CRC calculation.

EXAMPLE 13-1: CRC EXAMPLE


Rev. 10-000206A
1/8/2014

CRC-16-ANSI
x16 + x15 + x2 + 1 (17 bits)
Standard 16-bit representation = 0x8005
CRCXORH = 0b10000000
CRCXORL = 0b0000010- (1)

Data Sequence:
0x55, 0x66, 0x77, 0x88
DLEN = 0b0111
PLEN = 0b1111

Data entered into the CRC:


SHIFTM = 0:
01010101 01100110 01110111 10001000
SHIFTM = 1:
10101010 01100110 11101110 00010001

Check Value (ACCM = 1):


SHIFTM = 0: 0x32D6
CRCACCH = 0b00110010
CRCACCL = 0b11010110
SHIFTM = 1: 0x6BA2
CRCACCH = 0b01101011
CRCACCL = 0b10100010

Note 1: Bit 0 is unimplemented. The LSb of any


CRC polynomial is always 1 and will always
be treated as a 1 by the CRC for calculating
the CRC check value. This bit will be read in
software as a 0.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 159


PIC18(L)F26/45/46K40
13.4 CRC Polynomial Implementation corresponding CRCXOR<15:0> bits with the value of
0x8004. The actual value is 0x8005 because the
Any polynomial can be used. The polynomial and hardware sets the LSb to 1. However, the LSb of the
accumulator sizes are determined by the PLEN<3:0> CRCXORL register is unimplemented and always
bits. For an n-bit accumulator, PLEN = n-1 and the reads as 0. Refer to Example 13-1.
corresponding polynomial is n+1 bits. Therefore, the
accumulator can be any size up to 16 bits with a
corresponding polynomial up to 17 bits. The MSb and
LSb of the polynomial are always 1 which is forced by
hardware. All polynomial bits between the MSb and
LSb are specified by the CRCXOR registers. For
example, when using CRC16-ANSI, the polynomial is
defined as X16+X15+X2+1. The X16 and X0 = 1 terms
are the MSb and LSb controlled by hardware. The X15
and X2 terms are specified by setting the

EXAMPLE 13-2: CRC LFSR EXAMPLE

Rev. 10-000207A
Linear Feedback Shift Register for CRC-16-ANSI 5/27/2014

x16 + x15 + x2 + 1
Data in
Augmentation Mode ON

b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0

Data in
Augmentation Mode OFF

b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0

13.5 CRC Data Sources The CRC module can be seeded with an initial value by
setting the CRCACC<15:0> registers to the
Data can be input to the CRC module in two ways: appropriate value before beginning the CRC.
- User data using the CRCDATA registers
(CRCDATH and CRCDATL) 13.5.1 CRC FROM USER DATA
- Flash using the Program Memory Scanner To use the CRC module on data input from the user, the
To set the number of bits of data, up to 16 bits, the user must write the data to the CRCDAT registers. The
DLEN bits of CRCCON1 must be set accordingly. Only data from the CRCDAT registers will be latched into the
data bits in CRCDATA registers up to DLEN will be shift registers on any write to the CRCDATL register.
used, other data bits in CRCDATA registers will be
13.5.2 CRC FROM FLASH
ignored.
To use the CRC module on data located in Flash
Data is moved into the CRCSHIFT as an intermediate
memory, the user can initialize the Program Memory
to calculate the check value located in the CRCACC
Scanner as defined in Section 13.9, Program Memory
registers.
Scan Configuration.
The SHIFTM bit is used to determine the bit order of the
data being shifted into the accumulator. If SHIFTM is
not set, the data will be shifted in MSb first (Big Endian).
The value of DLEN will determine the MSb. If SHIFTM
bit is set, the data will be shifted into the accumulator in
reversed order, LSb first (Little Endian).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 160


PIC18(L)F26/45/46K40
13.6 CRC Check Value 13.8 Configuring the CRC
The CRC check value will be located in the CRCACC The following steps illustrate how to properly configure
registers after the CRC calculation has finished. The the CRC.
check value will depend on two mode settings of the 1. Determine if the automatic program memory
CRCCON register: ACCM and SHIFTM. scan will be used with the scanner or manual
When the ACCM bit is set, the CRC module augments calculation through the SFR interface and
the data with a number of zeros equal to the length of perform the actions specified in Section
the polynomial to align the final check value. When the 13.5 CRC Data Sources, depending on which
ACCM bit is not set, the CRC will stop at the end of the decision was made.
data. A number of zeros equal to the length of the 2. If desired, seed a starting CRC value into the
polynomial can then be entered into CRCDAT to find CRCACCH/L registers.
the same check value as augmented mode. 3. Program the CRCXORH/L registers with the
Alternatively, the expected check value can be entered desired generator polynomial.
at this point to make the final result equal 0.
4. Program the DLEN<3:0> bits of the CRCCON1
When the CRC check value is computed with the register with the length of the data word - 1 (refer
SHIFTM bit set, selecting LSb first, and the ACCM bit to Example 13-1). This determines how many
is set then the final value in the CRCACC registers will times the shifter will shift into the accumulator for
be reversed such that the LSb will be in the MSb each data word.
position and vice versa. This is the expected check 5. Program the PLEN<3:0> bits of the CRCCON1
value in bit reversed form. If you are creating a check register with the length of the polynomial -2
value to be appended to a data stream then a bit (refer to Example 13-1).
reversal must be performed on the final value to
6. Determine whether shifting in trailing zeros is
achieve the correct checksum. You can use the CRC to
desired and set the ACCM bit of the CRCCON0
do this reversal by the following method:
register appropriately.
Save CRCACC value in user RAM space 7. Likewise, determine whether the MSb or LSb
Clear the CRCACC registers should be shifted first and write the SHIFTM bit
Clear the CRCXOR registers of the CRCCON0 register appropriately.
Write the saved CRCACC value to the CRCDAT 8. Write the CRCGO bit of the CRCCON0 register
input to begin the shifting process.
The properly oriented check value will be in the 9a. If manual SFR entry is used, monitor the FULL bit
CRCACC registers as the result. of the CRCCON0 register. When FULL = 0,
another word of data can be written to the
13.7 CRC Interrupt CRCDATH/L registers, keeping in mind that
CRCDATH should be written first if the data has
The CRC will generate an interrupt when the BUSY bit more than eight bits, as the shifter will begin upon
transitions from 1 to 0. The CRCIF Interrupt Flag bit of the CRCDATL register being written.
the PIR7 register is set every time the BUSY bit 9b. If the scanner is used, the scanner will
transitions, regardless of whether or not the CRC automatically stuff words into the CRCDATH/L
interrupt is enabled. The CRCIF bit can only be cleared registers as needed, as long as the SCANGO bit
in software. The CRC interrupt enable is the CRCIE bit is set.
of the PIE7 register. 10a.If using the Flash memory scanner, monitor the
SCANIF (or the SCANGO bit) for the scanner to
finish pushing information into the CRCDATA
registers. After the scanner is completed,
monitor the CRCIF (or the BUSY bit) to
determine that the CRC has been completed
and the check value can be read from the
CRCACC registers. If both the interrupt flags are
set (or both BUSY and SCANGO bits are
cleared), the completed CRC calculation can be
read from the CRCACCH/L registers.
10b.If manual entry is used, monitor the CRCIF (or
BUSY bit) to determine when the CRCACC
registers will hold the check value.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 161


PIC18(L)F26/45/46K40
13.9 Program Memory Scan 13.11 Scanning Modes
Configuration The memory scanner can scan in four modes: Burst,
If desired, the program memory scan module may be Peek, Concurrent, and Triggered. These modes are
used in conjunction with the CRC module to perform a controlled by the MODE bits of the SCANCON0
CRC calculation over a range of program memory register. The four modes are summarized in Table 13-2.
addresses. In order to set up the scanner to work with
the CRC you need to perform the following steps: 13.11.1 BURST MODE
1. Set the Enable bit in both the CRCCON0 and When MODE = 01, the scanner is in Burst mode. In
SCANCON0 registers. If they get disabled, all Burst mode, CPU operation is stalled beginning with the
internal states of the scanner and the CRC are operation after the one that sets the SCANGO bit, and
reset (registers are unaffected). the scan begins, using the instruction clock to execute.
The CPU is held in its current state until the scan stops.
2. Choose which memory access mode is to be
Note that because the CPU is not executing instructions,
used (see Section 13.11 Scanning Modes)
the SCANGO bit cannot be cleared in software, so the
and set the MODE bits of the SCANCON0
CPU will remain stalled until one of the hardware end-
register appropriately.
conditions occurs. Burst mode has the highest
3. Based on the memory access mode, set the throughput for the scanner, but has the cost of stalling
INTM bits of the SCANCON0 register to the other execution while it occurs.
appropriate interrupt mode (see Section
13.11.5 Interrupt Interaction) 13.11.2 CONCURRENT MODE
4. Set the SCANLADRL/H/U and SCANHADRL/H/
When MODE = 00, the scanner is in Concurrent mode.
U registers with the beginning and ending
Concurrent mode, like Burst mode, stalls the CPU
locations in memory that are to be scanned.
while performing accesses of memory. However, while
5. The CRCGO bit must be set before setting the Burst mode stalls until all accesses are complete,
SCANGO bit. Setting the SCANGO bit starts the Concurrent mode allows the CPU to execute in
scan. Both CRCEN and CRCGO bits must be between access cycles.
enabled to use the scanner. When either of
these bits are disabled, the scan aborts and the 13.11.3 TRIGGERED MODE
INVALID bit SCANCON0 is set. The scanner will
When MODE = 11, the scanner is in Triggered mode.
wait for the signal from the CRC that it is ready
Triggered mode behaves identically to Concurrent
for the first Flash memory location, then begin
mode, except instead of beginning the scan
loading data into the CRC. It will continue to do
immediately upon the SCANGO bit being set, it waits
so until it either hits the configured end address
for a rising edge from a separate trigger clock, the
or an address that is unimplemented on the
source of which is determined by the SCANTRIG
device, at which point the SCANGO bit will clear,
register.
Scanner functions will cease, and the SCANIF
interrupt will be triggered. Alternately, the
13.11.4 PEEK MODE
SCANGO bit can be cleared in software if
desired. When MODE = 10, the scanner is in Peek mode. Peek
mode waits for an instruction cycle in which the CPU
13.10 Scanner Interrupt does not need to access the NVM (such as a branch
instruction) and uses that cycle to do its own NVM
The scanner will trigger an interrupt when the access. This results in the lowest throughput for the NVM
SCANGO bit transitions from 1 to 0. The SCANIF access (and can take a much longer time to complete a
interrupt flag of PIR7 is set when the last memory scan than the other modes), but does so without any
location is reached and the data is entered into the impact on execution times, unlike the other modes.
CRCDATA registers. The SCANIF bit can only be
cleared in software. The SCAN interrupt enable is the
SCANIE bit of the PIE7 register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 162


PIC18(L)F26/45/46K40

TABLE 13-2: SUMMARY OF SCANNER MODES


Description
MODE<1:0>
First Scan Access CPU Operation
As soon as possible CPU resumes execution following
11 Triggered Stalled during NVM access
following a trigger each access
CPU continues execution following
10 Peek At the first dead cycle Timing is unaffected
each access
CPU suspended until scan
01 Burst
completes
As soon as possible Stalled during NVM access
CPU resumes execution following
00 Concurrent
each access

13.11.5 INTERRUPT INTERACTION


The INTM bit of the SCANCON0 register controls the
scanners response to interrupts depending on which
mode the NVM scanner is in, as described in Table 13-3.

TABLE 13-3: SCAN INTERRUPT MODES


MODE<1:0>
INTM MODE == CONCURENT or
MODE == Burst MODE ==PEEK
TRIGGERED
Interrupt overrides SCANGO (to Scanner suspended during
zero) to pause the burst and the interrupt response (SCANGO = 0);
1 interrupt handler executes at full interrupt executes at full speed This bit is ignored
speed; Scanner Burst resumes and scan resumes when the
when interrupt completes. interrupt is complete.
Interrupts do not override
SCANGO, and the scan (burst)
operation will continue; interrupt Scanner accesses NVM during
0 This bit is ignored
response will be delayed until scan interrupt response.
completes (latency will be
increased).

In general, if INTM = 0, the scanner will take


precedence over the interrupt, resulting in decreased
interrupt processing speed and/or increased interrupt
response latency. If INTM = 1, the interrupt will take
precedence and have a better speed, delaying the
memory scan.

13.11.6 WWDT INTERACTION


Operation of the WWDT is not affected by scanner
activity. Hence, it is possible that long scans,
particularly in Burst mode, may exceed the WWDT
time-out period and result in an undesired device
Reset. This should be considered when performing
memory scans with an application that also utilizes
WWDT.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 163


PIC18(L)F26/45/46K40
13.11.7 IN-CIRCUIT DEBUG (ICD)
INTERACTION
The scanner freezes when an ICD halt occurs, and
remains frozen until user-mode operation resumes.
The debugger may inspect the SCANCON0 and
SCANLADR registers to determine the state of the
scan.
The ICD interaction with each operating mode is
summarized in Table 13-4.
TABLE 13-4: ICD AND SCANNER INTERACTIONS
Scanner Operating Mode
ICD Halt Concurrent
Peek Burst
Triggered
If external halt is asserted during
the BSF(SCANCON.GO), ICD
If external halt is asserted during
entry occurs, and the burst is
a scan cycle, the instruction
delayed until ICD exit.
(delayed by scan) may or may
not execute before ICD entry,
Otherwise, the current NVM-
depending on external halt
External access cycle will complete, and
timing.
Halt then the scanner will be
interrupted for ICD entry.
If external halt is asserted during
the cycle immediately prior to the If external halt is asserted during
scan cycle, both scan and the burst, the burst is suspended
instruction execution happen and will resume with ICD exit.
after the ICD exits.
If scanner would peek an Scan cycle occurs before ICD
PC
instruction that is not executed entry and instruction execution
Breakpoint
(because of ICD entry), the peek happens after the ICD exits. If PCPB (or single step) is on
will occur after ICD exit, when the The instruction with the dataBP BSF(SCANCON.GO), the ICD is
instruction executes. executes and ICD entry occurs entered before execution;
Data immediately after. If scan is execution of the burst will occur
Breakpoint requested during that cycle, the at ICD exit, and the burst will run
scan cycle is postponed until the to completion.
ICD exits.
If a scan cycle is ready after the Note that the burst can be
debug instruction is executed, interrupted by an external halt.
Single Step
the scan will read PFM and then
the ICD is re-entered.
If SWBP replaces
BSF(SCANCON.GO), the ICD will
If scan would stall a SWBP, the
SWBP and be entered; instruction execution
scan cycle occurs and the ICD is
ICDINST will occur at ICD exit (from
entered.
ICDINSTR register), and the
burst will run to completion.

13.11.8 PERIPHERAL MODULE DISABLE


Both the CRC and scanner module can be disabled
individually by setting the CRCMD and SCANMD bits
of the PMD0 register (Register 7-1). The SCANMD can
be used to enable or disable to the scanner module
only if the SCANE bit of Configuration Word 4 is set. If
the SCANE bit is cleared, then the scanner module is
not available for use and the SCANMD bit is ignored.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 164


PIC18(L)F26/45/46K40

TABLE 13-5: SUMMARY OF REGISTERS ASSOCIATED WITH CRC


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
CRCACCH ACC<15:8> 151
CRCACCL ACC<7:0> 152
CRCCON0 EN GO BUSY ACCM SHIFTM FULL 150
CRCCON1 DLEN<3:0> PLEN<3:0> 150
CRCDATH DATA<15:8> 151
CRCDATL DATA<7:0> 151
CRCSHIFTH SHIFT<15:8> 152
CRCSHIFTL SHIFT<7:0> 152
CRCXORH X<15:8> 153
CRCXORL X<7:1> 153
PMD0 SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD 67
SCANCON0 SCANEN SCANGO BUSY INVALID INTM MODE<1:0> 154
SCANHADRU HADR<21:16> 156
SCANHADRH HADR<15:8> 157
SCANHADRL HADR<7:0> 157
SCANLADRU LADR<21:16> 155
SCANLADRH LADR<15:8> 155
SCANLADRL LADR<7:0> 156
SCANTRIG TSEL<3:0> 158
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIR7 SCANIF CRCIF NVMIF CWG1IF 177
PIE7 SCANIE CRCIE NVMIE CWG1IE 185
IPR7 SCANIP CRCIP NVMIP CWG1IP 193
Legend: = unimplemented location, read as 0. Shaded cells are not used for the CRC module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 165


PIC18(L)F26/45/46K40
14.0 INTERRUPTS 14.2 Interrupt Priority
The PIC18(L)F2x/4xK40 devices have multiple The interrupt priority feature is enabled by setting the
interrupt sources and an interrupt priority feature that IPEN bit of the INTCON register. When interrupt priority
allows most interrupt sources to be assigned a high or is enabled the GIE/GIEH and PEIE/GIEL Global Inter-
low priority level. The high priority interrupt vector is at rupt Enable bits of Compatibility mode are replaced by
0008h and the low priority interrupt vector is at 0018h. the GIEH high priority, and GIEL low priority, global
A high priority interrupt event will interrupt a low priority interrupt enables. When the IPEN bit is set, the GEIH
interrupt that may be in progress. bit of the INTCON register enables all interrupts which
have their associated bit in the IPRx register set. When
The registers for controlling interrupt operation are:
the GEIH bit is cleared, then all interrupt sources
INTCON including those selected as low priority in the IPRx reg-
PIR1, PIR2, PIR3, PIR4, PIR5, PIR6, PIR7 ister are disabled.
PIE1, PIE2, PIE3, PIE4, PIE5, PIE6, PIE7 When both GIEH and GIEL bits are set, all interrupts
IPR1, IPR2, IPR3, IPR4, IPR5, IPR6, IPR7 selected as low priority sources are enabled.
It is recommended that the Microchip header files sup- A high priority interrupt will vector immediately to
plied with MPLAB IDE be used for the symbolic bit address 00 0008h and a low priority interrupt will vector
names in these registers. This allows the assembler/ to address 00 0018h.
compiler to automatically take care of the placement of
these bits within the specified register. 14.3 Interrupt Response
In general, interrupt sources have three bits to control
When an interrupt is responded to, the Global Interrupt
their operation. They are:
Enable bit is cleared to disable further interrupts. The
Flag bit to indicate that an interrupt event GIE/GIEH bit is the Global Interrupt Enable when the
occurred IPEN bit is cleared. When the IPEN bit is set, enabling
Enable bit that allows program execution to interrupt priority levels, the GIEH bit is the high priority
branch to the interrupt vector address when the Global Interrupt Enable and the GIEL bit is the low
flag bit is set priority Global Interrupt Enable. High priority interrupt
Priority bit to select high priority or low priority sources can interrupt a low priority interrupt. Low
priority interrupts are not processed while high priority
interrupts are in progress.
14.1 Mid-Range Compatibility
The return address is pushed onto the stack and the
When the IPEN bit is cleared (default state), the interrupt PC is loaded with the interrupt vector address (0008h
priority feature is disabled and interrupts are compatible or 0018h). Once in the Interrupt Service Routine, the
with PIC microcontroller mid-range devices. In source(s) of the interrupt can be determined by polling
Compatibility mode, the interrupt priority bits of the IPRx the interrupt flag bits in the INTCONx and PIRx
registers have no effect. The PEIE/GIEL bit of the registers. The interrupt flag bits must be cleared by
INTCON register is the global interrupt enable for the software before re-enabling interrupts to avoid
peripherals. The PEIE/GIEL bit disables only the repeating the same interrupt.
peripheral interrupt sources and enables the peripheral
interrupt sources when the GIE/GIEH bit is also set. The The return from interrupt instruction, RETFIE, exits
GIE/GIEH bit of the INTCON register is the global the interrupt routine and sets the GIE/GIEH bit (GIEH
interrupt enable which enables all non-peripheral or GIEL if priority levels are used), which re-enables
interrupt sources and disables all interrupt sources, interrupts.
including the peripherals. All interrupts branch to For external interrupt events, such as the INT pins or
address 0008h in Compatibility mode. the Interrupt-on-change pins, the interrupt latency will
be three to four instruction cycles. The exact latency is
the same for one-cycle or two-cycle instructions.
Individual interrupt flag bits are set, regardless of the
status of their corresponding enable bits or the Global
Interrupt Enable bit.

Note: Do not use the MOVFF instruction to


modify any of the interrupt control regis-
ters while any interrupt is enabled. Doing
so may cause erratic microcontroller
behavior.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 166


PIC18(L)F26/45/46K40
FIGURE 14-1: PIC18 INTERRUPT LOGIC

Rev. 10-000010B
5/4/2016

Wake-up if in
Idle or Sleep
PIR0 modes
PIE0
IPR0

PIR1 Interrupt to
PIE1 CPU Vector at
IPR1 Location 0008h

PIR2
PIE2 GIEH/GIE
IPR2

IPEN

IPEN
GIEL/PEIE
PIRx IPEN
PIEx
IPRx

High Priority Interrupt Generation


Low Priority Interrupt Generation

PIR1
PIE1
IPR1

PIR2
PIE2
IPR2

PIR0 Interrupt to
PIE0 CPU Vector at
IPR0 Location 0018h

PIRx GIEH/GIE
PIEx
IPRx GIEL/PEIE

2016 Microchip Technology Inc. Preliminary DS40001816C-page 167


PIC18(L)F26/45/46K40
14.4 INTCON Registers
The INTCON registers are readable and writable
registers, which contain various enable and priority
bits.

14.5 PIR Registers


The PIR registers contain the individual flag bits for the
peripheral interrupts. Due to the number of peripheral
interrupt sources, there are eight Peripheral Interrupt
Request Flag registers (PIR0, PIR1, PIR2, PIR3, PIR4,
PIR5, PIR6 and PIR7).

14.6 PIE Registers


The PIE registers contain the individual enable bits for the
peripheral interrupts. Due to the number of peripheral
interrupt sources, there are eight Peripheral Interrupt
Enable registers (PIE0, PIE1, PIE2, PIE3, PIE4, PIE5,
PIE6 and PIE7). When IPEN = 0, the PEIE/GIEL bit must
be set to enable any of these peripheral interrupts.

14.7 IPR Registers


The IPR registers contain the individual priority bits for the
peripheral interrupts. Due to the number of peripheral
interrupt sources, there are eight Peripheral Interrupt
Priority registers (IPR0, IPR1, IPR2, IPR3, IPR4 and
IPR5, IPR6 and IPR7). Using the priority bits requires that
the Interrupt Priority Enable (IPEN) bit be set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 168


PIC18(L)F26/45/46K40
14.8 Register Definitions: Interrupt Control
REGISTER 14-1: INTCON: INTERRUPT CONTROL REGISTER
R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0 R/W-1/1 R/W-1/1 R/W-1/1

GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 GIE/GIEH: Global Interrupt Enable bit


If IPEN = 1:
1 = Enables all unmasked interrupts and cleared by hardware for high-priority interrupts only
0 = Disables all interrupts
If IPEN = 0:
1 = Enables all unmasked interrupts and cleared by hardware for all interrupts
0 = Disables all interrupts
bit 6 PEIE/GIEL: Peripheral Interrupt Enable bit
If IPEN = 1:
1 = Enables all low-priority interrupts and cleared by hardware for low-priority interrupts only
0 = Disables all low-priority interrupts
If IPEN = 0:
1 = Enables all unmasked peripheral interrupts
0 = Disables all peripheral interrupts
bit 5 IPEN: Interrupt Priority Enable bit
1 = Enable priority levels on interrupts
0 = Disable priority levels on interrupts
bit 4-3 Unimplemented: Read as 0
bit 2 INT2EDG: External Interrupt 2 Edge Select bit
1 = Interrupt on rising edge of INT2 pin
0 = Interrupt on falling edge of INT2 pin
bit 1 INT1EDG: External Interrupt 1 Edge Select bit
1 = Interrupt on rising edge of INT1 pin
0 = Interrupt on falling edge of INT1 pin
bit 0 INT0EDG: External Interrupt 0 Edge Select bit
1 = Interrupt on rising edge of INT0 pin
0 = Interrupt on falling edge of INT0 pin

Note: Interrupt flag bits are set when an interrupt


condition occurs, regardless of the state of
its corresponding enable bit or the global
enable bit. User software should ensure
the appropriate interrupt flag bits are clear
prior to enabling an interrupt. This feature
allows for software polling.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 169


PIC18(L)F26/45/46K40

REGISTER 14-2: PIR0: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 0


U-0 U-0 R/W-0/0 R-0/0 U-0 R/W-0/0 R/W-0/0 R/W-0/0

TMR0IF(1) IOCIF(1,2) INT2IF(1,3) INT1IF(1,3) INT0IF(1,3)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR0IF: Timer0 Interrupt Flag bit(1)
1 = TMR0 register has overflowed (must be cleared by software)
0 = TMR0 register has not overflowed
bit 4 IOCIF: Interrupt-on-Change Flag bit(1,2)
1 = IOC event has occurred (must be cleared by software)
0 = IOC event has not occurred
bit 3 Unimplemented: Read as 0
bit 2 INT2IF: External Interrupt 2 Flag bit(1,3)
1 = External Interrupt 2 has occurred
0 = External Interrupt 2 has not occurred
bit 1 INT1IF: External Interrupt 1 Flag bit(1,3)
1 = External Interrupt 1 has occurred
0 = External Interrupt 1 has not occurred
bit 0 INT0IF: External Interrupt 0 Flag bit(1,3)
1 = External Interrupt 0 has occurred
0 = External Interrupt 0 has not occurred

Note 1: Interrupts are not disabled by the PEIE bit in the INTCON register.
2: IOCIF is a read-only bit, to clear the interrupt condition, all bits in the IOCF register must be cleared.
3: The external interrupt GPIO pin is selected by the INTPPS register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 170


PIC18(L)F26/45/46K40

REGISTER 14-3: PIR1: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 1


R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
OSCFIF CSWIF(1) ADTIF ADIF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 OSCFIF: Oscillator Fail Interrupt Flag bit


1 = Device oscillator failed, clock input has changed to HFINTOSC (must be cleared by software)
0 = Device clock operating
bit 6 CSWIF: Clock-Switch Interrupt Flag bit(1)
1 = New oscillator is ready for switch (must be cleared by software) (see Figure 4-6 and Figure 4-7)
0 = New oscillator is not ready for switch or has not been started
bit 5-2 Unimplemented: Read as 0
bit 1 ADTIF: ADC Threshold Interrupt Flag bit
1 = ADC Threshold interrupt has occurred (must be cleared by software)
0 = ADC Threshold event is not complete or has not been started
bit 0 ADIF: ADC Interrupt Flag bit
1 = An A/D conversion completed (must be cleared by software)
0 = The A/D conversion is not complete or has not been started

Note 1: The CSWIF interrupt will not wake the system from Sleep. The system will sleep until another interrupt
causes the wake-up.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 171


PIC18(L)F26/45/46K40

REGISTER 14-4: PIR2: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 2


R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
HLVDIF ZCDIF C2IF C1IF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 HLVDIF: HLVD Interrupt Flag bit


1 = HLVD interrupt event has occurred
0 = HLVD interrupt event has not occurred or has not been set up
bit 6 ZCDIF: Zero-Cross Detect Interrupt Flag bit
1 = ZCD Output has changed (must be cleared in software)
0 = ZCD Output has not changed
bit 5-2 Unimplemented: Read as 0
bit 1 C2IF: Comparator 2 Interrupt Flag bit
1 = Comparator C2 output has changed (must be cleared by software)
0 = Comparator C2 output has not changed
bit 0 C1IF: Comparator 1 Interrupt Flag bit
1 = Comparator C1 output has changed (must be cleared by software)
0 = Comparator C1 output has not changed

2016 Microchip Technology Inc. Preliminary DS40001816C-page 172


PIC18(L)F26/45/46K40

REGISTER 14-5: PIR3: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 3


R-0/0 R-0/0 R-0/0 R-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 RC2IF: EUSART2 Receive Interrupt Flag bit


1 = The EUSART2 receive buffer, RC1REG, is full (cleared by reading RC2REG)
0 = The EUSART2 receive buffer is empty
bit 6 TX2IF: EUSART2 Transmit Interrupt Flag bit
1 = The EUSART2 transmit buffer, TX2REG, is empty (cleared by writing TX2REG)
0 = The EUSART2 transmit buffer is full
bit 5 RC1IF: EUSART1 Receive Interrupt Flag bit
1 = The EUSART1 receive buffer, RC1REG, is full (cleared by reading RC1REG)
0 = The EUSART1 receive buffer is empty
bit 4 TX1IF: EUSART1 Transmit Interrupt Flag bit
1 = The EUSART1 transmit buffer, TX1REG, is empty (cleared by writing TX1REG)
0 = The EUSART1 transmit buffer is full
bit 3 BCL2IF: MSSP2 Bus Collision Interrupt Flag bit
1 = A bus collision has occurred while the MSSP2 module configured in I2C master was transmitting
(must be cleared in software)
0 = No bus collision occurred
bit 2 SSP2IF: Synchronous Serial Port 2 Interrupt Flag bit
1 = The transmission/reception is complete (must be cleared in software)
0 = Waiting to transmit/receive
bit 1 BCL1IF: MSSP1 Bus Collision Interrupt Flag bit
1 = A bus collision has occurred while the MSSP1 module configured in I2C master was transmitting
(must be cleared in software)
0 = No bus collision occurred
bit 0 SSP1IF: Synchronous Serial Port 1 Interrupt Flag bit
1 = The transmission/reception is complete (must be cleared in software)
0 = Waiting to transmit/receive

2016 Microchip Technology Inc. Preliminary DS40001816C-page 173


PIC18(L)F26/45/46K40

REGISTER 14-6: PIR4: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 4


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR6IF: TMR6 to PR6 Match Interrupt Flag bit
1 = TMR6 to PR6 match occurred (must be cleared in software)
0 = No TMR6 to PR6 match occurred
bit 4 TMR5IF: TMR5 Overflow Interrupt Flag bit
1 = TMR5 register overflowed (must be cleared in software)
0 = TMR5 register did not overflow
bit 3 TMR4IF: TMR4 to PR4 Match Interrupt Flag bit
1 = TMR4 to PR4 match occurred (must be cleared in software)
0 = No TMR4 to PR4 match occurred
bit 2 TMR3IF: TMR3 Overflow Interrupt Flag bit
1 = TMR3 register overflowed (must be cleared in software)
0 = TMR3 register did not overflow
bit 1 TMR2IF: TMR2 to PR2 Match Interrupt Flag bit
1 = TMR2 to PR2 match occurred (must be cleared in software)
0 = No TMR2 to PR2 match occurred
bit 0 TMR1IF: TMR1 Overflow Interrupt Flag bit
1 = TMR1 register overflowed (must be cleared in software)
0 = TMR1 register did not overflow

2016 Microchip Technology Inc. Preliminary DS40001816C-page 174


PIC18(L)F26/45/46K40

REGISTER 14-7: PIR5: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 5


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
TMR5GIF TMR3GIF TMR1GIF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-3 Unimplemented: Read as 0


bit 2 TMR5GIF: TMR5 Gate Interrupt Flag bit
1 = TMR5 gate interrupt occurred (must be cleared in software)
0 = No TMR5 gate occurred
bit 1 TMR3GIF: TMR3 Gate Interrupt Flag bit
1 = TMR3 gate interrupt occurred (must be cleared in software)
0 = No TMR3 gate occurred
bit 0 TMR1GIF: TMR1 Gate Interrupt Flag bit
1 = TMR1 gate interrupt occurred (must be cleared in software)
0 = No TMR1 gate occurred

2016 Microchip Technology Inc. Preliminary DS40001816C-page 175


PIC18(L)F26/45/46K40

REGISTER 14-8: PIR6: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 6


U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
CCP2IF CCP1IF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1 CCP2IF: ECCP2 Interrupt Flag bit
Capture mode:
1 = A TMR register capture occurred (must be cleared in software)
0 = No TMR register capture occurred
Compare mode:
1 = A TMR register compare match occurred (must be cleared in software)
0 = No TMR register compare match occurred
PWM mode:
Unused in PWM mode.
bit 0 CCP1IF: ECCP1 Interrupt Flag bit
Capture mode:
1 = A TMR register capture occurred (must be cleared in software)
0 = No TMR register capture occurred
Compare mode:
1 = A TMR register compare match occurred (must be cleared in software)
0 = No TMR register compare match occurred
PWM mode:
Unused in PWM mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 176


PIC18(L)F26/45/46K40

REGISTER 14-9: PIR7: PERIPHERAL INTERRUPT REQUEST (FLAG) REGISTER 7


R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0
SCANIF CRCIF NVMIF CWG1IF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 SCANIF: SCAN Interrupt Flag bit


1 = SCAN interrupt has occurred (must be cleared in software)
0 = SCAN interrupt has not occurred or has not been started
bit 6 CRCIF: CRC Interrupt Flag bit
1 = CRC interrupt has occurred (must be cleared in software)
0 = CRC interrupt has not occurred or has not been started
bit 5 NVMIF: NVM Interrupt Flag bit
1 = NVM interrupt has occurred (must be cleared in software)
0 = NVM interrupt has not occurred or has not been started
bit 4-1 Unimplemented: Read as 0
bit 0 CWG1IF: CWG Interrupt Flag bit
1 = CWG interrupt has occurred (must be cleared in software)
0 = CWG interrupt has not occurred or has not been started

2016 Microchip Technology Inc. Preliminary DS40001816C-page 177


PIC18(L)F26/45/46K40

REGISTER 14-10: PIE0: PERIPHERAL INTERRUPT ENABLE REGISTER 0


U-0 U-0 R/W-0/0 R/W-0/0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
TMR0IE(1) IOCIE(1) INT2IE(1) INT1IE(1) INT0IE(1)
bit 7 bit 0

Legend: IE
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR0IE: Timer0 Interrupt Enable bit(1)
1 = Enabled
0 = Disabled
bit 4 IOCIE: Interrupt-on-Change Enable bit(1)
1 = Enabled
0 = Disabled
bit 3 Unimplemented: Read as 0
bit 2 INT2IE: External Interrupt 2 Enable bit(1)
1 = Enabled
0 = Disabled
bit 1 INT1IE: External Interrupt 1 Enable bit(1)
1 = Enabled
0 = Disabled
bit 0 INT0IE: External Interrupt 0 Enable bit(1)
1 = Enabled
0 = Disabled

Note 1: PIR0 interrupts are not disabled by the PEIE bit in the INTCON register. are not disabled by the PEIE bit
in the INTCON register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 178


PIC18(L)F26/45/46K40

REGISTER 14-11: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1


R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
OSCFIE CSWIE ADTIE ADIE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 OSCFIE: Oscillator Fail Interrupt Enable bit


1 = Enabled
0 = Disabled
bit 6 CSWIE: Clock-Switch Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 5-2 Unimplemented: Read as 0
bit 1 ADTIE: ADC Threshold Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 ADIE: ADC Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 179


PIC18(L)F26/45/46K40

REGISTER 14-12: PIE2: PERIPHERAL INTERRUPT ENABLE REGISTER 2


R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
HLVDIE ZCDIE C2IE C1IE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 HLVDIE: HLVD Interrupt Enable bit


1 = Enabled
0 = Disabled
bit 6 ZCDIE: Zero-Cross Detect Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 5-2 Unimplemented: Read as 0
bit 1 C2IE: Comparator 2 Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 C1IE: Comparator 1 Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 180


PIC18(L)F26/45/46K40

REGISTER 14-13: PIE3: PERIPHERAL INTERRUPT ENABLE REGISTER 3


R/W-0/0 R/W-0/0 R/W-0/0 R-/W0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 RC2IE: EUSART2 Receive Interrupt Enable bit


1 = Enabled
0 = Disabled
bit 6 TX2IE: EUSART2 Transmit Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 5 RC1IE: EUSART1 Receive Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 4 TX1IE: EUSART1 Transmit Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 3 BCL2IE: MSSP2 Bus Collision Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 2 SSP2IE: Synchronous Serial Port 2 Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 1 BCL1IE: MSSP1 Bus Collision Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 SSP1IE: Synchronous Serial Port 1 Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 181


PIC18(L)F26/45/46K40

REGISTER 14-14: PIE4: PERIPHERAL INTERRUPT ENABLE REGISTER 4


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR6IE: TMR6 to PR6 Match Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 4 TMR5IE: TMR5 Overflow Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 3 TMR4IE: TMR4 to PR4 Match Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 2 TMR3IE: TMR3 Overflow Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 1 TMR2IE: TMR2 to PR2 Match Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 TMR1IE: TMR1 Overflow Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 182


PIC18(L)F26/45/46K40

REGISTER 14-15: PIE5: PERIPHERAL INTERRUPT ENABLE REGISTER 5


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
TMR5GIE TMR3GIE TMR1GIE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-3 Unimplemented: Read as 0


bit 2 TMR5GIE: TMR5 Gate Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 1 TMR3GIE: TMR3 Gate Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 TMR1GIE: TMR1 Gate Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 183


PIC18(L)F26/45/46K40

REGISTER 14-16: PIE6: PERIPHERAL INTERRUPT ENABLE REGISTER 6


U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
CCP2IE CCP1IE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1 CCP2IE: ECCP2 Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 0 CCP1IE: ECCP1 Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 184


PIC18(L)F26/45/46K40

REGISTER 14-17: PIE7: PERIPHERAL INTERRUPT ENABLE REGISTER 7


R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0
SCANIE CRCIE NVMIE CWG1IE
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 SCANIE: SCAN Interrupt Enable bit


1 = Enabled
0 = Disabled
bit 6 CRCIE: CRC Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 5 NVMIE: NVM Interrupt Enable bit
1 = Enabled
0 = Disabled
bit 4-1 Unimplemented: Read as 0
bit 0 CWG1IE: CWG Interrupt Enable bit
1 = Enabled
0 = Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 185


PIC18(L)F26/45/46K40

REGISTER 14-18: IPR0: PERIPHERAL INTERRUPT PRIORITY REGISTER 0


U-0 U-0 R/W-1/1 R/W-1/1 U-0 R/W-1/1 R/W-1/1 R/W-1/1
TMR0IP IOCIP INT2IP INT1IP INT0IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR0IP: Timer0 Interrupt Priority bit
1 = High priority
0 = Low priority
bit 4 IOCIP: Interrupt-on-Change Priority bit
1 = High priority
0 = Low priority
bit 3 Unimplemented: Read as 0
bit 2 INT2IP: External Interrupt 2 Priority bit
1 = High priority
0 = Low priority
bit 1 INT1IP: External Interrupt 1 Priority bit
1 = High priority
0 = Low priority
bit 0 INT0IP: External Interrupt 0 Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 186


PIC18(L)F26/45/46K40

REGISTER 14-19: IPR1: PERIPHERAL INTERRUPT PRIORITY REGISTER 1


R/W-1/1 R/W-1/1 U-0 U-0 U-0 U-0 R/W-1/1 R/W-1/1
OSCFIP CSWIP ADTIP ADIP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 OSCFIP: Oscillator Fail Interrupt Priority bit


1 = High priority
0 = Low priority
bit 6 CSWIP: Clock-Switch Interrupt Priority bit
1 = High priority
0 = Low priority
bit 5-2 Unimplemented: Read as 0
bit 1 ADTIP: ADC Threshold Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 ADIP: ADC Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 187


PIC18(L)F26/45/46K40

REGISTER 14-20: IPR2: PERIPHERAL INTERRUPT PRIORITY REGISTER 2


R/W-1/1 R/W-1/1 U-0 U-0 U-0 U-0 R/W-1/1 R/W-1/1
HLVDIP ZCDIP C2IP C1IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 HLVDIP: HLVD Interrupt Priority bit


1 = High priority
0 = Low priority
bit 6 ZCDIP: Zero-Cross Detect Interrupt Priority bit
1 = High priority
0 = Low priority
bit 5-2 Unimplemented: Read as 0
bit 1 C2IP: Comparator 2 Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 C1IP: Comparator 1 Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 188


PIC18(L)F26/45/46K40

REGISTER 14-21: IPR3: PERIPHERAL INTERRUPT PRIORITY REGISTER 3


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 RC2IP: EUSART2 Receive Interrupt Priority bit


1 = High priority
0 = Low priority
bit 6 TX2IP: EUSART2 Transmit Interrupt Priority bit
1 = High priority
0 = Low priority
bit 5 RC1IP: EUSART1 Receive Interrupt Priority bit
1 = High priority
0 = Low priority
bit 4 TX1IP: EUSART1 Transmit Interrupt Priority bit
1 = High priority
0 = Low priority
bit 3 BCL2IP: MSSP2 Bus Collision Interrupt Priority bit
1 = High priority
0 = Low priority
bit 2 SSP2IP: Synchronous Serial Port 2 Interrupt Priority bit
1 = High priority
0 = Low priority
bit 1 BCL1IP: MSSP1 Bus Collision Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 SSP1IP: Synchronous Serial Port 1 Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 189


PIC18(L)F26/45/46K40

REGISTER 14-22: IPR4: PERIPHERAL INTERRUPT PRIORITY REGISTER 4


U-0 U-0 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 Unimplemented: Read as 0


bit 5 TMR6IP: TMR6 to PR6 Match Interrupt Priority bit
1 = High priority
0 = Low priority
bit 4 TMR5IP: TMR5 Overflow Interrupt Priority bit
1 = High priority
0 = Low priority
bit 3 TMR4IP: TMR4 to PR4 Match Interrupt Priority bit
1 = High priority
0 = Low priority
bit 2 TMR3IP: TMR3 Overflow Interrupt Priority bit
1 = High priority
0 = Low priority
bit 1 TMR2IP: TMR2 to PR2 Match Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 TMR1IP: TMR1 Overflow Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 190


PIC18(L)F26/45/46K40

REGISTER 14-23: IPR5: PERIPHERAL INTERRUPT PRIORITY REGISTER 5


U-0 U-0 U-0 U-0 U-0 R/W-1/1 R/W-1/1 R/W-1/1
TMR5GIP TMR3GIP TMR1GIP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-3 Unimplemented: Read as 0


bit 2 TMR5GIP: TMR5 Gate Interrupt Priority bit
1 = High priority
0 = Low priority
bit 1 TMR3GIP: TMR3 Gate Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 TMR1GIP: TMR1 Gate Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 191


PIC18(L)F26/45/46K40

REGISTER 14-24: IPR6: PERIPHERAL INTERRUPT PRIORITY REGISTER 6


U-0 U-0 U-0 U-0 U-0 U-0 R/W-1/1 R/W-1/1
CCP2IP CCP1IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1 CCP2IP: ECCP2 Interrupt Priority bit
1 = High priority
0 = Low priority
bit 0 CCP1IP: ECCP1 Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 192


PIC18(L)F26/45/46K40

REGISTER 14-25: IPR7: PERIPHERAL INTERRUPT PRIORITY REGISTER 7


R/W-1/1 R/W-1/1 R/W-1/1 U-0 U-0 U-0 U-0 R/W-1/1
SCANIP CRCIP NVMIP CWG1IP
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 SCANIP: SCAN Interrupt Priority bit


1 = High priority
0 = Low priority
bit 6 CRCIP: CRC Interrupt Priority bit
1 = High priority
0 = Low priority
bit 5 NVMIP: NVM Interrupt Priority bit
1 = High priority
0 = Low priority
bit 4-1 Unimplemented: Read as 0
bit 0 CWG1IP: CWG Interrupt Priority bit
1 = High priority
0 = Low priority

2016 Microchip Technology Inc. Preliminary DS40001816C-page 193


PIC18(L)F26/45/46K40
14.9 INTn Pin Interrupts 14.10 TMR0 Interrupt
PIC18(L)F2x/4xK40 devices have three external inter- In 8-bit mode (which is the default), an overflow in the
rupt sources which can be assigned to any pin on TMR0 register (FFh 00h) will set flag bit, TMR0IF. In
PORTA and PORTB using PPS. The external interrupt 16-bit mode, an overflow in the TMR0H:TMR0L regis-
sources are edge-triggered. If the corresponding ter pair (FFFFh 0000h) will set TMR0IF. The interrupt
INTxEDG bit in the INTCON0 register is set (= 1), the can be enabled/disabled by setting/clearing enable bit,
interrupt is triggered by a rising edge. It the bit is clear, TMR0IE of the PIE0 register. Interrupt priority for
the trigger is on the falling edge. Timer0 is determined by the value contained in the
All external interrupts (INT0, INT1 and INT2) can wake- interrupt priority bit, TMR0IP of the IPR0 register. See
up the processor from Idle or Sleep modes if bit INTxE Section 18.0 Timer0 Module for further details on
was set prior to going into those modes. If the Global the Timer0 module.
Interrupt Enable bit, GIE/GIEH, is set, the processor
will branch to the interrupt vector following wake-up. 14.11 Interrupt-on-Change
Interrupt priority is determined by the value contained An input change on any port pins that support IOC sets
in the interrupt priority bits, INT0IP, INT1IP and INT2IP Flag bit, IOCIF of the PIR0 register. The interrupt can
of the IPR0 register. be enabled/disabled by setting/clearing the enable bit,
IOCIE of the PIE0 register. Pins must also be
individually enabled in the IOCxP and IOCxN register.
IOCIF is a read-only bit and the flag can be cleared by
clearing the corresponding IOCxF registers. For more
information refer to Section 16.0 Interrupt-on-
Change.

14.12 Context Saving During Interrupts


During interrupts, the return PC address is saved on
the stack. Additionally, the WREG, STATUS and BSR
registers are saved on the fast return stack. If a fast
return from interrupt is not used (see Section
10.2.2 Fast Register Stack), the user may need to
save the WREG, STATUS and BSR registers on entry
to the Interrupt Service Routine. Depending on the
users application, other registers may also need to be
saved. Example 14-1 saves and restores the WREG,
STATUS and BSR registers during an Interrupt Service
Routine.

EXAMPLE 14-1: SAVING STATUS, WREG AND BSR REGISTERS IN RAM


MOVWF W_TEMP ; W_TEMP is in virtual bank
MOVFF STATUS, STATUS_TEMP ; STATUS_TEMP located anywhere
MOVFF BSR, BSR_TEMP ; BSR_TEMP located anywhere
;
; USER ISR CODE
;
MOVFF BSR_TEMP, BSR ; Restore BSR
MOVF W_TEMP, W ; Restore WREG
MOVFF STATUS_TEMP, STATUS ; Restore STATUS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 194


PIC18(L)F26/45/46K40

TABLE 14-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page

INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169


PIE0 TMR0IE IOCIE INT2IE INT1IE INT0IE 178
PIE1 OSCFIE CSWIE ADTIE ADIE 179
PIE2 HLVDIE ZCDIE C2IE C1IE 180
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE 182
PIE5 TMR5GIE TMR3GIE TMR1GIE 183
PIE6 CCP2IE CCP1IE 184
PIE7 SCANIE CRCIE NVMIE CWG1IE 185
PIR0 TMR0IF IOCIF INT2IF INT1IF INT0IF 170
PIR1 OSCFIF CSWIF ADTIF ADIF 171
PIR2 HLVDIF ZCDIF C2IF C1IF 172
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF 174
PIR5 TMR5GIF TMR3GIF TMR1GIF 175
PIR6 CCP2IF CCP1IF 176
PIR7 SCANIF CRCIF NVMIF CWG1IF 177
IPR0 TMR0IP IOCIP INT2IP INT1IP INT0IP 186
IPR1 OSCFIP CSWIP ADTIP ADIP 187
IPR2 HLVDIP ZCDIP C2IP C1IP 188
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
IPR4 TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP 190
IPR5 TMR5GIP TMR3GIP TMR1GIP 191
IPR6 CCP2IP CCP1IP 192
IPR7 SCANIP CRCIP NVMIP CWG1IP 193
Legend: = unimplemented locations, read as 0. Shaded bits are not used for Interrupts.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 195


PIC18(L)F26/45/46K40
15.0 I/O PORTS FIGURE 15-1: GENERIC I/O PORT
OPERATION
TABLE 15-1: PORT AVAILABILITY PER
DEVICE

PORTE
PORTB

PORTC

PORTD
PORTA
Read LATx
TRISx
Device
D Q

PIC18(L)F26K40 Write LATx


Write PORTx
PIC18(L)F45/46K40 CK VDD
Each port has eight registers to control the operation. Data Register
These registers are:
Data Bus
PORTx registers (reads the levels on the pins of
I/O pin
the device) Read PORTx
LATx registers (output latch)
To digital peripherals
TRISx registers (data direction) VSS
ANSELx
ANSELx registers (analog select) To analog peripherals
WPUx registers (weak pull-up)
INLVLx (input level control)
SLRCONx registers (slew rate control)
ODCONx registers (open-drain control)
Most port pins share functions with device peripherals,
both analog and digital. In general, when a peripheral
is enabled on a port pin, that pin cannot be used as a
general purpose output; however, the pin can still be
read.
The Data Latch (LATx registers) is useful for
read-modify-write operations on the value that the I/O
pins are driving.
A write operation to the LATx register has the same
effect as a write to the corresponding PORTx register.
A read of the LATx register reads of the values held in
the I/O PORT latches, while a read of the PORTx
register reads the actual I/O pin value.
Ports that support analog inputs have an associated
ANSELx register. When an ANSELx bit is set, the
digital input buffer associated with that bit is disabled.
Disabling the input buffer prevents analog signal levels
on the pin between a logic high and low from causing
excessive current in the logic input circuitry. A
simplified model of a generic I/O port, without the
interfaces to other peripherals, is shown in Figure 15-1.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 196


PIC18(L)F26/45/46K40
15.1 I/O Priorities EXAMPLE 15-1: INITIALIZING PORTA
; This code example illustrates
Each pin defaults to the PORT data latch after Reset.
; initializing the PORTA register. The
Other functions are selected with the peripheral pin ; other ports are initialized in the same
select logic. See Section 17.0 Peripheral Pin Select ; manner.
(PPS) Module for more information.
Analog input functions, such as ADC and comparator BANKSEL PORTA ;
inputs, are not shown in the peripheral pin select lists. CLRF PORTA ;Init PORTA
These inputs are active when the I/O pin is set for BANKSEL LATA ;Data Latch
CLRF LATA ;
Analog mode using the ANSELx register. Digital output
BANKSEL ANSELA ;
functions may continue to control the pin when it is in CLRF ANSELA ;digital I/O
Analog mode. BANKSEL TRISA ;
Analog outputs, when enabled, take priority over digital MOVLW B'11111000' ;Set RA<7:3> as inputs
outputs and force the digital output driver into a MOVWF TRISA ;and set RA<2:0> as
high-impedance state. ;outputs

The pin function priorities are as follows:


1. Configuration bits 15.2.2 DIRECTION CONTROL
2. Analog outputs (disable the input buffers) The TRISx register (Register 15-2) controls the PORTx
3. Analog inputs pin output drivers, even when they are being used as
4. Port inputs and outputs from PPS analog inputs. The user should ensure the bits in the
TRISx register are maintained set when using them as
analog inputs. I/O pins configured as analog inputs
15.2 PORTx Registers always read 0.
In this section the generic names such as PORTx,
LATx, TRISx, etc. can be associated with PORTA, 15.2.3 ANALOG CONTROL
PORTB, PORTC and PORTD. For availability of The ANSELx register (Register 15-4) is used to
PORTD refer to Table 15-1. The functionality of configure the Input mode of an I/O pin to analog.
PORTE is different compared to other ports and is Setting the appropriate ANSELx bit high will cause all
explained in a separate section. digital reads on the pin to be read as 0 and allow
analog functions on the pin to operate correctly.
15.2.1 DATA REGISTER
The state of the ANSELx bits has no effect on digital
PORTx is an 8-bit wide, bidirectional port. The output functions. A pin with TRIS clear and ANSEL set
corresponding data direction register is TRISx will still operate as a digital output, but the Input mode
(Register 15-2). Setting a TRISx bit (1) will make the will be analog. This can cause unexpected behavior
corresponding PORTA pin an input (i.e., disable the when executing read-modify-write instructions on the
output driver). Clearing a TRISx bit (0) will make the affected port.
corresponding PORTx pin an output (i.e., it enables
output driver and puts the contents of the output latch Note: The ANSELx bits default to the Analog
on the selected pin). Example 15-1 shows how to mode after Reset. To use any pins as
initialize PORTx. digital general purpose or peripheral
inputs, the corresponding ANSEL bits
Reading the PORTx register (Register 15-1) reads the must be initialized to 0 by user software.
status of the pins, whereas writing to it will write to the
PORT latch. All write operations are read-modify-write 15.2.4 OPEN-DRAIN CONTROL
operations. Therefore, a write to a port implies that the
port pins are read, this value is modified and then The ODCONx register (Register 15-6) controls the
written to the PORT data latch (LATx). open-drain feature of the port. Open-drain operation is
independently selected for each pin. When an
The PORT data latch LATx (Register 15-3) holds the
ODCONx bit is set, the corresponding port output
output port data and contains the latest value of a LATx
becomes an open-drain driver capable of sinking
or PORTx write.
current only. When an ODCONx bit is cleared, the
corresponding port output pin is the standard push-pull
drive capable of sourcing and sinking current.

Note: It is not necessary to set open-drain


control when using the pin for I2C; the I2C
module controls the pin and makes the pin
open-drain.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 197


PIC18(L)F26/45/46K40
15.2.5 SLEW RATE CONTROL Clearing a TRISE bit (= 0) will make the corresponding
PORTE pin an output (i.e., enable the output driver and
The SLRCONx register (Register 15-7) controls the
put the contents of the output latch on the selected pin).
slew rate option for each port pin. Slew rate for each
port pin can be controlled independently. When an TRISE controls the direction of the REx pins, even
SLRCONx bit is set, the corresponding port pin drive is when they are being used as analog pins. The user
slew rate limited. When an SLRCONx bit is cleared, must make sure to keep the pins configured as inputs
The corresponding port pin drive slews at the maximum when using them as analog inputs. RE<2:0> bits have
rate possible. other registers associated with them (i.e., ANSELE,
WPUE, INLVLE, SLRCONE and ODCONE). The
15.2.6 INPUT THRESHOLD CONTROL functionality is similar to the other ports.
The INLVLx register (Register 15-8) controls the input The Data Latch register (LATE) is also memory
voltage threshold for each of the available PORTx input mapped. Read-modify-write operations on the LATE
pins. A selection between the Schmitt Trigger CMOS or register read and write the latched output value for
the TTL compatible thresholds is available. The input PORTE.
threshold is important in determining the value of a read
Note: On a Power-on Reset, RE<2:0> are
of the PORTx register and also the level at which an
configured as analog inputs.
interrupt-on-change occurs, if that feature is enabled.
See Table 37-8 for more information on threshold The fourth pin of PORTE (MCLR/VPP/RE3) is an input-
levels. only pin. Its operation is controlled by the MCLRE
Configuration bit. When selected as a port pin
Note: Changing the input threshold selection
(MCLRE = 0), it functions as a digital input-only pin; as
should be performed while all peripheral
such, it does not have TRIS or LAT bits associated with its
modules are disabled. Changing the
operation. Otherwise, it functions as the devices Master
threshold level during the time a module is
Clear input. In either configuration, RE3 also functions as
active may inadvertently generate a
the programming voltage input during programming.
transition associated with an input pin,
regardless of the actual voltage level on RE3 in PORTE register is a read-only bit and will read 1
that pin. when MCLRE = 1 (i.e., Master Clear enabled).
Note: On a Power-on Reset, RE3 is enabled as
15.2.7 WEAK PULL-UP CONTROL
a digital input only if Master Clear
The WPUx register (Register 15-5) controls the functionality is disabled.
individual weak pull-ups for each port pin.

15.2.8 EDGE SELECTABLE EXAMPLE 15-2: INITIALIZING PORTE


INTERRUPT-ON-CHANGE CLRF PORTE ; Initialize PORTE by
; clearing output
An interrupt can be generated by detecting a signal at ; data latches
the port pin that has either a rising edge or a falling CLRF LATE ; Alternate method
edge. Any individual pin can be configured to generate ; to clear output
an interrupt. The interrupt-on-change module is pres- ; data latches
ent on all the pins that are common between 28-pin and CLRF ANSELE ; Configure analog pins
40/44-pin devices. For further details about the IOC ; for digital only
MOVLW 05h ; Value used to
module refer to Section 16.0 Interrupt-on-Change.
; initialize data
; direction
15.3 PORTE Registers MOVWF TRISE ; Set RE<0> as input
; RE<1> as output
Depending on the device selected, PORTE is ; RE<2> as input
implemented in two different ways.

15.3.1 PORTE ON 40/44-PIN DEVICES 15.3.2 PORTE ON 28-PIN DEVICES


For PIC18(L)F2xK40 devices, PORTE is only available
For PIC18(L)F4xK40 devices, PORTE is a 4-bit wide
when Master Clear functionality is disabled
port. Three pins (RE0, RE1 and RE2) are individually
(MCLRE = 0). In this case, PORTE is a single bit, input-
configurable as inputs or outputs. These pins have
only port comprised of RE3 only. The pin operates as
Schmitt Trigger input buffers. When selected as an previously described. RE3 in PORTE register is a read-
analog input, these pins will read as 0s. only bit and will read 1 when MCLRE = 1 (i.e., Master
The corresponding data direction register is TRISE. Clear enabled).
Setting a TRISE bit (= 1) will make the corresponding
PORTE pin an input (i.e., disable the output driver).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 198


PIC18(L)F26/45/46K40
15.3.3 RE3 WEAK PULL-UP
The port RE3 pin has an individually controlled weak
internal pull-up. When set, the WPUE3 bit enables the
RE3 pin pull-up. When the RE3 port pin is configured
as MCLR, (CONFIG2L, MCLRE = 1 and CONFIG4H,
LVP = 0), or configured for Low-Voltage Programming,
(MCLRE = x and LVP = 1), the pull-up is always
enabled and the WPUE3 bit has no effect.

15.3.4 INTERRUPT-ON-CHANGE
The interrupt-on-change feature is available only on the
RE3 pin for all devices. For further details refer to
Section 14.11 Interrupt-on-Change.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 199


PIC18(L)F26/45/46K40
15.4 Register Definitions: Port Control
REGISTER 15-1: PORTx: PORTx REGISTER(1)
R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
Rx7 Rx6 Rx5 Rx4 Rx3 Rx2 Rx1 Rx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 Rx<7:0>: Rx7:Rx0 Port I/O Value bits


1 = Port pin is VIH
0 = Port pin is VIL

Note 1: Writes to PORTx are actually written to the corresponding LATx register.
Reads from PORTx register return actual I/O pin values.

TABLE 15-2: PORT REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
PORTA X X RA7 RA6 RA5 RA4 RA3 RA2 RA1 RA0
PORTB X X RB7(1) RB6(1) RB5 RB4 RB3 RB2 RB1 RB0
PORTC X X RC7 RC6 RC5 RC4 RC3 RC2 RC1 RC0
PORTD X
X RD7 RD6 RD5 RD4 RD3 RD2 RD1 RD0
PORTE X RE3(2)
X RE3(2) RE2 RE1 RE0
Note 1: Bits RB6 and RB7 read 1 while in Debug mode.
2: Bit PORTE3 is read-only, and will read 1 when MCLRE = 1 (Master Clear enabled).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 200


PIC18(L)F26/45/46K40

REGISTER 15-2: TRISx: TRI-STATE CONTROL REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
TRISx7 TRISx6 TRISx5 TRISx4 TRISx3 TRISx2 TRISx1 TRISx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 TRISx<7:0>: TRISx Port I/O Tri-state Control bits


1 = Port output driver is disabled
0 = Port output driver is enabled

TABLE 15-3: TRIS REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
TRISA X X TRISA7 TRISA6 TRISA5 TRISA4 TRISA3 TRISA2 TRISA1 TRISA0
TRISB X X TRISB7(1) TRISB6(1) TRISB5 TRISB4 TRISB3 TRISB2 TRISB1 TRISB0
TRISC X X TRISC7 TRISC6 TRISC5 TRISC4 TRISC3 TRISC2 TRISC1 TRISC0
TRISD X
X TRISD7 TRISD6 TRISD5 TRISD4 TRISD3 TRISD2 TRISD1 TRISD0
TRISE X
X (2) TRISE2 TRISE1 TRISE0
Note 1: Bits RB6 and RB7 read 1 while in Debug mode.
2: TRISE3 bit is read-only, and will read 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 201


PIC18(L)F26/45/46K40

REGISTER 15-3: LATx: LATx REGISTER(1)


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
LATx7 LATx6 LATx5 LATx4 LATx3 LATx2 LATx1 LATx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 LATx<7:0>: Rx7:Rx0 Output Latch Value bits


Note 1: Writes to LATx are equivalent with writes to the corresponding PORTx register. Reads from LATx register
return register values, not I/O pin values.

TABLE 15-4: LAT REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
LATA X X LATA7 LATA6 LATA5 LATA4 LATA3 LATA2 LATA1 LATA0
LATB X X LATB7 LATB6 LATB5 LATB4 LATB3 LATB2 LATB1 LATB0
LATC X X LATC7 LATC6 LATC5 LATC4 LATC3 LATC2 LATC1 LATC0
LATD X
X LATD7 LATD6 LATD5 LATD4 LATD3 LATD2 LATD1 LATD0
LATE X
X LATE2 LATE1 LATE0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 202


PIC18(L)F26/45/46K40

REGISTER 15-4: ANSELx: ANALOG SELECT REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
ANSELx7 ANSELx6 ANSELx5 ANSELx4 ANSELx3 ANSELx2 ANSELx1 ANSELx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 ANSELx<7:0>: Analog Select on Pins Rx<7:0>


1 = Digital Input buffers are disabled.
0 = ST and TTL input devices are enabled

TABLE 15-5: ANALOG SELECT PORT REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
ANSELA X X ANSELA7 ANSELA6 ANSELA5 ANSELA4 ANSELA3 ANSELA2 ANSELA1 ANSELA0
ANSELB X X ANSELB7 ANSELB6 ANSELB5 ANSELB4 ANSELB3 ANSELB2 ANSELB1 ANSELB0
ANSELC X X ANSELC7 ANSELC6 ANSELC5 ANSELC4 ANSELC3 ANSELC2 ANSELC1 ANSELC0
ANSELD X
X ANSELD7 ANSELD6 ANSELD5 ANSELD4 ANSELD3 ANSELD2 ANSELD1 ANSELD0
ANSELE X
X ANSELE2 ANSELE1 ANSELE0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 203


PIC18(L)F26/45/46K40

REGISTER 15-5: WPUx: WEAK PULL-UP REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
WPUx7 WPUx6 WPUx5 WPUx4 WPUx3 WPUx2 WPUx1 WPUx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 WPUx<7:0>: Weak Pull-up PORTx Control bits


1 = Weak Pull-up enabled
0 = Weak Pull-up disabled

TABLE 15-6: WEAK PULL-UP PORT REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
WPUA X X WPUA7 WPUA6 WPUA5 WPUA4 WPUA3 WPUA2 WPUA1 WPUA0
WPUB X X WPUB7 WPUB6 WPUB5 WPUB4 WPUB3 WPUB2 WPUB1 WPUB0
WPUC X X WPUC7 WPUC6 WPUC5 WPUC4 WPUC3 WPUC2 WPUC1 WPUC0
WPUD X
X WPUD7 WPUD6 WPUD5 WPUD4 WPUD3 WPUD2 WPUD1 WPUD0
WPUE X WPUE3(1)
X WPUE3(1) WPUE2 WPUE1 WPUE0
Note 1: If MCLRE = 1, the weak pull-up in RE3 is always enabled; bit WPUE3 is not affected.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 204


PIC18(L)F26/45/46K40

REGISTER 15-6: ODCONx: OPEN-DRAIN CONTROL REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ODCx7 ODCx6 ODCx5 ODCx4 ODCx3 ODCx2 ODCx1 ODCx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 ODCx<7:0>: Open-Drain Configuration on Pins Rx<7:0>


1 = Output drives only low-going signals (sink current only)
0 = Output drives both high-going and low-going signals (source and sink current)

TABLE 15-7: OPEN-DRAIN CONTROL REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
ODCONA X X ODCA7 ODCA6 ODCA5 ODCA4 ODCA3 ODCA2 ODCA1 ODCA0
ODCONB X X ODCB7 ODCB6 ODCB5 ODCB4 ODCB3 ODCB2 ODCB1 ODCB0
ODCONC X X ODCC7 ODCC6 ODCC5 ODCC4 ODCC3 ODCC2 ODCC1 ODCC0
ODCOND X
X ODCD7 ODCD6 ODCD5 ODCD4 ODCD3 ODCD2 ODCD1 ODCD0
ODCONE X
X ODCE2 ODCE1 ODCE0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 205


PIC18(L)F26/45/46K40

REGISTER 15-7: SLRCONx: SLEW RATE CONTROL REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
SLRx7 SLRx6 SLRx5 SLRx4 SLRx3 SLRx2 SLRx1 SLRx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 SLRx<7:0>: Slew Rate Control on Pins Rx<7:0>, respectively


1 = Port pin slew rate is limited
0 = Port pin slews at maximum rate

TABLE 15-8: SLEW RATE CONTROL REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
SLRCONA X X SLRA7 SLRA6 SLRA5 SLRA4 SLRA3 SLRA2 SLRA1 SLRA0
SLRCONB X X SLRB7 SLRB6 SLRB5 SLRB4 SLRB3 SLRB2 SLRB1 SLRB0
SLRCONC X X SLRC7 SLRC6 SLRC5 SLRC4 SLRC3 SLRC2 SLRC1 SLRC0
SLRCOND X
X SLRD7 SLRD6 SLRD5 SLRD4 SLRD3 SLRD2 SLRD1 SLRD0
SLRCONE X
X SLRE2 SLRE1 SLRE0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 206


PIC18(L)F26/45/46K40

REGISTER 15-8: INLVLx: INPUT LEVEL CONTROL REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
INLVLx7 INLVLx6 INLVLx5 INLVLx4 INLVLx3 INLVLx2 INLVLx1 INLVLx0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
1 = Bit is set 0 = Bit is cleared x = Bit is unknown
-n/n = Value at POR and BOR/Value at all other Resets

bit 7-0 INLVLx<7:0>: Input Level Select on Pins Rx<7:0>, respectively


1 = ST input used for port reads and interrupt-on-change
0 = TTL input used for port reads and interrupt-on-change

TABLE 15-9: INPUT LEVEL PORT REGISTERS


Device
Name 28 40/44 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
Pins Pins
INLVLA X X INLVLA7 INLVLA6 INLVLA5 INLVLA4 INLVLA3 INLVLA2 INLVLA1 INLVLA0
INLVLB X X INLVLB7 INLVLB6 INLVLB5 INLVLB4 INLVLB3 INLVLB2(1) INLVLB1(1) INLVLB0
INLVLC X X INLVLC7 INLVLC6 INLVLC5 INLVLC4(1) INLVLC3(1) INLVLC2 INLVLC1 INLVLC0
INLVLD X
(1)
X INLVLD7 INLVLD6 INLVLD5 INLVLD4 INLVLD3 INLVLD2 INLVLD1 INLVLD0(1)
INLVLE X INLVLE3
X INLVLE3 INLVLE2 INLVLE1 INLVLE0
Note 1: Pins read the I2C ST inputs when MSSP inputs select these pins, and I2C mode is enabled.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 207


PIC18(L)F26/45/46K40
16.0 INTERRUPT-ON-CHANGE 16.3 Interrupt Flags
PORTA, PORTB, PORTC and pin RE3 of PORTE can The IOCAFx, IOCBFx, IOCCFx and IOCEF3 bits located
be configured to operate as Interrupt-on-Change (IOC) in the IOCAF, IOCBF, IOCCF and IOCEF registers
pins on PIC18(L)F2x/4xK40 family devices. An interrupt respectively, are status flags that correspond to the
can be generated by detecting a signal that has either a interrupt-on-change pins of the associated port. If an
rising edge or a falling edge. Any individual port pin, or expected edge is detected on an appropriately enabled
combination of port pins, can be configured to generate pin, then the status flag for that pin will be set, and an
an interrupt. The interrupt-on-change module has the interrupt will be generated if the IOCIE bit is set. The
following features: IOCIF bit of the PIR0 register reflects the status of all
IOCAFx, IOCBFx, IOCCFx and IOCEF3 bits.
Interrupt-on-Change enable (Master Switch)
Individual pin configuration
16.4 Clearing Interrupt Flags
Rising and falling edge detection
Individual pin interrupt flags The individual status flags, (IOCAFx, IOCBFx, IOCCFx
and IOCEF3 bits), can be cleared by resetting them to
Figure 16-1 is a block diagram of the IOC module.
zero. If another edge is detected during this clearing
operation, the associated status flag will be set at the
16.1 Enabling the Module end of the sequence, regardless of the value actually
To allow individual port pins to generate an interrupt, the being written.
IOCIE bit of the PIE0 register must be set. If the IOCIE In order to ensure that no detected edge is lost while
bit is disabled, the edge detection on the pin will still clearing flags, only AND operations masking out known
occur, but an interrupt will not be generated. changed bits should be performed. The following
sequence is an example of what should be performed.
16.2 Individual Pin Configuration
EXAMPLE 16-1: CLEARING INTERRUPT
For each port pin, a rising edge detector and a falling
FLAGS
edge detector are present. To enable a pin to detect a
(PORTA EXAMPLE)
rising edge, the associated bit of the IOCxP register is
set. To enable a pin to detect a falling edge, the MOVLW 0xff
associated bit of the IOCxN register is set. XORWF IOCAF, W
ANDWF IOCAF, F
A pin can be configured to detect rising and falling
edges simultaneously by setting both associated bits of
the IOCxP and IOCxN registers, respectively. 16.5 Operation in Sleep
The interrupt-on-change interrupt sequence will wake
the device from Sleep mode, if the IOCIE bit is set.
If an edge is detected while in Sleep mode, the IOCxF
register will be updated prior to the first instruction
executed out of Sleep.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 208


PIC18(L)F26/45/46K40
FIGURE 16-1: INTERRUPT-ON-CHANGE BLOCK DIAGRAM (PORTA EXAMPLE)

Rev. 10-000 037A


6/2/201 4

IOCANx D Q

R Q4Q1
edge
detect

RAx

to data bus
data bus = S
IOCAFx
IOCAPx D Q
0 or 1
D Q

R
write IOCAFx
IOCIE
Q2
IOC interrupt
to CPU core
from all other
IOCnFx individual
pin detectors

FOSC

Q1 Q1 Q1

Q2 Q2 Q2

Q3 Q3 Q3

Q4 Q4 Q4

Q4Q1 Q4Q1 Q4Q1 Q4Q1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 209


PIC18(L)F26/45/46K40
16.6 Register Definitions: Interrupt-on-Change Control

REGISTER 16-1: IOCxP: INTERRUPT-ON-CHANGE POSITIVE EDGE REGISTER EXAMPLE


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
IOCxP7 IOCxP6 IOCxP5 IOCxP4 IOCxP3 IOCxP2 IOCxP1 IOCxP0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 IOCxP<7:0>: Interrupt-on-Change Positive Edge Enable bits


1 = Interrupt-on-Change enabled on the IOCx pin for a positive-going edge. Associated Status bit and interrupt flag
will be set upon detecting an edge.
0 = Interrupt-on-Change disabled for the associated pin.

REGISTER 16-2: IOCxN: INTERRUPT-ON-CHANGE NEGATIVE EDGE REGISTER EXAMPLE


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
IOCxN7 IOCxN6 IOCxN5 IOCxN4 IOCxN3 IOCxN2 IOCxN1 IOCxN0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 IOCxN<7:0>: Interrupt-on-Change Negative Edge Enable bits


1 = Interrupt-on-Change enabled on the IOCx pin for a negative-going edge. Associated Status bit and interrupt
flag will be set upon detecting an edge.
0 = Interrupt-on-Change disabled for the associated pin

REGISTER 16-3: IOCxF: INTERRUPT-ON-CHANGE FLAG REGISTER EXAMPLE


R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0 R/W/HS-0/0
IOCxF7 IOCxF6 IOCxF5 IOCxF4 IOCxF3 IOCxF2 IOCxF1 IOCxF0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HS - Bit is set in hardware

bit 7-0 IOCxF<7:0>: Interrupt-on-Change Flag bits


1 = A enabled change was detected on the associated pin. Set when IOCP[n] = 1 and a positive edge was detected
on the IOCn pin, or when IOCN[n] = 1 and a negative edge was detected on the IOCn pin
0 = No change was detected, or the user cleared the detected change

2016 Microchip Technology Inc. Preliminary DS40001816C-page 210


PIC18(L)F26/45/46K40

TABLE 16-1: IOC REGISTERS


Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
IOCAP IOCAP7 IOCAP6 IOCAP5 IOCAP4 IOCAP3 IOCAP2 IOCAP1 IOCAP0
IOCAN IOCAN7 IOCAN6 IOCAN5 IOCAN4 IOCAN3 IOCAN2 IOCAN1 IOCAN0
IOCAF IOCAF7 IOCAF6 IOCAF5 IOCAF4 IOCAF3 IOCAF2 IOCAF1 IOCAF0
IOCBP IOCBP7 IOCBP6 IOCBP5 IOCBP4 IOCBP3 IOCBP2 IOCBP1 IOCBP0
IOCBN IOCBN7 IOCBN6 IOCBN5 IOCBN4 IOCBN3 IOCBN2 IOCBN1 IOCBN0
IOCBF IOCBF7 IOCBF6 IOCBF5 IOCBF4 IOCBF3 IOCBF2 IOCBF1 IOCBF0
IOCCP IOCCP7 IOCCP6 IOCCP5 IOCCP4 IOCCP3 IOCCP2 IOCCP1 IOCCP0
IOCCN IOCCN7 IOCCN6 IOCCN5 IOCCN4 IOCCN3 IOCCN2 IOCCN1 IOCCN0
IOCCF IOCCF7 IOCCF6 IOCCF5 IOCCF4 IOCCF3 IOCCF2 IOCCF1 IOCCF0
IOCEP IOCEP3 (1)
IOCEN IOCEN3(1)
IOCEF IOCEF3(1)
Note 1: If MCLRE = 1 or LVP = 1, RE3 port functionality is disabled and IOC on RE3 is not available.

TABLE 16-2: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPT-ON-CHANGE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
IOCxF IOCxF7 IOCxF6 IOCxF5 IOCxF4 IOCxF3 IOCxF2 IOCxF1 IOCxF0 210
IOCxN IOCxN7 IOCxN6 IOCxN5 IOCxN4 IOCxN3 IOCxN2 IOCxN1 IOCxN0 210
IOCxP IOCxP7 IOCxP6 IOCxP5 IOCxP4 IOCxP3 IOCxP2 IOCxP1 IOCxP0 210
Legend: = unimplemented location, read as 0. Shaded cells are not used by interrupt-on-change.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 211


PIC18(L)F26/45/46K40
17.0 PERIPHERAL PIN SELECT
(PPS) MODULE
The Peripheral Pin Select (PPS) module connects
peripheral inputs and outputs to the device I/O pins. Only
digital signals are included in the selections. All analog
inputs and outputs remain fixed to their assigned pins.
Input and output selections are independent as shown in
the simplified block diagram Figure 17-1.
The peripheral input is selected with the peripheral
xxxPPS register (Register 17-1), and the peripheral
output is selected with the PORT RxyPPS register
(Register 17-2). For example, to select PORTC<7> as
the EUSART RX input, set RXxPPS to 5b1 0111,
and to select PORTC<6> as the EUSART TX output
set RC6PPS to 5'b0 1001.

17.1 PPS Inputs


Each peripheral has a PPS register with which the
inputs to the peripheral are selected. Inputs include the
device pins.
Multiple peripherals can operate from the same source
simultaneously. Port reads always return the pin level
regardless of peripheral PPS selection. If a pin also has
analog functions associated, the ANSEL bit for that pin
must be cleared to enable the digital input buffer.
Although every peripheral has its own PPS input selec-
tion register, the selections are identical for every
peripheral as shown in Register 17-1.
Note: The notation xxx in the register name is
a place holder for the peripheral identifier.
For example, INT0PPS.

17.2 PPS Outputs


Each I/O pin has a PPS register with which the pin
output source is selected. With few exceptions, the port
TRIS control associated with that pin retains control
over the pin output driver. Peripherals that control the
pin output driver as part of the peripheral operation will
override the TRIS control as needed. These
peripherals include:
EUSART (synchronous operation)
MSSP (I2C)
Although every pin has its own PPS peripheral
selection register, the selections are identical for every
pin as shown in Register 17-2.
Note: The notation Rxy is a place holder for the
pin identifier. For example, RA0PPS.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 212


PIC18(L)F26/45/46K40
FIGURE 17-1: SIMPLIFIED PPS BLOCK DIAGRAM
Rev. 10-000262A
12/8/2015

RA0PPS

abcPPS
RA0
RA0
Peripheral abc

RxyPPS

Rxy

Peripheral xyz
RE2PPS
RD7(1)

xyzPPS
RE2(1)

Note 1: PORTD<7:0> and PORTE<2:0> are only available on PIC18(L)F4xK40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 213


PIC18(L)F26/45/46K40
17.3 Bidirectional Pins EXAMPLE 17-2: PPS UNLOCK SEQUENCE
; Disable interrupts:
PPS selections for peripherals with bidirectional BCF INTCON,GIE
signals on a single pin must be made so that the PPS
input and PPS output select the same pin. Peripherals ; Bank to PPSLOCK register
that have bidirectional signals include: BANKSEL PPSLOCK
MOVLB PPSLOCK
EUSART (synchronous operation)
MOVLW 55h
MSSP (I2C)
CCP module ; Required sequence, next 4 instructions
MOVWF PPSLOCK
MOVLW AAh
Note: The I2C default input pins are I2C and MOVWF PPSLOCK
SMBus compatible. RB1 and RB2 are
additional pins. RC4 and RC3 are default ; Clear PPSLOCKED bit to enable writes
MMP1 pins and are SMBus compatible. ; Only a BCF instruction will work
BCF PPSLOCK,0
Clock and data signals can be routed to
any pin, however pins without I2C
; Enable Interrupts
compatibility will operate at standard BSF INTCON,GIE
TTL/ST logic levels as selected by the
INVLV register.
17.5 PPS One-Way Lock
17.4 PPS Lock Using the PPS1WAY Configuration bit, the PPS
settings can be locked in. When this bit is set, the
The PPS includes a mode in which all input and output
PPSLOCKED bit can only be cleared and set one time
selections can be locked to prevent inadvertent
after a device Reset. This allows for clearing the
changes. PPS selections are locked by setting the
PPSLOCKED bit so that the input and output selections
PPSLOCKED bit of the PPSLOCK register. Setting and
can be made during initialization. When the
clearing this bit requires a special sequence as an extra
PPSLOCKED bit is set after all selections have been
precaution against inadvertent changes. Examples of
made, it will remain set and cannot be cleared until after
setting and clearing the PPSLOCKED bit are shown in
the next device Reset event.
Example 17-1.

EXAMPLE 17-1: PPS LOCK SEQUENCE 17.6 Operation During Sleep


; Disable interrupts: PPS input and output selections are unaffected by
BCF INTCON,GIE Sleep.
; Bank to PPSLOCK register
BANKSEL PPSLOCK 17.7 Effects of a Reset
MOVLB PPSLOCK
A device Power-on-Reset (POR) clears all PPS input
MOVLW 55h
and output selections to their default values. All other
; Required sequence, next 4 instructions Resets leave the selections unchanged. Default input
MOVWF PPSLOCK selections are shown in the Section Pin Allocation
MOVLW AAh Tables.The PPS one-way is also removed.
MOVWF PPSLOCK

; Set PPSLOCKED bit to disable writes


; Only a BSF instruction will work
BSF PPSLOCK,0

; Enable Interrupts
BSF INTCON,GIE

2016 Microchip Technology Inc. Preliminary DS40001816C-page 214


PIC18(L)F26/45/46K40
17.8 Register Definitions: PPS Input Selection
REGISTER 17-1: xxxPPS: PERIPHERAL xxx INPUT SELECTION
U-0 U-0 U-0 R/W-m/u(1) R/W-m/u(1) R/W-m/u(1) R/W-m/u(1) R/W-m/u(1)
xxxPPS<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit -n/n = Value at POR and BOR/Value at all other Resets
u = Bit is unchanged x = Bit is unknown q = value depends on peripheral
1 = Bit is set U = Unimplemented bit, m = value depends on default location for that input
0 = Bit is cleared read as 0

bit 7-5 Unimplemented: Read as 0


bit 4-3 xxxPPS<4:3>: Peripheral xxx Input PORTx Pin Selection bits
See Table 17-1 for the list of available ports and default pin locations.
11 = PORTD (PIC18(L)F4xK40 only)
10 = PORTC
01 = PORTB
00 = PORTA
bit 2-0 xxxPPS<2:0>: Peripheral xxx Input PORTx Pin Selection bits
111 = Peripheral input is from PORTx Pin 7 (Rx7)
110 = Peripheral input is from PORTx Pin 6 (Rx6)
101 = Peripheral input is from PORTx Pin 5 (Rx5)
100 = Peripheral input is from PORTx Pin 4 (Rx4)
011 = Peripheral input is from PORTx Pin 3 (Rx3)
010 = Peripheral input is from PORTx Pin 2 (Rx2)
001 = Peripheral input is from PORTx Pin 1 (Rx1)
000 = Peripheral input is from PORTx Pin 0 (Rx0)

Note 1: The Reset value m of this register is determined by device default locations for that input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 215


PIC18(L)F26/45/46K40

TABLE 17-1: PPS INPUT REGISTER DETAILS


Default Pin Register Reset Input Available from Selected PORTx
PPS Input
Peripheral Selection Value
Register PIC18(L)F26K40 PIC18(L)F45/46K40
at POR at POR
Interrupt 0 INT0PPS RB0 5b0 1000 A B A B
Interrupt 1 INT1PPS RB1 5b0 1001 A B A B
Interrupt 2 INT2PPS RB2 5b0 1010 A B A B
Timer0 Clock T0CKIPPS RA4 5b0 0100 A B A B
Timer1 Clock T1CKIPPS RC0 5b1 0000 A C A C
Timer1 Gate T1GPPS RB5 5b0 1101 B C B C
Timer3 Clock T3CKIPPS RC0 5b1 0000 B C B C
Timer3 Gate T3GPPS RC0 5b1 0000 A C A C
Timer5 Clock T5CKIPPS RC2 5b1 0010 A C A C
Timer5 Gate T5GPPS RB4 5b0 1100 B C B D
Timer2 Clock T2INPPS RC3 5b1 0011 A C A C
Timer4 Clock T4INPPS RC5 5b1 0101 B C B C
Timer6 Clock T6INPPS RB7 5b0 1111 B C B D
CCP1 CCP1PPS RC2 5b1 0010 B C B C
CCP2 CCP2PPS RC1 5b1 0001 B C B C
CWG CWG1PPS RB0 5b0 1000 B C B D
DSM Carrier Low MDCARLPPS RA3 5b0 0011 A C A D
DSM Carrier High MDCARHPPS RA4 5b0 0100 A C A D
DSM Source MDSRCPPS RA5 5b0 0101 A C A D
ADC Conversion Trigger ADACTPPS RB4 5b0 1100 B C B D
MSSP1 Clock SSP1CLKPPS RC3 5b1 0011 B C B C
MSSP1 Data SSP1DATPPS RC4 5b1 0100 B C B C
MSSP1 Slave Select SSP1SSPPS RA5 5b0 0101 A C A D
MSSP2 Clock SSP2CLKPPS RB1 5b0 1001 B C B D
MSSP2 Data SSP2DATPPS RB2 5b0 1010 B C B D
MSSP2 Slave Select SSP2SSPPS RB0 5b0 1000 B C B D
EUSART1 Receive RX1PPS RC7 5b1 0111 B C B C
EUSART1 Transmit TX1PPS RC6 5b1 0110 B C B C
EUSART2 Receive RX2PPS RB7 5b0 1111 B C B D
EUSART2 Transmit TX2PPS RB6 5b0 1110 B C B D

2016 Microchip Technology Inc. Preliminary DS40001816C-page 216


PIC18(L)F26/45/46K40

REGISTER 17-2: RxyPPS: PIN Rxy OUTPUT SOURCE SELECTION REGISTER


U-0 U-0 U-0 R/W-0/u R/W-0/u R/W-0/u R/W-0/u R/W-0/u
RxyPPS<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 Unimplemented: Read as 0


bit 4-0 RxyPPS<4:0>: Pin Rxy Output Source Selection bits(1)

Device Configuration
RxyPPS<4:0> Pin Rxy Output Source
PIC18(L)F26K40 PIC18(L)F45/46K40
5b1 0111 ADGRDB A C A C
5b1 0110 ADGRDA A C A C
5b1 0101 DSM A C A D
5b1 0100 CLKR B C B C
5b1 0011 TMR0 B C B C
5b1 0010 MSSP2 (SDO/SDA) B C B D
5b1 0001 MSSP2 (SCK/SCL) B C B D
5b1 0000 MSSP1 (SDO/SDA) B C B C
5b0 1111 MSSP1 (SCK/SCL) B C B C
5b0 1110 CMP2 A C A E
5b0 1101 CMP1 A C A D
5b0 1100 EUSART2 (RX) B C B D
5b0 1011 EUSART2 (TX) B C B D
5b0 1010 EUSART1 (RX) B C B C
5b0 1001 EUSART1 (TX) B C B C
5b0 1000 PWM4 A C A C
5b0 0111 PWM3 A C A D
5b0 0110 CCP2 B C B C
5b0 0101 CCP1 B C B C
5b0 0100 CWG1D B C B D
5b0 0011 CWG1C B C B D
5b0 0010 CWG1B B C B D
5b0 0001 CWG1A B C B C
5b0 0000 LATxy A B C A B C D E

Note 1: PORTD is present only on the PIC18(L)F45/46K40 devices.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 217


PIC18(L)F26/45/46K40

REGISTER 17-3: PPSLOCK: PPS LOCK REGISTER


U-0 U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0
PPSLOCKED
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-1 Unimplemented: Read as 0


bit 0 PPSLOCKED: PPS Locked bit
1 = PPS is locked. PPS selections can not be changed.
0 = PPS is not locked. PPS selections can be changed.

TABLE 17-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE PPS MODULE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
PPSLOCK PPSLOCKED 218
INT0PPS INT0PPS<4:0> 215
INT1PPS INT1PPS<4:0> 215
INT2PPS INT2PPS<4:0> 215
T0CKIPPS T0CKIPPS<4:0> 215
T1CKIPPS T1CKIPPS<4:0> 215
T1GPPS T1GPPS<4:0> 215
T3CKIPPS T3CKIPPS<4:0> 215
T3GPPS T3GPPS<4:0> 215
T5CKIPPS T5CKIPPS<4:0> 215
T5GPPS T5GPPS<4:0> 215
T2INPPS T2INPPS<4:0> 215
T4INPPS T4INPPS<4:0> 215
T6INPPS T6INPPS<4:0> 215
CCP1PPS CCP1PPS<4:0> 215
CCP2PPS CCP2PPS<4:0> 215
CWG1PPS CWG1PPS<4:0> 215
MDCARLPPS MDCARLPPS<4:0> 215
MDCARHPPS MDCARHPPS<4:0> 215
MDSRCPPS MDSRCPPS<4:0> 215
ADACTPPS ADACTPPS<4:0> 215
SSP1CLKPPS SSP1CLKPPS<4:0> 215
SSP1DATPPS SSP1DATPPS<4:0> 215
SSP1SSPPS SSP1SSPPS<4:0> 215
RX1PPS RX1PPS<4:0> 217
TX1PPS TX1PPS<4:0> 215
SSP2CLKPPS SSP2CLKPPS<4:0> 215
SSP2DATPPS SSP2DATPPS<4:0> 215

2016 Microchip Technology Inc. Preliminary DS40001816C-page 218


PIC18(L)F26/45/46K40
TABLE 17-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE PPS MODULE (CONTINUED)
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
SSP2SSPPS SSP2SSPPS<4:0> 215
RX2PPS RX2PPS<4:0> 217
TX2PPS TX2PPS<4:0> 215
RxyPPS RxyPPS<4:0> 217
Legend: = unimplemented, read as 0. Shaded cells are unused by the PPS module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 219


PIC18(L)F26/45/46K40
18.0 TIMER0 MODULE
Timer0 module is an 8/16-bit timer/counter with the
following features:
16-bit timer/counter
8-bit timer/counter with programmable period
Synchronous or asynchronous operation
Selectable clock sources
Programmable prescaler
Programmable postscaler
Operation during Sleep mode
Interrupt on match or overflow
Output on I/O pin (via PPS) or to other peripherals

FIGURE 18-1: BLOCK DIAGRAM OF TIMER0


Rev. 10-000017C
10/27/2015

Reserved 111
Reserved 110 T0_match
Peripherals
SOSC 101 T0CKPS<3:0> TMR0
LFINTOSC 100 body T0OUTPS<3:0> T0IF
Prescaler 1
HFINTOSC 011 IN OUT Postscaler T0_out
SYNC 0
FOSC/4 010
PPS 001 FOSC/4 T016BIT TMR0
T0ASYNC D Q PPS
000
T0CKIPPS CK Q RxyPPS

T0CS<2:0>

8-bit TMR0 Body Diagram (T016BIT = 0) 16-bit TMR0 Body Diagram (T016BIT = 1)

Clear IN TMR0 High OUT


IN TMR0L R TMR0L Byte

Read TMR0L
COMPARATOR OUT
Write TMR0L
T0_match 8
8 TMR0H
TMR0 High
Byte
Latch 8
Enable
TMR0H
8
Internal Data Bus

2016 Microchip Technology Inc. Preliminary DS40001816C-page 220


PIC18(L)F26/45/46K40
18.1 Timer0 Operation Both the prescaler and postscaler counters are cleared
on the following events:
Timer0 can operate as either an 8-bit timer/counter or
A write to the TMR0L register
a 16-bit timer/counter. The mode is selected with the
A write to either the T0CON0 or T0CON1
T016BIT bit of the T0CON register.
registers
18.1.1 16-BIT MODE Any device Reset Power-on Reset (POR),
MCLR Reset, Watchdog Timer Reset (WDTR) or
The register pair TMR0H:TMR0L, increments on the Brown-out Reset (BOR)
rising edge of the clock source. A 15-bit prescaler on
the clock input gives several prescale options (see 18.1.3 COUNTER MODE
prescaler control bits, T0CKPS<3:0> in the T0CON1
In Counter mode, the prescaler is normally disabled by
register).
setting the T0CKPS bits of the T0CON1 register to
18.1.1.1 Timer0 Reads and Writes in 16-Bit 0000. Each rising edge of the clock input (or the
output of the prescaler if the prescaler is used)
Mode
increments the counter by 1.
In 16-bit mode, to avoid rollover between reading high
and low registers, the TMR0H register is a buffered 18.1.4 TIMER MODE
copy of the actual high byte of Timer0, which is neither
In Timer mode, the Timer0 module will increment every
directly readable nor writable (see Figure 18-1).
instruction cycle as long as there is a valid clock signal
TMR0H is updated with the contents of the high byte of
and the T0CKPS bits of the T0CON1 register
Timer0 during a read of TMR0L. This provides the
(Register 18-2) are set to 0000. When a prescaler is
ability to read all 16 bits of Timer0 without having to
added, the timer will increment at the rate based on the
verify that the read of the high and low byte was valid,
prescaler value.
due to a rollover between successive reads of the high
and low byte. 18.1.5 ASYNCHRONOUS MODE
Similarly, a write to the high byte of Timer0 must also When the T0ASYNC bit of the T0CON1 register is set
take place through the TMR0H Buffer register. The high (T0ASYNC = 1), the counter increments with each
byte is updated with the contents of TMR0H when a rising edge of the input source (or output of the
write occurs to TMR0L. This allows all 16 bits of Timer0 prescaler, if used). Asynchronous mode allows the
to be updated at once. counter to continue operation during Sleep mode
provided that the clock also continues to operate during
18.1.2 8-BIT MODE
Sleep.
In normal operation, TMR0 increments on the rising
edge of the clock source. A 15-bit prescaler on the 18.1.6 SYNCHRONOUS MODE
clock input gives several prescale options (see When the T0ASYNC bit of the T0CON1 register is clear
prescaler control bits, T0CKPS<3:0> in the T0CON1 (T0ASYNC = 0), the counter clock is synchronized to
register). the system clock (FOSC/4). When operating in
In 8-bit mode, the value of TMR0L is compared to that Synchronous mode, the counter clock frequency
of the Period buffer, a copy of TMR0H, on each clock cannot exceed FOSC/4.
cycle. When the two values match, the following events
happen: 18.2 Clock Source Selection
TMR0_out goes high for one prescaled clock
The T0CS<2:0> bits of the T0CON1 register are used
period
to select the clock source for Timer0. Register 18-2
TMR0L is reset
displays the clock source selections.
The contents of TMR0H are copied to the period
buffer 18.2.1 INTERNAL CLOCK SOURCE
In 8-bit mode, the TMR0L and TMR0H registers are
When the internal clock source is selected, Timer0
both directly readable and writable. The TMR0L
operates as a timer and will increment on multiples of
register is cleared on any device Reset, while the
the clock source, as determined by the Timer0
TMR0H register initializes at FFh.
prescaler.

18.2.2 EXTERNAL CLOCK SOURCE


When an external clock source is selected, Timer0 can
operate as either a timer or a counter. Timer0 will
increment on multiples of the rising edge of the external
clock source, as determined by the Timer0 prescaler.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 221


PIC18(L)F26/45/46K40
18.3 Programmable Prescaler 18.7 Timer0 Output
A software programmable prescaler is available for The Timer0 output can be routed to any I/O pin via the
exclusive use with Timer0. There are 16 prescaler RxyPPS output selection register (see Section
options for Timer0 ranging in powers of two from 1:1 to 17.0 Peripheral Pin Select (PPS) Module for addi-
1:32768. The prescaler values are selected using the tional information). The Timer0 output can also be used
T0CKPS<3:0> bits of the T0CON1 register. by other peripherals, such as the auto-conversion trig-
The prescaler is not directly readable or writable. ger of the Analog-to-Digital Converter. Finally, the
Clearing the prescaler register can be done by writing Timer0 output can be monitored through software via
to the TMR0L register or the T0CON0, T0CON1 the Timer0 output bit (T0OUT) of the T0CON0 register
registers or by any Reset. (Register 18-1).
TMR0_out will be a pulse of one postscaled clock
18.4 Programmable Postscaler period when a match occurs between TMR0L and PR0
(Period register for TMR0) in 8-bit mode, or when
A software programmable postscaler (output divider) is TMR0 rolls over in 16-bit mode. The Timer0 output is a
available for exclusive use with Timer0. There are 16 50% duty cycle that toggles on each TMR0_out rising
postscaler options for Timer0 ranging from 1:1 to 1:16. clock edge.
The postscaler values are selected using the
T0OUTPS<3:0> bits of the T0CON0 register.
The postscaler is not directly readable or writable.
Clearing the postscaler register can be done by writing
to the TMR0L register or the T0CON0, T0CON1 regis-
ters or by any Reset.

18.5 Operation During Sleep


When operating synchronously, Timer0 will halt. When
operating asynchronously, Timer0 will continue to
increment and wake the device from Sleep (if Timer0
interrupts are enabled) provided that the input clock
source is active.

18.6 Timer0 Interrupts


The Timer0 interrupt flag bit (TMR0IF) is set when
either of the following conditions occur:
8-bit TMR0L matches the TMR0H value
16-bit TMR0 rolls over from FFFFh
When the postscaler bits (T0OUTPS<3:0>) are set to
1:1 operation (no division), the T0IF flag bit will be set
with every TMR0 match or rollover. In general, the
TMR0IF flag bit will be set every T0OUTPS +1 matches
or rollovers.
If Timer0 interrupts are enabled (TMR0IE bit of the
PIE0 register = 1), the CPU will be interrupted and the
device may wake from Sleep (see Section
18.2 Clock Source Selection for more details).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 222


PIC18(L)F26/45/46K40
18.8 Register Definitions: Timer0 Control

REGISTER 18-1: T0CON0: TIMER0 CONTROL REGISTER 0


R/W-0/0 U-0 R-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
T0EN T0OUT T016BIT T0OUTPS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 T0EN:TMR0 Enable bit


1 = The module is enabled and operating
0 = The module is disabled and in the lowest power mode
bit 6 Unimplemented: Read as 0
bit 5 T0OUT:TMR0 Output bit (read-only)
TMR0 output bit
bit 4 T016BIT: TMR0 Operating as 16-Bit Timer Select bit
1 = TMR0 is a 16-bit timer
0 = TMR0 is an 8-bit timer
bit 3-0 T0OUTPS<3:0>: TMR0 Output Postscaler (Divider) Select bits
1111 = 1:16 Postscaler
1110 = 1:15 Postscaler
1101 = 1:14 Postscaler
1100 = 1:13 Postscaler
1011 = 1:12 Postscaler
1010 = 1:11 Postscaler
1001 = 1:10 Postscaler
1000 = 1:9 Postscaler
0111 = 1:8 Postscaler
0110 = 1:7 Postscaler
0101 = 1:6 Postscaler
0100 = 1:5 Postscaler
0011 = 1:4 Postscaler
0010 = 1:3 Postscaler
0001 = 1:2 Postscaler
0000 = 1:1 Postscaler

2016 Microchip Technology Inc. Preliminary DS40001816C-page 223


PIC18(L)F26/45/46K40
REGISTER 18-2: T0CON1: TIMER0 CONTROL REGISTER 1
R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
T0CS<2:0> T0ASYNC T0CKPS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 T0CS<2:0>:Timer0 Clock Source Select bits


111 = Reserved
110 = Reserved
101 = SOSC
100 = LFINTOSC
011 = HFINTOSC
010 = FOSC/4
001 = Pin selected by T0CKIPPS (Inverted)
000 = Pin selected by T0CKIPPS (Non-inverted)
bit 4 T0ASYNC: TMR0 Input Asynchronization Enable bit
1 = The input to the TMR0 counter is not synchronized to system clocks
0 = The input to the TMR0 counter is synchronized to FOSC/4
bit 3-0 T0CKPS<3:0>: Prescaler Rate Select bit
1111 = 1:32768
1110 = 1:16384
1101 = 1:8192
1100 = 1:4096
1011 = 1:2048
1010 = 1:1024
1001 = 1:512
1000 = 1:256
0111 = 1:128
0110 = 1:64
0101 = 1:32
0100 = 1:16
0011 = 1:8
0010 = 1:4
0001 = 1:2
0000 = 1:1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 224


PIC18(L)F26/45/46K40

REGISTER 18-3: TMR0L: TIMER0 COUNT REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TMR0<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 TMR0<7:0>:TMR0 Counter bits <7:0>

REGISTER 18-4: TMR0H: TIMER0 PERIOD REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
TMR0<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 When T016BIT = 0


PR0<7:0>:TMR0 Period Register Bits <7:0>
When T016BIT = 1
TMR0<15:8>: TMR0 Counter bits <15:8>

TABLE 18-1: SUMMARY OF REGISTERS ASSOCIATED WITH TIMER0

Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page

TMR0L TMR0<7:0> 225


TMR0H TMR0<15:8> 225
T0CON0 T0EN T0OUT T016BIT T0OUTPS<3:0> 223
T0CON1 T0CS<2:0> T0ASYNC T0CKPS<3:0> 224
T0CKIPPS T0CKIPPS<4:0> 215
TMR0PPS TMR0PPS<4:0> 215
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIR0 TMR0IF IOCIF INT2IF INT1IF INT0IF 170
PIE0 TMR0IE IOCIE INT2IE INT1IE INT0IE 178
IPR0 TMR0IP IOCIP INT2IP INT1IP INT0IP 186
PMD1 TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD 68
Legend: = Unimplemented location, read as 0. Shaded cells are not used by the Timer0 module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 225


PIC18(L)F26/45/46K40
19.0 TIMER1/3/5 MODULE WITH
GATE CONTROL
Timer1/3/5 module is a 16-bit timer/counter with the
following features:
16-bit timer/counter register pair (TMRxH:TMRxL)
Programmable internal or external clock source
2-bit prescaler
Dedicated Secondary 32 kHz oscillator circuit
Optionally synchronized comparator out
Multiple Timer1/3/5 gate (count enable) sources
Interrupt on overflow
Wake-up on overflow (external clock, Asynchronous
mode only)
16-Bit Read/Write Operation
Time base for the Capture/Compare function with
the CCP modules
Special Event Trigger (with CCP)
Selectable Gate Source Polarity
Gate Toggle mode
Gate Single-pulse mode
Gate Value Status
Gate Event Interrupt
Figure 19-1 is a block diagram of the Timer1/3/5
module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 226


PIC18(L)F26/45/46K40
FIGURE 19-1: TIMER1/3/5 BLOCK DIAGRAM

TMRxGATE<3:0> Rev. 10-000018G


8/7/2015

4
TxGPPS
TxGSPM
PPS 0000

1
0 Single Pulse D Q TxGVAL
NOTE (5) 0
1111
1 Acq. Control
Q1
D Q

TxGPOL TxGGO/DONE
CK Q
TMRxON Interrupt
set bit
R
TxGTM det TMRxGIF

TMRxGE
set flag bit
TMRxIF
TMRxON
EN
(2) To Comparators (6)
TMRx
Tx_overflow Synchronized Clock Input
TMRxH TMRxL Q D 0
1
TxCLK
TxSYNC

TMRxCLK<3:0>
4
TxCKIPPS
(1)
PPS 0000

Prescaler
Synchronize(3)
1,2,4,8
Note (4) det
1111
2
Fosc/2
TxCKPS<1:0> Internal Sleep
Clock Input

Note 1: ST Buffer is high speed type when using TxCKIPPS.


2: TMRx register increments on rising edge.
3: Synchronize does not operate while in Sleep.
4: See Register 19-3 for clock source selections.
5: See Register 19-4 for gate source selection.
6: Synchronized comparator output should not be used in conjunction with synchronized input clock.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 227


PIC18(L)F26/45/46K40
19.1 Register Definitions: Timer1/3/5
Long bit name prefixes for the Timer1/3/5 are shown in
Table 20-1. Refer to Section 1.4.2.2 Long Bit
Names for more information.
TABLE 19-1:
Peripheral Bit Name Prefix
Timer1 T1
Timer3 T3
Timer5 T5

REGISTER 19-1: TxCON: TIMERx CONTROL REGISTER


U-0 U-0 R/W-0/u R/W-0/u U-0 R/W-0/u R/W-0/0 R/W-0/u
CKPS<1:0> SYNC RD16 ON
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared u = unchanged

bit 7-6 Unimplemented: Read as 0


bit 5-4 CKPS<1:0>: Timerx Input Clock Prescale Select bits
11 = 1:8 Prescale value
10 = 1:4 Prescale value
01 = 1:2 Prescale value
00 = 1:1 Prescale value
bit 3 Unimplemented: Read as 0
bit 2 SYNC: Timerx External Clock Input Synchronization Control bit
TMRxCLK = FOSC/4 or FOSC:
This bit is ignored. Timer1 uses the incoming clock as is.
Else:
1 = Do not synchronize external clock input
0 = Synchronize external clock input with system clock
bit 1 RD16: 16-Bit Read/Write Mode Enable bit
1 = All 16 bits of Timer1 can be read simultaneously (TMR1H is buffered)
0 = 16-bit reads of Timer1 are disabled (TMR1H not buffered)
bit 0 ON: Timerx On bit
1 = Enables Timerx
0 = Disables Timerx

2016 Microchip Technology Inc. Preliminary DS40001816C-page 228


PIC18(L)F26/45/46K40

REGISTER 19-2: TxGCON: TIMERx GATE CONTROL REGISTER


R/W-0/u R/W-0/u R/W-0/u R/W-0/u R/W-0/u R-x U-0 U-0
GE GPOL GTM GSPM GGO/DONE GVAL
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 GE: Timerx Gate Enable bit


If TMRxON = 1:
1 = Timerx counting is controlled by the Timerx gate function
0 = Timerx is always counting
If TMRxON = 0:
This bit is ignored
bit 6 GPOL: Timerx Gate Polarity bit
1 = Timerx gate is active-high (Timerx counts when gate is high)
0 = Timerx gate is active-low (Timerx counts when gate is low)
bit 5 GTM: Timerx Gate Toggle Mode bit
1 = Timerx Gate Toggle mode is enabled
0 = Timerx Gate Toggle mode is disabled and Toggle flip-flop is cleared
Timerx Gate Flip Flop Toggles on every rising edge
bit 4 GSPM: Timerx Gate Single Pulse Mode bit
1 = Timerx Gate Single Pulse mode is enabled and is controlling Timerx gate)
0 = Timerx Gate Single Pulse mode is disabled
bit 3 GGO/DONE: Timerx Gate Single Pulse Acquisition Status bit
1 = Timerx Gate Single Pulse Acquisition is ready, waiting for an edge
0 = Timerx Gate Single Pulse Acquisition has completed or has not been started.
This bit is automatically cleared when TxGSPM is cleared.
bit 2 GVAL: Timerx Gate Current State bit
Indicates the current state of the Timerx gate that could be provided to TMRxH:TMRxL
Unaffected by Timerx Gate Enable (TMRxGE)
bit 1-0 Unimplemented: Read as 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 229


PIC18(L)F26/45/46K40

REGISTER 19-3: TMRxCLK: TIMERx CLOCK REGISTER


U-0 U-0 U-0 U-0 R/W-0/u R/W-0/u R/W-0/u R/W-0/u
CS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared u = unchanged

bit 7-4 Unimplemented: Read as 0


bit 3-0 CS<3:0>: Timerx Clock Source Selection bits

Timer1 Timer3 Timer5


CS
Clock Source Clock Source Clock Source
1111-1100 Reserved Reserved Reserved
1011 TMR5 overflow TMR5 overflow Reserved
1010 TMR3 overflow Reserved TMR3 overflow
1001 Reserved TMR1 overflow TMR1 overflow
1000 TMR0 overflow TMR0 overflow TMR0 overflow
0111 CLKREF CLKREF CLKREF
0110 SOSC SOSC SOSC
0101 MFINTOSC (500 kHz) MFINTOSC (500 kHz) MFINTOSC (500 kHz)
0100 LFINTOSC LFINTOSC LFINTOSC
0011 HFINTOSC HFINTOSC HFINTOSC
0010 Fosc Fosc Fosc
0001 Fosc/4 Fosc/4 Fosc/4
0000 T1CKIPPS T3CKIPPS T5CKIPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 230


PIC18(L)F26/45/46K40

REGISTER 19-4: TMRxGATE: TIMERx GATE ISM REGISTER


U-0 U-0 U-0 U-0 R/W-0/u R/W-0/u R/W-0/u R/W-0/u
GSS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared u = unchanged

bit 7-4 Unimplemented: Read as 0


bit 3-0 GSS<3:0>: Timerx Gate Source Selection bits

Timer1 Timer3 Timer5


GSS
Gate Source Gate Source Gate Source
1111 Reserved Reserved Reserved
1110 ZCDOUT ZCDOUT ZCDOUT
1101 CMP2OUT CMP2OUT CMP2OUT
1100 CMP1OUT CMP1OUT CMP1OUT
1011 PWM4OUT PWM4OUT PWM4OUT
1010 PWM3OUT PWM3OUT PWM3OUT
1001 CCP2OUT CCP2OUT CCP2OUT
1000 CCP1OUT CCP1OUT CCP1OUT
0111 TMR6OUT (post-scaled) TMR6OUT (post-scaled) TMR6OUT (post-scaled)
0110 TMR5 overflow TMR5 overflow Reserved
0101 TMR4OUT (post-scaled) TMR4OUT (post-scaled) TMR4OUT (post-scaled)
0100 TMR3 overflow Reserved TMR3 overflow
0011 TMR2OUT (post-scaled) TMR2OUT (post-scaled) TMR2OUT (post-scaled)
0010 Reserved TMR1 overflow TMR1 overflow
0001 TMR0 overflow TMR0 overflow TMR0 overflow
0000 Pin selected by T1GPPS Pin selected by T3GPPS Pin selected by T5GPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 231


PIC18(L)F26/45/46K40

REGISTER 19-5: TMRxL: TIMERx LOW BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
TMRxL<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 TMRxL<7:0>:Timerx Low Byte bits

REGISTER 19-6: TMRxH: TIMERx HIGH BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
TMRxH<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 TMRxH<7:0>:Timerx High Byte bits

2016 Microchip Technology Inc. Preliminary DS40001816C-page 232


PIC18(L)F26/45/46K40
19.2 Timer1/3/5 Operation The following asynchronous sources may be used at
the Timer1/3/5 gate:
The Timer1/3/5 module is a 16-bit incrementing
counter which is accessed through the TMRxH:TMRxL Asynchronous event on the TxGPPS pin
register pair. Writes to TMRxH or TMRxL directly TMR0OUT
update the counter. TMR1/3/5OUT (excluding the TMR for which it is
When used with an internal clock source, the module is being used)
a timer and increments on every instruction cycle. TMR 2/4/6OUT (post-scaled)
When used with an external clock source, the module CCP1/2OUT
can be used as either a timer or counter and incre- PWM3/4OUT
ments on every selected edge of the external source. CMP1/2OUT
Timer1/3/5 is enabled by configuring the ON and GE ZCDOUT
bits in the TxCON and TxGCON registers, respectively.
Table 19-2 displays the Timer1/3/5 enable selections. Note: In Counter mode, a falling edge must be
registered by the counter prior to the first
incrementing rising edge after any one or
TABLE 19-2: TIMER1/3/5 ENABLE
more of the following conditions:
SELECTIONS
Timer1/3/5 enabled after POR
Timer1/3/5
ON GE Write to TMRxH or TMRxL
Operation
Timer1/3/5 is disabled
1 1 Count Enabled
Timer1/3/5 is disabled (TMRxON = 0)
1 0 Always On when TxCKI is high then Timer1/3/5
0 1 Off is enabled (TMRxON = 1) when
0 0 Off TxCKI is low.

19.3.2 EXTERNAL CLOCK SOURCE


19.3 Clock Source Selection
When the external clock source is selected, the
The CS<3:0> bits of the TMRxCLK register Timer1/3/5 module may work as a timer or a counter.
(Register 19-3) are used to select the clock source for
When enabled to count, Timer1/3/5 is incremented on
Timer1/3/5. The four TMRxCLK bits allow the selection
the rising edge of the external clock input of the
of several possible synchronous and asynchronous
TxCKIPPS pin. This external clock source can be
clock sources. Register 19-3 displays the clock source
synchronized to the microcontroller system clock or it
selections.
can run asynchronously.
19.3.1 INTERNAL CLOCK SOURCE When used as a timer with a clock oscillator, an
When the internal clock source is selected the external 32.768 kHz crystal can be used in conjunction
TMRxH:TMRxL register pair will increment on multiples with the dedicated secondary internal oscillator circuit.
of FOSC as determined by the Timer1/3/5 prescaler.
When the FOSC internal clock source is selected, the
Timer1/3/5 register value will increment by four counts
every instruction clock cycle. Due to this condition, a
2 LSB error in resolution will occur when reading the
Timer1/3/5 value. To utilize the full resolution of Tim-
er1/3/5, an asynchronous input signal must be used to
gate the Timer1/3/5 clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 233


PIC18(L)F26/45/46K40
19.4 Timer1/3/5 Prescaler 19.6 Timer1/3/5 Operation in
Timer1/3/5 has four prescaler options allowing 1, 2, 4 or
Asynchronous Counter Mode
8 divisions of the clock input. The CKPS bits of the If control bit SYNC of the TxCON register is set, the
TxCON register control the prescale counter. The external clock input is not synchronized. The timer
prescale counter is not directly readable or writable; increments asynchronously to the internal phase
however, the prescaler counter is cleared upon a write to clocks. If external clock source is selected then the
TMRxH or TMRxL. timer will continue to run during Sleep and can
generate an interrupt on overflow, which will wake-up
19.5 Secondary Oscillator the processor. However, special precautions in
software are needed to read/write the timer (see
A secondary low-power 32.768 kHz oscillator circuit is Section 19.6.1 Reading and Writing Timer1/3/5 in
built-in between pins SOSCI (input) and SOSCO Asynchronous Counter Mode).
(amplifier output). This internal circuit is to be used in
conjunction with an external 32.768 kHz crystal. The Note: When switching from synchronous to
secondary oscillator is not dedicated only to asynchronous operation, it is possible to
Timer1/3/5; it can also be used by other modules. skip an increment. When switching from
asynchronous to synchronous operation,
The oscillator circuit is enabled by setting the SOSCEN
it is possible to produce an additional
bit of the OSCEN register (Register 4-7). This can be
increment.
used as the clock source to the Timer using the
TMRxCLK bits.The oscillator will continue to run during
Sleep. 19.6.1 READING AND WRITING
TIMER1/3/5 IN ASYNCHRONOUS
Note: The oscillator requires a start-up and COUNTER MODE
stabilization time before use. Thus, the
SOSCEN bit of the OSCEN register Reading TMRxH or TMRxL while the timer is running
should be set and a suitable delay from an external asynchronous clock will ensure a valid
observed prior to enabling Timer1/3/5. A read (taken care of in hardware). However, the user
software check can be performed to should keep in mind that reading the 16-bit timer in two
confirm if the secondary oscillator is 8-bit values itself, poses certain problems, since the
enabled and ready to use. This is done by timer may overflow between the reads. For writes, it is
polling the SOR bit of the OSCSTAT recommended that the user simply stop the timer and
(Register 4-4). write the desired values. A write contention may occur
by writing to the timer registers, while the register is
incrementing. This may produce an unpredictable
value in the TMRxH:TMRxL register pair.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 234


PIC18(L)F26/45/46K40
19.7 Timer1/3/5 16-Bit Read/Write Mode FIGURE 19-2: TIMER1/3/5 16-BIT
READ/WRITE MODE
Timer1/3/5 can be configured to read and write all 16
BLOCK DIAGRAM
bits of data, to and from, the 8-bit TMRxL and TMRxH
registers, simultaneously. The 16-bit read and write From
Timer1
operations are enabled by setting the RD16 bit of the Circuitry
TxCON register. TMR1 Set
TMR1L High Byte TMR1IF
To accomplish this function, the TMRxH register value on Overflow
8
is mapped to a buffer register called the TMRxH buffer
register. While in 16-Bit mode, the TMRxH register is
Read TMR1L
not directly readable or writable and all read and write
operations take place through the use of this TMRxH Write TMR1L
8
buffer register. 8
When a read from the TMRxL register is requested, the TMR1H
value of the TMRxH register is simultaneously loaded
into the TMRxH buffer register. When a read from the 8
TMRxH register is requested, the value is provided 8
Internal Data Bus
from the TMRxH buffer register instead. This provides
the user with the ability to accurately read all 16 bits of Block Diagram of Timer1 Example of TIMER1/3/5
the Timer1/3/5 value from a single instance in time.
Reference the block diagram in Figure 19-2 for more
details. 19.8 Timer1/3/5 Gate
In contrast, when not in 16-Bit mode, the user must Timer1/3/5 can be configured to count freely or the
read each register separately and determine if the count can be enabled and disabled using Timer1/3/5
values have become invalid due to a rollover that may gate circuitry. This is also referred to as Timer1/3/5 gate
have occurred between the read operations. enable.
When a write request of the TMRxL register is Timer1/3/5 gate can also be driven by multiple
requested, the TMRxH buffer register is simultaneously selectable sources.
updated with the contents of the TMRxH register. The
value of TMRxH must be preloaded into the TMRxH 19.8.1 TIMER1/3/5 GATE ENABLE
buffer register prior to the write request for the TMRxL
register. This provides the user with the ability to write The Timer1/3/5 Gate Enable mode is enabled by
all 16 bits to the TMRxL:TMRxH register pair at the setting the TMRxGE bit of the TxGCON register. The
same time. polarity of the Timer1/3/5 Gate Enable mode is
configured using the TxGPOL bit of the TxGCON
Any requests to write to the TMRxH directly does not register.
clear the Timer1/3/5 prescaler value. The prescaler
value is only cleared through write requests to the When Timer1/3/5 Gate Enable mode is enabled,
TMRxL register. Timer1/3/5 will increment on the rising edge of the
Timer1/3/5 clock source. When Timer1/3/5 Gate signal
is inactive, the timer will not increment and hold the
current count. Enable mode is disabled, no
incrementing will occur and Timer1/3/5 will hold the
current count. See Figure 19-4 for timing details.

TABLE 19-3: TIMER1/3/5 GATE ENABLE


SELECTIONS
Timer1/3/5
TMRxCLK TxGPOL TxG
Operation
1 1 Counts
1 0 Holds Count
0 1 Holds Count
0 0 Counts

2016 Microchip Technology Inc. Preliminary DS40001816C-page 235


PIC18(L)F26/45/46K40
19.8.2 TIMER1/3/5 GATE SOURCE 19.8.4 TIMER1/3/5 GATE SINGLE-PULSE
SELECTION MODE
The gate source for Timer1/3/5 can be selected using When Timer1/3/5 Gate Single-Pulse mode is enabled,
the GSS<3:0> bits of the TMRxGATE register it is possible to capture a single-pulse gate event.
(Register 19-4). The polarity selection for the gate Timer1/3/5 Gate Single-Pulse mode is first enabled by
source is controlled by the TxGPOL bit of the TxGCON setting the GSPM bit in the TxGCON register. Next, the
register (Register 19-2). GGO/DONE bit in the TxGCON register must be set.
Any of the above mentioned signals can be used to The Timer1/3/5 will be fully enabled on the next
trigger the gate. The output of the CMPx can be incrementing edge. On the next trailing edge of the
synchronized to the Timer1/3/5 clock or left pulse, the GGO/DONE bit will automatically be cleared.
asynchronous. For more information see Section No other gate events will be allowed to increment
32.5.1 Comparator Output Synchronization. Timer1/3/5 until the GGO/DONE bit is once again set in
software.
19.8.3 TIMER1/3/5 GATE TOGGLE MODE Clearing the TxGSPM bit of the TxGCON register will
When Timer1/3/5 Gate Toggle mode is enabled, it is also clear the GGO/DONE bit. See Figure 19-6 for tim-
possible to measure the full-cycle length of a ing details.
Timer1/3/5 gate signal, as opposed to the duration of a Enabling the Toggle mode and the Single-Pulse mode
single level pulse. simultaneously will permit both sections to work
The Timer1/3/5 gate source is routed through a flip-flop together. This allows the cycle times on the Timer1/3/5
that changes state on every incrementing edge of the gate source to be measured. See Figure 19-7 for timing
signal. See Figure 19-5 for timing details. details.

Timer1/3/5 Gate Toggle mode is enabled by setting the 19.8.5 TIMER1/3/5 GATE VALUE STATUS
GTM bit of the TxGCON register. When the GTM bit is
cleared, the flip-flop is cleared and held clear. This is When Timer1/3/5 Gate Value Status is utilized, it is
necessary in order to control which edge is measured. possible to read the most current level of the gate
control value. The value is stored in the GVAL bit in the
Note: Enabling Toggle mode at the same time TxGCON register. The GVAL bit is valid even when the
as changing the gate polarity may result in Timer1/3/5 gate is not enabled (GE bit is cleared).
indeterminate operation.
19.8.6 TIMER1/3/5 GATE EVENT
INTERRUPT
When Timer1/3/5 Gate Event Interrupt is enabled, it is
possible to generate an interrupt upon the completion
of a gate event. When the falling edge of GVAL occurs,
the TMRxGIF flag bit in the PIR5 register will be set. If
the TMRxGIE bit in the PIE5 register is set, then an
interrupt will be recognized.
The TMRxGIF flag bit operates even when the
Timer1/3/5 gate is not enabled (GE bit is cleared).
For more information on selecting high or low priority
status for the Timer1/3/5 Gate Event Interrupt see Sec-
tion 14.0 Interrupts.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 236


PIC18(L)F26/45/46K40
19.9 Timer1/3/5 Interrupt 19.11 CCP Capture/Compare Time Base
The Timer1/3/5 register pair (TMRxH:TMRxL) The CCP modules use the TMRxH:TMRxL register pair
increments to FFFFh and rolls over to 0000h. When as the time base when operating in Capture or
Timer1/3/5 rolls over, the Timer1/3/5 interrupt flag bit of Compare mode.
the PIR4 register is set. To enable the In Capture mode, the value in the TMRxH:TMRxL
interrupt-on-rollover, you must set these bits: register pair is copied into the CCPRxH:CCPRxL
TMRxON bit of the TxCON register register pair on a configured event.
TMRxIE bits of the PIE4 register In Compare mode, an event is triggered when the value
PEIE/GIEL bit of the INTCON register in the CCPRxH:CCPRxL register pair matches the
GIE/GIEH bit of the INTCON register value in the TMRxH:TMRxL register pair. This event
can be a Special Event Trigger.
The interrupt is cleared by clearing the TMRxIF bit in
the Interrupt Service Routine. For more information, see Section
21.0 Capture/Compare/PWM Module.
For more information on selecting high or low priority
status for the Timer1/3/5 Overflow Interrupt, see
Section 14.0 Interrupts. 19.12 CCP Special Event Trigger
Note: The TMRxH:TMRxL register pair and the When any of the CCPs are configured to trigger a
TMRxIF bit should be cleared before special event, the trigger will clear the TMRxH:TMRxL
enabling interrupts. register pair. This special event does not cause a
Timer1/3/5 interrupt. The CCP module may still be
configured to generate a CCP interrupt.
19.10 Timer1/3/5 Operation During Sleep
In this mode of operation, the CCPRxH:CCPRxL
Timer1/3/5 can only operate during Sleep when set up register pair becomes the period register for
in Asynchronous Counter mode. In this mode, an Timer1/3/5.
external crystal or clock source can be used to
Timer1/3/5 should be synchronized and FOSC/4 should
increment the counter. To set up the timer to wake the
be selected as the clock source in order to utilize the
device:
Special Event Trigger. Asynchronous operation of
TMRxON bit of the TxCON register must be set Timer1/3/5 can cause a Special Event Trigger to be
TMRxIE bit of the PIE4 register must be set missed.
PEIE/GIEL bit of the INTCON register must be set In the event that a write to TMRxH or TMRxL coincides
TxSYNC bit of the TxCON register must be set with a Special Event Trigger from the CCP, the write will
Configure the TMRxCLK register for using take precedence.
secondary oscillator as the clock source
Enable the SOSCEN bit of the OSCEN register
(Register 4-7)
The device will wake-up on an overflow and execute
the next instruction. If the GIE/GIEH bit of the INTCON
register is set, the device will call the Interrupt Service
Routine.
The secondary oscillator will continue to operate in
Sleep regardless of the TxSYNC bit setting.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 237


PIC18(L)F26/45/46K40
FIGURE 19-3: TIMER1/3/5 INCREMENTING EDGE

TxCKI = 1
when TMRx
Enabled

TxCKI = 0
when TMRx
Enabled

Note 1: Arrows indicate counter increments.


2: In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge of the clock.

FIGURE 19-4: TIMER1/3/5 GATE ENABLE MODE

TMRxGE

TxGPOL

TxG_IN

TxCKI

TxGVAL

Timer1/3/5 N N+1 N+2 N+3 N+4

2016 Microchip Technology Inc. Preliminary DS40001816C-page 238


PIC18(L)F26/45/46K40
FIGURE 19-5: TIMER1/3/5 GATE TOGGLE MODE

TMRxGE

TxGPOL

TxGTM

TxTxG_IN

TxCKI

TxGVAL

TIMER1/3/5 N N+1 N+2 N+3 N+4 N+5 N+6 N+7 N+8

FIGURE 19-6: TIMER1/3/5 GATE SINGLE-PULSE MODE

TMRxGE

TxGPOL

TxGSPM
Cleared by hardware on
TxGGO/ Set by software falling edge of TxGVAL
DONE
Counting enabled on
rising edge of TxG
TxG_IN

TxCKI

TxGVAL

TIMER1/3/5 N N+1 N+2

Cleared by
TMRxGIF Cleared by software Set by hardware on software
falling edge of TxGVAL

2016 Microchip Technology Inc. Preliminary DS40001816C-page 239


PIC18(L)F26/45/46K40
FIGURE 19-7: TIMER1/3/5 GATE SINGLE-PULSE AND TOGGLE COMBINED MODE

TMRxGE

TxGPOL

TxGSPM

TxGTM

Cleared by hardware on
TxGGO/ Set by software falling edge of TxGVAL
DONE Counting enabled on
rising edge of TxG
TxG_IN

TxCKI

TxGVAL

TIMER1/3/5 N N+1 N+2 N+3 N+4

Set by hardware on Cleared by


TMRxGIF Cleared by software falling edge of TxGVAL software

19.13 Peripheral Module Disable


When a peripheral module is not used or inactive, the
module can be disabled by setting the Module Disable
bit in the PMD registers. This will reduce power
consumption to an absolute minimum. Setting the PMD
bits holds the module in Reset and disconnects the
modules clock source. The Module Disable bits for
Timer1 (TMR1MD), Timer3 (TMR3MD) and Timer5
(TMR5MD) are in the PMD1 register. See Section
7.0 Peripheral Module Disable (PMD) for more
information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 240


PIC18(L)F26/45/46K40
TABLE 19-4: SUMMARY OF REGISTERS ASSOCIATED WITH TIMER1/3/5 AS A TIMER/COUNTER
Reset
Values
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on
Page

INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169


PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE 182
PIE5 TMR5GIE TMR3GIE TMR1GIE 183
PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF 173
PIR5 TMR5GIF TMR3GIF TMR1GIF 174
IPR4 TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP 190
IPR5 TMR5GIP TMR3GIP TMR1GIP 191
PMD1 TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD 68
T1CON CKPS<1:0> SYNC RD16 ON 228
T1GCON GE GPOL GTM GSPM GO/DONE GVAL 229
T3CON CKPS<1:0> SYNC RD16 ON 228
T3GCON GE GPOL GTM GSPM GO/DONE GVAL 229
T5CON CKPS<1:0> SYNC RD16 ON 228
T5GCON GE GPOL GTM GSPM GO/DONE GVAL 229
TMR1H Holding Register for the Most Significant Byte of the 16-bit TMR1 Register 232
TMR1L Least Significant Byte of the 16-bit TMR1 Register 232
TMR3H Holding Register for the Most Significant Byte of the 16-bit TMR3 Register 232
TMR3L Least Significant Byte of the 16-bit TMR3 Register 232
TMR5H Holding Register for the Most Significant Byte of the 16-bit TMR5 Register 232
TMR5L Least Significant Byte of the 16-bit TMR5 Register 232
T1CKIPPS T1CKIPPS<4:0> 215
T1GPPS T1GPPS<4:0> 215
T3CKIPPS T3CKIPPS<4:0> 215
T3GPPS T3GPPS<4:0> 215
T5CKIPPS T5CKIPPS<4:0> 215
T5GPPS T5GPPS<4:0> 215
Legend: = Unimplemented location, read as 0. Shaded cells are not used by TIMER1/3/5.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 241


PIC18(L)F26/45/46K40
20.0 TIMER2/4/6 MODULE
The Timer2/4/6 modules are 8-bit timers that
incorporate the following features:
8-bit Timer and Period registers (TMR2 and PR2,
respectively)
Readable and writable (both registers)
Software programmable prescaler (1:1 to 1:128)
Software programmable postscaler (1:1 to 1:16)
Interrupt on TMR2 match with PR2
One-shot operation
Full asynchronous operation
Includes Hardware Limit Timer (HLT)
Alternate clock sources
External Timer Reset signal sources
Configurable Timer Reset operation
See Figure 20-1 for Timer2 clock sources. See
Figure 20-2 for a block diagram of Timer2 with HLT.
Note: Three identical Timer2 modules are
implemented on this device. The timers are
named Timer2, Timer4 and Timer6. All
references to Timer2 apply as well to
Timer4 and Timer6. All references to PR2
apply as well to PR4 and PR6.

FIGURE 20-1: TIMER2 CLOCK SOURCE


BLOCK DIAGRAM
Rev. 10-000169D
8/7/2015

TxCLK <3:0>
TXINPPS
TXIN PPS 0000

See TMRx_clk
TxCLKCON
Register

1111

2016 Microchip Technology Inc. Preliminary DS40001816C-page 242


PIC18(L)F26/45/46K40
FIGURE 20-2: TIMER2 WITH HARDWARE LIMIT TIMER (HLT) BLOCK DIAGRAM
TxRSEL <3:0> Rev. 10-000168C
9/10/2015

TxINPPS
TxIN PPS TxMODE<4:0> MODE<3>

Edge Detector reset


External
TMRx_ers Level Detector CCP_pset(1)
Reset Mode Control
(2)
Sources (2 clock Sync)

enable MODE<4:3>=01
Clear ON
MODE<4:1>=1011 D Q

TxCPOL
TMRx_clk Prescaler 0
R
TMRx
Set flag bit
3 Sync 1 TMRxIF

TxCKPS<2:0> Fosc/4 TxPSYNC TMRx_postscaled


Comparator Postscaler

4
TxON Sync
(2 Clocks)
1
PRx TxOUTPS<3:0>
0

TxCSYNC

Note 1: Signal to the CCP to trigger the PWM pulse.


2: See TxRST Register 20-6 for external Reset sources.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 243


PIC18(L)F26/45/46K40
20.1 Register Definitions: Timer2/4/6
Control
Long bit name prefixes for the Timer2/4/6 peripherals
are shown in Table 20-1. Refer to Section
1.4.2.2 Long Bit Names for more information.
TABLE 20-1:
Peripheral Bit Name Prefix
Timer2 T2
Timer4 T4
Timer6 T6

REGISTER 20-1: TMRx: TIMERx COUNTER REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TxTMR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 TxTMR<7:0>: Timerx Counter bits

REGISTER 20-2: TxPR: TIMERx PERIOD REGISTER


R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1 R/W-1/1
TxPR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 TxPR<7:0>: Timerx Period Register bits

2016 Microchip Technology Inc. Preliminary DS40001816C-page 244


PIC18(L)F26/45/46K40

REGISTER 20-3: TxCON: TIMERx CONTROL REGISTER


R/W/HC-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
TxON CKPS<2:0> OUTPS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 ON: Timerx On bit(1)


1 = Timerx is on
0 = Timerx is off: all counters and state machines are reset
bit 6-4 CKPS<2:0>: Timerx-type Clock Prescale Select bits
111 = 1:128 Prescaler
110 = 1:64 Prescaler
101 = 1:32 Prescaler
100 = 1:16 Prescaler
011 = 1:8 Prescaler
010 = 1:4 Prescaler
001 = 1:2 Prescaler
000 = 1:1 Prescaler
bit 3-0 OUTPS<3:0>: Timerx Output Postscaler Select bits
1111 = 1:16 Postscaler
1110 = 1:15 Postscaler
1101 = 1:14 Postscaler
1100 = 1:13 Postscaler
1011 = 1:12 Postscaler
1010 = 1:11 Postscaler
1001 = 1:10 Postscaler
1000 = 1:9 Postscaler
0111 = 1:8 Postscaler
0110 = 1:7 Postscaler
0101 = 1:6 Postscaler
0100 = 1:5 Postscaler
0011 = 1:4 Postscaler
0010 = 1:3 Postscaler
0001 = 1:2 Postscaler
0000 = 1:1 Postscaler

Note 1: In certain modes, the TxON bit will be auto-cleared by hardware. See Section 20.5.1 One-Shot Mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 245


PIC18(L)F26/45/46K40

REGISTER 20-4: TxHLT: TIMERx HARDWARE LIMIT CONTROL REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
PSYNC CPOL CSYNC MODE<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 PSYNC: Timerx Prescaler Synchronization Enable bit(1, 2)


1 = TMRx Prescaler Output is synchronized to Fosc/4
0 = TMRx Prescaler Output is not synchronized to Fosc/4
bit 6 CPOL: Timerx Clock Polarity Selection bit(3)
1 = Falling edge of input clock clocks timer/prescaler
0 = Rising edge of input clock clocks timer/prescaler
bit 5 CSYNC: Timerx Clock Synchronization Enable bit(4, 5)
1 = ON register bit is synchronized to TMR2_clk input
0 = ON register bit is not synchronized to TMR2_clk input
bit 4-0 MODE<4:0>: Timerx Control Mode Selection bits(6, 7)
See Table 20-2 for all operating modes.

Note 1: Setting this bit ensures that reading TMRx will return a valid data value.
2: When this bit is 1, Timer2 cannot operate in Sleep mode.
3: CKPOL should not be changed while ON = 1.
4: Setting this bit ensures glitch-free operation when the ON is enabled or disabled.
5: When this bit is set then the timer operation will be delayed by two TMRx input clocks after the ON bit is set.
6: Unless otherwise indicated, all modes start upon ON = 1 and stop upon ON = 0 (stops occur without
affecting the value of TMRx).
7: When TMRx = PRx, the next clock clears TMRx, regardless of the operating mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 246


PIC18(L)F26/45/46K40

TABLE 20-2: TxMODE CONFIGURATION OPTIONS(2,6)


MODE<4:0> Timer Control
Output Operation Operation
<4:3> <2:0> <4:0> Start Reset(1) Stop
11 xxx 24-31 Reserved
10 000 16 Reserved
001 17 Monostable Input rising edge start timer TMRx_ers RE TxON = 0 or
edge-triggered and TxON = 1 Next clock after
010 18 start(3) Input falling edge start timer TMRx_ers FE TMRx = PR2(5)
and TxON = 1
011 19 Input either edge start timer TMRx_ers edge
and TxON = 1
100 20 Reserved
101 21 Reserved
110 22 One-shot level Input high start timer, Input TMRx_ers = 1 TMRx_ers = 0 TxON = 0 or held
triggered start with active-low Reset timer and TxON = 1 in Reset(4)
111 23 HLT action Input low start timer, Input TMRx_ers = 0 TMRx_ers = 1
active-high Reset timer and TxON = 1
01 000 08 One-shot SW start SW start (no HW control) TxON = 1 TxON = 0 or
001 09 One-shot Input rising edge start timer TMRx_ers RE Next clock after
edge-triggered and TxON = 1 TMRx = PR2(4)

010 10 start(3) Input falling edge start timer TMRx_ers FE


and TxON = 1
011 11 Input either edge start timer TMRx_ers edge
and TxON = 1
100 12 One-shot Input rising edge start timer; TMRx_ers RE TMRx_ers RE
edge-triggered Input rising edge Reset timer and TxON = 1
101 13 start with HLT Input falling edge start timer, TMRx_ers FE TMRx_ers FE
action(3) Input falling edge Reset timer and TxON = 1
110 14 Input rising edge start timer, TMRx_ers RE TMRx_ers = 0
Input active-low Reset timer and TxON = 1
111 15 Input falling edge start timer, TMRx_ers FE TMRx_ers = 1
Input active-high Reset timer and TxON = 1
00 000 00 Roll-over pulse SW gate (no HW control) TxON = 1 TxON = 0
001 01 HW gate, active-high TMRx_ers = 1 TxON = 0 or
and TxON = 1 TMRx_ers = 0
010 02 HW gate, active-low TMRx_ers = 0 TxON = 0 or
and TxON = 1 TMRx_ers = 1
011 03 Roll-over pulse Input either edge Reset timer TxON = 1 TMRx_ers edge TxON = 0
100 04 with HLT action Input rising edge Reset timer TMRx_ers RE
101 05 Input falling edge Reset timer TMRx_ers FE
110 06 Input active-low Reset timer TMRx_ers = 0 TxON = 0 or
111 07 Input active-high Reset timer TMRx_ers = 1 held in Reset

Note 1: When TMRx = PRx, the next clock clears TMRx, regardless of the operating mode.
2: In all operating modes, TxON = 0 stops the counter without affecting the value of TMRx
3: In edge-triggered one-shot and monostable modes (not SW Start mode), the triggered-start mechanism is reset and
rearmed (prepared for next start) if TxON becomes 0 (zero); the counter will not restart until an input edge occurs.
4: When TMRx = PRx, the next clock clears TxON.
5: When TMRx = PRx, TxON is not cleared.
6: Both TxON and TMRx_ers are subject to clock sync delays.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 247


PIC18(L)F26/45/46K40

REGISTER 20-5: TxCLKCON: TIMERx CLOCK SELECTION REGISTER


U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
CS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-4 Unimplemented: Read as 0


bit 3-0 CS<3:0>: Timerx Clock Selection bits

TMR2 TMR4 TMR6


CS<3:0>
Clock Source Clock Source Clock Source
1111-1001 Reserved Reserved Reserved
1000 ZCD_OUT ZCD_OUT ZCD_OUT
0111 CLKREF_OUT CLKREF_OUT CLKREF_OUT
0110 SOSC SOSC SOSC
0101 MFINTOSC (31 kHz) MFINTOSC (31 kHz) MFINTOSC (31 kHz)
0100 LFINTOSC LFINTOSC LFINTOSC
0011 HFINTOSC HFINTOSC HFINTOSC
0010 Fosc Fosc Fosc
0001 Fosc/4 Fosc/4 Fosc/4
0000 Pin selected by T2INPPS Pin selected by T4INPPS Pin selected by T6INPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 248


PIC18(L)F26/45/46K40

REGISTER 20-6: TxRST: TIMER2 EXTERNAL RESET SIGNAL SELECTION REGISTER


U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
RSEL<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-4 Unimplemented: Read as 0


bit 3-0 RSEL<3:0>: Timer2 External Reset Signal Source Selection bits

TMR2 TMR4 TMR6


RSEL<3:0>
Reset Source Reset Source Reset Source
1011-1111 Reserved Reserved Reserved
1010 ZCD_OUT ZCD_OUT ZCD_OUT
1001 CMP2OUT CMP2OUT CMP2OUT
1000 CMP1OUT CMP1OUT CMP1OUT
0111 PWM4OUT PWM4OUT PWM4OUT
0110 PWM3OUT PWM3OUT PWM3OUT
0101 CCP2OUT CCP2OUT CCP2OUT
0100 CCP1OUT CCP1OUT CCP1OUT
0011 TMR6 post-scaled TMR6 post-scaled Reserved
0010 TMR4 post-scaled Reserved TMR4 post-scaled
0001 Reserved TMR2 post-scaled TMR2 post-scaled
0000 Pin selected by T2INPPS Pin selected by T4INPPS Pin selected by T6INPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 249


PIC18(L)F26/45/46K40
20.2 Timer2 Operation 20.3 Timer2 Interrupt
The 3-bit prescaler on the clock input allows for several Timer2 can also generate a device interrupt. The
prescaler options, from direct input to divide-by-128. interrupt is generated when the postscaler counter
These options are selected by the prescaler control bits matches one of 16 postscale options (from 1:1 through
CKPS<2:0> of the T2CON register. 1:16), which is selected with the postscaler control bits,
The value of TMR2 is compared to that of the Period OUTPS<3:0> of the T2CON register. The interrupt is
register, PR2, on each clock cycle. When the two values enabled by setting the TMR2 Interrupt Enable bit,
match, the comparator resets the value of TMR2 to 00h TMR2IE, of the PIE4 register. The interrupt timing is
on the next cycle and drives the 4-bit output illustrated in Figure 20-3.
counter/postscaler (see Section 20.3 Timer2
Interrupt). In addition, the Timer can be Reset through
the use of an external Reset signal as outlined in
Section 20.5 External Reset Sources.
The TMR2 and PR2 registers are both directly readable
and writable. The TMR2 register is cleared on any
device Reset, whereas the PR2 register initializes to
FFh. Both the prescaler and postscaler counters are
cleared on the following events:
a write to the TMR2 register
a write to the T2CON register
Power-on Reset (POR)
Brown-out Reset (BOR)
MCLR Reset
Windowed Watchdog Timer (WWDT) Reset
Stack Overflow Reset
Stack Underflow Reset
RESET Instruction
External Reset Source events, which resets the
timer.
Note: TMR2 is not cleared when T2CON is
written.

FIGURE 20-3: TIMER2 PRESCALER, POSTSCALER, AND INTERRUPT TIMING DIAGRAM


Rev. 10-000205A
4/7/2016

CKPS 0b010

PRx 1

OUTPS 0b0001

TMRx_clk

TMRx 0 1 0 1 0 1 0

TMRx_postscaled

(1) (2) (1)


TMRxIF

Note 1: Setting the interrupt flag is synchronized with the instruction clock.
Synchronization may take as many as 2 instruction cycles
2: Cleared by software.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 250


PIC18(L)F26/45/46K40
20.4 Timer2 Output 20.6 Operation Examples
The Timer2 modules primary output is TMR2_posts- Unless otherwise specified, the following notes apply to
caled, which pulses for a single TMR2_clk period upon the following timing diagrams:
each match of the postscaler counter and the - Both the prescaler and postscaler are set to
OUTPS<3:0> bits of the T2CON register. The PR2 1:1 (both the CKPS and OUTPS bits in the
postscaler is incremented each time the TMR2 value TxCON register are cleared).
matches the PR2 value. This signal can be selected as
- The diagrams illustrate any clock except
an input to several other input modules:
FOSC/4 and show clock-sync delays of at
The CRC memory scanner, as a trigger for least two full cycles for both ON and
triggered mode Timer2_ers. When using FOSC/4, the
The ADC module, as an auto-conversion trigger clock-sync delay is at least one instruction
Gate source for Timer1/3/5 period for Timer2_ers; ON applies in the next
CWG, as an auto-shutdown source instruction period.
Alternate SPI clock - ON and Timer2_ers are somewhat general-
ized, and clock-sync delays may produce
Reset signals for other instances of itself
results that are slightly different than illus-
(Timer2/4/6)
trated.
In addition, the Timer2 is also used by the CCP module - The PWM Duty Cycle and PWM output are
for pulse generation in PWM mode. Both the actual illustrated assuming that the timer is used for
TMR2 value as well as other internal signals are sent to the PWM function of the CCP module as
the CCP module to properly clock both the period and described in Section 21.5 PWM Overview
pulse width of the PWM signal. See Section and Section 22.0 Pulse-Width Modula-
21.5 PWM Overview and Section tion (PWM ). The signals are not a part of
22.0 Pulse-Width Modulation (PWM ) for more the Timer2 module.
details on setting up Timer2 for use with the CCP and
PWM.

20.5 External Reset Sources


In addition to the clock source, Timer2 also takes in an
external Reset source. This external Reset source is
selected for Timer2, Timer4 and Timer6 with the
T2RST, T4RST and T6RST registers, respectively.
This source can control the starting and stopping of the
timer, as well as resetting the timer, depending on
which mode the timer is in. The mode of the timer is
controlled by the MODE<4:0> bits of the TxHLT
register.

20.5.1 ONE-SHOT MODE


The MODE<3> bit of the TxHLT register controls
whether the timer is in either the One-Shot mode or the
original Normal Period mode. When this bit is set, the
timer acts in the One-Shot mode, meaning that upon
the timer register matching the PRx period register, the
timer will stop incrementing until the timer is manually
started again.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 251


PIC18(L)F26/45/46K40
20.6.1 SOFTWARE GATE MODE
The Software Gate mode corresponds to legacy Timer2
operation. The timer increments with each clock input
when ON = 1 and does not increment when ON = 0.
When the TMRx count equals the PRx period count the
timer resets on the next clock and continues counting
from 0. Operation with the ON bit software controlled is
illustrated in Figure 20-4. With PRx = 5, the counter
advances until TMRx = 5, and goes to zero with the next
clock.

FIGURE 20-4: SOFTWARE GATE MODE TIMING DIAGRAM


Rev. 10-000195B
5/30/2014

MODE 0b00000

TMRx_clk

Instruction(1) BSF BCF BSF

ON

PRx 5

TMRx 0 1 2 3 4 5 0 1 2 3 4 5 0 1 2 3 4 5 0 1

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 252


PIC18(L)F26/45/46K40
20.6.2 HARDWARE GATE MODE
The Hardware Gate modes operate the same as the
Software Gate mode except the TMRx_ers external
signal can also gate the timer. When used with the CCP
the gating extends the PWM period. If the timer is
stopped when the PWM output is high then the duty
cycle is also extended.
When MODE<4:0> = 00001 then the timer is stopped
when the external signal is high. When
MODE<4:0> = 00010, the timer is stopped when the
external signal is low.
Figure 20-5 illustrates the Hardware Gating mode for
MODE<4:0> = 00001 in which a high input level stops
the counter.

FIGURE 20-5: HARDWARE GATE MODE TIMING DIAGRAM


Rev. 10-000 196B
5/30/201 4

MODE 0b00001

TMRx_clk

TMRx_ers

PRx 5

TMRx 0 1 2 3 4 5 0 1 2 3 4 5 0 1

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

2016 Microchip Technology Inc. Preliminary DS40001816C-page 253


PIC18(L)F26/45/46K40
20.6.3 EDGE-TRIGGERED HARDWARE
LIMIT MODE
In Edge-Triggered Hardware Limit mode the timer can
be reset by the TMRx_ers external signal before the
timer reaches the period count. Three types of Resets
are possible:
Reset on rising or falling edge
(MODE<4:0> = 00011)
Reset on rising edge (MODE<4:0> = 00100)
Reset on falling edge (MODE<4:0> = 00101)
When the timer is used in conjunction with the CCP in
PWM mode then an early Reset shortens the period
and restarts the PWM pulse after a two clock delay.
Refer to Figure 20-6.

FIGURE 20-6: EDGE-TRIGGERED HARDWARE LIMIT MODE TIMING DIAGRAM


Rev. 10-000 197B
5/30/201 4

MODE 0b00100

TMRx_clk

PRx 5

Instruction(1) BSF BCF BSF

ON

TMRx_ers

TMRx 0 1 2 0 1 2 3 4 5 0 1 2 3 4 5 0 1

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 254


PIC18(L)F26/45/46K40
20.6.4 LEVEL-TRIGGERED HARDWARE
LIMIT MODE
In the Level-Triggered Hardware Limit Timer modes the
counter is reset by high or low levels of the external sig-
nal TMRx_ers, as shown in Figure 20-7. Selecting
MODE<4:0> = 00110 will cause the timer to reset on a
low level external signal. Selecting
MODE<4:0> = 00111 will cause the timer to reset on a
high level external signal. In the example, the counter is
reset while TMRx_ers = 1. ON is controlled by BSF and
BCF instructions. When ON = 0 the external signal is
ignored.
When the CCP uses the timer as the PWM time base
then an external signal Reset will set the PWM output
high after a two clock synchronization delay or the timer
matches the PRx period value. The PWM output will
remain high until the external signal is released and the
timer counts up to match the CCPRx pulse-width value.

FIGURE 20-7: LEVEL-TRIGGERED HARDWARE LIMIT TIMING DIAGRAM


Rev. 10-000198B
5/30/2014

MODE 0b00111

TMRx_clk

PRx 5

Instruction(1) BSF BCF BSF

ON

TMRx_ers

TMRx 0 1 2 0 1 2 3 4 5 0 0 1 2 3 4 5 0

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 255


PIC18(L)F26/45/46K40
20.6.5 ONE-SHOT MODE When One-Shot mode is used in conjunction with the
CCP/PWM operation the PWM pulse drive starts con-
In One-Shot mode, the timer resets and the ON bit is
current with setting the ON bit. Clearing the ON bit
cleared when the timer value matches the PRx period
while the PWM drive is active will extend the PWM
value. The ON bit must be set by software to start
drive. The PWM drive will terminate when the timer
another timer cycle. Setting MODE<4:0> = 01000
value matches the CCPRx pulse-width value. The
selects One-Shot mode which is illustrated in
PWM drive will remain off until software sets the ON bit
Figure 20-8. In the example, ON is controlled by BSF
to start another cycle. If software clears the ON bit after
and BCF instructions. In the first case, a BSF instruc-
the CCPRx match but before the PRx match then the
tion sets ON and the counter runs to completion and
PWM drive will be extended by the length of time the
clears ON. In the second case, a BSF instruction starts
ON bit remains cleared. Another timing cycle can only
the cycle, BCF/BSF instructions turn the counter off
be initiated by setting the ON bit after it has been
and on during the cycle, and then it runs to completion.
cleared by a PRx period count match.

FIGURE 20-8: ONE-SHOT MODE TIMING DIAGRAM


Rev. 10-000199B
5/30/2014

MODE 0b01000

TMRx_clk

PRx 5

Instruction(1) BSF BSF BCF BSF

ON

TMRx 0 1 2 3 4 5 0 1 2 3 4 5 0

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions
executed by the CPU to set or clear the ON bit of TxCON. CPU
execution is asynchronous to the timer clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 256


PIC18(L)F26/45/46K40
20.6.6 EDGE-TRIGGERED ONE-SHOT If the timer is halted by clearing the ON bit then another
MODE TMRx_ers edge is required after the ON bit is set to
resume counting. Figure 20-9 illustrates operation in
The Edge-Triggered One-Shot modes start the timer the rising edge One-Shot mode.
on an edge from the external signal input, after the ON
When this mode is used in conjunction with the CCP
bit is set, and clear the ON bit when the timer matches
then the edge-trigger will activate the PWM drive and
the PRx period value. The following edges will start the the PWM drive will deactivate when the timer matches
timer: the CCPRx pulse-width value and stay deactivated
Rising edge (MODE<4:0> = 01001) when the timer halts at the PRx period count match.
Falling edge (MODE<4:0>= 01010)
Rising or Falling edge (MODE<4:0> = 01011)

FIGURE 20-9: EDGE-TRIGGERED ONE-SHOT MODE TIMING DIAGRAM


Rev. 10-000200B
5/30/2014

MODE 0b01001

TMRx_clk

PRx 5

Instruction(1) BSF BSF BCF

ON

TMRx_ers

TMRx 0 1 2 3 4 5 0 1 2

TMRx_out

TMRx_postscaled

PWM Duty
3
Cycle

PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 257


PIC18(L)F26/45/46K40
20.6.7 EDGE-TRIGGERED HARDWARE
LIMIT ONE-SHOT MODE
In Edge-Triggered Hardware Limit One-Shot modes
the timer starts on the first external signal edge after
the ON bit is set and resets on all subsequent edges.
Only the first edge after the ON bit is set is needed to
start the timer. The counter will resume counting
automatically two clocks after all subsequent external
Reset edges. Edge triggers are as follows:
Rising edge Start and Reset
(MODE<4:0> = 01100)
Falling edge Start and Reset
(MODE<4:0> = 01101)
The timer resets and clears the ON bit when the timer
value matches the PRx period value. External signal
edges will have no effect until after software sets the
ON bit. Figure 20-10 illustrates the rising edge hard-
ware limit one-shot operation.
When this mode is used in conjunction with the CCP
then the first starting edge trigger, and all subsequent
Reset edges, will activate the PWM drive. The PWM
drive will deactivate when the timer matches the
CCPRx pulse-width value and stay deactivated until
the timer halts at the PRx period match unless an exter-
nal signal edge resets the timer before the match
occurs.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 258


FIGURE 20-10: EDGE-TRIGGERED HARDWARE LIMIT ONE-SHOT TIMING DIAGRAM
2016 Microchip Technology Inc.

Rev. 10-000 201B


5/30/201 4

MODE 0b01100

TMRx_clk

PRx 5

Instruction(1) BSF BSF

ON

TMRx_ers

TMRx 0 1 2 3 4 5 0 1 2 0 1 2 3 4 5 0

TMRx_postscaled
Preliminary

PWM Duty
3
Cycle

PIC18(L)F26/45/46K40
PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.
DS40001816C-page 259
PIC18(L)F26/45/46K40
20.6.8 LEVEL TRIGGERED HARDWARE
LIMIT ONE-SHOT MODES
In Level Triggered One-Shot mode the timer count is
reset on the external signal level and starts counting
when the external signal level relinquishes the Reset.
Reset levels are selected as follows:
High Reset level (MODE<4:0> = 01110)
Low Reset level (MODE<4:0> = 01111)
When the timer count matches the PRx period count
then the timer is reset and the ON bit is cleared. When
the ON bit is cleared by either a PRx match or by soft-
ware control a new external signal edge is required
after the ON bit is set to start the counter.
When Level Triggered Reset One-Shot mode is used in
conjunction with the CCP PWM operation the PWM
drive goes active with the external signal edge that
starts the timer. The PWM drive goes inactive when the
timer count equals the CCPRx pulse-width count. The
PWM drive does not go active when the timer count
clears at the PRx period count match.

20.7 Timer2 Operation During Sleep


When TxPSYNC = 1, Timer2 cannot be operated while
the processor is in Sleep mode. The contents of the
TMR2 and PR2 registers will remain unchanged while
processor is in Sleep mode.
When TxPSYNC = 0, Timer2 will operate in Sleep as
long as the clock source selected is also still running.
Selecting the LFINTOSC, MFINTOSC, or HFINTOSC
oscillator as the timer clock source will keep the
selected oscillator running during Sleep.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 260


FIGURE 20-11: LEVEL-TRIGGERED HARDWARE LIMIT ONE-SHOT MODE TIMING DIAGRAM
2016 Microchip Technology Inc.

Rev. 10-000 202A


12/20/201 3

MODE 0b1110

TMRx_clk

PRx 5

Instruction(1) BSF BSF

ON

TMRx_ers

TMRx 0 1 2 3 4 5 0 1 0 1 2 3 4 5 0

TMRx_postscaled
Preliminary

PWM Duty
3
Cycle

PIC18(L)F26/45/46K40
PWM Output

Note 1: BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to
set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input.
DS40001816C-page 261
PIC18(L)F26/45/46K40
TABLE 20-3: SUMMARY OF REGISTERS ASSOCIATED WITH TIMER2
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
CCPTMRS P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0> 266
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE 182
PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF 174
IPR4 TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP 190
PMD1 TMR6MD TMR5MD TMR4MD TMR3MD TMR2MD TMR1MD TMR0MD 68
PR2 Timer2 Module Period Register 250*
TMR2 Holding Register for the 8-bit TMR2 Register 250*
T2CON ON CKPS<2:0> OUTPS<3:0> 245
T2CLKCON CS<2:0> 248
T2RST RSEL<3:0> 249
T2HLT PSYNC CPOL CSYNC MODE<4:0> 246
PR4 Timer4 Module Period Register 250*
TMR4 Holding Register for the 8-bit TMR4 Register 250*
T4CON ON CKPS<2:0> OUTPS<3:0> 245
T4CLKCON CS<2:0> 248
T4RST RSEL<3:0> 249
T4HLT PSYNC CPOL CSYNC MODE<4:0> 246
PR6 Timer6 Module Period Register 250*
TMR6 Holding Register for the 8-bit TMR6 Register 250*
T6CON ON CKPS<2:0> OUTPS<3:0> 245
T6CLKCON CS<2:0> 248
T6RST RSEL<3:0> 249
T6HLT PSYNC CPOL CSYNC MODE<4:0> 246
T2INPPS T2INPPS<4:0> 215
T4INPPS T4INPPS<4:0> 215
T6INPPS T6INPPS<4:0> 215
Legend: = unimplemented location, read as 0. Shaded cells are not used for Timer2 module.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 262


PIC18(L)F26/45/46K40
21.0 CAPTURE/COMPARE/PWM 21.1 CCP Module Configuration
MODULE Each Capture/Compare/PWM module is associated
The Capture/Compare/PWM module is a peripheral with a control register (CCPxCON), a capture input
that allows the user to time and control different events, selection register (CCPxCAP) and a data register
and to generate Pulse-Width Modulation (PWM) (CCPRx). The data register, in turn, is comprised of two
signals. In Capture mode, the peripheral allows the 8-bit registers: CCPRxL (low byte) and CCPRxH (high
timing of the duration of an event. The Compare mode byte).
allows the user to trigger an external event when a
21.1.1 CCP MODULES AND TIMER
predetermined amount of time has expired. The PWM
mode can generate Pulse-Width Modulated signals of RESOURCES
varying frequency and duty cycle. The CCP modules utilize Timers 1 through 6 that vary
This family of devices contains two standard with the selected mode. Various timers are available to
Capture/Compare/PWM modules (CCP1 and CCP2). the CCP modules in Capture, Compare or PWM
Each individual CCP module can select the timer modes, as shown in Table 21-1.
source that controls the module. Each module has an
independent timer selection which can be accessed TABLE 21-1: CCP MODE TIMER
using the CxTSEL bits in the CCPTMRS register RESOURCE
(Register 21-2). The default timer selection is TMR1 CCP Mode Timer Resource
when using Capture/Compare mode and TMR2 when
using PWM mode in the CCPx module. Capture
Timer1, Timer3 or Timer5
Please note that the Capture/Compare mode operation Compare
is described with respect to TMR1 and the PWM mode
PWM Timer2, Timer4 or Timer6
operation is described with respect to TMR2 in the
following sections. The assignment of a particular timer to a module is
The Capture and Compare functions are identical for all determined by the timer to CCP enable bits in the
CCP modules. CCPTMRS register (see Register 21-2) All of the
modules may be active at once and may share the
Note 1: In devices with more than one CCP same timer resource if they are configured to operate
module, it is very important to pay close in the same mode (Capture/Compare or PWM) at the
attention to the register names used. A same time.
number placed after the module acronym
is used to distinguish between separate 21.1.2 OPEN-DRAIN OUTPUT OPTION
modules. For example, the CCP1CON
When operating in Output mode (the Compare or PWM
and CCP2CON control the same
modes), the drivers for the CCPx pins can be optionally
operational aspects of two completely
configured as open-drain outputs. This feature allows
different CCP modules.
the voltage level on the pin to be pulled to a higher level
2: Throughout this section, generic through an external pull-up resistor and allows the
references to a CCP module in any of its output to communicate with external circuits without the
operating modes may be interpreted as need for additional level shifters.
being equally applicable to CCPx module.
Register names, module signals, I/O pins,
and bit names may use the generic
designator x to indicate the use of a
numeral to distinguish a particular module,
when required.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 263


PIC18(L)F26/45/46K40
21.2 Register Definitions: CCP Control
Long bit name prefixes for the CCP peripherals are
shown in Table 21-2. Refer to Section 1.4.2.2 Long
Bit Names for more information.
TABLE 21-2:
Peripheral Bit Name Prefix
CCP1 CCP1
CCP2 CCP2

REGISTER 21-1: CCPxCON: CCPx CONTROL REGISTER


R/W-0/0 U-0 R-x R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
EN OUT FMT MODE<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 EN: CCP Module Enable bit


1 = CCP is enabled
0 = CCP is disabled
bit 6 Unimplemented: Read as 0
bit 5 OUT: CCPx Output Data bit (read-only)
bit 4 FMT: CCPW (pulse-width) Alignment bit
MODE = Capture mode:
Unused
MODE = Compare mode:
Unused
MODE = PWM mode:
1 = Left-aligned format
0 = Right-aligned format

Note 1: The set and clear operations of the Compare mode are reset by setting MODE = 4b0000 or EN = 0.
2: When MODE = 0001 or 1011, then the timer associated with the CCP module is cleared. TMR1 is the
default selection for the CCP module, so it is used for indication purpose only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 264


PIC18(L)F26/45/46K40
REGISTER 21-1: CCPxCON: CCPx CONTROL REGISTER (CONTINUED)
bit 3-0 MODE<3:0>: CCPx Mode Select bits

Operating
MODE Operation Set CCPxIF
Mode
11xx PWM PWM operation Yes
1011 Pulse output; clear TMR1(2) Yes
1010 Pulse output Yes
Compare
1001 Clear output(1) Yes
1000 Set output(1) Yes
0111 Every 16th rising edge of CCPx input Yes
0110 Every 4th rising edge of CCPx input Yes
0101 Capture Every rising edge of CCPx input Yes
0100 Every falling edge of CCPx input Yes
0011 Every edge of CCPx input Yes
0010 Toggle output Yes
Compare
0001 Toggle output; clear TMR1(2) Yes
0000 Disabled

Note 1: The set and clear operations of the Compare mode are reset by setting MODE = 4b0000 or EN = 0.
2: When MODE = 0001 or 1011, then the timer associated with the CCP module is cleared. TMR1 is the
default selection for the CCP module, so it is used for indication purpose only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 265


PIC18(L)F26/45/46K40

REGISTER 21-2: CCPTMRS: CCP TIMERS CONTROL REGISTER


R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1
P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 P4TSEL<1:0>: PWM4 Timer Selection bits


11 = PWM4 based on TMR6
10 = PWM4 based on TMR4
01 = PWM4 based on TMR2
00 = Reserved
bit 5-4 P3TSEL<1:0>: PWM3 Timer Selection bits
11 = PWM3 based on TMR6
10 = PWM3 based on TMR4
01 = PWM3 based on TMR2
00 = Reserved
bit 3-2 C2TSEL<1:0>: CCP2 Timer Selection bits
11 = CCP2 is based off Timer5 in Capture/Compare mode and Timer6 in PWM mode
10 = CCP2 is based off Timer3 in Capture/Compare mode and Timer4 in PWM mode
01 = CCP2 is based off Timer1 in Capture/Compare mode and Timer2 in PWM mode
00 = Reserved
bit 1-0 C1TSEL<1:0>: CCP1 Timer Selection bits
11 = CCP1 is based off Timer5 in Capture/Compare mode and Timer6 in PWM mode
10 = CCP1 is based off Timer3 in Capture/Compare mode and Timer4 in PWM mode
01 = CCP1 is based off Timer1 in Capture/Compare mode and Timer2 in PWM mode
00 = Reserved

2016 Microchip Technology Inc. Preliminary DS40001816C-page 266


PIC18(L)F26/45/46K40

REGISTER 21-3: CCPxCAP: CAPTURE INPUT SELECTION MULTIPLEXER REGISTER


U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/x R/W-0/x
CTS<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1-0 CTS<1:0>: Capture Trigger Input Selection bits

Connection
CTS<1:0>
CCP1 CCP2
11 IOC_Interrupt
10 CMP2_output
01 CMP1_output
00 Pin selected by CCP1PPS Pin selected by CCP2PPS

REGISTER 21-4: CCPRxL: CCPx REGISTER LOW BYTE


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
CCPRx<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-0 MODE = Capture Mode:


CCPRxL<7:0>: LSB of captured TMR1 value
MODE = Compare Mode:
CCPRxL<7:0>: LSB compared to TMR1 value
MODE = PWM Mode && FMT = 0:
CCPRxL<7:0>: CCPW<7:0> Pulse-Width LS 8 bits
MODE = PWM Mode && FMT = 1:
CCPRxL<7:6>: CCPW<1:0> Pulse-Width LS 2 bits
CCPRxL<5:0>: Not used

2016 Microchip Technology Inc. Preliminary DS40001816C-page 267


PIC18(L)F26/45/46K40

REGISTER 21-5: CCPRxH: CCPx REGISTER HIGH BYTE


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
CCPRx<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-0 MODE = Capture Mode:


CCPRxH<7:0>: MSB of captured TMR1 value
MODE = Compare Mode:
CCPRxH<7:0>: MSB compared to TMR1 value
MODE = PWM Mode && FMT = 0:
CCPRxH<7:2>: Not used
CCPRxH<1:0>: CCPW<9:8> Pulse-Width MS 2 bits
MODE = PWM Mode && FMT = 1:
CCPRxH<7:0>: CCPW<9:2> Pulse-Width MS 8 bits

2016 Microchip Technology Inc. Preliminary DS40001816C-page 268


PIC18(L)F26/45/46K40
21.3 Capture Mode 21.3.1 CAPTURE SOURCES
Capture mode makes use of the 16-bit Timer1 In Capture mode, the CCPx pin should be configured
resource. When an event occurs on the capture as an input by setting the associated TRIS control bit.
source, the 16-bit CCPRxH:CCPRxL register pair Note: If the CCPx pin is configured as an output,
captures and stores the 16-bit value of the a write to the port can cause a capture
TMRxH:TMRxL register pair, respectively. An event is condition.
defined as one of the following and is configured by the
MODE<3:0> bits of the CCPxCON register: The capture source is selected by configuring the
CTS<1:0> bits of the CCPxCAP register. The following
Every falling edge of CCPx input
sources can be selected:
Every rising edge of CCPx input
Pin selected by CCPxPPS
Every 4th rising edge of CCPx input
C1_output
Every 16th rising edge of CCPx input C2_output
Every edge of CCPx input (rising or falling) IOC_interrupt
When a capture is made, the Interrupt Request Flag bit
CCPxIF of the PIR6 register is set. The interrupt flag 21.3.2 TIMER1 MODE RESOURCE
must be cleared in software. If another capture occurs Timer1 must be running in Timer mode or Synchronized
before the value in the CCPRxH:CCPRxL register pair Counter mode for the CCP module to use the capture
is read, the old captured value is overwritten by the new feature. In Asynchronous Counter mode, the capture
captured value. operation may not work.
See Section 19.0 Timer1/3/5 Module with Gate
Note: If an event occurs during a 2-byte read, Control for more information on configuring
the high and low-byte data will be from Timer1.
different events. It is recommended while
reading the CCPRxH:CCPRxL register
pair to either disable the module or read
the register pair twice for data integrity.
Figure 21-1 shows a simplified diagram of the capture
operation.

FIGURE 21-1: CAPTURE MODE OPERATION BLOCK DIAGRAM

RxyPPS
CCPx
PPS
TRIS Control
CCPxCTS<1:0>

CCPRxH CCPRxL
IOC_interrupt 11 16
C2OUT_sink set ccpxif
10 Prescaler and
C1OUT_sink 01 1,4,16 Edge Detect
PPS 00 16
CCPxMODE<3:0> TMR1H TMR1L
CCPxPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 269


PIC18(L)F26/45/46K40
21.3.3 SOFTWARE INTERRUPT MODE 21.4 Compare Mode
When the Capture mode is changed, a false capture The Compare mode function described in this section
interrupt may be generated. The user should keep the is available and identical for all CCP modules.
CCPxIE Interrupt Priority bit of the PIE6 register clear
to avoid false interrupts. Additionally, the user should Compare mode makes use of the 16-bit Timer1
clear the CCPxIF interrupt flag bit of the PIR6 register resource. The 16-bit value of the CCPRxH:CCPRxL
following any change in Operating mode. register pair is constantly compared against the 16-bit
value of the TMRxH:TMRxL register pair. When a
Note: Clocking Timer1 from the system clock match occurs, one of the following events can occur:
(FOSC) should not be used in Capture
Toggle the CCPx output, clear TMRx
mode. In order for Capture mode to
recognize the trigger event on the CCPx Toggle the CCPx output
pin, Timer1 must be clocked from the Set the CCPx output
instruction clock (FOSC/4) or from an Clear the CCPx output
external clock source. Pulse output
Pulse output, clear TMRx
21.3.4 CCP PRESCALER
The action on the pin is based on the value of the
There are four prescaler settings specified by the MODE<3:0> control bits of the CCPxCON register. At
MODE<3:0> bits of the CCPxCON register. Whenever the same time, the interrupt flag CCPxIF bit is set, and
the CCP module is turned off, or the CCP module is not an ADC conversion can be triggered, if selected.
in Capture mode, the prescaler counter is cleared. Any
Reset will clear the prescaler counter. All Compare modes can generate an interrupt and
trigger an ADC conversion. When MODE = 4'b0001
Switching from one capture prescaler to another does not or 4'b1011, the CCP resets the TMR register pair.
clear the prescaler and may generate a false interrupt. To
avoid this unexpected operation, turn the module off by Figure 21-2 shows a simplified diagram of the compare
clearing the CCPxCON register before changing the operation.
prescaler. Example 21-1 demonstrates the code to
perform this function. FIGURE 21-2: COMPARE MODE
OPERATION BLOCK
EXAMPLE 21-1: CHANGING BETWEEN DIAGRAM
CAPTURE PRESCALERS CCPxMODE<3:0>
Mode Select
BANKSEL CCPxCON ;Set Bank bits to point
;to CCPxCON
CLRF CCPxCON ;Turn CCP module off Set CCPxIF Interrupt Flag
(PIR6)
MOVLW NEW_CAPT_PS ;Load the W reg with 4
;the new prescaler CCPRxH CCPRxL
;move value and CCP ON PPS Q S
MOVWF CCPxCON ;Load CCPxCON with this Output Comparator
R Logic Match
;value RxyPPS
TMR1H TMR1L
TRIS
21.3.5 CAPTURE DURING SLEEP Output Enable
Capture mode depends upon the Timer1 module for Auto-conversion Trigger
proper operation. There are two options for driving the
Timer1 module in Capture mode. It can be driven by the
instruction clock (FOSC/4), or by an external clock source.
When Timer1 is clocked by FOSC/4, Timer1 will not
increment during Sleep. When the device wakes from
Sleep, Timer1 will continue from its previous state.
Capture mode will operate during Sleep when Timer1
is clocked by an external clock source.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 270


PIC18(L)F26/45/46K40
21.4.1 CCPx PIN CONFIGURATION 21.5 PWM Overview
The software must configure the CCPx pin as an output Pulse-Width Modulation (PWM) is a scheme that
by clearing the associated TRIS bit and defining the provides power to a load by switching quickly between
appropriate output pin through the RxyPPS registers. fully on and fully off states. The PWM signal resembles
See Section 17.0 Peripheral Pin Select (PPS) a square wave where the high portion of the signal is
Module for more details. considered the ON state and the low portion of the signal
The CCP output can also be used as an input for other is considered the OFF state. The high portion, also
peripherals. known as the pulse width, can vary in time and is defined
in steps. A larger number of steps applied, which
Note: Clearing the CCPxCON register will force lengthens the pulse width, also supplies more power to
the CCPx compare output latch to the the load. Lowering the number of steps applied, which
default low level. This is not the PORT I/O shortens the pulse width, supplies less power. The PWM
data latch. period is defined as the duration of one complete cycle
or the total amount of on and off time combined.
21.4.2 TIMER1 MODE RESOURCE
PWM resolution defines the maximum number of steps
In Compare mode, Timer1 must be running in either that can be present in a single PWM period. A higher
Timer mode or Synchronized Counter mode. The resolution allows for more precise control of the
compare operation may not work in Asynchronous pulse-width time and in turn the power that is applied to
Counter mode. the load.
See Section 19.0 Timer1/3/5 Module with Gate The term duty cycle describes the proportion of the on
Control for more information on configuring Timer1. time to the off time and is expressed in percentages,
Note: Clocking Timer1 from the system clock where 0% is fully off and 100% is fully on. A lower duty
(FOSC) should not be used in Compare cycle corresponds to less power applied and a higher
mode. In order for Compare mode to duty cycle corresponds to more power applied.
recognize the trigger event on the CCPx Figure 21-3 shows a typical waveform of the PWM
pin, TImer1 must be clocked from the signal.
instruction clock (FOSC/4) or from an
external clock source. 21.5.1 STANDARD PWM OPERATION
The standard PWM function described in this section is
21.4.3 AUTO-CONVERSION TRIGGER available and identical for all CCP modules.
All CCPx modes set the CCP interrupt flag (CCPxIF). The standard PWM mode generates a Pulse-Width
When this flag is set and a match occurs, an Modulation (PWM) signal on the CCPx pin with up to
auto-conversion trigger can take place if the CCP ten bits of resolution. The period, duty cycle, and
module is selected as the conversion trigger source. resolution are controlled by the following registers:
Refer to Section 31.2.6 Auto-Conversion Trigger PR2 registers
for more information.
T2CON registers
Note: Removing the match condition by CCPRxL and CCPRxH registers
changing the contents of the CCPRxH CCPxCON registers
and CCPRxL register pair, between the
clock edge that generates the It is required to have FOSC/4 as the clock input to
Auto-conversion Trigger and the clock TMR2/4/6 for correct PWM operation. Figure 21-4
edge that generates the Timer1 Reset, will shows a simplified block diagram of PWM operation.
preclude the Reset from occurring Note: The corresponding TRIS bit must be
cleared to enable the PWM output on the
21.4.4 COMPARE DURING SLEEP CCPx pin.
Since FOSC is shut down during Sleep mode, the
Compare mode will not function properly during Sleep, FIGURE 21-3: CCP PWM OUTPUT SIGNAL
unless the timer is running. The device will wake on
interrupt (if enabled). Period

Pulse Width
TMR2 = PR2

TMR2 = CCPRxH:CCPRxL

TMR2 = 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 271


PIC18(L)F26/45/46K40
FIGURE 21-4: SIMPLIFIED PWM BLOCK DIAGRAM
Rev. 10-000 157C

Duty cycle registers 9/5/201 4

CCPRxH CCPRxL
CCPx_out
To Peripherals
set CCPIF
10-bit Latch(2)
(Not accessible by user)

Comparator R Q PPS CCPx

S RxyPPS
TMR2 Module TRIS Control

R
TMR2 (1)

ERS logic
Comparator CCPx_pset

PR2

Notes: 1. 8-bit timer is concatenated with two bits generated by Fosc or two bits of the internal prescaler to
create 10-bit time-base.
2. The alignment of the 10 bits from the CCPR register is determined by the CCPxFMT bit.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 272


PIC18(L)F26/45/46K40
21.5.2 SETUP FOR PWM OPERATION 21.5.4 PWM PERIOD
The following steps should be taken when configuring The PWM period is specified by the PR2 register of
the CCP module for standard PWM operation: Timer2. The PWM period can be calculated using the
1. Use the desired output pin RxyPPS control to formula of Equation 21-1.
select CCPx as the source and disable the
CCPx pin output driver by setting the associated EQUATION 21-1: PWM PERIOD
TRIS bit.
PWM Period = PR2 + 1 4 T OSC
2. Load the PR2 register with the PWM period
value. (TMR2 Prescale Value)
3. Configure the CCP module for the PWM mode
by loading the CCPxCON register with the Note 1: TOSC = 1/FOSC
appropriate values.
When TMR2 is equal to PR2, the following three events
4. Load the CCPRxL register, and the CCPRxH
occur on the next increment cycle:
register with the PWM duty cycle value and
configure the FMT bit of the CCPxCON register TMR2 is cleared
to set the proper register alignment. The CCPx pin is set. (Exception: If the PWM duty
5. Configure and start Timer2: cycle = 0%, the pin will not be set.)
Clear the TMR2IF interrupt flag bit of the The PWM duty cycle is transferred from the
PIR4 register. See Note below. CCPRxL/H register pair into a 10-bit buffer.
Select the timer clock source to be as
FOSC/4 using the TxCLKCON register. This Note: The Timer postscaler (see Section
is required for correct operation of the 20.3 Timer2 Interrupt) is not used in
PWM module. the determination of the PWM frequency.
Configure the T2CKPS bits of the T2CON
register with the Timer prescale value.
Enable the Timer by setting the ON bit of
the T2CON register.
6. Enable PWM output pin:
Wait until the Timer overflows and the
TMR2IF bit of the PIR4 register is set. See
Note below.
Enable the CCPx pin output driver by
clearing the associated TRIS bit.

Note: In order to send a complete duty cycle and


period on the first PWM output, the above
steps must be included in the setup
sequence. If it is not critical to start with a
complete PWM signal on the first output,
then step 6 may be ignored.

21.5.3 TIMER2 TIMER RESOURCE


The PWM standard mode makes use of the 8-bit
Timer2 timer resources to specify the PWM period.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 273


PIC18(L)F26/45/46K40
21.5.5 PWM DUTY CYCLE 21.5.6 PWM RESOLUTION
The PWM duty cycle is specified by writing a 10-bit The resolution determines the number of available duty
value to the CCPRxH:CCPRxL register pair. The cycles for a given period. For example, a 10-bit resolution
alignment of the 10-bit value is determined by the FMT will result in 1024 discrete duty cycles, whereas an 8-bit
bit of the CCPxCON register (see Figure 21-5). The resolution will result in 256 discrete duty cycles.
CCPRxH:CCPRxL register pair can be written to at any The maximum PWM resolution is ten bits when PR2 is
time; however the duty cycle value is not latched into 255. The resolution is a function of the PR2 register
the 10-bit buffer until after a match between PR2 and value as shown by Equation 21-4.
TMR2.
Equation 21-2 is used to calculate the PWM pulse EQUATION 21-4: PWM RESOLUTION
width.
Equation 21-3 is used to calculate the PWM duty cycle log 4 PR2 + 1
Resolution = ------------------------------------------ bits
ratio. log 2

FIGURE 21-5: PWM 10-BIT ALIGNMENT


Rev. 10-000 160A
12/9/201 3 Note: If the pulse-width value is greater than the
period the assigned PWM pin(s) will
CCPRxH CCPRxL
FMT = 0 remain unchanged.
7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0

CCPRxH CCPRxL
FMT = 1 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0

10-bit Duty Cycle


9 8 7 6 5 4 3 2 1 0

EQUATION 21-2: PULSE WIDTH

Pulse Width = CCPRxH:CCPRxL register pair


T OSC (TMR2 Prescale Value)

EQUATION 21-3: DUTY CYCLE RATIO

CCPRxH:CCPRxL register pair


Duty Cycle Ratio = ----------------------------------------------------------------------------------
4 PR2 + 1

CCPRxH:CCPRxL register pair are used to double


buffer the PWM duty cycle. This double buffering is
essential for glitchless PWM operation.
The 8-bit timer TMR2 register is concatenated with
either the 2-bit internal system clock (FOSC), or two bits
of the prescaler, to create the 10-bit time base. The
system clock is used if the Timer2 prescaler is set to 1:1.
When the 10-bit time base matches the
CCPRxH:CCPRxL register pair, then the CCPx pin is
cleared (see Figure 21-4).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 274


PIC18(L)F26/45/46K40

TABLE 21-3: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (FOSC = 20 MHz)


PWM Frequency 1.22 kHz 4.88 kHz 19.53 kHz 78.12 kHz 156.3 kHz 208.3 kHz
Timer Prescale 16 4 1 1 1 1
PR2 Value 0xFF 0xFF 0xFF 0x3F 0x1F 0x17
Maximum Resolution (bits) 10 10 10 8 7 6.6

TABLE 21-4: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (FOSC = 8 MHz)


PWM Frequency 1.22 kHz 4.90 kHz 19.61 kHz 76.92 kHz 153.85 kHz 200.0 kHz
Timer Prescale 16 4 1 1 1 1
PR2 Value 0x65 0x65 0x65 0x19 0x0C 0x09
Maximum Resolution (bits) 8 8 8 6 5 5

21.5.7 OPERATION IN SLEEP MODE


In Sleep mode, the TMR2 register will not increment
and the state of the module will not change. If the CCPx
pin is driving a value, it will continue to drive that value.
When the device wakes up, TMR2 will continue from its
previous state.

21.5.8 CHANGES IN SYSTEM CLOCK


FREQUENCY
The PWM frequency is derived from the system clock
frequency. Any changes in the system clock frequency
will result in changes to the PWM frequency. See Sec-
tion 4.0 Oscillator Module (with Fail-Safe Clock
Monitor) for additional details.

21.5.9 EFFECTS OF RESET


Any Reset will force all ports to Input mode and the
CCP registers to their Reset states.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 275


PIC18(L)F26/45/46K40

TABLE 21-5: SUMMARY OF REGISTERS ASSOCIATED WITH CCPx


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE6 CCP2IE CCP1IE 184
PIR6 CCP2IF CCP1IF 176
IPR6 CCP2IP CCP1IP 192
PMD3 PWM4MD PWM3MD CCP2MD CCP1MD 70
CCPxCON EN OUT FMT MODE<3:0> 264
CCPxCAP CTS<1:0> 267
CCPRxL CCPRx<7:0> 267
CCPRxH CCPRx<15:8> 268
CCPTMRS P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0> 266
CCPxPPS CCPxPPS<4:0> 215
RxyPPS RxyPPS<4:0> 217
T1CON T1CKPS<1:0> T1SYNC T1RD16 TMR1ON 228
T1GCON TMR1GE T1GPOL T1GTM T1GSPM T1GO/DONE T1GVAL 229
T1CLK CS<3:0> 230
T1GATE GSS<3:0> 231
TMR1L TMR1L7 TMR1L6 TMR1L5 TMR1L4 TMR1L3 TMR1L2 TMR1L1 TMR1L0 232
TMR1H TMR1H7 TMR1H6 TMR1H5 TMR1H4 TMR1H3 TMR1H2 TMR1H1 TMR1H0 232
TMR2 TMR2<7:0> 244
T2PR PR2<7:0> 244
T2CON ON CKPS<2:0> OUTPS<3:0> 245
T2HLT PSYNC CPOL CSYNC MODE<4:0> 246
T2CLKCON CS<3:0> 248

T2RST RSEL<3:0> 249


Legend: = Unimplemented location, read as 0. Shaded cells are not used by the CCP module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 276


PIC18(L)F26/45/46K40
22.0 PULSE-WIDTH MODULATION Each PWM module can select the timer source that
controls the module. Each module has an independent
(PWM )
timer selection which can be accessed using the
The PWM module generates a Pulse-Width Modulated CCPTMRS register (Register 21-2). Please note that
signal determined by the duty cycle, period, and the PWM mode operation is described with respect to
resolution that are configured by the following registers: TMR2 in the following sections.
PRx Figure 22-1 shows a simplified block diagram of PWM
TxCON operation.
PWMxDCH Figure 22-2 shows a typical waveform of the PWM
PWMxDCL signal.
PWMxCON
Note: The corresponding TRIS bit must be
cleared to enable the PWM output on the
PWMx pin.

FIGURE 22-1: SIMPLIFIED PWM BLOCK DIAGRAM

Duty Cycle registers PWMxDCL<7:6>

PWMxDCH

Latched PWMxOUT
(Not visible to user)
to other peripherals

Comparator R Q 0
PPS PWMx

S Q 1
RxyPPS

TMR2 Module

TMR2 (1) Output Polarity (PWMxPOL)

Comparator

Clear Timer,
PR2 PWMx pin and
latch Duty Cycle

Note 1: 8-bit timer is concatenated with the two Least Significant bits of 1/FOSC adjusted by the Timer2 prescaler to
create a 10-bit time base.

FIGURE 22-2: PWM OUTPUT For a step-by-step procedure on how to set up this
module for PWM operation, refer to Section
Period 22.1.9 Setup for PWM Operation using PWMx
Pins.
Pulse Width
TMR2 = PR2

TMR2 =
PWMxDCH<7:0>:PWMxDCL<7:6>
TMR2 = 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 277


PIC18(L)F26/45/46K40
22.1 PWMx Pin Configuration 22.1.3 PWM PERIOD
All PWM outputs are multiplexed with the PORT data The PWM period is specified by the PR2 register of
latch. The user must configure the pins as outputs by Timer2. The PWM period can be calculated using the
clearing the associated TRIS bits. formula of Equation 22-1. It is required to have FOSC/4
as the clock input to TMR2/4/6 for correct PWM
22.1.1 FUNDAMENTAL OPERATION operation.
The PWM module produces a 10-bit resolution output.
The PWM timer can be selected using the PxTSEL bits EQUATION 22-1: PWM PERIOD
in the CCPTMRS register. The default selection for PWM Period = PR2 + 1 4 T OSC
PWMx is TMR2. Please note that the PWM module
(TMR2 Prescale Value)
operation in the following sections is described with
respect to TMR2. Timer2 and PR2 set the period of the Note: TOSC = 1/FOSC
PWM. The PWMxDCL and PWMxDCH registers con-
figure the duty cycle. The period is common to all PWM When TMR2 is equal to PR2, the following three events
modules, whereas the duty cycle is independently con- occur on the next increment cycle:
trolled. TMR2 is cleared
Note: The Timer2 postscaler is not used in the The PWM output is active. (Exception: When the
determination of the PWM frequency. The PWM duty cycle = 0%, the PWM output will
postscaler could be used to have a servo remain inactive.)
update rate at a different frequency than the The PWMxDCH and PWMxDCL register values
PWM output. are latched into the buffers.
All PWM outputs associated with Timer2 are set when
TMR2 is cleared. Each PWMx is cleared when TMR2 Note: The Timer2 postscaler has no effect on the
is equal to the value specified in the corresponding PWM operation.
PWMxDCH (8 MSb) and PWMxDCL<7:6> (2 LSb) reg-
isters. When the value is greater than or equal to PR2, 22.1.4 PWM DUTY CYCLE
the PWM output is never cleared (100% duty cycle). The PWM duty cycle is specified by writing a 10-bit
Note: The PWMxDCH and PWMxDCL registers value to the PWMxDCH and PWMxDCL register pair.
are double buffered. The buffers are updated The PWMxDCH register contains the eight MSbs and
when Timer2 matches PR2. Care should be the PWMxDCL<7:6>, the two LSbs. The PWMxDCH
taken to update both registers before the and PWMxDCL registers can be written to at any time.
timer match occurs. Equation 22-2 is used to calculate the PWM pulse
width.
22.1.2 PWM OUTPUT POLARITY Equation 22-3 is used to calculate the PWM duty cycle
The output polarity is inverted by setting the PWMxPOL ratio.
bit of the PWMxCON register.
EQUATION 22-2: PULSE WIDTH

Pulse Width = PWMxDCH:PWMxDCL<7:6>

T OS C (TMR2 Prescale Value)

Note: TOSC = 1/FOSC

EQUATION 22-3: DUTY CYCLE RATIO

PWMxDCH:PWMxDCL<7:6>
Duty Cycle Ratio = -----------------------------------------------------------------------------------
4 PR2 + 1

The 8-bit timer TMR2 register is concatenated with the


two Least Significant bits of 1/FOSC, adjusted by the
Timer2 prescaler to create the 10-bit time base. The
system clock is used if the Timer2 prescaler is set to 1:1.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 278


PIC18(L)F26/45/46K40
22.1.5 PWM RESOLUTION
The resolution determines the number of available duty
cycles for a given period. For example, a 10-bit resolution
will result in 1024 discrete duty cycles, whereas an 8-bit
resolution will result in 256 discrete duty cycles.
The maximum PWM resolution is ten bits when PR2 is
255. The resolution is a function of the PR2 register
value as shown by Equation 22-4.

EQUATION 22-4: PWM RESOLUTION

log 4 PR2 + 1
Resolution = ------------------------------------------ bits
log 2

Note: If the pulse-width value is greater than the


period the assigned PWM pin(s) will
remain unchanged.

TABLE 22-1: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (FOSC = 20 MHz)


PWM Frequency 0.31 kHz 4.88 kHz 19.53 kHz 78.12 kHz 156.3 kHz 208.3 kHz
Timer Prescale 64 4 1 1 1 1
PR2 Value 0xFF 0xFF 0xFF 0x3F 0x1F 0x17
Maximum Resolution (bits) 10 10 10 8 7 6.6

TABLE 22-2: EXAMPLE PWM FREQUENCIES AND RESOLUTIONS (FOSC = 8 MHz)


PWM Frequency 0.31 kHz 4.90 kHz 19.61 kHz 76.92 kHz 153.85 kHz 200.0 kHz
Timer Prescale 64 4 1 1 1 1
PR2 Value 0x65 0x65 0x65 0x19 0x0C 0x09
Maximum Resolution (bits) 8 8 8 6 5 5

22.1.6 OPERATION IN SLEEP MODE


In Sleep mode, the TMR2 register will not increment
and the state of the module will not change. If the
PWMx pin is driving a value, it will continue to drive that
value. When the device wakes up, TMR2 will continue
from its previous state.

22.1.7 CHANGES IN SYSTEM CLOCK


FREQUENCY
The PWM frequency is derived from the system clock
frequency (FOSC). Any changes in the system clock
frequency will result in changes to the PWM frequency.
Refer to Section 4.0 Oscillator Module (with
Fail-Safe Clock Monitor) for additional details.

22.1.8 EFFECTS OF RESET


Any Reset will force all ports to Input mode and the
PWM registers to their Reset states.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 279


PIC18(L)F26/45/46K40
22.1.9 SETUP FOR PWM OPERATION 22.1.10 SETUP FOR PWM OPERATION TO
USING PWMx PINS OTHER DEVICE PERIPHERALS
The following steps should be taken when configuring The following steps should be taken when configuring
the module for PWM operation using the PWMx pins: the module for PWM operation to be used by other
1. Disable the PWMx pin output driver(s) by setting device peripherals:
the associated TRIS bit(s). 1. Disable the PWMx pin output driver(s) by setting
2. Clear the PWMxCON register. the associated TRIS bit(s).
3. Load the PR2 register with the PWM period value. 2. Clear the PWMxCON register.
4. Load the PWMxDCH register and bits <7:6> of 3. Load the PR2 register with the PWM period value.
the PWMxDCL register with the PWM duty cycle 4. Load the PWMxDCH register and bits <7:6> of
value. the PWMxDCL register with the PWM duty cycle
5. Configure and start Timer2: value.
Clear the TMR2IF interrupt flag bit of the 5. Configure and start Timer2:
PIR4 register. See Note 1 below. Clear the TMR2IF interrupt flag bit of the
Select the timer clock source to be as PIR4 register. See Note 1 below.
FOSC/4 using the TxCLKCON register. This Select the timer clock source to be as
is required for correct operation of the FOSC/4 using the TxCLKCON register. This
PWM module. is required for correct operation of the
Configure the T2CKPS bits of the T2CON PWM module.
register with the Timer2 prescale value. Configure the T2CKPS bits of the T2CON
Enable Timer2 by setting the T2ON bit of the register with the Timer2 prescale value.
T2CON register. Enable Timer2 by setting the T2ON bit of the
6. Enable PWM output pin and wait until Timer2 T2CON register.
overflows, TMR2IF bit of the PIR4 register is set. 6. Enable PWM output pin:
See note below. Wait until Timer2 overflows, TMR2IF bit of the
7. Enable the PWMx pin output driver(s) by clear- PIR4 register is set. See Note 1 below.
ing the associated TRIS bit(s) and setting the 7. Configure the PWM module by loading the
desired pin PPS control bits. PWMxCON register with the appropriate values.
8. Configure the PWM module by loading the
PWMxCON register with the appropriate values.
Note 1: In order to send a complete duty cycle
and period on the first PWM output, the
Note 1: In order to send a complete duty cycle above steps must be included in the
and period on the first PWM output, the setup sequence. If it is not critical to start
above steps must be followed in the order with a complete PWM signal on the first
given. If it is not critical to start with a output, then step 6 may be ignored.
complete PWM signal, then move Step 8
to replace Step 4.
2: For operation with other peripherals only,
disable PWMx pin outputs.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 280


PIC18(L)F26/45/46K40
22.2 Register Definitions: PWM Control
Long bit name prefixes for the PWM peripherals are
shown in Table 22-3. Refer to Section 1.4.2.2 Long
Bit Names for more information.
TABLE 22-3:
Peripheral Bit Name Prefix
PWM3 PWM3
PWM4 PWM4

REGISTER 22-1: PWMxCON: PWM CONTROL REGISTER


R/W-0/0 U-0 R-0/0 R/W-0/0 U-0 U-0 U-0 U-0
EN OUT POL
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EN: PWM Module Enable bit


1 = PWM module is enabled
0 = PWM module is disabled
bit 6 Unimplemented: Read as 0
bit 5 OUT: PWM Module Output Level When Bit is Read
bit 4 POL: PWM Output Polarity Select bit
1 = PWM output is inverted
0 = PWM output is normal
bit 3-0 Unimplemented: Read as 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 281


PIC18(L)F26/45/46K40

REGISTER 22-2: CCPTMRS: CCP TIMERS CONTROL REGISTER


R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1
P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-6 P4TSEL<1:0>: PWM4 Timer Selection bits


11 = PWM4 based on TMR6
10 = PWM4 based on TMR4
01 = PWM4 based on TMR2
00 = Reserved
bit 5-4 P3TSEL<1:0>: PWM3 Timer Selection bits
11 = PWM3 based on TMR6
10 = PWM3 based on TMR4
01 = PWM3 based on TMR2
00 = Reserved
bit 3-2 C2TSEL<1:0>: CCP2 Timer Selection bits
11 = CCP2 is based off Timer5 in Capture/Compare mode and Timer6 in PWM mode
10 = CCP2 is based off Timer3 in Capture/Compare mode and Timer4 in PWM mode
01 = CCP2 is based off Timer1 in Capture/Compare mode and Timer2 in PWM mode
00 = Reserved
bit 1-0 C1TSEL<1:0>: CCP1 Timer Selection bits
11 = CCP1 is based off Timer5 in Capture/Compare mode and Timer6 in PWM mode
10 = CCP1 is based off Timer3 in Capture/Compare mode and Timer4 in PWM mode
01 = CCP1 is based off Timer1 in Capture/Compare mode and Timer2 in PWM mode
00 = Reserved

2016 Microchip Technology Inc. Preliminary DS40001816C-page 282


PIC18(L)F26/45/46K40

REGISTER 22-3: PWMxDCH: PWM DUTY CYCLE HIGH BITS


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
DCH<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 DCh<7:0>: PWM Duty Cycle Most Significant bits


These bits are the MSbs of the PWM duty cycle. The two LSbs are found in PWMxDCL Register.

REGISTER 22-4: PWMxDCL: PWM DUTY CYCLE LOW BITS


R/W-x/u R/W-x/u U-0 U-0 U-0 U-0 U-0 U-0
DCL<7:6>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 DC<8:9>: PWM Duty Cycle Least Significant bits


These bits are the LSbs of the PWM duty cycle. The MSbs are found in PWMxDCH Register.
bit 5-0 Unimplemented: Read as 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 283


PIC18(L)F26/45/46K40

TABLE 22-4: SUMMARY OF REGISTERS ASSOCIATED WITH PWM


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
CCPTMRS P4TSEL<1:0> P3TSEL<1:0> C2TSEL<1:0> C1TSEL<1:0> 282
PWM3CON EN OUT POL 281
PWM3DCH DC<7:0> 283
PWM3DCL DC<9:8>> 283
PWM4CON EN OUT POL 281
PWM4DCH DC<7:0> 283
PWM4DCL DC<9:8> 283
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE4 TMR6IE TMR5IE TMR4IE TMR3IE TMR2IE TMR1IE 182
PIR4 TMR6IF TMR5IF TMR4IF TMR3IF TMR2IF TMR1IF 174
IPR4 TMR6IP TMR5IP TMR4IP TMR3IP TMR2IP TMR1IP 190
RxyPPS RxyPPS<4:0> 217
TMR2 TMR2<7:0> 244
PR2 PR2<7:0> 244
T2CON T2ON T2CKPS<2:0> T2OUTPS<3:0> 245
T2HLT T2PSYNC T2CPOL T2CSYNC T2MODE<4:0> 246
T2CLKCON T2CS<3:0> 248
T2RST T2RSEL<3:0> 249
PMD3 PWM4MD PWM3MD CCP2MD CCP1MD 70
Legend: - = Unimplemented locations, read as 0, u = unchanged, x = unknown. Shaded cells are not used by the PWM.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 284


PIC18(L)F26/45/46K40
23.0 ZERO-CROSS DETECTION 23.1 External Resistor Selection
(ZCD) MODULE The ZCD module requires a current-limiting resistor in
The ZCD module detects when an A/C signal crosses series with the external voltage source. The impedance
through the ground potential. The actual zero crossing and rating of this resistor depends on the external
threshold is the zero crossing reference voltage, source peak voltage. Select a resistor value that will
VCPINV, which is typically 0.75V above ground. drop all of the peak voltage when the current through
the resistor is nominally 300 A. Refer to
The connection to the signal to be detected is through Equation 23-1 and Figure 23-1. Make sure that the
a series current-limiting resistor. The module applies a ZCD I/O pin internal weak pull-up is disabled so it does
current source or sink to the ZCD pin to maintain a not interfere with the current source and sink.
constant voltage on the pin, thereby preventing the pin
voltage from forward biasing the ESD protection
EQUATION 23-1: EXTERNAL RESISTOR
diodes. When the applied voltage is greater than the
reference voltage, the module sinks current. When the
applied voltage is less than the reference voltage, the V PEAK
module sources current. The current source and sink R SERIES = ----------------
4
-
action keeps the pin voltage constant over the full 3 10
range of the applied voltage. The ZCD module is
shown in the simplified block diagram Figure 23-2.
The ZCD module is useful when monitoring an A/C
waveform for, but not limited to, the following purposes: FIGURE 23-1: EXTERNAL VOLTAGE
A/C period measurement VMAXPEAK
Accurate long term time measurement VPEAK VMINPEAK
Dimmer phase delayed drive
Low EMI cycle switching
VCPINV

2016 Microchip Technology Inc. Preliminary DS40001816C-page 285


PIC18(L)F26/45/46K40
FIGURE 23-2: SIMPLIFIED ZCD BLOCK DIAGRAM

VPULLUP Rev. 10-000194B


5/14/2014

optional

VDD RPULLUP

- ZCDxIN RSERIES

External
Zcpinv + RPULLDOWN voltage
source

optional

ZCDx_output

D Q ZCDxOUT bit
ZCDxPOL
Q1

Interrupt
det
ZCDxINTP Set
ZCDIF
ZCDxINTN flag
Interrupt
det

2016 Microchip Technology Inc. Preliminary DS40001816C-page 286


PIC18(L)F26/45/46K40
23.2 ZCD Logic Output 23.5 Correcting for VCPINV offset
The ZCD module includes a Status bit, which can be The actual voltage at which the ZCD switches is the
read to determine whether the current source or sink is reference voltage at the non-inverting input of the ZCD
active. The ZCDOUT bit of the ZCDCON register is set op amp. For external voltage source waveforms other
when the current sink is active, and cleared when the than square waves, this voltage offset from zero
current source is active. The ZCDOUT bit is affected by causes the zero-cross event to occur either too early or
the polarity bit. too late. When the waveform is varying relative to VSS,
The ZCDOUT signal can also be used as input to other then the zero cross is detected too early as the
modules. This is controlled by the registers of the waveform falls and too late as the waveform rises.
corresponding module. ZCDOUT can be used as When the waveform is varying relative to VDD, then the
follows: zero cross is detected too late as the waveform rises
and too early as the waveform falls. The actual offset
Gate source for TMR1/3/5 time can be determined for sinusoidal waveforms with
Clock source for TMR2/4/6 the corresponding equations shown in Equation 23-2.
Reset source for TMR2/4/6
EQUATION 23-2: ZCD EVENT OFFSET
23.3 ZCD Logic Polarity
When External Voltage Source is relative to Vss:
The ZCDPOL bit of the ZCDCON register inverts the
ZCDOUT bit relative to the current source and sink
asin -------------------
output. When the ZCDPOL bit is set, a ZCDOUT high
V CPINV
indicates that the current source is active, and a low V PEAK
T OFFSET = -----------------------------------
output indicates that the current sink is active. 2 Freq
The ZCDPOL bit affects the ZCD interrupts.
When External Voltage Source is relative to VDD:
23.4 ZCD Interrupts

asin ---------------------------------
An interrupt will be generated upon a change in the V DD V CPINV
ZCD logic output when the appropriate interrupt V PEAK
enables are set. A rising edge detector and a falling T OFFSET = -------------------------------------------------
edge detector are present in the ZCD for this purpose. 2 Freq
The ZCDIF bit of the PIR2 register will be set when
either edge detector is triggered and its associated This offset time can be compensated for by adding a
enable bit is set. The ZCDINTP enables rising edge pull-up or pull-down biasing resistor to the ZCD pin. A
interrupts and the ZCDINTN bit enables falling edge pull-up resistor is used when the external voltage
interrupts. Both are located in the ZCDCON register. source is varying relative to VSS. A pull-down resistor is
Priority of the interrupt can be changed if the IPEN bit used when the voltage is varying relative to VDD. The
of the INTCON register is set. The ZCD interrupt can be resistor adds a bias to the ZCD pin so that the target
made high or low priority by setting or clearing the external voltage source must go to zero to pull the pin
ZCDIP bit of the IPR2 register. voltage to the VCPINV switching voltage. The pull-up or
To fully enable the interrupt, the following bits must be set: pull-down value can be determined with the equations
shown in Equation 23-3 or Equation 23-4.
ZCDIE bit of the PIE2 register
ZCDINTP bit of the ZCDCON register EQUATION 23-3: ZCD PULL-UP/DOWN
(for a rising edge detection)
ZCDINTN bit of the ZCDCON register When External Signal is relative to Vss:
(for a falling edge detection)
R SERIE S V PULLUP V CPINV
PEIE and GIE bits of the INTCON register R PULLUP = --------------------------------------------------------------------------
V CPINV
Changing the ZCDPOL bit will cause an interrupt,
regardless of the level of the ZCDSEN bit.
When External Signal is relative to VDD:
The ZCDIF bit of the PIR2 register must be cleared in
software as part of the interrupt service. If another edge R SERIES V CPINV
is detected while this flag is being cleared, the flag will
R PULLDOWN = ---------------------------------------------
V DD V CPINV
still be set at the end of the sequence.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 287


PIC18(L)F26/45/46K40
The pull-up and pull-down resistor values are 23.7 Operation During Sleep
significantly affected by small variations of VCPINV.
Measuring VCPINV can be difficult, especially when the The ZCD current sources and interrupts are unaffected
waveform is relative to VDD. However, by combining by Sleep.
Equations 23-2 and 23-3, the resistor value can be
determined from the time difference between the 23.8 Effects of a Reset
ZCD_output high and low periods. Note that the time
The ZCD circuit can be configured to default to the active
difference, T, is 4*TOFFSET. The equation for
or inactive state on Power-on-Reset (POR). When the
determining the pull-up and pull-down resistor values
ZCD Configuration bit is cleared, the ZCD circuit will be
from the high and low ZCD_output periods is shown in
active at POR. When the ZCD Configuration bit is set,
Equation 23-4.
the ZCDSEN bit of the ZCDCON register must be set to
enable the ZCD module.
EQUATION 23-4: PULL-UP/DOWN
RESISTOR VALUES
23.9 Disabling the ZCD Module
The ZCD module can be disabled in two ways:
V BI A S 1. Configuration Word 2H has the ZCD bit which
R = R SERIES ---------------------------------------------------------------- 1
V PE AK sin Freq ----------- T disables the ZCD module when set, but it can be
- enabled using the ZCDSEN bit of the ZCDCON
2
register (Register 23-1). If the ZCD bit is clear,
the ZCD is always enabled.
R is pull-up or pull-down resistor. 2. The ZCD can also be disabled using the
ZCDMD bit of the PMD2 register (Register 7-3).
VBIAS is VPULLUP when R is pull-up or VDD when R
This is subject to the status of the ZCD bit.
is pull-down.
T is the ZCDOUT high and low period difference.

23.6 Handling VPEAK Variations


If the peak amplitude of the external voltage is
expected to vary, the series resistor must be selected
to keep the ZCD current source and sink below the
design maximum range of 600 A and above a
reasonable minimum range. A general rule of thumb is
that the maximum peak voltage can be no more than
six times the minimum peak voltage. To ensure that the
maximum current does not exceed 600 A and the
minimum is at least 100 A, compute the series
resistance as shown in Equation 23-5. The
compensating pull-up for this series resistance can be
determined with Equation 23-3 because the pull-up
value is independent from the peak voltage.

EQUATION 23-5: SERIES R FOR V RANGE

V MAXPEAK + V MINPEAK
R SERIES = ---------------------------------------------------------
4
7 10

2016 Microchip Technology Inc. Preliminary DS40001816C-page 288


PIC18(L)F26/45/46K40
23.10 Register Definitions: ZCD Control

REGISTER 23-1: ZCDCON: ZERO-CROSS DETECT CONTROL REGISTER


R/W-0/0 U-0 R-x R/W-0/0 U-0 U-0 R/W-0/0 R/W-0/0
ZCDSEN ZCDOUT ZCDPOL ZCDINTP ZCDINTN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 ZCDSEN: Zero-Cross Detect Software Enable bit


This bit is ignored when ZCDSEN fuse is set.
1= Zero-cross detect is enabled. ZCD pin is forced to output to source and sink current.
0= Zero-cross detect is disabled. ZCD pin operates according to PPS and TRIS controls.
bit 6 Unimplemented: Read as 0
bit 5 ZCDOUT: Zero-Cross Detect Data Output bit
ZCDPOL bit = 0:
1 = ZCD pin is sinking current
0 = ZCD pin is sourcing current
ZCDPOL bit = 1:
1 = ZCD pin is sourcing current
0 = ZCD pin is sinking current
bit 4 ZCDPOL: Zero-Cross Detect Polarity bit
1 = ZCD logic output is inverted
0 = ZCD logic output is not inverted
bit 3-2 Unimplemented: Read as 0
bit 1 ZCDINTP: Zero-Cross Detect Positive-Going Edge Interrupt Enable bit
1 = ZCDIF bit is set on low-to-high ZCD_output transition
0 = ZCDIF bit is unaffected by low-to-high ZCD_output transition
bit 0 ZCDINTN: Zero-Cross Detect Negative-Going Edge Interrupt Enable bit
1 = ZCDIF bit is set on high-to-low ZCD_output transition
0 = ZCDIF bit is unaffected by high-to-low ZCD_output transition

2016 Microchip Technology Inc. Preliminary DS40001816C-page 289


PIC18(L)F26/45/46K40

TABLE 23-1: SUMMARY OF REGISTERS ASSOCIATED WITH THE ZCD MODULE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
PIE2 HLVDIE ZCDIE C2IE C1IE 180
PIR2 HLVDIF ZCDIF C2IF C1IF 172
IPR2 HLVDIP ZCDIP C2IP C1IP 188
ZCDCON ZCDSEN ZCDOUT ZCDPOL ZCDINTP ZCDINTN 289
PMD2 DACMD ADCMD CMP2MD CMP1MD ZCDMD 69
Legend: = unimplemented, read as 0. Shaded cells are unused by the ZCD module.

TABLE 23-2: SUMMARY OF CONFIGURATION WORD WITH THE ZCD MODULE


Register
Name Bits Bit 15/7 Bit 14/6 Bit 13/5 Bit 12/4 Bit 11/3 Bit 10/2 Bit 9/1 Bit 8/0
on Page
CONFIG2 15:8 XINST DEBUG STVREN PPS1WAY ZCD BORV1 BORV0 24
7:0 BOREN1 BOREN0 LPBOREN PWRTE MCLRE
Legend: = unimplemented location, read as 0. Shaded cells are not used by the ZCD module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 290


PIC18(L)F26/45/46K40
24.0 COMPLEMENTARY 24.2 Operating Modes
WAVEFORM GENERATOR The CWG module can operate in six different modes,
(CWG) MODULE as specified by the MODE<2:0> bits of the
CWG1CON0 register:
The Complementary Waveform Generator (CWG)
produces half-bridge, full-bridge, and steering of PWM Half-Bridge mode
waveforms. It is backwards compatible with previous Push-Pull mode
CCP functions. The PIC18(L)F2x/4xK40 family has Asynchronous Steering mode
one instance of the CWG module. Synchronous Steering mode
Full-Bridge mode, Forward
The CWG has the following features: Full-Bridge mode, Reverse
Six operating modes: All modes accept a single pulse data input, and
- Synchronous Steering mode provide up to four outputs as described in the following
- Asynchronous Steering mode sections.
- Full-Bridge mode, Forward All modes include auto-shutdown control as described
- Full-Bridge mode, Reverse in Section 24.10 Auto-Shutdown
- Half-Bridge mode
- Push-Pull mode Note: Except as noted for Full-bridge mode
Output polarity control (Section 24.2.3 Full-Bridge Modes),
Output steering mode changes should only be performed
Independent 6-bit rising and falling event dead- while EN = 0 (Register 24-1).
band timers
- Clocked dead band 24.2.1 HALF-BRIDGE MODE
- Independent rising and falling dead-band In Half-Bridge mode, two output signals are generated
enables as true and inverted versions of the input as illustrated
Auto-shutdown control with: in Figure 24-2. A non-overlap (dead-band) time is
inserted between the two outputs to prevent shoot
- Selectable shutdown sources
through current in various power supply applications.
- Auto-restart option Dead-band control is described in Section
- Auto-shutdown pin override control 24.6 Dead-Band Control. The output steering fea-
ture cannot be used in this mode. A basic block dia-
24.1 Fundamental Operation gram of this mode is shown in Figure 24-1.

The CWG generates two output waveforms from the The unused outputs CWG1C and CWG1D drive similar
selected input source. signals, with polarity independently controlled by the
POLC and POLD bits of the CWG1CON1 register,
The off-to-on transition of each output can be delayed respectively.
from the on-to-off transition of the other output, thereby,
creating a time delay immediately where neither output
is driven. This is referred to as dead time and is covered
in Section 24.6 Dead-Band Control.
It may be necessary to guard against the possibility of
circuit faults or a feedback event arriving too late or not
at all. In this case, the active drive must be terminated
before the Fault condition causes damage. This is
referred to as auto-shutdown and is covered in Section
24.10 Auto-Shutdown.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 291


PIC18(L)F26/45/46K40

FIGURE 24-1: SIMPLIFIED CWG BLOCK DIAGRAM (HALF-BRIDGE MODE, MODE<2:0> = 100)

LSAC<1:0> Rev. 10-000209C


8/7/2015

1 00
0 01
High-Z 10
11
Rising Dead-Band Block
CWG Clock clock 1
CWG Data A
data out
CWG Data data in 0 CWG1A
POLA

LSBD<1:0>

Falling Dead-Band Block 1 00


clock CWG Data B 0 01
data out
data in High-Z 10
11

CWG Data Input CWG 1


Data
0 CWG1B
POLB
D Q

E LSAC<1:0>

EN 1 00
0 01
High-Z 10
SHUTDOWN = 1
11
AS0E
PPS
CWG1PPS 1
Auto-
AS1E shutdown 0 CWG1C
POLC
TMR2_postscaled source

AS2E LSBD<1:0>
TMR4_postscaled

AS3E
TMR6_postscaled 1 00
0 01
AS4E
CMP1OUT High-Z 10

AS5E 11
S Q
CMP2OUT
R 1
0 CWG1D
REN POLD
SHUTDOWN = 0
SHUTDOWN

FREEZE
D Q

CWG Data

2016 Microchip Technology Inc. Preliminary DS40001816C-page 292


PIC18(L)F26/45/46K40
FIGURE 24-2: CWG1 HALF-BRIDGE MODE OPERATION

CWGx_clock

CWGxA
CWGxC
Rising Event Dead Band Rising Event D
Falling Event Dead Band Falling Event Dead Band
CWGxB
CWGxD

CWGx_data
Note: CWGx_rising_src = CCP1_out, CWGx_falling_src = ~CCP1_out

24.2.2 PUSH-PULL MODE


In Push-Pull mode, two output signals are generated,
alternating copies of the input as illustrated in
Figure 24-4. This alternation creates the push-pull
effect required for driving some transformer-based
power supply designs. Steering modes are not used in
Push-Pull mode. A basic block diagram for the
Push-Pull mode is shown in Figure 24-3.
The push-pull sequencer is reset whenever EN = 0 or
if an auto-shutdown event occurs. The sequencer is
clocked by the first input pulse, and the first output
appears on CWG1A.
The unused outputs CWG1C and CWG1D drive copies
of CWG1A and CWG1B, respectively, but with polarity
controlled by the POLC and POLD bits of the
CWG1CON1 register, respectively.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 293


PIC18(L)F26/45/46K40

FIGURE 24-3: SIMPLIFIED CWG BLOCK DIAGRAM (PUSH-PULL MODE, MODE<2:0> = 101)

LSAC<1:0>
Rev. 10-000210C
8/7/2015

1 00
0 01
High-Z 10
11

1
CWG Data CWG Data A
0 CWG1A
POLA

LSBD<1:0>
D Q

Q
1 00
0 01

High-Z 10

CWG Data B 11

1
CWG Data Input CWG 0 CWG1B
POLB
Data
D Q
LSAC<1:0>
E

1 00
EN 0 01
High-Z 10
11
SHUTDOWN = 1
AS0E 1
PPS
CWG1PPS 0 CWG1C
Auto- POLC
AS1E shutdown
TMR2_postscaled source
LSBD<1:0>
AS2E
TMR4_postscaled
1 00
AS3E
TMR6_postscaled 0 01
High-Z 10
AS4E
CMP1OUT 11
S Q
AS5E
CMP2OUT R 1
0 CWG1D
REN POLD
SHUTDOWN = 0
SHUTDOWN
FREEZE
D Q

CWG Data

2016 Microchip Technology Inc. Preliminary DS40001816C-page 294


PIC18(L)F26/45/46K40
FIGURE 24-4: CWG1 PUSH-PULL MODE OPERATION

CWG1
clock

Input
source

CWG1A

CWG1B

24.2.3 FULL-BRIDGE MODES


In Forward and Reverse Full-Bridge modes, three
outputs drive static values while the fourth is modulated
by the input data signal. The mode selection may be
toggled between forward and reverse by toggling the
MODE<0> bit of the CWG1CON0 while keeping
MODE<2:1> static, without disabling the CWG module.
When connected as shown in Figure 24-5, the outputs
are appropriate for a full-bridge motor driver. Each
CWG output signal has independent polarity control, so
the circuit can be adapted to high-active and low-active
drivers. A simplified block diagram for the Full-Bridge
modes is shown in Figure 24-6.

FIGURE 24-5: EXAMPLE OF FULL-BRIDGE APPLICATION


Rev. 10-000263A
12/8/2015

VDD

FET QA QC
FET
Driver Driver
CWG1A

CWG1B LOAD

CWG1C FET FET


Driver Driver

CWG1D QB QD

2016 Microchip Technology Inc. Preliminary DS40001816C-page 295


PIC18(L)F26/45/46K40

FIGURE 24-6: SIMPLIFIED CWG BLOCK DIAGRAM (FORWARD AND REVERSE FULL-BRIDGE
MODES)

MODE<2:0> = 010: Forward


Rev. 10-000212C
8/7/2015

LSAC<1:0>
MODE<2:0> = 011: Reverse

1 00
Rising Dead-Band Block 0 01
CWG Clock clock
signal out High-Z 10
signal in 11

CWG 1
CWG Data A
Data
MODE<2:0> 0 CWG1A
POLA
D Q
CWG Q LSBD<1:0>
Data

cwg data 1 00
signal in 0 01
signal out
CWG Clock clock High-Z 10

Falling Dead-Band Block 11

1
CWG Data Input CWG Data B
CWG Data
0 CWG1B
POLB
D Q

E LSAC<1:0>

1 00
EN
0 01
High-Z 10

SHUTDOWN = 1 11
AS0E
PPS CWG Data C
1
CWG1PPS 0 CWG1C
Auto-
POLC
AS1E shutdown
TMR2_postscaled source
LSBD<1:0>
AS2E
TMR4_postscaled

AS3E 1 00
TMR6_postscaled
0 01
AS4E High-Z 10
CMP1OUT
11
AS5E S Q
CMP2OUT
R
CWG Data D
1
0 CWG1D
REN POLD
SHUTDOWN = 0
SHUTDOWN

FREEZE
D Q

CWG Data

2016 Microchip Technology Inc. Preliminary DS40001816C-page 296


PIC18(L)F26/45/46K40
In Forward Full-Bridge mode (MODE<2:0> = 010), In Full-Bridge mode, the dead-band period is used
CWG1A is driven to its active state, CWG1B and when there is a switch from forward to reverse or vice-
CWG1C are driven to their inactive state, and CWG1D versa. This dead-band control is described in Section
is modulated by the input signal, as shown in 24.6 Dead-Band Control, with additional details in
Figure 24-7. Section 24.7 Rising Edge and Reverse Dead
In Reverse Full-Bridge mode (MODE<2:0> = 011), Band and Section 24.8 Falling Edge and Forward
CWG1C is driven to its active state, CWG1A and Dead Band. Steering modes are not used with either
CWG1D are driven to their inactive states, and CWG1B of the Full-Bridge modes. The mode selection may be
is modulated by the input signal, as shown in toggled between forward and reverse toggling the
Figure 24-7. MODE<0> bit of the CWG1CON0 while keeping
MODE<2:1> static, without disabling the CWG module.

FIGURE 24-7: EXAMPLE OF FULL-BRIDGE OUTPUT


Forward
Mode
Period

CWG1A(2)

CWG1B(2)

CWG1C(2)
Pulse Width

CWG1D(2)

(1) (1)

Reverse
Mode
Period

CWG1A(2)
Pulse Width

CWG1B(2)

CWG1C(2)

CWG1D(2)

(1) (1)

Note 1: A rising CWG data input creates a rising event on the modulated output.
2: Output signals shown as active-high; all POLy bits are clear.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 297


PIC18(L)F26/45/46K40
24.2.3.1 Direction Change in Full-Bridge The dead-band delay is inserted only when changing
Mode directions, and only the modulated output is affected.
The statically-configured outputs (CWG1A and
In Full-Bridge mode, changing MODE<2:0> controls
CWG1C) are not afforded dead band, and switch
the forward/reverse direction. Changes to MODE<2:0>
essentially simultaneously.
change to the new direction on the next rising edge of
the modulated input. Figure 24-8 shows an example of the CWG outputs
changing directions from forward to reverse, at near
A direction change is initiated in software by changing
100% duty cycle. In this example, at time t1, the output
the MODE<2:0> bits of the CWG1CON0 register. The
of CWG1A and CWG1D become inactive, while output
sequence is illustrated in Figure 24-8.
CWG1C becomes active. Since the turn-off time of the
The associated active output CWG1A and the power devices is longer than the turn-on time, a shoot-
inactive output CWG1C are switched to drive in through current will flow through power devices QC and
the opposite direction. QD for the duration of t. The same phenomenon will
The previously modulated output CWG1D is occur to power devices QA and QB for the CWG
switched to the inactive state, and the previously direction change from reverse to forward.
inactive output CWG1B begins to modulate.
When changing the CWG direction at high duty cycle is
CWG modulation resumes after the direction-
required for an application, two possible solutions for
switch dead band has elapsed.
eliminating the shoot-through current are:
24.2.3.2 Dead-Band Delay in Full-Bridge 1. Reduce the CWG duty cycle for one period
Mode before changing directions.
2. Use switch drivers that can drive the switches off
Dead-band delay is important when either of the
faster than they can drive them on.
following conditions is true:
1. The direction of the CWG output changes when
the duty cycle of the data input is at or near
100%, or
2. The turn-off time of the power switch, including
the power device and driver circuit, is greater
than the turn-on time.

FIGURE 24-8: EXAMPLE OF PWM DIRECTION CHANGE AT NEAR 100% DUTY CYCLE
t1
Forward Period Reverse Period

CWG1A

CWG1B Pulse Width

CWG1C

CWG1D Pulse Width


TON

External Switch C
TOFF

External Switch D

Potential Shoot- T = TOFF - TON


Through Current

2016 Microchip Technology Inc. Preliminary DS40001816C-page 298


PIC18(L)F26/45/46K40
24.2.4 STEERING MODES 24.2.4.1 Synchronous Steering Mode
In both Synchronous and Asynchronous Steering In Synchronous Steering mode (MODE<2:0>
modes, the modulated input signal can be steered to bits = 001, Register 24-1), changes to steering
any combination of four CWG outputs and a fixed-value selection registers take effect on the next rising edge of
will be presented on all the outputs not used for the the modulated data input (Figure 24-9). In
PWM output. Each output has independent polarity, Synchronous Steering mode, the output will always
steering, and shutdown options. Dead-band control is produce a complete waveform.
not used in either steering mode.
When STRx = 0 (Register 24-5), then the
corresponding pin is held at the level defined by DATx
(Register 24-5). When STRx = 1, then the pin is driven
by the modulated input signal.
The POLx bits (Register 24-2) control the signal
polarity only when STRx = 1.
The CWG auto-shutdown operation also applies to
steering modes as described in Section
24.14 Register Definitions: CWG Control.

Note: Only the STRx bits are synchronized; the


SDATx (data) bits are not synchronized.
The CWG auto-shutdown operation also applies in
Steering modes as described in Section 24.10 Auto-
Shutdown. An auto-shutdown event will only affect
pins that have STRx = 1.

FIGURE 24-9: EXAMPLE OF SYNCHRONOUS STEERING (MODE<2:0> = 001)

CWG1
clock

Input
source

CWG1A

CWG1B

2016 Microchip Technology Inc. Preliminary DS40001816C-page 299


PIC18(L)F26/45/46K40
24.2.4.2 Asynchronous Steering Mode
In Asynchronous mode (MODE<2:0> bits = 000,
Register 24-1), steering takes effect at the end of the
instruction cycle that writes to STR. In Asynchronous
Steering mode, the output signal may be an incomplete
waveform (Figure 24-10). This operation may be useful
when the user firmware needs to immediately remove
a signal from the output pin.

FIGURE 24-10: EXAMPLE OF ASYNCHRONOUS STEERING (MODE<2:0>= 000)

CWG1
INPUT
End of Instruction Cycle End of Instruction Cycle

STRA

CWG1A

CWG1A Follows CWG1 data input

24.2.4.3 Start-up Considerations


The application hardware must use the proper external
pull-up and/or pull-down resistors on the CWG output
pins. This is required because all I/O pins are forced to
high-impedance at Reset.
The POLy bits (Register 24-2) allow the user to choose
whether the output signals are active-high or active-
low.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 300


PIC18(L)F26/45/46K40

FIGURE 24-11: SIMPLIFIED CWG BLOCK DIAGRAM (OUTPUT STEERING MODES)

Rev. 10-000211C
8/7/2015

MODE<2:0> = 000: Asynchronous LSAC<1:0>


MODE<2:0> = 001: Synchronous

1 00
0 01
High-Z 10
11

CWG Data A 1
1
POLA 0 CWG1A
0
DATA

STRA LSBD<1:0>

1 00
0 01
CWG
CWG Data Data High-Z 10
Input
11

D Q CWG Data B
1
E 1
POLB 0 CWG1B
0
DATB
EN
STRB LSAC<1:0>

1 00
0 01
SHUTDOWN = 1
High-Z 10
AS0E
PPS 11
CWG1PPS
Auto-
AS1E shutdown CWG Data C 1
TMR2_postscaled source 1
POLC 0 CWG1C
AS2E 0
DATC
TMR4_postscaled
STRC LSBD<1:0>
AS3E
TMR6_postscaled

AS4E 1 00
CMP1OUT 0 01
AS5E High-Z 10
CMP2OUT
11
S Q
CWG Data D
R 1
1
POLD 0 CWG1D
REN 0
SHUTDOWN = 0 DATD
SHUTDOWN
STRD
FREEZE
D Q

CWG Data

2016 Microchip Technology Inc. Preliminary DS40001816C-page 301


PIC18(L)F26/45/46K40
24.3 Clock Source 24.5 Output Control
The clock source is used to drive the dead-band timing 24.5.1 CWG OUTPUTS
circuits. The CWG module allows the following clock
sources to be selected: Each CWG output can be routed to a Peripheral Pin
Select (PPS) output via the RxyPPS register (see Sec-
FOSC (system clock) tion 17.0 Peripheral Pin Select (PPS) Module).
HFINTOSC
When the HFINTOSC is selected, the HFINTOSC will 24.5.2 POLARITY CONTROL
be kept running during Sleep. Therefore, CWG modes The polarity of each CWG output can be selected inde-
requiring dead band can operate in Sleep, provided pendently. When the output polarity bit is set, the corre-
that the CWG data input is also active during Sleep.The sponding output is active-high. Clearing the output
clock sources are selected using the CS bit of the polarity bit configures the corresponding output as
CWG1CLKCON register (Register 24-3). The system active-low. However, polarity does not affect the over-
clock FOSC, is disabled in Sleep and thus dead-band ride levels. Output polarity is selected with the POLy
control cannot be used. bits of the CWG1CON1. Auto-shutdown and steering
options are unaffected by polarity.
24.4 Selectable Input Sources
The CWG generates the output waveforms from the 24.6 Dead-Band Control
input sources in Table 24-1. The dead-band control provides non-overlapping PWM
signals to prevent shoot-through current in PWM
TABLE 24-1: SELECTABLE INPUT switches. Dead-band operation is employed for Half-
Bridge and Full-Bridge modes. The CWG contains two
SOURCES
6-bit dead-band counters. One is used for the rising
Source edge of the input source control in Half-Bridge mode or
Signal Name ISM<2:0>
Peripheral for reverse dead-band Full-Bridge mode. The other is
Pin selected by used for the falling edge of the input source control in
CWG1PPS CWG1PPS
000 Half-Bridge mode or for forward dead band in Full-
Bridge mode.
CCP1 CCP1 Output 001
Dead band is timed by counting CWG clock periods
CCP2 CCP2 Output 010 from zero up to the value in the rising or falling dead-
PWM3 PWM3 Output 011 band counter registers. See CWG1DBR and
PWM4 PWM4 Output 100 CWG1DBF registers, respectively.

CMP1 Comparator 1 Output 101 24.6.1 DEAD-BAND FUNCTIONALITY IN


CMP2 Comparator 2 Output 110 HALF-BRIDGE MODE
Data signal modulator In Half-Bridge mode, the dead-band counters dictate
DSM 111
output the delay between the falling edge of the normal output
and the rising edge of the inverted output. This can be
The input sources are selected using the ISM<2:0> bits
seen in Figure 24-2.
in the CWG1ISM register (Register 24-4).
24.6.2 DEAD-BAND FUNCTIONALITY IN
FULL-BRIDGE MODE
In Full-Bridge mode, the dead-band counters are used
when undergoing a direction change. The MODE<0>
bit of the CWG1CON0 register can be set or cleared
while the CWG is running, allowing for changes from
Forward to Reverse mode. The CWG1A and CWG1C
signals will change immediately upon the first rising
input edge following a direction change, but the modu-
lated signals (CWG1B or CWG1D, depending on the
direction of the change) will experience a delay dictated
by the dead-band counters.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 302


PIC18(L)F26/45/46K40
24.7 Rising Edge and Reverse Dead
Band
In Half-Bridge mode, the rising edge dead band delays
the turn-on of the CWG1A output after the rising edge
of the CWG data input. In Full-Bridge mode, the
reverse dead-band delay is only inserted when
changing directions from Forward mode to Reverse
mode, and only the modulated output CWG1B is
affected.
The CWG1DBR register determines the duration of the
dead-band interval on the rising edge of the input
source signal. This duration is from 0 to 64 periods of
the CWG clock.
Dead band is always initiated on the edge of the input
source signal. A count of zero indicates that no dead
band is present.
If the input source signal reverses polarity before the
dead-band count is completed, then no signal will be
seen on the respective output.
The CWG1DBR register value is double-buffered.
When EN = 0 (Register 24-1), the buffer is loaded
when CWG1DBR is written. If EN = 1, then the buffer
will be loaded at the rising edge following the first falling
edge of the data input, after the LD bit (Register 24-1)
is set. Refer to Figure 24-12 for an example.

24.8 Falling Edge and Forward Dead


Band
In Half-Bridge mode, the falling edge dead band delays
the turn-on of the CWG1B output at the falling edge of
the CWG data input. In Full-Bridge mode, the forward
dead-band delay is only inserted when changing direc-
tions from Reverse mode to Forward mode, and only
the modulated output CWG1D is affected.
The CWG1DBF register determines the duration of the
dead-band interval on the falling edge of the input
source signal. This duration is from zero to 64 periods
of CWG clock.
Dead-band delay is always initiated on the edge of the
input source signal. A count of zero indicates that no
dead band is present.
If the input source signal reverses polarity before the
dead-band count is completed, then no signal will be
seen on the respective output.
The CWG1DBF register value is double-buffered.
When EN = 0 (Register 24-1), the buffer is loaded
when CWG1DBF is written. If EN = 1, then the buffer
will be loaded at the rising edge following the first
falling edge of the data input after the LD (Register 24-
1) is set. Refer to Figure 24-13 for an example.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 303


FIGURE 24-12: DEAD-BAND OPERATION, CWG1DBR = 0x01, CWG1DBF = 0x02
2016 Microchip Technology Inc.

cwg_clock

Input Source

CWGxA

CWGxB
Preliminary

FIGURE 24-13: DEAD-BAND OPERATION, CWG1DBR = 0x03, CWG1DBF = 0x06, SOURCE SHORTER THAN DEAD BAND

PIC18(L)F26/45/46K40
cwg_clock

Input Source

CWGxA
DS40001816C-page 304

CWGxB

source shorter than dead band


PIC18(L)F26/45/46K40
24.9 Dead-Band Jitter
When the rising and falling edges of the input source
are asynchronous to the CWG clock, it creates jitter in
the dead-band time delay. The maximum jitter is equal
to one CWG clock period. Refer to Equation 24-1 for
more details.

EQUATION 24-1: DEAD-BAND DELAY TIME


CALCULATION
1
T = ------------------------------------------ DBx 4: 0>
DEAD BAND_MIN F
CWG CLOCK
1
T = ------------------------------------------ DBx 4: 0>+1
DEAD BANDMAX F
CWG CLOCK

T
JITTER
= T
DEAD BAND _ MAX
TDEAD BAND _ MIN
1
T = --------------------------------------------
JITTER F
CWG _ CLOCK
T = T +T
DEAD BAND _ MAX DEAD BAND _ MIN JITTER

EXAMPLE

DBR<4:0> = 0x0A = 10

F = 8 MHz
CWG_CLOCK
1
T = ---------------- = 125 ns
JITTER 8MHz
T = 125 ns*10 = 125 s
DEAD BAND_MIN

T = 1.25 s + 0.125s = 1.37s


DEAD BAND_MAX

2016 Microchip Technology Inc. Preliminary DS40001816C-page 305


PIC18(L)F26/45/46K40
24.10 Auto-Shutdown 24.10.1.3 Pin Override Levels
Auto-shutdown is a method to immediately override the The levels driven to the CWG outputs during an auto-
CWG output levels with specific overrides that allow for shutdown event are controlled by the LSBD<1:0> and
safe shutdown of the circuit. The shutdown state can be LSAC<1:0> bits of the CWG1AS0 register
either cleared automatically or held until cleared by (Register 24-6). The LSBD<1:0> bits control CWG1B/
software. The auto-shutdown circuit is illustrated in D output levels, while the LSAC<1:0> bits control the
Figure 24-14. CWG1A/C output levels.

24.10.1 SHUTDOWN 24.10.1.4 Auto-Shutdown Interrupts


The shutdown state can be entered by either of the When an auto-shutdown event occurs, either by soft-
following two methods: ware or hardware setting SHUTDOWN, the CWG1IF
flag bit of the PIR7 register is set (Register 14-5).
Software generated
External Input 24.11 Auto-Shutdown Restart
24.10.1.1 Software Generated Shutdown After an auto-shutdown event has occurred, there are
Setting the SHUTDOWN bit of the CWG1AS0 register two ways to resume operation:
will force the CWG into the shutdown state. Software controlled
When the auto-restart is disabled, the shutdown state Auto-restart
will persist as long as the SHUTDOWN bit is set. In either case, the shut-down source must be cleared
before the restart can take place. That is, either the
When auto-restart is enabled, the SHUTDOWN bit will
shutdown condition must be removed, or the
clear automatically and resume operation on the next
corresponding ASxE bit must be cleared.
rising edge event. The SHUTDOWN bit indicates when
a shutdown condition exists. The bit may be set or
24.11.1 SOFTWARE-CONTROLLED
cleared in software or by hardware.
RESTART
24.10.1.2 External Input Source If the REN bit of the CWG1AS0 register is clear
External shutdown inputs provide the fastest way to safely (REN = 0), the CWG module must be restarted after an
suspend CWG operation in the event of a Fault condition. auto-shutdown event through software.
When any of the selected shutdown inputs goes active, Once all auto-shutdown sources are removed, the
the CWG outputs will immediately go to the selected over- software must clear SHUTDOWN. Once SHUTDOWN
ride levels without software delay. The override levels are is cleared, the CWG module will resume operation
selected by the LSBD<1:0> and LSAC<1:0> bits of the upon the first rising edge of the CWG data input.
CWG1AS0 register (Register 24-6). Several input
sources can be selected to cause a shutdown condition.
All input sources are active-low. The sources are: Note: The SHUTDOWN bit cannot be cleared in
software if the auto-shutdown condition is
Pin selected by CWG1PPS still present.
Timer2 post-scaled output
Timer4 post-scaled output 24.11.2 AUTO-RESTART
Timer6 post-scaled output If the REN bit of the CWG1AS0 register is set (REN = 1),
Comparator 1 output the CWG module will restart from the shutdown state
Comparator 2 output automatically.
Shutdown input sources are individually enabled by the Once all auto-shutdown conditions are removed, the
ASxE bits of the CWG1AS1 register (Register 24-7). hardware will automatically clear SHUTDOWN. Once
SHUTDOWN is cleared, the CWG module will resume
Note: Shutdown inputs are level sensitive, not operation upon the first rising edge of the CWG data
edge sensitive. The shutdown state can- input.
not be cleared, except by disabling auto-
shutdown, as long as the shutdown input
level persists. Note: The SHUTDOWN bit cannot be cleared in
software if the auto-shutdown condition is
still present.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 306


PIC18(L)F26/45/46K40
24.12 Operation During Sleep 24.13 Configuring the CWG
The CWG module operates independently from the 1. Ensure that the TRIS control bits corresponding
system clock and will continue to run during Sleep, to CWG outputs are set so that all are
provided that the clock and input sources selected configured as inputs, ensuring that the outputs
remain active. are inactive during setup. External hardware
The HFINTOSC remains active during Sleep when all should ensure that pin levels are held to safe
the following conditions are met: levels.
2. Clear the EN bit, if not already cleared.
CWG module is enabled
3. Configure the MODE<2:0> bits of the
Input source is active CWG1CON0 register to set the output operating
HFINTOSC is selected as the clock source, mode.
regardless of the system clock source selected. 4. Configure the POLy bits of the CWG1CON1
In other words, if the HFINTOSC is simultaneously register to set the output polarities.
selected as the system clock and the CWG clock 5. Configure the ISM<2:0> bits of the CWG1ISM
source, when the CWG is enabled and the input source register to select the data input source.
is active, then the CPU will go idle during Sleep, but the 6. If a steering mode is selected, configure the
HFINTOSC will remain active and the CWG will con- STRx bits to select the desired output on the
tinue to operate. This will have a direct effect on the CWG outputs.
Sleep mode current. 7. Configure the LSBD<1:0> and LSAC<1:0> bits
of the CWG1ASD0 register to select the auto-
shutdown output override states (this is
necessary even if not using auto-shutdown
because start-up will be from a shutdown state).
8. If auto-restart is desired, set the REN bit of
CWG1AS0.
9. If auto-shutdown is desired, configure the ASxE
bits of the CWG1AS1 register to select the shut-
down source.
10. Set the desired rising and falling dead-band
times with the CWG1DBR and CWG1DBF
registers.
11. Select the clock source in the CWG1CLKCON
register.
12. Set the EN bit to enable the module.
13. Clear the TRIS bits that correspond to the CWG
outputs to set them as outputs.
If auto-restart is to be used, set the REN bit and the
SHUTDOWN bit will be cleared automatically. Other-
wise, clear the SHUTDOWN bit in software to start the
CWG.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 307


FIGURE 24-14: CWG SHUTDOWN BLOCK DIAGRAM
2016 Microchip Technology Inc.

Write 1 to Rev. 10-000172C


8/7/2015

SHUTDOWN bit
PPS
AS0E
CWGxINPPS
C1OUT_sync
AS4E
C2OUT_sync
AS5E
TMR2_postscaled SHUTDOWN S
S Q
AS1E D Q CWG_shutdown
TMR4_postscaled
REN FREEZE
R
AS2E Write 0 to
SHUTDOWN bit
TMR6_postscaled CWG_data CK
AS3E

FIGURE 24-15: SHUTDOWN FUNCTIONALITY, AUTO-RESTART DISABLED (REN = 0, LSAC = 01, LSBD = 01)
Preliminary

Shutdown Event Ceases REN Cleared by Software

PIC18(L)F26/45/46K40
CWG Input
Source

Shutdown Source

SHUTDOWN

CWG1A Tri-State (No Pulse)


CWG1C

CWG1B Tri-State (No Pulse)


CWG1D
No Shutdown
Shutdown Output Resumes
DS40001816C-page 308
FIGURE 24-16: SHUTDOWN FUNCTIONALITY, AUTO-RESTART ENABLED (REN = 1, LSAC = 01, LSBD = 01)
2016 Microchip Technology Inc.

Shutdown Event Ceases REN auto-cleared by hardware

CWG Input
Source

Shutdown Source

SHUTDOWN

CWG1A Tri-State (No Pulse)


CWG1C

CWG1B Tri-State (No Pulse)


CWG1D
No Shutdown
Shutdown Output Resumes
Preliminary

PIC18(L)F26/45/46K40
DS40001816C-page 309
PIC18(L)F26/45/46K40
24.14 Register Definitions: CWG Control
Long bit name prefixes for the CWG peripheral is
shown in Table 24-2. Refer to Section 1.4.2.2 Long
Bit Names for more information.
TABLE 24-2:
Peripheral Bit Name Prefix
CWG CWG

l
REGISTER 24-1: CWG1CON0: CWG CONTROL REGISTER 0
R/W-0/0 R/W/HC-0/0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
EN LD(1) MODE<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 EN: CWG1 Enable bit


1 = Module is enabled
0 = Module is disabled
bit 6 LD: CWG1 Load Buffers bit(1)
1 = Dead-band count buffers to be loaded on CWG data rising edge, following first falling edge after
this bit is set
0 = Buffers remain unchanged
bit 5-3 Unimplemented: Read as 0
bit 2-0 MODE<2:0>: CWG1 Mode bits
111 = Reserved
110 = Reserved
101 = CWG outputs operate in Push-Pull mode
100 = CWG outputs operate in Half-Bridge mode
011 = CWG outputs operate in Reverse Full-Bridge mode
010 = CWG outputs operate in Forward Full-Bridge mode
001 = CWG outputs operate in Synchronous Steering mode
000 = CWG outputs operate in Asynchronous Steering mode

Note 1: This bit can only be set after EN = 1; it cannot be set in the same cycle when EN is set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 310


PIC18(L)F26/45/46K40

REGISTER 24-2: CWG1CON1: CWG CONTROL REGISTER 1


U-0 U-0 R-x U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
IN POLD POLC POLB POLA
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-6 Unimplemented: Read as 0


bit 5 IN: CWG Input Value bit (read-only)
bit 4 Unimplemented: Read as 0
bit 3 POLD: CWG1D Output Polarity bit
1 = Signal output is inverted polarity
0 = Signal output is normal polarity
bit 2 POLC: CWG1C Output Polarity bit
1 = Signal output is inverted polarity
0 = Signal output is normal polarity
bit 1 POLB: CWG1B Output Polarity bit
1 = Signal output is inverted polarity
0 = Signal output is normal polarity
bit 0 POLA: CWG1A Output Polarity bit
1 = Signal output is inverted polarity
0 = Signal output is normal polarity

2016 Microchip Technology Inc. Preliminary DS40001816C-page 311


PIC18(L)F26/45/46K40

REGISTER 24-3: CWG1CLKCON: CWG1 CLOCK INPUT SELECTION REGISTER


U-0 U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0
CS
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-1 Unimplemented: Read as 0


bit 0 CS: CWG Clock Source Selection Select bits

CS Clock Source
1 HFINTOSC (remains operating during Sleep)
0 FOSC

REGISTER 24-4: CWG1ISM: CWGx INPUT SELECTION REGISTER


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
ISM<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-3 Unimplemented Read as 0


bit 2-0 ISM<2:0>: CWG Data Input Selection Multiplexer Select bits

ISM<2:0> Input Source


111 DSM OUT
110 CMP2 OUT
101 CMP1 OUT
100 PWM4 OUT
011 PWM3 OUT
010 CCP2 OUT
001 CCP1 OUT
000 Pin selected by CWG1PPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 312


PIC18(L)F26/45/46K40
REGISTER 24-5: CWG1STR(1): CWG STEERING CONTROL REGISTER
R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
OVRD OVRC OVRB OVRA STRD(2) STRC(2) STRB(2) STRA(2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 OVRD: Steering Data D bit


bit 6 OVRC: Steering Data C bit
bit 5 OVRB: Steering Data B bit
bit 4 OVRA: Steering Data A bit
bit 3 STRD: Steering Enable bit D(2)
1 = CWG1D output has the CWG data input waveform with polarity control from POLD bit
0 = CWG1D output is assigned to value of OVRD bit
bit 2 STRC: Steering Enable bit C(2)
1 = CWG1C output has the CWG data input waveform with polarity control from POLC bit
0 = CWG1C output is assigned to value of OVRC bit
bit 1 STRB: Steering Enable bit B(2)
1 = CWG1B output has the CWG data input waveform with polarity control from POLB bit
0 = CWG1B output is assigned to value of OVRB bit
bit 0 STRA: Steering Enable bit A(2)
1 = CWG1A output has the CWG data input waveform with polarity control from POLA bit
0 = CWG1A output is assigned to value of OVRA bit

Note 1: The bits in this register apply only when MODE<2:0> = 00x (Register 24-1, Steering modes).
2: This bit is double-buffered when MODE<2:0> = 001.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 313


PIC18(L)F26/45/46K40
REGISTER 24-6: CWG1AS0: CWG AUTO-SHUTDOWN CONTROL REGISTER 0
R/W/HS/HC-0/0 R/W-0/0 R/W-0/0 R/W-1/1 R/W-0/0 R/W-1/1 U-0 U-0
SHUTDOWN REN LSBD<1:0> LSAC<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HS/HC = Bit is set/cleared by hardware
q = Value depends on condition

bit 7 SHUTDOWN: Auto-Shutdown Event Status bit(1,2)


1 = An auto-shutdown state is in effect
0 = No auto-shutdown event has occurred
bit 6 REN: Auto-Restart Enable bit
1 = Auto-restart is enabled
0 = Auto-restart is disabled
bit 5-4 LSBD<1:0>: CWG1B and CWG1D Auto-Shutdown State Control bits
11 = A logic 1 is placed on CWG1B/D when an auto-shutdown event occurs.
10 = A logic 0 is placed on CWG1B/D when an auto-shutdown event occurs.
01 = Pin is tri-stated on CWG1B/D when an auto-shutdown event occurs.
00 = The inactive state of the pin, including polarity, is placed on CWG1B/D after the required
dead-band interval when an auto-shutdown event occurs.
bit 3-2 LSAC<1:0>: CWG1A and CWG1C Auto-Shutdown State Control bits
11 = A logic 1 is placed on CWG1A/C when an auto-shutdown event occurs.
10 = A logic 0 is placed on CWG1A/C when an auto-shutdown event occurs.
01 = Pin is tri-stated on CWG1A/C when an auto-shutdown event occurs.
00 = The inactive state of the pin, including polarity, is placed on CWG1A/C after the required
dead-band interval when an auto-shutdown event occurs.
bit 1-0 Unimplemented: Read as 0

Note 1: This bit may be written while EN = 0 (Register 24-1), to place the outputs into the shutdown configuration.
2: The outputs will remain in auto-shutdown state until the next rising edge of the CWG data input after this
bit is cleared.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 314


PIC18(L)F26/45/46K40

REGISTER 24-7: CWG1AS1: CWG AUTO-SHUTDOWN CONTROL REGISTER 1


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
AS5E AS4E AS3E AS2E AS1E AS0E
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-6 Unimplemented Read as 0


bit 5 AS5E: CWG Auto-shutdown Source 5 (CMP2 OUT) Enable bit
1 = Auto-shutdown for CMP2 OUT is enabled
0 = Auto-shutdown for CMP2 OUT is disabled
bit 4 AS4E: CWG Auto-shutdown Source 4 (CMP1 OUT) Enable bit
1 = Auto-shutdown for CMP1 OUT is enabled
0 = Auto-shutdown for CMP1 OUT is disabled
bit 3 AS3E: CWG Auto-shutdown Source 3 (TMR6_Postscaled) Enable bit
1 = Auto-shutdown for TMR6_Postscaled is enabled
0 = Auto-shutdown for TMR6_Postscaled is disabled
bit 2 AS2E: CWG Auto-shutdown Source 2 (TMR4_Postscaled) Enable bit
1 = Auto-shutdown for TMR4_Postscaled is enabled
0 = Auto-shutdown for TMR4_Postscaled is disabled
bit 1 AS1E: CWG Auto-shutdown Source 1 (TMR2_Postscaled) Enable bit
1 = Auto-shutdown for TMR2_Postscaled is enabled
0 = Auto-shutdown for TMR2_Postscaled is disabled
bit 0 AS0E: CWG Auto-shutdown Source 0 (Pin selected by CWG1PPS) Enable bit
1 = Auto-shutdown for CWG1PPS Pin is enabled
0 = Auto-shutdown for CWG1PPS Pin is disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 315


PIC18(L)F26/45/46K40

REGISTER 24-8: CWG1DBR: CWG RISING DEAD-BAND COUNT REGISTER


U-0 U-0 R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
DBR<5:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-6 Unimplemented: Read as 0


bit 5-0 DBR<5:0>: CWG Rising Edge Triggered Dead-Band Count bits
11 1111 = 63-64 CWG clock periods
11 1110 = 62-63 CWG clock periods
.
.
.
00 0010 = 2-3 CWG clock periods
00 0001 = 1-2 CWG clock periods
00 0000 = 0 CWG clock periods. Dead-band generation is bypassed

REGISTER 24-9: CWG1DBF: CWG FALLING DEAD-BAND COUNT REGISTER


U-0 U-0 R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
DBF<5:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7-6 Unimplemented: Read as 0


bit 5-0 DBF<5:0>: CWG Falling Edge Triggered Dead-Band Count bits
11 1111 = 63-64 CWG clock periods
11 1110 = 62-63 CWG clock periods
.
.
.
00 0010 = 2-3 CWG clock periods
00 0001 = 1-2 CWG clock periods
00 0000 = 0 CWG clock periods. Dead-band generation is bypassed.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 316


PIC18(L)F26/45/46K40

TABLE 24-3: SUMMARY OF REGISTERS ASSOCIATED WITH CWG


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
CWG1CON0 EN LD MODE<2:0> 310
CWG1CON1 IN POLD POLC POLB POLA 311
CWG1CLKCON CS 312
CWG1ISM ISM<2:0> 312
CWG1STR OVRD OVRC OVRB OVRA STRD STRC STRB STRA 313
CWG1AS0 SHUTDOWN REN LSBD<1:0> LSAC<1:0> 314
CWG1AS1 AS5E AS4E AS3E AS2E AS1E AS0E 315
CWG1DBR DBR<5:0> 316
CWG1DBF DBF<5:0> 316
PIE7 SCANIE CRCIE NVMIE CWG1IE 185
PIR7 SCANIF CRCIF NVMIF CWG1IF 177
IPR7 SCANIP CRCIP NVMIP CWG1IP 193
PMD4 UART2MD UART1MD MSSP2MD MSSP1MD CWG1MD 71
Legend: = unimplemented locations read as 0. Shaded cells are not used by CWG.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 317


PIC18(L)F26/45/46K40
25.0 DATA SIGNAL MODULATOR
(DSM) MODULE
The Data Signal Modulator (DSM) is a peripheral which
allows the user to mix a data stream, also known as a
modulator signal, with a carrier signal to produce a
modulated output.
Both the carrier and the modulator signals are supplied
to the DSM module either internally, from the output of
a peripheral, or externally through an input pin.
The modulated output signal is generated by
performing a logical AND operation of both the carrier
and modulator signals and then provided to the MDOUT
pin.
The carrier signal is comprised of two distinct and
separate signals. A carrier high (CARH) signal and a
carrier low (CARL) signal. During the time in which the
modulator (MOD) signal is in a logic high state, the
DSM mixes the carrier high signal with the modulator
signal. When the modulator signal is in a logic low
state, the DSM mixes the carrier low signal with the
modulator signal.
Using this method, the DSM can generate the following
types of Key Modulation schemes:
Frequency-Shift Keying (FSK)
Phase-Shift Keying (PSK)
On-Off Keying (OOK)
Additionally, the following features are provided within
the DSM module:
Carrier Synchronization
Carrier Source Polarity Select
Programmable Modulator Data
Modulated Output Polarity Select
Peripheral Module Disable, which provides the
ability to place the DSM module in the lowest
power consumption mode
Figure 25-1 shows a Simplified Block Diagram of the
Data Signal Modulator peripheral.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 318


PIC18(L)F26/45/46K40
FIGURE 25-1: SIMPLIFIED BLOCK DIAGRAM OF THE DATA SIGNAL MODULATOR

MDCHS<2:0> Rev. 10-000248E


8/7/2015

Data Signal Modulator


000

See
MDCARH CARH
Register

MDCHPOL D
111 SYNC
Q

MDSRCS<3:0> 1
0

0000

MDCHSYNC
RxyPPS
See MOD
MDSRC
PPS
Register

MDOPOL
1111

MDCLS<2:0>
D
SYNC
000 Q

1
0
See
MDCARL CARL
Register MDCLSYNC

MDCLPOL
111

2016 Microchip Technology Inc. Preliminary DS40001816C-page 319


PIC18(L)F26/45/46K40
25.1 Register Definitions: Modulation Control
Long bit name prefixes for the Modulation peripheral is
shown in Table 25-1. Refer to Section 1.4.2.2 Long
Bit Names for more information.
TABLE 25-1:
Peripheral Bit Name Prefix
MD MD

REGISTER 25-1: MDCON0: MODULATION CONTROL REGISTER 0


R/W-0/0 U-0 R/W-0/0 R/W-0/0 U-0 U-0 U-0 R/W-0/0
EN OUT OPOL BIT
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EN: Modulator Module Enable bit


1 = Modulator module is enabled and mixing input signals
0 = Modulator module is disabled and has no output
bit 6 Unimplemented: Read as 0
bit 5 OUT: Modulator Output bit
Displays the current output value of the Modulator module.(1)
bit 4 OPOL: Modulator Output Polarity Select bit
1 = Modulator output signal is inverted; idle high output
0 = Modulator output signal is not inverted; idle low output
bit 3-1 Unimplemented: Read as 0
bit 0 BIT: Allows software to manually set modulation source input to module(2)

Note 1: The modulated output frequency can be greater and asynchronous from the clock that updates this
register bit, the bit value may not be valid for higher speed modulator or carrier signals.
2: MDBIT must be selected as the modulation source in the MDSRC register for this operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 320


PIC18(L)F26/45/46K40

REGISTER 25-2: MDCON1: MODULATION CONTROL REGISTER 1


U-0 U-0 R/W-0/0 R/W-0/0 U-0 U-0 R/W-0/0 R/W-0/0
CHPOL CHSYNC CLPOL CLSYNC
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5 CHPOL: Modulator High Carrier Polarity Select bit
1 = Selected high carrier signal is inverted
0 = Selected high carrier signal is not inverted
bit 4 CHSYNC: Modulator High Carrier Synchronization Enable bit
1 = Modulator waits for a falling edge on the high time carrier signal before allowing a switch to the
low time carrier
0 = Modulator output is not synchronized to the high time carrier signal(1)
bit 3-2 Unimplemented: Read as 0
bit 1 CLPOL: Modulator Low Carrier Polarity Select bit
1 = Selected low carrier signal is inverted
0 = Selected low carrier signal is not inverted
bit 0 CLSYNC: Modulator Low Carrier Synchronization Enable bit
1 = Modulator waits for a falling edge on the low time carrier signal before allowing a switch to the high
time carrier
0 = Modulator output is not synchronized to the low time carrier signal(1)
Note 1:Narrowed carrier pulse widths or spurs may occur in the signal stream if the carrier is not synchronized.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 321


PIC18(L)F26/45/46K40

REGISTER 25-3: MDCARH: MODULATION HIGH CARRIER CONTROL REGISTER


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
(1)
CHS<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-3 Unimplemented: Read as 0


bit 2-0 CHS<2:0>: Modulator Carrier High Selection bits(1)
See Table 25-2 for signal list

Note 1:Unused selections provide an input value.

REGISTER 25-4: MDCARL: MODULATION LOW CARRIER CONTROL REGISTER


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
CLS<2:0>(1)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-3 Unimplemented: Read as 0


bit 2-0 CLS<2:0>: Modulator Carrier Low Input Selection bits(1)
See Table 25-2 for signal list

Note 1:Unused selections provide a zero as the input value.

TABLE 25-2: MDCARH/MDCARL SELECTION MUX CONNECTIONS


MDCARH MDCARL

CHS<2:0> Connection CLS<2:0> Connection


111 7 PWM4 OUT 111 7 PWM4 OUT
110 6 PWM3 OUT 110 6 PWM3 OUT
101 5 CCP2 OUT 101 5 CCP2 OUT
100 4 CCP1 OUT 100 4 CCP1 OUT
011 3 CLKREF output 011 3 CLKREF output
010 2 HFINTOSC 010 2 HFINTOSC
001 1 FOSC (system clock) 001 1 FOSC (system clock)
000 0 Pin selected by MDCARHPPS 000 0 Pin selected by MDCARLPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 322


PIC18(L)F26/45/46K40

REGISTER 25-5: MDSRC: MODULATION SOURCE CONTROL REGISTER


U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
SRCS<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-4 Unimplemented: Read as 0


bit 3-0 SRCS<3:0>: Modulator Source Selection bits(1)
See Table 25-3 for signal list

Note 1:Unused selections provide a zero as the input value.

TABLE 25-3: MDSRC SELECTION MUX


CONNECTIONS
MDSRCS<3:0> Connection
1111-1110 Reserved
1101 13 MSSP2 SDO
1100 12 MSSP1 SDO
1011 11 EUSART2 TX (TX/CK output)
1010 10 EUSART2 RX (DT output)
1001 9 EUSART1 TX (TX/CK output)
1000 8 EUSART1 RX (DT output)
0111 7 CMP2 OUT
0110 6 CMP1 OUT
0101 5 PWM4 OUT
0100 4 PWM3 OUT
0011 3 CCP2 OUT
0010 2 CCP1 OUT
0001 1 MDBIT
0000 0 Pin selected by MDSRCPPS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 323


PIC18(L)F26/45/46K40
TABLE 25-4: SUMMARY OF REGISTERS ASSOCIATED WITH DATA SIGNAL MODULATOR MODE
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
MDCON0 EN OUT OPOL BIT 320
MDCON1 CHPOL CHSYNC CLPOL CLSYNC 321
MDCARH CHS<2:0> 322
MDCARL CLS<2:0> 322
MDSRC SRCS<3:0> 323
MDCARLPPS CARLPPS<4:0> 215
MDCARHPPS CARHPPS<4:0> 215
MDSRCPPS SRCPPS<4:0> 215
RxyPPS RxyPPS<4:0> 217
PMD5 DSMMD 72
Legend: = unimplemented, read as 0. Shaded cells are not used in the Data Signal Modulator mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 324


PIC18(L)F26/45/46K40
25.2 DSM Operation 25.4 Carrier Signal Sources
The DSM module can be enabled by setting the MDEN The carrier high signal and carrier low signal can be
bit in the MDCON0 register. Clearing the MDEN bit in supplied from the following sources:
the MDCON0 register, disables the DSM module out- External signal on pin selected by MDCARHPPS/
put and switches the carrier high and carrier low signals MDCARLPPS
to the default option of MDCARHPPS and
FOSC (system clock)
MDCARLPPS, respectively. The modulator signal
source is also switched to the MDBIT in the MDCON0 HFINTOSC
register. This not only assures that the DSM module is Reference Clock Module Signal
inactive, but that it is also consuming the least amount CCP1/2 Output Signal
of current. PWM3/4 Output
The values used to select the carrier high, carrier low, The carrier high signal is selected by configuring the
and modulator sources held by the Modulation Source, MDCHS<2:0> bits in the MDCARH register. The carrier
Modulation High Carrier, and Modulation Low Carrier low signal is selected by configuring the MDCLS<2:0>
control registers are not affected when the MDEN bit is bits in the MDCARL register.
cleared and the DSM module is disabled. The values
inside these registers remain unchanged while the
25.5 Carrier Synchronization
DSM is inactive. The sources for the carrier high, car-
rier low and modulator signals will once again be During the time when the DSM switches between car-
selected when the MDEN bit is set and the DSM rier high and carrier low signal sources, the carrier data
module is again enabled and active. in the modulated output signal can become truncated.
The modulated output signal can be disabled without To prevent this, the carrier signal can be synchronized
shutting down the DSM module. The DSM module will to the modulator signal. When synchronization is
remain active and continue to mix signals, but the out- enabled, the carrier pulse that is being mixed at the
put value will not be sent to the DSM pin. During the time of the transition is allowed to transition low before
time that the output is disabled, the DSM pin will remain the DSM switches over to the next carrier source.
low. The modulated output can be disabled by clearing Synchronization is enabled separately for the carrier
the MDEN bit in the MDCON register. high and carrier low signal sources. Synchronization for
the carrier high signal is enabled by setting the
25.3 Modulator Signal Sources MDCHSYNC bit in the MDCON1 register.
Synchronization for the carrier low signal is enabled by
The modulator signal can be supplied from the follow- setting the MDCLSYNC bit in the MDCON1 register.
ing sources:
Figure 25-2 through Figure 25-6 show timing diagrams
External signal on pin selected by MDSRCPPS of using various synchronization methods.
MDBIT bit in the MDCON0 register
CCP1/2 Output
PWM3/4 Output
Comparator C1/C2 Output
EUSART RX Signal
EUSART TX Signal
MSSP SDO Signal (SPI Mode Only)
The modulator signal is selected by configuring the
MDSRCS<3:0> bits in the MDSRC register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 325


PIC18(L)F26/45/46K40
FIGURE 25-2: On Off Keying (OOK) Synchronization
Carrier Low (CARL)

Carrier High (CARH)

Modulator (MOD)

MDCHSYNC = 1
MDCLSYNC = 0

MDCHSYNC = 1
MDCLSYNC = 1

MDCHSYNC = 0
MDCLSYNC = 0

MDCHSYNC = 0
MDCLSYNC = 1

FIGURE 25-3: No Synchronization (MDSHSYNC = 0, MDCLSYNC = 0)

carrier_high

carrier_low

modulator

MDCHSYNC = 0
MDCLSYNC = 0

Active Carrier
carrier_high carrier_low carrier_high carrier_low
State

FIGURE 25-4: Carrier High Synchronization (MDSHSYNC = 1, MDCLSYNC = 0)

carrier_high

carrier_low

modulator

MDCHSYNC = 1
MDCLSYNC = 0

Active Carrier carrier_high carrier_high carrier_low


State both carrier_low both

2016 Microchip Technology Inc. Preliminary DS40001816C-page 326


PIC18(L)F26/45/46K40
FIGURE 25-5: Carrier Low Synchronization (MDSHSYNC = 0, MDCLSYNC = 1)

carrier_high

carrier_low

modulator

MDCHSYNC = 0
MDCLSYNC = 1

Active Carrier
State carrier_high carrier_low carrier_high carrier_low

FIGURE 25-6: Full Synchronization (MDSHSYNC = 1, MDCLSYNC = 1)

carrier_high

carrier_low

modulator Falling edges


used to sync
MDCHSYNC = 1
MDCLSYNC = 1

Active Carrier
State carrier_high carrier_low carrier_high CL

2016 Microchip Technology Inc. Preliminary DS40001816C-page 327


PIC18(L)F26/45/46K40
25.6 Carrier Source Polarity Select 25.9 Operation in Sleep Mode
The signal provided from any selected input source for The DSM module is not affected by Sleep mode. The
the carrier high and carrier low signals can be inverted. DSM can still operate during Sleep, if the Carrier and
Inverting the signal for the carrier high source is Modulator input sources are also still operable during
enabled by setting the MDCHPOL bit of the MDCON1 Sleep. Refer to Section 6.0 Power-Saving Opera-
register. Inverting the signal for the carrier low source is tion Modes for more details.
enabled by setting the MDCLPOL bit of the MDCON1
register. 25.10 Effects of a Reset

25.7 Programmable Modulator Data Upon any device Reset, the DSM module is disabled.
The users firmware is responsible for initializing the
The MDBIT of the MDCON0 register can be selected module before enabling the output. The registers are
as the source for the modulator signal. This gives the reset to their default values.
user the ability to program the value used for modula-
tion. 25.11 Peripheral Module Disable

25.8 Modulated Output Polarity The DSM module can be completely disabled using the
PMD module to achieve maximum power saving. The
The modulated output signal provided on the DSM pin DSMMD bit of PMD5 (Register 7-6) when set disables
can also be inverted. Inverting the modulated output the DSM module completely. When enabled again all
signal is enabled by setting the MDOPOL bit of the the registers of the DSM module default to POR status.
MDCON0 register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 328


PIC18(L)F26/45/46K40
26.0 MASTER SYNCHRONOUS 26.2 SPI Mode Overview
SERIAL PORT MODULE The Serial Peripheral Interface (SPI) bus is a
synchronous serial data communication bus that
Note: The PIC18(L)F26/45/46K40 devices have
operates in Full-Duplex mode. Devices communicate
two MSSP. Therefore, all information in
in a master/slave environment where the master device
this section refers to both MSSP1 and
initiates the communication. A slave device is
MSSP2.
controlled through a Chip Select known as Slave
Select.
26.1 MSSP Module Overview The SPI bus specifies four signal connections:
The Master Synchronous Serial Port (MSSP) module is Serial Clock (SCK)
a serial interface useful for communicating with other Serial Data Out (SDO)
peripheral or microcontroller devices. These peripheral
Serial Data In (SDI)
devices may be serial EEPROMs, shift registers,
display drivers, A/D converters, etc. The Slave Select (SS)
PIC18(L)F26/45/46K40 devices have two MSSP Figure 26-1 shows the block diagram of the MSSP
modules that can operate in one of two modes: module when operating in SPI mode.
Serial Peripheral Interface (SPI)
Inter-Integrated Circuit (I2C)
The SPI interface supports the following modes and
features:
Master mode
Slave mode
Clock Parity
Slave Select Synchronization (Slave mode only)
Daisy-chain connection of slave devices
The I2C interface supports the following modes and
features:
Master mode
Slave mode
Byte NACKing (Slave mode)
Limited multi-master support
7-bit and 10-bit addressing
Start and Stop interrupts
Interrupt masking
Clock stretching
Bus collision detection
General call address matching
Address masking
Address Hold and Data Hold modes
Selectable SDA hold times

2016 Microchip Technology Inc. Preliminary DS40001816C-page 329


PIC18(L)F26/45/46K40
FIGURE 26-1: MSSP BLOCK DIAGRAM (SPI MODE)

Data Bus
Read Write

SSPxBUF Reg

SSPxDATPPS
SDI
PPS SSPSR Reg
SDO bit 0 Shift
Clock
PPS

RxyPPS

SS SS Control 2 (CKP, CKE)


PPS Enable Clock Select

Edge
SSPxSSPPS Select

SSPxCLKPPS(2) SSPM<3:0>

SCK PPS
4
( T2_match
2
)
Edge Prescaler TOSC
PPS Select 4, 16, 64

TRIS bit RxyPPS(1) Baud Rate


Generator
(SSPxADD)
Note 1: Output selection for master mode
2: Input selection for slave mode

The SPI bus operates with a single master device and


one or more slave devices. When multiple slave
devices are used, an independent Slave Select
connection is required from the master device to each
slave device.
Figure 26-2 shows a typical connection between a
master device and multiple slave devices.
The master selects only one slave at a time. Most slave
devices have tri-state outputs so their output signal
appears disconnected from the bus when they are not
selected.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 330


PIC18(L)F26/45/46K40
FIGURE 26-2: SPI MASTER AND MULTIPLE SLAVE CONNECTION

SCK SCK
SPI Master
SDO SDI SPI Slave
SDI SDO #1
General I/O SS
General I/O
General I/O SCK
SDI SPI Slave
SDO #2
SS

SCK
SDI SPI Slave
SDO #3
SS

26.3 SPI Mode Registers


The MSSP module has five registers for SPI mode
operation. These are:
MSSP STATUS register (SSPxSTAT)
MSSP Control register 1 (SSPxCON1)
MSSP Control register 3 (SSPxCON3)
MSSP Data Buffer register (SSPxBUF)
MSSP Address register (SSPxADD)
MSSP Shift register (SSPSR)
(Not directly accessible)
SSPxCON1 and SSPxSTAT are the control and
STATUS registers in SPI mode operation. The
SSPxCON1 register is readable and writable. The
lower six bits of the SSPxSTAT are read-only. The
upper two bits of the SSPxSTAT are read/write.
In one SPI master mode, SSPxADD can be loaded
with a value used in the Baud Rate Generator. More
information on the Baud Rate Generator is available in
Section 26.11 Baud Rate Generator.
SSPSR is the shift register used for shifting data in and
out. SSPxBUF provides indirect access to the SSPSR
register. SSPxBUF is the buffer register to which data
bytes are written, and from which data bytes are read.
In receive operations, SSPSR and SSPxBUF together
create a buffered receiver. When SSPSR receives a
complete byte, it is transferred to SSPxBUF and the
SSPxIF interrupt is set.
During transmission, the SSPxBUF is not buffered. A
write to SSPxBUF will write to both SSPxBUF and
SSPSR.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 331


PIC18(L)F26/45/46K40
26.4 Register Definitions: MSSP Control

REGISTER 26-1: SSPxSTAT: MSSPx STATUS REGISTER (SPI MODE)


R/W-0 R/W-0 R-0 R-0 R-0 R-0 R-0 R-0
(1)
SMP CKE D/A P S R/W UA BF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 SMP: Sample bit


SPI Master mode:
1 = Input data is sampled at the end of data output time
0 = Input data is sampled at the middle of data output time
SPI Slave mode:
SMP must be cleared when SPI is used in Slave mode.
bit 6 CKE: SPI Clock Select bit(1)
1 = Transmit occurs on the transition from active to Idle clock state
0 = Transmit occurs on the transition from Idle to active clock state
bit 5 D/A: Data/Address bit
Used in I2C mode only.
bit 4 P: Stop bit
Used in I2C mode only. This bit is cleared when the MSSPx module is disabled; SSPEN is cleared.
bit 3 S: Start bit
Used in I2C mode only.
bit 2 R/W: Read/Write Information bit
Used in I2C mode only.
bit 1 UA: Update Address bit
Used in I2C mode only.
bit 0 BF: Buffer Full Status bit (Receive mode only)
1 = Receive is complete, SSPxBUF is full
0 = Receive is not complete, SSPxBUF is empty

Note 1: Polarity of clock state is set by the CKP bit (SSPxCON1<4>).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 332


PIC18(L)F26/45/46K40

REGISTER 26-2: SSPxCON1: MSSPx CONTROL REGISTER 1 (SPI MODE)


R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
(1) (2) (4) (4) (4)
WCOL SSPOV SSPEN CKP SSPM3 SSPM2 SSPM1 SSPM0(4)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 WCOL: Write Collision Detect bit


1 = The SSPxBUF register is written while it is still transmitting the previous word (must be cleared in
software)
0 = No collision
bit 6 SSPOV: Receive Overflow Indicator bit(1)
SPI Slave mode:
1 = A new byte is received while the SSPxBUF register is still holding the previous data. In case of
overflow, the data in SSPxSR is lost. Overflow can only occur in Slave mode. The user must read
the SSPxBUF, even if only transmitting data, to avoid setting overflow (must be cleared in
software).
0 = No overflow
bit 5 SSPEN: Master Synchronous Serial Port Enable bit(2)
1 = Enables serial port and configures SCKx, SDOx, SDIx and SSx as serial port pins
0 = Disables serial port and configures these pins as I/O port pins
bit 4 CKP: Clock Polarity Select bit
1 = Idle state for the clock is a high level
0 = Idle state for the clock is a low level
bit 3-0 SSPM<3:0>: Master Synchronous Serial Port Mode Select bits(4)
1010 = SPI Master mode: Clock = FOSC/(4 * (SSPxADD + 1))(3)
0101 = SPI Slave mode: Clock = SCKx pin; SSx pin control is disabled; SSx can be used as I/O pin
0100 = SPI Slave mode: Clock = SCKx pin; SSx pin control is enabled
0011 = SPI Master mode: Clock = TMR2 output/2
0010 = SPI Master mode: Clock = FOSC/64
0001 = SPI Master mode: Clock = FOSC/16
0000 = SPI Master mode: Clock = FOSC/4

Note 1: In Master mode, the overflow bit is not set since each new reception (and transmission) is initiated by
writing to the SSPxBUF register.
2: When enabled, these pins must be properly configured as inputs or outputs.
3: SSPxADD = 0 is not supported.
4: Bit combinations not specifically listed here are either reserved or implemented in I2C mode only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 333


PIC18(L)F26/45/46K40

REGISTER 26-3: SSPxCON3: MSSPx CONTROL REGISTER 3 (SPI MODE)


R/HS/HC-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
ACKTIM PCIE(1) SCIE (1)
BOEN (2)
SDAHT SBCDE AHEN DHEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set HS/HC = Bit is set/cleared by hardware
x = Bit is unknown 0 = Bit is cleared

bit 7 ACKTIM: Acknowledge Time Status bit


Unused in SPI.
bit 6 PCIE: Stop Condition Interrupt Enable bit(1)
1 = Enable interrupt on detection of Stop condition
0 = Stop detection interrupts are disabled
bit 5 SCIE: Start Condition Interrupt Enable bit(1)
1 = Enable interrupt on detection of Start or Restart conditions
0 = Start detection interrupts are disabled
bit 4 BOEN: Buffer Overwrite Enable bit(2)
1 = SSPxBUF updates every time a new data byte is shifted in, ignoring the BF bit
0 = If a new byte is received with BF bit already set, SSPOV is set, and the buffer is not updated
bit 3 SDAHT: SDA Hold Time Selection bit
Unused in SPI.
bit 2 SBCDE: Slave Mode Bus Collision Detect Enable bit
Unused in SPI.
bit 1 AHEN: Address Hold Enable bit
Unused in SPI.
bit 0 DHEN: Data Hold Enable bit
Unused in SPI.

Note 1: This bit has no effect in Slave modes that Start and Stop condition detection is explicitly listed as enabled.
2: For daisy-chained SPI operation; allows the user to ignore all but the last received byte. SSPOV is still set
when a new byte is received and BF = 1, but hardware continues to write the most recent byte to
SSPxBUF.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 334


PIC18(L)F26/45/46K40

REGISTER 26-4: SSPxBUF: MSSP DATA BUFFER REGISTER


R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x
BUF<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 BUF<7:0>: MSSP Buffer bits

REGISTER 26-5: SSPxADD: MSSP ADDRESS REGISTER (SPI MODE)


R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
ADD<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

Master mode: SPI mode

bit 7-0 Baud Rate Clock Divider bits


SCK/SCL pin clock period = ((SSPxADD<7:0> + 1) *4)/FOSC

2016 Microchip Technology Inc. Preliminary DS40001816C-page 335


PIC18(L)F26/45/46K40
26.5 SPI Mode Operation When initializing the SPI, several options need to be
specified. This is done by programming the appropriate
Transmissions involve two shift registers, eight bits in control bits (SSPxCON1<5:0> and SSPxSTAT<7:6>).
size, one in the master and one in the slave. With either These control bits allow the following to be specified:
the master or the slave device, data is always shifted
out one bit at a time, with the Most Significant bit (MSb) Master mode (SCK is the clock output)
shifted out first. At the same time, a new Least Slave mode (SCK is the clock input)
Significant bit (LSb) is shifted into the same register. Clock Polarity (Idle state of SCK)
Figure 26-3 shows a typical connection between two Data Input Sample Phase (middle or end of data
processors configured as master and slave devices. output time)
Data is shifted out of both shift registers on the Clock Edge (output data on rising/falling edge of
programmed clock edge and latched on the opposite SCK)
edge of the clock. Clock Rate (Master mode only)
The master device transmits information out on its SDO Slave Select mode (Slave mode only)
output pin which is connected to, and received by, the To enable the serial port, SSP Enable bit, SSPEN of the
slaves SDI input pin. The slave device transmits infor- SSPxCON1 register, must be set. To reset or reconfig-
mation out on its SDO output pin, which is connected ure SPI mode, clear the SSPEN bit, re-initialize the
to, and received by, the masters SDI input pin. SSPxCONx registers and then set the SSPEN bit. This
To begin communication, the master device first sends configures the SDI, SDO, SCK and SS pins as serial
out the clock signal. Both the master and the slave port pins. For the pins to behave as the serial port
devices should be configured for the same clock polar- function, some must have their data direction bits (in
ity. the TRIS register) appropriately programmed as
follows:
The master device starts a transmission by sending out
the MSb from its shift register. The slave device reads SDI must have corresponding TRIS bit set
this bit from that same line and saves it into the LSb SDO must have corresponding TRIS bit cleared
position of its shift register. SCK (Master mode) must have corresponding
During each SPI clock cycle, a full-duplex data TRIS bit cleared
transmission occurs. This means that while the master SCK (Slave mode) must have corresponding
device is sending out the MSb from its shift register (on TRIS bit set
its SDO pin) and the slave device is reading this bit and SS must have corresponding TRIS bit set
saving it as the LSb of its shift register, that the slave Any serial port function that is not desired may be
device is also sending out the MSb from its shift register overridden by programming the corresponding data
(on its SDO pin) and the master device is reading this direction (TRIS) register to the opposite value.
bit and saving it as the LSb of its shift register.
The MSSP consists of a transmit/receive shift register
After eight bits have been shifted out, the master and (SSPSR) and a buffer register (SSPxBUF). The
slave have exchanged register values. SSPSR shifts the data in and out of the device, MSb
If there is more data to exchange, the shift registers are first. The SSPxBUF holds the data that was written to
loaded with new data and the process repeats itself. the SSPSR until the received data is ready. Once the
Whether the data is meaningful or not (dummy data), eight bits of data have been received, that byte is
depends on the application software. This leads to moved to the SSPxBUF register. Then, the Buffer Full
three scenarios for data transmission: Detect bit, BF of the SSPxSTAT register, and the inter-
rupt flag bit, SSPxIF, are set. This double-buffering of
Master sends useful data and slave sends dummy the received data (SSPxBUF) allows the next byte to
data. start reception before reading the data that was just
Master sends useful data and slave sends useful received. Any write to the SSPxBUF register during
data. transmission/reception of data will be ignored and the
Master sends dummy data and slave sends useful write collision detect bit, WCOL of the SSPxCON1 reg-
data. ister, will be set. User software must clear the WCOL bit
to allow the following write(s) to the SSPxBUF register
Transmissions may involve any number of clock
to complete successfully.
cycles. When there is no more data to be transmitted,
the master stops sending the clock signal and it
deselects the slave.
Every slave device connected to the bus that has not
been selected through its slave select line must disre-
gard the clock and transmission signals and must not
transmit out any data of its own.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 336


PIC18(L)F26/45/46K40
When the application software is expecting to receive
valid data, the SSPxBUF should be read before the
next byte of data to transfer is written to the SSPxBUF.
The Buffer Full bit, BF of the SSPxSTAT register,
indicates when SSPxBUF has been loaded with the
received data (transmission is complete). When the
SSPxBUF is read, the BF bit is cleared. This data may
be irrelevant if the SPI is only a transmitter. Generally,
the MSSP interrupt is used to determine when the
transmission/reception has completed. If the interrupt
method is not going to be used, then software polling
can be done to ensure that a write collision does not
occur.
The SSPSR is not directly readable or writable and can
only be accessed by addressing the SSPxBUF register.
Additionally, the SSPxSTAT register indicates the
various Status conditions.

FIGURE 26-3: SPI MASTER/SLAVE CONNECTION

SPI Master SSPM<3:0> = 00xx SPI Slave SSPM<3:0> = 010x


= 1010
SDO SDI

Serial Input Buffer Serial Input Buffer


(BUF) (SSPxBUF)

Shift Register SDI SDO Shift Register


(SSPSR) (SSPSR)
MSb LSb MSb LSb
Serial Clock
SCK SCK

Slave Select
General I/O SS
Processor 1 (optional) Processor 2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 337


PIC18(L)F26/45/46K40
26.5.1 SPI MASTER MODE The clock polarity is selected by appropriately
programming the CKP bit of the SSPxCON1 register
The master can initiate the data transfer at any time
and the CKE bit of the SSPxSTAT register. This then,
because it controls the SCK line. The master
would give waveforms for SPI communication as
determines when the slave (Processor 2, Figure 26-3)
shown in Figure 26-4, Figure 26-6, Figure 26-7 and
is to broadcast data by the software protocol.
Figure 26-8, where the MSB is transmitted first. In
In Master mode, the data is transmitted/received as Master mode, the SPI clock rate (bit rate) is user
soon as the SSPxBUF register is written to. If the SPI programmable to be one of the following:
is only going to receive, the SDO output could be
FOSC/4 (or TCY)
disabled (programmed as an input). The SSPSR
register will continue to shift in the signal present on the FOSC/16 (or 4 * TCY)
SDI pin at the programmed clock rate. As each byte is FOSC/64 (or 16 * TCY)
received, it will be loaded into the SSPxBUF register as Timer2 output/2
if a normal received byte (interrupts and Status bits FOSC/(4 * (SSPxADD + 1))
appropriately set).
Figure 26-4 shows the waveforms for Master mode.
When the CKE bit is set, the SDO data is valid before
there is a clock edge on SCK. The change of the input
sample is shown based on the state of the SMP bit. The
time when the SSPxBUF is loaded with the received
data is shown.
Note: In Master mode the clock signal output to
the SCK pin is also the clock signal input
to the peripheral. The pin selected for out-
put with the RxyPPS register must also be
selected as the peripheral input with the
SSPxCLKPPS register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 338


PIC18(L)F26/45/46K40
FIGURE 26-4: SPI MODE WAVEFORM (MASTER MODE)

Write to
SSPxBUF

SCK
(CKP = 0
CKE = 0)

SCK
(CKP = 1
CKE = 0)
4 Clock
SCK Modes
(CKP = 0
CKE = 1)

SCK
(CKP = 1
CKE = 1)

SDO bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0


(CKE = 0)
SDO bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0
(CKE = 1)
SDI
(SMP = 0) bit 7 bit 0
Input
Sample
(SMP = 0)
SDI
(SMP = 1) bit 0
bit 7

Input
Sample
(SMP = 1)
SSPxIF

SSPSR to
SSPxBUF

26.5.2 SPI SLAVE MODE 26.5.3 DAISY-CHAIN CONFIGURATION


In Slave mode, the data is transmitted and received as The SPI bus can sometimes be connected in a
external clock pulses appear on SCK. When the last daisy-chain configuration. The first slave output is
bit is latched, the SSPxIF interrupt flag bit is set. connected to the second slave input, the second slave
Before enabling the module in SPI Slave mode, the clock output is connected to the third slave input, and so on.
line must match the proper Idle state. The clock line can The final slave output is connected to the master input.
be observed by reading the SCK pin. The Idle state is Each slave sends out, during a second group of clock
determined by the CKP bit of the SSPxCON1 register. pulses, an exact copy of what was received during the
first group of clock pulses. The whole chain acts as
While in Slave mode, the external clock is supplied by one large communication shift register. The
the external clock source on the SCK pin. This external daisy-chain feature only requires a single Slave Select
clock must meet the minimum high and low times as line from the master device.
specified in the electrical specifications.
Figure 26-5 shows the block diagram of a typical
While in Sleep mode, the slave can transmit/receive daisy-chain connection when operating in SPI mode.
data. The shift register is clocked from the SCK pin
input and when a byte is received, the device will In a daisy-chain configuration, only the most recent
generate an interrupt. If enabled, the device will byte on the bus is required by the slave. Setting the
wake-up from Sleep. BOEN bit of the SSPxCON3 register will enable writes
to the SSPxBUF register, even if the previous byte has
not been read. This allows the software to ignore data
that may not apply to it.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 339


PIC18(L)F26/45/46K40
26.5.4 SLAVE SELECT When the SS pin is low, transmission and reception are
SYNCHRONIZATION enabled and the SDO pin is driven.
The Slave Select can also be used to synchronize When the SS pin goes high, the SDO pin is no longer
communication. The Slave Select line is held high until driven, even if in the middle of a transmitted byte and
the master device is ready to communicate. When the becomes a floating output. External pull-up/pull-down
Slave Select line is pulled low, the slave knows that a resistors may be desirable depending on the applica-
new transmission is starting. tion.
If the slave fails to receive the communication properly, Note 1: When the SPI is in Slave mode with SS pin
it will be reset at the end of the transmission, when the control enabled (SSPxCON1<3:0> =
Slave Select line returns to a high state. The slave is 0100), the SPI module will reset if the SS
then ready to receive a new transmission when the pin is set to VDD.
Slave Select line is pulled low again. If the Slave Select
2: When the SPI is used in Slave mode with
line is not used, there is a risk that the slave will
CKE set; the user must enable SS pin
eventually become out of sync with the master. If the
control.
slave misses a bit, it will always be one bit off in future
transmissions. Use of the Slave Select line allows the 3: While operated in SPI Slave mode the
slave and master to align themselves at the beginning SMP bit of the SSPxSTAT register must
of each transmission. remain clear.
The SS pin allows a Synchronous Slave mode. The When the SPI module resets, the bit counter is forced
SPI must be in Slave mode with SS pin control enabled to 0. This can be done by either forcing the SS pin to
(SSPxCON1<3:0> = 0100). a high level or clearing the SSPEN bit.

FIGURE 26-5: SPI DAISY-CHAIN CONNECTION

SCK SCK
SPI Master
SDO SDI SPI Slave
SDI SDO #1
General I/O SS

SCK
SDI SPI Slave
SDO #2
SS

SCK
SDI SPI Slave
SDO #3
SS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 340


PIC18(L)F26/45/46K40
FIGURE 26-6: SLAVE SELECT SYNCHRONOUS WAVEFORM

SS

SCK
(CKP = 0
CKE = 0)

SCK
(CKP = 1
CKE = 0)

Write to
SSPxBUF
Shift register SSPSR
and bit count are reset
SSPxBUF to
SSPSR

SDO bit 7 bit 6 bit 7 bit 6 bit 0

SDI bit 0
bit 7 bit 7
Input
Sample

SSPxIF
Interrupt
Flag

SSPSR to
SSPxBUF

2016 Microchip Technology Inc. Preliminary DS40001816C-page 341


PIC18(L)F26/45/46K40
FIGURE 26-7: SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 0)

SS
Optional

SCK
(CKP = 0
CKE = 0)

SCK
(CKP = 1
CKE = 0)
Write to
SSPxBUF
Valid
SDO bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0

SDI
bit 7 bit 0
Input
Sample

SSPxIF
Interrupt
Flag
SSPSR to
SSPxBUF

Write Collision
detection active

FIGURE 26-8: SPI MODE WAVEFORM (SLAVE MODE WITH CKE = 1)

SS
Not Optional

SCK
(CKP = 0
CKE = 1)

SCK
(CKP = 1
CKE = 1)
Write to
SSPxBUF
Valid
SDO bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0

SDI
bit 7 bit 0
Input
Sample

SSPxIF
Interrupt
Flag

SSPSR to
SSPxBUF

Write Collision
detection active

2016 Microchip Technology Inc. Preliminary DS40001816C-page 342


PIC18(L)F26/45/46K40
26.5.5 SPI OPERATION IN SLEEP MODE In SPI Master mode, when the Sleep mode is selected,
all module clocks are halted and the transmis-
In SPI Master mode, module clocks may be operating
sion/reception will remain in that state until the device
at a different speed than when in Full-Power mode; in
wakes. After the device returns to Run mode, the
the case of the Sleep mode, all clocks are halted.
module will resume transmitting and receiving data.
Special care must be taken by the user when the MSSP
In SPI Slave mode, the SPI Transmit/Receive Shift
clock is much faster than the system clock.
register operates asynchronously to the device. This
In Slave mode, when MSSP interrupts are enabled, allows the device to be placed in Sleep mode and data
after the master completes sending data, an MSSP to be shifted into the SPI Transmit/Receive Shift
interrupt will wake the controller from Sleep. register. When all eight bits have been received, the
If an exit from Sleep mode is not desired, MSSP MSSP interrupt flag bit will be set and if enabled, will
interrupts should be disabled. wake the device.

TABLE 26-1: SUMMARY OF REGISTERS ASSOCIATED WITH SPI OPERATION


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 on Page
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RxyPPS RxyPPS<4:0> 217
SSPxBUF BUF<7:0> 331*
SSPxCLKPPS SSPxCLKPPS<4:0> 215
SSPxCON1 WCOL SSPOV SSPEN CKP SSPM<3:0> 333
SSPxCON3 ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN 334
SSPxDATPPS SSPDATPPS<4:0> 215
SSPxSSPPS SSPSSPPS<4:0> 215
SSPxSTAT SMP CKE D/A P S R/W UA BF 348
Legend: = Unimplemented location, read as 0. Shaded cells are not used by the MSSP in SPI mode.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 343


PIC18(L)F26/45/46K40
26.6 I2C Mode Overview controlled through addressing. Figure 26-9 is a block
diagram of the I2C interface module in Master mode.
The Inter-Integrated Circuit (I2C) bus is a multi-master Figure 26-10 is a diagram of the I2C interface module
serial data communication bus. Devices communicate in Slave mode.
in a master/slave environment where the master
devices initiate the communication. A slave device is

FIGURE 26-9: MSSP BLOCK DIAGRAM (I2C MASTER MODE)

Internal
data bus [SSPM<3:0>]
SSPxDATPPS(1) Read Write
SDA
SDA in
PPS SSPxBUF Baud Rate
Generator
(SSPxADD)
Shift
RxyPPS(1) Clock

Clock arbitrate/BCOL detect


SSPSR

Clock Cntl

(Hold off clock source)


PPS MSb LSb
Receive Enable (RCEN)

Start bit, Stop bit,


Acknowledge
SSPxCLKPPS(2) Generate (SSPxCON2)
SCL
PPS

PPS

Start bit detect,


RxyPPS(2) Stop bit detect
Write collision detect Set/Reset: S, P, SSPxSTAT, WCOL, SSPOV
SCL in
Clock arbitration Reset SEN, PEN (SSPxCON2)
State counter for Set SSP1IF, BCL1IF
Bus Collision end of XMIT/RCV
Address Match detect

Note 1: SDA pin selections must be the same for input and output
2: SCL pin selections must be the same for input and output

2016 Microchip Technology Inc. Preliminary DS40001816C-page 344


PIC18(L)F26/45/46K40
FIGURE 26-10: MSSP BLOCK DIAGRAM (I2C SLAVE MODE)
Internal
Data Bus

Read Write

SSPxCLKPPS(2) SSPxBUF Reg


SCL
PPS
Shift
Clock
Clock
PPS Stretching SSPSR Reg
MSb LSb
RxyPPS(2)

SSPxMSK Reg
(1)
SSPxDATPPS
SDA Match Detect Addr Match
PPS
SSPxADD Reg
PPS
Start and Set, Reset
RxyPPS(1) Stop bit Detect S, P bits
(SSPxSTAT Reg)

Note 1: SDA pin selections must be the same for input and output
2: SCL pin selections must be the same for input and output

The I2C bus specifies two signal connections: If the requested slave exists on the bus, it will respond
Serial Clock (SCL) with an Acknowledge bit, otherwise known as an ACK.
The master then continues in either Transmit mode or
Serial Data (SDA)
Receive mode and the slave continues in the comple-
Both the SCL and SDA connections are bidirectional ment, either in Receive mode or Transmit mode,
open-drain lines, each requiring pull-up resistors for the respectively.
supply voltage. Pulling the line to ground is considered
A Start bit is indicated by a high-to-low transition of the
a logical zero and letting the line float is considered a
SDA line while the SCL line is held high. Address and
logical one.
data bytes are sent out, Most Significant bit (MSb) first.
Figure 26-11 shows a typical connection between two The Read/Write bit is sent out as a logical one when the
processors configured as master and slave devices. master intends to read data from the slave, and is sent
The I2C bus can operate with one or more master out as a logical zero when it intends to write data to the
devices and one or more slave devices. slave.
There are four potential modes of operation for a given
FIGURE 26-11: I2C MASTER/
device:
SLAVE CONNECTION
Master Transmit mode
(master is transmitting data to a slave)
VDD
Master Receive mode
(master is receiving data from a slave)
Slave Transmit mode SCL SCL
(slave is transmitting data to a master)
VDD
Slave Receive mode Master Slave
(slave is receiving data from the master)
To begin communication, a master device starts out in SDA SDA
Master Transmit mode. The master device sends out a
Start bit followed by the address byte of the slave it
intends to communicate with. This is followed by a
single Read/Write bit, which determines whether the The Acknowledge bit (ACK) is an active-low signal,
master intends to transmit to or receive data from the which holds the SDA line low to indicate to the transmit-
slave device. ter that the slave device has received the transmitted
data and is ready to receive more.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 345


PIC18(L)F26/45/46K40
The transition of a data bit is always performed while When one device is transmitting a logical one, or letting
the SCL line is held low. Transitions that occur while the the line float, and a second device is transmitting a log-
SCL line is held high are used to indicate Start and Stop ical zero, or holding the line low, the first device can
bits. detect that the line is not a logical one. This detection,
If the master intends to write to the slave, then it repeat- when used on the SCL line, is called clock stretching.
edly sends out a byte of data, with the slave responding Clock stretching gives slave devices a mechanism to
after each byte with an ACK bit. In this example, the control the flow of data. When this detection is used on
master device is in Master Transmit mode and the the SDA line, it is called arbitration. Arbitration ensures
slave is in Slave Receive mode. that there is only one master device communicating at
any single time.
If the master intends to read from the slave, then it
repeatedly receives a byte of data from the slave, and 26.6.1 CLOCK STRETCHING
responds after each byte with an ACK bit. In this exam-
When a slave device has not completed processing
ple, the master device is in Master Receive mode and
data, it can delay the transfer of more data through the
the slave is Slave Transmit mode.
process of clock stretching. An addressed slave device
On the last byte of data communicated, the master may hold the SCL clock line low after receiving or send-
device may end the transmission by sending a Stop bit. ing a bit, indicating that it is not yet ready to continue.
If the master device is in Receive mode, it sends the The master that is communicating with the slave will
Stop bit in place of the last ACK bit. A Stop bit is attempt to raise the SCL line in order to transfer the
indicated by a low-to-high transition of the SDA line next bit, but will detect that the clock line has not yet
while the SCL line is held high. been released. Because the SCL connection is
In some cases, the master may want to maintain open-drain, the slave has the ability to hold that line low
control of the bus and re-initiate another transmission. until it is ready to continue communicating.
If so, the master device may send another Start bit in Clock stretching allows receivers that cannot keep up
place of the Stop bit or last ACK bit when it is in receive with a transmitter to control the flow of incoming data.
mode.
The I2C bus specifies three message protocols;
Single message where a master writes data to a
slave.
Single message where a master reads data from
a slave.
Combined message where a master initiates a
minimum of two writes, or two reads, or a
combination of writes and reads, to one or more
slaves.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 346


PIC18(L)F26/45/46K40
26.6.2 ARBITRATION 26.7 Register Definitions: I2C Mode
Each master device must monitor the bus for Start and
Stop bits. If the device detects that the bus is busy, it The MSSPx module has seven registers for I2C
cannot begin a new message until the bus returns to an operation.
Idle state. These are:
MSSP Status Register (SSPxSTAT)
However, two master devices may try to initiate a trans- MSSP Control Register 1 (SSPxCON1)
mission on or about the same time. When this occurs, MSSP Control Register 2 (SSPxCON2)
the process of arbitration begins. Each transmitter MSSP Control Register 3 (SSPxCON3)
checks the level of the SDA data line and compares it Serial Receive/Transmit Buffer Register
to the level that it expects to find. The first transmitter to (SSPxBUF)
observe that the two levels do not match, loses arbitra- MSSP Address Register (SSPxADD)
tion, and must stop transmitting on the SDA line. I2C Slave Address Mask Register (SSPxMSK)
For example, if one transmitter holds the SDA line to a MSSP Shift Register (SSPSR) not directly
logical one (lets it float) and a second transmitter holds accessible
it to a logical zero (pulls it low), the result is that the SSPxCON1, SSPxCON2, SSPxCON3 and SSPxSTAT
SDA line will be low. The first transmitter then observes
are the Control and Status registers in I2C mode
that the level of the line is different than expected and
operation. The SSPxCON1, SSPxCON2, and
concludes that another transmitter is communicating.
SSPxCON3 registers are readable and writable. The
The first transmitter to notice this difference is the one lower six bits of the SSPxSTAT are read-only. The
that loses arbitration and must stop driving the SDA
upper two bits of the SSPxSTAT are read/write.
line. If this transmitter is also a master device, it also
SSPSR is the Shift register used for shifting data in or
must stop driving the SCL line. It then can monitor the
lines for a Stop condition before trying to reissue its out. SSPxBUF is the buffer register to which data
transmission. In the meantime, the other device that bytes are written to or read from. SSPxADD contains
has not noticed any difference between the expected the slave device address when the MSSP is
and actual levels on the SDA line continues with its configured in I2C Slave mode. When the MSSP is
original transmission. It can do so without any compli- configured in Master mode, the lower seven bits of
cations, because so far, the transmission appears SSPxADD act as the Baud Rate Generator reload
exactly as expected with no other transmitter disturbing
value.
the message.
SSPxMSK holds the slave address mask value when
Slave Transmit mode can also be arbitrated, when a the module is configured for 7-Bit Address Masking
master addresses multiple slaves, but this is less mode. While it is a separate register, it shares the
common.
same SFR address as SSPxADD; it is only accessible
If two master devices are sending a message to two when the SSPM<3:0> bits are specifically set to permit
different slave devices at the address stage, the master access. In receive operations, SSPSR and SSPxBUF
sending the lower slave address always wins arbitra- together, create a double-buffered receiver. When
tion. When two master devices send messages to the
SSPSR receives a complete byte, it is transferred to
same slave address, and addresses can sometimes
SSPxBUF and the SSPxIF interrupt is set. During
refer to multiple slaves, the arbitration process must
continue into the data stage. transmission, the SSPxBUF is not double-buffered. A
write to SSPxBUF will write to both SSPxBUF and
Arbitration usually occurs very rarely, but it is a
SSPSR.
necessary process for proper multi-master support.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 347


PIC18(L)F26/45/46K40

REGISTER 26-6: SSPxSTAT: MSSPx STATUS REGISTER (I2C MASTER MODE)


R/W-0 R/W-0 R-0 R-0 R-0 R-0 R-0 R-0
SMP CKE D/A P(1) S(1) R/W(2,3) UA BF
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 SMP: Slew Rate Control bit


In Master or Slave mode:
1 = Slew rate control is disabled for Standard Speed mode (100 kHz and 1 MHz)
0 = Slew rate control is enabled for High-Speed mode (400 kHz)
bit 6 CKE: SMBus Select bit
In Master or Slave mode:
1 = Enables SMBus-specific inputs
0 = Disables SMBus-specific inputs
bit 5 D/A: Data/Address bit
In Master mode:
Reserved.
In Slave mode:
1 = Indicates that the last byte received or transmitted was data
0 = Indicates that the last byte received or transmitted was address
bit 4 P: Stop bit(1)
1 = Indicates that a Stop bit has been detected last
0 = Stop bit was not detected last
bit 3 S: Start bit(1)
1 = Indicates that a Start bit has been detected last
0 = Start bit was not detected last
bit 2 R/W: Read/Write Information bit(2,3)
In Slave mode:
1 = Read
0 = Write
In Master mode:
1 = Transmit is in progress
0 = Transmit is not in progress
bit 1 UA: Update Address bit (10-Bit Slave mode only)
1 = Indicates that the user needs to update the address in the SSPxADD register
0 = Address does not need to be updated
bit 0 BF: Buffer Full Status bit
In Transmit mode:
1 = SSPxBUF is full
0 = SSPxBUF is empty
In Receive mode:
1 = SSPxBUF is full (does not include the ACK and Stop bits)
0 = SSPxBUF is empty (does not include the ACK and Stop bits)

Note 1: This bit is cleared on Reset and when SSPEN is cleared.


2: This bit holds the R/W bit information following the last address match. This bit is only valid from the
address match to the next Start bit, Stop bit or not ACK bit.
3: ORing this bit with SEN, RSEN, PEN, RCEN or ACKEN will indicate if the MSSPx is in Active mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 348


PIC18(L)F26/45/46K40

REGISTER 26-7: SSPxCON1: MSSPx CONTROL REGISTER 1 (I2C MASTER MODE)


R/W-0 R/W/HC-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
WCOL SSPOV SSPEN(1) CKP SSPM3(2) SSPM2(2) SSPM1(2) SSPM0(2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit HC = Bit is cleared by hardware
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 WCOL: Write Collision Detect bit


In Master Transmit mode:
1 = A write to the SSPxBUF register was attempted while the I2C conditions were not valid for a
transmission to be started (must be cleared in software)
0 = No collision
In Slave Transmit mode:
1 = The SSPxBUF register is written while it is still transmitting the previous word (must be cleared in
software)
0 = No collision
In Receive mode (Master or Slave modes):
This is a dont care bit.
bit 6 SSPOV: Receive Overflow Indicator bit
In Receive mode:
1 = A byte is received while the SSPxBUF register is still holding the previous byte (must be cleared in
software)
0 = No overflow
In Transmit mode:
This is a dont care bit in Transmit mode.
bit 5 SSPEN: Master Synchronous Serial Port Enable bit(1)
1 = Enables the serial port and configures the SDAx and SCLx pins as the serial port pins
0 = Disables serial port and configures these pins as I/O port pins
bit 4 CKP: SCKx Release Control bit
In Slave mode:
1 = Releases clock
0 = Holds clock low (clock stretch), used to ensure data setup time
In Master mode:
Unused in this mode.
bit 3-0 SSPM<3:0>: Master Synchronous Serial Port Mode Select bits(2)
1111 = I2C Slave mode: 10-bit address with Start and Stop bit interrupts enabled
1110 = I2C Slave mode: 7-bit address with Start and Stop bit interrupts enabled
1011 = I2C Firmware Controlled Master mode (slave Idle)
1001 = Load SSPxMSK register at SSPxADD SFR address(3,4)
1000 = I2C Master mode: Clock = FOSC/(4 * (SSPxADD + 1))
0111 = I2C Slave mode: 10-bit address(3,4)
0110 = I2C Slave mode: 7-bit address

Note 1: When enabled, the SDAx and SCLx pins must be configured as inputs.
2: Bit combinations not specifically listed here are either reserved or implemented in SPI mode only.
3: When SSPM<3:0> = 1001, any reads or writes to the SSPxADD SFR address actually accesses the
SSPxMSK register.
4: This mode is only available when 7-Bit Address Masking mode is selected (MSSPMSK Configuration bit
is 1).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 349


PIC18(L)F26/45/46K40
REGISTER 26-8: SSPxCON2: MSSPx CONTROL REGISTER 2 (I2C MASTER MODE)
R/W-0 R/W/HC-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
GCEN ACKSTAT ACKDT(1) ACKEN(2) RCEN(2) PEN(2) RSEN(2) SEN(2)
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit HC = Bit is cleared by hardware
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 GCEN: General Call Enable bit


Unused in Master mode.
bit 6 ACKSTAT: Acknowledge Status bit (Master Transmit mode only)
1 = Acknowledge was not received from slave
0 = Acknowledge was received from slave
bit 5 ACKDT: Acknowledge Data bit (Master Receive mode only)(1)
1 = Not Acknowledge
0 = Acknowledge
bit 4 ACKEN: Acknowledge Sequence Enable bit(2)
1 = Initiates Acknowledge sequence on SDAx and SCLx pins and transmits ACKDT data bit;
automatically cleared by hardware
0 = Acknowledge sequence is Idle
bit 3 RCEN: Receive Enable bit (Master Receive mode only)(2)
1 = Enables Receive mode for I2C
0 = Receive is Idle
bit 2 PEN: Stop Condition Enable bit(2)
1 = Initiates Stop condition on SDAx and SCLx pins; automatically cleared by hardware
0 = Stop condition is Idle
bit 1 RSEN: Repeated Start Condition Enable bit(2)
1 = Initiates Repeated Start condition on SDAx and SCLx pins; automatically cleared by hardware
0 = Repeated Start condition is Idle
bit 0 SEN: Start Condition Enable bit(2)
1 = Initiates Start condition on SDAx and SCLx pins; automatically cleared by hardware
0 = Start condition is Idle

Note 1: The value that will be transmitted when the user initiates an Acknowledge sequence at the end of a
receive.
2: If the I2C module is active, these bits may not be set (no spooling) and the SSPxBUF may not be written
(or writes to the SSPxBUF are disabled).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 350


PIC18(L)F26/45/46K40

REGISTER 26-9: SSPxCON3: MSSPx CONTROL REGISTER 3 (I2C MASTER MODE)


R/HS/HC-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set HS/HC = Bit is set/cleared by hardware
x = Bit is unknown 0 = Bit is cleared

bit 7 ACKTIM: Acknowledge Time Status bit


Unused in Master mode.
bit 6 PCIE: Stop Condition Interrupt Enable bit(1)
1 = Enable interrupt on detection of Stop condition
0 = Stop detection interrupts are disabled
bit 5 SCIE: Start Condition Interrupt Enable bit(1)
1 = Enable interrupt on detection of Start or Restart conditions
0 = Start detection interrupts are disabled
bit 4 BOEN: Buffer Overwrite Enable bit
1 = SSPxBUF is updated every time a new data byte is available, ignoring the SSPOV effect on
updating the buffer
0 = SSPxBUF is only updated when SSPOV is clear
bit 3 SDAHT: SDA Hold Time Selection bit
1 = Minimum of 300ns hold time on SDA after the falling edge of SCL
0 = Minimum of 100ns hold time on SDA after the falling edge of SCL
bit 2 SBCDE: Slave Mode Bus Collision Detect Enable bit
Unused in Master mode.
bit 1 AHEN: Address Hold Enable bit
Unused in Master mode.
bit 0 DHEN: Data Hold Enable bit
Unused in Master mode.

Note 1: This bit has no effect in Slave modes that Start and Stop condition detection is explicitly listed as enabled.

REGISTER 26-10: SSPxBUF: MSSP DATA BUFFER REGISTER (I2C MASTER MODE)
R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x R/W-x
BUF<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 BUF<7:0>: MSSP Buffer bits

2016 Microchip Technology Inc. Preliminary DS40001816C-page 351


PIC18(L)F26/45/46K40

REGISTER 26-11: SSPxADD: MSSP ADDRESS REGISTER (I2C MASTER MODE)


R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0
ADD<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

Master mode: I2 C mode

bit 7-0 Baud Rate Clock Divider bits(1)


SCK/SCL pin clock period = ((SSPxADD<7:0> + 1) *4)/FOSC
10-Bit Slave mode Most Significant Address Byte:

bit 7-3 Not used: Unused for Most Significant Address Byte. Bit state of this register is a dont care. Bit
pattern sent by master is fixed by I2C specification and must be equal to 11110. However, those bits
are compared by hardware and are not affected by the value in this register.
bit 2-1 ADD<9:8>: Two Most Significant bits of 10-bit Address
bit 0 Not used: Unused in this mode. Bit state is a dont care.
10-Bit Slave mode Least Significant Address Byte:

bit 7-0 ADD<7:0>: Eight Least Significant bits of 10-bit Address


7-Bit Slave mode:

bit 7-1 7-bit Slave Address


bit 0 Not used: Unused in this mode. Bit state is a dont care.
Note 1: Values of 0x00, 0x01 and 0x02 are not valid for SSPxADD when used as a Baud Rate Generator for I2C.
This is an implementation limitation.

REGISTER 26-12: SSPxMSK: MSSPx ADDRESS MASK REGISTER


R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1 R/W-1
MSK<7:1> MSK0
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-1 MSK<7:1>: Mask bits


1 = The received address bit n is compared to SSPxADDn to detect I2C address match
0 = The received address bit n is not used to detect I2C address match
bit 0 MSK0: Mask bit for I2C Slave mode, 10-bit Address
I2C Slave mode, 10-bit address (SSPM<3:0> = 0111 or 1111):
1 = The received address bit 0 is compared to SSPxADD0 to detect I2C address match
0 = The received address bit 0 is not used to detect I2C address match
I2C Slave mode, 7-bit address, the bit is ignored.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 352


PIC18(L)F26/45/46K40
26.8 I2C Mode Operation TABLE 26-2: I2C BUS TERMS
All MSSP I2C communication is byte oriented and TERM Description
shifted out MSb first. Six SFR registers and two Transmitter The device which shifts data out
interrupt flags interface the module with the PIC onto the bus.
microcontroller and user software. Two pins, SDA and Receiver The device which shifts data in
SCL, are exercised by the module to communicate from the bus.
with other external I2C devices.
Master The device that initiates a transfer,
generates clock signals and
26.8.1 BYTE FORMAT
terminates a transfer.
All communication in I2C is done in 9-bit segments. A Slave The device addressed by the
byte is sent from a master to a slave or vice-versa, fol- master.
lowed by an Acknowledge bit sent back. After the
Multi-master A bus with more than one device
eighth falling edge of the SCL line, the device output-
that can initiate data transfers.
ting data on the SDA changes that pin to an input and
reads in an acknowledge value on the next clock Arbitration Procedure to ensure that only one
pulse. master at a time controls the bus.
Winning arbitration ensures that
The clock signal, SCL, is provided by the master. Data the message is not corrupted.
is valid to change while the SCL signal is low, and
Synchronization Procedure to synchronize the
sampled on the rising edge of the clock. Changes on
clocks of two or more devices on
the SDA line while the SCL line is high define special
the bus.
conditions on the bus, explained below.
Idle No master is controlling the bus,
26.8.2 DEFINITION OF I2C TERMINOLOGY and both SDA and SCL lines are
high.
There is language and terminology in the description
of I2C communication that have definitions specific to Active Any time one or more master
I2C. That word usage is defined below and may be devices are controlling the bus.
used in the rest of this document without explanation. Addressed Slave device that has received a
This table was adapted from the Philips I2C Slave matching address and is actively
specification. being clocked by a master.
Matching Address byte that is clocked into a
26.8.3 SDA AND SCL PINS Address slave that matches the value
Selection of any I2C mode with the SSPEN bit set, stored in SSPxADD.
forces the SCL and SDA pins to be open-drain. These Write Request Slave receives a matching
pins should be set by the user to inputs by setting the address with R/W bit clear, and is
appropriate TRIS bits. ready to clock in data.
Read Request Master sends an address byte with
Note 1: Data is tied to output zero when an I2C
the R/W bit set, indicating that it
mode is enabled.
wishes to clock data out of the
2: Any device pin can be selected for SDA Slave. This data is the next and all
and SCL functions with the PPS peripheral. following bytes until a Restart or
These functions are bidirectional. The SDA Stop.
input is selected with the SSPxDATPPS Clock Stretching When a device on the bus hold
registers. The SCL input is selected with SCL low to stall communication.
the SSPxCLKPPS registers. Outputs are
Bus Collision Any time the SDA line is sampled
selected with the RxyPPS registers. It is the
low by the module while it is out-
users responsibility to make the selections
putting and expected high state.
so that both the input and the output for
each function is on the same pin.

26.8.4 SDA HOLD TIME


The hold time of the SDA pin is selected by the SDAHT
bit of the SSPxCON3 register. Hold time is the time
SDA is held valid after the falling edge of SCL. Setting
the SDAHT bit selects a longer 300 ns minimum hold
time and may help on buses with large capacitance.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 353


PIC18(L)F26/45/46K40
26.8.5 START CONDITION 26.8.7 RESTART CONDITION
The I2C specification defines a Start condition as a A Restart is valid any time that a Stop would be valid.
transition of SDA from a high to a low state while SCL A master can issue a Restart if it wishes to hold the
line is high. A Start condition is always generated by bus after terminating the current transfer. A Restart
the master and signifies the transition of the bus from has the same effect on the slave that a Start would,
an Idle to an Active state. Figure 26-12 shows wave resetting all slave logic and preparing it to clock in an
forms for Start and Stop conditions. address. The master may want to address the same or
A bus collision can occur on a Start condition if the another slave. Figure 26-13 shows the wave form for a
module samples the SDA line low before asserting it Restart condition.
low. This does not conform to the I2C Specification that In 10-bit Addressing Slave mode a Restart is required
states no bus collision can occur on a Start. for the master to clock data out of the addressed
slave. Once a slave has been fully addressed, match-
26.8.6 STOP CONDITION ing both high and low address bytes, the master can
A Stop condition is a transition of the SDA line from issue a Restart and the high address byte with the
low-to-high state while the SCL line is high. R/W bit set. The slave logic will then hold the clock
and prepare to clock out data.
Note: At least one SCL low time must appear
After a full match with R/W clear in 10-bit mode, a prior
before a Stop is valid, therefore, if the SDA
match flag is set and maintained until a Stop condition, a
line goes low then high again while the SCL
high address with R/W clear, or high address match fails.
line stays high, only the Start condition is
detected.
26.8.8 START/STOP CONDITION
INTERRUPT MASKING
The SCIE and PCIE bits of the SSPxCON3 register
can enable the generation of an interrupt in Slave
modes that do not typically support this function. Slave
modes where interrupt on Start and Stop detect are
already enabled, these bits will have no effect.

FIGURE 26-12: I2C START AND STOP CONDITIONS

SDA

SCL
S P
Change of Change of
Data Allowed Data Allowed
Start Stop
Condition Condition

FIGURE 26-13: I2C RESTART CONDITION

Sr

Change of Change of
Data Allowed Data Allowed
Restart
Condition

2016 Microchip Technology Inc. Preliminary DS40001816C-page 354


PIC18(L)F26/45/46K40
26.8.9 ACKNOWLEDGE SEQUENCE 26.9.1.1 I2C Slave 7-bit Addressing Mode
The ninth SCL pulse for any transferred byte in I2C is In 7-bit Addressing mode, the LSb of the received data
dedicated as an Acknowledge. It allows receiving byte is ignored when determining if there is an address
devices to respond back to the transmitter by pulling match.
the SDA line low. The transmitter must release control
of the line during this time to shift in the response. The 26.9.1.2 I2C Slave 10-bit Addressing Mode
Acknowledge (ACK) is an active-low signal, pulling the In 10-bit Addressing mode, the first received byte is
SDA line low indicates to the transmitter that the compared to the binary value of 1 1 1 1 0 A9 A8 0. A9
device has received the transmitted data and is ready and A8 are the two MSbs of the 10-bit address and
to receive more. stored in bits 2 and 1 of the SSPxADD register.
The result of an ACK is placed in the ACKSTAT bit of After the acknowledge of the high byte the UA bit is set
the SSPxCON2 register. and SCL is held low until the user updates SSPxADD
Slave software, when the AHEN and DHEN bits are with the low address. The low address byte is clocked
set, allow the user to set the ACK value sent back to in and all eight bits are compared to the low address
the transmitter. The ACKDT bit of the SSPxCON2 reg- value in SSPxADD. Even if there is not an address
ister is set/cleared to determine the response. match; SSPxIF and UA are set, and SCL is held low
until SSPxADD is updated to receive a high byte
Slave hardware will generate an ACK response if the
again. When SSPxADD is updated the UA bit is
AHEN and DHEN bits of the SSPxCON3 register are
cleared. This ensures the module is ready to receive
clear.
the high address byte on the next communication.
There are certain conditions where an ACK will not be
A high and low address match as a write request is
sent by the slave. If the BF bit of the SSPxSTAT regis-
required at the start of all 10-bit addressing communi-
ter or the SSPOV bit of the SSPxCON1 register are
cation. A transmission can be initiated by issuing a
set when a byte is received.
Restart once the slave is addressed, and clocking in
When the module is addressed, after the eighth falling the high address with the R/W bit set. The slave
edge of SCL on the bus, the ACKTIM bit of the hardware will then acknowledge the read request and
SSPxCON3 register is set. The ACKTIM bit indicates prepare to clock out data. This is only valid for a slave
the acknowledge time of the active bus. The ACKTIM after it has received a complete high and low address
Status bit is only active when the AHEN bit or DHEN byte match.
bit is enabled.
26.9.2 SLAVE RECEPTION
26.9 I2C Slave Mode Operation When the R/W bit of a matching received address byte
The MSSP Slave mode operates in one of four modes is clear, the R/W bit of the SSPxSTAT register is
selected by the SSPM bits of the SSPxCON1 register. cleared. The received address is loaded into the
The modes can be divided into 7-bit and 10-bit SSPxBUF register and acknowledged.
Addressing mode. 10-bit Addressing modes operate When the overflow condition exists for a received
the same as 7-bit with some additional overhead for address, then not Acknowledge is given. An overflow
handling the larger addresses. condition is defined as either bit BF of the SSPxSTAT
Modes with Start and Stop bit interrupts operate the register is set, or bit SSPOV of the SSPxCON1 register
same as the other modes with SSPxIF additionally is set. The BOEN bit of the SSPxCON3 register modi-
getting set upon detection of a Start, Restart, or Stop fies this operation. For more information see
condition. Register 26-3.
An MSSP interrupt is generated for each transferred
26.9.1 SLAVE MODE ADDRESSES data byte. Flag bit, SSPxIF, must be cleared by soft-
The SSPxADD register (Register 26-5) contains the ware.
Slave mode address. The first byte received after a When the SEN bit of the SSPxCON2 register is set,
Start or Restart condition is compared against the SCL will be held low (clock stretch) following each
value stored in this register. If the byte matches, the received byte. The clock must be released by setting
value is loaded into the SSPxBUF register and an the CKP bit of the SSPxCON1 register, except
interrupt is generated. If the value does not match, the sometimes in 10-bit mode. See Section
module goes idle and no indication is given to the 26.9.6.2 10-bit Addressing Mode for more detail.
software that anything happened.
The SSP Mask register affects the address matching
process. See Section 26.9.9 SSP Mask Register
for more information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 355


PIC18(L)F26/45/46K40
26.9.2.1 7-bit Addressing Reception 26.9.2.2 7-bit Reception with AHEN and
This section describes a standard sequence of events DHEN
for the MSSP module configured as an I2C slave in Slave device reception with AHEN and DHEN set
7-bit Addressing mode. Figure 26-14 and Figure 26-15 operate the same as without these options with extra
is used as a visual reference for this description. interrupts and clock stretching added after the eighth
This is a step by step process of what typically must falling edge of SCL. These additional interrupts allow
be done to accomplish I2C communication. the slave software to decide whether it wants to ACK
the receive address or data byte, rather than the hard-
1. Start bit detected. ware. This functionality adds support for PMBus that
2. S bit of SSPxSTAT is set; SSPxIF is set if inter- was not present on previous versions of this module.
rupt on Start detect is enabled.
This list describes the steps that need to be taken by
3. Matching address with R/W bit clear is received. slave software to use these options for I2C communi-
4. The slave pulls SDA low sending an ACK to the cation. Figure 26-16 displays a module using both
master, and sets SSPxIF bit. address and data holding. Figure 26-17 includes the
5. Software clears the SSPxIF bit. operation with the SEN bit of the SSPxCON2 register
6. Software reads received address from set.
SSPxBUF clearing the BF flag. 1. S bit of SSPxSTAT is set; SSPxIF is set if inter-
7. If SEN = 1; Slave software sets CKP bit to rupt on Start detect is enabled.
release the SCL line. 2. Matching address with R/W bit clear is clocked
8. The master clocks out a data byte. in. SSPxIF is set and CKP cleared after the
9. Slave drives SDA low sending an ACK to the eighth falling edge of SCL.
master, and sets SSPxIF bit. 3. Slave clears the SSPxIF.
10. Software clears SSPxIF. 4. Slave can look at the ACKTIM bit of the
11. Software reads the received byte from SSPxCON3 register to determine if the SSPxIF
SSPxBUF clearing BF. was after or before the ACK.
12. Steps 8-12 are repeated for all received bytes 5. Slave reads the address value from SSPxBUF,
from the master. clearing the BF flag.
13. Master sends Stop condition, setting P bit of 6. Slave sets ACK value clocked out to the master
SSPxSTAT, and the bus goes idle. by setting ACKDT.
7. Slave releases the clock by setting CKP.
8. SSPxIF is set after an ACK, not after a NACK.
9. If SEN = 1 the slave hardware will stretch the
clock after the ACK.
10. Slave clears SSPxIF.
Note: SSPxIF is still set after the ninth falling edge
of SCL even if there is no clock stretching
and BF has been cleared. Only if NACK is
sent to master is SSPxIF not set
11. SSPxIF set and CKP cleared after eighth falling
edge of SCL for a received data byte.
12. Slave looks at ACKTIM bit of SSPxCON3 to
determine the source of the interrupt.
13. Slave reads the received data from SSPxBUF
clearing BF.
14. Steps 7-14 are the same for each received data
byte.
15. Communication is ended by either the slave
sending an ACK = 1, or the master sending a
Stop condition. If a Stop is sent and Interrupt on
Stop Detect is disabled, the slave will only know
by polling the P bit of the SSTSTAT register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 356


FIGURE 26-14: I2C SLAVE, 7-BIT ADDRESS, RECEPTION (SEN = 0, AHEN = 0, DHEN = 0)
2016 Microchip Technology Inc.

Bus Master sends


Stop condition
From Slave to Master

Receiving Address Receiving Data Receiving Data ACK = 1


SDA
A7 A6 A5 A4 A3 A2 A1 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
S P

SSPxIF
SSPxIF set on 9th
Cleared by software Cleared by software falling edge of
SCL
Preliminary

BF
First byte
SSPxBUF is read of data is
available
in SSPxBUF

PIC18(L)F26/45/46K40
SSPOV

SSPOV set because


SSPxBUF is still full.
ACK is not sent.
DS40001816C-page 357
FIGURE 26-15: I2C SLAVE, 7-BIT ADDRESS, RECEPTION (SEN = 1, AHEN = 0, DHEN = 0)
2016 Microchip Technology Inc.

Bus Master sends


Stop condition

Receive Address Receive Data Receive Data ACK


SDA A7 A6 A5 A4 A3 A2 A1 R/W=0 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL S 1 2 3 4 5 6 7 8 9 SEN 1 2 3 4 5 6 7 8 9 SEN 1 2 3 4 5 6 7 8 9 P

Clock is held low until CKP is set to 1

SSPxIF

SSPxIF set on 9th


Cleared by software Cleared by software falling edge of SCL
Preliminary

BF
First byte
of data is
SSPxBUF is read available

PIC18(L)F26/45/46K40
in SSPxBUF
SSPOV

SSPOV set because


SSPxBUF is still full.
ACK is not sent.
CKP

SCL is not held


CKP is written to 1 in software, CKP is written to 1 in software,
low because
releasing SCL releasing SCL
ACK= 1
DS40001816C-page 358
FIGURE 26-16: I2C SLAVE, 7-BIT ADDRESS, RECEPTION (SEN = 0, AHEN = 1, DHEN = 1)
2016 Microchip Technology Inc.

Master Releases SDA Master sends


to slave for ACK sequence Stop condition

SDA Receiving Address Receiving Data ACK Received Data ACK=1


A7 A6 A5 A4 A3 A2 A1 ACK D7 D6 D5 D4 D3 D2 D1 D0 D7 D6 D5 D4 D3 D2 D1 D0

SCL
S 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 P

SSPxIF
If AHEN = 1: SSPxIF is set on
SSPxIF is set 9th falling edge of Cleared by software No interrupt
SCL, after ACK after not ACK
BF from Slave
Address is
read from Data is read from SSPxBUF
ACKDT SSBUF
Preliminary

Slave software
clears ACKDT to Slave software
ACK the received sets ACKDT to
byte not ACK

PIC18(L)F26/45/46K40
CKP

When AHEN=1:
When DHEN=1: CKP set by software,
CKP is cleared by hardware
CKP is cleared by SCL is released
and SCL is stretched hardware on 8th falling
edge of SCL
ACKTIM

ACKTIM set by hardware ACKTIM cleared by ACKTIM set by hardware


on 8th falling edge of SCL hardware in 9th on 8th falling edge of SCL
rising edge of SCL

S
DS40001816C-page 359

P
FIGURE 26-17: I2C SLAVE, 7-BIT ADDRESS, RECEPTION (SEN = 1, AHEN = 1, DHEN = 1)
2016 Microchip Technology Inc.

Master sends
Stop condition
Master releases
R/W = 0 SDA to slave for ACK sequence
Receiving Address Receive Data Receive Data ACK
SDA ACK
A7 A6 A5 A4 A3 A2 A1 D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 P
S

SSPxIF
Cleared by software No interrupt after
if not ACK
from Slave
BF
Received
address is loaded into Received data is SSPxBUF can be
Preliminary

SSPxBUF available on SSPxBUF read any time before


next byte is loaded
ACKDT

Slave software clears


Slave sends

PIC18(L)F26/45/46K40
ACKDT to ACK not ACK
the received byte
CKP
When AHEN = 1; When DHEN = 1; CKP is not cleared
on the 8th falling edge on the 8th falling edge Set by software, if not ACK
of SCL of an address of SCL of a received release SCL
byte, CKP is cleared data byte, CKP is cleared

ACKTIM

ACKTIM is set by hardware ACKTIM is cleared by hardware


on 8th falling edge of SCL on 9th rising edge of SCL

S
DS40001816C-page 360

P
PIC18(L)F26/45/46K40
26.9.3 SLAVE TRANSMISSION 26.9.3.2 7-bit Transmission
When the R/W bit of the incoming address byte is set A master device can transmit a read request to a
and an address match occurs, the R/W bit of the slave, and then clock data out of the slave. The list
SSPxSTAT register is set. The received address is below outlines what software for a slave will need to
loaded into the SSPxBUF register, and an ACK pulse is do to accomplish a standard transmission.
sent by the slave on the ninth bit. Figure 26-18 can be used as a reference to this list.
Following the ACK, slave hardware clears the CKP bit 1. Master sends a Start condition on SDA and
and the SCL pin is held low (see Section SCL.
26.9.6 Clock Stretching for more detail). By 2. S bit of SSPxSTAT is set; SSPxIF is set if inter-
stretching the clock, the master will be unable to assert rupt on Start detect is enabled.
another clock pulse until the slave is done preparing 3. Matching address with R/W bit set is received by
the transmit data. the Slave setting SSPxIF bit.
The transmit data must be loaded into the SSPxBUF 4. Slave hardware generates an ACK and sets
register which also loads the SSPSR register. Then the SSPxIF.
SCL pin should be released by setting the CKP bit of 5. SSPxIF bit is cleared by user.
the SSPxCON1 register. The eight data bits are shifted
6. Software reads the received address from
out on the falling edge of the SCL input. This ensures
SSPxBUF, clearing BF.
that the SDA signal is valid during the SCL high time.
7. R/W is set so CKP was automatically cleared
The ACK pulse from the master-receiver is latched on after the ACK.
the rising edge of the ninth SCL input pulse. This ACK
8. The slave software loads the transmit data into
value is copied to the ACKSTAT bit of the SSPxCON2
SSPxBUF.
register. If ACKSTAT is set (not ACK), then the data
transfer is complete. In this case, when the not ACK is 9. CKP bit is set releasing SCL, allowing the
latched by the slave, the slave goes idle and waits for master to clock the data out of the slave.
another occurrence of the Start bit. If the SDA line was 10. SSPxIF is set after the ACK response from the
low (ACK), the next transmit data must be loaded into master is loaded into the ACKSTAT register.
the SSPxBUF register. Again, the SCL pin must be 11. SSPxIF bit is cleared.
released by setting bit CKP. 12. The slave software checks the ACKSTAT bit to
An MSSP interrupt is generated for each data transfer see if the master wants to clock out more data.
byte. The SSPxIF bit must be cleared by software and
Note 1: If the master ACKs the clock will be
the SSPxSTAT register is used to determine the status
stretched.
of the byte. The SSPxIF bit is set on the falling edge of
the ninth clock pulse. 2: ACKSTAT is the only bit updated on the
rising edge of SCL (9th) rather than the
26.9.3.1 Slave Mode Bus Collision falling.
A slave receives a Read request and begins shifting 13. Steps 9-13 are repeated for each transmitted
data out on the SDA line. If a bus collision is detected byte.
and the SBCDE bit of the SSPxCON3 register is set, 14. If the master sends a not ACK; the clock is not
the BCLxIF bit of the PIR register is set. Once a bus col- held, but SSPxIF is still set.
lision is detected, the slave goes idle and waits to be
15. The master sends a Restart condition or a Stop.
addressed again. User software can use the BCLxIF bit
to handle a slave bus collision. 16. The slave is no longer addressed.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 361


FIGURE 26-18: I2C SLAVE, 7-BIT ADDRESS, TRANSMISSION (AHEN = 0)
2016 Microchip Technology Inc.

Master sends
Stop condition

Receiving Address ACK


R/W = 1 Automatic Transmitting Data Automatic Transmitting Data
SDA A7 A6 A5 A4 A3 A2 A1 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
S P

SSPxIF

Cleared by software

BF
BF is automatically
Received address Data to transmit is cleared after 8th falling
is read from SSPxBUF loaded into SSPxBUF edge of SCL

CKP
Preliminary

When R/W is set CKP is not


SCL is always held for not
held low after 9th SCL Set by software ACK
falling edge
ACKSTAT

PIC18(L)F26/45/46K40
Masters not ACK
is copied to
ACKSTAT
R/W
R/W is copied from the
matching address byte
D/A

Indicates an address
has been received

S
DS40001816C-page 362

P
PIC18(L)F26/45/46K40
26.9.3.3 7-bit Transmission with Address
Hold Enabled
Setting the AHEN bit of the SSPxCON3 register
enables additional clock stretching and interrupt
generation after the eighth falling edge of a received
matching address. Once a matching address has
been clocked in, CKP is cleared and the SSPxIF
interrupt is set.
Figure 26-19 displays a standard waveform of a 7-bit
address slave transmission with AHEN enabled.
1. Bus starts Idle.
2. Master sends Start condition; the S bit of
SSPxSTAT is set; SSPxIF is set if interrupt on
Start detect is enabled.
3. Master sends matching address with R/W bit
set. After the eighth falling edge of the SCL line
the CKP bit is cleared and SSPxIF interrupt is
generated.
4. Slave software clears SSPxIF.
5. Slave software reads the ACKTIM bit of
SSPxCON3 register, and R/W and D/A of the
SSPxSTAT register to determine the source of
the interrupt.
6. Slave reads the address value from the
SSPxBUF register clearing the BF bit.
7. Slave software decides from this information if it
wishes to ACK or not ACK and sets the ACKDT
bit of the SSPxCON2 register accordingly.
8. Slave sets the CKP bit releasing SCL.
9. Master clocks in the ACK value from the slave.
10. Slave hardware automatically clears the CKP bit
and sets SSPxIF after the ACK if the R/W bit is
set.
11. Slave software clears SSPxIF.
12. Slave loads value to transmit to the master into
SSPxBUF setting the BF bit.
Note: SSPxBUF cannot be loaded until after the
ACK.
13. Slave sets the CKP bit releasing the clock.
14. Master clocks out the data from the slave and
sends an ACK value on the ninth SCL pulse.
15. Slave hardware copies the ACK value into the
ACKSTAT bit of the SSPxCON2 register.
16. Steps 10-15 are repeated for each byte transmit-
ted to the master from the slave.
17. If the master sends a not ACK the slave
releases the bus allowing the master to send a
Stop and end the communication.

Note: Master must send a not ACK on the last


byte to ensure that the slave releases the
SCL line to receive a Stop.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 363


FIGURE 26-19: I2C SLAVE, 7-BIT ADDRESS, TRANSMISSION (AHEN = 1)
2016 Microchip Technology Inc.

Master sends
Master releases SDA Stop condition
to slave for ACK sequence
Receiving Address R/W = 1 Automatic Transmitting Data Automatic Transmitting Data ACK
SDA
A7 A6 A5 A4 A3 A2 A1 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL
S 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
P

SSPxIF
Cleared by software

BF BF is automatically
Received address Data to transmit is cleared after 8th falling
is read from SSPxBUF loaded into SSPxBUF edge of SCL

ACKDT
Preliminary

Slave clears
ACKDT to ACK
address

PIC18(L)F26/45/46K40
ACKSTAT
Masters ACK
response is copied
to SSPxSTAT
CKP
When AHEN = 1; CKP not cleared
CKP is cleared by hardware When R/W = 1; Set by software, after not ACK
after receiving matching CKP is always releases SCL
address. cleared after ACK

ACKTIM
ACKTIM is set on 8th falling ACKTIM is cleared
edge of SCL on 9th rising edge of SCL

R/W
DS40001816C-page 364

D/A
PIC18(L)F26/45/46K40
26.9.4 SLAVE MODE 10-BIT ADDRESS 26.9.5 10-BIT ADDRESSING WITH
RECEPTION ADDRESS OR DATA HOLD
This section describes a standard sequence of events Reception using 10-bit addressing with AHEN or
for the MSSP module configured as an I2C slave in DHEN set is the same as with 7-bit modes. The only
10-bit Addressing mode. difference is the need to update the SSPxADD register
Figure 26-20 is used as a visual reference for this using the UA bit. All functionality, specifically when the
description. CKP bit is cleared and SCL line is held low are the
same. Figure 26-21 can be used as a reference of a
This is a step by step process of what must be done by slave in 10-bit addressing with AHEN set.
slave software to accomplish I2C communication.
Figure 26-22 shows a standard waveform for a slave
1. Bus starts Idle. transmitter in 10-bit Addressing mode.
2. Master sends Start condition; S bit of SSPxSTAT
is set; SSPxIF is set if interrupt on Start detect is
enabled.
3. Master sends matching high address with R/W
bit clear; UA bit of the SSPxSTAT register is set.
4. Slave sends ACK and SSPxIF is set.
5. Software clears the SSPxIF bit.
6. Software reads received address from
SSPxBUF clearing the BF flag.
7. Slave loads low address into SSPxADD,
releasing SCL.
8. Master sends matching low address byte to the
slave; UA bit is set.
Note: Updates to the SSPxADD register are not
allowed until after the ACK sequence.

9. Slave sends ACK and SSPxIF is set.


Note: If the low address does not match, SSPxIF
and UA are still set so that the slave soft-
ware can set SSPxADD back to the high
address. BF is not set because there is no
match. CKP is unaffected.
10. Slave clears SSPxIF.
11. Slave reads the received matching address
from SSPxBUF clearing BF.
12. Slave loads high address into SSPxADD.
13. Master clocks a data byte to the slave and
clocks out the slaves ACK on the ninth SCL
pulse; SSPxIF is set.
14. If SEN bit of SSPxCON2 is set, CKP is cleared
by hardware and the clock is stretched.
15. Slave clears SSPxIF.
16. Slave reads the received byte from SSPxBUF
clearing BF.
17. If SEN is set the slave sets CKP to release the
SCL.
18. Steps 13-17 repeat for each received byte.
19. Master sends Stop to end the transmission.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 365


FIGURE 26-20: I2C SLAVE, 10-BIT ADDRESS, RECEPTION (SEN = 1, AHEN = 0, DHEN = 0)
2016 Microchip Technology Inc.

Master sends
Stop condition

Receive First Address Byte Receive Second Address Byte Receive Data Receive Data
SDA
1 1 1 1
0 A9 A8 ACK A7 A6 A5 A4 A3 A2 A1 A0 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK

SCL
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 P
S
SCL is held low
while CKP = 0

SSPxIF
Set by hardware Cleared by software
on 9th falling edge
Preliminary

BF
If address matches Receive address is Data is read
SSPxADD it is loaded into read from SSPxBUF from SSPxBUF

PIC18(L)F26/45/46K40
SSPxBUF

UA
When UA = 1; Software updates SSPxADD
SCL is held low and releases SCL

CKP

When SEN = 1; Set by software,


CKP is cleared after releasing SCL
9th falling edge of received byte
DS40001816C-page 366
FIGURE 26-21: I2C SLAVE, 10-BIT ADDRESS, RECEPTION (SEN = 0, AHEN = 1, DHEN = 0)
2016 Microchip Technology Inc.

Receive First Address Byte R/W = 0 Receive Second Address Byte Receive Data Receive Data
SDA 1 1 1 1 0 A9 A8 ACK A7 A6 A5 A4 A3 A2 A1 A0 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5

SCL S 1 2 3 4 5 6 7 8 9 UA 1 2 3 4 5 6 7 8 9 UA 1 2 3 4 5 6 7 8 9 1 2

SSPxIF
Set by hardware Cleared by software Cleared by software
on 9th falling edge

BF
Preliminary

SSPxBUF can be Received data


read anytime before is read from
the next received byte SSPxBUF

PIC18(L)F26/45/46K40
ACKDT
Slave software clears
ACKDT to ACK
the received byte

UA

Update to SSPxADD is Update of SSPxADD,


not allowed until 9th
falling edge of SCL clears UA and releases
SCL

CKP If when AHEN = 1;


on the 8th falling edge Set CKP with software
of SCL of an address releases SCL
byte, CKP is cleared
DS40001816C-page 367

ACKTIM
ACKTIM is set by hardware
on 8th falling edge of SCL
FIGURE 26-22: I2C SLAVE, 10-BIT ADDRESS, TRANSMISSION (SEN = 0, AHEN = 0, DHEN = 0)
2016 Microchip Technology Inc.

Master sends
Master sends Stop condition
Restart event Master sends
not ACK

Receiving Address R/W = 0 Receiving Second Address Byte Receive First Address Byte Transmitting Data Byte ACK = 1
SDA 1 1 1 1 0 A9 A8 ACK A7 A6 A5 A4 A3 A2 A1 A0 ACK 1 1 1 1 0 A9 A8 ACK D7 D6 D5 D4 D3 D2 D1 D0

SCL 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 P
S
Sr

SSPxIF

Set by hardware Cleared by software Set by hardware

BF

SSPxBUF loaded Received address is Data to transmit is


Preliminary

with received address read from SSPxBUF loaded into SSPxBUF


UA
High address is loaded
UA indicates SSPxADD After SSPxADD is back into SSPxADD

PIC18(L)F26/45/46K40
must be updated updated, UA is cleared
CKP and SCL is released

When R/W = 1; Set by software


ACKSTAT CKP is cleared on releases SCL
9th falling edge of SCL

Masters not ACK


is copied
R/W
R/W is copied from the
matching address byte
D/A

Indicates an address
has been received
DS40001816C-page 368
PIC18(L)F26/45/46K40
26.9.6 CLOCK STRETCHING 26.9.6.2 10-bit Addressing Mode
Clock stretching occurs when a device on the bus In 10-bit Addressing mode, when the UA bit is set, the
holds the SCL line low, effectively pausing communi- clock is always stretched. This is the only time the SCL
cation. The slave may stretch the clock to allow more is stretched without CKP being cleared. SCL is
time to handle data or prepare a response for the released immediately after a write to SSPxADD.
master device. A master device is not concerned with
Note: Previous versions of the module did not
stretching as anytime it is active on the bus and not
stretch the clock if the second address byte
transferring data it is stretching. Any stretching done
did not match.
by a slave is invisible to the master software and
handled by the hardware that generates SCL.
26.9.6.3 Byte NACKing
The CKP bit of the SSPxCON1 register is used to
control stretching in software. Any time the CKP bit is When the AHEN bit of SSPxCON3 is set; CKP is
cleared, the module will wait for the SCL line to go low cleared by hardware after the eighth falling edge of
and then hold it. Setting CKP will release SCL and SCL for a received matching address byte. When the
allow more communication. DHEN bit of SSPxCON3 is set; CKP is cleared after
the eighth falling edge of SCL for received data.
26.9.6.1 Normal Clock Stretching Stretching after the eighth falling edge of SCL allows
Following an ACK if the R/W bit of SSPxSTAT is set, a the slave to look at the received address or data and
read request, the slave hardware will clear CKP. This decide if it wants to ACK the received data.
allows the slave time to update SSPxBUF with data to
transfer to the master. If the SEN bit of SSPxCON2 is 26.9.7 CLOCK SYNCHRONIZATION AND
set, the slave hardware will always stretch the clock THE CKP BIT
after the ACK sequence. Once the slave is ready; CKP Any time the CKP bit is cleared, the module will wait
is set by software and communication resumes. for the SCL line to go low and then hold it. However,
clearing the CKP bit will not assert the SCL output low
Note 1: The BF bit has no effect on if the clock will
until the SCL output is already sampled low. There-
be stretched or not. This is different than
fore, the CKP bit will not assert the SCL line until an
previous versions of the module that
external I2C master device has already asserted the
would not stretch the clock, clear CKP, if
SCL line. The SCL output will remain low until the CKP
SSPxBUF was read before the ninth
bit is set and all other devices on the I2C bus have
falling edge of SCL.
released SCL. This ensures that a write to the CKP bit
2: Previous versions of the module did not will not violate the minimum high time requirement for
stretch the clock for a transmission if SCL (see Figure 26-23).
SSPxBUF was loaded before the ninth
falling edge of SCL. It is now always
cleared for read requests.

FIGURE 26-23: CLOCK SYNCHRONIZATION TIMING

Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4

SDA DX DX 1

SCL

Master device
CKP asserts clock

Master device
releases clock
WR
SSPxCON1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 369


PIC18(L)F26/45/46K40
26.9.8 GENERAL CALL ADDRESS If the AHEN bit of the SSPxCON3 register is set, just
SUPPORT as with any other address reception, the slave
hardware will stretch the clock after the eighth falling
The addressing procedure for the I2C bus is such that
edge of SCL. The slave must then set its ACKDT
the first byte after the Start condition usually deter-
value and release the clock with communication
mines which device will be the slave addressed by the
progressing as it would normally.
master device. The exception is the general call
address which can address all devices. When this 26.9.9 SSP MASK REGISTER
address is used, all devices should, in theory, respond
with an acknowledge. An SSP Mask (SSPxMSK) register (Register 26-12) is
available in I2C Slave mode as a mask for the value
The general call address is a reserved address in the held in the SSPSR register during an address
I2C protocol, defined as address 0x00. When the comparison operation. A zero (0) bit in the SSPxMSK
GCEN bit of the SSPxCON2 register is set, the slave register has the effect of making the corresponding bit
module will automatically ACK the reception of this of the received address a dont care.
address regardless of the value stored in SSPxADD.
After the slave clocks in an address of all zeros with This register is reset to all 1s upon any Reset
the R/W bit clear, an interrupt is generated and slave condition and, therefore, has no effect on standard
software can read SSPxBUF and respond. SSP operation until written with a mask value.
Figure 26-24 shows a general call reception The SSP Mask register is active during:
sequence.
7-bit Address mode: address compare of A<7:1>.
In 10-bit Address mode, the UA bit will not be set on
10-bit Address mode: address compare of A<7:0>
the reception of the general call address. The slave
only. The SSP mask has no effect during the reception
will prepare to receive the second byte as data, just as
of the first (high) byte of the address.
it would in 7-bit mode.

FIGURE 26-24: SLAVE MODE GENERAL CALL ADDRESS SEQUENCE


Address is compared to General Call Address
after ACK, set interrupt

R/W = 0 Receiving Data ACK


General Call Address ACK D7
SDA D6 D5 D4 D3 D2 D1 D0

SCL
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
S

SSPxIF

BF (SSPxSTAT<0>)

Cleared by software
SSPxBUF is read
GCEN (SSPxCON2<7>)
1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 370


PIC18(L)F26/45/46K40
26.10 I2C Master Mode 26.10.1 I2C MASTER MODE OPERATION
Master mode is enabled by setting and clearing the The master device generates all of the serial clock
appropriate SSPM bits in the SSPxCON1 register and pulses and the Start and Stop conditions. A transfer is
by setting the SSPEN bit. In Master mode, the SDA and ended with a Stop condition or with a Repeated Start
SCK pins must be configured as inputs. The MSSP condition. Since the Repeated Start condition is also
peripheral hardware will override the output driver TRIS the beginning of the next serial transfer, the I2C bus will
controls when necessary to drive the pins low. not be released.

Master mode of operation is supported by interrupt In Master Transmitter mode, serial data is output
generation on the detection of the Start and Stop through SDA, while SCL outputs the serial clock. The
conditions. The Stop (P) and Start (S) bits are cleared first byte transmitted contains the slave address of the
from a Reset or when the MSSP module is disabled. receiving device (7 bits) and the Read/Write (R/W) bit.
Control of the I 2C bus may be taken when the P bit is In this case, the R/W bit will be logic 0. Serial data is
set, or the bus is Idle. transmitted eight bits at a time. After each byte is
transmitted, an Acknowledge bit is received. Start and
In Firmware Controlled Master mode, user code Stop conditions are output to indicate the beginning
conducts all I 2C bus operations based on Start and and the end of a serial transfer.
Stop bit condition detection. Start and Stop condition
detection is the only active circuitry in this mode. All In Master Receive mode, the first byte transmitted
other communication is done by the user software contains the slave address of the transmitting device
directly manipulating the SDA and SCL lines. (7 bits) and the R/W bit. In this case, the R/W bit will be
logic 1. Thus, the first byte transmitted is a 7-bit slave
The following events will cause the SSP Interrupt Flag address followed by a 1 to indicate the receive bit.
bit, SSPxIF, to be set (SSP interrupt, if enabled): Serial data is received via SDA, while SCL outputs the
Start condition detected serial clock. Serial data is received eight bits at a time.
After each byte is received, an Acknowledge bit is
Stop condition detected
transmitted. Start and Stop conditions indicate the
Data transfer byte transmitted/received beginning and end of transmission.
Acknowledge transmitted/received
A Baud Rate Generator is used to set the clock
Repeated Start generated frequency output on SCL. See Section 26.11 Baud
Rate Generator for more detail.
Note 1: The MSSP module, when configured in
I2C Master mode, does not allow queuing
26.10.2 CLOCK ARBITRATION
of events. For instance, the user is not
allowed to initiate a Start condition and Clock arbitration occurs when the master, during any
immediately write the SSPxBUF register receive, transmit or Repeated Start/Stop condition,
to initiate transmission before the Start releases the SCL pin (SCL allowed to float high). When
condition is complete. In this case, the the SCL pin is allowed to float high, the Baud Rate
SSPxBUF will not be written to and the Generator (BRG) is suspended from counting until the
WCOL bit will be set, indicating that a SCL pin is actually sampled high. When the SCL pin is
write to the SSPxBUF did not occur sampled high, the Baud Rate Generator is reloaded
with the contents of SSPxADD<7:0> and begins count-
2: When in Master mode, Start/Stop
ing. This ensures that the SCL high time will always be
detection is masked and an interrupt is
at least one BRG rollover count in the event that the
generated when the SEN/PEN bit is
clock is held low by an external device (Figure 26-25).
cleared and the generation is complete.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 371


PIC18(L)F26/45/46K40
FIGURE 26-25: BAUD RATE GENERATOR TIMING WITH CLOCK ARBITRATION

SDA DX DX 1

SCL deasserted but slave holds SCL allowed to transition high


SCL low (clock arbitration)
SCL

BRG decrements on
Q2 and Q4 cycles

BRG
03h 02h 01h 00h (hold off) 03h 02h
Value

SCL is sampled high, reload takes


place and BRG starts its count
BRG
Reload

26.10.3 WCOL STATUS FLAG the Start condition and causes the S bit of the
SSPxSTAT1 register to be set. Following this, the
If the user writes the SSPxBUF when a Start, Restart,
Baud Rate Generator is reloaded with the contents of
Stop, Receive or Transmit sequence is in progress, the
SSPxADD<7:0> and resumes its count. When the
WCOL bit is set and the contents of the buffer are
Baud Rate Generator times out (TBRG), the SEN bit of
unchanged (the write does not occur). Any time the
the SSPxCON2 register will be automatically cleared
WCOL bit is set it indicates that an action on SSPxBUF
by hardware; the Baud Rate Generator is suspended,
was attempted while the module was not idle.
leaving the SDA line held low and the Start condition is
Note: Because queuing of events is not allowed, complete.
writing to the lower five bits of SSPxCON2
Note 1: If at the beginning of the Start condition,
is disabled until the Start condition is
the SDA and SCL pins are already
complete.
sampled low, or if during the Start condi-
tion, the SCL line is sampled low before
26.10.4 I2C MASTER MODE START
the SDA line is driven low, a bus collision
CONDITION TIMING occurs, the Bus Collision Interrupt Flag,
To initiate a Start condition (Figure 26-26), the user BCLxIF, is set, the Start condition is
sets the Start Enable bit, SEN bit of the SSPxCON2 aborted and the I2C module is reset into
register. If the SDA and SCL pins are sampled high, its Idle state.
the Baud Rate Generator is reloaded with the contents 2: The Philips I2C specification states that a
of SSPxADD<7:0> and starts its count. If SCL and bus collision cannot occur on a Start.
SDA are both sampled high when the Baud Rate Gen-
erator times out (TBRG), the SDA pin is driven low. The
action of the SDA being driven low while SCL is high is

FIGURE 26-26: FIRST START BIT TIMING

Write to SEN bit occurs here Set S bit (SSPxSTAT<3>)

At completion of Start bit,


SDA = 1,
SCL = 1 hardware clears SEN bit
and sets SSPxIF bit
TBRG TBRG Write to SSPxBUF occurs here
SDA 1st bit 2nd bit

TBRG
SCL
S
TBRG

2016 Microchip Technology Inc. Preliminary DS40001816C-page 372


PIC18(L)F26/45/46K40
26.10.5 I2C MASTER MODE REPEATED 26.10.6 I2C MASTER MODE
START CONDITION TIMING TRANSMISSION
A Repeated Start condition (Figure 26-27) occurs when Transmission of a data byte, a 7-bit address or the
the RSEN bit of the SSPxCON2 register is pro- other half of a 10-bit address is accomplished by simply
grammed high and the master state machine is no lon- writing a value to the SSPxBUF register. This action will
ger active. When the RSEN bit is set, the SCL pin is set the Buffer Full flag bit, BF, and allow the Baud Rate
asserted low. When the SCL pin is sampled low, the Generator to begin counting and start the next trans-
Baud Rate Generator is loaded and begins counting. mission. Each bit of address/data will be shifted out
The SDA pin is released (brought high) for one Baud onto the SDA pin after the falling edge of SCL is
Rate Generator count (TBRG). When the Baud Rate asserted. SCL is held low for one Baud Rate Generator
Generator times out, if SDA is sampled high, the SCL rollover count (TBRG). Data should be valid before SCL
pin will be deasserted (brought high). When SCL is is released high. When the SCL pin is released high, it
sampled high, the Baud Rate Generator is reloaded is held that way for TBRG. The data on the SDA pin
and begins counting. SDA and SCL must be sampled must remain stable for that duration and some hold
high for one TBRG. This action is then followed by time after the next falling edge of SCL. After the eighth
assertion of the SDA pin (SDA = 0) for one TBRG while bit is shifted out (the falling edge of the eighth clock),
SCL is high. SCL is asserted low. Following this, the the BF flag is cleared and the master releases SDA.
RSEN bit of the SSPxCON2 register will be automati- This allows the slave device being addressed to
cally cleared and the Baud Rate Generator will not be respond with an ACK bit during the ninth bit time if an
reloaded, leaving the SDA pin held low. As soon as a address match occurred, or if data was received prop-
Start condition is detected on the SDA and SCL pins, erly. The status of ACK is written into the ACKSTAT bit
the S bit of the SSPxSTAT register will be set. The on the rising edge of the ninth clock. If the master
SSPxIF bit will not be set until the Baud Rate Generator receives an Acknowledge, the Acknowledge Status bit,
has timed out. ACKSTAT, is cleared. If not, the bit is set. After the ninth
clock, the SSPxIF bit is set and the master clock (Baud
Note 1: If RSEN is programmed while any other
Rate Generator) is suspended until the next data byte
event is in progress, it will not take effect.
is loaded into the SSPxBUF, leaving SCL low and SDA
2: A bus collision during the Repeated Start unchanged (Figure 26-28).
condition occurs if:
SDA is sampled low when SCL
goes from low-to-high.
SCL goes low before SDA is
asserted low. This may indicate
that another master is attempting
to transmit a data 1.

FIGURE 26-27: REPEATED START CONDITION WAVEFORM

S bit set by hardware


Write to SSPxCON2
occurs here At completion of Start bit,
SDA = 1, SDA = 1,
hardware clears the RSEN bit
SCL (no change) SCL = 1 and sets SSPxIF

TBRG TBRG TBRG

SDA 1st bit

Write to SSPxBUF occurs here


TBRG
SCL
Sr TBRG
Repeated Start

2016 Microchip Technology Inc. Preliminary DS40001816C-page 373


PIC18(L)F26/45/46K40
After the write to the SSPxBUF, each bit of the address 9. The user loads the SSPxBUF with eight bits of
will be shifted out on the falling edge of SCL until all data.
seven address bits and the R/W bit are completed. On 10. Data is shifted out the SDA pin until all eight bits
the falling edge of the eighth clock, the master will are transmitted.
release the SDA pin, allowing the slave to respond with 11. The MSSP module shifts in the ACK bit from the
an Acknowledge. On the falling edge of the ninth clock, slave device and writes its value into the
the master will sample the SDA pin to see if the address ACKSTAT bit of the SSPxCON2 register.
was recognized by a slave. The status of the ACK bit is
12. Steps 8-11 are repeated for all transmitted data
loaded into the ACKSTAT Status bit of the SSPxCON2
bytes.
register. Following the falling edge of the ninth clock
transmission of the address, the SSPxIF is set, the BF 13. The user generates a Stop or Restart condition
flag is cleared and the Baud Rate Generator is turned by setting the PEN or RSEN bits of the
off until another write to the SSPxBUF takes place, SSPxCON2 register. Interrupt is generated once
holding SCL low and allowing SDA to float. the Stop/Restart condition is complete.

26.10.6.1 BF Status Flag


In Transmit mode, the BF bit of the SSPxSTAT register
is set when the CPU writes to SSPxBUF and is cleared
when all eight bits are shifted out.

26.10.6.2 WCOL Status Flag


If the user writes the SSPxBUF when a transmit is
already in progress (i.e., SSPSR is still shifting out a
data byte), the WCOL bit is set and the contents of the
buffer are unchanged (the write does not occur).
The WCOL bit must be cleared by software before the
next transmission.

26.10.6.3 ACKSTAT Status Flag


In Transmit mode, the ACKSTAT bit of the SSPxCON2
register is cleared when the slave has sent an Acknowl-
edge (ACK = 0) and is set when the slave does not
Acknowledge (ACK = 1). A slave sends an Acknowl-
edge when it has recognized its address (including a
general call), or when the slave has properly received
its data.

26.10.6.4 Typical transmit sequence:


1. The user generates a Start condition by setting
the SEN bit of the SSPxCON2 register.
2. SSPxIF is set by hardware on completion of the
Start.
3. SSPxIF is cleared by software.
4. The MSSP module will wait the required start
time before any other operation takes place.
5. The user loads the SSPxBUF with the slave
address to transmit.
6. Address is shifted out the SDA pin until all eight
bits are transmitted. Transmission begins as
soon as SSPxBUF is written to.
7. The MSSP module shifts in the ACK bit from the
slave device and writes its value into the
ACKSTAT bit of the SSPxCON2 register.
8. The MSSP module generates an interrupt at the
end of the ninth clock cycle by setting the
SSPxIF bit.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 374


FIGURE 26-28: I2C MASTER MODE WAVEFORM (TRANSMISSION, 7 OR 10-BIT ADDRESS)
2016 Microchip Technology Inc.

Write SSPxCON2<0> SEN = 1 ACKSTAT in


Start condition begins SSPxCON2 = 1
From slave, clear ACKSTAT bit SSPxCON2<6>
SEN = 0
R/W = 0 Transmitting Data or Second Half
Transmit Address to Slave of 10-bit Address ACK

SDA A7 A6 A5 A4 A3 A2 A1 ACK = 0 D7 D6 D5 D4 D3 D2 D1 D0

SSPxBUF written with 7-bit address and R/W


start transmit
SCL 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
S P
SCL held low
while CPU
responds to SSPxIF
SSPxIF
Cleared by software service routine
Cleared by software from SSP interrupt
Cleared by software
Preliminary

BF (SSPxSTAT<0>)

SSPxBUF written SSPxBUF is written by software

PIC18(L)F26/45/46K40
SEN

After Start condition, SEN cleared by hardware

PEN

R/W
DS40001816C-page 375
PIC18(L)F26/45/46K40
26.10.7 I2C Master Mode Reception 26.10.7.4 Typical Receive Sequence:
Master mode reception (Figure 26-29) is enabled by 1. The user generates a Start condition by setting
programming the Receive Enable bit, RCEN bit of the the SEN bit of the SSPxCON2 register.
SSP1CON2 register. 2. SSPxIF is set by hardware on completion of the
Note: The MSSP module must be in an Idle Start.
state before the RCEN bit is set or the 3. SSPxIF is cleared by software.
RCEN bit will be disregarded. 4. User writes SSPxBUF with the slave address to
transmit and the R/W bit set.
The Baud Rate Generator begins counting and on each
rollover, the state of the SCL pin changes 5. Address is shifted out the SDA pin until all eight
(high-to-low/low-to-high) and data is shifted into the bits are transmitted. Transmission begins as
SSPSR. After the falling edge of the eighth clock, the soon as SSPxBUF is written to.
receive enable flag is automatically cleared, the 6. The MSSP module shifts in the ACK bit from the
contents of the SSPSR are loaded into the SSPxBUF, slave device and writes its value into the
the BF flag bit is set, the SSPxIF flag bit is set and the ACKSTAT bit of the SSPxCON2 register.
Baud Rate Generator is suspended from counting, 7. The MSSP module generates an interrupt at the
holding SCL low. The MSSP is now in Idle state end of the ninth clock cycle by setting the
awaiting the next command. When the buffer is read by SSPxIF bit.
the CPU, the BF flag bit is automatically cleared. The 8. User sets the RCEN bit of the SSPxCON2 regis-
user can then send an Acknowledge bit at the end of ter and the master clocks in a byte from the slave.
reception by setting the Acknowledge Sequence 9. After the eighth falling edge of SCL, SSPxIF and
Enable, ACKEN bit of the SSPxCON2 register. BF are set.
26.10.7.1 BF Status Flag 10. Master clears SSPxIF and reads the received
byte from SSPUF, clears BF.
In receive operation, the BF bit is set when an address
11. Master sets the ACK value sent to slave in the
or data byte is loaded into SSPxBUF from SSPSR. It is
ACKDT bit of the SSPxCON2 register and initi-
cleared when the SSPxBUF register is read.
ates the ACK by setting the ACKEN bit.
26.10.7.2 SSPOV Status Flag 12. Masters ACK is clocked out to the slave and
SSPxIF is set.
In receive operation, the SSPOV bit is set when eight
bits are received into the SSPSR and the BF flag bit is 13. User clears SSPxIF.
already set from a previous reception. 14. Steps 8-13 are repeated for each received byte
from the slave.
26.10.7.3 WCOL Status Flag 15. Master sends a not ACK or Stop to end
If the user writes the SSPxBUF when a receive is communication.
already in progress (i.e., SSPSR is still shifting in a data
byte), the WCOL bit is set and the contents of the buffer
are unchanged (the write does not occur).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 376


FIGURE 26-29: I2C MASTER MODE WAVEFORM (RECEPTION, 7-BIT ADDRESS)
2016 Microchip Technology Inc.

Write to SSPxCON2<4>
to start Acknowledge sequence
SDA = ACKDT (SSPxCON2<5>) = 0
Write to SSPxCON2<0>(SEN = 1),
begin Start condition ACK from Master Set ACKEN, start Acknowledge sequence
Master configured as a receiver SDA = ACKDT = 0 SDA = ACKDT = 1
SEN = 0 by programming SSPxCON2<3> (RCEN = 1)
PEN bit = 1
Write to SSPxBUF occurs here, RCEN cleared RCEN = 1, start RCEN cleared
ACK from Slave next receive automatically written here
start XMIT automatically
Transmit Address to Slave Receiving Data from Slave Receiving Data from Slave
SDA A7 A6 A5 A4 A3 A2 A1 R/W ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK D7 D6 D5 D4 D3 D2 D1 D0 ACK

Bus master
ACK is not sent terminates
transfer
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9
SCL S P
Data shifted in on falling edge of CLK Set SSPxIF at end
of receive Set SSPxIF interrupt
Set SSPxIF interrupt at end of Acknow-
Set SSPxIF interrupt ledge sequence
at end of receive at end of Acknowledge
SSPxIF sequence
Preliminary

Set P bit
Cleared by software Cleared by software Cleared by software Cleared by software (SSPxSTAT<4>)
SDA = 0, SCL = 1 Cleared in
while CPU software and SSPxIF
responds to SSPxIF

PIC18(L)F26/45/46K40
BF
(SSPxSTAT<0>) Last bit is shifted into SSPSR and
contents are unloaded into SSPxBUF

SSPOV

SSPOV is set because


SSPxBUF is still full

ACKEN

RCEN
DS40001816C-page 377

Master configured as a receiver RCEN cleared ACK from Master RCEN cleared
by programming SSPxCON2<3> (RCEN = 1) automatically SDA = ACKDT = 0 automatically
PIC18(L)F26/45/46K40
26.10.8 ACKNOWLEDGE SEQUENCE 26.10.9 STOP CONDITION TIMING
TIMING A Stop bit is asserted on the SDA pin at the end of a
An Acknowledge sequence is enabled by setting the receive/transmit by setting the Stop Sequence Enable
Acknowledge Sequence Enable bit, ACKEN bit of the bit, PEN bit of the SSPxCON2 register. At the end of a
SSPxCON2 register. When this bit is set, the SCL pin is receive/transmit, the SCL line is held low after the
pulled low and the contents of the Acknowledge data bit falling edge of the ninth clock. When the PEN bit is set,
are presented on the SDA pin. If the user wishes to the master will assert the SDA line low. When the SDA
generate an Acknowledge, then the ACKDT bit should line is sampled low, the Baud Rate Generator is
be cleared. If not, the user should set the ACKDT bit reloaded and counts down to 0. When the Baud Rate
before starting an Acknowledge sequence. The Baud Generator times out, the SCL pin will be brought high
Rate Generator then counts for one rollover period and one TBRG (Baud Rate Generator rollover count)
(TBRG) and the SCL pin is deasserted (pulled high). later, the SDA pin will be deasserted. When the SDA
When the SCL pin is sampled high (clock arbitration), pin is sampled high while SCL is high, the P bit of the
the Baud Rate Generator counts for TBRG. The SCL pin SSPxSTAT register is set. A TBRG later, the PEN bit is
is then pulled low. Following this, the ACKEN bit is auto- cleared and the SSPxIF bit is set (Figure 26-31).
matically cleared, the Baud Rate Generator is turned off
and the MSSP module then goes into Idle mode 26.10.9.1 WCOL Status Flag
(Figure 26-30). If the user writes the SSPxBUF when a Stop sequence
is in progress, then the WCOL bit is set and the
26.10.8.1 WCOL Status Flag contents of the buffer are unchanged (the write does
If the user writes the SSPxBUF when an Acknowledge not occur).
sequence is in progress, then the WCOL bit is set and
the contents of the buffer are unchanged (the write
does not occur).
FIGURE 26-30: ACKNOWLEDGE SEQUENCE WAVEFORM
Acknowledge sequence starts here, ACKEN automatically cleared
write to SSPxCON2
ACKEN = 1, ACKDT = 0
TBRG TBRG
SDA D0 ACK

SCL 8 9

SSPxIF

Cleared in
SSPxIF set at software
the end of receive Cleared in
software SSPxIF set at the end
of Acknowledge sequence
Note: TBRG = one Baud Rate Generator period.

FIGURE 26-31: STOP CONDITION RECEIVE OR TRANSMIT MODE


Write to SSPxCON2, SCL = 1 for TBRG, followed by SDA = 1 for TBRG
set PEN after SDA sampled high. P bit (SSPxSTAT<4>) is set.

Falling edge of PEN bit (SSPxCON2<2>) is cleared by


9th clock hardware and the SSPxIF bit is set
TBRG
SCL

SDA ACK

P
TBRG TBRG TBRG
SCL brought high after TBRG
SDA asserted low before rising edge of clock
to setup Stop condition

Note: TBRG = one Baud Rate Generator period.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 378


PIC18(L)F26/45/46K40
26.10.10 SLEEP OPERATION 26.10.13 MULTI -MASTER
While in Sleep mode, the I2C slavemodule can receive COMMUNICATION, BUS COLLISION
addresses or data and when an address match or AND BUS ARBITRATION
complete byte transfer occurs, wake the processor Multi-Master mode support is achieved by bus arbitra-
from Sleep (if the MSSP interrupt is enabled). tion. When the master outputs address/data bits onto
the SDA pin, arbitration takes place when the master
26.10.11 EFFECTS OF A RESET outputs a 1 on SDA, by letting SDA float high and
A Reset disables the MSSP module and terminates the another master asserts a 0. When the SCL pin floats
current transfer. high, data should be stable. If the expected data on
SDA is a 1 and the data sampled on the SDA pin is 0,
26.10.12 MULTI-MASTER MODE then a bus collision has taken place. The master will set
In Multi-Master mode, the interrupt generation on the the Bus Collision Interrupt Flag, BCLxIF and reset the
detection of the Start and Stop conditions allows the I2C port to its Idle state (Figure 26-32).
determination of when the bus is free. The Stop (P) and If a transmit was in progress when the bus collision
Start (S) bits are cleared from a Reset or when the occurred, the transmission is halted, the BF flag is
MSSP module is disabled. Control of the I 2C bus may cleared, the SDA and SCL lines are deasserted and the
be taken when the P bit of the SSPxSTAT register is SSPxBUF can be written to. When the user services
set, or the bus is Idle, with both the S and P bits clear. the bus collision Interrupt Service Routine and if the I2C
When the bus is busy, enabling the SSP interrupt will bus is free, the user can resume communication by
generate the interrupt when the Stop condition occurs. asserting a Start condition.
In multi-master operation, the SDA line must be If a Start, Repeated Start, Stop or Acknowledge condi-
monitored for arbitration to see if the signal level is the tion was in progress when the bus collision occurred, the
expected output level. This check is performed by condition is aborted, the SDA and SCL lines are
hardware with the result placed in the BCLxIF bit. deasserted and the respective control bits in the
The states where arbitration can be lost are: SSPxCON2 register are cleared. When the user ser-
vices the bus collision Interrupt Service Routine and if
Address Transfer the I2C bus is free, the user can resume communication
Data Transfer by asserting a Start condition.
A Start Condition The master will continue to monitor the SDA and SCL
A Repeated Start Condition pins. If a Stop condition occurs, the SSPxIF bit will be set.
An Acknowledge Condition A write to the SSPxBUF will start the transmission of
data at the first data bit, regardless of where the
transmitter left off when the bus collision occurred.
In Multi-Master mode, the interrupt generation on the
detection of Start and Stop conditions allows the deter-
mination of when the bus is free. Control of the I2C bus
can be taken when the P bit is set in the SSPxSTAT
register, or the bus is Idle and the S and P bits are
cleared.

FIGURE 26-32: BUS COLLISION TIMING FOR TRANSMIT AND ACKNOWLEDGE


Sample SDA. While SCL is high,
Data changes SDA line pulled low data does not match what is driven
while SCL = 0 by another source by the master.
Bus collision has occurred.
SDA released
by master

SDA

SCL Set bus collision


interrupt (BCLxIF)

BCLxIF

2016 Microchip Technology Inc. Preliminary DS40001816C-page 379


PIC18(L)F26/45/46K40
26.10.13.1 Bus Collision During a Start If the SDA pin is sampled low during this count, the
Condition BRG is reset and the SDA line is asserted early
(Figure 26-35). If, however, a 1 is sampled on the SDA
During a Start condition, a bus collision occurs if:
pin, the SDA pin is asserted low at the end of the BRG
a) SDA or SCL are sampled low at the beginning of count. The Baud Rate Generator is then reloaded and
the Start condition (Figure 26-33). counts down to zero; if the SCL pin is sampled as 0
b) SCL is sampled low before SDA is asserted low during this time, a bus collision does not occur. At the
(Figure 26-34). end of the BRG count, the SCL pin is asserted low.
During a Start condition, both the SDA and the SCL Note: The reason that bus collision is not a
pins are monitored. factor during a Start condition is that no
If the SDA pin is already low, or the SCL pin is already two bus masters can assert a Start condi-
low, then all of the following occur: tion at the exact same time. Therefore,
one master will always assert SDA before
the Start condition is aborted,
the other. This condition does not cause a
the BCLxIF flag is set and bus collision because the two masters
the MSSP module is reset to its Idle state must be allowed to arbitrate the first
(Figure 26-33). address following the Start condition. If the
The Start condition begins with the SDA and SCL pins address is the same, arbitration must be
deasserted. When the SDA pin is sampled high, the allowed to continue into the data portion,
Baud Rate Generator is loaded and counts down. If the Repeated Start or Stop conditions.
SCL pin is sampled low while SDA is high, a bus
collision occurs because it is assumed that another
master is attempting to drive a data 1 during the Start
condition.

FIGURE 26-33: BUS COLLISION DURING START CONDITION (SDA ONLY)


SDA goes low before the SEN bit is set.
Set BCLxIF,
S bit and SSPxIF set because
SDA = 0, SCL = 1.

SDA

SCL
Set SEN, enable Start SEN cleared automatically because of bus collision.
condition if SDA = 1, SCL = 1 SSPx module reset into Idle state.
SEN
SDA sampled low before
Start condition. Set BCLxIF.
S bit and SSPxIF set because
BCLxIF SDA = 0, SCL = 1.
SSPxIF and BCLxIF are
cleared by software

SSPxIF

SSPxIF and BCLxIF are


cleared by software

2016 Microchip Technology Inc. Preliminary DS40001816C-page 380


PIC18(L)F26/45/46K40
FIGURE 26-34: BUS COLLISION DURING START CONDITION (SCL = 0)
SDA = 0, SCL = 1

TBRG TBRG

SDA

SCL Set SEN, enable Start


sequence if SDA = 1, SCL = 1
SCL = 0 before SDA = 0,
bus collision occurs. Set BCLxIF.
SEN
SCL = 0 before BRG time-out,
bus collision occurs. Set BCLxIF.
BCLxIF
Interrupt cleared
by software
S 0 0

SSPxIF 0 0

FIGURE 26-35: BRG RESET DUE TO SDA ARBITRATION DURING START CONDITION
SDA = 0, SCL = 1
Set S Set SSPxIF
Less than TBRG
TBRG

SDA SDA pulled low by other master.


Reset BRG and assert SDA.

SCL S
SCL pulled low after BRG
time out
SEN
Set SEN, enable Start
sequence if SDA = 1, SCL = 1
BCLxIF 0

SSPxIF
SDA = 0, SCL = 1, Interrupts cleared
set SSPxIF by software

2016 Microchip Technology Inc. Preliminary DS40001816C-page 381


PIC18(L)F26/45/46K40
26.10.13.2 Bus Collision During a Repeated If SDA is low, a bus collision has occurred (i.e., another
Start Condition master is attempting to transmit a data 0, Figure 26-36).
If SDA is sampled high, the BRG is reloaded and begins
During a Repeated Start condition, a bus collision
counting. If SDA goes from high-to-low before the BRG
occurs if:
times out, no bus collision occurs because no two
a) A low level is sampled on SDA when SCL goes masters can assert SDA at exactly the same time.
from low level to high level (Case 1).
If SCL goes from high-to-low before the BRG times out
b) SCL goes low before SDA is asserted low, and SDA has not already been asserted, a bus collision
indicating that another master is attempting to occurs. In this case, another master is attempting to
transmit a data 1 (Case 2). transmit a data 1 during the Repeated Start condition,
When the user releases SDA and the pin is allowed to see Figure 26-37.
float high, the BRG is loaded with SSPxADD and If, at the end of the BRG time out, both SCL and SDA
counts down to zero. The SCL pin is then deasserted are still high, the SDA pin is driven low and the BRG is
and when sampled high, the SDA pin is sampled. reloaded and begins counting. At the end of the count,
regardless of the status of the SCL pin, the SCL pin is
driven low and the Repeated Start condition is
complete.

FIGURE 26-36: BUS COLLISION DURING A REPEATED START CONDITION (CASE 1)

SDA

SCL

Sample SDA when SCL goes high.


If SDA = 0, set BCLxIF and release SDA and SCL.

RSEN

BCLxIF

Cleared by software
S 0

SSPxIF 0

FIGURE 26-37: BUS COLLISION DURING REPEATED START CONDITION (CASE 2)

TBRG TBRG

SDA

SCL

SCL goes low before SDA,


BCLxIF set BCLxIF. Release SDA and SCL.
Interrupt cleared
by software
RSEN

S 0

SSPxIF

2016 Microchip Technology Inc. Preliminary DS40001816C-page 382


PIC18(L)F26/45/46K40
26.10.13.3 Bus Collision During a Stop The Stop condition begins with SDA asserted low.
Condition When SDA is sampled low, the SCL pin is allowed to
float. When the pin is sampled high (clock arbitration),
Bus collision occurs during a Stop condition if:
the Baud Rate Generator is loaded with SSPxADD and
a) After the SDA pin has been deasserted and counts down to zero. After the BRG times out, SDA is
allowed to float high, SDA is sampled low after sampled. If SDA is sampled low, a bus collision has
the BRG has timed out (Case 1). occurred. This is due to another master attempting to
b) After the SCL pin is deasserted, SCL is sampled drive a data 0 (Figure 26-38). If the SCL pin is sampled
low before SDA goes high (Case 2). low before SDA is allowed to float high, a bus collision
occurs. This is another case of another master
attempting to drive a data 0 (Figure 26-39).

FIGURE 26-38: BUS COLLISION DURING A STOP CONDITION (CASE 1)

TBRG TBRG TBRG SDA sampled


low after TBRG,
set BCLxIF
SDA

SDA asserted low


SCL

PEN

BCLxIF

P 0

SSPxIF 0

FIGURE 26-39: BUS COLLISION DURING A STOP CONDITION (CASE 2)

TBRG TBRG TBRG

SDA

Assert SDA SCL goes low before SDA goes high,


set BCLxIF
SCL

PEN

BCLxIF

P 0

SSPxIF 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 383


PIC18(L)F26/45/46K40
26.11 Baud Rate Generator EQUATION 26-1:
The MSSP module has a Baud Rate Generator avail- FOSC
able for clock generation in both I2C and SPI Master FCLOCK = ----------------------------------------------
SSPADD + 1 4
modes. The Baud Rate Generator (BRG) reload value
is placed in the SSPxADD register (Register 26-5).
When a write occurs to SSPxBUF, the Baud Rate
Generator will automatically begin counting down.
Once the given operation is complete, the internal clock
will automatically stop counting and the clock pin will
remain in its last state.
An internal signal Reload in Figure 26-40 triggers the
value from SSPxADD to be loaded into the BRG
counter. This occurs twice for each oscillation of the
module clock line. The logic dictating when the reload
signal is asserted depends on the mode the MSSP is
being operated in.
Table 26-3 demonstrates clock rates based on
instruction cycles and the BRG value loaded into
SSPxADD.

FIGURE 26-40: BAUD RATE GENERATOR BLOCK DIAGRAM

SSPM<3:0> SSPxADD<7:0>

SSPM<3:0> Reload Reload


SCL Control

SSPCLK BRG Down Counter FOSC/2

Note: Values of 0x00, 0x01 and 0x02 are not valid


for SSPxADD when used as a Baud Rate
Generator for I2C. This is an implementation
limitation.

TABLE 26-3: MSSP CLOCK RATE W/BRG


FCLOCK
FOSC FCY BRG Value
(2 Rollovers of BRG)
32 MHz 8 MHz 13h 400 kHz
32 MHz 8 MHz 19h 308 kHz
32 MHz 8 MHz 4Fh 100 kHz
16 MHz 4 MHz 09h 400 kHz
16 MHz 4 MHz 0Ch 308 kHz
16 MHz 4 MHz 27h 100 kHz
4 MHz 1 MHz 09h 100 kHz
Note: Refer to the I/O port electrical specifications in Table 37-8: Internal Oscillator Parameters, to ensure the sys-
tem is designed to support IOL requirements.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 384


PIC18(L)F26/45/46K40

TABLE 26-4: SUMMARY OF REGISTERS ASSOCIATED WITH I2C OPERATION


Reset
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Values
on Page

INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RxyPPS RxyPPS<4:0> 217
SSPxADD ADD<7:0> 335
SSPxBUF BUF<7:0> 331*
SSPxCLKPPS SSPCLKPPS<4:0> 215
SSPxCON1 WCOL SSPOV SSPEN CKP SSPM<3:0> 333
SSPxCON2 GCEN ACKSTAT ACKDT ACKEN RCEN PEN RSEN SEN 350
SSPxCON3 ACKTIM PCIE SCIE BOEN SDAHT SBCDE AHEN DHEN 334
SSPxDATPPS SSPDATPPS<4:0> 215
SSPxMSK MSK<7:0> 352
SSPxSTAT SMP CKE D/A P S R/W UA BF 332
Legend: = unimplemented location, read as 0. Shaded cells are not used by the MSSP module in I2C mode.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 385


PIC18(L)F26/45/46K40
27.0 ENHANCED UNIVERSAL These devices typically do not have internal clocks for
baud rate generation and require the external clock
SYNCHRONOUS
signal provided by a master synchronous device.
ASYNCHRONOUS RECEIVER
The EUSART module includes the following capabilities:
TRANSMITTER (EUSART)
Full-duplex asynchronous transmit and receive
Two-character input buffer
Note: The PIC18(L)F26/45/46K40 devices have One-character output buffer
two EUSARTs. Therefore, all information
Programmable 8-bit or 9-bit character length
in this section refers to both EUSART 1
and EUSART 2. Address detection in 9-bit mode
Input buffer overrun error detection
The Enhanced Universal Synchronous Asynchronous
Received character framing error detection
Receiver Transmitter (EUSART) module is a serial I/O
communications peripheral. It contains all the clock Half-duplex synchronous master
generators, shift registers and data buffers necessary Half-duplex synchronous slave
to perform an input or output serial data transfer Programmable clock polarity in synchronous
independent of device program execution. The modes
EUSART, also known as a Serial Communications Sleep operation
Interface (SCI), can be configured as a full-duplex
The EUSART module implements the following
asynchronous system or half-duplex synchronous
additional features, making it ideally suited for use in
system. Full-Duplex mode is useful for
Local Interconnect Network (LIN) bus systems:
communications with peripheral systems, such as CRT
terminals and personal computers. Half-Duplex Automatic detection and calibration of the baud rate
Synchronous mode is intended for communications Wake-up on Break reception
with peripheral devices, such as A/D or D/A integrated 13-bit Break character transmit
circuits, serial EEPROMs or other microcontrollers.
Block diagrams of the EUSART transmitter and
receiver are shown in Figure 27-1 and Figure 27-2.

FIGURE 27-1: EUSART TRANSMIT BLOCK DIAGRAM

Data Bus
TXxIE
SYNC
Interrupt
CSRC
TXxREG Register TXxIF
8 RxyPPS(1)
CKx pin TXEN
MSb LSb RXx/DTx pin
PPS 1 (8) 0 Pin Buffer
and Control PPS
0 Transmit Shift Register (TSR)
CKPPS SYNC

TRMT TX_out
Baud Rate Generator FOSC
n
TX9
BRG16 n
+1 Multiplier x4 x16 x64
TX9D TXx/CKx pin
SYNC 1 X 0 0 0 0
SPxBRGH SPxBRGL PPS
BRGH X 1 1 0 0
1
BRG16 X 1 0 1 0
RxyPPS
SYNC
Note 1: In Synchronous mode, the DT output and RX input PPS CSRC
selections should enable the same pin.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 386


PIC18(L)F26/45/46K40
FIGURE 27-2: EUSART RECEIVE BLOCK DIAGRAM

SPEN CREN OERR RCIDL

RXxPPS(1)
RXx/DTx pin MSb RSR Register LSb
Pin Buffer Data
PPS and Control Recovery
Stop (8) 7 1 0 Start

Baud Rate Generator FOSC RX9


n

BRG16
+1 n
Multiplier x4 x16 x64
SYNC 1 X 0 0 0
SPxBRGH SPxBRGL BRGH FIFO
X 1 1 0 0 FERR RX9D RCxREG Register
BRG16 X 1 0 1 0
8
Data Bus

Note 1: In Synchronous mode, the DT output and RX input PPS RCxIF Interrupt
selections should enable the same pin. RCxIE

The operation of the EUSART module is controlled


through three registers:
Transmit Status and Control (TXxSTA)
Receive Status and Control (RCxSTA)
Baud Rate Control (BAUDxCON)
These registers are detailed in Register 27-1,
Register 27-2 and Register 27-3, respectively.
The RXx/DTx and TXx/CKx input pins are selected with
the RXxPPS and TXxPPS registers, respectively. TXx,
CKx, and DTx output pins are selected with each pins
RxyPPS register. Since the RX input is coupled with the
DT output in Synchronous mode, it is the users
responsibility to select the same pin for both of these
functions when operating in Synchronous mode. The
EUSART control logic will control the data direction
drivers automatically.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 387


PIC18(L)F26/45/46K40
27.1 Register Definitions: EUSART Control
REGISTER 27-1: TXxSTA: TRANSMIT STATUS AND CONTROL REGISTER
R/W-/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R-1/1 R/W-0/0
(1)
CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 CSRC: Clock Source Select bit


Asynchronous mode:
Dont care
Synchronous mode:
1 = Master mode (clock generated internally from BRG)
0 = Slave mode (clock from external source)
bit 6 TX9: 9-bit Transmit Enable bit
1 = Selects 9-bit transmission
0 = Selects 8-bit transmission
bit 5 TXEN: Transmit Enable bit(1)
1 = Transmit enabled
0 = Transmit disabled
bit 4 SYNC: EUSART Mode Select bit
1 = Synchronous mode
0 = Asynchronous mode
bit 3 SENDB: Send Break Character bit
Asynchronous mode:
1 = Send Sync Break on next transmission (cleared by hardware upon completion)
0 = Sync Break transmission disabled or completed
Synchronous mode:
Dont care
bit 2 BRGH: High Baud Rate Select bit
Asynchronous mode:
1 = High speed, if BRG16 = 1, baud rate is baudclk/4; else baudclk/16
0 = Low speed
Synchronous mode:
Unused in this mode
bit 1 TRMT: Transmit Shift Register Status bit
1 = TSR empty
0 = TSR full
bit 0 TX9D: Ninth bit of Transmit Data
Can be address/data bit or a parity bit.

Note 1: SREN/CREN bits of RCxSTA (Register 27-2) override TXEN in Sync mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 388


PIC18(L)F26/45/46K40

REGISTER 27-2: RCxSTA: RECEIVE STATUS AND CONTROL REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R-0/0 R/HC-0/0 R/HC-0/0
SPEN RX9 SREN CREN ADDEN FERR OERR RX9D
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit HC = Bit is cleared by hardware
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 SPEN: Serial Port Enable bit


1 = Serial port enabled
0 = Serial port disabled (held in Reset)
bit 6 RX9: 9-Bit Receive Enable bit
1 = Selects 9-bit reception
0 = Selects 8-bit reception
bit 5 SREN: Single Receive Enable bit
Asynchronous mode:
Dont care
Synchronous mode Master:
1 = Enables single receive
0 = Disables single receive
This bit is cleared after reception is complete.
Synchronous mode Slave
Dont care
bit 4 CREN: Continuous Receive Enable bit
Asynchronous mode:
1 = Enables receiver
0 = Disables receiver
Synchronous mode:
1 = Enables continuous receive until enable bit CREN is cleared (CREN overrides SREN)
0 = Disables continuous receive
bit 3 ADDEN: Address Detect Enable bit
Asynchronous mode 9-bit (RX9 = 1):
1 = Enables address detection, enable interrupt and load the receive buffer when RSR<8> is set
0 = Disables address detection, all bytes are received and ninth bit can be used as parity bit
Asynchronous mode 8-bit (RX9 = 0):
Dont care
bit 2 FERR: Framing Error bit
1 = Framing error (can be updated by reading RCxREG register and receive next valid byte)
0 = No framing error
bit 1 OERR: Overrun Error bit
1 = Overrun error (can be cleared by clearing bit CREN)
0 = No overrun error
bit 0 RX9D: Ninth bit of Received Data
This can be address/data bit or a parity bit and must be calculated by user firmware.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 389


PIC18(L)F26/45/46K40

REGISTER 27-3: BAUDxCON: BAUD RATE CONTROL REGISTER


R-0/0 R-1/1 U-0 R/W-0/0 R/W-0/0 U-0 R/W-0/0 R/W-0/0
ABDOVF RCIDL SCKP BRG16 WUE ABDEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 ABDOVF: Auto-Baud Detect Overflow bit


Asynchronous mode:
1 = Auto-baud timer overflowed
0 = Auto-baud timer did not overflow
Synchronous mode:
Dont care
bit 6 RCIDL: Receive Idle Flag bit
Asynchronous mode:
1 = Receiver is Idle
0 = Start bit has been received and the receiver is receiving
Synchronous mode:
Dont care
bit 5 Unimplemented: Read as 0
bit 4 SCKP: Synchronous Clock Polarity Select bit
Asynchronous mode:
1 = Idle state for transmit (TX) is a low level (transmit data inverted)
0 = Idle state for transmit (TX) is a high level (transmit data is non-inverted)
Synchronous mode:
1 = Data is clocked on rising edge of the clock
0 = Data is clocked on falling edge of the clock
bit 3 BRG16: 16-bit Baud Rate Generator bit
1 = 16-bit Baud Rate Generator is used
0 = 8-bit Baud Rate Generator is used
bit 2 Unimplemented: Read as 0
bit 1 WUE: Wake-up Enable bit
Asynchronous mode:
1 = Receiver is waiting for a falling edge. No character will be received, byte RCxIF will be set. WUE
will automatically clear after RCxIF is set.
0 = Receiver is operating normally
Synchronous mode:
Dont care
bit 0 ABDEN: Auto-Baud Detect Enable bit
Asynchronous mode:
1 = Auto-Baud Detect mode is enabled (clears when auto-baud is complete)
0 = Auto-Baud Detect mode is disabled
Synchronous mode:
Dont care

2016 Microchip Technology Inc. Preliminary DS40001816C-page 390


PIC18(L)F26/45/46K40
27.2 EUSART Asynchronous Mode 27.2.1.2 Transmitting Data
The EUSART transmits and receives data using the A transmission is initiated by writing a character to the
standard non-return-to-zero (NRZ) format. NRZ is TXxREG register. If this is the first character, or the
implemented with two levels: a VOH Mark state which previous character has been completely flushed from
represents a 1 data bit, and a VOL Space state which the TSR, the data in the TXxREG is immediately
represents a 0 data bit. NRZ refers to the fact that transferred to the TSR register. If the TSR still contains
consecutively transmitted data bits of the same value all or part of a previous character, the new character
stay at the output level of that bit without returning to a data is held in the TXxREG until the Stop bit of the
neutral level between each bit transmission. An NRZ previous character has been transmitted. The pending
transmission port idles in the Mark state. Each character character in the TXxREG is then transferred to the TSR
transmission consists of one Start bit followed by eight in one TCY immediately following the Stop bit
or nine data bits and is always terminated by one or transmission. The transmission of the Start bit, data bits
more Stop bits. The Start bit is always a space and the and Stop bit sequence commences immediately
Stop bits are always marks. The most common data following the transfer of the data to the TSR from the
format is eight bits. Each transmitted bit persists for a TXxREG.
period of 1/(Baud Rate). An on-chip dedicated
8-bit/16-bit Baud Rate Generator is used to derive 27.2.1.3 Transmit Data Polarity
standard baud rate frequencies from the system The polarity of the transmit data can be controlled with
oscillator. See Table 27-5 for examples of baud rate the SCKP bit of the BAUDxCON register. The default
configurations. state of this bit is 0 which selects high true transmit idle
The EUSART transmits and receives the LSb first. The and data bits. Setting the SCKP bit to 1 will invert the
EUSARTs transmitter and receiver are functionally transmit data resulting in low true idle and data bits. The
independent, but share the same data format and baud SCKP bit controls transmit data polarity in
rate. Parity is not supported by the hardware, but can Asynchronous mode only. In Synchronous mode, the
be implemented in software and stored as the ninth SCKP bit has a different function. See Section
data bit. 27.5.1.2 Clock Polarity.

27.2.1 EUSART ASYNCHRONOUS 27.2.1.4 Transmit Interrupt Flag


TRANSMITTER The TXxIF interrupt flag bit of the PIR3 register is set
whenever the EUSART transmitter is enabled and no
The EUSART transmitter block diagram is shown in
character is being held for transmission in the TXxREG.
Figure 27-1. The heart of the transmitter is the serial
In other words, the TXxIF bit is only clear when the TSR
Transmit Shift Register (TSR), which is not directly
is busy with a character and a new character has been
accessible by software. The TSR obtains its data from
queued for transmission in the TXxREG. The TXxIF flag
the transmit buffer, which is the TXxREG register.
bit is not cleared immediately upon writing TXxREG.
27.2.1.1 Enabling the Transmitter TXxIF becomes valid in the second instruction cycle
following the write execution. Polling TXxIF immediately
The EUSART transmitter is enabled for asynchronous following the TXxREG write will return invalid results.
operations by configuring the following three control The TXxIF bit is read-only, it cannot be set or cleared by
bits: software.
TXEN = 1 The TXxIF interrupt can be enabled by setting the
SYNC = 0 TXxIE interrupt enable bit of the PIE3 register.
SPEN = 1 However, the TXxIF flag bit will be set whenever the
TXxREG is empty, regardless of the state of TXxIE
All other EUSART control bits are assumed to be in
enable bit.
their default state.
To use interrupts when transmitting data, set the TXxIE
Setting the TXEN bit of the TXxSTA register enables the
bit only when there is more data to send. Clear the
transmitter circuitry of the EUSART. Clearing the SYNC
TXxIE interrupt enable bit upon writing the last charac-
bit of the TXxSTA register configures the EUSART for
ter of the transmission to the TXxREG.
asynchronous operation. Setting the SPEN bit of the
RCxSTA register enables the EUSART and
automatically configures the TXx/CKx I/O pin as an
output. If the TXx/CKx pin is shared with an analog
peripheral, the analog I/O function must be disabled by
clearing the corresponding ANSEL bit.
Note: The TXxIF Transmitter Interrupt flag is set
when the TXEN enable bit is set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 391


PIC18(L)F26/45/46K40
27.2.1.5 TSR Status 27.2.1.7 Asynchronous Transmission Setup:
The TRMT bit of the TXxSTA register indicates the 1. Initialize the SPxBRGH, SPxBRGL register pair
status of the TSR register. This is a read-only bit. The and the BRGH and BRG16 bits to achieve the
TRMT bit is set when the TSR register is empty and is desired baud rate (see Section 27.4 EUSART
cleared when a character is transferred to the TSR Baud Rate Generator (BRG)).
register from the TXxREG. The TRMT bit remains clear 2. Enable the asynchronous serial port by clearing
until all bits have been shifted out of the TSR register. the SYNC bit and setting the SPEN bit.
No interrupt logic is tied to this bit, so the user has to 3. If 9-bit transmission is desired, set the TX9
poll this bit to determine the TSR status. control bit. A set ninth data bit will indicate that
Note: The TSR register is not mapped in data the eight Least Significant data bits are an
memory, so it is not available to the user. address when the receiver is set for address
detection.
27.2.1.6 Transmitting 9-Bit Characters 4. Set SCKP bit if inverted transmit is desired.
The EUSART supports 9-bit character transmissions. 5. Enable the transmission by setting the TXEN
When the TX9 bit of the TXxSTA register is set, the control bit. This will cause the TXxIF interrupt bit
EUSART will shift nine bits out for each character trans- to be set.
mitted. The TX9D bit of the TXxSTA register is the 6. If interrupts are desired, set the TXxIE interrupt
ninth, and Most Significant data bit. When transmitting enable bit of the PIE3 register. An interrupt will
9-bit data, the TX9D data bit must be written before occur immediately provided that the GIE and
writing the eight Least Significant bits into the TXxREG. PEIE bits of the INTCON register are also set.
All nine bits of data will be transferred to the TSR shift 7. If 9-bit transmission is selected, the ninth bit
register immediately after the TXxREG is written. should be loaded into the TX9D data bit.
A special 9-bit Address mode is available for use with 8. Load 8-bit data into the TXxREG register. This
multiple receivers. See Section 27.2.2.7 Address will start the transmission.
Detection for more information on the Address mode.

FIGURE 27-3: ASYNCHRONOUS TRANSMISSION

Write to TXxREG
Word 1
BRG Output
(Shift Clock)
TXx/CKx
pin Start bit bit 0 bit 1 bit 7/8 Stop bit
Word 1
TXxIF bit
(Transmit Buffer 1 TCY
Reg. Empty Flag)

Word 1
TRMT bit Transmit Shift Reg.
(Transmit Shift
Reg. Empty Flag)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 392


PIC18(L)F26/45/46K40
FIGURE 27-4: ASYNCHRONOUS TRANSMISSION (BACK-TO-BACK)

Write to TXxREG
Word 1 Word 2
BRG Output
(Shift Clock)
TXx/CKx
pin Start bit bit 0 bit 1 bit 7/8 Stop bit Start bit bit 0
TXxIF bit 1 TCY Word 1 Word 2
(Transmit Buffer
Reg. Empty Flag) 1 TCY

TRMT bit Word 1 Word 2


(Transmit Shift Transmit Shift Reg. Transmit Shift Reg.
Reg. Empty Flag)

Note: This timing diagram shows two consecutive transmissions.

TABLE 27-1: SUMMARY OF REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page

BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390


INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 173
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
TXxPPS TXPPS<4:0> 215
SPxBRGH EUSARTx Baud Rate Generator, High Byte 399*
SPxBRGL EUSARTx Baud Rate Generator, Low Byte 399*
TXxREG EUSARTx Transmit Register 391*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for asynchronous transmission.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 393


PIC18(L)F26/45/46K40
27.2.2 EUSART ASYNCHRONOUS 27.2.2.2 Receiving Data
RECEIVER The receiver data recovery circuit initiates character
The Asynchronous mode is typically used in RS-232 reception on the falling edge of the first bit. The first bit,
systems. The receiver block diagram is shown in also known as the Start bit, is always a zero. The data
Figure 27-2. The data is received on the RXx/DTx pin recovery circuit counts one-half bit time to the center of
and drives the data recovery block. The data recovery the Start bit and verifies that the bit is still a zero. If it is
block is actually a high-speed shifter operating at 16 not a zero then the data recovery circuit aborts
times the baud rate, whereas the serial Receive Shift character reception, without generating an error, and
Register (RSR) operates at the bit rate. When all eight resumes looking for the falling edge of the Start bit. If
or nine bits of the character have been shifted in, they the Start bit zero verification succeeds then the data
are immediately transferred to a two character recovery circuit counts a full bit time to the center of the
First-In-First-Out (FIFO) memory. The FIFO buffering next bit. The bit is then sampled by a majority detect
allows reception of two complete characters and the circuit and the resulting 0 or 1 is shifted into the RSR.
start of a third character before software must start This repeats until all data bits have been sampled and
servicing the EUSART receiver. The FIFO and RSR shifted into the RSR. One final bit time is measured and
registers are not directly accessible by software. the level sampled. This is the Stop bit, which is always
Access to the received data is via the RCxREG register. a 1. If the data recovery circuit samples a 0 in the
Stop bit position then a framing error is set for this
27.2.2.1 Enabling the Receiver character, otherwise the framing error is cleared for this
The EUSART receiver is enabled for asynchronous character. See Section 27.2.2.4 Receive Framing
operation by configuring the following three control bits: Error for more information on framing errors.

CREN = 1 Immediately after all data bits and the Stop bit have
been received, the character in the RSR is transferred
SYNC = 0
to the EUSART receive FIFO and the RCxIF interrupt
SPEN = 1 flag bit of the PIR3 register is set. The top character in
All other EUSART control bits are assumed to be in the FIFO is transferred out of the FIFO by reading the
their default state. RCxREG register.
Setting the CREN bit of the RCxSTA register enables Note: If the receive FIFO is overrun, no additional
the receiver circuitry of the EUSART. Clearing the SYNC characters will be received until the overrun
bit of the TXxSTA register configures the EUSART for condition is cleared. See Section
asynchronous operation. Setting the SPEN bit of the 27.2.2.5 Receive Overrun Error for
RCxSTA register enables the EUSART. The more information on overrun errors.
programmer must set the corresponding TRIS bit to
configure the RXx/DTx I/O pin as an input. 27.2.2.3 Receive Interrupts
Note: If the RX/DT function is on an analog pin, The RCxIF interrupt flag bit of the PIR3 register is set
the corresponding ANSEL bit must be whenever the EUSART receiver is enabled and there is
cleared for the receiver to function. an unread character in the receive FIFO. The RCxIF
interrupt flag bit is read-only, it cannot be set or cleared
by software.
RCxIF interrupts are enabled by setting all of the
following bits:
RCxIE, Interrupt Enable bit of the PIE3 register
PEIE, Peripheral Interrupt Enable bit of the
INTCON register
GIE, Global Interrupt Enable bit of the INTCON
register
The RCxIF interrupt flag bit will be set when there is an
unread character in the FIFO, regardless of the state of
interrupt enable bits.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 394


PIC18(L)F26/45/46K40
27.2.2.4 Receive Framing Error 27.2.2.7 Address Detection
Each character in the receive FIFO buffer has a A special Address Detection mode is available for use
corresponding framing error Status bit. A framing error when multiple receivers share the same transmission
indicates that a Stop bit was not seen at the expected line, such as in RS-485 systems. Address detection is
time. The framing error status is accessed via the enabled by setting the ADDEN bit of the RCxSTA
FERR bit of the RCxSTA register. The FERR bit register.
represents the status of the top unread character in the Address detection requires 9-bit character reception.
receive FIFO. Therefore, the FERR bit must be read When address detection is enabled, only characters
before reading the RCxREG. with the ninth data bit set will be transferred to the
The FERR bit is read-only and only applies to the top receive FIFO buffer, thereby setting the RCxIF interrupt
unread character in the receive FIFO. A framing error bit. All other characters will be ignored.
(FERR = 1) does not preclude reception of additional Upon receiving an address character, user software
characters. It is not necessary to clear the FERR bit. determines if the address matches its own. Upon
Reading the next character from the FIFO buffer will address match, user software must disable address
advance the FIFO to the next character and the next detection by clearing the ADDEN bit before the next
corresponding framing error. Stop bit occurs. When user software detects the end of
The FERR bit can be forced clear by clearing the SPEN the message, determined by the message protocol
bit of the RCxSTA register which resets the EUSART. used, software places the receiver back into the
Clearing the CREN bit of the RCxSTA register does not Address Detection mode by setting the ADDEN bit.
affect the FERR bit. A framing error by itself does not
generate an interrupt.
Note: If all receive characters in the receive
FIFO have framing errors, repeated reads
of the RCxREG will not clear the FERR bit.

27.2.2.5 Receive Overrun Error


The receive FIFO buffer can hold two characters. An
overrun error will be generated if a third character, in its
entirety, is received before the FIFO is accessed. When
this happens the OERR bit of the RCxSTA register is
set. The characters already in the FIFO buffer can be
read but no additional characters will be received until
the error is cleared. The error must be cleared by either
clearing the CREN bit of the RCxSTA register or by
resetting the EUSART by clearing the SPEN bit of the
RCxSTA register.

27.2.2.6 Receiving 9-Bit Characters


The EUSART supports 9-bit character reception. When
the RX9 bit of the RCxSTA register is set the EUSART
will shift nine bits into the RSR for each character
received. The RX9D bit of the RCxSTA register is the
ninth and Most Significant data bit of the top unread
character in the receive FIFO. When reading 9-bit data
from the receive FIFO buffer, the RX9D data bit must
be read before reading the eight Least Significant bits
from the RCxREG.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 395


PIC18(L)F26/45/46K40
27.2.2.8 Asynchronous Reception Setup: 27.2.2.9 9-Bit Address Detection Mode Setup
1. Initialize the SPxBRGH:SPxBRGL register pair This mode would typically be used in RS-485 systems.
and the BRGH and BRG16 bits to achieve the To set up an Asynchronous Reception with Address
desired baud rate (see Section 27.4 EUSART Detect Enable:
Baud Rate Generator (BRG)). 1. Initialize the SPxBRGH:SPxBRGL register pair
2. Clear the ANSEL bit for the RXx pin (if applicable). and the BRGH and BRG16 bits to achieve the
3. Enable the serial port by setting the SPEN bit. desired baud rate (see Section 27.4 EUSART
The SYNC bit must be clear for asynchronous Baud Rate Generator (BRG)).
operation. 2. Clear the ANSEL bit for the RXx pin (if applicable).
4. If interrupts are desired, set the RCxIE bit of the 3. Enable the serial port by setting the SPEN bit.
PIE3 register and the GIE and PEIE bits of the The SYNC bit must be clear for asynchronous
INTCON register. operation.
5. If 9-bit reception is desired, set the RX9 bit. 4. If interrupts are desired, set the RCxIE bit of the
6. Enable reception by setting the CREN bit. PIE3 register and the GIE and PEIE bits of the
7. The RCxIF interrupt flag bit will be set when a INTCON register.
character is transferred from the RSR to the 5. Enable 9-bit reception by setting the RX9 bit.
receive buffer. An interrupt will be generated if 6. Enable address detection by setting the ADDEN
the RCxIE interrupt enable bit was also set. bit.
8. Read the RCxSTA register to get the error flags 7. Enable reception by setting the CREN bit.
and, if 9-bit data reception is enabled, the ninth 8. The RCxIF interrupt flag bit will be set when a
data bit. character with the ninth bit set is transferred
9. Get the received eight Least Significant data bits from the RSR to the receive buffer. An interrupt
from the receive buffer by reading the RCxREG will be generated if the RCxIE interrupt enable
register. bit was also set.
10. If an overrun occurred, clear the OERR flag by 9. Read the RCxSTA register to get the error flags.
clearing the CREN receiver enable bit. The ninth data bit will always be set.
10. Get the received eight Least Significant data bits
from the receive buffer by reading the RCxREG
register. Software determines if this is the
devices address.
11. If an overrun occurred, clear the OERR flag by
clearing the CREN receiver enable bit.
12. If the device has been addressed, clear the
ADDEN bit to allow all received data into the
receive buffer and generate interrupts.

FIGURE 27-5: ASYNCHRONOUS RECEPTION


Start Start Start
RXx/DTx pin bit bit 0 bit 1 bit 7/8 Stop bit bit 0 bit 7/8 Stop bit bit 7/8 Stop
bit bit bit
Rcv Shift
Reg
Rcv Buffer Reg.
Word 1 Word 2
RCxREG RCxREG
RCIDL

Read Rcv
Buffer Reg.
RCxREG

RCxIF
(Interrupt Flag)

OERR bit
CREN

Note: This timing diagram shows three words appearing on the RXx input. The RCxREG (receive buffer) is read after the third word,
causing the OERR (overrun) bit to be set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 396


PIC18(L)F26/45/46K40

TABLE 27-2: SUMMARY OF REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTION


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxREG EUSARTx Receive Register 394*
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
RXxPPS RXPPS<4:0> 215
SPxBRGH EUSARTx Baud Rate Generator, High Byte 399*
SPxBRGL EUSARTx Baud Rate Generator, Low Byte 399*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for asynchronous reception.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 397


PIC18(L)F26/45/46K40
27.3 Clock Accuracy with
Asynchronous Operation
The factory calibrates the internal oscillator block
output (INTOSC). However, the INTOSC frequency
may drift as VDD or temperature changes, and this
directly affects the asynchronous baud rate. Two
methods may be used to adjust the baud rate clock, but
both require a reference clock source of some kind.
The first (preferred) method uses the OSCTUNE
register to adjust the INTOSC output. Adjusting the
value in the OSCTUNE register allows for fine resolution
changes to the system clock source. See Section
4.3.2.3 Internal Oscillator Frequency Adjustment
for more information.
The other method adjusts the value in the Baud Rate
Generator. This can be done automatically with the
Auto-Baud Detect feature (see Section
27.4.1 Auto-Baud Detect). There may not be fine
enough resolution when adjusting the Baud Rate
Generator to compensate for a gradual change in the
peripheral clock frequency.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 398


PIC18(L)F26/45/46K40
27.4 EUSART Baud Rate Generator EXAMPLE 27-1: CALCULATING BAUD
(BRG) RATE ERROR
The Baud Rate Generator (BRG) is an 8-bit or 16-bit For a device with FOSC of 16 MHz, desired baud rate
timer that is dedicated to the support of both the of 9600, Asynchronous mode, 8-bit BRG:
asynchronous and synchronous EUSART operation. F OS C
Desired Baud Rate = -----------------------------------------------------------------------------
By default, the BRG operates in 8-bit mode. Setting the 64 [SPxBRGH:SPxBRGL] + 1
BRG16 bit of the BAUDxCON register selects 16-bit Solving for SPxBRGH:SPxBRGL:
mode.
F OS C
The SPxBRGH, SPxBRGL register pair determines the ---------------------------------------------
Desired Baud Rate
period of the free running baud rate timer. In SPBRGH:SPBRGL = --------------------------------------------- 1
64
Asynchronous mode the multiplier of the baud rate
16000000
period is determined by both the BRGH bit of the ------------------------
9600
TXxSTA register and the BRG16 bit of the BAUDxCON = ------------------------ 1
64
register. In Synchronous mode, the BRGH bit is ignored.
= 25.042 = 25
Table 27-3 contains the formulas for determining the
baud rate. Example 27-1 provides a sample calculation 16000000
Calculated Baud Rate = ---------------------------
for determining the baud rate and baud rate error. 64 25 + 1

Typical baud rates and error values for various = 9615


asynchronous modes have been computed for your
convenience and are shown in Table 27-5. It may be Calc. Baud Rate Desired Baud Rate
Error = --------------------------------------------------------------------------------------------
advantageous to use the high baud rate (BRGH = 1), Desired Baud Rate
or the 16-bit BRG (BRG16 = 1) to reduce the baud rate
9615 9600
error. The 16-bit BRG mode is used to achieve slow = ---------------------------------- = 0.16%
9600
baud rates for fast oscillator frequencies.
Writing a new value to the SPxBRGH, SPxBRGL regis-
ter pair causes the BRG timer to be reset (or cleared).
This ensures that the BRG does not wait for a timer
overflow before outputting the new baud rate.
If the system clock is changed during an active receive
operation, a receive error or data loss may result. To
avoid this problem, check the status of the RCIDL bit to
make sure that the receive operation is idle before
changing the system clock.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 399


PIC18(L)F26/45/46K40

TABLE 27-3: BAUD RATE FORMULAS


Configuration Bits
BRG/EUSART Mode Baud Rate Formula
SYNC BRG16 BRGH

0 0 0 8-bit/Asynchronous FOSC/[64 (n+1)]


0 0 1 8-bit/Asynchronous
FOSC/[16 (n+1)]
0 1 0 16-bit/Asynchronous
0 1 1 16-bit/Asynchronous
1 0 x 8-bit/Synchronous FOSC/[4 (n+1)]
1 1 x 16-bit/Synchronous
Legend: x = Dont care, n = value of SPxBRGH:SPxBRGL register pair.

TABLE 27-4: SUMMARY OF REGISTERS ASSOCIATED WITH THE BAUD RATE GENERATOR
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
SPxBRGH EUSARTx Baud Rate Generator, High Byte 399*
SPxBRGL EUSARTx Baud Rate Generator, Low Byte 399*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for the Baud Rate Generator.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 400


PIC18(L)F26/45/46K40

TABLE 27-5: SAMPLE BAUD RATES FOR ASYNCHRONOUS MODES


SYNC = 0, BRGH = 0, BRG16 = 0
FOSC = 32.000 MHz FOSC = 20.000 MHz FOSC = 18.432 MHz FOSC = 11.0592 MHz
BAUD
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300
1200 1221 1.73 255 1200 0.00 239 1200 0.00 143
2400 2404 0.16 207 2404 0.16 129 2400 0.00 119 2400 0.00 71
9600 9615 0.16 51 9470 -1.36 32 9600 0.00 29 9600 0.00 17
10417 10417 0.00 47 10417 0.00 29 10286 -1.26 27 10165 -2.42 16
19.2k 19.23k 0.16 25 19.53k 1.73 15 19.20k 0.00 14 19.20k 0.00 8
57.6k 55.55k -3.55 3 57.60k 0.00 7 57.60k 0.00 2
115.2k

SYNC = 0, BRGH = 0, BRG16 = 0

BAUD FOSC = 8.000 MHz FOSC = 4.000 MHz FOSC = 3.6864 MHz FOSC = 1.000 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 300 0.16 207 300 0.00 191 300 0.16 51
1200 1202 0.16 103 1202 0.16 51 1200 0.00 47 1202 0.16 12
2400 2404 0.16 51 2404 0.16 25 2400 0.00 23
9600 9615 0.16 12 9600 0.00 5
10417 10417 0.00 11 10417 0.00 5
19.2k 19.20k 0.00 2
57.6k 57.60k 0.00 0
115.2k

SYNC = 0, BRGH = 1, BRG16 = 0

BAUD FOSC = 32.000 MHz FOSC = 20.000 MHz FOSC = 18.432 MHz FOSC = 11.0592 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300
1200
2400
9600 9615 0.16 207 9615 0.16 129 9600 0.00 119 9600 0.00 71
10417 10417 0.00 191 10417 0.00 119 10378 -0.37 110 10473 0.53 65
19.2k 19.23k 0.16 103 19.23k 0.16 64 19.20k 0.00 59 19.20k 0.00 35
57.6k 57.14k -0.79 34 56.82k -1.36 21 57.60k 0.00 19 57.60k 0.00 11
115.2k 117.64k 2.12 16 113.64k -1.36 10 115.2k 0.00 9 115.2k 0.00 5

2016 Microchip Technology Inc. Preliminary DS40001816C-page 401


PIC18(L)F26/45/46K40
TABLE 27-5: SAMPLE BAUD RATES FOR ASYNCHRONOUS MODES (CONTINUED)
SYNC = 0, BRGH = 1, BRG16 = 0

BAUD FOSC = 8.000 MHz FOSC = 4.000 MHz FOSC = 3.6864 MHz FOSC = 1.000 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 300 0.16 207
1200 1202 0.16 207 1200 0.00 191 1202 0.16 51
2400 2404 0.16 207 2404 0.16 103 2400 0.00 95 2404 0.16 25
9600 9615 0.16 51 9615 0.16 25 9600 0.00 23
10417 10417 0.00 47 10417 0.00 23 10473 0.53 21 10417 0.00 5
19.2k 19231 0.16 25 19.23k 0.16 12 19.2k 0.00 11
57.6k 55556 -3.55 8 57.60k 0.00 3
115.2k 115.2k 0.00 1

SYNC = 0, BRGH = 0, BRG16 = 1

BAUD FOSC = 32.000 MHz FOSC = 20.000 MHz FOSC = 18.432 MHz FOSC = 11.0592 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 300.0 0.00 6666 300.0 -0.01 4166 300.0 0.00 3839 300.0 0.00 2303
1200 1200 -0.02 3332 1200 -0.03 1041 1200 0.00 959 1200 0.00 575
2400 2401 -0.04 832 2399 -0.03 520 2400 0.00 479 2400 0.00 287
9600 9615 0.16 207 9615 0.16 129 9600 0.00 119 9600 0.00 71
10417 10417 0.00 191 10417 0.00 119 10378 -0.37 110 10473 0.53 65
19.2k 19.23k 0.16 103 19.23k 0.16 64 19.20k 0.00 59 19.20k 0.00 35
57.6k 57.14k -0.79 34 56.818 -1.36 21 57.60k 0.00 19 57.60k 0.00 11
115.2k 117.6k 2.12 16 113.636 -1.36 10 115.2k 0.00 9 115.2k 0.00 5

SYNC = 0, BRGH = 0, BRG16 = 1

BAUD FOSC = 8.000 MHz FOSC = 4.000 MHz FOSC = 3.6864 MHz FOSC = 1.000 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 299.9 -0.02 1666 300.1 0.04 832 300.0 0.00 767 300.5 0.16 207
1200 1199 -0.08 416 1202 0.16 207 1200 0.00 191 1202 0.16 51
2400 2404 0.16 207 2404 0.16 103 2400 0.00 95 2404 0.16 25
9600 9615 0.16 51 9615 0.16 25 9600 0.00 23
10417 10417 0.00 47 10417 0.00 23 10473 0.53 21 10417 0.00 5
19.2k 19.23k 0.16 25 19.23k 0.16 12 19.20k 0.00 11
57.6k 55556 -3.55 8 57.60k 0.00 3
115.2k 115.2k 0.00 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 402


PIC18(L)F26/45/46K40
TABLE 27-5: SAMPLE BAUD RATES FOR ASYNCHRONOUS MODES (CONTINUED)
SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1

BAUD FOSC = 32.000 MHz FOSC = 20.000 MHz FOSC = 18.432 MHz FOSC = 11.0592 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 300.0 0.00 26666 300.0 0.00 16665 300.0 0.00 15359 300.0 0.00 9215
1200 1200 0.00 6666 1200 -0.01 4166 1200 0.00 3839 1200 0.00 2303
2400 2400 0.01 3332 2400 0.02 2082 2400 0.00 1919 2400 0.00 1151
9600 9604 0.04 832 9597 -0.03 520 9600 0.00 479 9600 0.00 287
10417 10417 0.00 767 10417 0.00 479 10425 0.08 441 10433 0.16 264
19.2k 19.18k -0.08 416 19.23k 0.16 259 19.20k 0.00 239 19.20k 0.00 143
57.6k 57.55k -0.08 138 57.47k -0.22 86 57.60k 0.00 79 57.60k 0.00 47
115.2k 115.9k 0.64 68 116.3k 0.94 42 115.2k 0.00 39 115.2k 0.00 23

SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1

BAUD FOSC = 8.000 MHz FOSC = 4.000 MHz FOSC = 3.6864 MHz FOSC = 1.000 MHz
RATE SPBRG SPBRG SPBRG SPBRG
Actual % Actual % Actual % Actual %
value value value value
Rate Error Rate Error Rate Error Rate Error
(decimal) (decimal) (decimal) (decimal)
300 300.0 0.00 6666 300.0 0.01 3332 300.0 0.00 3071 300.1 0.04 832
1200 1200 -0.02 1666 1200 0.04 832 1200 0.00 767 1202 0.16 207
2400 2401 0.04 832 2398 0.08 416 2400 0.00 383 2404 0.16 103
9600 9615 0.16 207 9615 0.16 103 9600 0.00 95 9615 0.16 25
10417 10417 0 191 10417 0.00 95 10473 0.53 87 10417 0.00 23
19.2k 19.23k 0.16 103 19.23k 0.16 51 19.20k 0.00 47 19.23k 0.16 12
57.6k 57.14k -0.79 34 58.82k 2.12 16 57.60k 0.00 15
115.2k 117.6k 2.12 16 111.1k -3.55 8 115.2k 0.00 7

2016 Microchip Technology Inc. Preliminary DS40001816C-page 403


PIC18(L)F26/45/46K40
27.4.1 AUTO-BAUD DETECT BRGH and SPxBRGL registers are clocked at 1/8th the
BRG base clock rate. The resulting byte measurement
The EUSART module supports automatic detection
is the average bit time when clocked at full speed.
and calibration of the baud rate.
Note 1: If the WUE bit is set with the ABDEN bit,
In the Auto-Baud Detect (ABD) mode, the clock to the
auto-baud detection will occur on the byte
BRG is reversed. Rather than the BRG clocking the
following the Break character (see Sec-
incoming RX signal, the RX signal is timing the BRG.
tion 27.4.3 Auto-Wake-up on Break).
The Baud Rate Generator is used to time the period of
a received 55h (ASCII U) which is the Sync character 2: It is up to the user to determine that the
for the LIN bus. The unique feature of this character is incoming character baud rate is within the
that it has five rising edges including the Stop bit edge. range of the selected BRG clock source.
Some combinations of oscillator frequency
Setting the ABDEN bit of the BAUDxCON register
and EUSART baud rates are not possible.
starts the auto-baud calibration sequence. While the
ABD sequence takes place, the EUSART state 3: During the auto-baud process, the
machine is held in Idle. On the first rising edge of the auto-baud counter starts counting at one.
receive line, after the Start bit, the SPxBRG begins Upon completion of the auto-baud
counting up using the BRG counter clock as shown in sequence, to achieve maximum accuracy,
Figure 27-6. The fifth rising edge will occur on the RXx subtract 1 from the SPxBRGH:SPxBRGL
pin at the end of the eighth bit period. At that time, an register pair.
accumulated value totaling the proper BRG period is
left in the SPxBRGH, SPxBRGL register pair, the
ABDEN bit is automatically cleared and the RCxIF TABLE 27-6: BRG COUNTER CLOCK RATES
interrupt flag is set. The value in the RCxREG needs to BRG Base BRG ABD
be read to clear the RCxIF interrupt. RCxREG content BRG16 BRGH
Clock Clock
should be discarded. When calibrating for modes that
do not use the SPxBRGH register the user can verify 1 1 FOSC/4 FOSC/32
that the SPxBRGL register did not overflow by 1 0 FOSC/16 FOSC/128
checking for 00h in the SPxBRGH register.
0 1 FOSC/16 FOSC/128
The BRG auto-baud clock is determined by the BRG16
and BRGH bits as shown in Table 27-6. During ABD, 0 0 FOSC/64 FOSC/512
both the SPxBRGH and SPxBRGL registers are used Note: During the ABD sequence, SPxBRGL and
as a 16-bit counter, independent of the BRG16 bit set- SPxBRGH registers are both used as a
ting. While calibrating the baud rate period, the SPx- 16-bit counter, independent of the BRG16
setting.

FIGURE 27-6: AUTOMATIC BAUD RATE CALIBRATION

BRG Value XXXXh 0000h 001Ch

Edge #1 Edge #2 Edge #3 Edge #4 Edge #5


RXx pin Start bit 0 bit 1 bit 2 bit 3 bit 4 bit 5 bit 6 bit 7 Stop bit

BRG Clock

Set by User Auto Cleared


ABDEN bit

RCIDL

RCxIF bit
(Interrupt)

Read
RCxREG

SPxBRGL XXh 1Ch

SPxBRGH XXh 00h

Note 1: The ABD sequence requires the EUSART module to be configured in Asynchronous mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 404


PIC18(L)F26/45/46K40
27.4.2 AUTO-BAUD OVERFLOW 27.4.3.1 Special Considerations
During the course of automatic baud detection, the Break Character
ABDOVF bit of the BAUDxCON register will be set if the To avoid character errors or character fragments during
baud rate counter overflows before the fifth rising edge a wake-up event, the wake-up character must be all
is detected on the RXx pin. The ABDOVF bit indicates zeros.
that the counter has exceeded the maximum count that
can fit in the 16 bits of the SPxBRGH:SPxBRGL regis- When the wake-up is enabled the function works
ter pair. After the ABDOVF bit has been set, the counter independent of the low time on the data stream. If the
continues to count until the fifth rising edge is detected WUE bit is set and a valid non-zero character is
on the RXx pin. Upon detecting the fifth RX edge, the received, the low time from the Start bit to the first rising
hardware will set the RCxIF interrupt flag and clear the edge will be interpreted as the wake-up event. The
ABDEN bit of the BAUDxCON register. The RCxIF flag remaining bits in the character will be received as a
can be subsequently cleared by reading the RCxREG fragmented character and subsequent characters can
register. The ABDOVF flag of the BAUDxCON register result in framing or overrun errors.
can be cleared by software directly. Therefore, the initial character in the transmission must
To terminate the auto-baud process before the RCxIF be all 0s. This must be ten or more bit times, 13-bit
flag is set, clear the ABDEN bit then clear the ABDOVF times recommended for LIN bus, or any number of bit
bit of the BAUDxCON register. The ABDOVF bit will times for standard RS-232 devices.
remain set if the ABDEN bit is not cleared first. Oscillator Start-up Time
Oscillator start-up time must be considered, especially
27.4.3 AUTO-WAKE-UP ON BREAK
in applications using oscillators with longer start-up
During Sleep mode, all clocks to the EUSART are intervals (i.e., LP, XT or HS/PLL mode). The Sync
suspended. Because of this, the Baud Rate Generator Break (or wake-up signal) character must be of
is inactive and a proper character reception cannot be sufficient length, and be followed by a sufficient
performed. The Auto-Wake-up feature allows the interval, to allow enough time for the selected oscillator
controller to wake-up due to activity on the RX/DT line. to start and provide proper initialization of the EUSART.
This feature is available only in Asynchronous mode.
WUE Bit
The Auto-Wake-up feature is enabled by setting the
The wake-up event causes a receive interrupt by
WUE bit of the BAUDxCON register. Once set, the
setting the RCxIF bit. The WUE bit is cleared in
normal receive sequence on RX/DT is disabled, and the
hardware by a rising edge on RX/DT. The interrupt
EUSART remains in an Idle state, monitoring for a
condition is then cleared in software by reading the
wake-up event independent of the CPU mode. A
RCxREG register and discarding its contents.
wake-up event consists of a high-to-low transition on the
RX/DT line. (This coincides with the start of a Sync Break To ensure that no actual data is lost, check the RCIDL
or a wake-up signal character for the LIN protocol.) bit to verify that a receive operation is not in process
before setting the WUE bit. If a receive operation is not
The EUSART module generates an RCxIF interrupt
occurring, the WUE bit may then be set just prior to
coincident with the wake-up event. The interrupt is
entering the Sleep mode.
generated synchronously to the Q clocks in normal CPU
operating modes (Figure 27-7), and asynchronously if
the device is in Sleep mode (Figure 27-8). The interrupt
condition is cleared by reading the RCxREG register.
The WUE bit is automatically cleared by the low-to-high
transition on the RX line at the end of the Break. This
signals to the user that the Break event is over. At this
point, the EUSART module is in Idle mode waiting to
receive the next character.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 405


PIC18(L)F26/45/46K40
FIGURE 27-7: AUTO-WAKE-UP BIT (WUE) TIMING DURING NORMAL OPERATION
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
OSC1
Bit set by user Auto Cleared
WUE bit
RXx/DTx
Line
RCxIF
Cleared due to User Read of RCxREG

Note 1: The EUSART remains in Idle while the WUE bit is set.

FIGURE 27-8: AUTO-WAKE-UP BIT (WUE) TIMINGS DURING SLEEP

Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1Q2 Q3 Q4


OSC1
Bit Set by User Auto Cleared
WUE bit
RXx/DTx
Note 1
Line
RCxIF
Cleared due to User Read of RCxREG
Sleep Command Executed Sleep Ends

Note 1: If the wake-up event requires long oscillator warm-up time, the automatic clearing of the WUE bit can occur while the stposc signal is
still active. This sequence should not depend on the presence of Q clocks.
2: The EUSART remains in Idle while the WUE bit is set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 406


PIC18(L)F26/45/46K40
27.4.4 BREAK CHARACTER SEQUENCE 27.4.5 RECEIVING A BREAK CHARACTER
The EUSART module has the capability of sending the The Enhanced EUSART module can receive a Break
special Break character sequences that are required by character in two ways.
the LIN bus standard. A Break character consists of a The first method to detect a Break character uses the
Start bit, followed by 12 0 bits and a Stop bit. FERR bit of the RCxSTA register and the received data
To send a Break character, set the SENDB and TXEN as indicated by RCxREG. The Baud Rate Generator is
bits of the TXxSTA register. The Break character trans- assumed to have been initialized to the expected baud
mission is then initiated by a write to the TXxREG. The rate.
value of data written to TXxREG will be ignored and all A Break character has been received when;
0s will be transmitted.
RCxIF bit is set
The SENDB bit is automatically reset by hardware after
FERR bit is set
the corresponding Stop bit is sent. This allows the user
to preload the transmit FIFO with the next transmit byte RCxREG = 00h
following the Break character (typically, the Sync The second method uses the Auto-Wake-up feature
character in the LIN specification). described in Section 27.4.3 Auto-Wake-up on
The TRMT bit of the TXxSTA register indicates when the Break. By enabling this feature, the EUSART will
transmit operation is active or idle, just as it does during sample the next two transitions on RX/DT, cause an
normal transmission. See Figure 27-9 for the timing of RCxIF interrupt, and receive the next data byte fol-
the Break character sequence. lowed by another interrupt.
Note that following a Break character, the user will
27.4.4.1 Break and Sync Transmit Sequence typically want to enable the Auto-Baud Detect feature.
The following sequence will start a message frame For both methods, the user can set the ABDEN bit of
header made up of a Break, followed by an auto-baud the BAUDxCON register before placing the EUSART in
Sync byte. This sequence is typical of a LIN bus Sleep mode.
master.
1. Configure the EUSART for the desired mode.
2. Set the TXEN and SENDB bits to enable the
Break sequence.
3. Load the TXxREG with a dummy character to
initiate transmission (the value is ignored).
4. Write 55h to TXxREG to load the Sync charac-
ter into the transmit FIFO buffer.
5. After the Break has been sent, the SENDB bit is
reset by hardware and the Sync character is
then transmitted.
When the TXxREG becomes empty, as indicated by
the TXxIF, the next data byte can be written to TXxREG.

FIGURE 27-9: SEND BREAK CHARACTER SEQUENCE

Write to TXxREG
Dummy Write

BRG Output
(Shift Clock)
TXx (pin) Start bit bit 0 bit 1 bit 11 Stop bit
Break
TXxIF bit
(Transmit
Interrupt Flag)
TRMT bit
(Transmit Shift
Empty Flag)
SENDB Sampled Here Auto Cleared
SENDB
(send Break
control bit)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 407


PIC18(L)F26/45/46K40
27.5 EUSART Synchronous Mode 27.5.1.2 Clock Polarity
Synchronous serial communications are typically used A clock polarity option is provided for Microwire
in systems with a single master and one or more compatibility. Clock polarity is selected with the SCKP
slaves. The master device contains the necessary bit of the BAUDxCON register. Setting the SCKP bit
circuitry for baud rate generation and supplies the clock sets the clock Idle state as high. When the SCKP bit is
for all devices in the system. Slave devices can take set, the data changes on the falling edge of each clock.
advantage of the master clock by eliminating the Clearing the SCKP bit sets the Idle state as low. When
internal clock generation circuitry. the SCKP bit is cleared, the data changes on the rising
edge of each clock.
There are two signal lines in Synchronous mode: a
bidirectional data line and a clock line. Slaves use the 27.5.1.3 Synchronous Master Transmission
external clock supplied by the master to shift the serial
Data is transferred out of the device on the RXx/DTx
data into and out of their respective receive and trans-
pin. The RXx/DTx and TXx/CKx pin output drivers are
mit shift registers. Since the data line is bidirectional,
automatically enabled when the EUSART is configured
synchronous operation is half-duplex only. Half-duplex
for synchronous master transmit operation.
refers to the fact that master and slave devices can
receive and transmit data but not both simultaneously. A transmission is initiated by writing a character to the
The EUSART can operate as either a master or slave TXxREG register. If the TSR still contains all or part of
device. a previous character the new character data is held in
the TXxREG until the last bit of the previous character
Start and Stop bits are not used in synchronous
has been transmitted. If this is the first character, or the
transmissions.
previous character has been completely flushed from
27.5.1 SYNCHRONOUS MASTER MODE the TSR, the data in the TXxREG is immediately trans-
ferred to the TSR. The transmission of the character
The following bits are used to configure the EUSART commences immediately following the transfer of the
for synchronous master operation: data to the TSR from the TXxREG.
SYNC = 1 Each data bit changes on the leading edge of the
CSRC = 1 master clock and remains valid until the subsequent
SREN = 0 (for transmit); SREN = 1 (for receive) leading clock edge.
CREN = 0 (for transmit); CREN = 1 (for receive) Note: The TSR register is not mapped in data
SPEN = 1 memory, so it is not available to the user.
Setting the SYNC bit of the TXxSTA register configures
the device for synchronous operation. Setting the CSRC 27.5.1.4 Synchronous Master Transmission
bit of the TXxSTA register configures the device as a Setup:
master. Clearing the SREN and CREN bits of the 1. Initialize the SPxBRGH, SPxBRGL register pair
RCxSTA register ensures that the device is in the and the BRGH and BRG16 bits to achieve the
Transmit mode, otherwise the device will be configured desired baud rate (see Section 27.4 EUSART
to receive. Setting the SPEN bit of the RCxSTA register Baud Rate Generator (BRG)).
enables the EUSART. 2. Enable the synchronous master serial port by
setting bits SYNC, SPEN and CSRC.
27.5.1.1 Master Clock
3. Disable Receive mode by clearing bits SREN
Synchronous data transfers use a separate clock line, and CREN.
which is synchronous with the data. A device config-
4. Enable Transmit mode by setting the TXEN bit.
ured as a master transmits the clock on the TX/CK line.
The TXx/CKx pin output driver is automatically enabled 5. If 9-bit transmission is desired, set the TX9 bit.
when the EUSART is configured for synchronous 6. If interrupts are desired, set the TXxIE bit of the
transmit or receive operation. Serial data bits change PIE3 register and the GIE and PEIE bits of the
on the leading edge to ensure they are valid at the INTCON register.
trailing edge of each clock. One clock cycle is gener- 7. If 9-bit transmission is selected, the ninth bit
ated for each data bit. Only as many clock cycles are should be loaded in the TX9D bit.
generated as there are data bits. 8. Start transmission by loading data to the
TXxREG register.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 408


PIC18(L)F26/45/46K40
FIGURE 27-10: SYNCHRONOUS TRANSMISSION
RXx/DTx
pin bit 0 bit 1 bit 2 bit 7 bit 0 bit 1 bit 7
Word 1 Word 2
TXx/CKx pin
(SCKP = 0)

TXx/CKx pin
(SCKP = 1)
Write to
TXxREG Reg Write Word 1 Write Word 2
TXxIF bit
(Interrupt Flag)

TRMT bit

1 1
TXEN bit

Note: Sync Master mode, SPxBRGL = 0, continuous transmission of two 8-bit words.

FIGURE 27-11: SYNCHRONOUS TRANSMISSION (THROUGH TXEN)

RXx/DTx pin bit 0 bit 1 bit 2 bit 6 bit 7

TXx/CKx pin

Write to
TXxREG reg

TXxIF bit

TRMT bit

TXEN bit

2016 Microchip Technology Inc. Preliminary DS40001816C-page 409


PIC18(L)F26/45/46K40

TABLE 27-7: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER


TRANSMISSION
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
TXxPPS TXPPS<4:0> 215
SPxBRGH EUSARTx Baud Rate Generator, High Byte 399*
SPxBRGL EUSARTx Baud Rate Generator, Low Byte 399*
TXxREG EUSARTx Transmit Data Register 391*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for synchronous master transmission.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 410


PIC18(L)F26/45/46K40
27.5.1.5 Synchronous Master Reception 27.5.1.7 Receive Overrun Error
Data is received at the RXx/DTx pin. The RXx/DTx pin The receive FIFO buffer can hold two characters. An
output driver is automatically disabled when the overrun error will be generated if a third character, in its
EUSART is configured for synchronous master receive entirety, is received before RCxREG is read to access
operation. the FIFO. When this happens the OERR bit of the
In Synchronous mode, reception is enabled by setting RCxSTA register is set. Previous data in the FIFO will
either the Single Receive Enable bit (SREN of the not be overwritten. The two characters in the FIFO
RCxSTA register) or the Continuous Receive Enable buffer can be read, however, no additional characters
bit (CREN of the RCxSTA register). will be received until the error is cleared. The OERR bit
can only be cleared by clearing the overrun condition.
When SREN is set and CREN is clear, only as many If the overrun error occurred when the SREN bit is set
clock cycles are generated as there are data bits in a and CREN is clear then the error is cleared by reading
single character. The SREN bit is automatically cleared RCxREG. If the overrun occurred when the CREN bit is
at the completion of one character. When CREN is set, set then the error condition is cleared by either clearing
clocks are continuously generated until CREN is the CREN bit of the RCxSTA register or by clearing the
cleared. If CREN is cleared in the middle of a character SPEN bit which resets the EUSART.
the CK clock stops immediately and the partial charac-
ter is discarded. If SREN and CREN are both set, then 27.5.1.8 Receiving 9-Bit Characters
SREN is cleared at the completion of the first character
The EUSART supports 9-bit character reception. When
and CREN takes precedence.
the RX9 bit of the RCxSTA register is set the EUSART
To initiate reception, set either SREN or CREN. Data is will shift nine bits into the RSR for each character
sampled at the RXx/DTx pin on the trailing edge of the received. The RX9D bit of the RCxSTA register is the
TX/CK clock pin and is shifted into the Receive Shift ninth, and Most Significant, data bit of the top unread
Register (RSR). When a complete character is character in the receive FIFO. When reading 9-bit data
received into the RSR, the RCxIF bit is set and the from the receive FIFO buffer, the RX9D data bit must
character is automatically transferred to the two char- be read before reading the eight Least Significant bits
acter receive FIFO. The Least Significant eight bits of from the RCxREG.
the top character in the receive FIFO are available in
RCxREG. The RCxIF bit remains set as long as there 27.5.1.9 Synchronous Master Reception
are unread characters in the receive FIFO. Setup:
Note: If the RX/DT function is on an analog pin, 1. Initialize the SPxBRGH:SPxBRGL register pair
the corresponding ANSEL bit must be for the appropriate baud rate. Set or clear the
cleared for the receiver to function. BRGH and BRG16 bits, as required, to achieve
the desired baud rate.
27.5.1.6 Slave Clock 2. Clear the ANSEL bit for the RXx pin (if applicable).
Synchronous data transfers use a separate clock line, 3. Enable the synchronous master serial port by
which is synchronous with the data. A device configured setting bits SYNC, SPEN and CSRC.
as a slave receives the clock on the TX/CK line. The 4. Ensure bits CREN and SREN are clear.
TXx/CKx pin output driver is automatically disabled 5. If interrupts are desired, set the RCxIE bit of the
when the device is configured for synchronous slave PIE3 register and the GIE and PEIE bits of the
transmit or receive operation. Serial data bits change on INTCON register.
the leading edge to ensure they are valid at the trailing
6. If 9-bit reception is desired, set bit RX9.
edge of each clock. One data bit is transferred for each
clock cycle. Only as many clock cycles should be 7. Start reception by setting the SREN bit or for
received as there are data bits. continuous reception, set the CREN bit.
8. Interrupt flag bit RCxIF will be set when recep-
Note: If the device is configured as a slave and tion of a character is complete. An interrupt will
the TX/CK function is on an analog pin, the be generated if the enable bit RCxIE was set.
corresponding ANSEL bit must be cleared.
9. Read the RCxSTA register to get the ninth bit (if
enabled) and determine if any error occurred
during reception.
10. Read the 8-bit received data by reading the
RCxREG register.
11. If an overrun error occurs, clear the error by
either clearing the CREN bit of the RCxSTA
register or by clearing the SPEN bit which resets
the EUSART.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 411


PIC18(L)F26/45/46K40
FIGURE 27-12: SYNCHRONOUS RECEPTION (MASTER MODE, SREN)

RXx/DTx
pin bit 0 bit 1 bit 2 bit 3 bit 4 bit 5 bit 6 bit 7

TXx/CKx pin
(SCKP = 0)

TXx/CKx pin
(SCKP = 1)

Write to
bit SREN

SREN bit

CREN bit 0 0

RCxIF bit
(Interrupt)
Read
RCxREG

Note: Timing diagram demonstrates Sync Master mode with bit SREN = 1 and bit BRGH = 0.

TABLE 27-8: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER


RECEPTION
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
ANSELB ANSELB7 ANSELB6 ANSELB5 ANSELB4 ANSELB3 ANSELB2 ANSELB1 ANSELB0 203
ANSELC ANSELC7 ANSELC6 ANSELC5 ANSELC4 ANSELC3 ANSELC2 ANSELC1 ANSELC0 203
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxREG EUSARTx Receive Data Register 394*
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
RXxPPS RXPPS<4:0> 215
SPxBRGH EUSARTx Baud Rate Generator, High Byte 399*
SPxBRGL EUSARTx Baud Rate Generator, Low Byte 399*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for synchronous master reception.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 412


PIC18(L)F26/45/46K40
27.5.2 SYNCHRONOUS SLAVE MODE 27.5.2.2 Synchronous Slave Transmission
The following bits are used to configure the EUSART Setup
for synchronous slave operation: 1. Set the SYNC and SPEN bits and clear the
SYNC = 1 CSRC bit.
CSRC = 0 2. Clear the ANSEL bit for the CKx pin (if applicable).
SREN = 0 (for transmit); SREN = 1 (for receive) 3. Clear the CREN and SREN bits.
CREN = 0 (for transmit); CREN = 1 (for receive) 4. If interrupts are desired, set the TXxIE bit of the
PIE3 register and the GIE and PEIE bits of the
SPEN = 1
INTCON register.
Setting the SYNC bit of the TXxSTA register configures 5. If 9-bit transmission is desired, set the TX9 bit.
the device for synchronous operation. Clearing the
6. Enable transmission by setting the TXEN bit.
CSRC bit of the TXxSTA register configures the device as
a slave. Clearing the SREN and CREN bits of the 7. If 9-bit transmission is selected, insert the Most
RCxSTA register ensures that the device is in the Significant bit into the TX9D bit.
Transmit mode, otherwise the device will be configured to 8. Start transmission by writing the Least
receive. Setting the SPEN bit of the RCxSTA register Significant eight bits to the TXxREG register.
enables the EUSART.

27.5.2.1 EUSART Synchronous Slave


Transmit
The operation of the Synchronous Master and Slave
modes are identical (see Section
27.5.1.3 Synchronous Master Transmission),
except in the case of the Sleep mode.
If two words are written to the TXxREG and then the
SLEEP instruction is executed, the following will occur:
1. The first character will immediately transfer to
the TSR register and transmit.
2. The second word will remain in the TXxREG
register.
3. The TXxIF bit will not be set.
4. After the first character has been shifted out of
TSR, the TXxREG register will transfer the
second character to the TSR and the TXxIF bit
will now be set.
5. If the PEIE and TXxIE bits are set, the interrupt
will wake the device from Sleep and execute the
next instruction. If the GIE bit is also set, the
program will call the Interrupt Service Routine.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 413


PIC18(L)F26/45/46K40

TABLE 27-9: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE


TRANSMISSION
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
TXxPPS TXPPS<4:0> 215
TXxREG EUSARTx Transmit Data Register 391*
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for synchronous slave transmission.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 414


PIC18(L)F26/45/46K40
27.5.2.3 EUSART Synchronous Slave 27.5.2.4 Synchronous Slave Reception
Reception Setup:
The operation of the Synchronous Master and Slave 1. Set the SYNC and SPEN bits and clear the
modes is identical (Section 27.5.1.5 Synchronous CSRC bit.
Master Reception), with the following exceptions: 2. Clear the ANSEL bit for both the CKx and DTx
Sleep pins (if applicable).
CREN bit is always set, therefore the receiver is 3. If interrupts are desired, set the RCxIE bit of the
never idle PIE3 register and the GIE and PEIE bits of the
SREN bit, which is a dont care in Slave mode INTCON register.
4. If 9-bit reception is desired, set the RX9 bit.
A character may be received while in Sleep mode by
setting the CREN bit prior to entering Sleep. Once the 5. Set the CREN bit to enable reception.
word is received, the RSR register will transfer the data 6. The RCxIF bit will be set when reception is
to the RCxREG register. If the RCxIE enable bit is set, complete. An interrupt will be generated if the
the interrupt generated will wake the device from Sleep RCxIE bit was set.
and execute the next instruction. If the GIE bit is also 7. If 9-bit mode is enabled, retrieve the Most
set, the program will branch to the interrupt vector. Significant bit from the RX9D bit of the RCxSTA
register.
8. Retrieve the eight Least Significant bits from the
receive FIFO by reading the RCxREG register.
9. If an overrun error occurs, clear the error by
either clearing the CREN bit of the RCxSTA
register or by clearing the SPEN bit which resets
the EUSART.

TABLE 27-10: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE


RECEPTION
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
BAUDxCON ABDOVF RCIDL SCKP BRG16 WUE ABDEN 390
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE3 RC2IE TX2IE RC1IE TX1IE BCL2IE SSP2IE BCL1IE SSP1IE 181
PIR3 RC2IF TX2IF RC1IF TX1IF BCL2IF SSP2IF BCL1IF SSP1IF 173
IPR3 RC2IP TX2IP RC1IP TX1IP BCL2IP SSP2IP BCL1IP SSP1IP 189
RCxREG EUSART Receive Data Register 394*
RCxSTA SPEN RX9 SREN CREN ADDEN FERR OERR RX9D 389
RxyPPS RxyPPS<4:0> 217
RXxPPS RXPPS<4:0> 215
TXxSTA CSRC TX9 TXEN SYNC SENDB BRGH TRMT TX9D 388
Legend: = unimplemented location, read as 0. Shaded cells are not used for synchronous slave reception.
* Page provides register information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 415


PIC18(L)F26/45/46K40
27.6 EUSART Operation During Sleep 27.6.2 SYNCHRONOUS TRANSMIT
DURING SLEEP
The EUSART will remain active during Sleep only in the
Synchronous Slave mode. All other modes require the To transmit during Sleep, all the following conditions
system clock and therefore cannot generate the neces- must be met before entering Sleep mode:
sary signals to run the Transmit or Receive Shift The RCxSTA and TXxSTA Control registers must
registers during Sleep. be configured for synchronous slave transmission
Synchronous Slave mode uses an externally generated (see Section 27.5.2.2 Synchronous Slave
clock to run the Transmit and Receive Shift registers. Transmission Setup).
The TXxIF interrupt flag must be cleared by writ-
27.6.1 SYNCHRONOUS RECEIVE DURING ing the output data to the TXxREG, thereby filling
SLEEP the TSR and transmit buffer.
To receive during Sleep, all the following conditions If interrupts are desired, set the TXxIE bit of the
must be met before entering Sleep mode: PIE3 register and the PEIE bit of the INTCON
register.
RCxSTA and TXxSTA Control registers must be
configured for Synchronous Slave Reception (see Interrupt enable bits TXxIE of the PIE3 register
Section 27.5.2.4 Synchronous Slave and PEIE of the INTCON register must set.
Reception Setup:). Upon entering Sleep mode, the device will be ready to
If interrupts are desired, set the RCxIE bit of the accept clocks on TXx/CKx pin and transmit data on the
PIE3 register and the GIE and PEIE bits of the RXx/DTx pin. When the data word in the TSR has been
INTCON register. completely clocked out by the external device, the
The RCxIF interrupt flag must be cleared by read- pending byte in the TXxREG will transfer to the TSR
ing RCxREG to unload any pending characters in and the TXxIF flag will be set. Thereby, waking the pro-
the receive buffer. cessor from Sleep. At this point, the TXxREG is avail-
able to accept another character for transmission,
Upon entering Sleep mode, the device will be ready to which will clear the TXxIF flag.
accept data and clocks on the RXx/DTx and TXx/CKx
pins, respectively. When the data word has been com- Upon waking from Sleep, the instruction following the
pletely clocked in by the external device, the RCxIF SLEEP instruction will be executed. If the Global
interrupt flag bit of the PIR3 register will be set. Interrupt Enable (GIE) bit is also set then the Interrupt
Thereby, waking the processor from Sleep. Service Routine at address 0004h will be called.

Upon waking from Sleep, the instruction following the


SLEEP instruction will be executed. If the Global
Interrupt Enable (GIE) bit of the INTCON register is
also set, then the Interrupt Service Routine at address
004h will be called.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 416


PIC18(L)F26/45/46K40
28.0 FIXED VOLTAGE REFERENCE The ADFVR<1:0> bits of the FVRCON register are
used to enable and configure the gain amplifier settings
(FVR)
for the reference supplied to the ADC module.
The Fixed Voltage Reference, or FVR, is a stable Reference Section 31.0 Analog-to-Digital Con-
voltage reference, independent of VDD, with 1.024V, verter with Computation (ADC2) Module for addi-
2.048V or 4.096V selectable output levels. The output tional information.
of the FVR can be configured to supply a reference The CDAFVR<1:0> bits of the FVRCON register are
voltage to the following: used to enable and configure the gain amplifier settings
ADC input channel for the reference supplied to the DAC and comparator
ADC positive reference module. Reference Section 30.0 5-Bit Digi-
tal-to-Analog Converter (DAC) Module and Section
Comparator input
32.0 Comparator Module for additional information.
Digital-to-Analog Converter (DAC)
The FVR can be enabled by setting the FVREN bit of 28.2 FVR Stabilization Period
the FVRCON register.
When the Fixed Voltage Reference module is enabled, it
Note: Fixed Voltage Reference output cannot requires time for the reference and amplifier circuits to
exceed VDD. stabilize. Once the circuits stabilize and are ready for use,
the FVRRDY bit of the FVRCON register will be set.

28.1 Independent Gain Amplifiers


The output of the FVR, which is connected to the ADC,
Comparators, and DAC, is routed through two
independent programmable gain amplifiers. Each
amplifier can be programmed for a gain of 1x, 2x or 4x,
to produce the three possible voltage levels.

FIGURE 28-1: VOLTAGE REFERENCE BLOCK DIAGRAM

Rev. 10-000 053C


12/9/201 3

2
ADFVR<1:0>
1x
FVR_buffer1
2x
4x (To ADC Module)

2
CDAFVR<1:0>
1x FVR_buffer2
2x (To Comparators
4x and DAC)

FVREN
+
_ FVRRDY
Note 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 417


PIC18(L)F26/45/46K40
28.3 Register Definitions: FVR Control

REGISTER 28-1: FVRCON: FIXED VOLTAGE REFERENCE CONTROL REGISTER


R/W-0/0 R-q/q R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
(1) (3) (3)
FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared q = Value depends on condition

bit 7 FVREN: Fixed Voltage Reference Enable bit


1 = Fixed Voltage Reference is enabled
0 = Fixed Voltage Reference is disabled
bit 6 FVRRDY: Fixed Voltage Reference Ready Flag bit(1)
1 = Fixed Voltage Reference output is ready for use
0 = Fixed Voltage Reference output is not ready or not enabled
bit 5 TSEN: Temperature Indicator Enable bit(3)
1 = Temperature Indicator is enabled
0 = Temperature Indicator is disabled
bit 4 TSRNG: Temperature Indicator Range Selection bit(3)
1 = VOUT = VDD - 4VT (High Range)
0 = VOUT = VDD - 2VT (Low Range)
bit 3-2 CDAFVR<1:0>: Comparator FVR Buffer Gain Selection bits
11 = Comparator FVR Buffer Gain is 4x, (4.096V)(2)
10 = Comparator FVR Buffer Gain is 2x, (2.048V)(2)
01 = Comparator FVR Buffer Gain is 1x, (1.024V)
00 = Comparator FVR Buffer is off
bit 1-0 ADFVR<1:0>: ADC FVR Buffer Gain Selection bit
11 = ADC FVR Buffer Gain is 4x, (4.096V)(2)
10 = ADC FVR Buffer Gain is 2x, (2.048V)(2)
01 = ADC FVR Buffer Gain is 1x, (1.024V)
00 = ADC FVR Buffer is off

Note 1: FVRRDY is always 1.


2: Fixed Voltage Reference output cannot exceed VDD.
3: See Section 29.0 Temperature Indicator Module for additional information.

TABLE 28-1: SUMMARY OF REGISTERS ASSOCIATED WITH FIXED VOLTAGE REFERENCE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
FVRCON FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0> 418
ADCON0 ADON ADCONT ADCS ADFM ADGO 443
CMxNCH CxNCH<2:0> 464
CMxPCH CxPCH<2:0> 465
DAC1CON1 DAC1R<4:0> 424
Legend: = Unimplemented location, read as 0. Shaded cells are not used with the Fixed Voltage Reference.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 418


PIC18(L)F26/45/46K40
29.0 TEMPERATURE INDICATOR FIGURE 29-1: TEMPERATURE CIRCUIT
MODULE DIAGRAM

This family of devices is equipped with a temperature Rev. 10-000069A


7/31/2013
VDD
circuit designed to measure the operating temperature
of the silicon die. The circuits range of operating
temperature falls between -40C and +85C. The
output is a voltage that is proportional to the device TSEN
temperature. The output of the temperature indicator is
internally connected to the device ADC.
The circuit may be used as a temperature threshold
detector or a more accurate temperature indicator, TSRNG
depending on the level of calibration performed. A one-
point calibration allows the circuit to indicate a
temperature closely surrounding that point. A two-point
calibration allows the circuit to sense the entire range
of temperature more accurately. Reference Application VOUT
Note AN1333, Use and Calibration of the Internal Temp. Indicator
To ADC
Temperature Indicator (DS00001333) for more details
regarding the calibration process.

29.1 Circuit Operation


Figure 29-1 shows a simplified block diagram of the 29.2 Minimum Operating VDD
temperature circuit. The proportional voltage output is
achieved by measuring the forward voltage drop across When the temperature circuit is operated in low range,
multiple silicon junctions. the device may be operated at any operating voltage
that is within specifications.
Equation 29-1 describes the output characteristics of
the temperature indicator. When the temperature circuit is operated in high range,
the device operating voltage, VDD, must be high
EQUATION 29-1: VOUT RANGES enough to ensure that the temperature circuit is
correctly biased.

High Range: VOUT = VDD - 4VT Table 29-1 shows the recommended minimum VDD vs.
range setting.
Low Range: VOUT = VDD - 2VT
TABLE 29-1: RECOMMENDED VDD VS.
RANGE
The temperature sense circuit is integrated with the
Fixed Voltage Reference (FVR) module. See Section Min. VDD, TSRNG = 1 Min. VDD, TSRNG = 0
28.0 Fixed Voltage Reference (FVR) for more 3.6V 1.8V
information.
The circuit is enabled by setting the TSEN bit of the 29.3 Temperature Output
FVRCON register. When disabled, the circuit draws no
current. The output of the circuit is measured using the internal
Analog-to-Digital Converter. A channel is reserved for
The circuit operates in either high or low range. The high
the temperature circuit output. Refer to Section
range, selected by setting the TSRNG bit of the
31.0 Analog-to-Digital Converter with Computation
FVRCON register, provides a wider output voltage. This
(ADC2) Module for detailed information.
provides more resolution over the temperature range,
but may be less consistent from part to part. This range
requires a higher bias voltage to operate and thus, a
higher VDD is needed.
The low range is selected by clearing the TSRNG bit of
the FVRCON register. The low range generates a lower
voltage drop and thus, a lower bias voltage is needed to
operate the circuit. The low range is provided for low
voltage operation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 419


PIC18(L)F26/45/46K40
29.4 ADC Acquisition Time
To ensure accurate temperature measurements, the
user must wait at least 200 s after the ADC input
multiplexer is connected to the temperature indicator
output before the conversion is performed. In addition,
the user must wait 200 s between consecutive
conversions of the temperature indicator output.

TABLE 29-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE TEMPERATURE INDICATOR


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
FVRCON FVREN FVRRDY TSEN TSRNG CDFVR<1:0> ADFVR<1:0> 418
Legend: = Unimplemented location, read as 0. Shaded cells are unused by the temperature indicator module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 420


PIC18(L)F26/45/46K40
30.0 5-BIT DIGITAL-TO-ANALOG The output of the DAC (DACx_output) can be selected
as a reference voltage to the following:
CONVERTER (DAC) MODULE
Comparator positive input
The Digital-to-Analog Converter supplies a variable
ADC input channel
voltage reference, ratiometric with the input source,
with 32 selectable output levels. DACxOUT1 pin
DACxOUT2 pin
The positive input source (VSOURCE+) of the DAC can
be connected to: The Digital-to-Analog Converter (DAC) can be enabled
by setting the DACEN bit of the DAC1CON0 register.
FVR Buffer
External VREF+ pin
VDD supply voltage
The negative input source (VSOURCE-) of the DAC can
be connected to:
External VREF- pin
Vss

FIGURE 30-1: DIGITAL-TO-ANALOG CONVERTER BLOCK DIAGRAM

Rev. 10-000026F
8/7/2015

Reserved 11
VSOURCE+ DACR<4:0>
FVR Buffer 10 5
VREF+ 01 R

AVDD 00

R
DACPSS

R
32-to-1 MUX

32 DACx_output
To Peripherals
Steps
DACEN
R

R DACxOUT1(1)

DACOE1
R
DACxOUT2(1)

VREF- 1 VSOURCE- DACOE2


AVSS 0

DACNSS

Note 1: The unbuffered DACx_output is provided on the DACxOUT pin(s).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 421


PIC18(L)F26/45/46K40
30.1 Output Voltage Selection Reading the DACxOUTn pin when it has been
configured for DAC reference voltage output will
The DAC has 32 voltage level ranges. The 32 levels always return a 0.
are set with the DAC1R<4:0> bits of the DAC1CON1
register. Note: The unbuffered DAC output (DACxOUTn)
is not intended to drive an external load.
The DAC output voltage can be determined by using
Equation 30-1.
30.4 Operation During Sleep
30.2 Ratiometric Output Level When the device wakes up from Sleep through an
The DAC output value is derived using a resistor ladder interrupt or a Windowed Watchdog Timer Time-out, the
with each end of the ladder tied to a positive and contents of the DACxCON0 register are not affected.
negative voltage reference input source. If the voltage To minimize current consumption in Sleep mode, the
of either input source fluctuates, a similar fluctuation voltage reference should be disabled.
will result in the DAC output value.
30.5 Effects of a Reset
The value of the individual resistors within the ladder
can be found in Table 37-16. A device Reset affects the following:
DACx is disabled.
30.3 DAC Voltage Reference Output DACX output voltage is removed from the
The unbuffered DAC voltage can be output to the DACxOUTn pin(s).
DACxOUTn pin(s) by setting the respective DACOEn The DAC1R<4:0> range select bits are cleared.
bit(s) of the DACxCON0 register. Selecting the DAC
reference voltage for output on either DACxOUTn pin
automatically overrides the digital output buffer, the
weak pull-up and digital input threshold detector
functions of that pin.

EQUATION 30-1: DAC OUTPUT VOLTAGE


IF DACEN = 1

DACR 4:0
DACx_output = VREF+ VREF- -----------------------------
5 + VREF-
2

Note: See the DAC1CON0 register for the available VSOURCE+ and VSOURCE- selections.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 422


PIC18(L)F26/45/46K40
30.6 Register Definitions: DAC Control
Long bit name prefixes for the DAC peripheral is shown
in Table 30-1. Refer to Section 1.4.2.2 Long Bit
Names for more information.
TABLE 30-1:
Peripheral Bit Name Prefix
DAC DAC
l
REGISTER 30-1: DAC1CON0: DAC CONTROL REGISTER
R/W-0/0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 U-0 R/W-0/0
EN OE1 OE2 PSS<1:0> NSS
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 EN: DAC Enable bit


1 = DAC is enabled
0 = DAC is disabled
bit 6 Unimplemented: Read as 0
bit 5 OE1: DAC Voltage Output Enable bit
1 = DAC voltage level is output on the DAC1OUT1 pin
0 = DAC voltage level is disconnected from the DAC1OUT1 pin
bit 4 OE2: DAC Voltage Output Enable bit
1 = DAC voltage level is output on the DAC1OUT2 pin
0 = DAC voltage level is disconnected from the DAC1OUT2 pin
bit 3-2 PSS<1:0>: DAC Positive Source Select bit
11 = Reserved
10 = FVR buffer
01 = VREF+
00 = AVDD
bit 1 Unimplemented: Read as 0
bit 0 NSS: DAC Negative Source Select bit
1 = VREF-
0 = AVSS

2016 Microchip Technology Inc. Preliminary DS40001816C-page 423


PIC18(L)F26/45/46K40

REGISTER 30-2: DAC1CON1: DAC DATA REGISTER


U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
DAC1R<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 Unimplemented: Read as 0


bit 4-0 DAC1R<4:0>: Data Input Register for DAC bits

TABLE 30-2: SUMMARY OF REGISTERS ASSOCIATED WITH THE DAC MODULE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on page
DAC1CON0 EN OE1 OE2 PSS<1:0> NSS 423
DAC1CON1 DAC1R<4:0> 424
FVRCON FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0> 418
Legend: = Unimplemented location, read as 0. Shaded cells are not used with the DAC module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 424


PIC18(L)F26/45/46K40
31.0 ANALOG-TO-DIGITAL
CONVERTER WITH
COMPUTATION (ADC2)
MODULE
The Analog-to-Digital Converter with Computation
(ADC2) allows conversion of an analog input signal to
a 10-bit binary representation of that signal. This device
uses analog inputs, which are multiplexed into a single
sample and hold circuit. The output of the sample and
hold is connected to the input of the converter. The
converter generates a 10-bit binary result via
successive approximation and stores the conversion
result into the ADC result registers (ADRESH:ADRESL
register pair).
Additionally, the following features are provided within
the ADC module:
8-bit Acquisition Timer
Hardware Capacitive Voltage Divider (CVD)
support:
- 8-bit precharge timer
- Adjustable sample and hold capacitor array
- Guard ring digital output drive
Automatic repeat and sequencing:
- Automated double sample conversion for
CVD
- Two sets of result registers (Result and
Previous result)
- Auto-conversion trigger
- Internal retrigger
Computation features:
- Averaging and low-pass filter functions
- Reference comparison
- 2-level threshold comparison
- Selectable interrupts
Figure 31-1 shows the block diagram of the ADC.
The ADC voltage reference is software selectable to be
either internally generated or externally supplied.
The ADC can generate an interrupt upon completion of
a conversion and upon threshold comparison. These
interrupts can be used to wake-up the device from
Sleep.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 425


PIC18(L)F26/45/46K40
FIGURE 31-1: ADC2 BLOCK DIAGRAM
ADPREF<1:0> Rev. 10-000034B
10/13/2015

VREF+ pin FVR_buffer1 11 Positive


Reference
10 Select
Reserved 01
00
ADNREF
VDD
1
VREF- pin
0
VSS ADCS<2:0>
AN0
ANa Vref- Vref+
External .
Channel . FOSC/n Fosc
. Divider FOSC
Inputs ADC
ANz ADC_clk
sampled Clock
VSS input Select FRC
FRC
Temp Indicator
Internal
Channel DACx_output ADC CLOCK SOURCE
Inputs
FVR_buffer1 ADC
Sample Circuit
CHS<4:0>
ADFM
set bit ADIF

10
complete 10-bit Result
Write to bit
GO/DONE
GO/DONE Q1 16
start
Q4
ADRESH ADRESL
Q2 Enable

Trigger Select
TRIGSEL<3:0> ADON
. . . VSS
Trigger Sources

AUTO CONVERSION
TRIGGER

2016 Microchip Technology Inc. Preliminary DS40001816C-page 426


PIC18(L)F26/45/46K40
31.1 ADC Configuration 31.1.3 ADC VOLTAGE REFERENCE
When configuring and using the ADC the following The ADPREF<1:0> bits of the ADREF register provide
functions must be considered: control of the positive voltage reference. The positive
voltage reference can be:
Port configuration
VREF+ pin
Channel selection
VDD
ADC voltage reference selection
FVR 1.024V
ADC conversion clock source
FVR 2.048V
Interrupt control
FVR 4.096V
Result formatting
Conversion Trigger Selection The ADNREF bit of the ADREF register provides
control of the negative voltage reference. The negative
ADC Acquisition Time
voltage reference can be:
ADC Precharge Time
VREF- pin
Additional Sample and Hold Capacitor
VSS
Single/Double Sample Conversion
See Section 28.0 Fixed Voltage Reference (FVR)
Guard Ring Outputs
for more details on the Fixed Voltage Reference.
31.1.1 PORT CONFIGURATION
31.1.4 CONVERSION CLOCK
The ADC can be used to convert both analog and
The source of the conversion clock is software
digital signals. When converting analog signals, the I/O
selectable via the ADCLK register and the ADCS bits of
pin should be configured for analog by setting the
the ADCON0 register. There are 66 possible clock
associated TRIS and ANSEL bits. Refer to Section
options:
15.0 I/O Ports for more information.
FOSC/2
Note: Analog voltages on any pin that is defined
FOSC/4
as a digital input may cause the input
buffer to conduct excess current. FOSC/6
FOSC/8
31.1.2 CHANNEL SELECTION FOSC/10
There are several channel selections available: .
Eight PORTA pins (RA<7:0>) .
Eight PORTB pins (RB<7:0>) .
Eight PORTC pins (RC<7:0>) FOSC/128
Eight PORTD pins (RD<7:0>), PIC18(L)F45/46K40 FRC (dedicated RC oscillator)
only)
The time to complete one bit conversion is defined as
Three PORTE pins (RE<2:0>), PIC18(L)F45/46K40
TAD. One full 10-bit conversion requires 11.5 TAD
only)
periods as shown in Figure 31-2.
Temperature Indicator
For correct conversion, the appropriate TAD specification
DAC output
must be met. Refer to Table 37-14 for more information.
Fixed Voltage Reference (FVR) Table 31-1 gives examples of appropriate ADC clock
AVSS (ground) selections.
The ADPCH register determines which channel is Note 1: Unless using the FRC, any changes in the
connected to the sample and hold circuit. system clock frequency will change the
When changing channels, a delay is required before ADC clock frequency, which may
starting the next conversion. 0 adversely affect the ADC result.
Refer to Section 31.2 ADC Operation for more informa- 2: The internal control logic of the ADC runs
tion. off of the clock selected by the ADCS bit
of ADCON0. What this can mean is when
the ADCS bit of ADCON0 is set to 1
(ADC runs on FRC), there may be
unexpected delays in operation when
setting ADC control bits.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 427


PIC18(L)F26/45/46K40
TABLE 31-1: ADC CLOCK PERIOD (TAD) VS. DEVICE OPERATING FREQUENCIES(1,4)
ADC Clock Period (TAD) Device Frequency (FOSC)

ADC
ADCS<5:0> 64 MHz 32 MHz 20 MHz 16 MHz 8 MHz 4 MHz 1 MHz
Clock Source

FOSC/2 000000 31.25 ns(2) 62.5 ns(2) 100 ns(2) 125 ns(2) 250 ns(2) 500 ns(2) 2.0 s
FOSC/4 000001 62.5 ns(2) 125 ns(2) 200 ns(2) 250 ns(2) 500 ns(2) 1.0 s 4.0 s
FOSC/6 000010 125 ns(2) 187.5 ns(2) 300 ns(2) 375 ns(2) 750 ns(2) 1.5 s 6.0 s
FOSC/8 000011 187.5 ns(2) 250 ns(2) 400 ns(2) 500 ns(2) 1.0 s 2.0 s 8.0 s(3)
... ... ... ... ... ... ... ... ...
FOSC/16 000100 250 ns(2) 500 ns(2) 800 ns(2) 1.0 s 2.0 s 4.0 s 16.0 s(3)
... ... ... ... ... ... ... ... ...
FOSC/128 111111 2.0 s 4.0 s 6.4 s 8.0 s 16.0 s(3) 32.0 s(2) 128.0 s(2)
FRC ADCS(ADCON0<4>) = 1 1.0-6.0 s 1.0-6.0 s 1.0-6.0 s 1.0-6.0 s 1.0-6.0 s 1.0-6.0 s 1.0-6.0 s
Legend: Shaded cells are outside of recommended range.
Note 1: See TAD parameter for FRC source typical TAD value.
2: These values violate the required TAD time.
3: Outside the recommended TAD time.
4: The ADC clock period (TAD) and total ADC conversion time can be minimized when the ADC clock is derived from the system
clock FOSC. However, the FRC oscillator source must be used when conversions are to be performed with the device in Sleep
mode.

FIGURE 31-2: ANALOG-TO-DIGITAL CONVERSION TAD CYCLES

Rev. 10-000035B
7/15/2016
Precharge Acquisition/ Conversion Time
Time Sharing Time (Traditional Timing of ADC Conversion)
1-127 TCY 1-127 TCY
(TPRE) (TACQ) TCY TCY-TAD TAD1 TAD2 TAD3 TAD4 TAD5 TAD6 TAD7 TAD8 TAD9 TAD10TAD11 2 TCY
b9 b8 b7 b6 b5 b4 b3 b2 b1 b0

External and Internal External and Internal Conversion starts


Channels are Channels share
charged/discharged charge Holding capacitor CHOLD is disconnected from analog input (typically 100ns)

If ADPRE 0 If ADACQ 0 If ADPRE = 0


If ADACQ = 0 On the following cycle:
(Traditional Operation Start) ADRESH:ADRESL is loaded,
GO bit is cleared,
Set GO bit ADIF bit is set,

2016 Microchip Technology Inc. Preliminary DS40001816C-page 428


PIC18(L)F26/45/46K40
31.1.5 INTERRUPTS 31.1.6 RESULT FORMATTING
The ADC module allows for the ability to generate an The 10-bit ADC conversion result can be supplied in
interrupt upon completion of an Analog-to-Digital two formats, left justified or right justified. The ADFM
conversion. The ADC Interrupt Flag is the ADIF bit in bits of the ADCON0 register controls the output format.
the PIR1 register. The ADC Interrupt Enable is the Figure 31-3 shows the two output formats.
ADIE bit in the PIE1 register. The ADIF bit must be
cleared in software. Writes to the ADRES register pair are always right
justified regardless of the selected format mode. There-
Note 1: The ADIF bit is set at the completion of fore, data read after writing to ADRES when
every conversion, regardless of whether ADFRM0 = 0 will be shifted left six places. For exam-
or not the ADC interrupt is enabled. ple, writing 0xFF to ADRESL will be read as 0xC0 in
2: The ADC operates during Sleep only ADRESL and 0x3F logical ORd with whatever was in
when the FRC oscillator is selected. the two MS bits in ADRESH.

This interrupt can be generated while the device is


operating or while in Sleep. If the device is in Sleep, the
interrupt will wake-up the device. Upon waking from
Sleep, the next instruction following the SLEEP
instruction is always executed. If the user is attempting
to wake-up from Sleep and resume in-line code
execution, the ADIE bit of the PIE1 register and the
PEIE bit of the INTCON register must both be set and
the GIE bit of the INTCON register must be cleared. If
all three of these bits are set, the execution will switch
to the Interrupt Service Routine.

FIGURE 31-3: 10-BIT ADC CONVERSION RESULT FORMAT

ADRESH ADRESL
(ADFM = 0) MSB LSB
bit 7 bit 0 bit 7 bit 0

10-bit ADC Result Unimplemented: Read as 0

(ADFM = 1) MSB LSB


bit 7 bit 0 bit 7 bit 0

Unimplemented: Read as 0 10-bit ADC Result

2016 Microchip Technology Inc. Preliminary DS40001816C-page 429


PIC18(L)F26/45/46K40
31.2 ADC Operation 31.2.4 ADC OPERATION DURING SLEEP
The ADC module can operate during Sleep. This
31.2.1 STARTING A CONVERSION requires the ADC clock source to be set to the FRC
To enable the ADC module, the ADON bit of the option. When the FRC oscillator source is selected, the
ADCON0 register must be set to a 1. A conversion ADC waits one additional instruction before starting the
may be started by any of the following: conversion. This allows the SLEEP instruction to be
Software setting the ADGO bit of ADCON0 to 1 executed, which can reduce system noise during the
An external trigger (selected by Register 31-3) conversion. If the ADC interrupt is enabled, the device
A continuous-mode retrigger (see section Sec- will wake-up from Sleep when the conversion
tion 31.5.8 Continuous Sampling mode) completes. If the ADC interrupt is disabled, the ADC
module is turned off after the conversion completes,
. although the ADON bit remains set.
Note: The ADGO bit should not be set in the
same instruction that turns on the ADC. 31.2.5 EXTERNAL TRIGGER DURING
Refer to Section 31.2.7 ADC Conver- SLEEP
sion Procedure (Basic Mode). If the external trigger is received during sleep while
ADC clock source is set to the FRC, ADC module will
31.2.2 COMPLETION OF A CONVERSION perform the conversion and set the ADIF bit upon com-
When any individual conversion is complete, the value pletion.
already in ADRES is written into ADPREV (if If an external trigger is received when the ADC clock
ADPSIS = 1) and the new conversion results appear in source is something other than FRC, the trigger will be
ADRES. When the conversion completes, the ADC recorded, but the conversion will not begin until the
module will: device exits Sleep.
Clear the ADGO bit (unless the ADCONT bit of
ADCON0 is set)
Set the ADIF Interrupt Flag bit
Set the ADMATH bit
Update ADACC
When ADDSEN = 0 then after every conversion, or
when ADDSEN = 1 then after every other conversion,
the following events occur:
ADERR is calculated
ADTIF is set if ADERR calculation meets thresh-
old comparison
Importantly, filter and threshold computations occur
after the conversion itself is complete. As such,
interrupt handlers responding to ADIF should check
ADTIF before reading filter and threshold results.

31.2.3 TERMINATING A CONVERSION


If a conversion must be terminated before completion,
the ADGO bit can be cleared in software. The ADRESH
and ADRESL registers will be updated with the partially
complete Analog-to-Digital conversion sample.
Incomplete bits will match the last bit converted. In this
case, filter and/or threshold occur.
Note: A device Reset forces all registers to their
Reset state. Thus, the ADC module is
turned off and any pending conversion is
terminated.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 430


PIC18(L)F26/45/46K40
31.2.6 AUTO-CONVERSION TRIGGER
The Auto-conversion Trigger allows periodic ADC mea-
surements without software intervention. When a rising
edge of the selected source occurs, the ADGO bit is set
by hardware.
The Auto-conversion Trigger source is selected with
the ADACT<4:0> bits of the ADACT register.
Using the Auto-conversion Trigger does not assure
proper ADC timing. It is the users responsibility to
ensure that the ADC timing requirements are met. See
Table 31-2 for auto-conversion sources.

TABLE 31-2: ADC AUTO-CONVERSION


TABLE
Source
Description
Peripheral
ADCACTPPS Pin selected by ADCACTPPS
TMR0 Timer0 overflow condition
TMR1/3/5 Timer1/3/5 overflow condition
TMR2/4/6 Match between Timer2/4/6 postscaled
value and PR2/4/6
CCP1/2 CCP1/2 output
PWM3/4 PWM3/4 output
C1/2 Comparator C1/2 output
IOC Interrupt-on-change interrupt trigger
ADERR Read of ADERRH register
ADRESH Read of ADRESH register
ADPCH Write of ADPCH register

2016 Microchip Technology Inc. Preliminary DS40001816C-page 431


PIC18(L)F26/45/46K40
31.2.7 ADC CONVERSION PROCEDURE EXAMPLE 31-1: ADC CONVERSION
(BASIC MODE) ;This code block configures the ADC
This is an example procedure for using the ADC to ;for polling, VDD and VSS references, FRC
perform an Analog-to-Digital conversion: ;oscillator and AN0 input.
;
1. Configure Port: ;Conversion start & polling for completion
Disable pin output driver (Refer to the TRISx ;are included.
register) ;
BANKSEL ADCON1 ;
Configure pin as analog (Refer to the
MOVLW B11110000 ;Right justify,
ANSELx register)
;FRC oscillator
2. Configure the ADC module: MOVWF ADCON1 ;Vdd and Vss Vref
Select ADC conversion clock BANKSEL TRISA ;
BSF TRISA,0 ;Set RA0 to input
Configure voltage reference
BANKSEL ANSEL ;
Select ADC input channel BSF ANSEL,0 ;Set RA0 to analog
(precharge+acquisition) BANKSEL ADCON0 ;
Turn on ADC module MOVLW B00000001 ;Select channel AN0
MOVWF ADCON0 ;Turn ADC On
3. Configure ADC interrupt (optional):
CALL SampleTime ;Acquisiton delay
Clear ADC interrupt flag BSF ADCON0,ADGO ;Start conversion
Enable ADC interrupt BTFSC ADCON0,ADGO ;Is conversion done?
Enable peripheral interrupt (PEIE bit) GOTO $-1 ;No, test again
BANKSEL ADRESH ;
Enable global interrupt (GIE bit)(1) MOVF ADRESH,W ;Read upper 2 bits
4. If ADACQ = 0, software must wait the required MOVWF RESULTHI ;store in GPR space
acquisition time(2). BANKSEL ADRESL ;
5. Start conversion by setting the ADGO bit. MOVF ADRESL,W ;Read lower 8 bits
MOVWF RESULTLO ;Store in GPR space
6. Wait for ADC conversion to complete by one of
the following:
Polling the ADGO bit
Waiting for the ADC interrupt (interrupts
enabled)
7. Read ADC Result.
8. Clear the ADC interrupt flag (required if interrupt
is enabled).

Note 1: The global interrupt can be disabled if the


user is attempting to wake-up from Sleep
and resume in-line code execution.
2: Refer to Section 31.3 ADC Acquisi-
tion Requirements.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 432


PIC18(L)F26/45/46K40
31.3 ADC Acquisition Requirements source impedance is decreased, the acquisition time
may be decreased. After the analog input channel is
For the ADC to meet its specified accuracy, the charge selected (or changed), an ADC acquisition must be
holding capacitor (CHOLD) must be allowed to fully completed before the conversion can be started. To
charge to the input channel voltage level. The Analog calculate the minimum acquisition time, Equation 31-1
Input model is shown in Figure 31-4. The source may be used. This equation assumes that 1/2 LSb error
impedance (RS) and the internal sampling switch (RSS) is used (1,024 steps for the ADC). The 1/2 LSb error is
impedance directly affect the time required to charge the maximum error allowed for the ADC to meet its
the capacitor CHOLD. The sampling switch (RSS) specified resolution.
impedance varies over the device voltage (VDD), refer
to Figure 31-4. The maximum recommended
impedance for analog sources is 10 k. As the

EQUATION 31-1: ACQUISITION TIME EXAMPLE

Assumptions: Temperature = 50C and external impedance of 10k 5.0V V DD

T ACQ = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient
= T AMP + T C + T COFF
= 2s + T C + Temperature - 25C 0.05s/C

The value for TC can be approximated with the following equations:

V AP P LI ED 1 -------------------------- = V CHOLD
1
;[1] VCHOLD charged to within 1/2 lsb
n+1
2 1
TC
----------
RC
V AP P LI ED 1 e = V CHOLD ;[2] VCHOLD charge response to VAPPLIED

Tc
---------
V AP P LI ED 1 e = V A PP LIE D 1 -------------------------- ;combining [1] and [2]
RC 1
n+1
2 1

Note: Where n = number of bits of the ADC.

Solving for TC:

T C = C HOLD R IC + R SS + R S ln(1/2047)
= 10pF 1k + 7k + 10k ln(0.0004885)
= 1.37 s
Therefore:
T A CQ = 2s + 892ns + 50C- 25C 0.05 s/C
= 4.62s

Note 1: The reference voltage (VREF) has no effect on the equation, since it cancels itself out.
2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
3: The maximum recommended impedance for analog sources is 10 k. This is required to meet the pin
leakage specification.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 433


PIC18(L)F26/45/46K40
FIGURE 31-4: ANALOG INPUT MODEL

VDD
Analog Sampling
Input Switch
VT 0.6V
Rs pin RIC 1k SS Rss

VA CPIN I LEAKAGE(1)
VT 0.6V CHOLD = 10 pF
5 pF
Ref-

6V
5V RSS
Legend: CHOLD = Sample/Hold Capacitance VDD 4V
3V
CPIN = Input Capacitance 2V
I LEAKAGE = Leakage current at the pin due to
various junctions
5 6 7 8 9 10 11
RIC = Interconnect Resistance
Sampling Switch
RSS = Resistance of Sampling Switch (k)
SS = Sampling Switch
VT = Threshold Voltage

Note 1: Refer to Table 37-4 (parameter D340 and D341).

FIGURE 31-5: ADC TRANSFER FUNCTION

Full-Scale Range

3FFh
3FEh
3FDh
3FCh
ADC Output Code

3FBh

03h
02h
01h
00h
Analog Input Voltage
0.5 LSB 1.5 LSB

REF- Zero-Scale
Transition Full-Scale
Transition REF+

2016 Microchip Technology Inc. Preliminary DS40001816C-page 434


PIC18(L)F26/45/46K40
31.4 Capacitive Voltage Divider (CVD)
Features
The ADC module contains several features that allow
the user to perform a relative capacitance
measurement on any ADC channel using the internal
ADC sample and hold capacitance as a reference. This
relative capacitance measurement can be used to
implement capacitive touch or proximity sensing
applications. Figure 31-6 shows the basic block
diagram of the CVD portion of the ADC module.

FIGURE 31-6: HARDWARE CAPACITIVE VOLTAGE DIVIDER BLOCK DIAGRAM

ADOUT Pad

ADOUT

ADOEN

VDD

ADIPPOL = 1

ANx ADC Conversion Bus

ANx Pads
ADIPPOL = 0

VGND

ADDCAP<2:0>
Additional
Sample and
Hold Cap

VGND VGND VGND

2016 Microchip Technology Inc. Preliminary DS40001816C-page 435


PIC18(L)F26/45/46K40
31.4.1 CVD OPERATION
A CVD operation begins with the ADCs internal
sample and hold capacitor (CHOLD) being
disconnected from the path which connects it to the
external capacitive sensor node. While disconnected,
CHOLD is precharged to VDD or VSS, while the path to
the sensor node is also discharged to VDD or VSS.
Typically, this node is discharged to the level opposite
that of CHOLD. When the precharge phase is complete,
the VDD/VSS bias paths for the two nodes are shut off
and CHOLD and the path to the external sensor node
are re-connected, at which time the acquisition phase
of the CVD operation begins. During acquisition, a
capacitive voltage divider is formed between the
precharged CHOLD and sensor nodes, which results in
a final voltage level setting on CHOLD, which is
determined by the capacitances and precharge levels
of the two nodes. After acquisition, the ADC converts
the voltage level on CHOLD. This process is then
repeated with the selected precharge levels for both
the CHOLD and the inverted sensor nodes. Figure 31-7
shows the waveform for two inverted CVD
measurements, which is known as differential CVD
measurement.

FIGURE 31-7: DIFFERENTIAL CVD MEASUREMENT WAVEFORM

Precharge Acquisition Conversion Precharge Acquisition Conversion


VDD
ADC Sample and Hold Capacitor
Voltage

External Capacitive Sensor

VSS
First Sample Second Sample
Time

2016 Microchip Technology Inc. Preliminary DS40001816C-page 436


PIC18(L)F26/45/46K40
31.4.2 PRECHARGE CONTROL 31.4.4 GUARD RING OUTPUTS
The Precharge stage is an optional period of time that Figure 31-8 shows a typical guard ring circuit. CGUARD
brings the external channel and internal sample and represents the capacitance of the guard ring trace
hold capacitor to known voltage levels. Precharge is placed on the PCB board. The user selects values for
enabled by writing a non-zero value to the ADPRE RA and RB that will create a voltage profile on CGUARD,
register. This stage is initiated when an ADC which will match the selected acquisition channel.
conversion begins, either from setting the ADGO bit, a The purpose of the guard ring is to generate a signal in
special event trigger, or a conversion restart from the phase with the CVD sensing signal to minimize the
computation functionality. If the ADPRE register is effects of the parasitic capacitance on sensing elec-
cleared when an ADC conversion begins, this stage is trodes. It also can be used as a mutual drive for mutual
skipped. capacitive sensing. For more information about active
During the precharge time, CHOLD is disconnected from guard and mutual drive, see Application Note AN1478,
the outer portion of the sample path that leads to the mTouchTM Sensing Solution Acquisition Methods
external capacitive sensor and is connected to either Capacitive Voltage Divider (DS01478).
VDD or VSS, depending on the value of the ADPPOL bit The ADC has two guard ring drive outputs, ADGRDA
of ADCON1. At the same time, the port pin logic of the and ADGRDB. These outputs can be routed through
selected analog channel is overridden to drive a digital PPS controls to I/O pins (see Section
high or low out, in order to precharge the outer portion 17.0 Peripheral Pin Select (PPS) Module for
of the ADCs sample path, which includes the external details) and the polarity of these outputs are controlled
sensor. The output polarity of this override is also deter- by the ADGPOL and ADIPEN bits of ADCON1.
mined by the ADPPOL bit of ADCON1. The amount of
time that this charging needs is controlled by the At the start of the first precharge stage, both outputs
ADPRE register. are set to match the ADGPOL bit of ADCON1. Once
the acquisition stage begins, ADGRDA changes
polarity, while ADGRDB remains unchanged. When
Note: The external charging overrides the TRIS performing a double sample conversion, setting the
setting of the respective I/O pin. If there is ADIPEN bit of ADCON1 causes both guard ring
a device attached to this pin, Precharge outputs to transition to the opposite polarity of
should not be used. ADGPOL at the start of the second precharge stage,
and ADGRDA toggles again for the second acquisition.
31.4.3 ACQUISITION CONTROL For more information on the timing of the guard ring
output, refer to Figure 31-8 and Figure 31-9.
The Acquisition stage is an optional time for the voltage
on the internal sample and hold capacitor to charge or
FIGURE 31-8: GUARD RING CIRCUIT
discharge from the selected analog channel.This
acquisition time is controlled by the ADACQ register. If
ADPRE = 0, acquisition starts at the beginning of
conversion. When ADPRE = 1, the acquisition stage ADGRDA
begins when precharge ends. RA
At the start of the acquisition stage, the port pin logic of
the selected analog channel is overridden to turn off the
digital high/low output drivers so they do not affect the
final result of the charge averaging. Also, the selected RB CGUARD
ADC channel is connected to CHOLD. This allows
charge averaging to proceed between the precharged ADGRDB
channel and the CHOLD capacitor.

Note: When ADPRE! = 0, acquisition time can-


not be 0. In this case, setting ADACQ to
0 will set a maximum acquisition time
(256 ADC clock cycles). When precharge
is disabled, setting ADACQ to 0 will dis-
able hardware acquisition time control.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 437


PIC18(L)F26/45/46K40
FIGURE 31-9: DIFFERENTIAL CVD WITH GUARD RING OUTPUT WAVEFORM
VDD

Voltage
External Capacitive Sensor
Guard Ring Output

VSS
First Sample Second Sample
Time

FIGURE 31-10: HARDWARE CVD SEQUENCE TIMING DIAGRAM


Precharge Acquisition/ Conversion Time
Time Sharing Time (Traditional Timing of ADC Conversion)
1-255 TINST 1-255 TINST
(TPRE) (TACQ) TCY - TAD TAD1 TAD2 TAD3 TAD4 TAD5 TAD6 TAD7 TAD8 TAD9 TAD10 TAD11
b9 b8 b7 b6 b5 b4 b3 b2 b1 b0
External and Internal External and Internal Conversion starts
Channels are Channels share
charged/discharged charge Holding capacitor CHOLD is disconnected from analog input (typically 100 ns)

If ADPRE 0 If ADACQ 0 If ADPRE = 0 On the following cycle:


If ADACQ = 0
AADRES0H:AADRES0L is loaded,
(Traditional Operation Start)
ADIF bit is set,
GO/DONE bit is cleared
Set GO/DONE bit

31.4.5 ADDITIONAL SAMPLE AND HOLD


CAPACITANCE
Additional capacitance can be added in parallel with the
internal sample and hold capacitor (CHOLD) by using
the ADCAP register. This register selects a digitally
programmable capacitance which is added to the ADC
conversion bus, increasing the effective internal capac-
itance of the sample and hold capacitor in the ADC
module. This is used to improve the match between
internal and external capacitance for a better sensing
performance. The additional capacitance does not
affect analog performance of the ADC because it is not
connected during conversion. See Figure 31-11.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 438


PIC18(L)F26/45/46K40
31.5 Computation Operation
The ADC module hardware is equipped with post
conversion computation features. These features
provide data post-processing functions that can be
operated on the ADC conversion result, including
digital filtering/averaging and threshold comparison
functions.

FIGURE 31-11: COMPUTATIONAL FEATURES SIMPLIFIED BLOCK DIAGRAM


Rev. 10-000260B
8/4/2015

ADCALC<2:0>

ADMD<2:0>
ADRES

ADFILT
Set
Error Threshold
Interrupt
Average/ Calculation ADERR Logic
1 Flag
Filter ADPREV
0
ADSTPT
ADUTHR ADLTHR
ADPSIS

The operation of the ADC computational features is


controlled by ADMD <2:0> bits in the ADCON2 register.
The module can be operated in one of five modes:
Basic: This is a legacy mode. In this mode, ADC
conversion occurs on single (ADDSEN = 0) or double
(ADDSEN = 1) samples. ADIF is set after all the
conversion are complete.
Accumulate: With each trigger, the ADC conversion
result is added to accumulator and ADCNT increments.
ADIF is set after each conversion. ADTIF is set accord-
ing to the calculation mode.
Average: With each trigger, the ADC conversion
result is added to the accumulator. When the ADRPT
number of samples have been accumulated, a
threshold test is performed. Upon the next trigger, the
accumulator is cleared. For the subsequent tests,
additional ADRPT samples are required to be
accumulated.
Burst Average: At the trigger, the accumulator is
cleared. The ADC conversion results are then collected
repetitively until ADRPT samples are accumulated and
finally the threshold is tested.
Low-Pass Filter (LPF): With each trigger, the ADC
conversion result is sent through a filter. When ADRPT
samples have occurred, a threshold test is performed.
Every trigger after that the ADC conversion result is
sent through the filter and another threshold test is
performed.
The five modes are summarized in Table 31-3 below.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 439


2016 Microchip Technology Inc.

TABLE 31-3: COMPUTATION MODES


Bit Clear Conditions Value after Trigger completion Threshold Operations Value at ADTIF interrupt

Mode ADMD ADACC and ADCNT ADACC ADCNT Retrigger Threshold Interrupt ADAOV ADFLTR ADCNT
Test
Basic 0 ADACLR = 1 Unchanged Unchanged No Every If thresh- N/A N/A count
Sample old=true
Accumulate 1 ADACLR = 1 S + ADACC If (ADCNT=FF): ADCNT, No Every If thresh- ADACC Overflow ADACC/2ADCRS count
or otherwise: ADCNT+1 Sample old=true
(S2-S1) + ADACC
Average 2 ADACLR = 1 or S + ADACC If (ADCNT=FF): ADCNT, No If If thresh- ADACC Overflow ADACC/2ADCRS count
ADCNT>=ADRPT at ADGO or otherwise: ADCNT+1 ADCNT>= old=true
or retrigger (S2-S1) + ADACC ADRPT
Burst 3 ADACLR = 1 or ADGO set or Each repetition: same as Each repetition: same as Repeat while If If thresh- ADACC Overflow ADACC/2ADCRS ADRPT
Average retrigger Average Average ADCNT<ADRPT ADCNT>= old=true
End with sum of all End with ADCNT=ADRPT ADRPT
samples
Low-pass 4 ADACLR = 1 S+ADACC-ADACC/ If (ADCNT=FF): ADCNT, No If If thresh- ADACC Overflow Filtered Value count
Filter 2ADCRS otherwise: ADCNT+1 ADCNT>= old=true
or ADRPT
(S2-S1)+ADACC-ADACC/
Preliminary

2ADCRS

Note: S1 and S2 are abbreviations for Sample 1 and Sample 2, respectively. When ADDSEN = 0, S1 = ADRES; When ADDSEN = 1, S1 = ADPREV and S2 = ADRES.

PIC18(L)F26/45/46K40
DS40001816C-page 440
PIC18(L)F26/45/46K40
31.5.1 DIGITAL FILTER/AVERAGE register, as well as the ADCNT register. The ADACLR
bit is cleared by the hardware when accumulator
The digital filter/average module consists of an accu-
clearing action is complete.
mulator with data feedback options, and control logic to
determine when threshold tests need to be applied.
The accumulator is a 16-bit wide register which can be Note: When ADC is operating from FRC, five
accessed through the ADACCH:ADACCL register pair. FRC clock cycles are required to execute
the ADACC clearing operation.
Upon each trigger event (the ADGO bit set or external
event trigger), the ADC conversion result is added to The ADCRS <2:0> bits in the ADCON2 register control
the accumulator. If the accumulated value exceeds the data shift on the accumulator result, which
2(accumulator_width)-1 = 216 = 65535, the overflow bit effectively divides the value in accumulator
ADAOV in the ADSTAT register is set. (ADACCH:ADACCL) register pair. For the Accumulate
mode of the digital filter, the shift provides a simple
The number of samples to be accumulated is
scaling operation. For the Average/Burst Average
determined by the ADRPT (A/D Repeat Setting)
mode, the shift bits are used to determine number of
register. Each time a sample is added to the
samples for averaging. For the Low-pass Filter mode,
accumulator, the ADCNT register is incremented. Once
the shift is an integral part of the filter, and determines
ADRPT samples are accumulated (ADCNT = ADRPT),
the cut-off frequency of the filter. Table 31-4 shows the
an accumulator clear command can be issued by the
-3 dB cut-off frequency in T (radians) and the highest
software by setting the ADACLR bit in the ADCON2
signal attenuation obtained by this filter at nyquist
register. Setting the ADACLR bit will also clear the
frequency (T = ).
ADAOV (Accumulator overflow) bit in the ADSTAT

TABLE 31-4: LOW-PASS FILTER -3 dB CUT-OFF FREQUENCY


ADCRS T (radians) @ -3 dB Frequency dB @ Fnyquist=1/(2T)
1 0.72 -9.5
2 0.284 -16.9
3 0.134 -23.5
4 0.065 -29.8
5 0.032 -36.0
6 0.016 -42.0
7 0.0078 -48.1

31.5.2 BASIC MODE 31.5.4 AVERAGE MODE


Basic mode (ADMD = 000) disables all additional In Average Mode (ADMD = 010), the ADACC registers
computation features. In this mode, no accumulation accumulate with each ADC sample, much as in
occurs but threshold error comparison is performed. Accumulate mode, and the ADCNT register increments
Double sampling, Continuous mode, and all CVD with each sample. The ADFLT register is also updated
features are still available, but no features involving the with the right-shifted value of the ADACC register. The
digital filter/average features are used. value of the ADCRS bits governs the number of right
shifts. However, in Average mode, the threshold
31.5.3 ACCUMULATE MODE comparison is performed upon ADCNT being greater
In Accumulate mode (ADMD = 001), after every than or equal to a user-defined ADRPT value. In this
conversion, the ADC result is added to the ADACC mode when ADRPT = 2^ADCNT, then the final
register. The ADACC register is right-shifted by the accumulated value will be divided by number of
value of the ADCRS bits in the ADCON2 register. This samples, allowing for a threshold comparison operation
right-shifted value is copied in to the ADFLT register. on the average of all gathered samples.
The Formatting mode does not affect the
right-justification of the ADACC value. Upon each
sample, ADCNT is also incremented, incrementing the
number of samples accumulated. After each sample
and accumulation, the ADACC value has a threshold
comparison performed on it (see Section
31.5.7 Threshold Comparison) and the ADTIF
interrupt may trigger.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 441


PIC18(L)F26/45/46K40
31.5.5 BURST AVERAGE MODE 31.5.7 THRESHOLD COMPARISON
The Burst Average mode (ADMD = 011) acts the same At the end of each computation:
as the Average mode in most respects. The one way it The conversion results are latched and held
differs is that it continuously retriggers ADC sampling stable at the end-of-conversion.
until the ADCNT value is greater than or equal to The error is calculated based on a difference
ADRPT, even if Continuous Sampling mode (see calculation which is selected by the
Section 31.5.8 Continuous Sampling mode) is not ADCALC<2:0> bits in the ADCON3 register. The
enabled. This allows for a threshold comparison on the value can be one of the following calculations
average of a short burst of ADC samples. (see Register 31-4 for more details):
- The first derivative of single measurements
31.5.6 LOW-PASS FILTER MODE
- The CVD result in CVD mode
The Low-pass Filter mode (ADMD = 100) acts similarly - The current result vs. a setpoint
to the Average mode in how it handles samples - The current result vs. the filtered/average
(accumulates samples until ADCNT value greater than result
or equal to ADRPT, then triggers threshold - The first derivative of the filtered/average
comparison), but instead of a simple average, it value
performs a low-pass filter operation on all of the - Filtered/average value vs. a setpoint
samples, reducing the effect of high-frequency noise The result of the calculation (ADERR) is
on the average, then performs a threshold comparison compared to the upper and lower thresholds,
on the results. (see Table 31-3 for a more detailed ADUTH<ADUTHH:ADUTHL> and
description of the mathematical operation). In this ADLTH<ADLTHH:ADLTHL> registers, to set the
mode, the ADCRS bits determine the cut-off frequency ADUTHR and ADLTHR flag bits. The threshold
of the low-pass filter (as demonstrated by Table 31-4). logic is selected by ADTMD<2:0> bits in the
ADCON3 register. The threshold trigger option
can be one of the following:
- Never interrupt
- Error is less than lower threshold
- Error is greater than or equal to lower
threshold
- Error is between thresholds (inclusive)
- Error is outside of thresholds
- Error is less than or equal to upper threshold
- Error is greater than upper threshold
- Always interrupt regardless of threshold test
results
- If the threshold condition is met, the threshold
interrupt flag ADTIF is set.

Note 1: The threshold tests are signed


operations.
2: If ADAOV is set, a threshold interrupt is
signaled.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 442


PIC18(L)F26/45/46K40
31.5.8 CONTINUOUS SAMPLING MODE 31.5.9 DOUBLE SAMPLE CONVERSION
Setting the ADCONT bit in the ADCON0 register Double sampling is enabled by setting the ADDSEN bit
automatically retriggers a new conversion cycle after of the ADCON1 register. When this bit is set, two
updating the ADACC register. That means the ADGO conversions are required before the module will
bit is set to generate automatic retriggering, until the calculate threshold error (each conversion must still be
device Reset occurs or the A/D Stop-on-interrupt bit triggered separately). The first conversion will set the
(ADSOI in the ADCON3 register) is set (correct logic). ADMATH bit of the ADSTAT register and update
ADACC, but will not calculate ADERR or trigger ADTIF.
When the second conversion completes, the first value
is transferred to ADPREV (depending on the setting of
ADPSIS) and the value of the second conversion is
placed into ADRES. Only upon the completion of the
second conversion is ADERR calculated and ADTIF
triggered (depending on the value of ADCALC).

31.6 Register Definitions: ADC Control

REGISTER 31-1: ADCON0: ADC CONTROL REGISTER 0


R/W-0/0 R/W-0/0 U-0 R/W-0/0 U-0 R/W-0/0 U-0 R/W/HC-0
ADON ADCONT ADCS ADFM ADGO
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 ADON: ADC Enable bit


1 = ADC is enabled
0 = ADC is disabled
bit 6 ADCONT: ADC Continuous Operation Enable bit
1 = ADGO is retriggered upon completion of each conversion trigger until ADTIF is set (if ADSOI is
set) or until ADGO is cleared (regardless of the value of ADSOI)
0 = ADC is cleared upon completion of each conversion trigger
bit 5 Unimplemented: Read as 0
bit 4 ADCS: ADC Clock Selection bit
1 = Clock supplied from FRC dedicated oscillator
0 = Clock supplied by FOSC, divided according to ADCLK register
bit 3 Unimplemented: Read as 0
bit 2 ADFM: ADC results Format/alignment Selection
1 = ADRES and ADPREV data are right-justified
0 = ADRES and ADPREV data are left-justified, zero-filled
bit 1 Unimplemented: Read as 0
bit 0 ADGO: ADC Conversion Status bit
1 = ADC conversion cycle in progress. Setting this bit starts an ADC conversion cycle. The bit is
cleared by hardware as determined by the ADCONT bit
0 = ADC conversion completed/not in progress

2016 Microchip Technology Inc. Preliminary DS40001816C-page 443


PIC18(L)F26/45/46K40
REGISTER 31-2: ADCON1: ADC CONTROL REGISTER 1
R/W-0/0 R/W-0/0 R/W-0/0 U-0 U-0 U-0 U-0 R/W-0/0
ADPPOL ADIPEN ADGPOL ADDSEN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7 ADDPOL: Precharge Polarity bit


If ADPRE>0x00:

Action During 1st Precharge Stage


ADPPOL
External (selected analog I/O pin) Internal (AD sampling capacitor)
1 Shorted to AVDD CHOLD shorted to VSS
0 Shorted to VSS CHOLD shorted to AVDD

Otherwise:
The bit is ignored
bit 6 ADIPEN: A/D Inverted Precharge Enable bit
If ADDSEN = 1
1 = The precharge and guard signals in the second conversion cycle are the opposite polarity of the
first cycle
0 = Both Conversion cycles use the precharge and guards specified by ADPPOL and ADGPOL
Otherwise:
The bit is ignored
bit 5 ADGPOL: Guard Ring Polarity Selection bit
1 = ADC guard Ring outputs start as digital high during Precharge stage
0 = ADC guard Ring outputs start as digital low during Precharge stage
bit 4-1 Unimplemented: Read as 0
bit 0 ADDSEN: Double-sample enable bit
1 = Two conversions are performed on each trigger. Data from the first conversion appears in
ADPREV
0 = One conversion is performed for each trigger

2016 Microchip Technology Inc. Preliminary DS40001816C-page 444


PIC18(L)F26/45/46K40

REGISTER 31-3: ADCON2: ADC CONTROL REGISTER 2


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W/HC-0 R/W-0/0 R/W-0/0 R/W-0/0
ADPSIS ADCRS<2:0> ADACLR ADMD<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 ADPSIS: ADC Previous Sample Input Select bits


1 = ADFLTR is transfered to ADPREV at start-of-conversion
0 = ADRES is transfered to ADPREV at start-of-conversion
bit 6-4 ADCRS<2:0>: ADC Accumulated Calculation Right Shift Select bits
If ADMD = 100:
Low-pass filter time constant is 2ADCRS, filter gain is 1:1
If ADMD = 001, 010 or 011:
The accumulated value is right-shifted by ADCRS (divided by 2ADCRS)(1,2)
Otherwise:
Bits are ignored
bit 3 ADACLR: A/D Accumulator Clear Command bit(3)
0 = Clearing action is complete (or not started)
1 = ADACC, ADAOV and ADCNT registers are cleared
bit 2-0 ADMD<2:0>: ADC Operating Mode Selection bits(4)
111-101 = Reserved
100 = Low-pass Filter mode
011 = Burst Average mode
010 = Average mode
001 = Accumulate mode
000 = Basic (Legacy) mode
Note 1: To correctly calculate an average, the number of samples (set in ADRPT) must be 2ADCRS.
2: ADCRS = 3'b111 is a reserved option.
3: This bit is cleared by hardware when the accumulator operation is complete; depending on oscillator
selections, the delay may be many instructions.
4: See Table 31-2 for Full mode descriptions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 445


PIC18(L)F26/45/46K40

REGISTER 31-4: ADCON3: ADC CONTROL REGISTER 3


U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W/HC-0 R/W-0/0 R/W-0/0 R/W-0/0
ADCALC<2:0> ADSOI ADTMD<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HC = Bit is cleared by hardware

bit 7 Unimplemented: Read as 0


bit 6-4 ADCALC<2:0>: ADC Error Calculation Mode Select bits

Action During 1st Precharge Stage


ADCALC ADDSEN = 0 ADDSEN = 1 CVD Application
Single-Sample Mode Double-Sample Mode(1)
111 Reserved Reserved Reserved
110 Reserved Reserved Reserved
101 ADLFTR-ADSTPT ADFLTR-ADSTPT Average/filtered value vs.
setpoint
100 ADPREV-ADFLTR ADPREV-ADFLTR First derivative of filtered
value(3) (negative)
011 Reserved Reserved Reserved
010 ADRES-ADFLTR (ADRES-ADPREV)-ADFLTR Actual result vs.
averaged/filtered value
001 ADRES-ADSTPT (ADRES-ADPREV)-ADSTPT Actual result vs.setpoint
000 ADRES-ADPREV ADRES-ADPREV First derivative of single
measurement(2)
Actual CVD result in CVD
mode(2)

bit 3 ADSOI: ADC Stop-on-Interrupt bit


If ADCONT = 1:
1 = ADGO is cleared when the threshold conditions are met, otherwise the conversion is retriggered
0 = ADGO is not cleared by hardware, must be cleared by software to stop retriggers
bit 2-0 ADTMD<2:0>: Threshold Interrupt Mode Select bits
111 = Interrupt regardless of threshold test results
110 = Interrupt if ADERR>ADUTH
101 = Interrupt if ADERRADUTH
100 = Interrupt if ADERRADLTH or ADERR>ADUTH
011 = Interrupt if ADERR>ADLTH and ADERR<ADUTH
010 = Interrupt if ADERRADLTH
001 = Interrupt if ADERR<ADLTH
000 = Never interrupt

Note 1: When ADPSIS = 0, the value of ADRES-ADPREV) is the value of (S2-S1) from Table 31-3.
2: When ADPSIS = 0
3: When ADPSIS = 1.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 446


PIC18(L)F26/45/46K40

REGISTER 31-5: ADSTAT: ADC STATUS REGISTER


R-0/0 R-0/0 R-0/0 R/HS/HC-0/0 U-0 R-0/0 R-0/0 R-0/0
ADAOV ADUTHR ADLTHR ADMATH ADSTAT<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared HS/HC = Bit is set/cleared by hardware

bit 7 ADAOV: ADC Accumulator Overflow bit


1 = ADC accumulator or ADERR calculation have overflowed
0 = ADC accumulator and ADERR calculation have not overflowed
bit 6 ADUTHR: ADC Module Greater-than Upper Threshold Flag bit
1 = ADERR >ADUTH
0 = ADERRADUTH
bit 5 ADLTHR: ADC Module Less-than Lower Threshold Flag bit
1 = ADERR<ADLTH
0 = ADERRADLTH
bit 4 ADMATH: ADC Module Computation Status bit
1 = Registers ADACC, ADFLTR, ADUTH, ADLTH and the ADAOV bit are updating or have already
updated
0 = Associated registers/bits have not changed since this bit was last cleared
bit 3 Unimplemented: Read as 0
bit 2-0 ADSTAT<2:0>: ADC Module Cycle Multistage Status bits(1)
111 = ADC module is in 2nd conversion stage
110 = ADC module is in 2nd acquisition stage
101 = ADC module is in 2nd precharge stage
100 = Not used
011 = ADC module is in 1st conversion stage
010 = ADC module is in 1st acquisition stage
001 = ADC module is in 1st precharge stage
000 = ADC module is not converting

Note 1: If ADCS = 1, and FOSC<FRC, these bits may be invalid.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 447


PIC18(L)F26/45/46K40

REGISTER 31-6: ADCLK: ADC CLOCK SELECTION REGISTER


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADCS<5:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5-0 ADCS<5:0>: ADC Conversion Clock Select bits
111111 = FOSC/128
111110 = FOSC/126
111101 = FOSC/124



000000 = FOSC/2

REGISTER 31-7: ADREF: ADC REFERENCE SELECTION REGISTER


U-0 U-0 U-0 R/W-0/0 U-0 U-0 R/W-0/0 R/W-0/0
ADNREF ADPREF<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 Unimplemented: Read as 0


bit 4 ADNREF: ADC Negative Voltage Reference Selection bit
1 = VREF- is connected to external VREF-
0 = VREF- is connected to AVSS
bit 3-2 Unimplemented: Read as 0
bit 1-0 ADPREF: ADC Positive Voltage Reference Selection bits
11 = VREF+ is connected to internal Fixed Voltage Reference (FVR) module
10 = VREF+ is connected to external VREF+
01 = Reserved
00 = VREF+ is connected to VDD

2016 Microchip Technology Inc. Preliminary DS40001816C-page 448


PIC18(L)F26/45/46K40

REGISTER 31-8: ADPCH: ADC POSITIVE CHANNEL SELECTION REGISTER


U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADPCH<5:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 Unimplemented: Read as 0


bit 5-0 ADPCH<5:0>: ADC Positive Input Channel Selection bits

111111 = Fixed Voltage Reference (FVR)(2) 010111 = ANC7


111110 = DAC1 output(1) 010110 = ANC6
111101 = Temperature Indicator(3) 010101 = ANC5
111100 = AVSS (Analog Ground) 010100 = ANC4
111011 = Reserved. No channel connected. 010011 = ANC3
010010 = ANC2
010001 = ANC1
010000 = ANC0
100010 = ANE2(4) 001111 = ANB7
100001 = ANE1(4) 001110 = ANB6
100000 = ANE0(4) 001101 = ANB5
011111 = AND7(4) 001100 = ANB4
011110 = AND6(4) 001011 = ANB3
011101 = AND5(4) 001010 = ANB2
011100 = AND4(4) 001001 = ANB1
011011 = AND3(4) 001000 = ANB0
011010 = AND2(4) 000111 = ANA7
011001 = AND1(4) 000110 = ANA6
011000 = AND0(4) 000101 = ANA5
000100 = ANA4
000011 = ANA3
000010 = ANA2
000001 = ANA1
000000 = ANA0
Note 1: See Section 30.0 5-Bit Digital-to-Analog Converter (DAC) Module for more information.
2: See Section 28.0 Fixed Voltage Reference (FVR) for more information.
3: See Section 29.0 Temperature Indicator Module for more information.
4: PIC18F45/46K40 only.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 449


PIC18(L)F26/45/46K40

REGISTER 31-9: ADPRE: ADC PRECHARGE TIME CONTROL REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADPRE<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADPRE<7:0>: Precharge Time Select bits


11111111 = Precharge time is 255 clocks of the selected ADC clock
11111110 = Precharge time is 254 clocks of the selected ADC clock



00000001 = Precharge time is 1 clock of the selected ADC clock
00000000 = Precharge time is not included in the data conversion cycle

REGISTER 31-10: ADACQ: ADC ACQUISITION TIME CONTROL REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADACQ<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADACQ<7:0>: Acquisition (charge share time) Select bits


11111111 = Acquisition time is 255 clocks of the selected ADC clock
11111110 = Acquisition time is 254 clocks of the selected ADC clock



00000001 = Acquisition time is 1 clock of the selected ADC clock
00000000 = Acquisition time is not included in the data conversion cycle

Note: If ADPRE is not equal to 0, then ADACQ = b00000000 means Acquisition time is 256 clocks of the
selected ADC clock.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 450


PIC18(L)F26/45/46K40

REGISTER 31-11: ADCAP: ADC ADDITIONAL SAMPLE CAPACITOR SELECTION REGISTER


U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADCAP<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 Unimplemented: Read as 0


bit 4-0 ADCAP<4:0>: ADC Additional Sample Capacitor Selection bits
11111 = 31 pF
11110 = 30 pF
11101 = 29 pF



00011 = 3 pF
00010 = 2 pF
00001 = 1 pF
00000 = No additional capacitance

REGISTER 31-12: ADRPT: ADC REPEAT SETTING REGISTER


R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADRPT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 Unimplemented: Read as 0


bit 7-0 ADRPT<7:0>: ADC Repeat Threshold bits
Counts the number of times that the ADC has been triggered and is used along with ADCNT to deter-
mine when the error threshold is checked when the computation is Low-pass Filter, Burst Average, or
Average modes. See Table 31-3 for more details.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 451


PIC18(L)F26/45/46K40

REGISTER 31-13: ADCNT: ADC REPEAT COUNTER REGISTER


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADCNT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADCNT<7:0>: ADC Repeat Count bits


Determines the number of times that the ADC is triggered before the threshold is checked when the
computation is Low-pass Filter, Burst Average, or Average modes. See Table 31-2 for more details.

REGISTER 31-14: ADFLTRH: ADC FILTER HIGH BYTE REGISTER


R-x R-x R-x R-x R-x R-x R-x R-x
ADFLTR<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADFLTR<15:8>: ADC Filter Output Most Significant bits


In Accumulate, Average, and Burst Average mode, this is equal to ADACC right shifted by the ADCRS
bits of ADCON2. In LPF mode, this is the output of the Low-pass Filter.

REGISTER 31-15: ADFLTRL: ADC FILTER LOW BYTE REGISTER


R-x R-x R-x R-x R-x R-x R-x R-x
ADFLTR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADFLTR<7:0>: ADC Filter Output Least Significant bits


In Accumulate, Average, and Burst Average mode, this is equal to ADACC right shifted by the ADCRS
bits of ADCON2. In LPF mode, this is the output of the Low-pass Filter.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 452


PIC18(L)F26/45/46K40

REGISTER 31-16: ADRESH: ADC RESULT REGISTER HIGH, ADFM = 0


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADRES<9:2>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADRES<9:2>: ADC Result Register bits


Upper eight bits of 10-bit conversion result.

REGISTER 31-17: ADRESL: ADC RESULT REGISTER LOW, ADFM = 0


R/W-x/u R/W-x/u U-0 U-0 U-0 U-0 U-0 U-0
ADRES<1:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-6 ADRES<1:0>: ADC Result Register bits. Lower two bits of 10-bit conversion result.
bit 5-0 Reserved: Do not use.

REGISTER 31-18: ADRESH: ADC RESULT REGISTER HIGH, ADFM = 1


U-0 U-0 U-0 U-0 U-0 U-0 R/W-x/u R/W-x/u
ADRES<9:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-2 Reserved: Do not use.


bit 1-0 ADRES<9:8>: ADC Sample Result bits. Upper two bits of 10-bit conversion result.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 453


PIC18(L)F26/45/46K40

REGISTER 31-19: ADRESL: ADC RESULT REGISTER LOW, ADFM = 1


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADRES<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADRES<7:0>: ADC Result Register bits. Lower eight bits of 10-bit conversion result.

REGISTER 31-20: ADPREVH: ADC PREVIOUS RESULT REGISTER


R-x R-x R-x R-x R-x R-x R-x R-x
ADPREV<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADPREV<15:8>: Previous ADC Results bits


If ADPSIS = 1:
Upper byte of ADFLTR at the start of current ADC conversion
If ADPSIS = 0:
Upper bits of ADRES at the start of current ADC conversion(1)

Note 1: If ADPSIS = 0, ADPREVH and ADPREVL are formatted the same way as ADRES is, depending on the
ADFM bit.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 454


PIC18(L)F26/45/46K40

REGISTER 31-21: ADPREVL: ADC PREVIOUS RESULT REGISTER


R-x R-x R-x R-x R-x R-x R-x R-x
ADPREV<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADPREV<7:0>: Previous ADC Results bits


If ADPSIS = 1:
Lower byte of ADFLTR at the start of current ADC conversion
If ADPSIS = 0:
Lower bits of ADRES at the start of current ADC conversion(1)

Note 1: If ADPSIS = 0, ADPREVH and ADPREVL are formatted the same way as ADRES is, depending on the
ADFM bit.

REGISTER 31-22: ADACCH: ADC ACCUMULATOR REGISTER HIGH


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADACC<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADACC<15:8>: ADC Accumulator MSB. Upper eight bits of accumulator value. See Table 31-2 for
more details.

REGISTER 31-23: ADACCL: ADC ACCUMULATOR REGISTER LOW


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADACC<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADACC<7:0>: ADC Accumulator LSB. Lower eight bits of accumulator value. See Table 31-2 for more
details.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 455


PIC18(L)F26/45/46K40

REGISTER 31-24: ADSTPTH: ADC THRESHOLD SETPOINT REGISTER HIGH


R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u R/W-x/u
ADSTPT<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADSTPT<15:8>: ADC Threshold Setpoint MSB. Upper byte of ADC threshold setpoint, depending on
ADCALC, may be used to determine ADERR, see Register 23-1 for more details.

REGISTER 31-25: ADSTPTL: ADC THRESHOLD SETPOINT REGISTER LOW


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
ADSTPT<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADSTPT<7:0>: ADC Threshold Setpoint LSB. Lower byte of ADC threshold setpoint, depending on
ADCALC, may be used to determine ADERR, see Register 23-1 for more details.

REGISTER 31-26: ADERRH: ADC SETPOINT ERROR REGISTER HIGH


R-x R-x R-x R-x R-x R-x R-x R-x
ADERR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADERR<7:0>: ADC Setpoint Error MSB. Upper byte of ADC Setpoint Error. Setpoint Error calculation
is determined by ADCALC bits of ADCON3, see Register 23-1 for more details.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 456


PIC18(L)F26/45/46K40

REGISTER 31-27: ADERRL: ADC SETPOINT ERROR LOW BYTE REGISTER


R-x R-x R-x R-x R-x R-x R-x R-x
ADERR<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADERR<7:0>: ADC Setpoint Error LSB. Lower byte of ADC Setpoint Error calculation is determined
by ADCALC bits of ADCON3, see Register 23-1 for more details.

REGISTER 31-28: ADLTHH: ADC LOWER THRESHOLD HIGH BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
ADLTH<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADLTH<15:8>: ADC Lower Threshold MSB. ADLTH and ADUTH are compared with ADERR to set
the ADUTHR and ADLTHR bits of ADSTAT. Depending on the setting of ADTMD, an interrupt may be
triggered by the results of this comparison.

REGISTER 31-29: ADLTHL: ADC LOWER THRESHOLD LOW BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
ADLTH<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADLTH<7:0>: ADC Lower Threshold LSB. ADLTH and ADUTH are compared with ADERR to set the
ADUTHR and ADLTHR bits of ADSTAT. Depending on the setting of ADTMD, an interrupt may be
triggered by the results of this comparison.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 457


PIC18(L)F26/45/46K40

REGISTER 31-30: ADUTHH: ADC UPPER THRESHOLD HIGH BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
ADUTH<15:8>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADUTH<15:8>: ADC Upper Threshold MSB. ADLTH and ADUTH are compared with ADERR to set
the ADUTHR and ADLTHR bits of ADSTAT. Depending on the setting of ADTMD, an interrupt may be
triggered by the results of this comparison.

REGISTER 31-31: ADUTHL: ADC UPPER THRESHOLD LOW BYTE REGISTER


R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x R/W-x/x
ADUTH<7:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-0 ADUTH<7:0>: ADC Upper Threshold LSB. ADLTH and ADUTH are compared with ADERR to set the
ADUTHR and ADLTHR bits of ADSTAT. Depending on the setting of ADTMD, an interrupt may be
triggered by the results of this comparison.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 458


PIC18(L)F26/45/46K40

REGISTER 31-32: ADACT: ADC AUTO CONVERSION TRIGGER CONTROL REGISTER


U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0
ADACT<4:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
u = Bit is unchanged x = Bit is unknown -n/n = Value at POR and BOR/Value at all other Resets
1 = Bit is set 0 = Bit is cleared

bit 7-5 Unimplemented: Read as 0


bit 4-0 ADACT<4:0>: Auto-Conversion Trigger Select Bits
11111 = Software write to ADPCH
11110 = Reserved, do not use
11101 = Software read of ADRESH
11100 = Software read of ADERRH
11011 = Reserved, do not use



10000 = Reserved, do not use
01111 = Interrupt-on-change Interrupt Flag
01110 = C2_out
01101 = C1_out
01100 = PWM4_out
01011 = PWM3_out
01010 = CCP2_trigger
01001 = CCP1_trigger
01000 = TMR6_postscaled
00111 = TMR5_overflow
00110 = TMR4_postscaled
00101 = TMR3_overflow
00100 = TMR2_postscaled
00011 = TMR1_overflow
00010 = TMR0_overflow
00001 = Pin selected by ADACTPPS
00000 = External Trigger Disabled

2016 Microchip Technology Inc. Preliminary DS40001816C-page 459


PIC18(L)F26/45/46K40
TABLE 31-5: SUMMARY OF REGISTERS ASSOCIATED WITH ADC
Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIE1 OSCFIE CSWIE ADTIE ADIE 179
PIR1 OSCFIF CSWIF ADTIF ADIF 171
ADCON0 ADON ADCON ADCS ADFM ADGO 443
ADCON1 ADPPOL ADIPEN ADGPOL ADDSEN 444
ADCON2 ADPSIS ADCRS<2:0> ADACLR ADMD<2:0> 445
ADCON3 ADCALC<2:0> ADSOI ADTMD<2:0> 446
ADACT ADACT<4:0> 445
ADRESH ADRESH<7:0> 453, 453
ADRESL ADRESL<7:0> 453, 454
ADPREVH ADPREV<15:8> 454
ADPREVL ADPREV<7:0> 455
ADACCH ADACC<15:8> 455
ADACCL ADACC<7:0> 455
ADSTPTH ADSTPT<15:8> 456
ADSTPT ADSTPT<7:0> 456
ADERRL ADERR<7:0> 457
ADLTHH ADLTH<15:8> 457
ADLTHL ADLTH<7:0> 457
ADUTHH ADUTH<15:8> 458
ADUTHL ADUTH<7:0> 458
ADSTAT ADAOV ADUTHR ADLTHR ADMATH ADSTAT<3:0> 447
ADCLK ADCS<5:0> 448
ADREF ADNREF ADPREF<1:0> 448
ADPCH ADPCH<5:0> 449
ADPRE ADPRE<7:0> 450
ADACQ ADACQ<7:0> 450
ADCAP ADCAP<4:0> 451
ADRPT ADRPT<7:0> 451
ADCNT ADCNT<7:0> 452
ADFLTRH ADFLTR<15:8> 452
ADFLTRL ADFLTR<7:0> 452
FVRCON FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0> 418
DAC1CON1 DAC1R<4:0> 424
OSCSTAT EXTOR HFOR MFOR LFOR SOR ADOR PLLR 39
Legend: = unimplemented read as 0. Shaded cells are not used for the ADC module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 460


PIC18(L)F26/45/46K40
32.0 COMPARATOR MODULE 32.1 Comparator Overview
A single comparator is shown in Figure 32-1 along with
the relationship between the analog input levels and
Note: The PIC18(L)F26/45/46K40 devices have
the digital output. When the analog voltage at VIN+ is
two comparators. Therefore, all informa-
less than the analog voltage at VIN-, the output of the
tion in this section refers to both C1 and
comparator is a digital low level. When the analog
C2.
voltage at VIN+ is greater than the analog voltage at
Comparators are used to interface analog circuits to a VIN-, the output of the comparator is a digital high level.
digital circuit by comparing two analog voltages and
providing a digital indication of their relative magnitudes. FIGURE 32-1: SINGLE COMPARATOR
Comparators are very useful mixed signal building
blocks because they provide analog functionality
VIN+ +
independent of program execution.
Output
The analog comparator module includes the following VIN-
features:
Programmable input selection
Programmable output polarity
Rising/falling output edge interrupts VIN-
Wake-up from Sleep VIN+
CWG Auto-shutdown source
Selectable voltage reference
ADC Auto-trigger
TMR1/3/5 Gate
TMR2/4/6 Reset Output
CCP Capture Mode Input
DSM Modulator Source
Input and Window signal to Signal Measurement Note: The black areas of the output of the
Timer comparator represents the uncertainty
due to input offsets and response time.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 461


PIC18(L)F26/45/46K40
FIGURE 32-2: COMPARATOR MODULE SIMPLIFIED BLOCK DIAGRAM

CxNCH<2:0>
CxEN(1)
3 Interrupt CxINTP

det
CXIN0- 0 Set CxIF
CXIN1- 1
2 MUX Interrupt CxINTN
CXIN2-
(2)
det
CXIN3- 3
CXPOL
Reserved 4 CxNCH
-
to CMXCON0 (CXOUT)
Reserved 5 D Q
Cx and CMOUT (MCXOUT)
FVR Buffer 2 6 +
CxPCH
Q1 EN
7
CxHYS
AGND

CXSYNC
TRIS bit

0
PPS
D Q 1 CXOUT
CXIN0+ 0 From Timer1 RxyPPS
tmr1_clk sync_CxOUT
CXIN1+ 1 To Other
MUX Peripherals
(2)
Reserved 2

Reserved 3

Reserved 4

DAC_Output 5

FVR Buffer 2 6

AGND CxEN

CXPCH<2:0>
3

Note 1: When CxEN = 0, the comparator will produce a 0 at the output.


2: When CxEN = 0, all multiplexer inputs are disconnected.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 462


PIC18(L)F26/45/46K40
32.2 Register Definitions: Comparator Control
Long bit name prefixes for the Comparators are shown
in Table 32-1. Refer to Section 1.4.2.2 Long Bit
Names for more information.
TABLE 32-1:
Peripheral Bit Name Prefix
C1 C1
C2 C2

REGISTER 32-1: CMxCON0: COMPARATOR x CONTROL REGISTER 0


R/W-0/0 R-0/0 U-0 R/W-0/0 U-0 U-1 R/W-0/0 R/W-0/0
EN OUT POL HYS SYNC
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 EN: Comparator Enable bit


1 = Comparator is enabled
0 = Comparator is disabled and consumes no active power
bit 6 OUT: Comparator Output bit
If POL = 0 (non-inverted polarity):
1 = CxVP > CxVN
0 = CxVP < CxVN
If POL = 1 (inverted polarity):
1 = CxVP < CxVN
0 = CxVP > CxVN
bit 5 Unimplemented: Read as 0
bit 4 POL: Comparator Output Polarity Select bit
1 = Comparator output is inverted
0 = Comparator output is not inverted
bit 3 Unimplemented: Read as 0
bit 2 Unimplemented: Read as 1
bit 1 HYS: Comparator Hysteresis Enable bit
1 = Comparator hysteresis enabled
0 = Comparator hysteresis disabled
bit 0 SYNC: Comparator Output Synchronous Mode bit
1 = Comparator output to Timer1/3/5 and I/O pin is synchronous to changes on Timer1 clock source.
0 = Comparator output to Timer1/3/5 and I/O pin is asynchronous
Output updated on the falling edge of Timer1/3/5 clock source.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 463


PIC18(L)F26/45/46K40

REGISTER 32-2: CMxCON1: COMPARATOR x CONTROL REGISTER 1


U-0 U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0
INTP INTN
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1 INTP: Comparator Interrupt on Positive-Going Edge Enable bit
1 = The CxIF interrupt flag will be set upon a positive-going edge of the CxOUT bit
0 = No interrupt flag will be set on a positive-going edge of the CxOUT bit
bit 0 INTN: Comparator Interrupt on Negative-Going Edge Enable bit
1 = The CxIF interrupt flag will be set upon a negative-going edge of the CxOUT bit
0 = No interrupt flag will be set on a negative-going edge of the CxOUT bit

REGISTER 32-3: CMxNCH: COMPARATOR x INVERTING CHANNEL SELECT REGISTER


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
NCH<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-3 Unimplemented: Read as 0


bit 2-0 NCH<2:0>: Comparator Inverting Input Channel Select bits
111 = AVSS
110 = FVR_Buffer2
101 = CxNCH not connected
100 = CxNCH not connected
011 = CxIN3-
010 = CxIN2-
001 = CxIN1-
000 = CxIN0-

2016 Microchip Technology Inc. Preliminary DS40001816C-page 464


PIC18(L)F26/45/46K40

REGISTER 32-4: CMxPCH: COMPARATOR x NON-INVERTING CHANNEL SELECT REGISTER


U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0
PCH<2:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-3 Unimplemented: Read as 0


bit 2-0 PCH<2:0>: Comparator Non-Inverting Input Channel Select bits
111 = AVSS
110 = FVR_Buffer2
101 = DAC_Output
100 = CxPCH not connected
011 = CxPCH not connected
010 = CxPCH not connected
001 = CxIN1+
000 = CxIN0+

REGISTER 32-5: CMOUT: COMPARATOR OUTPUT REGISTER


U-0 U-0 U-0 U-0 U-0 U-0 R-0/0 R-0/0
MC2OUT MC1OUT
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7-2 Unimplemented: Read as 0


bit 1 MC2OUT: Mirror copy of C2OUT bit
bit 0 MC1OUT: Mirror copy of C1OUT bit

2016 Microchip Technology Inc. Preliminary DS40001816C-page 465


PIC18(L)F26/45/46K40
32.3 Comparator Control 32.3.3 COMPARATOR OUTPUT POLARITY
Each comparator has two control registers: CMxCON0 Inverting the output of the comparator is functionally
and CMxCON1. equivalent to swapping the comparator inputs. The
polarity of the comparator output can be inverted by
The CMxCON0 register (see Register 32-1) contains setting the CxPOL bit of the CMxCON0 register.
Control and Status bits for the following: Clearing the CxPOL bit results in a non-inverted output.
Enable Table 32-2 shows the output state versus input
Output conditions, including polarity control.
Output polarity TABLE 32-2: COMPARATOR OUTPUT
Hysteresis enable STATE VS. INPUT
Timer1 output synchronization CONDITIONS
The CMxCON1 register (see Register 32-2) contains Input Condition CxPOL CxOUT
Control bits for the following:
CxVN > CxVP 0 0
Interrupt on positive/negative edge enables
CxVN < CxVP 0 1
Positive input channel selection
CxVN > CxVP 1 1
Negative input channel selection
CxVN < CxVP 1 0
32.3.1 COMPARATOR ENABLE
Setting the EN bit of the CMxCON0 register enables
the comparator for operation. Clearing the CxEN bit
disables the comparator resulting in minimum current
consumption.

32.3.2 COMPARATOR OUTPUT


The output of the comparator can be monitored by
reading either the CxOUT bit of the CMxCON0 register
or the MCxOUT bit of the CMOUT register.
The comparator output can also be routed to an
external pin through the RxyPPS register (Register 17-2).
The corresponding TRIS bit must be clear to enable the
pin as an output.
Note 1: The internal output of the comparator is
latched with each instruction cycle.
Unless otherwise specified, external out-
puts are not latched.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 466


PIC18(L)F26/45/46K40
32.4 Comparator Hysteresis The associated interrupt flag bit, CxIF bit of the PIR2
register, must be cleared in software. If another edge is
A selectable amount of separation voltage can be detected while this flag is being cleared, the flag will still
added to the input pins of each comparator to provide a be set at the end of the sequence.
hysteresis function to the overall operation. Hysteresis
is enabled by setting the CxHYS bit of the CMxCON0 Note: Although a comparator is disabled, an
register. interrupt can be generated by changing
the output polarity with the CxPOL bit of
See Comparator Specifications in Table 37-15 for more
the CMxCON0 register, or by switching
information.
the comparator on or off with the CxEN bit
of the CMxCON0 register.
32.5 Timer1/3/5 Gate Operation
The output resulting from a comparator operation can 32.7 Comparator Positive Input
be used as a source for gate control of Timer1/3/5. See Selection
Section 19.8 Timer1/3/5 Gate for more information.
This feature is useful for timing the duration or interval Configuring the PCH<2:0> bits of the CMxPCH register
of an analog event. directs an internal voltage reference or an analog pin to
the non-inverting input of the comparator:
It is recommended that the comparator output be
synchronized to Timer1. This ensures that Timer1 does CxIN0+, CxIN1+ analog pin
not increment while a change in the comparator is DAC output
occurring. FVR (Fixed Voltage Reference)
AVSS (Ground)
32.5.1 COMPARATOR OUTPUT
SYNCHRONIZATION See Section 28.0 Fixed Voltage Reference (FVR)
for more information on the Fixed Voltage Reference
The output from a comparator can be synchronized module.
with Timer1 by setting the SYNC bit of the CMxCON0
register. See Section 30.0 5-Bit Digital-to-Analog Converter
(DAC) Module for more information on the DAC input
Once enabled, the comparator output is latched on the signal.
falling edge of the Timer1 source clock. If a prescaler is
used with Timer1, the comparator output is latched after Any time the comparator is disabled (CxEN = 0), all
the prescaling function. To prevent a race condition, the comparator inputs are disabled.
comparator output is latched on the falling edge of the
Timer1 clock source and Timer1 increments on the 32.8 Comparator Negative Input
rising edge of its clock source. See the Comparator Selection
Block Diagram (Figure 32-2) and the Timer1 Block
Diagram (Figure 19-1) for more information. The NCH<2:0> bits of the CMxNCH register direct an
analog input pin and internal reference voltage or ana-
log ground to the inverting input of the comparator:
32.6 Comparator Interrupt
CxIN0-, CxIN1-, CxIN2-, CxIN3- analog pin
An interrupt can be generated upon a change in the
FVR (Fixed Voltage Reference)
output value of the comparator for each comparator, a
rising edge detector and a falling edge detector are Analog Ground
present.
When either edge detector is triggered and its associ- Note: To use CxINy+ and CxINy- pins as analog
ated enable bit is set (CxINTP and/or CxINTN bits of input, the appropriate bits must be set in
the CMxCON1 register), the Corresponding Interrupt the ANSEL register and the correspond-
Flag bit (CxIF bit of the PIR2 register) will be set. ing TRIS bits must also be set to disable
To enable the interrupt, you must set the following bits: the output drivers.

EN and POL bits of the CMxCON0 register


CxIE bit of the PIE2 register
INTP bit of the CMxCON1 register (for a rising
edge detection)
INTN bit of the CMxCON1 register (for a falling
edge detection)
PEIE and GIE bits of the INTCON register

2016 Microchip Technology Inc. Preliminary DS40001816C-page 467


PIC18(L)F26/45/46K40
32.9 Comparator Response Time 32.10 Analog Input Connection
The comparator output is indeterminate for a period of
Considerations
time after the change of an input source or the selection A simplified circuit for an analog input is shown in
of a new reference voltage. This period is referred to as Figure 32-3. Since the analog input pins share their
the response time. The response time of the comparator connection with a digital input, they have reverse
differs from the settling time of the voltage reference. biased ESD protection diodes to VDD and VSS. The
Therefore, both of these times must be considered when analog input, therefore, must be between VSS and VDD.
determining the total response time to a comparator If the input voltage deviates from this range by more
input change. See the Comparator and Voltage than 0.6V in either direction, one of the diodes is
Reference Specifications in Table 37-15 and Table 37- forward biased and a latch-up may occur.
17 for more details.
A maximum source impedance of 10 k is recommended
for the analog sources. Also, any external component
connected to an analog input pin, such as a capacitor or
a Zener diode, should have very little leakage current to
minimize inaccuracies introduced.

Note 1: When reading a PORT register, all pins


configured as analog inputs will read as a
0. Pins configured as digital inputs will
convert as an analog input, according to
the input specification.
2: Analog levels on any pin defined as a
digital input, may cause the input buffer to
consume more current than is specified.

FIGURE 32-3: ANALOG INPUT MODEL

Rev. 10-000071A
8/2/2013

VDD
Analog
VT 0.6V
RS < 10K Input pin RIC
To Comparator
ILEAKAGE(1)
VA CPIN VT 0.6V
5pF

VSS

Legend: CPIN = Input Capacitance


ILEAKAGE = Leakage Current at the pin due to various junctions
RIC = Interconnect Resistance
RS = Source Impedance
VA = Analog Voltage
VT = Threshold Voltage

Note 1: See Section 37.0 Electrical Specifications.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 468


PIC18(L)F26/45/46K40
32.11 CWG1 Auto-Shutdown Source
The output of the comparator module can be used as
an auto-shutdown source for the CWG1 module. When
the output of the comparator is active and the
corresponding WGASxE is enabled, the CWG
operation will be suspended immediately (see Section
24.10.1.2 External Input Source).

32.12 ADC Auto-Trigger Source


The output of the comparator module can be used to
trigger an ADC conversion. When the ADACT register
is set to trigger on a comparator output, an ADC
conversion will trigger when the Comparator output
goes high.

32.13 TMR2/4/6 Reset


The output of the comparator module can be used to
reset Timer2. When the TxERS register is
appropriately set, the timer will reset when the
Comparator output goes high.

32.14 Operation in Sleep Mode


The comparator module can operate during Sleep. The
comparator clock source is based on the Timer1 clock
source. If the Timer1 clock source is either the system
clock (FOSC) or the instruction clock (FOSC/4), Timer1
will not operate during Sleep, and synchronized
comparator outputs will not operate.
A comparator interrupt will wake the device from Sleep.
The CxIE bits of the PIE2 register must be set to enable
comparator interrupts.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 469


PIC18(L)F26/45/46K40

TABLE 32-3: SUMMARY OF REGISTERS ASSOCIATED WITH COMPARATOR MODULE


Reset
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Values
on page

CMxCON0 EN OUT POL HYS SYNC 463


CMxCON1 CxINTP CxINTN 464
CMxNCH NCH<2:0> 464
CMxPCH PCH<2:0> 465
CMOUT MC2OUT MC1OUT 465
FVRCON FVREN FVRRDY TSEN TSRNG CDAFVR<1:0> ADFVR<1:0> 418
INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIR2 HLVDIF ZCDIF C2IF C1IF 172
PIE2 HLVDIE ZCDIE C2IE C1IE 180
IPR2 HLVDIP ZCDIP C2IP C1IP 188
PMD2 DACMD ADCMD CMP2MD CMP1MD ZCDMD 69
RxyPPS RxyPPS<4:0> 217
Legend: = unimplemented, read as 0. Shaded cells are unused by the comparator module.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 470


PIC18(L)F26/45/46K40
33.0 HIGH/LOW-VOLTAGE DETECT The HLVDINTH and HLVDINTL bits determine the
overall operation of the module. When HLVDINTH is
(HLVD)
set, the module monitors for rises in VDD above the trip
The PIC18(L)F2x/4xK40 of devices has a High/Low- point set by the HLVDCON1 register. When HLVDINTL
Voltage Detect module (HLVD). This is a programmable is set, the module monitors for drops in VDD below the
circuit that sets both a device voltage trip point and the trip point set by the HLVDCON1 register. When both
direction of change from that point (positive going, neg- the HLVDINTH and HLVDINTL bits are set, any
ative going or both). If the device experiences an excur- changes above or below the trip point set by the
sion past the trip point in that direction, an interrupt flag HLVDCON1 register can be monitored.
is set. If the interrupt is enabled, the program execution The OUT bit can be read to determine if the voltage is
branches to the interrupt vector address and the soft- greater than or less than the voltage level selected by
ware responds to the interrupt. the HLVDCON1 register.
Complete control of the HLVD module is provided
through the HLVDCON0 and HLVDCON1 register. This 33.1 Operation
allows the circuitry to be turned off by the user under
software control, which minimizes the current When the HLVD module is enabled, a comparator uses
consumption for the device. an internally generated voltage reference as the set
point. The set point is compared with the trip point,
The modules block diagram is shown in Figure 33-1. where each node in the resistor divider represents a
Since the HLVD can be software enabled through the trip point voltage. The trip point voltage is the voltage
HLVDEN bit, setting and clearing the enable bit does level at which the device detects a high or low-voltage
not produce a false HLVD event glitch. Each time the event, depending on the configuration of the module.
HLVD module is enabled, the circuitry requires some When the supply voltage is equal to the trip point, the
time to stabilize. The RDY bit (HLVDCON0<4>) is a voltage tapped off of the resistor array is equal to the
read-only bit used to indicate when the band gap internal reference voltage generated by the voltage
reference voltages are stable. reference module. The comparator then generates an
The module can only generate an interrupt after the interrupt signal by setting the HLVDIF bit.
module is turned ON and the band gap reference The trip point voltage is software programmable to any of
voltages are ready. 16 values. The trip point is selected by programming the
HLVDSEL<3:0> bits (HLVDCON1<3:0>).

FIGURE 33-1: HLVD MODULE BLOCK DIAGRAM

VDD
4 HLVDSEL<3:0>

HLVDEN
16-to-1 MUX

HLVDOUT

- Trigger/
Interrupt HLVDIF
+ Generation
HLVDRDY HLVDINTH HLVDINTL

Bandgap
Reference
HLVDEN Volatge

2016 Microchip Technology Inc. Preliminary DS40001816C-page 471


PIC18(L)F26/45/46K40
33.2 HLVD Setup 33.3 Current Consumption
To set up the HLVD module: When the module is enabled, the HLVD comparator
1. Select the desired HLVD trip point by writing the and voltage divider are enabled and consume static
value to the HLVDSEL<3:0> bits of the current. The total current consumption, when enabled,
HLVDCON1 register. is specified in electrical specification Parameter D206
(Table 37-3).
2. Depending on the application to detect
high-voltage peaks or low-voltage drops or both, Depending on the application, the HLVD module does
set the HLVDINTH or HLVDINTL bit not need to operate constantly. To reduce current
appropriately. requirements, the HLVD circuitry may only need to be
3. Enable the HLVD module by setting the enabled for short periods where the voltage is checked.
HLVDEN bit. After such a check, the module could be disabled.
4. Clear the HLVD interrupt flag (PIR2 register),
which may have been set from a previous inter- 33.4 HLVD Start-up Time
rupt. The internal reference voltage of the HLVD module,
5. If interrupts are desired, enable the HLVD specified in electrical specification (Table 37-17), may
interrupt by setting the HLVDIE in the PIE2 be used by other internal circuitry, such as the
register and GIE bits. programmable Brown-out Reset. If the HLVD or other
An interrupt will not be generated until the circuits using the voltage reference are disabled to
HLVDRDY bit is set. lower the devices current consumption, the reference
voltage circuit will require time to become stable before
Note: Before changing any module settings a low or high-voltage condition can be reliably
(HLVDINTH, HLVDINTL, HLVDSEL<3:0>), detected. This start-up time, TFVRST, is an interval that
first disable the module (HLVDEN = 0), is independent of device clock speed. It is specified in
make the changes and re-enable the electrical specification (Table 37-17).
module. This prevents the generation of
The HLVD interrupt flag is not enabled until TFVRST has
false HLVD events.
expired and a stable reference voltage is reached. For
this reason, brief excursions beyond the set point may
not be detected during this interval (see Figure 33-2 or
Figure 33-3).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 472


PIC18(L)F26/45/46K40
FIGURE 33-2: LOW-VOLTAGE DETECT OPERATION (HLVDINTL = 1)
CASE 1: HLVDIF may not be Set

VDD

VHLVD

HLVDIF

Enable HLVD

TFVRST
HLVDRDY
HLVDIF Cleared in Software
Band Gap Reference Voltage is Stable

CASE 2:
VDD
VHLVD

HLVDIF

Enable HLVD

HLVDRDY TFVRST

Band Gap Reference Voltage is Stable


HLVDIF Cleared in Software

HLVDIF Cleared in Software,


HLVDIF Remains Set since HLVD Condition still Exists

2016 Microchip Technology Inc. Preliminary DS40001816C-page 473


PIC18(L)F26/45/46K40
FIGURE 33-3: HIGH-VOLTAGE DETECT OPERATION (HLVDINTH = 1)
CASE 1:
HLVDIF may not be Set

VHLVD
VDD

HLVDIF

Enable HLVD

HLVDRDY TIRVST

HLVDIF Cleared in Software


Band Gap Reference Voltage is Stable

CASE 2:

VHLVD
VDD

HLVDIF

Enable HLVD

HLVDRDY TIRVST

Band Gap Reference Voltage is Stable


HLVDIF Cleared in Software

HLVDIF Cleared in Software,


HLVDIF Remains Set since HLVD Condition still Exists

33.5 Applications FIGURE 33-4: TYPICAL LOW-VOLTAGE


DETECT APPLICATION
In many applications, it is desirable to detect a drop
below, or rise above, a particular voltage threshold. For
example, the HLVD module could be periodically
enabled to detect Universal Serial Bus (USB) attach or
detach. This assumes the device is powered by a lower
voltage source than the USB when detached. An attach VA
would indicate a High-Voltage Detect from, for example, VB
3.3V to 5V (the voltage on USB) and vice versa for a
Voltage

detach. This feature could save a design a few extra


components and an attach signal (input pin).
For general battery applications, Figure 33-4 shows a
possible voltage curve. Over time, the device voltage
decreases. When the device voltage reaches voltage,
VA, the HLVD logic generates an interrupt at time, TA.
The interrupt could cause the execution of an Interrupt TA TB
Time
Service Routine (ISR), which would allow the applica-
tion to perform housekeeping tasks and a controlled Legend: VA = HLVD trip point
shutdown before the device voltage exits the valid VB = Minimum valid device
operating range at TB. This would give the application operating voltage
a time window, represented by the difference between
TA and TB, to safely exit.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 474


PIC18(L)F26/45/46K40
33.6 Operation During Sleep
When enabled, the HLVD circuitry continues to operate
during Sleep. If the device voltage crosses the trip
point, the HLVDIF bit will be set and the device will
wake up from Sleep. Device execution will continue
from the interrupt vector address if interrupts have
been globally enabled.

33.7 Operation During Idle and Doze


Modes
In both Idle and Doze modes, the module is active and
events are generated if peripheral is enabled.

33.8 Operation During Freeze


When in Freeze mode, no new event or interrupt can
be generated. The state of the LVDRDY bit is frozen.
Register reads and writes through the CPU interface
are allowed.

33.9 Effects of a Reset


A device Reset forces all registers to their Reset state.
This forces the HLVD module to be turned off.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 475


PIC18(L)F26/45/46K40
33.10 Register Definitions: HLVD Control
Long bit name prefixes for the HLVD peripheral is
shown in Table 33-1. Refer to Section 1.4.2.2 Long
Bit Names for more information.
TABLE 33-1:
Peripheral Bit Name Prefix
HLVD HLVD

REGISTER 33-1: HLVDCON1: LOW-VOLTAGE DETECT CONTROL REGISTER 1


U-0 U-0 U-0 U-0 R/W-0/u R/W-0/u R/W-0/u R/W-0/u
SEL<3:0>
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared u = Bit is unchanged

bit 7-4 Unimplemented: Read as 0


bit 3-0 SEL<3:0>: High/Low Voltage Detection Limit Selection bits

SEL<3:0> Typical Voltage


1111 Reserved
1110 4.63V
1101 4.32V
1100 4.12V
1011 3.91V
1010 3.71V
1001 3.60V
1000 3.4V
0111 3.09V
0110 2.88V
0101 2.78V
0100 2.57V
0011 2.47V
0010 2.26V
0001 2.06V
0000 1.85V

2016 Microchip Technology Inc. Preliminary DS40001816C-page 476


PIC18(L)F26/45/46K40

REGISTER 33-2: HLVDCON0: HIGH/LOW-VOLTAGE DETECT CONTROL REGISTER 0


R/W-0/0 U-0 R-x R-x U-0 U-0 R/W-0/0 R/W-0/0
EN OUT RDY INTH INTL
bit 7 bit 0

Legend:
R = Readable bit W = Writable bit U = Unimplemented bit, read as 0
-n = Value at POR 1 = Bit is set 0 = Bit is cleared x = Bit is unknown

bit 7 EN: High/Low-voltage Detect Power Enable bit


1 = Enables HLVD, powers up HLVD circuit and supporting reference circuitry
0 = Disables HLVD, powers down HLVD and supporting circuitry
bit 6 Unimplemented: Read as 0
bit 5 OUT: HLVD Comparator Output bit
1 = Voltage selected detection limit (HLVDL<3:0>)
0 = Voltage selected detection limit (HLVDL<3:0>)
bit 4 RDY: Band Gap Reference Voltages Stable Status Flag bit
1 = Indicates HLVD Module is ready and output is stable
0 = Indicates HLVD Module is not ready
bit 3-2 Unimplemented: Read as 0
bit 1 INTH: HLVD Positive going (High Voltage) Interrupt Enable
1 = HLVDIF will be set when voltage selected detection limit (HLVDSEL<3:0>)
0 = HLVDIF will not be set
bit 0 INTL: HLVD Negative going (Low Voltage) Interrupt Enable
1 = HLVDIF will be set when voltage selected detection limit (HLVDSEL<3:0>)
0 = HLVDIF will not be set

TABLE 33-2: REGISTERS ASSOCIATED WITH HIGH/LOW-VOLTAGE DETECT MODULE


Register
Name Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0
on Page
HLVDCON0 EN OUT RDY INTH INTL 477
HLVDCON1 SEL<3:0> 476

INTCON GIE/GIEH PEIE/GIEL IPEN INT2EDG INT1EDG INT0EDG 169
PIR2 HLVDIF ZCDIF C2IF C1IF 172

PIE2 HLVDIE ZCDIE C2IE C1IE 180

IPR2 HLVDIP ZCDIP C2IP C1IP 188
PMD0 SYSCMD FVRMD HLVDMD CRCMD SCANMD NVMMD CLKRMD IOCMD 67
Legend: = unimplemented, read as 0. Shaded cells are unused by the HLVD module.
Note 1: PORTA<7:6> and their direction bits are individually configured as port pins based on various primary oscillator modes.
When disabled, these bits read as 0.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 477


PIC18(L)F26/45/46K40
34.0 IN-CIRCUIT SERIAL 34.3 Common Programming Interfaces
PROGRAMMING (ICSP) Connection to a target device is typically done through
ICSP programming allows customers to manufacture an ICSP header. A commonly found connector on
circuit boards with unprogrammed devices. Programming development tools is the RJ-11 in the 6P6C (6-pin,
can be done after the assembly process, allowing the 6-connector) configuration. See Figure 34-1.
device to be programmed with the most recent firmware
or a custom firmware. Five pins are needed for ICSP FIGURE 34-1: ICD RJ-11 STYLE
programming: CONNECTOR INTERFACE
ICSPCLK
ICSPDAT
MCLR/VPP
VDD
ICSPDAT
VSS
2 4 6 NC
VDD
In Program/Verify mode the program memory, User IDs ICSPCLK
and the Configuration Words are programmed through 1 3 5
Target
serial communications. The ICSPDAT pin is a VPP/MCLR PC Board
VSS
bidirectional I/O used for transferring the serial data Bottom Side
and the ICSPCLK pin is the clock input. For more
information on ICSP refer to the
PIC18(L)F2X/4XK40 Memory Programming Pin Description*
Specification (DS40001772).
1 = VPP/MCLR
2 = VDD Target
34.1 High-Voltage Programming Entry 3 = VSS (ground)
Mode 4 = ICSPDAT

The device is placed into High-Voltage Programming 5 = ICSPCLK


Entry mode by holding the ICSPCLK and ICSPDAT 6 = No Connect
pins low then raising the voltage on MCLR/VPP to VIHH.
Another connector often found in use with the PICkit
34.2 Low-Voltage Programming Entry programmers is a standard 6-pin header with 0.1 inch
Mode spacing. Refer to Figure 34-2.
The Low-Voltage Programming Entry mode allows the For additional interface recommendations, refer to your
PIC Flash MCUs to be programmed using VDD only, specific device programmer manual prior to PCB
without high voltage. When the LVP bit of Configuration design.
Words is set to 1, the low-voltage ICSP programming It is recommended that isolation devices be used to
entry is enabled. To disable the Low-Voltage ICSP separate the programming pins from other circuitry.
mode, the LVP bit must be programmed to 0. The type of isolation is highly dependent on the specific
Entry into the Low-Voltage Programming Entry mode application and may include devices such as resistors,
requires the following steps: diodes, or even jumpers. See Figure 34-3 for more
information.
1. MCLR is brought to VIL.
2. A 32-bit key sequence is presented on
ICSPDAT, while clocking ICSPCLK.
Once the key sequence is complete, MCLR must be
held at VIL for as long as Program/Verify mode is to be
maintained.
If low-voltage programming is enabled (LVP = 1), the
MCLR Reset function is automatically enabled and
cannot be disabled. See Section 8.6 MCLR for more
information.
The LVP bit can only be reprogrammed to 0 by using
the High-Voltage Programming mode.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 478


PIC18(L)F26/45/46K40
FIGURE 34-2: PICkit PROGRAMMER STYLE CONNECTOR INTERFACE

Pin 1 Indicator

Pin Description*
1 1 = VPP/MCLR
2
2 = VDD Target
3
4 3 = VSS (ground)
5
6 4 = ICSPDAT
5 = ICSPCLK
6 = No Connect

* The 6-pin header (0.100" spacing) accepts 0.025" square pins.

FIGURE 34-3: TYPICAL CONNECTION FOR ICSP PROGRAMMING

External
Programming VDD Device to be
Signals Programmed

VDD VDD

VPP MCLR/VPP
VSS VSS

Data ICSPDAT
Clock ICSPCLK

* * *

To Normal Connections

* Isolation devices (as required).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 479


PIC18(L)F26/45/46K40
35.0 INSTRUCTION SET SUMMARY The literal instructions may use some of the following
operands:
PIC18(L)F2x/4xK40 devices incorporate the standard
A literal value to be loaded into a file register
set of 75 PIC18 core instructions, as well as an extended
(specified by k)
set of eight new instructions, for the optimization of code
that is recursive or that utilizes a software stack. The The desired FSR register to load the literal value
extended set is discussed later in this section. into (specified by f)
No operand required
(specified by )
35.1 Standard Instruction Set
The control instructions may use some of the following
The standard PIC18 instruction set adds many operands:
enhancements to the previous PIC MCU instruction
sets, while maintaining an easy migration from these A program memory address (specified by n)
PIC MCU instruction sets. Most instructions are a The mode of the CALL or RETURN instructions
single program memory word (16 bits), but there are (specified by s)
four instructions that require two program memory The mode of the table read and table write
locations. instructions (specified by m)
No operand required
Each single-word instruction is a 16-bit word divided
(specified by )
into an opcode, which specifies the instruction type and
one or more operands, which further specify the All instructions are a single word, except for four
operation of the instruction. double-word instructions. These instructions were
made double-word to contain the required information
The instruction set is highly orthogonal and is grouped
in 32 bits. In the second word, the four MSbs are 1s. If
into four basic categories:
this second word is executed as an instruction (by
Byte-oriented operations itself), it will execute as a NOP.
Bit-oriented operations All single-word instructions are executed in a single
Literal operations instruction cycle, unless a conditional test is true or the
Control operations program counter is changed as a result of the instruc-
The PIC18 instruction set summary in Table 35-2 lists tion. In these cases, the execution takes two instruction
byte-oriented, bit-oriented, literal and control cycles, with the additional instruction cycle(s) executed
operations. Table 35-1 shows the opcode field as a NOP.
descriptions. The double-word instructions execute in two instruction
Most byte-oriented instructions have three operands: cycles.

1. The file register (specified by f) One instruction cycle consists of four oscillator periods.
Thus, for an oscillator frequency of 4 MHz, the normal
2. The destination of the result (specified by d)
instruction execution time is 1 s. If a conditional test is
3. The accessed memory (specified by a)
true, or the program counter is changed as a result of
The file register designator f specifies which file an instruction, the instruction execution time is 2 s.
register is to be used by the instruction. The destination Two-word branch instructions (if true) would take 3 s.
designator d specifies where the result of the opera-
Figure 35-1 shows the general formats that the instruc-
tion is to be placed. If d is zero, the result is placed in
tions can have. All examples use the convention nnh
the WREG register. If d is one, the result is placed in
to represent a hexadecimal number.
the file register specified in the instruction.
The Instruction Set Summary, shown in Table 35-2,
All bit-oriented instructions have three operands:
lists the standard instructions recognized by the
1. The file register (specified by f) Microchip Assembler (MPASMTM).
2. The bit in the file register (specified by b) Section 35.1.1 Standard Instruction Set provides
3. The accessed memory (specified by a) a description of each instruction.
The bit field designator b selects the number of the bit
affected by the operation, while the file register
designator f represents the number of the file in which
the bit is located.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 480


PIC18(L)F26/45/46K40

TABLE 35-1: OPCODE FIELD DESCRIPTIONS


Field Description

a RAM access bit


a = 0: RAM location in Access RAM (BSR register is ignored)
a = 1: RAM bank is specified by BSR register
bbb Bit address within an 8-bit file register (0 to 7).
BSR Bank Select Register. Used to select the current RAM bank.
C, DC, Z, OV, N ALU Status bits: Carry, Digit Carry, Zero, Overflow, Negative.
d Destination select bit
d = 0: store result in WREG
d = 1: store result in file register f
dest Destination: either the WREG register or the specified register file location.
f 8-bit Register file address (00h to FFh) or 2-bit FSR designator (0h to 3h).
fs 12-bit Register file address (000h to FFFh). This is the source address.
fd 12-bit Register file address (000h to FFFh). This is the destination address.
GIE Global Interrupt Enable bit.
k Literal field, constant data or label (may be either an 8-bit, 12-bit or a 20-bit value).
label Label name.
mm The mode of the TBLPTR register for the table read and table write instructions.
Only used with table read and table write instructions:
* No change to register (such as TBLPTR with table reads and writes)
*+ Post-Increment register (such as TBLPTR with table reads and writes)
*- Post-Decrement register (such as TBLPTR with table reads and writes)
+* Pre-Increment register (such as TBLPTR with table reads and writes)
n The relative address (2s complement number) for relative branch instructions or the direct address for
CALL/BRANCH and RETURN instructions.
PC Program Counter.
PCL Program Counter Low Byte.
PCH Program Counter High Byte.
PCLATH Program Counter High Byte Latch.
PCLATU Program Counter Upper Byte Latch.
PD Power-down bit.
PRODH Product of Multiply High Byte.
PRODL Product of Multiply Low Byte.
s Fast Call/Return mode select bit
s = 0: do not update into/from shadow registers
s = 1: certain registers loaded into/from shadow registers (Fast mode)
TBLPTR 21-bit Table Pointer (points to a Program Memory location).
TABLAT 8-bit Table Latch.
TO Time-out bit.
TOS Top-of-Stack.
u Unused or unchanged.
WDT Watchdog Timer.
WREG Working register (accumulator).
x Dont care (0 or 1). The assembler will generate code with x = 0. It is the recommended form of use for compatibility with
all Microchip software tools.
zs 7-bit offset value for indirect addressing of register files (source).
zd 7-bit offset value for indirect addressing of register files (destination).
{ } Optional argument.
[text] Indicates an indexed address.
(text) The contents of text.
[expr]<n> Specifies bit n of the register indicated by the pointer expr.
Assigned to.
< > Register bit field.
In the set of.
italics User defined term (font is Courier).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 481


PIC18(L)F26/45/46K40
FIGURE 35-1: General Format for Instructions
Byte-oriented file register operations Example Instruction
15 10 9 8 7 0
OPCODE d a f (FILE #) ADDWF MYREG, W, B
d = 0 for result destination to be WREG register
d = 1 for result destination to be file register (f)
a = 0 to force Access Bank
a = 1 for BSR to select bank
f = 8-bit file register address

Byte to Byte move operations (2-word)


15 12 11 0
OPCODE f (Source FILE #) MOVFF MYREG1, MYREG2
15 12 11 0
1111 f (Destination FILE #)

f = 12-bit file register address

Bit-oriented file register operations


15 12 11 9 8 7 0
OPCODE b (BIT #) a f (FILE #) BSF MYREG, bit, B

b = 3-bit position of bit in file register (f)


a = 0 to force Access Bank
a = 1 for BSR to select bank
f = 8-bit file register address

Literal operations
15 8 7 0
OPCODE k (literal) MOVLW 7Fh

k = 8-bit immediate value

Control operations
CALL, GOTO and Branch operations
15 8 7 0
OPCODE n<7:0> (literal) GOTO Label
15 12 11 0
1111 n<19:8> (literal)

n = 20-bit immediate value

15 8 7 0
OPCODE S n<7:0> (literal) CALL MYFUNC
15 12 11 0
1111 n<19:8> (literal)
S = Fast bit

15 11 10 0
OPCODE n<10:0> (literal) BRA MYFUNC

15 8 7 0
OPCODE n<7:0> (literal) BC MYFUNC

2016 Microchip Technology Inc. Preliminary DS40001816C-page 482


PIC18(L)F26/45/46K40

TABLE 35-2: INSTRUCTION SET


Mnemonic, 16-Bit Instruction Word Status
Description Cycles Notes
Operands MSb LSb Affected

BYTE-ORIENTED OPERATIONS
ADDWF f, d, a Add WREG and f 1 0010 01da ffff ffff C, DC, Z, OV, N 1, 2
ADDWFC f, d, a Add WREG and CARRY bit to f 1 0010 00da ffff ffff C, DC, Z, OV, N 1, 2
ANDWF f, d, a AND WREG with f 1 0001 01da ffff ffff Z, N 1,2
CLRF f, a Clear f 1 0110 101a ffff ffff Z 2
COMF f, d, a Complement f 1 0001 11da ffff ffff Z, N 1, 2
CPFSEQ f, a Compare f with WREG, skip = 1 (2 or 3) 0110 001a ffff ffff None 4
CPFSGT f, a Compare f with WREG, skip > 1 (2 or 3) 0110 010a ffff ffff None 4
CPFSLT f, a Compare f with WREG, skip < 1 (2 or 3) 0110 000a ffff ffff None 1, 2
DECF f, d, a Decrement f 1 0000 01da ffff ffff C, DC, Z, OV, N 1, 2, 3, 4
DECFSZ f, d, a Decrement f, Skip if 0 1 (2 or 3) 0010 11da ffff ffff None 1, 2, 3, 4
DCFSNZ f, d, a Decrement f, Skip if Not 0 1 (2 or 3) 0100 11da ffff ffff None 1, 2
INCF f, d, a Increment f 1 0010 10da ffff ffff C, DC, Z, OV, N 1, 2, 3, 4
INCFSZ f, d, a Increment f, Skip if 0 1 (2 or 3) 0011 11da ffff ffff None 4
INFSNZ f, d, a Increment f, Skip if Not 0 1 (2 or 3) 0100 10da ffff ffff None 1, 2
IORWF f, d, a Inclusive OR WREG with f 1 0001 00da ffff ffff Z, N 1, 2
MOVF f, d, a Move f 1 0101 00da ffff ffff Z, N 1
MOVFF fs, fd Move fs (source) to 1st word 2 1100 ffff ffff ffff None
fd (destination) 2nd word 1111 ffff ffff ffff
MOVWF f, a Move WREG to f 1 0110 111a ffff ffff None
MULWF f, a Multiply WREG with f 1 0000 001a ffff ffff None 1, 2
NEGF f, a Negate f 1 0110 110a ffff ffff C, DC, Z, OV, N
RLCF f, d, a Rotate Left f through Carry 1 0011 01da ffff ffff C, Z, N 1, 2
RLNCF f, d, a Rotate Left f (No Carry) 1 0100 01da ffff ffff Z, N
RRCF f, d, a Rotate Right f through Carry 1 0011 00da ffff ffff C, Z, N
RRNCF f, d, a Rotate Right f (No Carry) 1 0100 00da ffff ffff Z, N
SETF f, a Set f 1 0110 100a ffff ffff None 1, 2
SUBFWB f, d, a Subtract f from WREG with 1 0101 01da ffff ffff C, DC, Z, OV, N
borrow
SUBWF f, d, a Subtract WREG from f 1 0101 11da ffff ffff C, DC, Z, OV, N 1, 2
SUBWFB f, d, a Subtract WREG from f with 1 0101 10da ffff ffff C, DC, Z, OV, N
borrow
SWAPF f, d, a Swap nibbles in f 1 0011 10da ffff ffff None 4
TSTFSZ f, a Test f, skip if 0 1 (2 or 3) 0110 011a ffff ffff None 1, 2
XORWF f, d, a Exclusive OR WREG with f 1 0001 10da ffff ffff Z, N
Note 1: When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value
present on the pins themselves. For example, if the data latch is 1 for a pin configured as input and is driven low by an
external device, the data will be written back with a 0.
2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if
assigned.
3: If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is
executed as a NOP.
4: Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless
the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program mem-
ory locations have a valid instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 483


PIC18(L)F26/45/46K40
TABLE 35-2: INSTRUCTION SET (CONTINUED)
Mnemonic, 16-Bit Instruction Word Status
Description Cycles Notes
Operands MSb LSb Affected

BIT-ORIENTED OPERATIONS
BCF f, b, a Bit Clear f 1 1001 bbba ffff ffff None 1, 2
BSF f, b, a Bit Set f 1 1000 bbba ffff ffff None 1, 2
BTFSC f, b, a Bit Test f, Skip if Clear 1 (2 or 3) 1011 bbba ffff ffff None 3, 4
BTFSS f, b, a Bit Test f, Skip if Set 1 (2 or 3) 1010 bbba ffff ffff None 3, 4
BTG f, b, a Bit Toggle f 1 0111 bbba ffff ffff None 1, 2
CONTROL OPERATIONS
BC n Branch if Carry 1 (2) 1110 0010 nnnn nnnn None
BN n Branch if Negative 1 (2) 1110 0110 nnnn nnnn None
BNC n Branch if Not Carry 1 (2) 1110 0011 nnnn nnnn None
BNN n Branch if Not Negative 1 (2) 1110 0111 nnnn nnnn None
BNOV n Branch if Not Overflow 1 (2) 1110 0101 nnnn nnnn None
BNZ n Branch if Not Zero 1 (2) 1110 0001 nnnn nnnn None
BOV n Branch if Overflow 1 (2) 1110 0100 nnnn nnnn None
BRA n Branch Unconditionally 2 1101 0nnn nnnn nnnn None
BZ n Branch if Zero 1 (2) 1110 0000 nnnn nnnn None
CALL k, s Call subroutine 1st word 2 1110 110s kkkk kkkk None
2nd word 1111 kkkk kkkk kkkk
CLRWDT Clear Watchdog Timer 1 0000 0000 0000 0100 TO, PD
DAW Decimal Adjust WREG 1 0000 0000 0000 0111 C
GOTO k Go to address 1st word 2 1110 1111 kkkk kkkk None
2nd word 1111 kkkk kkkk kkkk
NOP No Operation 1 0000 0000 0000 0000 None
NOP No Operation 1 1111 xxxx xxxx xxxx None 4
POP Pop top of return stack (TOS) 1 0000 0000 0000 0110 None
PUSH Push top of return stack (TOS) 1 0000 0000 0000 0101 None
RCALL n Relative Call 2 1101 1nnn nnnn nnnn None
RESET Software device Reset 1 0000 0000 1111 1111 All
RETFIE s Return from interrupt enable 2 0000 0000 0001 000s GIE/GIEH,
PEIE/GIEL
RETLW k Return with literal in WREG 2 0000 1100 kkkk kkkk None
RETURN s Return from Subroutine 2 0000 0000 0001 001s None
SLEEP Go into Standby mode 1 0000 0000 0000 0011 TO, PD
Note 1: When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value
present on the pins themselves. For example, if the data latch is 1 for a pin configured as input and is driven low by an
external device, the data will be written back with a 0.
2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if
assigned.
3: If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is
executed as a NOP.
4: Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless
the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program mem-
ory locations have a valid instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 484


PIC18(L)F26/45/46K40
TABLE 35-2: INSTRUCTION SET (CONTINUED)
Mnemonic, 16-Bit Instruction Word Status
Description Cycles Notes
Operands MSb LSb Affected

LITERAL OPERATIONS
ADDLW k Add literal and WREG 1 0000 1111 kkkk kkkk C, DC, Z, OV, N
ANDLW k AND literal with WREG 1 0000 1011 kkkk kkkk Z, N
IORLW k Inclusive OR literal with WREG 1 0000 1001 kkkk kkkk Z, N
LFSR f, k Move literal (12-bit) 2nd word 2 1110 1110 00ff kkkk None
to FSR(f) 1st word 1111 0000 kkkk kkkk
MOVLB k Move literal to BSR<3:0> 1 0000 0001 0000 kkkk None
MOVLW k Move literal to WREG 1 0000 1110 kkkk kkkk None
MULLW k Multiply literal with WREG 1 0000 1101 kkkk kkkk None
RETLW k Return with literal in WREG 2 0000 1100 kkkk kkkk None
SUBLW k Subtract WREG from literal 1 0000 1000 kkkk kkkk C, DC, Z, OV, N
XORLW k Exclusive OR literal with WREG 1 0000 1010 kkkk kkkk Z, N
DATA MEMORY PROGRAM MEMORY OPERATIONS
TBLRD* Table Read 2 0000 0000 0000 1000 None
TBLRD*+ Table Read with post-increment 0000 0000 0000 1001 None
TBLRD*- Table Read with post-decrement 0000 0000 0000 1010 None
TBLRD+* Table Read with pre-increment 0000 0000 0000 1011 None
TBLWT* Table Write 2 0000 0000 0000 1100 None
TBLWT*+ Table Write with post-increment 0000 0000 0000 1101 None
TBLWT*- Table Write with post-decrement 0000 0000 0000 1110 None
TBLWT+* Table Write with pre-increment 0000 0000 0000 1111 None
Note 1: When a PORT register is modified as a function of itself (e.g., MOVF PORTB, 1, 0), the value used will be that value
present on the pins themselves. For example, if the data latch is 1 for a pin configured as input and is driven low by an
external device, the data will be written back with a 0.
2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if
assigned.
3: If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is
executed as a NOP.
4: Some instructions are two-word instructions. The second word of these instructions will be executed as a NOP unless
the first word of the instruction retrieves the information embedded in these 16 bits. This ensures that all program mem-
ory locations have a valid instruction.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 485


PIC18(L)F26/45/46K40
35.1.1 STANDARD INSTRUCTION SET

ADDLW ADD literal to W ADDWF ADD W to f


Syntax: ADDLW k Syntax: ADDWF f {,d {,a}}
Operands: 0 k 255 Operands: 0 f 255
Operation: (W) + k W d [0,1]
a [0,1]
Status Affected: N, OV, C, DC, Z
Operation: (W) + (f) dest
Encoding: 0000 1111 kkkk kkkk
Status Affected: N, OV, C, DC, Z
Description: The contents of W are added to the
8-bit literal k and the result is placed in Encoding: 0010 01da ffff ffff
W. Description: Add W to register f. If d is 0, the
Words: 1 result is stored in W. If d is 1, the
result is stored back in register f
Cycles: 1 (default).
Q Cycle Activity: If a is 0, the Access Bank is selected.
If a is 1, the BSR is used to select the
Q1 Q2 Q3 Q4
GPR bank.
Decode Read Process Write to W If a is 0 and the extended instruction
literal k Data set is enabled, this instruction operates
in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). See Sec-
Example: ADDLW 15h tion 35.2.3 Byte-Oriented and Bit-
Before Instruction Oriented Instructions in Indexed Lit-
W = 10h eral Offset Mode for details.
After Instruction Words: 1
W = 25h Cycles: 1

Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write to
register f Data destination

Example: ADDWF REG, 0, 0


Before Instruction
W = 17h
REG = 0C2h
After Instruction
W = 0D9h
REG = 0C2h

Note: All PIC18 instructions may take an optional label argument preceding the instruction mnemonic for use in
symbolic addressing. If a label is used, the instruction format then becomes: {label} instruction argument(s).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 486


PIC18(L)F26/45/46K40

ADDWFC ADD W and CARRY bit to f ANDLW AND literal with W


Syntax: ADDWFC f {,d {,a}} Syntax: ANDLW k
Operands: 0 f 255 Operands: 0 k 255
d [0,1]
Operation: (W) .AND. k W
a [0,1]
Status Affected: N, Z
Operation: (W) + (f) + (C) dest
Encoding: 0000 1011 kkkk kkkk
Status Affected: N,OV, C, DC, Z
Description: The contents of W are ANDed with the
Encoding: 0010 00da ffff ffff
8-bit literal k. The result is placed in W.
Description: Add W, the CARRY flag and data mem-
Words: 1
ory location f. If d is 0, the result is
placed in W. If d is 1, the result is Cycles: 1
placed in data memory location f. Q Cycle Activity:
If a is 0, the Access Bank is selected.
Q1 Q2 Q3 Q4
If a is 1, the BSR is used to select the
GPR bank. Decode Read literal Process Write to W
If a is 0 and the extended instruction k Data
set is enabled, this instruction operates
in Indexed Literal Offset Addressing Example: ANDLW 05Fh
mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- Before Instruction
Oriented Instructions in Indexed Lit- W = A3h
eral Offset Mode for details. After Instruction
Words: 1 W = 03h
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write to
register f Data destination

Example: ADDWFC REG, 0, 1


Before Instruction
CARRY bit = 1
REG = 02h
W = 4Dh
After Instruction
CARRY bit = 0
REG = 02h
W = 50h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 487


PIC18(L)F26/45/46K40

ANDWF AND W with f BC Branch if Carry


Syntax: ANDWF f {,d {,a}} Syntax: BC n
Operands: 0 f 255 Operands: -128 n 127
d [0,1]
Operation: if CARRY bit is 1
a [0,1] (PC) + 2 + 2n PC
Operation: (W) .AND. (f) dest
Status Affected: None
Status Affected: N, Z Encoding: 1110 0010 nnnn nnnn
Encoding: 0001 01da ffff ffff
Description: If the CARRY bit is 1, then the program
Description: The contents of W are ANDed with will branch.
register f. If d is 0, the result is stored The 2s complement number 2n is
in W. If d is 1, the result is stored back added to the PC. Since the PC will have
in register f (default). incremented to fetch the next
If a is 0, the Access Bank is selected. instruction, the new address will be
If a is 1, the BSR is used to select the PC + 2 + 2n. This instruction is then a
GPR bank. 2-cycle instruction.
If a is 0 and the extended instruction Words: 1
set is enabled, this instruction operates
in Indexed Literal Offset Addressing Cycles: 1(2)
mode whenever f 95 (5Fh). See Sec- Q Cycle Activity:
tion 35.2.3 Byte-Oriented and Bit- If Jump:
Oriented Instructions in Indexed Lit-
Q1 Q2 Q3 Q4
eral Offset Mode for details.
Decode Read literal Process Write to PC
Words: 1 n Data
Cycles: 1 No No No No
operation operation operation operation
Q Cycle Activity:
If No Jump:
Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4
Decode Read Process Write to
Decode Read literal Process No
register f Data destination
n Data operation

Example: ANDWF REG, 0, 0


Example: HERE BC 5
Before Instruction
Before Instruction
W = 17h PC = address (HERE)
REG = C2h After Instruction
After Instruction
If CARRY = 1;
W = 02h PC = address (HERE + 12)
REG = C2h If CARRY = 0;
PC = address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 488


PIC18(L)F26/45/46K40

BCF Bit Clear f BN Branch if Negative


Syntax: BCF f, b {,a} Syntax: BN n
Operands: 0 f 255 Operands: -128 n 127
0b7
Operation: if NEGATIVE bit is 1
a [0,1] (PC) + 2 + 2n PC
Operation: 0 f<b>
Status Affected: None
Status Affected: None Encoding: 1110 0110 nnnn nnnn
Encoding: 1001 bbba ffff ffff
Description: If the NEGATIVE bit is 1, then the
Description: Bit b in register f is cleared. program will branch.
If a is 0, the Access Bank is selected. The 2s complement number 2n is
If a is 1, the BSR is used to select the added to the PC. Since the PC will have
GPR bank. incremented to fetch the next
If a is 0 and the extended instruction instruction, the new address will be
set is enabled, this instruction operates PC + 2 + 2n. This instruction is then a
in Indexed Literal Offset Addressing 2-cycle instruction.
mode whenever f 95 (5Fh). See Sec- Words: 1
tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit- Cycles: 1(2)
eral Offset Mode for details. Q Cycle Activity:
Words: 1 If Jump:
Cycles: 1 Q1 Q2 Q3 Q4
Decode Read literal Process Write to PC
Q Cycle Activity: n Data
Q1 Q2 Q3 Q4 No No No No
Decode Read Process Write operation operation operation operation
register f Data register f If No Jump:
Q1 Q2 Q3 Q4
Example: BCF FLAG_REG, 7, 0 Decode Read literal Process No
Before Instruction n Data operation
FLAG_REG = C7h
After Instruction Example: HERE BN Jump
FLAG_REG = 47h
Before Instruction
PC = address (HERE)
After Instruction
If NEGATIVE = 1;
PC = address (Jump)
If NEGATIVE = 0;
PC = address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 489


PIC18(L)F26/45/46K40

BNC Branch if Not Carry BNN Branch if Not Negative


Syntax: BNC n Syntax: BNN n
Operands: -128 n 127 Operands: -128 n 127
Operation: if CARRY bit is 0 Operation: if NEGATIVE bit is 0
(PC) + 2 + 2n PC (PC) + 2 + 2n PC
Status Affected: None Status Affected: None
Encoding: 1110 0011 nnnn nnnn Encoding: 1110 0111 nnnn nnnn
Description: If the CARRY bit is 0, then the program Description: If the NEGATIVE bit is 0, then the
will branch. program will branch.
The 2s complement number 2n is The 2s complement number 2n is
added to the PC. Since the PC will have added to the PC. Since the PC will have
incremented to fetch the next incremented to fetch the next
instruction, the new address will be instruction, the new address will be
PC + 2 + 2n. This instruction is then a PC + 2 + 2n. This instruction is then a
2-cycle instruction. 2-cycle instruction.
Words: 1 Words: 1
Cycles: 1(2) Cycles: 1(2)
Q Cycle Activity: Q Cycle Activity:
If Jump: If Jump:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read literal Process Write to PC Decode Read literal Process Write to PC
n Data n Data
No No No No No No No No
operation operation operation operation operation operation operation operation
If No Jump: If No Jump:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read literal Process No Decode Read literal Process No
n Data operation n Data operation

Example: HERE BNC Jump Example: HERE BNN Jump


Before Instruction Before Instruction
PC = address (HERE) PC = address (HERE)
After Instruction After Instruction
If CARRY = 0; If NEGATIVE = 0;
PC = address (Jump) PC = address (Jump)
If CARRY = 1; If NEGATIVE = 1;
PC = address (HERE + 2) PC = address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 490


PIC18(L)F26/45/46K40

BNOV Branch if Not Overflow BNZ Branch if Not Zero


Syntax: BNOV n Syntax: BNZ n
Operands: -128 n 127 Operands: -128 n 127
Operation: if OVERFLOW bit is 0 Operation: if ZERO bit is 0
(PC) + 2 + 2n PC (PC) + 2 + 2n PC
Status Affected: None Status Affected: None
Encoding: 1110 0101 nnnn nnnn Encoding: 1110 0001 nnnn nnnn
Description: If the OVERFLOW bit is 0, then the Description: If the ZERO bit is 0, then the program
program will branch. will branch.
The 2s complement number 2n is The 2s complement number 2n is
added to the PC. Since the PC will have added to the PC. Since the PC will have
incremented to fetch the next incremented to fetch the next
instruction, the new address will be instruction, the new address will be
PC + 2 + 2n. This instruction is then a PC + 2 + 2n. This instruction is then a
2-cycle instruction. 2-cycle instruction.
Words: 1 Words: 1
Cycles: 1(2) Cycles: 1(2)
Q Cycle Activity: Q Cycle Activity:
If Jump: If Jump:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read literal Process Write to PC Decode Read literal Process Write to PC
n Data n Data
No No No No No No No No
operation operation operation operation operation operation operation operation
If No Jump: If No Jump:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read literal Process No Decode Read literal Process No
n Data operation n Data operation

Example: HERE BNOV Jump Example: HERE BNZ Jump


Before Instruction Before Instruction
PC = address (HERE) PC = address (HERE)
After Instruction After Instruction
If OVERFLOW = 0; If ZERO = 0;
PC = address (Jump) PC = address (Jump)
If OVERFLOW = 1; If ZERO = 1;
PC = address (HERE + 2) PC = address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 491


PIC18(L)F26/45/46K40

BRA Unconditional Branch BSF Bit Set f


Syntax: BRA n Syntax: BSF f, b {,a}
Operands: -1024 n 1023 Operands: 0 f 255
0b7
Operation: (PC) + 2 + 2n PC
a [0,1]
Status Affected: None
Operation: 1 f<b>
Encoding: 1101 0nnn nnnn nnnn
Status Affected: None
Description: Add the 2s complement number 2n to
the PC. Since the PC will have incre- Encoding: 1000 bbba ffff ffff
mented to fetch the next instruction, the Description: Bit b in register f is set.
new address will be PC + 2 + 2n. This If a is 0, the Access Bank is selected.
instruction is a 2-cycle instruction. If a is 1, the BSR is used to select the
GPR bank.
Words: 1
If a is 0 and the extended instruction
Cycles: 2 set is enabled, this instruction operates
Q Cycle Activity: in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). See Sec-
Q1 Q2 Q3 Q4
tion 35.2.3 Byte-Oriented and Bit-
Decode Read literal Process Write to PC Oriented Instructions in Indexed Lit-
n Data eral Offset Mode for details.
No No No No
Words: 1
operation operation operation operation
Cycles: 1
Q Cycle Activity:
Example: HERE BRA Jump
Q1 Q2 Q3 Q4
Before Instruction Decode Read Process Write
PC = address (HERE) register f Data register f
After Instruction
PC = address (Jump)
Example: BSF FLAG_REG, 7, 1
Before Instruction
FLAG_REG = 0Ah
After Instruction
FLAG_REG = 8Ah

2016 Microchip Technology Inc. Preliminary DS40001816C-page 492


PIC18(L)F26/45/46K40

BTFSC Bit Test File, Skip if Clear BTFSS Bit Test File, Skip if Set
Syntax: BTFSC f, b {,a} Syntax: BTFSS f, b {,a}
Operands: 0 f 255 Operands: 0 f 255
0b7 0b<7
a [0,1] a [0,1]
Operation: skip if (f<b>) = 0 Operation: skip if (f<b>) = 1
Status Affected: None Status Affected: None
Encoding: 1011 bbba ffff ffff Encoding: 1010 bbba ffff ffff
Description: If bit b in register f is 0, then the next Description: If bit b in register f is 1, then the next
instruction is skipped. If bit b is 0, then instruction is skipped. If bit b is 1, then
the next instruction fetched during the the next instruction fetched during the
current instruction execution is discarded current instruction execution is discarded
and a NOP is executed instead, making and a NOP is executed instead, making
this a 2-cycle instruction. this a 2-cycle instruction.
If a is 0, the Access Bank is selected. If If a is 0, the Access Bank is selected. If
a is 1, the BSR is used to select the a is 1, the BSR is used to select the
GPR bank. GPR bank.
If a is 0 and the extended instruction If a is 0 and the extended instruction
set is enabled, this instruction operates in set is enabled, this instruction operates
Indexed Literal Offset Addressing in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). mode whenever f 95 (5Fh).
See Section 35.2.3 Byte-Oriented and See Section 35.2.3 Byte-Oriented and
Bit-Oriented Instructions in Indexed Bit-Oriented Instructions in Indexed
Literal Offset Mode for details. Literal Offset Mode for details.
Words: 1 Words: 1
Cycles: 1(2) Cycles: 1(2)
Note: 3 cycles if skip and followed Note: 3 cycles if skip and followed
by a 2-word instruction. by a 2-word instruction.
Q Cycle Activity: Q Cycle Activity:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read Process No Decode Read Process No
register f Data operation register f Data operation
If skip: If skip:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
No No No No No No No No
operation operation operation operation operation operation operation operation
If skip and followed by 2-word instruction: If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
No No No No No No No No
operation operation operation operation operation operation operation operation
No No No No No No No No
operation operation operation operation operation operation operation operation

Example: HERE BTFSC FLAG, 1, 0 Example: HERE BTFSS FLAG, 1, 0


FALSE : FALSE :
TRUE : TRUE :
Before Instruction Before Instruction
PC = address (HERE) PC = address (HERE)
After Instruction After Instruction
If FLAG<1> = 0; If FLAG<1> = 0;
PC = address (TRUE) PC = address (FALSE)
If FLAG<1> = 1; If FLAG<1> = 1;
PC = address (FALSE) PC = address (TRUE)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 493


PIC18(L)F26/45/46K40

BTG Bit Toggle f BOV Branch if Overflow


Syntax: BTG f, b {,a} Syntax: BOV n
Operands: 0 f 255 Operands: -128 n 127
0b<7
Operation: if OVERFLOW bit is 1
a [0,1] (PC) + 2 + 2n PC
Operation: (f<b>) f<b>
Status Affected: None
Status Affected: None Encoding: 1110 0100 nnnn nnnn
Encoding: 0111 bbba ffff ffff
Description: If the OVERFLOW bit is 1, then the
Description: Bit b in data memory location f is program will branch.
inverted. The 2s complement number 2n is
If a is 0, the Access Bank is selected. added to the PC. Since the PC will have
If a is 1, the BSR is used to select the incremented to fetch the next
GPR bank. instruction, the new address will be
If a is 0 and the extended instruction PC + 2 + 2n. This instruction is then a
set is enabled, this instruction operates 2-cycle instruction.
in Indexed Literal Offset Addressing Words: 1
mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- Cycles: 1(2)
Oriented Instructions in Indexed Lit- Q Cycle Activity:
eral Offset Mode for details. If Jump:
Words: 1 Q1 Q2 Q3 Q4
Cycles: 1 Decode Read literal Process Write to PC
n Data
Q Cycle Activity:
No No No No
Q1 Q2 Q3 Q4 operation operation operation operation
Decode Read Process Write If No Jump:
register f Data register f
Q1 Q2 Q3 Q4
Decode Read literal Process No
Example: BTG PORTC, 4, 0 n Data operation
Before Instruction:
PORTC = 0111 0101 [75h]
Example: HERE BOV Jump
After Instruction:
PORTC = 0110 0101 [65h] Before Instruction
PC = address (HERE)
After Instruction
If OVERFLOW = 1;
PC = address (Jump)
If OVERFLOW = 0;
PC = address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 494


PIC18(L)F26/45/46K40

BZ Branch if Zero CALL Subroutine Call


Syntax: BZ n Syntax: CALL k {,s}
Operands: -128 n 127 Operands: 0 k 1048575
s [0,1]
Operation: if ZERO bit is 1
(PC) + 2 + 2n PC Operation: (PC) + 4 TOS,
k PC<20:1>,
Status Affected: None
if s = 1
Encoding: 1110 0000 nnnn nnnn (W) WS,
Description: If the ZERO bit is 1, then the program (Status) STATUSS,
will branch. (BSR) BSRS
The 2s complement number 2n is Status Affected: None
added to the PC. Since the PC will
have incremented to fetch the next Encoding:
1st word (k<7:0>) 1110 110s k7kkk kkkk0
instruction, the new address will be
PC + 2 + 2n. This instruction is then a 2nd word(k<19:8>) 1111 k19kkk kkkk kkkk8
2-cycle instruction. Description: Subroutine call of entire 2-Mbyte
Words: 1 memory range. First, return address
(PC + 4) is pushed onto the return
Cycles: 1(2) stack. If s = 1, the W, Status and BSR
Q Cycle Activity: registers are also pushed into their
If Jump: respective shadow registers, WS,
STATUSS and BSRS. If s = 0, no
Q1 Q2 Q3 Q4
update occurs (default). Then, the
Decode Read literal Process Write to PC 20-bit value k is loaded into PC<20:1>.
n Data CALL is a 2-cycle instruction.
No No No No
operation operation operation operation Words: 2
If No Jump: Cycles: 2
Q1 Q2 Q3 Q4 Q Cycle Activity:
Decode Read literal Process No Q1 Q2 Q3 Q4
n Data operation Decode Read literal PUSH PC to Read literal
k<7:0>, stack k<19:8>,
Example: HERE BZ Jump Write to PC
No No No No
Before Instruction
PC = address (HERE) operation operation operation operation
After Instruction
If ZERO = 1; Example: HERE CALL THERE, 1
PC = address (Jump)
If ZERO = 0; Before Instruction
PC = address (HERE + 2) PC = address (HERE)
After Instruction
PC = address (THERE)
TOS = address (HERE + 4)
WS = W
BSRS = BSR
STATUSS = Status

2016 Microchip Technology Inc. Preliminary DS40001816C-page 495


PIC18(L)F26/45/46K40

CLRF Clear f CLRWDT Clear Watchdog Timer


Syntax: CLRF f {,a} Syntax: CLRWDT
Operands: 0 f 255 Operands: None
a [0,1]
Operation: 000h WDT,
Operation: 000h f 000h WDT postscaler,
1Z 1 TO,
Status Affected: Z 1 PD
Status Affected: TO, PD
Encoding: 0110 101a ffff ffff
Description: Clears the contents of the specified Encoding: 0000 0000 0000 0100
register. Description: CLRWDT instruction resets the
If a is 0, the Access Bank is selected. Watchdog Timer. It also resets the post-
If a is 1, the BSR is used to select the scaler of the WDT. Status bits, TO and
GPR bank. PD, are set.
If a is 0 and the extended instruction Words: 1
set is enabled, this instruction operates
in Indexed Literal Offset Addressing Cycles: 1
mode whenever f 95 (5Fh). See Sec- Q Cycle Activity:
tion 35.2.3 Byte-Oriented and Bit-
Q1 Q2 Q3 Q4
Oriented Instructions in Indexed Lit-
eral Offset Mode for details. Decode No Process No
operation Data operation
Words: 1
Cycles: 1
Example: CLRWDT
Q Cycle Activity: Before Instruction
Q1 Q2 Q3 Q4 WDT Counter = ?
Decode Read Process Write After Instruction
register f Data register f WDT Counter = 00h
WDT Postscaler = 0
TO = 1
Example: CLRF FLAG_REG, 1 PD = 1
Before Instruction
FLAG_REG = 5Ah
After Instruction
FLAG_REG = 00h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 496


PIC18(L)F26/45/46K40

COMF Complement f CPFSEQ Compare f with W, skip if f = W


Syntax: COMF f {,d {,a}} Syntax: CPFSEQ f {,a}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] a [0,1]
a [0,1] Operation: (f) (W),
Operation: (f) dest skip if (f) = (W)
(unsigned comparison)
Status Affected: N, Z
Status Affected: None
Encoding: 0001 11da ffff ffff
Encoding: 0110 001a ffff ffff
Description: The contents of register f are Description: Compares the contents of data memory
complemented. If d is 0, the result is location f to the contents of W by
stored in W. If d is 1, the result is performing an unsigned subtraction.
stored back in register f (default). If f = W, then the fetched instruction is
If a is 0, the Access Bank is selected. discarded and a NOP is executed
If a is 1, the BSR is used to select the instead, making this a 2-cycle
GPR bank. instruction.
If a is 0 and the extended instruction If a is 0, the Access Bank is selected.
set is enabled, this instruction operates If a is 1, the BSR is used to select the
in Indexed Literal Offset Addressing GPR bank.
mode whenever f 95 (5Fh). See Sec- If a is 0 and the extended instruction
tion 35.2.3 Byte-Oriented and Bit- set is enabled, this instruction operates
Oriented Instructions in Indexed Lit- in Indexed Literal Offset Addressing
eral Offset Mode for details. mode whenever f 95 (5Fh). See Sec-
Words: 1 tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit-
Cycles: 1
eral Offset Mode for details.
Q Cycle Activity: Words: 1
Q1 Q2 Q3 Q4 Cycles: 1(2)
Decode Read Process Write to Note: 3 cycles if skip and followed
register f Data destination by a 2-word instruction.
Q Cycle Activity:
Example: COMF REG, 0, 0 Q1 Q2 Q3 Q4
Before Instruction Decode Read Process No
REG = 13h register f Data operation
After Instruction If skip:
REG = 13h Q1 Q2 Q3 Q4
W = ECh No No No No
operation operation operation operation
If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4
No No No No
operation operation operation operation
No No No No
operation operation operation operation

Example: HERE CPFSEQ REG, 0


NEQUAL :
EQUAL :
Before Instruction
PC Address = HERE
W = ?
REG = ?
After Instruction
If REG = W;
PC = Address (EQUAL)
If REG W;
PC = Address (NEQUAL)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 497


PIC18(L)F26/45/46K40

CPFSGT Compare f with W, skip if f > W CPFSLT Compare f with W, skip if f < W
Syntax: CPFSGT f {,a} Syntax: CPFSLT f {,a}
Operands: 0 f 255 Operands: 0 f 255
a [0,1] a [0,1]
Operation: (f) W), Operation: (f) W),
skip if (f) > (W) skip if (f) < (W)
(unsigned comparison) (unsigned comparison)
Status Affected: None Status Affected: None
Encoding: 0110 010a ffff ffff
Encoding: 0110 000a ffff ffff
Description: Compares the contents of data memory
location f to the contents of the W by Description: Compares the contents of data memory
performing an unsigned subtraction. location f to the contents of W by
performing an unsigned subtraction.
If the contents of f are greater than the
contents of WREG, then the fetched If the contents of f are less than the
instruction is discarded and a NOP is contents of W, then the fetched
instruction is discarded and a NOP is
executed instead, making this a
2-cycle instruction. executed instead, making this a
If a is 0, the Access Bank is selected. 2-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 1, the BSR is used to select the
If a is 0 and the extended instruction GPR bank.
set is enabled, this instruction operates Words: 1
in Indexed Literal Offset Addressing Cycles: 1(2)
mode whenever f 95 (5Fh). See Sec-
Note: 3 cycles if skip and followed
tion 35.2.3 Byte-Oriented and Bit- by a 2-word instruction.
Oriented Instructions in Indexed Lit-
eral Offset Mode for details. Q Cycle Activity:
Words: 1 Q1 Q2 Q3 Q4
Cycles: 1(2) Decode Read Process No
Note: 3 cycles if skip and followed register f Data operation
by a 2-word instruction. If skip:
Q Cycle Activity: Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4 No No No No
Decode Read Process No operation operation operation operation
register f Data operation If skip and followed by 2-word instruction:
If skip: Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4 No No No No
No No No No operation operation operation operation
operation operation operation operation No No No No
If skip and followed by 2-word instruction: operation operation operation operation
Q1 Q2 Q3 Q4
No No No No Example: HERE CPFSLT REG, 1
operation operation operation operation NLESS :
No No No No LESS :
operation operation operation operation
Before Instruction
PC = Address (HERE)
Example: HERE CPFSGT REG, 0 W = ?
NGREATER : After Instruction
GREATER :
If REG < W;
Before Instruction PC = Address (LESS)
PC = Address (HERE) If REG W;
W = ? PC = Address (NLESS)
After Instruction
If REG W;
PC = Address (GREATER)
If REG W;
PC = Address (NGREATER)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 498


PIC18(L)F26/45/46K40

DAW Decimal Adjust W Register DECF Decrement f


Syntax: DAW Syntax: DECF f {,d {,a}}
Operands: None Operands: 0 f 255
d [0,1]
Operation: If [W<3:0> > 9] or [DC = 1] then
(W<3:0>) + 6 W<3:0>; a [0,1]
else Operation: (f) 1 dest
(W<3:0>) W<3:0>; Status Affected: C, DC, N, OV, Z
If [W<7:4> + DC > 9] or [C = 1] then Encoding: 0000 01da ffff ffff
(W<7:4>) + 6 + DC W<7:4>; Description: Decrement register f. If d is 0, the
else result is stored in W. If d is 1, the
(W<7:4>) + DC W<7:4> result is stored back in register f
Status Affected: C (default).
If a is 0, the Access Bank is selected.
Encoding: 0000 0000 0000 0111
If a is 1, the BSR is used to select the
Description: DAW adjusts the 8-bit value in W, result- GPR bank.
ing from the earlier addition of two vari- If a is 0 and the extended instruction
ables (each in packed BCD format) and set is enabled, this instruction operates
produces a correct packed BCD result. in Indexed Literal Offset Addressing
Words: 1 mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit-
Cycles: 1 Oriented Instructions in Indexed Lit-
Q Cycle Activity: eral Offset Mode for details.
Q1 Q2 Q3 Q4 Words: 1
Decode Read Process Write Cycles: 1
register W Data W
Q Cycle Activity:
Example1:
Q1 Q2 Q3 Q4
DAW
Decode Read Process Write to
Before Instruction register f Data destination
W = A5h
C = 0
DC = 0 Example: DECF CNT, 1, 0
After Instruction Before Instruction
W = 05h CNT = 01h
C = 1 Z = 0
DC = 0 After Instruction
Example 2: CNT = 00h
Before Instruction Z = 1
W = CEh
C = 0
DC = 0
After Instruction
W = 34h
C = 1
DC = 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 499


PIC18(L)F26/45/46K40

DECFSZ Decrement f, skip if 0 DCFSNZ Decrement f, skip if not 0


Syntax: DECFSZ f {,d {,a}} Syntax: DCFSNZ f {,d {,a}}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] d [0,1]
a [0,1] a [0,1]
Operation: (f) 1 dest, Operation: (f) 1 dest,
skip if result = 0 skip if result 0
Status Affected: None Status Affected: None
Encoding: 0010 11da ffff ffff Encoding: 0100 11da ffff ffff
Description: The contents of register f are Description: The contents of register f are
decremented. If d is 0, the result is decremented. If d is 0, the result is
placed in W. If d is 1, the result is placed in W. If d is 1, the result is
placed back in register f (default). placed back in register f (default).
If the result is 0, the next instruction, If the result is not 0, the next
which is already fetched, is discarded instruction, which is already fetched, is
and a NOP is executed instead, making discarded and a NOP is executed
it a 2-cycle instruction. instead, making it a 2-cycle
If a is 0, the Access Bank is selected. instruction.
If a is 1, the BSR is used to select the If a is 0, the Access Bank is selected.
GPR bank. If a is 1, the BSR is used to select the
If a is 0 and the extended instruction GPR bank.
set is enabled, this instruction operates If a is 0 and the extended instruction
in Indexed Literal Offset Addressing set is enabled, this instruction operates
mode whenever f 95 (5Fh). See Sec- in Indexed Literal Offset Addressing
tion 35.2.3 Byte-Oriented and Bit- mode whenever f 95 (5Fh). See Sec-
Oriented Instructions in Indexed Lit- tion 35.2.3 Byte-Oriented and Bit-
eral Offset Mode for details. Oriented Instructions in Indexed Lit-
Words: 1 eral Offset Mode for details.
Words: 1
Cycles: 1(2)
Note: 3 cycles if skip and followed Cycles: 1(2)
by a 2-word instruction. Note: 3 cycles if skip and followed
Q Cycle Activity: by a 2-word instruction.

Q1 Q2 Q3 Q4 Q Cycle Activity:
Decode Read Process Write to Q1 Q2 Q3 Q4
register f Data destination Decode Read Process Write to
If skip: register f Data destination
Q1 Q2 Q3 Q4 If skip:
No No No No Q1 Q2 Q3 Q4
operation operation operation operation No No No No
If skip and followed by 2-word instruction: operation operation operation operation
Q1 Q2 Q3 Q4 If skip and followed by 2-word instruction:
No No No No Q1 Q2 Q3 Q4
operation operation operation operation No No No No
No No No No operation operation operation operation
operation operation operation operation No No No No
operation operation operation operation
Example: HERE DECFSZ CNT, 1, 1
GOTO LOOP Example: HERE DCFSNZ TEMP, 1, 0
CONTINUE ZERO :
NZERO :
Before Instruction
PC = Address (HERE) Before Instruction
After Instruction TEMP = ?
CNT = CNT - 1 After Instruction
If CNT = 0; TEMP = TEMP 1,
PC = Address (CONTINUE) If TEMP = 0;
If CNT 0; PC = Address (ZERO)
PC = Address (HERE + 2) If TEMP 0;
PC = Address (NZERO)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 500


PIC18(L)F26/45/46K40

GOTO Unconditional Branch INCF Increment f


Syntax: GOTO k Syntax: INCF f {,d {,a}}
Operands: 0 k 1048575 Operands: 0 f 255
d [0,1]
Operation: k PC<20:1>
a [0,1]
Status Affected: None
Operation: (f) + 1 dest
Encoding:
1st word (k<7:0>) 1110 1111 k7kkk kkkk0 Status Affected: C, DC, N, OV, Z
2nd word(k<19:8>) 1111 k19kkk kkkk kkkk8 Encoding: 0010 10da ffff ffff
Description: GOTO allows an unconditional branch Description: The contents of register f are
anywhere within entire incremented. If d is 0, the result is
2-Mbyte memory range. The 20-bit placed in W. If d is 1, the result is
value k is loaded into PC<20:1>. placed back in register f (default).
GOTO is always a 2-cycle If a is 0, the Access Bank is selected.
instruction. If a is 1, the BSR is used to select the
GPR bank.
Words: 2
If a is 0 and the extended instruction
Cycles: 2 set is enabled, this instruction operates
Q Cycle Activity: in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). See Sec-
Q1 Q2 Q3 Q4
tion 35.2.3 Byte-Oriented and Bit-
Decode Read literal No Read literal Oriented Instructions in Indexed Lit-
k<7:0>, operation k<19:8>, eral Offset Mode for details.
Write to PC
Words: 1
No No No No
operation operation operation operation Cycles: 1
Q Cycle Activity:
Example: GOTO THERE Q1 Q2 Q3 Q4
After Instruction Decode Read Process Write to
PC = Address (THERE) register f Data destination

Example: INCF CNT, 1, 0


Before Instruction
CNT = FFh
Z = 0
C = ?
DC = ?
After Instruction
CNT = 00h
Z = 1
C = 1
DC = 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 501


PIC18(L)F26/45/46K40

INCFSZ Increment f, skip if 0 INFSNZ Increment f, skip if not 0


Syntax: INCFSZ f {,d {,a}} Syntax: INFSNZ f {,d {,a}}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] d [0,1]
a [0,1] a [0,1]

Operation: (f) + 1 dest, Operation: (f) + 1 dest,


skip if result 0
skip if result = 0
Status Affected: None
Status Affected: None
Encoding: 0100 10da ffff ffff
Encoding: 0011 11da ffff ffff
Description: The contents of register f are
Description: The contents of register f are incremented. If d is 0, the result is
incremented. If d is 0, the result is placed in W. If d is 1, the result is
placed in W. If d is 1, the result is placed back in register f (default).
placed back in register f (default). If the result is not 0, the next
If the result is 0, the next instruction, instruction, which is already fetched, is
which is already fetched, is discarded discarded and a NOP is executed
and a NOP is executed instead, making instead, making it a 2-cycle
it a 2-cycle instruction. instruction.
If a is 0, the Access Bank is selected. If a is 0, the Access Bank is selected.
If a is 1, the BSR is used to select the If a is 1, the BSR is used to select the
GPR bank. GPR bank.
If a is 0 and the extended instruction If a is 0 and the extended instruction
set is enabled, this instruction operates set is enabled, this instruction operates
in Indexed Literal Offset Addressing in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). See Sec- mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit- Oriented Instructions in Indexed Lit-
eral Offset Mode for details. eral Offset Mode for details.
Words: 1 Words: 1
Cycles: 1(2) Cycles: 1(2)
Note: 3 cycles if skip and followed Note: 3 cycles if skip and followed
by a 2-word instruction. by a 2-word instruction.
Q Cycle Activity: Q Cycle Activity:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
Decode Read Process Write to Decode Read Process Write to
register f Data destination register f Data destination
If skip: If skip:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
No No No No No No No No
operation operation operation operation operation operation operation operation
If skip and followed by 2-word instruction: If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4
No No No No No No No No
operation operation operation operation operation operation operation operation
No No No No No No No No
operation operation operation operation operation operation operation operation

Example: HERE INCFSZ CNT, 1, 0 Example: HERE INFSNZ REG, 1, 0


NZERO : ZERO
ZERO : NZERO
Before Instruction Before Instruction
PC = Address (HERE) PC = Address (HERE)
After Instruction After Instruction
CNT = CNT + 1 REG = REG + 1
If CNT = 0; If REG 0;
PC = Address (ZERO) PC = Address (NZERO)
If CNT 0; If REG = 0;
PC = Address (NZERO) PC = Address (ZERO)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 502


PIC18(L)F26/45/46K40

IORLW Inclusive OR literal with W IORWF Inclusive OR W with f


Syntax: IORLW k Syntax: IORWF f {,d {,a}}
Operands: 0 k 255 Operands: 0 f 255
d [0,1]
Operation: (W) .OR. k W
a [0,1]
Status Affected: N, Z
Operation: (W) .OR. (f) dest
Encoding: 0000 1001 kkkk kkkk
Status Affected: N, Z
Description: The contents of W are ORed with the 8-
bit literal k. The result is placed in W. Encoding: 0001 00da ffff ffff
Description: Inclusive OR W with register f. If d is
Words: 1
0, the result is placed in W. If d is 1,
Cycles: 1 the result is placed back in register f
Q Cycle Activity: (default).
If a is 0, the Access Bank is selected.
Q1 Q2 Q3 Q4
If a is 1, the BSR is used to select the
Decode Read Process Write to W GPR bank.
literal k Data If a is 0 and the extended instruction
set is enabled, this instruction operates
Example: IORLW 35h in Indexed Literal Offset Addressing
mode whenever f 95 (5Fh). See Sec-
Before Instruction tion 35.2.3 Byte-Oriented and Bit-
W = 9Ah Oriented Instructions in Indexed Lit-
After Instruction eral Offset Mode for details.
W = BFh Words: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write to
register f Data destination

Example: IORWF RESULT, 0, 1


Before Instruction
RESULT = 13h
W = 91h
After Instruction
RESULT = 13h
W = 93h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 503


PIC18(L)F26/45/46K40

LFSR Load FSR MOVF Move f


Syntax: LFSR f, k Syntax: MOVF f {,d {,a}}
Operands: 0f2 Operands: 0 f 255
0 k 4095 d [0,1]
Operation: k FSRf a [0,1]
Operation: f dest
Status Affected: None
Encoding: 1110 1110 00ff k11kkk
Status Affected: N, Z
1111 0000 k7kkk kkkk Encoding: 0101 00da ffff ffff
Description: The 12-bit literal k is loaded into the Description: The contents of register f are moved to
File Select Register pointed to by f. a destination dependent upon the
Words: 2 status of d. If d is 0, the result is
placed in W. If d is 1, the result is
Cycles: 2 placed back in register f (default).
Q Cycle Activity: Location f can be anywhere in the
256-byte bank.
Q1 Q2 Q3 Q4
If a is 0, the Access Bank is selected.
Decode Read literal Process Write If a is 1, the BSR is used to select the
k MSB Data literal k GPR bank.
MSB to If a is 0 and the extended instruction
FSRfH set is enabled, this instruction operates
Decode Read literal Process Write literal in Indexed Literal Offset Addressing
k LSB Data k to FSRfL mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit-
Example: LFSR 2, 3ABh
eral Offset Mode for details.
After Instruction
Words: 1
FSR2H = 03h
FSR2L = ABh Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write W
register f Data

Example: MOVF REG, 0, 0


Before Instruction
REG = 22h
W = FFh
After Instruction
REG = 22h
W = 22h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 504


PIC18(L)F26/45/46K40

MOVFF Move f to f MOVLB Move literal to low nibble in BSR


Syntax: MOVFF fs,fd Syntax: MOVLW k
Operands: 0 fs 4095 Operands: 0 k 255
0 fd 4095
Operation: k BSR
Operation: (fs) fd Status Affected: None
Status Affected: None Encoding: 0000 0001 kkkk kkkk
Encoding:
Description: The 8-bit literal k is loaded into the
1st word (source) 1100 ffff ffff ffffs
Bank Select Register (BSR). The value
2nd word (destin.) 1111 ffff ffff ffffd
of BSR<7:4> always remains 0,
Description: The contents of source register fs are regardless of the value of k7:k4.
moved to destination register fd. Words: 1
Location of source fs can be anywhere
in the 4096-byte data space (000h to Cycles: 1
FFFh) and location of destination fd Q Cycle Activity:
can also be anywhere from 000h to
Q1 Q2 Q3 Q4
FFFh.
Either source or destination can be W Decode Read Process Write literal
(a useful special situation). literal k Data k to BSR
MOVFF is particularly useful for
transferring a data memory location to a Example: MOVLB 5
peripheral register (such as the transmit
Before Instruction
buffer or an I/O port).
The MOVFF instruction cannot use the BSR Register = 02h
PCL, TOSU, TOSH or TOSL as the After Instruction
BSR Register = 05h
destination register.
Words: 2
Cycles: 2 (3)
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process No
register f Data operation
(src)
Decode No No Write
operation operation register f
No dummy (dest)
read

Example: MOVFF REG1, REG2


Before Instruction
REG1 = 33h
REG2 = 11h
After Instruction
REG1 = 33h
REG2 = 33h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 505


PIC18(L)F26/45/46K40

MOVLW Move literal to W MOVWF Move W to f


Syntax: MOVLW k Syntax: MOVWF f {,a}
Operands: 0 k 255 Operands: 0 f 255
a [0,1]
Operation: kW
Status Affected: None Operation: (W) f

Encoding: 0000 1110 kkkk kkkk Status Affected: None


Encoding: 0110 111a ffff ffff
Description: The 8-bit literal k is loaded into W.
Words: 1 Description: Move data from W to register f.
Location f can be anywhere in the
Cycles: 1 256-byte bank.
Q Cycle Activity: If a is 0, the Access Bank is selected.
If a is 1, the BSR is used to select the
Q1 Q2 Q3 Q4
GPR bank.
Decode Read Process Write to W If a is 0 and the extended instruction
literal k Data set is enabled, this instruction operates
in Indexed Literal Offset Addressing
Example: MOVLW 5Ah mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit-
After Instruction
Oriented Instructions in Indexed Lit-
W = 5Ah eral Offset Mode for details.
Words: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write
register f Data register f

Example: MOVWF REG, 0


Before Instruction
W = 4Fh
REG = FFh
After Instruction
W = 4Fh
REG = 4Fh

2016 Microchip Technology Inc. Preliminary DS40001816C-page 506


PIC18(L)F26/45/46K40

MULLW Multiply literal with W MULWF Multiply W with f


Syntax: MULLW k Syntax: MULWF f {,a}
Operands: 0 k 255 Operands: 0 f 255
a [0,1]
Operation: (W) x k PRODH:PRODL
Status Affected: None Operation: (W) x (f) PRODH:PRODL

Encoding: 0000 1101 kkkk kkkk Status Affected: None


Encoding: 0000 001a ffff ffff
Description: An unsigned multiplication is carried
out between the contents of W and the Description: An unsigned multiplication is carried
8-bit literal k. The 16-bit result is out between the contents of W and the
placed in the PRODH:PRODL register register file location f. The 16-bit
pair. PRODH contains the high byte. result is stored in the PRODH:PRODL
W is unchanged. register pair. PRODH contains the
None of the Status flags are affected. high byte. Both W and f are
Note that neither overflow nor carry is unchanged.
possible in this operation. A zero result None of the Status flags are affected.
is possible but not detected. Note that neither overflow nor carry is
Words: 1 possible in this operation. A zero
result is possible but not detected.
Cycles: 1 If a is 0, the Access Bank is
Q Cycle Activity: selected. If a is 1, the BSR is used
to select the GPR bank.
Q1 Q2 Q3 Q4
If a is 0 and the extended instruction
Decode Read Process Write set is enabled, this instruction
literal k Data registers operates in Indexed Literal Offset
PRODH: Addressing mode whenever
PRODL f 95 (5Fh). See Section
35.2.3 Byte-Oriented and Bit-Ori-
Example: MULLW 0C4h ented Instructions in Indexed Literal
Offset Mode for details.
Before Instruction
Words: 1
W = E2h
PRODH = ? Cycles: 1
PRODL = ?
After Instruction Q Cycle Activity:

W = E2h Q1 Q2 Q3 Q4
PRODH = ADh Decode Read Process Write
PRODL = 08h register f Data registers
PRODH:
PRODL

Example: MULWF REG, 1


Before Instruction
W = C4h
REG = B5h
PRODH = ?
PRODL = ?
After Instruction
W = C4h
REG = B5h
PRODH = 8Ah
PRODL = 94h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 507


PIC18(L)F26/45/46K40

NEGF Negate f NOP No Operation


Syntax: NEGF f {,a} Syntax: NOP
Operands: 0 f 255 Operands: None
a [0,1]
Operation: No operation
Operation: (f)+1f Status Affected: None
Status Affected: N, OV, C, DC, Z Encoding: 0000 0000 0000 0000
Encoding: 0110 110a ffff ffff 1111 xxxx xxxx xxxx
Description: Location f is negated using twos Description: No operation.
complement. The result is placed in the
Words: 1
data memory location f.
If a is 0, the Access Bank is selected. Cycles: 1
If a is 1, the BSR is used to select the Q Cycle Activity:
GPR bank.
Q1 Q2 Q3 Q4
If a is 0 and the extended instruction
set is enabled, this instruction operates Decode No No No
in Indexed Literal Offset Addressing operation operation operation
mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- Example:
Oriented Instructions in Indexed Lit-
eral Offset Mode for details. None.

Words: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write
register f Data register f

Example: NEGF REG, 1


Before Instruction
REG = 0011 1010 [3Ah]
After Instruction
REG = 1100 0110 [C6h]

2016 Microchip Technology Inc. Preliminary DS40001816C-page 508


PIC18(L)F26/45/46K40

POP Pop Top of Return Stack PUSH Push Top of Return Stack
Syntax: POP Syntax: PUSH
Operands: None Operands: None
Operation: (TOS) bit bucket Operation: (PC + 2) TOS
Status Affected: None Status Affected: None
Encoding: 0000 0000 0000 0110 Encoding: 0000 0000 0000 0101
Description: The TOS value is pulled off the return Description: The PC + 2 is pushed onto the top of
stack and is discarded. The TOS value the return stack. The previous TOS
then becomes the previous value that value is pushed down on the stack.
was pushed onto the return stack. This instruction allows implementing a
This instruction is provided to enable software stack by modifying TOS and
the user to properly manage the return then pushing it onto the return stack.
stack to incorporate a software stack. Words: 1
Words: 1
Cycles: 1
Cycles: 1 Q Cycle Activity:
Q Cycle Activity: Q1 Q2 Q3 Q4
Q1 Q2 Q3 Q4 Decode PUSH No No
Decode No POP TOS No PC + 2 onto operation operation
operation value operation return stack

Example: POP Example: PUSH


GOTO NEW
Before Instruction
Before Instruction TOS = 345Ah
TOS = 0031A2h PC = 0124h
Stack (1 level down) = 014332h
After Instruction
After Instruction PC = 0126h
TOS = 014332h TOS = 0126h
PC = NEW Stack (1 level down) = 345Ah

2016 Microchip Technology Inc. Preliminary DS40001816C-page 509


PIC18(L)F26/45/46K40

RCALL Relative Call RESET Reset


Syntax: RCALL n Syntax: RESET
Operands: -1024 n 1023 Operands: None
Operation: (PC) + 2 TOS, Operation: Reset all registers and flags that are
(PC) + 2 + 2n PC affected by a MCLR Reset.
Status Affected: None Status Affected: All
Encoding: 1101 1nnn nnnn nnnn Encoding: 0000 0000 1111 1111
Description: Subroutine call with a jump up to 1K Description: This instruction provides a way to
from the current location. First, return execute a MCLR Reset by software.
address (PC + 2) is pushed onto the Words: 1
stack. Then, add the 2s complement
number 2n to the PC. Since the PC will Cycles: 1
have incremented to fetch the next Q Cycle Activity:
instruction, the new address will be
Q1 Q2 Q3 Q4
PC + 2 + 2n. This instruction is a
2-cycle instruction. Decode Start No No
Reset operation operation
Words: 1
Cycles: 2 Example: RESET
Q Cycle Activity: After Instruction
Q1 Q2 Q3 Q4 Registers = Reset Value
Decode Read literal Process Write to PC Flags* = Reset Value
n Data
PUSH PC to
stack
No No No No
operation operation operation operation

Example: HERE RCALL Jump


Before Instruction
PC = Address (HERE)
After Instruction
PC = Address (Jump)
TOS = Address (HERE + 2)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 510


PIC18(L)F26/45/46K40

RETFIE Return from Interrupt RETLW Return literal to W


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

2016 Microchip Technology Inc. Preliminary DS40001816C-page 511


PIC18(L)F26/45/46K40

RETURN Return from Subroutine RLCF Rotate Left f through Carry


Syntax: RETURN {s} Syntax: RLCF f {,d {,a}}
Operands: s [0,1] Operands: 0 f 255
d [0,1]
Operation: (TOS) PC,
if s = 1 a [0,1]
(WS) W, Operation: (f<n>) dest<n + 1>,
(STATUSS) Status, (f<7>) C,
(BSRS) BSR, (C) dest<0>
PCLATU, PCLATH are unchanged
Status Affected: C, N, Z
Status Affected: None Encoding: 0011 01da ffff ffff
Encoding: 0000 0000 0001 001s
Description: The contents of register f are rotated
Description: Return from subroutine. The stack is one bit to the left through the CARRY
popped and the top of the stack (TOS) flag. If d is 0, the result is placed in
is loaded into the program counter. If W. If d is 1, the result is stored back
s= 1, the contents of the shadow in register f (default).
registers, WS, STATUSS and BSRS, If a is 0, the Access Bank is
are loaded into their corresponding selected. If a is 1, the BSR is used to
registers, W, Status and BSR. If select the GPR bank.
s = 0, no update of these registers If a is 0 and the extended instruction
occurs (default). set is enabled, this instruction
operates in Indexed Literal Offset
Words: 1
Addressing mode whenever
Cycles: 2 f 95 (5Fh). See Section
Q Cycle Activity: 35.2.3 Byte-Oriented and Bit-Ori-
ented Instructions in Indexed Literal
Q1 Q2 Q3 Q4
Offset Mode for details.
Decode No Process POP PC
operation Data from stack C register f
No No No No
operation operation operation operation Words: 1
Cycles: 1
Q Cycle Activity:
Example: RETURN Q1 Q2 Q3 Q4
After Instruction: Decode Read Process Write to
PC = TOS register f Data destination

Example: RLCF REG, 0, 0


Before Instruction
REG = 1110 0110
C = 0
After Instruction
REG = 1110 0110
W = 1100 1100
C = 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 512


PIC18(L)F26/45/46K40

RLNCF Rotate Left f (No Carry) RRCF Rotate Right f through Carry
Syntax: RLNCF f {,d {,a}} Syntax: RRCF f {,d {,a}}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] d [0,1]
a [0,1] a [0,1]
Operation: (f<n>) dest<n + 1>, Operation: (f<n>) dest<n 1>,
(f<7>) dest<0> (f<0>) C,
Status Affected: N, Z (C) dest<7>

Encoding: 0100 01da ffff ffff Status Affected: C, N, Z


Encoding: 0011 00da ffff ffff
Description: The contents of register f are rotated
one bit to the left. If d is 0, the result Description: The contents of register f are rotated
is placed in W. If d is 1, the result is one bit to the right through the CARRY
stored back in register f (default). flag. If d is 0, the result is placed in W.
If a is 0, the Access Bank is selected. If d is 1, the result is placed back in
If a is 1, the BSR is used to select the register f (default).
GPR bank. If a is 0, the Access Bank is selected.
If a is 0 and the extended instruction If a is 1, the BSR is used to select the
set is enabled, this instruction operates GPR bank.
in Indexed Literal Offset Addressing If a is 0 and the extended instruction
mode whenever f 95 (5Fh). See Sec- set is enabled, this instruction operates
tion 35.2.3 Byte-Oriented and Bit- in Indexed Literal Offset Addressing
Oriented Instructions in Indexed Lit- mode whenever f 95 (5Fh). See Sec-
eral Offset Mode for details. tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit-
register f
eral Offset Mode for details.

Words: 1 C register f
Cycles: 1
Words: 1
Q Cycle Activity:
Cycles: 1
Q1 Q2 Q3 Q4
Decode Read Process Write to Q Cycle Activity:
register f Data destination Q1 Q2 Q3 Q4
Decode Read Process Write to
Example: RLNCF REG, 1, 0 register f Data destination

Before Instruction
REG = 1010 1011 Example: RRCF REG, 0, 0
After Instruction Before Instruction
REG = 0101 0111 REG = 1110 0110
C = 0
After Instruction
REG = 1110 0110
W = 0111 0011
C = 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 513


PIC18(L)F26/45/46K40

RRNCF Rotate Right f (No Carry) SETF Set f


Syntax: RRNCF f {,d {,a}} Syntax: SETF f {,a}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] a [0,1]
a [0,1] Operation: FFh f
Operation: (f<n>) dest<n 1>,
Status Affected: None
(f<0>) dest<7>
Encoding: 0110 100a ffff ffff
Status Affected: N, Z
Description: The contents of the specified register
Encoding: 0100 00da ffff ffff
are set to FFh.
Description: The contents of register f are rotated If a is 0, the Access Bank is selected.
one bit to the right. If d is 0, the result If a is 1, the BSR is used to select the
is placed in W. If d is 1, the result is GPR bank.
placed back in register f (default). If a is 0 and the extended instruction
If a is 0, the Access Bank will be set is enabled, this instruction operates
selected (default), overriding the BSR in Indexed Literal Offset Addressing
value. If a is 1, then the bank will be mode whenever f 95 (5Fh). See Sec-
selected as per the BSR value. tion 35.2.3 Byte-Oriented and Bit-
If a is 0 and the extended instruction Oriented Instructions in Indexed Lit-
set is enabled, this instruction operates eral Offset Mode for details.
in Indexed Literal Offset Addressing Words: 1
mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- Cycles: 1
Oriented Instructions in Indexed Lit- Q Cycle Activity:
eral Offset Mode for details.
Q1 Q2 Q3 Q4
register f Decode Read Process Write
register f Data register f
Words: 1
Cycles: 1 Example: SETF REG, 1
Q Cycle Activity: Before Instruction
Q1 Q2 Q3 Q4 REG = 5Ah
Decode Read Process Write to After Instruction
REG = FFh
register f Data destination

Example 1: RRNCF REG, 1, 0


Before Instruction
REG = 1101 0111
After Instruction
REG = 1110 1011

Example 2: RRNCF REG, 0, 0


Before Instruction
W = ?
REG = 1101 0111
After Instruction
W = 1110 1011
REG = 1101 0111

2016 Microchip Technology Inc. Preliminary DS40001816C-page 514


PIC18(L)F26/45/46K40

SLEEP Enter Sleep mode SUBFWB Subtract f from W with borrow


Syntax: SLEEP Syntax: SUBFWB f {,d {,a}}
Operands: None Operands: 0 f 255
d [0,1]
Operation: 00h WDT,
0 WDT postscaler, a [0,1]
1 TO, Operation: (W) (f) (C) dest
0 PD Status Affected: N, OV, C, DC, Z
Status Affected: TO, PD
Encoding: 0101 01da ffff ffff
Encoding: 0000 0000 0000 0011 Description: Subtract register f and CARRY flag
Description: The Power-down Status bit (PD) is (borrow) from W (2s complement
cleared. The Time-out Status bit (TO) method). If d is 0, the result is stored
is set. Watchdog Timer and its posts- in W. If d is 1, the result is stored in
caler are cleared. register f (default).
The processor is put into Sleep mode If a is 0, the Access Bank is
with the oscillator stopped. selected. If a is 1, the BSR is used
Words: 1 to select the GPR bank.
If a is 0 and the extended instruction
Cycles: 1 set is enabled, this instruction
Q Cycle Activity: operates in Indexed Literal Offset
Addressing mode whenever
Q1 Q2 Q3 Q4
f 95 (5Fh). See Section
Decode No Process Go to 35.2.3 Byte-Oriented and Bit-Ori-
operation Data Sleep ented Instructions in Indexed Literal
Offset Mode for details.
Example: SLEEP Words: 1
Before Instruction Cycles: 1
TO = ?
Q Cycle Activity:
PD = ?
After Instruction Q1 Q2 Q3 Q4
TO = 1 Decode Read Process Write to
PD = 0 register f Data destination
Example 1: SUBFWB REG, 1, 0
If WDT causes wake-up, this bit is cleared.
Before Instruction
REG = 3
W = 2
C = 1
After Instruction
REG = FF
W = 2
C = 0
Z = 0
N = 1 ; result is negative
Example 2: SUBFWB REG, 0, 0
Before Instruction
REG = 2
W = 5
C = 1
After Instruction
REG = 2
W = 3
C = 1
Z = 0
N = 0 ; result is positive
Example 3: SUBFWB REG, 1, 0
Before Instruction
REG = 1
W = 2
C = 0
After Instruction
REG = 0
W = 2
C = 1
Z = 1 ; result is zero
N = 0

2016 Microchip Technology Inc. Preliminary DS40001816C-page 515


PIC18(L)F26/45/46K40

SUBLW Subtract W from literal SUBWF Subtract W from f


Syntax: SUBLW k Syntax: SUBWF f {,d {,a}}
Operands: 0 k 255 Operands: 0 f 255
d [0,1]
Operation: k (W) W
a [0,1]
Status Affected: N, OV, C, DC, Z
Operation: (f) (W) dest
Encoding: 0000 1000 kkkk kkkk
Status Affected: N, OV, C, DC, Z
Description W is subtracted from the 8-bit
literal k. The result is placed in W. Encoding: 0101 11da ffff ffff
Description: Subtract W from register f (2s
Words: 1
complement method). If d is 0, the
Cycles: 1 result is stored in W. If d is 1, the
Q Cycle Activity: result is stored back in register f
(default).
Q1 Q2 Q3 Q4
If a is 0, the Access Bank is
Decode Read Process Write to W selected. If a is 1, the BSR is used
literal k Data to select the GPR bank.
If a is 0 and the extended instruction
Example 1: SUBLW 02h
set is enabled, this instruction
Before Instruction operates in Indexed Literal Offset
W = 01h Addressing mode whenever
C = ?
f 95 (5Fh). See Section
After Instruction
W = 01h 35.2.3 Byte-Oriented and Bit-Ori-
C = 1 ; result is positive ented Instructions in Indexed Literal
Z = 0 Offset Mode for details.
N = 0
Words: 1
Example 2: SUBLW 02h
Cycles: 1
Before Instruction
W = 02h Q Cycle Activity:
C = ?
Q1 Q2 Q3 Q4
After Instruction
W = 00h Decode Read Process Write to
C = 1 ; result is zero register f Data destination
Z = 1
N = 0 Example 1: SUBWF REG, 1, 0
Example 3: SUBLW 02h Before Instruction
REG = 3
Before Instruction W = 2
W = 03h C = ?
C = ? After Instruction
After Instruction REG = 1
W = FFh ; (2s complement) W = 2
C = 0 ; result is negative C = 1 ; result is positive
Z = 0 Z = 0
N = 1 N = 0
Example 2: SUBWF REG, 0, 0
Before Instruction
REG = 2
W = 2
C = ?
After Instruction
REG = 2
W = 0
C = 1 ; result is zero
Z = 1
N = 0
Example 3: SUBWF REG, 1, 0
Before Instruction
REG = 1
W = 2
C = ?
After Instruction
REG = FFh ;(2s complement)
W = 2
C = 0 ; result is negative
Z = 0
N = 1

2016 Microchip Technology Inc. Preliminary DS40001816C-page 516


PIC18(L)F26/45/46K40

SUBWFB Subtract W from f with Borrow SWAPF Swap f


Syntax: SUBWFB f {,d {,a}} Syntax: SWAPF f {,d {,a}}
Operands: 0 f 255 Operands: 0 f 255
d [0,1] d [0,1]
a [0,1] a [0,1]
Operation: (f) (W) (C) dest Operation: (f<3:0>) dest<7:4>,
Status Affected: N, OV, C, DC, Z (f<7:4>) dest<3:0>
Encoding: 0101 10da ffff ffff Status Affected: None
Description: Subtract W and the CARRY flag Encoding: 0011 10da ffff ffff
(borrow) from register f (2s comple-
ment method). If d is 0, the result is Description: The upper and lower nibbles of register
stored in W. If d is 1, the result is f are exchanged. If d is 0, the result
stored back in register f (default). is placed in W. If d is 1, the result is
If a is 0, the Access Bank is selected. placed in register f (default).
If a is 1, the BSR is used to select the If a is 0, the Access Bank is selected.
GPR bank. If a is 1, the BSR is used to select the
If a is 0 and the extended instruction GPR bank.
set is enabled, this instruction operates If a is 0 and the extended instruction
in Indexed Literal Offset Addressing set is enabled, this instruction operates
mode whenever f 95 (5Fh). See Sec- in Indexed Literal Offset Addressing
tion 35.2.3 Byte-Oriented and Bit- mode whenever f 95 (5Fh). See Sec-
Oriented Instructions in Indexed Lit- tion 35.2.3 Byte-Oriented and Bit-
eral Offset Mode for details. Oriented Instructions in Indexed Lit-
eral Offset Mode for details.
Words: 1
Words: 1
Cycles: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4 Q Cycle Activity:
Decode Read Process Write to Q1 Q2 Q3 Q4
register f Data destination Decode Read Process Write to
Example 1: SUBWFB REG, 1, 0 register f Data destination
Before Instruction
REG = 19h (0001 1001) Example: SWAPF REG, 1, 0
W = 0Dh (0000 1101)
C = 1 Before Instruction
After Instruction REG = 53h
REG = 0Ch (0000 1100) After Instruction
W = 0Dh (0000 1101)
C = 1 REG = 35h
Z = 0
N = 0 ; result is positive
Example 2: SUBWFB REG, 0, 0
Before Instruction
REG = 1Bh (0001 1011)
W = 1Ah (0001 1010)
C = 0
After Instruction
REG = 1Bh (0001 1011)
W = 00h
C = 1
Z = 1 ; result is zero
N = 0
Example 3: SUBWFB REG, 1, 0
Before Instruction
REG = 03h (0000 0011)
W = 0Eh (0000 1110)
C = 1
After Instruction
REG = F5h (1111 0101)
; [2s comp]
W = 0Eh (0000 1110)
C = 0
Z = 0
N = 1 ; result is negative

2016 Microchip Technology Inc. Preliminary DS40001816C-page 517


PIC18(L)F26/45/46K40

TBLRD Table Read TBLRD Table Read (Continued)


Syntax: TBLRD ( *; *+; *-; +*) Example1: TBLRD *+ ;
Operands: None Before Instruction
TABLAT = 55h
Operation: if TBLRD *, TBLPTR = 00A356h
(Prog Mem (TBLPTR)) TABLAT; MEMORY (00A356h) = 34h
TBLPTR No Change; After Instruction
if TBLRD *+, TABLAT = 34h
(Prog Mem (TBLPTR)) TABLAT; TBLPTR = 00A357h
(TBLPTR) + 1 TBLPTR;
Example2: TBLRD +* ;
if TBLRD *-,
(Prog Mem (TBLPTR)) TABLAT; Before Instruction
(TBLPTR) 1 TBLPTR; TABLAT = AAh
TBLPTR = 01A357h
if TBLRD +*, MEMORY (01A357h) = 12h
(TBLPTR) + 1 TBLPTR; MEMORY (01A358h) = 34h
(Prog Mem (TBLPTR)) TABLAT; After Instruction
Status Affected: None TABLAT = 34h
TBLPTR = 01A358h
Encoding: 0000 0000 0000 10nn
nn=0 *
=1 *+
=2 *-
=3 +*
Description: This instruction is used to read the contents
of Program Memory (P.M.). To address the
program memory, a pointer called Table
Pointer (TBLPTR) is used.
The TBLPTR (a 21-bit pointer) points to
each byte in the program memory. TBLPTR
has a 2-Mbyte address range.
TBLPTR[0] = 0: Least Significant Byte
of Program Memory
Word
TBLPTR[0] = 1: Most Significant Byte
of Program Memory
Word
The TBLRD instruction can modify the value
of TBLPTR as follows:
no change
post-increment
post-decrement
pre-increment
Words: 1
Cycles: 2
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode No No No
operation operation operation
No No operation No No operation
operation (Read Program operation (Write TABLAT)
Memory)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 518


PIC18(L)F26/45/46K40

TBLWT Table Write TBLWT Table Write (Continued)


Syntax: TBLWT ( *; *+; *-; +*) Example1: TBLWT *+;
Operands: None Before Instruction
Operation: if TBLWT*, TABLAT = 55h
(TABLAT) Holding Register; TBLPTR = 00A356h
TBLPTR No Change; HOLDING REGISTER
(00A356h) = FFh
if TBLWT*+,
After Instructions (table write completion)
(TABLAT) Holding Register;
TABLAT = 55h
(TBLPTR) + 1 TBLPTR; TBLPTR = 00A357h
if TBLWT*-, HOLDING REGISTER
(TABLAT) Holding Register; (00A356h) = 55h
(TBLPTR) 1 TBLPTR; Example 2: TBLWT +*;
if TBLWT+*,
(TBLPTR) + 1 TBLPTR; Before Instruction
(TABLAT) Holding Register; TABLAT = 34h
TBLPTR = 01389Ah
Status Affected: None HOLDING REGISTER
(01389Ah) = FFh
Encoding: 0000 0000 0000 11nn
HOLDING REGISTER
nn=0 * (01389Bh) = FFh
=1 *+ After Instruction (table write completion)
=2 *- TABLAT = 34h
=3 +* TBLPTR = 01389Bh
HOLDING REGISTER
Description: This instruction uses the three LSBs of (01389Ah) = FFh
TBLPTR to determine which of the eight HOLDING REGISTER
holding registers the TABLAT is written to. (01389Bh) = 34h
The holding registers are used to program
the contents of Program Memory (P.M.).
(Refer to Section 11.1 Program Flash
Memory for additional details on pro-
gramming Flash memory.)
The TBLPTR (a 21-bit pointer) points to
each byte in the program memory.
TBLPTR has a 2-MByte address range.
The LSb of the TBLPTR selects which
byte of the program memory location to
access.
TBLPTR[0] = 0: Least Significant
Byte of Program
Memory Word
TBLPTR[0] = 1: Most Significant
Byte of Program
Memory Word
The TBLWT instruction can modify the
value of TBLPTR as follows:
no change
post-increment
post-decrement
pre-increment
Words: 1
Cycles: 2
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode No No No
operation operation operation
No No No No
operation operation operation operation
(Read (Write to
TABLAT) Holding
Register )

2016 Microchip Technology Inc. Preliminary DS40001816C-page 519


PIC18(L)F26/45/46K40

TSTFSZ Test f, skip if 0 XORLW Exclusive OR literal with W


Syntax: TSTFSZ f {,a} Syntax: XORLW k
Operands: 0 f 255 Operands: 0 k 255
a [0,1]
Operation: (W) .XOR. k W
Operation: skip if f = 0 Status Affected: N, Z
Status Affected: None Encoding: 0000 1010 kkkk kkkk
Encoding: 0110 011a ffff ffff
Description: The contents of W are XORed with
Description: If f = 0, the next instruction fetched the 8-bit literal k. The result is placed
during the current instruction execution in W.
is discarded and a NOP is executed, Words: 1
making this a 2-cycle instruction.
If a is 0, the Access Bank is selected. Cycles: 1
If a is 1, the BSR is used to select the Q Cycle Activity:
GPR bank.
Q1 Q2 Q3 Q4
If a is 0 and the extended instruction
set is enabled, this instruction operates Decode Read Process Write to W
in Indexed Literal Offset Addressing literal k Data
mode whenever f 95 (5Fh). See Sec-
tion 35.2.3 Byte-Oriented and Bit- Example: XORLW 0AFh
Oriented Instructions in Indexed Lit-
eral Offset Mode for details. Before Instruction
W = B5h
Words: 1
After Instruction
Cycles: 1(2)
W = 1Ah
Note: 3 cycles if skip and followed
by a 2-word instruction.
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process No
register f Data operation
If skip:
Q1 Q2 Q3 Q4
No No No No
operation operation operation operation
If skip and followed by 2-word instruction:
Q1 Q2 Q3 Q4
No No No No
operation operation operation operation
No No No No
operation operation operation operation

Example: HERE TSTFSZ CNT, 1


NZERO :
ZERO :
Before Instruction
PC = Address (HERE)
After Instruction
If CNT = 00h,
PC = Address (ZERO)
If CNT 00h,
PC = Address (NZERO)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 520


PIC18(L)F26/45/46K40

XORWF Exclusive OR W with f


Syntax: XORWF f {,d {,a}}
Operands: 0 f 255
d [0,1]
a [0,1]
Operation: (W) .XOR. (f) dest
Status Affected: N, Z
Encoding: 0001 10da ffff ffff
Description: Exclusive OR the contents of W with
register f. If d is 0, the result is stored
in W. If d is 1, the result is stored back
in the register f (default).
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 Sec-
tion 35.2.3 Byte-Oriented and Bit-
Oriented Instructions in Indexed Lit-
eral Offset Mode for details.
Words: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read Process Write to
register f Data destination

Example: XORWF REG, 1, 0


Before Instruction
REG = AFh
W = B5h
After Instruction
REG = 1Ah
W = B5h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 521


PIC18(L)F26/45/46K40
35.2 Extended Instruction Set A summary of the instructions in the extended instruc-
tion set is provided in Table 35-3. Detailed descriptions
In addition to the standard 75 instructions of the PIC18 are provided in Section 35.2.2 Extended Instruction
instruction set, PIC18(L)F2x/4xK40 devices also Set. The opcode field descriptions in Table 35-1 apply
provide an optional extension to the core CPU to both the standard and extended PIC18 instruction
functionality. The added features include eight sets.
additional instructions that augment indirect and
indexed addressing operations and the implementation Note: The instruction set extension and the
of Indexed Literal Offset Addressing mode for many of Indexed Literal Offset Addressing mode
the standard PIC18 instructions. were designed for optimizing applications
written in C; the user may likely never use
The additional features of the extended instruction set
these instructions directly in assembler.
are disabled by default. To enable them, users must set
The syntax for these commands is pro-
the XINST Configuration bit.
vided as a reference for users who may be
The instructions in the extended set can all be reviewing code that has been generated
classified as literal operations, which either manipulate by a compiler.
the File Select Registers, or use them for indexed
addressing. Two of the instructions, ADDFSR and 35.2.1 EXTENDED INSTRUCTION SYNTAX
SUBFSR, each have an additional special instantiation
Most of the extended instructions use indexed
for using FSR2. These versions (ADDULNK and
arguments, using one of the File Select Registers and
SUBULNK) allow for automatic return after execution.
some offset to specify a source or destination register.
The extended instructions are specifically implemented When an argument for an instruction serves as part of
to optimize re-entrant program code (that is, code that indexed addressing, it is enclosed in square brackets
is recursive or that uses a software stack) written in ([ ]). This is done to indicate that the argument is used
high-level languages, particularly C. Among other as an index or offset. MPASM Assembler will flag an
things, they allow users working in high-level error if it determines that an index or offset value is not
languages to perform certain operations on data bracketed.
structures more efficiently. These include:
When the extended instruction set is enabled, brackets
dynamic allocation and deallocation of software are also used to indicate index arguments in byte-
stack space when entering and leaving oriented and bit-oriented instructions. This is in addition
subroutines to other changes in their syntax. For more details, see
function pointer invocation Section 35.2.3.1 Extended Instruction Syntax with
software Stack Pointer manipulation Standard PIC18 Commands.
manipulation of variables located in a software Note: In the past, square brackets have been
stack used to denote optional arguments in the
PIC18 and earlier instruction sets. In this
text and going forward, optional
arguments are denoted by braces ({ }).

TABLE 35-3: EXTENSIONS TO THE PIC18 INSTRUCTION SET


Mnemonic, 16-Bit Instruction Word Status
Description Cycles
Operands MSb LSb Affected

ADDFSR f, k Add literal to FSR 1 1110 1000 ffkk kkkk None


ADDULNK k Add literal to FSR2 and return 2 1110 1000 11kk kkkk None
CALLW Call subroutine using WREG 2 0000 0000 0001 0100 None
MOVSF zs, fd Move zs (source) to 1st word 2 1110 1011 0zzz zzzz None
fd (destination) 2nd word 1111 ffff ffff ffff
MOVSS zs, zd Move zs (source) to 1st word 2 1110 1011 1zzz zzzz None
zd (destination) 2nd word 1111 xxxx xzzz zzzz
PUSHL k Store literal at FSR2, 1 1110 1010 kkkk kkkk None
decrement FSR2
SUBFSR f, k Subtract literal from FSR 1 1110 1001 ffkk kkkk None
SUBULNK k Subtract literal from FSR2 and 2 1110 1001 11kk kkkk None
return

2016 Microchip Technology Inc. Preliminary DS40001816C-page 522


PIC18(L)F26/45/46K40
35.2.2 EXTENDED INSTRUCTION SET

ADDFSR Add Literal to FSR ADDULNK Add Literal to FSR2 and Return
Syntax: ADDFSR f, k Syntax: ADDULNK k
Operands: 0 k 63 Operands: 0 k 63
f [ 0, 1, 2 ] Operation: FSR2 + k FSR2,
Operation: FSR(f) + k FSR(f) (TOS) PC
Status Affected: None Status Affected: None
Encoding: 1110 1000 ffkk kkkk Encoding: 1110 1000 11kk kkkk
Description: The 6-bit literal k is added to the Description: The 6-bit literal k is added to the
contents of the FSR specified by f. contents of FSR2. A RETURN is then
Words: 1 executed by loading the PC with the
Cycles: 1 TOS.
The instruction takes two cycles to
Q Cycle Activity:
execute; a NOP is performed during
Q1 Q2 Q3 Q4 the second cycle.
Decode Read Process Write to This may be thought of as a special
literal k Data FSR case of the ADDFSR instruction,
where f = 3 (binary 11); it operates
only on FSR2.
Example: ADDFSR 2, 23h Words: 1
Before Instruction Cycles: 2
FSR2 = 03FFh
After Instruction Q Cycle Activity:
FSR2 = 0422h
Q1 Q2 Q3 Q4
Decode Read Process Write to
literal k Data FSR
No No No No
Operation Operation Operation Operation

Example: ADDULNK 23h


Before Instruction
FSR2 = 03FFh
PC = 0100h
After Instruction
FSR2 = 0422h
PC = (TOS)

Note: All PIC18 instructions may take an optional label argument preceding the instruction mnemonic for use in
symbolic addressing. If a label is used, the instruction syntax then becomes: {label} instruction argument(s).

2016 Microchip Technology Inc. Preliminary DS40001816C-page 523


PIC18(L)F26/45/46K40

CALLW Subroutine Call Using WREG MOVSF Move Indexed to f


Syntax: CALLW Syntax: MOVSF [zs], fd
Operands: None Operands: 0 zs 127
0 fd 4095
Operation: (PC + 2) TOS,
(W) PCL, Operation: ((FSR2) + zs) fd
(PCLATH) PCH,
Status Affected: None
(PCLATU) PCU
Encoding:
Status Affected: None
1st word (source) 1110 1011 0zzz zzzzs
Encoding: 0000 0000 0001 0100 2nd word (destin.) 1111 ffff ffff ffffd
Description First, the return address (PC + 2) is Description: The contents of the source register are
pushed onto the return stack. Next, the moved to destination register fd. The
contents of W are written to PCL; the actual address of the source register is
existing value is discarded. Then, the determined by adding the 7-bit literal
contents of PCLATH and PCLATU are offset zs in the first word to the value of
latched into PCH and PCU, FSR2. The address of the destination
respectively. The second cycle is register is specified by the 12-bit literal
executed as a NOP instruction while the fd in the second word. Both addresses
new next instruction is fetched. can be anywhere in the 4096-byte data
Unlike CALL, there is no option to space (000h to FFFh).
update W, Status or BSR. The MOVSF instruction cannot use the
PCL, TOSU, TOSH or TOSL as the
Words: 1
destination register.
Cycles: 2 If the resultant source address points to
Q Cycle Activity: an indirect addressing register, the
value returned will be 00h.
Q1 Q2 Q3 Q4
Decode Read PUSH PC to No Words: 2
WREG stack operation Cycles: 2
No No No No Q Cycle Activity:
operation operation operation operation
Q1 Q2 Q3 Q4
Decode Determine Determine Read
Example: HERE CALLW source addr source addr source reg
Decode No No Write
Before Instruction
PC = address (HERE) operation operation register f
PCLATH = 10h No dummy (dest)
PCLATU = 00h read
W = 06h
After Instruction
PC = 001006h Example: MOVSF [05h], REG2
TOS = address (HERE + 2)
PCLATH = 10h Before Instruction
PCLATU = 00h FSR2 = 80h
W = 06h
Contents
of 85h = 33h
REG2 = 11h
After Instruction
FSR2 = 80h
Contents
of 85h = 33h
REG2 = 33h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 524


PIC18(L)F26/45/46K40

MOVSS Move Indexed to Indexed PUSHL Store Literal at FSR2, Decrement FSR2
Syntax: MOVSS [zs], [zd] Syntax: PUSHL k
Operands: 0 zs 127 Operands: 0k 255
0 zd 127
Operation: k (FSR2),
Operation: ((FSR2) + zs) ((FSR2) + zd) FSR2 1 FSR2
Status Affected: None
Status Affected: None
Encoding:
Encoding: 1111 1010 kkkk kkkk
1st word (source) 1110 1011 1zzz zzzzs
2nd word (dest.) 1111 xxxx xzzz zzzzd Description: The 8-bit literal k is written to the data
memory address specified by FSR2. FSR2
Description The contents of the source register are
moved to the destination register. The is decremented by 1 after the operation.
addresses of the source and destination This instruction allows users to push values
onto a software stack.
registers are determined by adding the
7-bit literal offsets zs or zd, Words: 1
respectively, to the value of FSR2. Both
Cycles: 1
registers can be located anywhere in
the 4096-byte data memory space Q Cycle Activity:
(000h to FFFh). Q1 Q2 Q3 Q4
The MOVSS instruction cannot use the Decode Read k Process Write to
PCL, TOSU, TOSH or TOSL as the data destination
destination register.
If the resultant source address points to
an indirect addressing register, the Example: PUSHL 08h
value returned will be 00h. If the
resultant destination address points to Before Instruction
an indirect addressing register, the FSR2H:FSR2L = 01ECh
Memory (01ECh) = 00h
instruction will execute as a NOP.
Words: 2 After Instruction
Cycles: 2 FSR2H:FSR2L = 01EBh
Memory (01ECh) = 08h
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Determine Determine Read
source addr source addr source reg
Decode Determine Determine Write
dest addr dest addr to dest reg

Example: MOVSS [05h], [06h]


Before Instruction
FSR2 = 80h
Contents
of 85h = 33h
Contents
of 86h = 11h
After Instruction
FSR2 = 80h
Contents
of 85h = 33h
Contents
of 86h = 33h

2016 Microchip Technology Inc. Preliminary DS40001816C-page 525


PIC18(L)F26/45/46K40

SUBFSR Subtract Literal from FSR SUBULNK Subtract Literal from FSR2 and Return
Syntax: SUBFSR f, k Syntax: SUBULNK k
Operands: 0 k 63 Operands: 0 k 63
f [ 0, 1, 2 ] Operation: FSR2 k FSR2
Operation: FSR(f) k FSRf (TOS) PC
Status Affected: None Status Affected: None
Encoding: 1110 1001 ffkk kkkk Encoding: 1110 1001 11kk kkkk
Description: The 6-bit literal k is subtracted from Description: The 6-bit literal k is subtracted from the
the contents of the FSR specified by contents of the FSR2. A RETURN is then
f. executed by loading the PC with the TOS.
Words: 1 The instruction takes two cycles to
execute; a NOP is performed during the
Cycles: 1
second cycle.
Q Cycle Activity: This may be thought of as a special case of
Q1 Q2 Q3 Q4 the SUBFSR instruction, where f = 3 (binary
Decode Read Process Write to 11); it operates only on FSR2.
register f Data destination Words: 1
Cycles: 2
Q Cycle Activity:
Example: SUBFSR 2, 23h
Before Instruction Q1 Q2 Q3 Q4
FSR2 = 03FFh Decode Read Process Write to
register f Data destination
After Instruction
FSR2 = 03DCh No No No No
Operation Operation Operation Operation

Example: SUBULNK 23h


Before Instruction
FSR2 = 03FFh
PC = 0100h
After Instruction
FSR2 = 03DCh
PC = (TOS)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 526


PIC18(L)F26/45/46K40
35.2.3 BYTE-ORIENTED AND 35.2.3.1 Extended Instruction Syntax with
BIT-ORIENTED INSTRUCTIONS IN Standard PIC18 Commands
INDEXED LITERAL OFFSET MODE When the extended instruction set is enabled, the file
Note: Enabling the PIC18 instruction set register argument, f, in the standard byte-oriented and
extension may cause legacy applications bit-oriented commands is replaced with the literal offset
to behave erratically or fail entirely. value, k. As already noted, this occurs only when f is
less than or equal to 5Fh. When an offset value is used,
In addition to eight new commands in the extended set, it must be indicated by square brackets ([ ]). As with
enabling the extended instruction set also enables the extended instructions, the use of brackets indicates
Indexed Literal Offset Addressing mode (Section to the compiler that the value is to be interpreted as an
10.7.1 Indexed Addressing with Literal Offset). index or an offset. Omitting the brackets, or using a
This has a significant impact on the way that many value greater than 5Fh within brackets, will generate an
commands of the standard PIC18 instruction set are error in the MPASM assembler.
interpreted.
If the index argument is properly bracketed for Indexed
When the extended set is disabled, addresses Literal Offset Addressing, the Access RAM argument is
embedded in opcodes are treated as literal memory never specified; it will automatically be assumed to be
locations: either as a location in the Access Bank (a = 0. This is in contrast to standard operation (extended
0), or in a GPR bank designated by the BSR (a = 1). instruction set disabled) when a is set on the basis of
When the extended instruction set is enabled and a = the target address. Declaring the Access RAM bit in
0, however, a file register argument of 5Fh or less is this mode will also generate an error in the MPASM
interpreted as an offset from the pointer value in FSR2 assembler.
and not as a literal address. For practical purposes, this
The destination argument, d, functions as before.
means that all instructions that use the Access RAM bit
as an argument that is, all byte-oriented and bit- In the latest versions of the MPASM assembler,
oriented instructions, or almost half of the core PIC18 language support for the extended instruction set must
instructions may behave differently when the be explicitly invoked. This is done with either the
extended instruction set is enabled. command line option, /y, or the PE directive in the
source listing.
When the content of FSR2 is 00h, the boundaries of the
Access RAM are essentially remapped to their original
35.2.4 CONSIDERATIONS WHEN
values. This may be useful in creating backward
ENABLING THE EXTENDED
compatible code. If this technique is used, it may be
necessary to save the value of FSR2 and restore it INSTRUCTION SET
when moving back and forth between C and assembly It is important to note that the extensions to the instruc-
routines in order to preserve the Stack Pointer. Users tion set may not be beneficial to all users. In particular,
must also keep in mind the syntax requirements of the users who are not writing code that uses a software
extended instruction set (see Section stack may not benefit from using the extensions to the
35.2.3.1 Extended Instruction Syntax with instruction set.
Standard PIC18 Commands). Additionally, the Indexed Literal Offset Addressing
Although the Indexed Literal Offset Addressing mode mode may create issues with legacy applications
can be very useful for dynamic stack and pointer written to the PIC18 assembler. This is because
manipulation, it can also be very annoying if a simple instructions in the legacy code may attempt to address
arithmetic operation is carried out on the wrong registers in the Access Bank below 5Fh. Since these
register. Users who are accustomed to the PIC18 addresses are interpreted as literal offsets to FSR2
programming must keep in mind that, when the when the instruction set extension is enabled, the
extended instruction set is enabled, register addresses application may read or write to the wrong data
of 5Fh or less are used for Indexed Literal Offset addresses.
Addressing. When porting an application to the PIC18(L)F2x/
Representative examples of typical byte-oriented and 4xK40, it is very important to consider the type of code.
bit-oriented instructions in the Indexed Literal Offset A large, re-entrant application that is written in C and
Addressing mode are provided on the following page to would benefit from efficient compilation will do well
show how execution is affected. The operand condi- when using the instruction set extensions. Legacy
tions shown in the examples are applicable to all applications that heavily use the Access Bank will most
instructions of these types. likely not benefit from using the extended instruction
set.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 527


PIC18(L)F26/45/46K40

ADD W to Indexed Bit Set Indexed


ADDWF BSF
(Indexed Literal Offset mode) (Indexed Literal Offset mode)
Syntax: ADDWF [k] {,d} Syntax: BSF [k], b
Operands: 0 k 95 Operands: 0 f 95
d [0,1] 0b7
Operation: (W) + ((FSR2) + k) dest Operation: 1 ((FSR2) + k)<b>
Status Affected: N, OV, C, DC, Z Status Affected: None
Encoding: 0010 01d0 kkkk kkkk Encoding: 1000 bbb0 kkkk kkkk
Description: The contents of W are added to the Description: Bit b of the register indicated by FSR2,
contents of the register indicated by offset by the value k, is set.
FSR2, offset by the value k.
Words: 1
If d is 0, the result is stored in W. If d
is 1, the result is stored back in Cycles: 1
register f (default). Q Cycle Activity:
Words: 1 Q1 Q2 Q3 Q4
Cycles: 1 Decode Read Process Write to
Q Cycle Activity: register f Data destination
Q1 Q2 Q3 Q4
Example: BSF [FLAG_OFST], 7
Decode Read k Process Write to
Before Instruction
Data destination
FLAG_OFST = 0Ah
FSR2 = 0A00h
Example: ADDWF [OFST] , 0 Contents
of 0A0Ah = 55h
Before Instruction
After Instruction
W = 17h Contents
OFST = 2Ch of 0A0Ah = D5h
FSR2 = 0A00h
Contents
of 0A2Ch = 20h
After Instruction
W = 37h
Contents
Set Indexed
SETF
of 0A2Ch = 20h (Indexed Literal Offset mode)
Syntax: SETF [k]
Operands: 0 k 95
Operation: FFh ((FSR2) + k)
Status Affected: None
Encoding: 0110 1000 kkkk kkkk
Description: The contents of the register indicated by
FSR2, offset by k, are set to FFh.
Words: 1
Cycles: 1
Q Cycle Activity:
Q1 Q2 Q3 Q4
Decode Read k Process Write
Data register

Example: SETF [OFST]


Before Instruction
OFST = 2Ch
FSR2 = 0A00h
Contents
of 0A2Ch = 00h
After Instruction
Contents
of 0A2Ch = FFh

2016 Microchip Technology Inc. Preliminary DS40001816C-page 528


PIC18(L)F26/45/46K40
35.2.5 SPECIAL CONSIDERATIONS WITH
MICROCHIP MPLAB IDE TOOLS
The latest versions of Microchips software tools have
been designed to fully support the extended instruction
set of the PIC18(L)F2x/4xK40 family of devices. This
includes the MPLAB C18 C compiler, MPASM
assembly language and MPLAB Integrated
Development Environment (IDE).
When selecting a target device for software
development, MPLAB IDE will automatically set default
Configuration bits for that device. The default setting for
the XINST Configuration bit is 0, disabling the
extended instruction set and Indexed Literal Offset
Addressing mode. For proper execution of applications
developed to take advantage of the extended
instruction set, XINST must be set during
programming.
To develop software for the extended instruction set,
the user must enable support for the instructions and
the Indexed Addressing mode in their language tool(s).
Depending on the environment being used, this may be
done in several ways:
A menu option, or dialog box within the
environment, that allows the user to configure the
language tool and its settings for the project
A command line option
A directive in the source code
These options vary between different compilers,
assemblers and development environments. Users are
encouraged to review the documentation accompanying
their development systems for the appropriate
information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 529


PIC18(L)F26/45/46K40
36.0 DEVELOPMENT SUPPORT 36.1 MPLAB X Integrated Development
Environment Software
The PIC microcontrollers (MCU) and dsPIC digital
signal controllers (DSC) are supported with a full range The MPLAB X IDE is a single, unified graphical user
of software and hardware development tools: interface for Microchip and third-party software, and
Integrated Development Environment hardware development tool that runs on Windows,
Linux and Mac OS X. Based on the NetBeans IDE,
- MPLAB X IDE Software
MPLAB X IDE is an entirely new IDE with a host of free
Compilers/Assemblers/Linkers software components and plug-ins for high-
- MPLAB XC Compiler performance application development and debugging.
- MPASMTM Assembler Moving between tools and upgrading from software
- MPLINKTM Object Linker/ simulators to hardware debugging and programming
MPLIBTM Object Librarian tools is simple with the seamless user interface.
- MPLAB Assembler/Linker/Librarian for With complete project management, visual call graphs,
Various Device Families a configurable watch window and a feature-rich editor
Simulators that includes code completion and context menus,
- MPLAB X SIM Software Simulator MPLAB X IDE is flexible and friendly enough for new
users. With the ability to support multiple tools on
Emulators
multiple projects with simultaneous debugging, MPLAB
- MPLAB REAL ICE In-Circuit Emulator X IDE is also suitable for the needs of experienced
In-Circuit Debuggers/Programmers users.
- MPLAB ICD 3 Feature-Rich Editor:
- PICkit 3
Color syntax highlighting
Device Programmers
Smart code completion makes suggestions and
- MPLAB PM3 Device Programmer provides hints as you type
Low-Cost Demonstration/Development Boards, Automatic code formatting based on user-defined
Evaluation Kits and Starter Kits rules
Third-party development tools Live parsing
User-Friendly, Customizable Interface:
Fully customizable interface: toolbars, toolbar
buttons, windows, window placement, etc.
Call graph window
Project-Based Workspaces:
Multiple projects
Multiple tools
Multiple configurations
Simultaneous debugging sessions
File History and Bug Tracking:
Local file history feature
Built-in support for Bugzilla issue tracker

2016 Microchip Technology Inc. Preliminary DS40001816C-page 530


PIC18(L)F26/45/46K40
36.2 MPLAB XC Compilers 36.4 MPLINK Object Linker/
The MPLAB XC Compilers are complete ANSI C
MPLIB Object Librarian
compilers for all of Microchips 8, 16, and 32-bit MCU The MPLINK Object Linker combines relocatable
and DSC devices. These compilers provide powerful objects created by the MPASM Assembler. It can link
integration capabilities, superior code optimization and relocatable objects from precompiled libraries, using
ease of use. MPLAB XC Compilers run on Windows, directives from a linker script.
Linux or MAC OS X.
The MPLIB Object Librarian manages the creation and
For easy source level debugging, the compilers provide modification of library files of precompiled code. When
debug information that is optimized to the MPLAB X a routine from a library is called from a source file, only
IDE. the modules that contain that routine will be linked in
The free MPLAB XC Compiler editions support all with the application. This allows large libraries to be
devices and commands, with no time or memory used efficiently in many different applications.
restrictions, and offer sufficient code optimization for The object linker/library features include:
most applications.
Efficient linking of single libraries instead of many
MPLAB XC Compilers include an assembler, linker and smaller files
utilities. The assembler generates relocatable object Enhanced code maintainability by grouping
files that can then be archived or linked with other relo- related modules together
catable object files and archives to create an execut-
Flexible creation of libraries with easy module
able file. MPLAB XC Compiler uses the assembler to
listing, replacement, deletion and extraction
produce its object file. Notable features of the assem-
bler include:
36.5 MPLAB Assembler, Linker and
Support for the entire device instruction set
Librarian for Various Device
Support for fixed-point and floating-point data
Families
Command-line interface
Rich directive set MPLAB Assembler produces relocatable machine
Flexible macro language code from symbolic assembly language for PIC24,
PIC32 and dsPIC DSC devices. MPLAB XC Compiler
MPLAB X IDE compatibility
uses the assembler to produce its object file. The
assembler generates relocatable object files that can
36.3 MPASM Assembler then be archived or linked with other relocatable object
The MPASM Assembler is a full-featured, universal files and archives to create an executable file. Notable
macro assembler for PIC10/12/16/18 MCUs. features of the assembler include:

The MPASM Assembler generates relocatable object Support for the entire device instruction set
files for the MPLINK Object Linker, Intel standard HEX Support for fixed-point and floating-point data
files, MAP files to detail memory usage and symbol Command-line interface
reference, absolute LST files that contain source lines Rich directive set
and generated machine code, and COFF files for Flexible macro language
debugging.
MPLAB X IDE compatibility
The MPASM Assembler features include:
Integration into MPLAB X IDE projects
User-defined macros to streamline
assembly code
Conditional assembly for multipurpose
source files
Directives that allow complete control over the
assembly process

2016 Microchip Technology Inc. Preliminary DS40001816C-page 531


PIC18(L)F26/45/46K40
36.6 MPLAB X SIM Software Simulator 36.8 MPLAB ICD 3 In-Circuit Debugger
The MPLAB X SIM Software Simulator allows code
System
development in a PC-hosted environment by simulat- The MPLAB ICD 3 In-Circuit Debugger System is
ing the PIC MCUs and dsPIC DSCs on an instruction Microchips most cost-effective, high-speed hardware
level. On any given instruction, the data areas can be debugger/programmer for Microchip Flash DSC and
examined or modified and stimuli can be applied from MCU devices. It debugs and programs PIC Flash
a comprehensive stimulus controller. Registers can be microcontrollers and dsPIC DSCs with the powerful,
logged to files for further run-time analysis. The trace yet easy-to-use graphical user interface of the MPLAB
buffer and logic analyzer display extend the power of IDE.
the simulator to record and track program execution,
The MPLAB ICD 3 In-Circuit Debugger probe is
actions on I/O, most peripherals and internal registers.
connected to the design engineers PC using a high-
The MPLAB X SIM Software Simulator fully supports speed USB 2.0 interface and is connected to the target
symbolic debugging using the MPLAB XC Compilers, with a connector compatible with the MPLAB ICD 2 or
and the MPASM and MPLAB Assemblers. The soft- MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3
ware simulator offers the flexibility to develop and supports all MPLAB ICD 2 headers.
debug code outside of the hardware laboratory envi-
ronment, making it an excellent, economical software 36.9 PICkit 3 In-Circuit Debugger/
development tool.
Programmer
36.7 MPLAB REAL ICE In-Circuit The MPLAB PICkit 3 allows debugging and program-
Emulator System ming of PIC and dsPIC Flash microcontrollers at a most
affordable price point using the powerful graphical user
The MPLAB REAL ICE In-Circuit Emulator System is interface of the MPLAB IDE. The MPLAB PICkit 3 is
Microchips next generation high-speed emulator for connected to the design engineers PC using a full-
Microchip Flash DSC and MCU devices. It debugs and speed USB interface and can be connected to the tar-
programs all 8, 16 and 32-bit MCU, and DSC devices get via a Microchip debug (RJ-11) connector (compati-
with the easy-to-use, powerful graphical user interface of ble with MPLAB ICD 3 and MPLAB REAL ICE). The
the MPLAB X IDE. connector uses two device I/O pins and the Reset line
The emulator is connected to the design engineers to implement in-circuit debugging and In-Circuit Serial
PC using a high-speed USB 2.0 interface and is Programming (ICSP).
connected to the target with either a connector
compatible with in-circuit debugger systems (RJ-11) 36.10 MPLAB PM3 Device Programmer
or with the new high-speed, noise tolerant, Low-
Voltage Differential Signal (LVDS) interconnection The MPLAB PM3 Device Programmer is a universal,
(CAT5). CE compliant device programmer with programmable
voltage verification at VDDMIN and VDDMAX for
The emulator is field upgradable through future firmware maximum reliability. It features a large LCD display
downloads in MPLAB X IDE. MPLAB REAL ICE offers (128 x 64) for menus and error messages, and a mod-
significant advantages over competitive emulators ular, detachable socket assembly to support various
including full-speed emulation, run-time variable package types. The ICSP cable assembly is included
watches, trace analysis, complex breakpoints, logic as a standard item. In Stand-Alone mode, the MPLAB
probes, a ruggedized probe interface and long (up to PM3 Device Programmer can read, verify and program
three meters) interconnection cables. PIC devices without a PC connection. It can also set
code protection in this mode. The MPLAB PM3
connects to the host PC via an RS-232 or USB cable.
The MPLAB PM3 has high-speed communications and
optimized algorithms for quick programming of large
memory devices, and incorporates an MMC card for file
storage and data applications.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 532


PIC18(L)F26/45/46K40
36.11 Demonstration/Development 36.12 Third-Party Development Tools
Boards, Evaluation Kits, and Microchip also offers a great collection of tools from
Starter Kits third-party vendors. These tools are carefully selected
A wide variety of demonstration, development and to offer good value and unique functionality.
evaluation boards for various PIC MCUs and dsPIC Device Programmers and Gang Programmers
DSCs allows quick application development on fully from companies, such as SoftLog and CCS
functional systems. Most boards include prototyping Software Tools from companies, such as Gimpel
areas for adding custom circuitry and provide applica- and Trace Systems
tion firmware and source code for examination and Protocol Analyzers from companies, such as
modification. Saleae and Total Phase
The boards support a variety of features, including LEDs, Demonstration Boards from companies, such as
temperature sensors, switches, speakers, RS-232 MikroElektronika, Digilent and Olimex
interfaces, LCD displays, potentiometers and additional Embedded Ethernet Solutions from companies,
EEPROM memory. such as EZ Web Lynx, WIZnet and IPLogika
The demonstration and development boards can be
used in teaching environments, for prototyping custom
circuits and for learning about various microcontroller
applications.
In addition to the PICDEM and dsPICDEM
demonstration/development board series of circuits,
Microchip has a line of evaluation kits and demonstra-
tion software for analog filter design, KEELOQ security
ICs, CAN, IrDA, PowerSmart battery management,
SEEVAL evaluation system, Sigma-Delta ADC, flow
rate sensing, plus many more.
Also available are starter kits that contain everything
needed to experience the specified device. This usually
includes a single application and debug capability, all
on one board.
Check the Microchip web page (www.microchip.com)
for the complete list of demonstration, development
and evaluation kits.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 533


PIC18(L)F26/45/46K40
37.0 ELECTRICAL SPECIFICATIONS
37.1 Absolute Maximum Ratings()
Ambient temperature under bias...................................................................................................... -40C to +125C
Storage temperature ........................................................................................................................ -65C to +150C
Voltage on pins with respect to VSS
on VDD pin
PIC18F26/45/46K40 ................................................................................................. -0.3V to +6.5V
PIC18LF26/45/46K40 ............................................................................................... -0.3V to +4.0V
on MCLR pin ........................................................................................................................... -0.3V to +9.0V
on all other pins ............................................................................................................ -0.3V to (VDD + 0.3V)
Maximum current
on VSS pin(1)
-40C TA +85C .............................................................................................................. 350 mA
85C TA +125C ............................................................................................................. 120 mA
on VDD pin for 28-Pin devices(1)
-40C TA +85C .............................................................................................................. 250 mA
85C TA +125C ............................................................................................................... 85 mA
on VDD pin for 40-Pin devices(1)
-40C TA +85C .............................................................................................................. 350 mA
85C TA +125C ............................................................................................................. 120 mA
on any standard I/O pin ...................................................................................................................... 50 mA
Clamp current, IK (VPIN < 0 or VPIN > VDD) ................................................................................................... 20 mA
Total power dissipation(2)................................................................................................................................ 800 mW

Note 1: Maximum current rating requires even load distribution across I/O pins. Maximum current rating may be
limited by the device package power dissipation characterizations, see Table 37-6 to calculate device
specifications.
2: Power dissipation is calculated as follows:
PDIS = VDD x {IDD - IOH} + VDD - VOH) x IOH} + VOI x IOL

NOTICE: Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the
device. This is a stress rating only and functional operation of the device at those or any other conditions above those
indicated in the operation listings of this specification is not implied. Exposure above maximum rating conditions for
extended periods may affect device reliability.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 534


PIC18(L)F26/45/46K40
37.2 Standard Operating Conditions
The standard operating conditions for any device are defined as:
Operating Voltage: VDDMIN VDD VDDMAX
Operating Temperature: TA_MIN TA TA_MAX
VDD Operating Supply Voltage(1)
PIC18LF26/45/46K40
VDDMIN (Fosc 16 MHz) ......................................................................................................... +1.8V
VDDMIN (Fosc 32 MHz) ......................................................................................................... +2.5V
VDDMIN (Fosc 64 MHz) ......................................................................................................... +3.0V
VDDMAX .................................................................................................................................... +3.6V
PIC18F26/45/46K40
VDDMIN (Fosc 16 MHz) ......................................................................................................... +2.3V
VDDMIN (Fosc 32 MHz) ......................................................................................................... +2.5V
VDDMIN (Fosc 64 MHz) ......................................................................................................... +3.0V
VDDMAX .................................................................................................................................... +5.5V
TA Operating Ambient Temperature Range
Industrial Temperature
TA_MIN ...................................................................................................................................... -40C
TA_MAX .................................................................................................................................... +85C
Extended Temperature
TA_MIN ...................................................................................................................................... -40C
TA_MAX .................................................................................................................................. +125C
Note 1: See Parameter Supply Voltage, DS Characteristics: Supply Voltage.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 535


PIC18(L)F26/45/46K40
FIGURE 37-1: VOLTAGE FREQUENCY GRAPH, -40C TA +125C, PIC18F26/45/46K40 ONLY

5.5

3.0
VDD (V)

2.5

2.3

0 4 10 16 32 64
Frequency (MHz)

Note 1: The shaded region indicates the permissible combinations of voltage and frequency.
2: Refer to Table 37-7 for each Oscillator modes supported frequencies.

FIGURE 37-2: VOLTAGE FREQUENCY GRAPH, -40C TA +125C, PIC18LF26/45/46K40


ONLY

3.6
VDD (V)

3.0

2.5

1.8

0 4 10 16 32 64
Frequency (MHz)

Note 1: The shaded region indicates the permissible combinations of voltage and frequency.
2: Refer to Table 37-7 for each Oscillator modes supported frequencies.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 536


PIC18(L)F26/45/46K40
37.3 DC Characteristics
TABLE 37-1: SUPPLY VOLTAGE
PIC18LF26/45/46K40 Standard Operating Conditions (unless otherwise stated)

PIC18F26/45/46K40

Param.
Sym. Characteristic Min. Typ. Max. Units Conditions
No.
Supply Voltage
D002 VDD 1.8 3.6 V FOSC 16 MHz
2.5 3.6 V FOSC 16 MHz
3.0 3.6 V FOSC 32 MHz
D002 VDD 2.3 5.5 V FOSC 16 MHz
2.5 5.5 V FOSC 16 MHz
3.0 5.5 V FOSC 32 MHz
RAM Data Retention(1)
D003 VDR 1.5 V Device in Sleep mode
D003 VDR 1.7 V Device in Sleep mode
Power-on Reset Release Voltage(2)
D004 VPOR 1.6 V BOR or LPBOR disabled(3)
D004 VPOR 1.6 V BOR or LPBOR disabled(3)
Power-on Reset Rearm Voltage(2)
D005 VPORR 0.8 V BOR or LPBOR disabled(3)
D005 VPORR 1.5 V BOR or LPBOR disabled(3)
VDD Rise Rate to ensure internal Power-on Reset signal(2)
D006 SVDD 0.05 V/ms BOR or LPBOR disabled(3)
D006 SVDD 0.05 V/ms BOR or LPBOR disabled(3)

Data in Typ. column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance
only and are not tested.
Note 1: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.
2: See Figure 37-3, POR and POR REARM with Slow Rising VDD.
3: Please see Table 37-11 for BOR and LPBOR trip point information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 537


PIC18(L)F26/45/46K40
FIGURE 37-3: POR AND POR REARM WITH SLOW RISING VDD

VDD

VPOR
VPORR
SVDD

VSS
NPOR(1)

POR REARM

VSS

TVLOW(3) TPOR(2)

Note 1: When NPOR is low, the device is held in Reset.


2: TPOR 1 s typical.
3: TVLOW 2.7 s typical.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 538


PIC18(L)F26/45/46K40

TABLE 37-2: SUPPLY CURRENT (IDD)(1,2,4)


PIC18LF26/45/46K40 Standard Operating Conditions (unless otherwise stated)

PIC18F26/45/46K40

Param. Conditions
Symbol Device Characteristics Min. Typ. Max. Units
No. VDD Note
D100 IDDXT4 XT = 4 MHz 450 650 A 3.0V
D100 IDDXT4 XT = 4 MHz 550 750 A 3.0V
D100A IDDXT4 XT = 4 MHz 310 A 3.0V PMDs all 1s
D100A IDDXT4 XT = 4 MHz 410 A 3.0V PMDs all 1s
D101 IDDHFO16 HFINTOSC = 16 MHz 1.9 2.6 mA 3.0V
D101 IDDHFO16 HFINTOSC = 16 MHz 2.0 2.7 mA 3.0V
D101A IDDHFO16 HFINTOSC = 16 MHz 1.4 mA 3.0V PMDs all 1s
D101A IDDHFO16 HFINTOSC = 16 MHz 1.5 mA 3.0V PMDs all 1s
D102 IDDHFOPLL HFINTOSC = 64 MHz 7.4 9.4 mA 3.0V
D102 IDDHFOPLL HFINTOSC = 64 MHz 7.5 9.5 mA 3.0V
D102A IDDHFOPLL HFINTOSC = 64 MHz 5.2 mA 3.0V PMDs all 1s
D102A IDDHFOPLL HFINTOSC = 64 MHz 5.3 mA 3.0V PMDs all 1s
D103 IDDHSPLL32 HS+PLL = 64 MHz 6.9 8.9 mA 3.0V
D103 IDDHSPLL32 HS+PLL = 64 MHz 7.0 9.0 mA 3.0V
D103A IDDHSPLL32 HS+PLL = 64 MHz 4.9 mA 3.0V PMDs all 1s
D103A IDDHSPLL32 HS+PLL = 64 MHz 5.0 mA 3.0V PMDs all 1s
D104 IDDIDLE IDLE mode, HFINTOSC = 16 MHz 1.05 mA 3.0V
D104 IDDIDLE IDLE mode, HFINTOSC = 16 MHz 1.15 mA 3.0V
D105 IDDDOZE(3) DOZE mode, HFINTOSC = 16 MHz, Doze Ratio = 16 1.1 mA 3.0V
D105 IDDDOZE(3) DOZE mode, HFINTOSC = 16 MHz, Doze Ratio = 16 1.2 mA 3.0V
Data in Typ. column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not tested.
Note 1: The test conditions for all IDD measurements in active operation mode are: OSC1 = external square wave, from
rail-to-rail; all I/O pins are outputs driven low; MCLR = VDD; WDT disabled.
2: The supply current is mainly a function of the operating voltage and frequency. Other factors, such as I/O pin loading and switch-
ing rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption.
3: IDDDOZE = [IDDIDLE*(N-1)/N] + IDDHFO16/N where N = DOZE Ratio (Register 6-2).
4: PMD bits are all in the default state, no modules are disabled.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 539


PIC18(L)F26/45/46K40

TABLE 37-3: POWER-DOWN CURRENT (IPD)(1,2)


PIC18LF26/45/46K40 Standard Operating Conditions (unless otherwise stated)

Standard Operating Conditions (unless otherwise stated)


PIC18F26/45/46K40
VREGPM = 1

Param. Max. Max. Conditions


Symbol Device Characteristics Min. Typ. Units
No. +85C +125C VDD Note
D200 IPD IPD Base 0.05 2 9 A 3.0V

D200 IPD IPD Base 0.4 4 12 A 3.0V


D200A 20 A 3.0V VREGPM = 0
D201 IPD_WDT Low-Frequency Internal Oscillator/ 0.4 3 10 A 3.0V
WDT
D201 IPD_WDT Low-Frequency Internal Oscillator/ 0.6 5 13 A 3.0V
WDT
D202 IPD_SOSC Secondary Oscillator (SOSC) 0.6 5 13 A 3.0V
D202 IPD_SOSC Secondary Oscillator (SOSC) 0.8 8.5 15 A 3.0V
D203 IPD_FVR FVR 31 A 3.0V FVRCON = 0X81 or 0x84
D203 IPD_FVR FVR 32 A 3.0V FVRCON = 0X81 or 0x84
D204 IPD_BOR Brown-out Reset (BOR) 9 14 18 A 3.0V
D204 IPD_BOR Brown-out Reset (BOR) 14 19 21 A 3.0V
D205 IPD_LPBOR Low-Power Brown-out Reset (LPBOR) 0.5 A 3.0V
D205 IPD_LPBOR Low-Power Brown-out Reset (LPBOR) 0.7 A 3.0V
D206 IPD_HLVD High/Low Voltage Detect (HLVD) 31 A 3.0V
D206 IPD_HLVD High/Low Voltage Detect (HLVD) 32 A 3.0V
D207 IPD_ADCA ADC - Active 250 A 3.0V ADC is converting (4)
D207 IPD_ADCA ADC - Active 280 A 3.0V ADC is converting (4)
D208 IPD_CMP Comparator 25 38 40 A 3.0V
D208 IPD_CMP Comparator 28 50 60 A 3.0V
Data in Typ. column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.
Note 1: The peripheral current is the sum of the base IDD and the additional current consumed when this peripheral is enabled. The
peripheral current can be determined by subtracting the base IDD or IPD current from this limit. Max. values should be used
when calculating total current consumption.
2: The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part
in Sleep mode with all I/O pins in high-impedance state and tied to VSS.
3: All peripheral currents listed are on a per-peripheral basis if more than one instance of a peripheral is available.
4: ADC clock source is FRC.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 540


PIC18(L)F26/45/46K40

TABLE 37-4: I/O PORTS


Standard Operating Conditions (unless otherwise stated)
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
VIL Input Low Voltage
I/O PORT:
D300 with TTL buffer 0.8 V 4.5V VDD 5.5V
D301 0.15 VDD V 1.8V VDD 4.5V
D302 with Schmitt Trigger buffer 0.2 VDD V 2.0V VDD 5.5V
D303 with I2C levels 0.3 VDD V
D304 with SMBus levels 0.8 V 2.7V VDD 5.5V
D305 MCLR 0.2 VDD V
VIH Input High Voltage
I/O PORT:
D320 with TTL buffer 2.0 V 4.5V VDD 5.5V
D321 0.25 VDD + V 1.8V VDD 4.5V
0.8
D322 with Schmitt Trigger buffer 0.8 VDD V 2.0V VDD 5.5V
D323 with I2C levels 0.7 VDD V
D324 with SMBus levels 2.1 V 2.7V VDD 5.5V
D325 MCLR 0.7 VDD V
IIL Input Leakage Current(1)
D340 I/O Ports 5 125 nA VSS VPIN VDD,
Pin at high-impedance, 85C
D341 5 1000 nA VSS VPIN VDD,
Pin at high-impedance, 125C
D342 MCLR(2) 50 200 nA VSS VPIN VDD,
Pin at high-impedance, 85C
IPUR Weak Pull-up Current
D350 25 120 200 A VDD = 3.0V, VPIN = VSS
VOL Output Low Voltage
D360 I/O ports 0.6 V IOL = 10.0mA, VDD = 3.0V
VOH Output High Voltage
D370 I/O ports VDD - 0.7 V IOH = 6.0 mA, VDD = 3.0V
D380 CIO All I/O pins 5 50 pF
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are
not tested.
Note 1: Negative current is defined as current sourced by the pin.
2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent
normal operating conditions. Higher leakage current may be measured at different input voltages.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 541


PIC18(L)F26/45/46K40

TABLE 37-5: MEMORY PROGRAMMING SPECIFICATIONS


Standard Operating Conditions (unless otherwise stated)
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
Data EEPROM Memory Specifications
MEM20 ED DataEE Byte Endurance 100k E/W -40C TA +85C
MEM21 TD_RET Characteristic Retention Provided no other
40 Year
specifications are violated
MEM22 ND_REF Total Erase/Write Cycles before 1M 10M -40C TA +60C
E/W
Refresh 500k -40C TA +85C
MEM23 VD_RW VDD for Read or Erase/Write
VDDMIN VDDMAX V
operation
MEM24 TD_BEW Byte Erase and Write Cycle Time 4.0 5.0 ms
Program Flash Memory Specifications
MEM30 EP Flash Memory Cell Endurance -40C TA +85C
10k E/W
(Note 1)
MEM32 TP_RET Characteristic Retention Provided no other
40 Year specifications are violated

MEM33 VP_RD VDD for Read operation VDDMIN VDDMAX V


MEM34 VP_REW VDD for Row Erase or Write
VDDMIN VDDMAX V
operation
MEM35 TP_REW Self-Timed Row Erase or Self-Timed
2.0 2.5 ms
Write
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are
not tested.
Note 1: Flash Memory Cell Endurance for the Flash memory is defined as: One Row Erase operation and one Self-Timed
Write.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 542


PIC18(L)F26/45/46K40
TABLE 37-6: THERMAL CHARACTERISTICS
Standard Operating Conditions (unless otherwise stated)
Param
Sym. Characteristic Typ. Units Conditions
No.

TH01 JA Thermal Resistance Junction to Ambient 60 C/W 28-pin SPDIP package


80 C/W 28-pin SOIC package
90 C/W 28-pin SSOP package
27.5 C/W 28-pin UQFN 4x4 mm package
27.5 C/W 28-pin QFN 6x6mm package
47.2 C/W 40-pin PDIP package
46 C/W 44-pin TQFP package
24.4 C/W 44-pin QFN 8x8mm package
TH02 JC Thermal Resistance Junction to Case 31.4 C/W 28-pin SPDIP package
24 C/W 28-pin SOIC package
24 C/W 28-pin SSOP package
24 C/W 28-pin UQFN 4x4mm package
24 C/W 28-pin QFN 6x6mm package
24.7 C/W 40-pin PDIP package
14.5 C/W 44-pin TQFP package
20 C/W 44-pin QFN 8x8mm package
TH03 TJMAX Maximum Junction Temperature 150 C
TH04 PD Power Dissipation W PD = PINTERNAL + PI/O(3)
TH05 PINTERNAL Internal Power Dissipation W PINTERNAL = IDD x VDD(1)
TH06 PI/O I/O Power Dissipation W PI/O = (IOL * VOL) + (IOH * (VDD - VOH))
TH07 PDER Derated Power W PDER = PDMAX (TJ - TA)/JA(2)
Note 1: IDD is current to run the chip alone without driving any load on the output pins.
2: TA = Ambient Temperature, TJ = Junction Temperature
3: See absolute maximum ratings for total power dissipation.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 543


PIC18(L)F26/45/46K40
37.4 AC Characteristics

FIGURE 37-4: LOAD CONDITIONS

Rev. 10-000133A
8/1/2013

Load Condition

Pin

CL

VSS

Legend: CL=50 pF for all pins

2016 Microchip Technology Inc. Preliminary DS40001816C-page 544


PIC18(L)F26/45/46K40
FIGURE 37-5: CLOCK TIMING
Q4 Q1 Q2 Q3 Q4 Q1

CLKIN
OS1 OS2 OS2

OS20

CLKOUT
(CLKOUT Mode)

Note 1: See Table 37-7.

TABLE 37-7: EXTERNAL CLOCK/OSCILLATOR TIMING REQUIREMENTS


Standard Operating Conditions (unless otherwise stated)

Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
ECL Oscillator
OS1 FECL Clock Frequency 500 kHz
OS2 TECL_DC Clock Duty Cycle 40 60 %
ECM Oscillator
OS3 FECM Clock Frequency 4 MHz
OS4 TECM_DC Clock Duty Cycle 40 60 %
ECH Oscillator
OS5 FECH Clock Frequency 32 MHz
OS6 TECH_DC Clock Duty Cycle 40 60 %
LP Oscillator
OS7 FLP Clock Frequency 100 kHz Note 4
XT Oscillator
OS8 FXT Clock Frequency 4 MHz Note 4
HS Oscillator
OS9 FHS Clock Frequency 20 MHz Note 4
Secondary Oscillator
OS10 FSEC Clock Frequency 32.4 32.768 33.1 kHz
System Oscillator
OS20 FOSC System Clock Frequency 64 MHz (Note 2, Note 3)
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are
not tested.
Note 1: Instruction cycle period (TCY) equals four times the input oscillator time base period. All specified values are based on
characterization data for that particular oscillator type under standard operating conditions with the device executing
code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected
current consumption. All devices are tested to operate at min values with an external clock applied to OSC1 pin.
When an external clock input is used, the max cycle time limit is DC (no clock) for all devices.
2: The system clock frequency (FOSC) is selected by the main clock switch controls as described in Section 6.0 Power-
Saving Operation Modes.
3: The system clock frequency (FOSC) must meet the voltage requirements defined in the Section 37.2 Standard
Operating Conditions.
4: LP, XT and HS oscillator modes require an appropriate crystal or resonator to be connected to the device. For clocking
the device with the external square wave, one of the EC mode selections must be used.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 545


PIC18(L)F26/45/46K40
TABLE 37-7: EXTERNAL CLOCK/OSCILLATOR TIMING REQUIREMENTS (CONTINUED)
Standard Operating Conditions (unless otherwise stated)

Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
OS21 FCY Instruction Frequency FOSC/4 MHz
OS22 TCY Instruction Period 62.5 1/FCY ns
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are
not tested.
Note 1: Instruction cycle period (TCY) equals four times the input oscillator time base period. All specified values are based on
characterization data for that particular oscillator type under standard operating conditions with the device executing
code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected
current consumption. All devices are tested to operate at min values with an external clock applied to OSC1 pin.
When an external clock input is used, the max cycle time limit is DC (no clock) for all devices.
2: The system clock frequency (FOSC) is selected by the main clock switch controls as described in Section 6.0 Power-
Saving Operation Modes.
3: The system clock frequency (FOSC) must meet the voltage requirements defined in the Section 37.2 Standard
Operating Conditions.
4: LP, XT and HS oscillator modes require an appropriate crystal or resonator to be connected to the device. For clocking
the device with the external square wave, one of the EC mode selections must be used.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 546


PIC18(L)F26/45/46K40
TABLE 37-8: INTERNAL OSCILLATOR PARAMETERS(1)
Standard Operating Conditions (unless otherwise stated)

Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
OS50 FHFOSC Precision Calibrated HFINTOSC 4 MHz (Note 2)
Frequency 8
12
16
32
64
OS51 FHFOSCLP Low-Power Optimized HFINTOSC 1 MHz
Frequency 2 MHz
OS52 FMFOSC Internal Calibrated MFINTOSC 500 kHz
Frequency
OS53* FLFOSC Internal LFINTOSC Frequency 31 kHz
OS54* THFOSCST HFINTOSC 11 20 s VREGPM = 0
Wake-up from Sleep Start-up 50 s VREGPM = 1
Time
OS56 TLFOSCST LFINTOSC 0.2 ms
Wake-up from Sleep Start-up Time
*These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance
only and are not tested.
Note 1: To ensure these oscillator frequency tolerances, VDD and VSS must be capacitively decoupled as close to
the device as possible. 0.1 F and 0.01 F values in parallel are recommended.
2: See Figure 37-6: Precision Calibrated HFINTOSC Frequency Accuracy Over Device VDD and Tempera-
ture.

FIGURE 37-6: PRECISION CALIBRATED HFINTOSC FREQUENCY ACCURACY OVER DEVICE


VDD AND TEMPERATURE

125

5%

85

3%
Temperature (C)

60

2%

0
5%

-40
1.8 2.0 2.3 3.0 3.5 4.0 4.5 5.0 5.5

VDD (V)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 547


PIC18(L)F26/45/46K40
TABLE 37-9: PLL SPECIFICATIONS
Standard Operating Conditions (unless otherwise stated) VDD 2.5V
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
PLL01 FPLLIN PLL Input Frequency Range 4 16 MHz
PLL02 FPLLOUT PLL Output Frequency Range 16 64 MHz Note 1
PLL03 TPLLST PLL Lock Time from Start-up 200 s
PLL04 FPLLJIT PLL Output Frequency Stability (Jitter) -0.25 0.25 %
* These parameters are characterized but not tested.
Data in Typ column is at 5V, 25C unless otherwise stated. These parameters are for design guidance
only and are not tested.
Note 1: The output frequency of the PLL must meet the FOSC requirements listed in Parameter D002.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 548


PIC18(L)F26/45/46K40
FIGURE 37-7: CLKOUT AND I/O TIMING

Cycle Write Fetch Read Execute


Q4 Q1 Q2 Q3
FOSC
IO1 IO2
IO10
CLKOUT
IO8 IO4 IO7
IO5
I/O pin
(Input)
IO3
I/O pin Old Value New Value
(Output)
IO7, IO8

TABLE 37-10: I/O AND CLKOUT TIMING SPECIFICATIONS


Standard Operating Conditions (unless otherwise stated)
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
IO1* TCLKOUTH CLKOUT rising edge delay (rising edge 70 ns
Fosc (Q1 cycle) to falling edge CLKOUT
IO2* TCLKOUTL CLKOUT falling edge delay (rising edge 72 ns
Fosc (Q3 cycle) to rising edge CLKOUT
IO3* TIO_VALID Port output valid time (rising edge Fosc 50 70 ns
(Q1 cycle) to port valid)
IO4* TIO_SETUP Port input setup time (Setup time before 20 ns
rising edge Fosc Q2 cycle)
IO5* TIO_HOLD Port input hold time (Hold time after rising 50 ns
edge Fosc Q2 cycle)
IO6* TIOR_SLREN Port I/O rise time, slew rate enabled 25 ns VDD = 3.0V
IO7* TIOR_SLRDIS Port I/O rise time, slew rate disabled 5 ns VDD = 3.0V
IO8* TIOF_SLREN Port I/O fall time, slew rate enabled 25 ns VDD = 3.0V
IO9* TIOF_SLRDIS Port I/O fall time, slew rate disabled 5 ns VDD = 3.0V
IO10* TINT INT pin high or low time to trigger an 25 ns
interrupt

IO11* TIOC Interrupt-on-Change minimum high or low 25 ns


time to trigger interrupt
*These parameters are characterized but not tested.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 549


PIC18(L)F26/45/46K40
FIGURE 37-8: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP
TIMER TIMING

VDD

MCLR

RST01
Internal
POR

RST04
PWRT
Time-out RST05
OSC
Start-up Time

Internal Reset(1)

Watchdog Timer
Reset(1)
RST03
RST02
RST02
I/O pins

Note 1: Asserted low.

FIGURE 37-9: BROWN-OUT RESET TIMING AND CHARACTERISTICS

VDD
VBOR and VHYST
VBOR

(Device in Brown-out Reset) (Device not in Brown-out Reset)

RST08

Reset
RST04(1)
(due to BOR)

Note 1: Only if PWRTE bit in the Configuration Word register is programmed to 1; 2 ms delay if
PWRTE = 0.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 550


PIC18(L)F26/45/46K40
TABLE 37-11: RESET, WDT, OSCILLATOR START-UP TIMER, POWER-UP TIMER, BROWN-OUT
RESET AND LOW-POWER BROWN-OUT RESET SPECIFICATIONS
Standard Operating Conditions (unless otherwise stated)

Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.

RST01* TMCLR MCLR Pulse Width Low to ensure Reset 2 s


RST02* TIOZ I/O high-impedance from Reset detection 2 s
RST03 TWDT Watchdog Timer Time-out Period 16 ms 1:512 Prescaler
RST04* TPWRT Power-up Timer Period 65 ms
RST05 TOST Oscillator Start-up Timer Period(1,2) 1024 TOSC
RST06 VBOR Brown-out Reset Voltage(4) 2.7 2.85 3.0 V BORV = 00
2.55 2.7 2.85 V BORV = 01
2.3 2.45 2.6 V BORV = 10
2.3 2.45 2.6 V BORV = 11 (PIC18Fxxx)
1.8 1.9 2.05 V BORV = 11 (PIC18LFxxx)
RST07 VBORHYS Brown-out Reset Hysteresis 40 mV
RST08 TBORDC Brown-out Reset Response Time 3 s
RST09 VLPBOR Low-Power Brown-out Reset Voltage 1.8 1.9 2.2 V
*These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.
Note 1: By design, the Oscillator Start-up Timer (OST) counts the first 1024 cycles, independent of frequency.
2: To ensure these voltage tolerances, VDD and VSS must be capacitively decoupled as close to the device as possible.
0.1 F and 0.01 F values in parallel are recommended.

TABLE 37-12: HIGH/LOW-VOLTAGE DETECT CHARACTERISTICS


Standard Operating Conditions (unless otherwise stated)
Param. No. Symbol Characteristic Min. Typ Max. Units Conditions
HLVD01 VDET Voltage Detection 1.90 V HLVDSEL<3:0>=0000
2.10 V HLVDSEL<3:0>=0001
2.25 V HLVDSEL<3:0>=0010
2.50 V HLVDSEL<3:0>=0011
2.60 V HLVDSEL<3:0>=0100
2.75 V HLVDSEL<3:0>=0101
2.90 V HLVDSEL<3:0>=0110
3.15 V HLVDSEL<3:0>=0111
3.35 V HLVDSEL<3:0>=1000
3.60 V HLVDSEL<3:0>=1001
3.75 V HLVDSEL<3:0>=1010
4.00 V HLVDSEL<3:0>=1011
4.20 V HLVDSEL<3:0>=1100
4.35 V HLVDSEL<3:0>=1101
4.65 V HLVDSEL<3:0>=1110

2016 Microchip Technology Inc. Preliminary DS40001816C-page 551


PIC18(L)F26/45/46K40
TABLE 37-13: ANALOG-TO-DIGITAL CONVERTER (ADC) ACCURACY SPECIFICATIONS(1,2):
Operating Conditions (unless otherwise stated)
VDD = 3.0V, TA = 25C, TAD = 1s
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
AD01 NR Resolution 10 bit
AD02 EIL Integral Error 0.1 1.0 LSb ADCREF+ = 3.0V, ADCREF-= 0V
AD03 EDL Differential Error 0.1 1.0 LSb ADCREF+ = 3.0V, ADCREF-= 0V
AD04 EOFF Offset Error 0.5 2.0 LSb ADCREF+ = 3.0V, ADCREF-= 0V
AD05 EGN Gain Error 0.2 1.0 LSb ADCREF+ = 3.0V, ADCREF-= 0V
AD06 VADREF ADC Reference Voltage 1.8 VDD V
(ADREF+ - ADREF-)
AD07 VAIN Full-Scale Range ADREF- ADREF+ V
AD08 ZAIN Recommended Impedance of 10 k
Analog Voltage Source
AD09 RVREF ADC Voltage Reference Ladder 50 k Note 3
Impedance
*These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.
Note 1: Total Absolute Error is the sum of the offset, gain and integral non-linearity (INL) errors.
2: The ADC conversion result never decreases with an increase in the input and has no missing codes.
3: This is the impedance seen by the VREF pads when the external reference pads are selected.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 552


PIC18(L)F26/45/46K40
TABLE 37-14: ANALOG-TO-DIGITAL CONVERTER (ADC) CONVERSION TIMING SPECIFICATIONS
Standard Operating Conditions (unless otherwise stated)

Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
AD20 TAD ADC Clock Period 1 9 s Using FOSC as the ADC clock
source ADOCS = 0
AD21 2 s Using FRC as the ADC clock
source ADOCS = 1
AD22 TCNV Conversion Time(1) 11 + 3TCY TAD Set of GO/DONE bit to Clear of GO/
DONE bit
AD23 TACQ Acquisition Time 2 s
AD24 THCD Sample and Hold Capacitor s FOSC-based clock source
Disconnect Time FRC-based clock source
*
These parameters are characterized but not tested.

Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.
Note 1: Does not apply for the ADCRC oscillator.

FIGURE 37-10: ADC CONVERSION TIMING (ADC CLOCK FOSC-BASED)

BSF ADCON0, GO
1 TCY
AD133
AD131
Q4
AD130

ADC_clk

ADC Data 9 8 7 6 3 2 1 0

ADRES OLD_DATA NEW_DATA

ADIF 1 TCY

GO DONE

AD132 Sampling Stopped


Sample

2016 Microchip Technology Inc. Preliminary DS40001816C-page 553


PIC18(L)F26/45/46K40
FIGURE 37-11: ADC CONVERSION TIMING (ADC CLOCK FROM ADCRC)

BSF ADCON0, GO
AD133 1 TCY
AD131
Q4
AD130
ADC_clk

ADC Data 9 8 7 6 3 2 1 0

ADRES OLD_DATA NEW_DATA

ADIF 1 TCY

GO DONE

AD132 Sampling Stopped


Sample

Note 1: If the ADC clock source is selected as ADCRC, a time of TCY is added before the ADC clock starts. This allows the
SLEEP instruction to be executed.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 554


PIC18(L)F26/45/46K40
TABLE 37-15: COMPARATOR SPECIFICATIONS
Operating Conditions (unless otherwise stated)
VDD = 3.0V, TA = 25C

Param
Sym. Characteristics Min. Typ. Max. Units Comments
No.
CM01 VIOFF Input Offset Voltage 30 mV VICM = VDD/2
CM02 VICM Input Common Mode Range GND VDD V
CM03 CMRR Common Mode Input Rejection Ratio 50 dB
CM04 VHYST Comparator Hysteresis 15 25 35 mV
CM05 TRESP(1) Response Time, Rising Edge 300 600 ns
Response Time, Falling Edge 220 500 ns
* These parameters are characterized but not tested.
Note 1: Response time measured with one comparator input at VDD/2, while the other input transitions from VSS to VDD.
2: A mode change includes changing any of the control register values, including module enable.

TABLE 37-16: 5-BIT DAC SPECIFICATIONS


Standard Operating Conditions (unless otherwise stated)
VDD = 3.0V, TA = 25C

Param
Sym. Characteristics Min. Typ. Max. Units Comments
No.

DSB01 VLSB Step Size (VDACREF+ -VDACREF-) / V


32
DSB01 VACC Absolute Accuracy 0.5 LSb
DSB03* RUNIT Unit Resistor Value 5000
DSB04* TST Settling Time(1) 10 s
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not tested.
Note 1: Settling time measured while DACR<4:0> transitions from 00000 to 01111.

TABLE 37-17: FIXED VOLTAGE REFERENCE (FVR) SPECIFICATIONS


Standard Operating Conditions (unless otherwise stated)

Param.
Symbol Characteristic Min. Typ. Max. Units Conditions
No.
FVR01 VFVR1 1x Gain (1.024V) -4 +4 % VDD 2.5V, -40C to 85C
FVR02 VFVR2 2x Gain (2.048V) -4 +4 % VDD 2.5V, -40C to 85C
FVR03 VFVR4 4x Gain (4.096V) -5 +5 % VDD 4.75V, -40C to 85C
FVR04 TFVRST FVR Start-up Time 25 us

TABLE 37-18: ZERO CROSS DETECT (ZCD) SPECIFICATIONS


Standard Operating Conditions (unless otherwise stated)
VDD = 3.0V, TA = 25C

Param.
Sym. Characteristics Min Typ Max Units Comments
No.
ZC01 VPINZC Voltage on Zero Cross Pin 0.75 V
ZC02 IZCD_MAX Maximum source or sink current 600 A
ZC03 TRESPH Response Time, Rising Edge 1 s
TRESPL Response Time, Falling Edge 1 s
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not tested.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 555


PIC18(L)F26/45/46K40
FIGURE 37-12: TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS

T0CKI

40 41

42

T1CKI
45 46

47 49

TMR0 or
TMR1

TABLE 37-19: TIMER0 AND TIMER1 EXTERNAL CLOCK REQUIREMENTS


Standard Operating Conditions (unless otherwise stated)
Operating Temperature -40C TA +125C
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
40* TT0H T0CKI High Pulse Width No Prescaler 0.5 TCY + 20 ns
With Prescaler 10 ns
41* TT0L T0CKI Low Pulse Width No Prescaler 0.5 TCY + 20 ns
With Prescaler 10 ns
42* TT0P T0CKI Period Greater of: ns N = prescale value
20 or TCY + 40
N
45* TT1H T1CKI High Synchronous, No Prescaler 0.5 TCY + 20 ns
Time Synchronous, with Prescaler 15 ns
Asynchronous 30 ns
46* TT1L T1CKI Low Synchronous, No Prescaler 0.5 TCY + 20 ns
Time Synchronous, with Prescaler 15 ns
Asynchronous 30 ns
47* TT1P T1CKI Input Synchronous Greater of: ns N = prescale value
Period 30 or TCY + 40
N
Asynchronous 60 ns
49* TCKEZTMR1 Delay from External Clock Edge to Timer 2 TOSC 7 TOSC Timers in Sync
Increment mode
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 556


PIC18(L)F26/45/46K40
FIGURE 37-13: CAPTURE/COMPARE/PWM TIMINGS (CCP)
CCPx
(Capture mode)

CC01 CC02

CC03

Note: Refer to Figure 37-4 for load conditions.

TABLE 37-20: CAPTURE/COMPARE/PWM REQUIREMENTS (CCP)


Standard Operating Conditions (unless otherwise stated)
Operating Temperature -40C TA +125C
Param
Sym. Characteristic Min. Typ Max. Units Conditions
No.
CC01* TccL CCPx Input Low Time No Prescaler 0.5TCY + 20 ns
With Prescaler 20 ns
CC02* TccH CCPx Input High Time No Prescaler 0.5TCY + 20 ns
With Prescaler 20 ns
CC03* TccP CCPx Input Period 3TCY + 40 ns N = prescale value
N
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance only and are not
tested.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 557


PIC18(L)F26/45/46K40
FIGURE 37-14: EUSART SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING

CK
US121 US121

DT

US120 US122

Note: Refer to Figure 37-4 for load conditions.

TABLE 37-21: EUSART SYNCHRONOUS TRANSMISSION REQUIREMENTS


Standard Operating Conditions (unless otherwise stated)

Param.
Symbol Characteristic Min. Max. Units Conditions
No.
US120 TCKH2DTV SYNC XMIT (Master and Slave) 80 ns 3.0V VDD 5.5V
Clock high to data-out valid 100 ns 1.8V VDD 5.5V
US121 TCKRF Clock out rise time and fall time 45 ns 3.0V VDD 5.5V
(Master mode) 50 ns 1.8V VDD 5.5V
US122 TDTRF Data-out rise time and fall time 45 ns 3.0V VDD 5.5V
50 ns 1.8V VDD 5.5V

FIGURE 37-15: EUSART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING

CK
US125

DT
US126

Note: Refer to Figure 37-4 for load conditions.

TABLE 37-22: EUSART SYNCHRONOUS RECEIVE REQUIREMENTS


Standard Operating Conditions (unless otherwise stated)

Param.
Symbol Characteristic Min. Max. Units Conditions
No.
US125 TDTV2CKL SYNC RCV (Master and Slave)
Data-setup before CK (DT hold time) 10 ns
US126 TCKL2DTL Data-hold after CK (DT hold time) 15 ns

2016 Microchip Technology Inc. Preliminary DS40001816C-page 558


PIC18(L)F26/45/46K40
FIGURE 37-16: SPI MASTER MODE TIMING (CKE = 0, SMP = 0)

SS
SP81
SCK
(CKP = 0)
SP71 SP72
SP78 SP79

SCK
(CKP = 1)

SP79 SP78
SP80

SDO MSb bit 6 - - - - - -1 LSb

SP75, SP76

SDI MSb In bit 6 - - - -1 LSb In

SP74
SP73

Note: Refer to Figure 37-4 for load conditions.

FIGURE 37-17: SPI MASTER MODE TIMING (CKE = 1, SMP = 1)

SS

SP81
SCK
(CKP = 0)
SP71 SP72
SP79
SP73
SCK
(CKP = 1)

SP80
SP78

SDO MSb bit 6 - - - - - -1 LSb

SP75, SP76

SDI MSb In bit 6 - - - -1 LSb In

SP74

Note: Refer to Figure 37-4 for load conditions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 559


PIC18(L)F26/45/46K40
FIGURE 37-18: SPI SLAVE MODE TIMING (CKE = 0)

SS

SP70

SCK SP83
(CKP = 0)
SP71 SP72
SP78 SP79

SCK
(CKP = 1)

SP79 SP78
SP80

SDO MSb bit 6 - - - - - -1 LSb

SP75, SP76 SP77

SDI MSb In bit 6 - - - -1 LSb In

SP74

SP73

Note: Refer to Figure 37-4 for load conditions.

FIGURE 37-19: SPI SLAVE MODE TIMING (CKE = 1)

SP82
SS

SP70
SCK SP83
(CKP = 0)

SP71 SP72

SCK
(CKP = 1)

SP80

SDO MSb bit 6 - - - - - -1 LSb

SP77
SP75, SP76

SDI
MSb In bit 6 - - - -1 LSb In

SP74

Note: Refer to Figure 37-4 for load conditions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 560


PIC18(L)F26/45/46K40
TABLE 37-23: SPI MODE REQUIREMENTS
Standard Operating Conditions (unless otherwise stated)

Param
Symbol Characteristic Min. Typ Max. Units Conditions
No.

SP70* TSSL2SCH, SS to SCK or SCK input 2.25*TCY ns


TSSL2SCL
SP71* TSCH SCK input high time (Slave mode) TCY + 20 ns
SP72* TSCL SCK input low time (Slave mode) TCY + 20 ns
SP73* TDIV2SCH, Setup time of SDI data input to SCK 100 ns
TDIV2SCL edge
SP74* TSCH2DIL, Hold time of SDI data input to SCK edge 100 ns
TSCL2DIL
SP75* TDOR SDO data output rise time 10 25 ns 3.0V VDD 5.5V
25 50 ns 1.8V VDD 5.5V
SP76* TDOF SDO data output fall time 10 25 ns
SP77* TSSH2DOZ SS to SDO output high-impedance 10 50 ns
SP78* TSCR SCK output rise time 10 25 ns 3.0V VDD 5.5V
(Master mode) 25 50 ns 1.8V VDD 5.5V
SP79* TSCF SCK output fall time (Master mode) 10 25 ns
SP80* TSCH2DOV, SDO data output valid after SCK edge 50 ns 3.0V VDD 5.5V
TSCL2DOV 145 ns 1.8V VDD 5.5V
SP81* TDOV2SCH, SDO data output setup to SCK edge 1 Tcy ns
TDOV2SCL
SP82* TSSL2DOV SDO data output valid after SS edge 50 ns
SP83* TSCH2SSH, SS after SCK edge 1.5 TCY + 40 ns
TSCL2SSH
* These parameters are characterized but not tested.
Data in Typ column is at 3.0V, 25C unless otherwise stated. These parameters are for design guidance
only and are not tested.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 561


PIC18(L)F26/45/46K40
FIGURE 37-20: I2C BUS START/STOP BITS TIMING

SCL
SP91 SP93
SP90 SP92

SDA

Start Stop
Condition Condition

Note: Refer to Figure 37-4 for load conditions.

TABLE 37-24: I2C BUS START/STOP BITS REQUIREMENTS


Standard Operating Conditions (unless otherwise stated)

Param
Symbol Characteristic Min. Typ Max. Units Conditions
No.

SP90* TSU:STA Start condition 100 kHz mode 4700 ns Only relevant for Repeated Start
Setup time 400 kHz mode 600 condition
SP91* THD:STA Start condition 100 kHz mode 4000 ns After this period, the first clock
Hold time 400 kHz mode 600 pulse is generated

SP92* TSU:STO Stop condition 100 kHz mode 4700 ns


Setup time 400 kHz mode 600
SP93 THD:STO Stop condition 100 kHz mode 4000 ns
Hold time 400 kHz mode 600
* These parameters are characterized but not tested.

FIGURE 37-21: I2C BUS DATA TIMING

SP103 SP100 SP102


SP101

SCL
SP90
SP106
SP107
SP91 SP92
SDA
In
SP110
SP109
SP109
SDA
Out

Note: Refer to Figure 37-4 for load conditions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 562


PIC18(L)F26/45/46K40
TABLE 37-25: I2C BUS DATA REQUIREMENTS
Standard Operating Conditions (unless otherwise stated)

Param.
Symbol Characteristic Min. Max. Units Conditions
No.
SP100* THIGH Clock high time 100 kHz mode 4.0 s Device must operate at a
minimum of 1.5 MHz
400 kHz mode 0.6 s Device must operate at a
minimum of 10 MHz
SSP module 1.5TCY
SP101* TLOW Clock low time 100 kHz mode 4.7 s Device must operate at a
minimum of 1.5 MHz
400 kHz mode 1.3 s Device must operate at a
minimum of 10 MHz
SSP module 1.5TCY
SP102* TR SDA and SCL rise 100 kHz mode 1000 ns
time 400 kHz mode 20 + 0.1CB 300 ns CB is specified to be from
10-400 pF
SP103* TF SDA and SCL fall time 100 kHz mode 250 ns
400 kHz mode 20 + 0.1CB 250 ns CB is specified to be from
10-400 pF
SP106* THD:DAT Data input hold time 100 kHz mode 0 ns
400 kHz mode 0 0.9 s
SP107* TSU:DAT Data input setup time 100 kHz mode 250 ns (Note 2)
400 kHz mode 100 ns
SP109* TAA Output valid from 100 kHz mode 3500 ns (Note 1)
clock 400 kHz mode ns
SP110* TBUF Bus free time 100 kHz mode 4.7 s Time the bus must be free
400 kHz mode 1.3 s before a new transmission
can start
SP111 CB Bus capacitive loading 400 pF
* These parameters are characterized but not tested.
Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns)
of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.
2: A Fast mode (400 kHz) I2C bus device can be used in a Standard mode (100 kHz) I2C bus system, but the requirement
TSU:DAT 250 ns must then be met. This will automatically be the case if the device does not stretch the low period of
the SCL signal. If such a device does stretch the low period of the SCL signal, it must output the next data bit to the SDA
line TR max. + TSU:DAT = 1000 + 250 = 1250 ns (according to the Standard mode I2C bus specification), before the SCL
line is released.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 563


PIC18(L)F26/45/46K40
38.0 DC AND AC
CHARACTERISTICS GRAPHS
AND TABLES
Graphs and tables are not available at this time.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 564


PIC18(L)F26/45/46K40
39.0 PACKAGING INFORMATION
Package Marking Information

28-Lead SPDIP (.300) Example

PIC18F26K40
/SP e3
1526017

28-Lead SOIC (7.50 mm) Example

XXXXXXXXXXXXXXXXXXXX PIC18F26K40
XXXXXXXXXXXXXXXXXXXX /SO e3
XXXXXXXXXXXXXXXXXXXX 1526017
YYWWNNN

28-Lead SSOP (5.30 mm) Example

PIC18F26K40
/SS e3
1526017

Legend: XX...X Customer-specific information or Microchip part number


Y Year code (last digit of calendar year)
YY Year code (last 2 digits of calendar year)
WW Week code (week of January 1 is week 01)
NNN Alphanumeric traceability code
e3 Pb-free JEDEC designator for Matte Tin (Sn)
* This package is Pb-free. The Pb-free JEDEC designator ( e3 )
can be found on the outer packaging for this package.

Note: In the event the full Microchip part number cannot be marked on one line, it will
be carried over to the next line, thus limiting the number of available
characters for customer-specific information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 565


PIC18(L)F26/45/46K40
Package Marking Information (Continued)

28-Lead QFN (6x6 mm) Example

PIN 1 PIN 1
XXXXXXXX 18F26K40
XXXXXXXX /ML e3
YYWWNNN 1526017

28-Lead UQFN (4x4x0.5 mm) Example

PIN 1 PIN 1 PIC18


F26K40
/MV e 3

526017

40-Lead PDIP (600 mil) Example

XXXXXXXXXXXXXXXXXX PIC18F45K40
XXXXXXXXXXXXXXXXXX /P e3
XXXXXXXXXXXXXXXXXX
YYWWNNN 1526017

Legend: XX...X Customer-specific information or Microchip part number


Y Year code (last digit of calendar year)
YY Year code (last 2 digits of calendar year)
WW Week code (week of January 1 is week 01)
NNN Alphanumeric traceability code
e3 Pb-free JEDEC designator for Matte Tin (Sn)
* This package is Pb-free. The Pb-free JEDEC designator ( e3 )
can be found on the outer packaging for this package.

Note: In the event the full Microchip part number cannot be marked on one line, it will
be carried over to the next line, thus limiting the number of available
characters for customer-specific information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 566


PIC18(L)F26/45/46K40
Package Marking Information (Continued)

40-Lead UQFN (5x5x0.5 mm) Example

PIN 1 PIN 1

PIC18
F45K40
/MV e 3

1526017
44-Lead QFN (8x8x0.9 mm) Example

PIN 1 PIN 1
XXXXXXXXXXX 18F45K40
XXXXXXXXXXX /ML e3
XXXXXXXXXXX 1526017
YYWWNNN

44-Lead TQFP (10x10x1 mm) Example

XXXXXXXXXX 18F45K40
XXXXXXXXXX /PT e3
XXXXXXXXXX
YYWWNNN 1526017

Legend: XX...X Customer-specific information or Microchip part number


Y Year code (last digit of calendar year)
YY Year code (last 2 digits of calendar year)
WW Week code (week of January 1 is week 01)
NNN Alphanumeric traceability code
e3 Pb-free JEDEC designator for Matte Tin (Sn)
* This package is Pb-free. The Pb-free JEDEC designator ( e3 )
can be found on the outer packaging for this package.

Note: In the event the full Microchip part number cannot be marked on one line, it will
be carried over to the next line, thus limiting the number of available
characters for customer-specific information.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 567


PIC18(L)F26/45/46K40
39.1 Package Details
The following sections give the technical details of the packages.


       
      
!
"# J
* + #* $

*  K%
6#/ ##* 
 ! K  ' *  *%*
** HLL666+
  +L  K

NOTE 1
E1

1 2 3

A A2

L c

A1 b1
b e eB

V*# X9Y?
+# [+*# X X\ ]
X$+5
 '!# X ^
!*  G9
 * *!  _ _ 
 %%! K  K##   ; 
G#* *!   _ _
 $%
*  $%
`%* ?  ; ;;
 %%! K`%* ?  ^ 
\"
[*  ; ;j 
 * *! [  ; 
[%  K## ^  
V 
[%`%* 5   
[ 6
[%`%* 5  ^ 
\"
 6  7 G _ _ ;
"#
 !"#$%&'*$
+"
/5$*+$#*5 *%6* *  * %

 7' *9 
 *
#* 
; +# #%?%  * $%+ %'# 

*
$# # %'# 

*
$# ##  *& %@ 
#%
 +# %* 
  
?B
G9H G# +#  
* & *"$# 66* $** 
 #


     
6 9G

2016 Microchip Technology Inc. Preliminary DS40001816C-page 568


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 569


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 570


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 571


PIC18(L)F26/45/46K40

  
$%
 &  

  '*   

&!
"# J
* + #* $

*  K%
6#/ ##* 
 ! K  ' *  *%*
** HLL666+
  +L  K

D
N

E
E1

1 2
b
NOTE 1
e

c
A A2


A1
L1 L

V*# [[??
+# [+*# X X\ ]
X$+5
 '!# X ^
!*  jG9
\"
Y *  _ _ 
 %%! K  K##  j  ^
*% ''   _ _
\"
`%* ?  ^ ^
 %%! K`%* ?  ; j
\"
[*    
J *[* [   
J *
* [ ?J
[%  K##  _ 
J *  { { ^{
[%`%* 5  _ ;^
"#
 !"#$%&'*$
+"
/5$*+$#*5 *%6* *  * %

 +# #%?%  * $%+ %'# 

*
$# # %'# 

*
$# ##  *& %++ 
#%
; +# %* 
  
?B
G9H G# +#  
* & *"$# 66* $** 
 #
?JH '
 +# /$#$6* $** 
 /'
'
+*  $
## 


     
6 9;G

2016 Microchip Technology Inc. Preliminary DS40001816C-page 572


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 573


PIC18(L)F26/45/46K40

2016 Microchip Technology Inc. Preliminary DS40001816C-page 574


PIC18(L)F26/45/46K40

2016 Microchip Technology Inc. Preliminary DS40001816C-page 575


PIC18(L)F26/45/46K40

   + ,4 "   5 7  9;9   +,"!
< $ *''  =   5$
"# J
* + #* $

*  K%
6#/ ##* 
 ! K  ' *  *%*
** HLL666+
  +L  K

2016 Microchip Technology Inc. Preliminary DS40001816C-page 576


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 577


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 578


PIC18(L)F26/45/46K40

>         9    !


"# J
* + #* $

*  K%
6#/ ##* 
 ! K  ' *  *%*
** HLL666+
  +L  K

NOTE 1
E1

1 2 3

A A2
L c
b1
A1
b e eB

V*# X9Y?
+# [+*# X X\ ]
X$+5
 '!# X 
!*  G9
 * *!  _ _ 
 %%! K  K##   _ 
G#* *!   _ _
 $%
*  $%
`%* ?  _ j
 %%! K`%* ? ^ _ ^
\"
[*  ^ _ 
 * *! [  _ 
[%  K## ^ _ 
V 
[%`%* 5 ; _ 
[ 6
[%`%* 5  _ ;
\"
 6  7 G _ _ 
"#
 !"#$%&'*$
+"
/5$*+$#*5 *%6* *  * %

 7' *9 
 *
#* 
; +# #%?%  * $%+ %'# 

*
$# # %'# 

*
$# ##  *& %@ 
#%
 +# %* 
  
?B
G9H G# +#  
* & *"$# 66* $** 
 #


     
6 9jG

2016 Microchip Technology Inc. Preliminary DS40001816C-page 579


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 580


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 581


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 582


PIC18(L)F26/45/46K40

44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

D A B
N
NOTE 1
1
2

E
(DATUM B)
(DATUM A)
2X
0.20 C

2X
0.20 C TOP VIEW

0.10 C A1
C
SEATING A
PLANE 44X
A3 0.08 C
SIDE VIEW
L
0.10 C A B
D2

0.10 C A B

E2

K
2
1

NOTE 1 N
44X b
e 0.07 C A B
0.05 C
BOTTOM VIEW
Microchip Technology Drawing C04-103D Sheet 1 of 2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 583


PIC18(L)F26/45/46K40

44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

Units MILLIMETERS
Dimension Limits MIN NOM MAX
Number of Pins N 44
Pitch e 0.65 BSC
Overall Height A 0.80 0.90 1.00
Standoff A1 0.00 0.02 0.05
Terminal Thickness A3 0.20 REF
Overall Width E 8.00 BSC
Exposed Pad Width E2 6.25 6.45 6.60
Overall Length D 8.00 BSC
Exposed Pad Length D2 6.25 6.45 6.60
Terminal Width b 0.20 0.30 0.35
Terminal Length L 0.30 0.40 0.50
Terminal-to-Exposed-Pad K 0.20 - -
Notes:
1. Pin 1 visual index feature may vary, but must be located within the hatched area.
2. Package is saw singulated
3. Dimensioning and tolerancing per ASME Y14.5M
BSC: Basic Dimension. Theoretically exact value shown without tolerances.
REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-103D Sheet 2 of 2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 584


PIC18(L)F26/45/46K40

44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN or VQFN]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

C1
X2
EV
44
G2
1
2
V
EV
C2 Y2
G1

Y1

E SILK SCREEN
X1

RECOMMENDED LAND PATTERN


Units MILLIMETERS
Dimension Limits MIN NOM MAX
Contact Pitch E 0.65 BSC
Optional Center Pad Width X2 6.60
Optional Center Pad Length Y2 6.60
Contact Pad Spacing C1 8.00
Contact Pad Spacing C2 8.00
Contact Pad Width (X44) X1 0.35
Contact Pad Length (X44) Y1 0.85
Contact Pad to Contact Pad (X40) G1 0.30
Contact Pad to Center Pad (X44) G2 0.28
Thermal Via Diameter V 0.33
Thermal Via Pitch EV 1.20
Notes:
1. Dimensioning and tolerancing per ASME Y14.5M
BSC: Basic Dimension. Theoretically exact value shown without tolerances.
2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during
reflow process

Microchip Technology Drawing No. C04-2103C

2016 Microchip Technology Inc. Preliminary DS40001816C-page 585


PIC18(L)F26/45/46K40

44-Lead Plastic Thin Quad Flatpack (PT) - 10x10x1.0 mm Body [TQFP]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

D A
D1 B
NOTE 2

(DATUM A)
(DATUM B)
E1 E
NOTE 1 A A

2X
N
0.20 H A B

2X 1 2 3
0.20 H A B 4X 11 TIPS
TOP VIEW
0.20 C A B

A A2
C

SEATING PLANE
0.10 C A1
SIDE VIEW
1 2 3

NOTE 1

44 X b
e 0.20 C A B

BOTTOM VIEW
Microchip Technology Drawing C04-076C Sheet 1 of 2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 586


PIC18(L)F26/45/46K40

44-Lead Plastic Thin Quad Flatpack (PT) - 10x10x1.0 mm Body [TQFP]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

(L1)
SECTION A-A

Units MILLIMETERS
Dimension Limits MIN NOM MAX
Number of Leads N 44
Lead Pitch e 0.80 BSC
Overall Height A - - 1.20
Standoff A1 0.05 - 0.15
Molded Package Thickness A2 0.95 1.00 1.05
Overall Width E 12.00 BSC
Molded Package Width E1 10.00 BSC
Overall Length D 12.00 BSC
Molded Package Length D1 10.00 BSC
Lead Width b 0.30 0.37 0.45
Lead Thickness c 0.09 - 0.20
Lead Length L 0.45 0.60 0.75
Footprint L1 1.00 REF
Foot Angle 0 3.5 7
Notes:
1. Pin 1 visual index feature may vary, but must be located within the hatched area.
2. Exact shape of each corner is optional.
3. Dimensioning and tolerancing per ASME Y14.5M
BSC: Basic Dimension. Theoretically exact value shown without tolerances.
REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-076C Sheet 2 of 2

2016 Microchip Technology Inc. Preliminary DS40001816C-page 587


PIC18(L)F26/45/46K40

Note: For the most current package drawings, please see the Microchip Packaging Specification located at
http://www.microchip.com/packaging

2016 Microchip Technology Inc. Preliminary DS40001816C-page 588


PIC18(L)F26/45/46K40
APPENDIX A: REVISION HISTORY
Revision A (9/2015)
Initial Release.

Revision B (5/2016)
Updated Example 11-6; Figures 37-1, 37-2, 37-5; Reg-
ister 31-5; Sections 1.1.2, 21.4.1, 21.4.2, 22.1.3,
22.1.9, 22.1.10, 37.2; Tables 37-1, 37-2, 37-3, 37-7, 37-
8, 37-9, 37-11, 37-13.
Removed Register 5-3.
Added long name bit/short name bits section 1.4 and
updated bit names accordingly.

Revision C (9/2016)
Updated Peripheral Module, Memory and Core fea-
tures descriptions on cover page. Updated the
PIC18(L)F2x/4xK40 Family Types Table. Updated
Examples 11-1, 11-3, 11-5 and 11-6; Figures 14-1 and
31-2; Registers 4-2, 4-5, 13-18 and 31-6; Sections 1.2,
4.4.1, 4.5, 4.5.4, 17.3, 17.5, 17.7, 18.1, 18.1.1,
18.1.1.1, 18.1.2, 18.1.6, 18.3, 18.4, 18.7, 19.0, 19.8.1,
20.0, 21.3, and 25.3; Tables 4-2, 37-2, 37-3, 37-5, 37-
13 and 37-14.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 589


PIC18(L)F26/45/46K40
APPENDIX B: DEVICE
DIFFERENCES
The differences between the devices listed in this data
sheet are shown in Table B-1.

TABLE B-1: DEVICE DIFFERENCES


Features(1) PIC18(L)F26K40 PIC18(L)F45K40 PIC18(L)F46K40
Program Memory (Bytes) 65536 32768 65536
SRAM (Bytes) 3720 2048 3720
EEPROM (Bytes) 1024 256 1024
Interrupt Sources 36 36 36
I/O Ports Ports A, B, C, (E) Ports A, B, C, D, E Ports A, B, C, D, E
Capture/Compare/PWM Modules 2 2 2
(CCP)
10-bit Analog-to-Digital Module 4 internal 4 internal 4 internal
24 external 35 external 35 external
Packages 28-pin SPDIP 40-pin PDIP 40-pin PDIP
28-pin SOIC 40-pin UQFN 40-pin UQFN
28-pin SSOP 44-pin TQFP 44-pin TQFP
28-pin QFN 44-pin QFN 44-pin QFN
28-pin UQFN

Note 1: PIC18F2x/4xK40: operating voltage, 2.3V-5.5V. PIC18LF2x/4xK40: operating voltage, 1.8V-3.6V.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 590


PIC18(L)F26/45/46K40
THE MICROCHIP WEBSITE CUSTOMER SUPPORT
Microchip provides online support via our website at Users of Microchip products can receive assistance
www.microchip.com. This website is used as a means through several channels:
to make files and information easily available to Distributor or Representative
customers. Accessible by using your favorite Internet
Local Sales Office
browser, the website contains the following information:
Field Application Engineer (FAE)
Product Support Data sheets and errata,
Technical Support
application notes and sample programs, design
resources, users guides and hardware support Customers should contact their distributor,
documents, latest software releases and archived representative or Field Application Engineer (FAE) for
software support. Local sales offices are also available to help
General Technical Support Frequently Asked customers. A listing of sales offices and locations is
Questions (FAQ), technical support requests, included in the back of this document.
online discussion groups, Microchip consultant Technical support is available through the website
program member listing at: http://www.microchip.com/support
Business of Microchip Product selector and
ordering guides, latest Microchip press releases,
listing of seminars and events, listings of
Microchip sales offices, distributors and factory
representatives

CUSTOMER CHANGE NOTIFICATION


SERVICE
Microchips customer notification service helps keep
customers current on Microchip products. Subscribers
will receive e-mail notification whenever there are
changes, updates, revisions or errata related to a
specified product family or development tool of interest.
To register, access the Microchip website at
www.microchip.com. Under Support, click on
Customer Change Notification and follow the
registration instructions.

2016 Microchip Technology Inc. Preliminary DS40001816C-page 591


PIC18(L)F26/45/46K40
PRODUCT IDENTIFICATION SYSTEM
To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

PART NO. [X](2) - X /XX XXX


Examples:
Device Tape and Reel Temperature Package Pattern a) PIC18F26K40-E/P 301 = Extended temp.,
Option Range PDIP package, QTP pattern #301.
b) PIC18F45K40-E/SO = Extended temp., SOIC
package.
c) PIC18F46K40T-I/ML = Tape and reel, Industrial
Device: PIC18F26K40, PIC18LF26K40,
temp., QFN package.
PIC18F45K40, PIC18LF45K40,
PIC18F46K40, PIC18LF46K40

Tape and Reel Blank = standard packaging (tube or tray)


Option: T = Tape and Reel(1), (2)

Temperature E = -40C to +125C (Extended)


Range: I = -40C to +85C (Industrial)
Note 1: Tape and Reel option is available for ML,
MV, PT, SO and SS packages with industrial
Package: ML = 28-lead QFN 6x6mm Temperature Range only.
ML = 44-lead QFN 8x8x0.9mm 2: Tape and Reel identifier only appears in
MV = 28-lead UQFN 4x4x0.5mm
MV = 40-lead UQFN 5x5x0.5mm catalog part number description. This
P = 40-lead PDIP identifier is used for ordering purposes and
PT = 44-lead TQFP (Thin Quad Flatpack) is not printed on the device package.
SO = 28-lead SOIC
SP = 28-lead Skinny Plastic DIP
SS = 28-lead SSOP

Pattern: QTP, SQTP, Code or Special Requirements


(blank otherwise)

2016 Microchip Technology Inc. Preliminary DS40001816C-page 592


PIC18(L)F26/45/46K40

Note the following details of the code protection feature on Microchip devices:
Microchip products meet the specification contained in their particular Microchip Data Sheet.

Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the
intended manner and under normal conditions.

There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our
knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchips Data
Sheets. Most likely, the person doing so is engaged in theft of intellectual property.

Microchip is willing to work with the customer who is concerned about the integrity of their code.

Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
mean that we are guaranteeing the product as unbreakable.

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our
products. Attempts to break Microchips code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts
allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device Trademarks


applications and the like is provided only for your convenience The Microchip name and logo, the Microchip logo, AnyRate,
and may be superseded by updates. It is your responsibility to
dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq,
ensure that your application meets with your specifications. KeeLoq logo, Kleer, LANCheck, LINK MD, MediaLB, MOST,
MICROCHIP MAKES NO REPRESENTATIONS OR MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 logo,
WARRANTIES OF ANY KIND WHETHER EXPRESS OR
RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O
IMPLIED, WRITTEN OR ORAL, STATUTORY OR are registered trademarks of Microchip Technology
OTHERWISE, RELATED TO THE INFORMATION, Incorporated in the U.S.A. and other countries.
INCLUDING BUT NOT LIMITED TO ITS CONDITION,
QUALITY, PERFORMANCE, MERCHANTABILITY OR ClockWorks, The Embedded Control Solutions Company,
FITNESS FOR PURPOSE. Microchip disclaims all liability ETHERSYNCH, Hyper Speed Control, HyperLight Load,
arising from this information and its use. Use of Microchip IntelliMOS, mTouch, Precision Edge, and QUIET-WIRE are
devices in life support and/or safety applications is entirely at registered trademarks of Microchip Technology Incorporated
the buyers risk, and the buyer agrees to defend, indemnify and in the U.S.A.
hold harmless Microchip from any and all damages, claims, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut,
suits, or expenses resulting from such use. No licenses are BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM,
conveyed, implicitly or otherwise, under any Microchip dsPICDEM.net, Dynamic Average Matching, DAM, ECAN,
intellectual property rights unless otherwise stated. EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip
Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi,
motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB,
MPLINK, MultiTRAK, NetDetach, Omniscient Code
Generation, PICDEM, PICDEM.net, PICkit, PICtail,
PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker,
Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, Total
Endurance, TSHARC, USBCheck, VariSense, ViewSpan,
WiperLock, Wireless DNA, and ZENA are trademarks of
Microchip Technology Incorporated in the U.S.A. and other
countries.
SQTP is a service mark of Microchip Technology Incorporated
in the U.S.A.
Microchip received ISO/TS-16949:2009 certification for its worldwide
headquarters, design and wafer fabrication facilities in Chandler and Silicon Storage Technology is a registered trademark of
Tempe, Arizona; Gresham, Oregon and design centers in California Microchip Technology Inc. in other countries.
and India. The Companys quality system processes and procedures
are for its PIC MCUs and dsPIC DSCs, KEELOQ code hopping GestIC is a registered trademark of Microchip Technology
devices, Serial EEPROMs, microperipherals, nonvolatile memory and Germany II GmbH & Co. KG, a subsidiary of Microchip
analog products. In addition, Microchips quality system for the design
and manufacture of development systems is ISO 9001:2000 certified. Technology Inc., in other countries.
All other trademarks mentioned herein are property of their
respective companies.
QUALITY MANAGEMENT SYSTEM 2016, Microchip Technology Incorporated, Printed in the
CERTIFIED BY DNV U.S.A., All Rights Reserved.
ISBN: 978-1-5224-0947-2
== ISO/TS 16949 ==

2016 Microchip Technology Inc. Preliminary DS40001816C-page 593


Worldwide Sales and Service
AMERICAS ASIA/PACIFIC ASIA/PACIFIC EUROPE
Corporate Office Asia Pacific Office China - Xiamen Austria - Wels
2355 West Chandler Blvd. Suites 3707-14, 37th Floor Tel: 86-592-2388138 Tel: 43-7242-2244-39
Chandler, AZ 85224-6199 Tower 6, The Gateway Fax: 86-592-2388130 Fax: 43-7242-2244-393
Tel: 480-792-7200 Harbour City, Kowloon China - Zhuhai Denmark - Copenhagen
Fax: 480-792-7277 Hong Kong Tel: 86-756-3210040 Tel: 45-4450-2828
Technical Support: Tel: 852-2943-5100 Fax: 86-756-3210049 Fax: 45-4485-2829
http://www.microchip.com/ Fax: 852-2401-3431 India - Bangalore France - Paris
support Tel: 91-80-3090-4444 Tel: 33-1-69-53-63-20
Australia - Sydney
Web Address:
Tel: 61-2-9868-6733 Fax: 91-80-3090-4123 Fax: 33-1-69-30-90-79
www.microchip.com Fax: 61-2-9868-6755 India - New Delhi Germany - Dusseldorf
Atlanta China - Beijing Tel: 91-11-4160-8631 Tel: 49-2129-3766400
Duluth, GA Tel: 86-10-8569-7000 Fax: 91-11-4160-8632
Tel: 678-957-9614 Germany - Karlsruhe
Fax: 86-10-8528-2104 India - Pune Tel: 49-721-625370
Fax: 678-957-1455
China - Chengdu Tel: 91-20-3019-1500 Germany - Munich
Austin, TX Tel: 86-28-8665-5511
Tel: 512-257-3370 Japan - Osaka Tel: 49-89-627-144-0
Fax: 86-28-8665-7889 Tel: 81-6-6152-7160 Fax: 49-89-627-144-44
Boston China - Chongqing Fax: 81-6-6152-9310
Westborough, MA Italy - Milan
Tel: 86-23-8980-9588 Japan - Tokyo Tel: 39-0331-742611
Tel: 774-760-0087 Fax: 86-23-8980-9500
Fax: 774-760-0088 Tel: 81-3-6880- 3770 Fax: 39-0331-466781
China - Dongguan Fax: 81-3-6880-3771 Italy - Venice
Chicago Tel: 86-769-8702-9880 Korea - Daegu Tel: 39-049-7625286
Itasca, IL
Tel: 630-285-0071 China - Guangzhou Tel: 82-53-744-4301 Netherlands - Drunen
Fax: 630-285-0075 Tel: 86-20-8755-8029 Fax: 82-53-744-4302 Tel: 31-416-690399
China - Hangzhou Korea - Seoul Fax: 31-416-690340
Cleveland
Tel: 86-571-8792-8115 Tel: 82-2-554-7200 Poland - Warsaw
Independence, OH
Tel: 216-447-0464 Fax: 86-571-8792-8116 Fax: 82-2-558-5932 or Tel: 48-22-3325737
Fax: 216-447-0643 China - Hong Kong SAR 82-2-558-5934
Spain - Madrid
Tel: 852-2943-5100 Malaysia - Kuala Lumpur Tel: 34-91-708-08-90
Dallas
Fax: 852-2401-3431 Tel: 60-3-6201-9857 Fax: 34-91-708-08-91
Addison, TX
Tel: 972-818-7423 China - Nanjing Fax: 60-3-6201-9859
Sweden - Stockholm
Fax: 972-818-2924 Tel: 86-25-8473-2460 Malaysia - Penang Tel: 46-8-5090-4654
Fax: 86-25-8473-2470 Tel: 60-4-227-8870
Detroit UK - Wokingham
China - Qingdao Fax: 60-4-227-4068
Novi, MI Tel: 44-118-921-5800
Tel: 248-848-4000 Tel: 86-532-8502-7355 Philippines - Manila Fax: 44-118-921-5820
Fax: 86-532-8502-7205 Tel: 63-2-634-9065
Houston, TX
Tel: 281-894-5983 China - Shanghai Fax: 63-2-634-9069
Tel: 86-21-5407-5533 Singapore
Indianapolis
Fax: 86-21-5407-5066 Tel: 65-6334-8870
Noblesville, IN
Tel: 317-773-8323 China - Shenyang Fax: 65-6334-8850
Fax: 317-773-5453 Tel: 86-24-2334-2829 Taiwan - Hsin Chu
Fax: 86-24-2334-2393 Tel: 886-3-5778-366
Los Angeles
China - Shenzhen Fax: 886-3-5770-955
Mission Viejo, CA
Tel: 949-462-9523 Tel: 86-755-8864-2200 Taiwan - Kaohsiung
Fax: 949-462-9608 Fax: 86-755-8203-1760 Tel: 886-7-213-7828
New York, NY China - Wuhan Taiwan - Taipei
Tel: 631-435-6000 Tel: 86-27-5980-5300 Tel: 886-2-2508-8600
Fax: 86-27-5980-5118 Fax: 886-2-2508-0102
San Jose, CA
Tel: 408-735-9110 China - Xian Thailand - Bangkok
Tel: 86-29-8833-7252 Tel: 66-2-694-1351
Canada - Toronto
Tel: 905-695-1980 Fax: 86-29-8833-7256 Fax: 66-2-694-1350
Fax: 905-695-2078
06/23/16

2016 Microchip Technology Inc Preliminary DS40001816C-page 594

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy