

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



### Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









# PIC18F87J50 Family Data Sheet

64/80-Pin High-Performance, 1-Mbit Flash USB Microcontrollers with nanoWatt Technology

#### 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 Microchip's 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 Microchip's 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 applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION. QUALITY, PERFORMANCE, MERCHANTABILITY FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

#### **Trademarks**

The Microchip name and logo, the Microchip logo, dsPIC, Keeloq, Keeloq logo, MPLAB, PIC, PICmicro, PICSTART, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Octopus, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, PIC<sup>32</sup> logo, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

 $\ensuremath{\mathsf{SQTP}}$  is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2009, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

QUALITY MANAGEMENT SYSTEM

CERTIFIED BY DNV

ISO/TS 16949:2002

Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.



## 64/80-Pin High-Performance, 1-Mbit Flash USB Microcontrollers with nanoWatt Technology

#### **Universal Serial Bus Features:**

- USB V2.0 Compliant SIE
- Low Speed (1.5 Mb/s) and Full Speed (12 Mb/s)
- Supports Control, Interrupt, Isochronous and Bulk Transfers
- Supports up to 32 Endpoints (16 bidirectional)
- · 3.9-Kbyte Dual Access RAM for USB
- · On-Chip USB Transceiver

#### Flexible Oscillator Structure:

- · High-Precision PLL for USB
- Two External Clock modes, up to 48 MHz
- Internal 31 kHz Oscillator, Tunable Internal Oscillator, 31 kHz to 8 MHz
- Secondary Oscillator using Timer1 @ 32 kHz
- · Fail-Safe Clock Monitor:
  - Allows for safe shutdown if any clock stops

#### **Peripheral Highlights:**

- High-Current Sink/Source 25 mA/25mA (PORTB and PORTC)
- · Four Programmable External Interrupts
- · Four Input Change Interrupts
- Two Capture/Compare/PWM (CCP) modules
- Three Enhanced Capture/Compare/PWM (ECCP) modules:
  - One, two or four PWM outputs
  - Selectable polarity
  - Programmable dead time
  - Auto-shutdown and auto-restart
- Two Master Synchronous Serial Port (MSSP) modules supporting 3-Wire SPI (all 4 modes) and I<sup>2</sup>C™ Master and Slave modes
- 8-Bit Parallel Master Port/Enhanced Parallel Slave Port with 16 Address Lines
- · Dual Analog Comparators with Input Multiplexing

#### Peripheral Highlights (continued):

- 10-Bit, up to 12-Channel Analog-to-Digital (A/D) Converter module:
  - Auto-acquisition capability
  - Conversion available during Sleep
- · Two Enhanced USART modules:
  - Supports RS-485, RS-232 and LIN 1.2
  - Auto-wake-up on Start bit
  - Auto-Baud Detect

### External Memory Bus (80-pin devices only):

- · Address Capability of up to 2 Mbytes
- · 8-Bit or 16-Bit Interface
- 12-Bit, 16-Bit and 20-Bit Addressing modes

#### **Special Microcontroller Features:**

- · 5.5V Tolerant Inputs (digital-only pins)
- · Low-Power, High-Speed CMOS Flash Technology
- C Compiler Optimized Architecture for Re-Entrant Code
- · Power Management Features:
  - Run: CPU on, peripherals on
  - Idle: CPU off, peripherals on
  - Sleep: CPU off, peripherals off
- · Priority Levels for Interrupts
- · Self-Programmable under Software Control
- 8 x 8 Single-Cycle Hardware Multiplier
- Extended Watchdog Timer (WDT):
  - Programmable period from 4 ms to 131s
- Single-Supply In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) via Two Pins
- In-Circuit Debug (ICD) with 3 Breakpoints via Two Pins
- · Operating Voltage Range of 2.0V to 3.6V
- On-Chip 2.5V Regulator
- Flash Program Memory of 10000 Erase/Write Cycles and 20-Year Data Retention

|             |                                 |                                |     |                    |                       |   | MSSP |                             | _      | ors         |                    | Bus        | Ь       |
|-------------|---------------------------------|--------------------------------|-----|--------------------|-----------------------|---|------|-----------------------------|--------|-------------|--------------------|------------|---------|
| Device      | Flash Program<br>Memory (bytes) | SRAM Data<br>Memory<br>(bytes) | I/O | 10-Bit<br>A/D (ch) | CCP/<br>ECCP<br>(PWM) |   | SPI  | Master<br>I <sup>2</sup> C™ | EUSART | Comparators | Timers<br>8/16-Bit | External B | PMP/PSP |
| PIC18F65J50 | 32K                             | 3904*                          | 49  | 8                  | 2/3                   | 2 | Υ    | Y                           | 2      | 2           | 2/3                | N          | Υ       |
| PIC18F66J50 | 64K                             | 3904*                          | 49  | 8                  | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Ν          | Υ       |
| PIC18F66J55 | 96K                             | 3904*                          | 49  | 8                  | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Ν          | Υ       |
| PIC18F67J50 | 128K                            | 3904*                          | 49  | 8                  | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Ν          | Υ       |
| PIC18F85J50 | 32K                             | 3904*                          | 65  | 12                 | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Υ          | Υ       |
| PIC18F86J50 | 64K                             | 3904*                          | 65  | 12                 | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Υ          | Υ       |
| PIC18F86J55 | 96K                             | 3904*                          | 65  | 12                 | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Υ          | Υ       |
| PIC18F87J50 | 128K                            | 3904*                          | 65  | 12                 | 2/3                   | 2 | Υ    | Υ                           | 2      | 2           | 2/3                | Υ          | Υ       |

Includes the dual access RAM used by the USB module which is shared with data memory.





#### **Table of Contents**

| 1.0   | Device Overview                                                           | 9     |  |  |  |  |  |
|-------|---------------------------------------------------------------------------|-------|--|--|--|--|--|
| 2.0   | Oscillator Configurations                                                 | 35    |  |  |  |  |  |
| 3.0   | Power-Managed Modes                                                       | 47    |  |  |  |  |  |
| 4.0   | Reset                                                                     | 55    |  |  |  |  |  |
| 5.0   | Memory Organization                                                       | 69    |  |  |  |  |  |
| 6.0   | Flash Program Memory                                                      | 97    |  |  |  |  |  |
| 7.0   | External Memory Bus                                                       |       |  |  |  |  |  |
| 8.0   | 8 x 8 Hardware Multiplier                                                 | . 119 |  |  |  |  |  |
| 9.0   | Interrupts                                                                | . 121 |  |  |  |  |  |
| 10.0  | I/O Ports                                                                 | . 137 |  |  |  |  |  |
| 11.0  | Parallel Master Port                                                      | . 167 |  |  |  |  |  |
| 12.0  | Timer0 Module                                                             | . 191 |  |  |  |  |  |
| 13.0  | Timer1 Module                                                             | . 195 |  |  |  |  |  |
| 14.0  | Timer2 Module                                                             | . 201 |  |  |  |  |  |
| 15.0  | Timer3 Module                                                             | . 203 |  |  |  |  |  |
| 16.0  | Timer4 Module                                                             | . 207 |  |  |  |  |  |
| 17.0  | Capture/Compare/PWM (CCP) Modules                                         | . 209 |  |  |  |  |  |
| 18.0  | Enhanced Capture/Compare/PWM (ECCP) Module                                | . 217 |  |  |  |  |  |
| 19.0  | Master Synchronous Serial Port (MSSP) Module                              | . 233 |  |  |  |  |  |
| 20.0  | Enhanced Universal Synchronous Asynchronous Receiver Transmitter (EUSART) | . 279 |  |  |  |  |  |
| 21.0  | 10-bit Analog-to-Digital Converter (A/D) Module                           | . 301 |  |  |  |  |  |
| 22.0  | Universal Serial Bus (USB)                                                | . 311 |  |  |  |  |  |
| 23.0  | Comparator Module                                                         | . 337 |  |  |  |  |  |
| 24.0  | Comparator Voltage Reference Module                                       | . 345 |  |  |  |  |  |
| 25.0  | Special Features of the CPU                                               | . 349 |  |  |  |  |  |
| 26.0  | Instruction Set Summary                                                   | . 365 |  |  |  |  |  |
| 27.0  | Development Support                                                       | . 415 |  |  |  |  |  |
| 28.0  | Electrical Characteristics                                                | . 419 |  |  |  |  |  |
| 29.0  | Packaging Information                                                     | . 459 |  |  |  |  |  |
| Appe  | ndix A: Revision History                                                  | . 463 |  |  |  |  |  |
| Appe  | ndix B: Device Differences                                                | . 463 |  |  |  |  |  |
| The I | Vicrochip Web Site                                                        | . 477 |  |  |  |  |  |
| Custo | stomer Change Notification Service                                        |       |  |  |  |  |  |
| Custo | Customer Support                                                          |       |  |  |  |  |  |
| Read  | er Response                                                               | . 478 |  |  |  |  |  |
| Produ | uct Identification System                                                 | . 479 |  |  |  |  |  |

#### 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** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. 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 Web site 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., DS30000A is version A of document DS30000).

#### **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:

- · Microchip's Worldwide Web site; 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 web site at www.microchip.com to receive the most current information on all of our products.

NOTES:

#### 1.0 DEVICE OVERVIEW

This document contains device-specific information for the following devices:

PIC18F65J50
 PIC18F85J50
 PIC18F66J50
 PIC18F66J55
 PIC18F66J55
 PIC18F87J50

This family introduces a new line of low-voltage USB microcontrollers with the main traditional advantage of all PIC18 microcontrollers – namely, high computational performance and a rich feature set – at an extremely competitive price point. These features make the PIC18F87J10 family a logical choice for many high-performance applications, where cost is a primary consideration.

#### 1.1 Core Features

#### 1.1.1 nanoWatt TECHNOLOGY

All of the devices in the PIC18F87J10 family incorporate a range of features that can significantly reduce power consumption during operation. Key items include:

- Alternate Run Modes: By clocking the controller from the Timer1 source or the internal RC oscillator, power consumption during code execution can be reduced by as much as 90%.
- Multiple Idle Modes: The controller can also run
  with its CPU core disabled but the peripherals still
  active. In these states, power consumption can be
  reduced even further, to as little as 4% of normal
  operation requirements.
- On-the-Fly Mode Switching: The power-managed modes are invoked by user code during operation, allowing the user to incorporate power-saving ideas into their application's software design.

#### 1.1.2 UNIVERSAL SERIAL BUS (USB)

Devices in the PIC18F87J10 family incorporate a fully-featured Universal Serial Bus communications module with a built-in transceiver that is compliant with the USB Specification Revision 2.0. The module supports both low-speed and full-speed communication for all supported data transfer types.

### 1.1.3 OSCILLATOR OPTIONS AND FEATURES

All of the devices in the PIC18F87J10 family offer five different oscillator options, allowing users a range of choices in developing application hardware. These include:

- Two Crystal modes, using crystals or ceramic resonators.
- Two External Clock modes, offering the option of a divide-by-4 clock output.
- An internal oscillator block which provides an 8 MHz clock and an INTRC source (approximately 31 kHz, stable over temperature and VDD), as well as a range of 6 user-selectable clock frequencies, between 125 kHz to 4 MHz, for a total of 8 clock frequencies. This option frees an oscillator pin for use as an additional general purpose I/O.
- A Phase Lock Loop (PLL) frequency multiplier, available to the high-speed crystal, external oscillator and internal oscillator, providing a clock speed up to 48 MHz.
- Dual clock operation, allowing the USB module to run from a high-frequency oscillator while the rest of the microcontroller is clocked at a different frequency.

The internal oscillator block provides a stable reference source that gives the family additional features for robust operation:

- Fail-Safe Clock Monitor: This option constantly
  monitors the main clock source against a reference
  signal provided by the internal oscillator. If a clock
  failure occurs, the controller is switched to the
  internal oscillator, allowing for continued low-speed
  operation or a safe application shutdown.
- Two-Speed Start-up: This option allows the internal oscillator to serve as the clock source from Power-on Reset, or wake-up from Sleep mode, until the primary clock source is available.

#### 1.1.4 EXPANDED MEMORY

The PIC18F87J10 family provides ample room for application code, from 32 Kbytes to 128 Kbytes of code space. The Flash cells for program memory are rated to last in excess of 10000 erase/write cycles. Data retention without refresh is conservatively estimated to be greater than 20 years.

The Flash program memory is readable and writable during normal operation. The PIC18F87J10 family also provides plenty of room for dynamic application data with up to 3904 bytes of data RAM.

#### 1.1.5 EXTERNAL MEMORY BUS

In the event that 128 Kbytes of memory are inadequate for an application, the 80-pin members of the PIC18F87J10 family also implement an External Memory Bus (EMB). This allows the controller's internal program counter to address a memory space of up to 2 Mbytes, permitting a level of data access that few 8-bit devices can claim. This allows additional memory options, including:

- Using combinations of on-chip and external memory up to the 2-Mbyte limit
- Using external Flash memory for reprogrammable application code or large data tables
- Using external RAM devices for storing large amounts of variable data

#### 1.1.6 EXTENDED INSTRUCTION SET

The PIC18F87J10 family implements the optional extension to the PIC18 instruction set, adding 8 new instructions and an Indexed Addressing mode. Enabled as a device configuration option, the extension has been specifically designed to optimize re-entrant application code originally developed in high-level languages, such as 'C'.

#### 1.1.7 EASY MIGRATION

Regardless of the memory size, all devices share the same rich set of peripherals, allowing for a smooth migration path as applications grow and evolve.

The consistent pinout scheme used throughout the entire family also aids in migrating to the next larger device. This is true when moving between the 64-pin members, between the 80-pin members, or even jumping from 64-pin to 80-pin devices.

The PIC18F87J10 family is also pin compatible with other PIC18 families, such as the PIC18F87J10, PIC18F87J11, PIC18F8720 and PIC18F8722. This allows a new dimension to the evolution of applications, allowing developers to select different price points within Microchip's PIC18 portfolio, while maintaining the same feature set.

#### 1.2 Other Special Features

Communications: The PIC18F87J10 family incorporates a range of serial and parallel communication peripherals, including a fully featured Universal Serial Bus communications module that is compliant with the USB Specification Revision 2.0. This device also includes 2 independent Enhanced USARTs and 2 Master SSP modules, capable of both SPI and I2C™ (Master and Slave) modes of operation. The device also has a parallel port and can be configured to serve as either a Parallel Master Port or as a Parallel Slave Port.

- CCP Modules: All devices in the family incorporate
  two Capture/Compare/PWM (CCP) modules and
  three Enhanced CCP modules to maximize
  flexibility in control applications. Up to four different
  time bases may be used to perform several
  different operations at once. Each of the three
  ECCPs offers up to four PWM outputs, allowing for
  a total of 12 PWMs. The ECCPs also offer many
  beneficial features, including polarity selection,
  programmable dead time, auto-shutdown and
  restart and Half-Bridge and Full-Bridge Output
  modes.
- 10-Bit A/D Converter: 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, reducing code overhead.
- Extended Watchdog Timer (WDT): This
  enhanced version incorporates a 16-bit prescaler,
  allowing an extended time-out range that is stable
  across operating voltage and temperature. See
  Section 28.0 "Electrical Characteristics" for
  time-out periods.

### 1.3 Details on Individual Family Members

Devices in the PIC18F87J10 family are available in 64-pin and 80-pin packages. Block diagrams for the two groups are shown in Figure 1-1 and Figure 1-2. The devices are differentiated from each other in two ways:

- 1. Flash program memory (six sizes, ranging from 32 Kbytes for PIC18FX5J50 devices to 128 Kbytes for PIC18FX7J50).
- 2. I/O ports (7 bidirectional ports on 64-pin devices, 9 bidirectional ports on 80-pin devices).

All other features for devices in this family are identical. These are summarized in Table 1-1 and Table 1-2.

The pinouts for all devices are listed in Table 1-3 and Table 1-4.

TABLE 1-1: DEVICE FEATURES FOR THE PIC18F6XJ5X (64-PIN DEVICES)

| Features                                 | PIC18F65J50                                                                     | PIC18F66J50               | PIC18F66J55       | PIC18F67J50 |  |  |  |  |
|------------------------------------------|---------------------------------------------------------------------------------|---------------------------|-------------------|-------------|--|--|--|--|
| Operating Frequency                      | DC – 48 MHz                                                                     | DC – 48 MHz               | DC – 48 MHz       | DC – 48 MHz |  |  |  |  |
| Program Memory (Bytes)                   | 32K                                                                             | 64K                       | 96K               | 128K        |  |  |  |  |
| Program Memory (Instructions)            | 16384                                                                           | 32768                     | 49152             | 65536       |  |  |  |  |
| Data Memory (Bytes)                      | 3904                                                                            | 3904                      | 3904              | 3904        |  |  |  |  |
| Interrupt Sources                        |                                                                                 | 3                         | 0                 |             |  |  |  |  |
| I/O Ports                                |                                                                                 | Ports A, B, C, D, E, F, G |                   |             |  |  |  |  |
| Timers                                   | 5                                                                               |                           |                   |             |  |  |  |  |
| Capture/Compare/PWM Modules              |                                                                                 | 2                         |                   |             |  |  |  |  |
| Enhanced Capture/<br>Compare/PWM Modules |                                                                                 | 3                         |                   |             |  |  |  |  |
| Serial Communications                    |                                                                                 | MSSP (2), Enhance         | ed USART (2), USB |             |  |  |  |  |
| Parallel Communications (PMP)            |                                                                                 | Y                         | es                |             |  |  |  |  |
| 10-Bit Analog-to-Digital Module          |                                                                                 | 8 Input (                 | Channels          |             |  |  |  |  |
| Resets (and Delays)                      | POR, BOR, RESET Instruction, Stack Full, Stack Underflow, MCLR, WDT (PWRT, OST) |                           |                   |             |  |  |  |  |
| Instruction Set                          | 75 Instructions, 83 with Extended Instruction Set Enabled                       |                           |                   |             |  |  |  |  |
| Packages                                 | 64-Pin TQFP                                                                     |                           |                   |             |  |  |  |  |

TABLE 1-2: DEVICE FEATURES FOR THE PIC18F8XJ5X (80-PIN DEVICES)

| Features                                 | PIC18F85J50   | PIC18F86J50                                                                     | PIC18F86J55       | PIC18F87J50 |  |  |  |  |
|------------------------------------------|---------------|---------------------------------------------------------------------------------|-------------------|-------------|--|--|--|--|
| Operating Frequency                      | DC – 48 MHz   | DC – 48 MHz                                                                     | DC – 48 MHz       | DC – 48 MHz |  |  |  |  |
| Program Memory (Bytes)                   | 32K           | 64K                                                                             | 96K               | 128K        |  |  |  |  |
| Program Memory (Instructions)            | 16384         | 32768                                                                           | 49152             | 65536       |  |  |  |  |
| Data Memory (Bytes)                      | 3904          | 3904                                                                            | 3904              | 3904        |  |  |  |  |
| Interrupt Sources                        |               | 30                                                                              |                   |             |  |  |  |  |
| I/O Ports                                |               | Ports A, B, C, D, E, F, G, H, J                                                 |                   |             |  |  |  |  |
| Timers                                   |               | 5                                                                               |                   |             |  |  |  |  |
| Capture/Compare/PWM Modules              |               | 2                                                                               |                   |             |  |  |  |  |
| Enhanced Capture/<br>Compare/PWM Modules |               | 3                                                                               |                   |             |  |  |  |  |
| Serial Communications                    |               | MSSP (2), Enhance                                                               | ed USART (2), USB |             |  |  |  |  |
| Parallel Communications (PMP)            |               | Y                                                                               | es                |             |  |  |  |  |
| 10-Bit Analog-to-Digital Module          |               | 12 Input                                                                        | Channels          |             |  |  |  |  |
| Resets (and Delays)                      | POR, BOR, RES | POR, BOR, RESET Instruction, Stack Full, Stack Underflow, MCLR, WDT (PWRT, OST) |                   |             |  |  |  |  |
| Instruction Set                          | 75 Instru     | 75 Instructions, 83 with Extended Instruction Set Enabled                       |                   |             |  |  |  |  |
| Packages                                 | 80-Pin TQFP   |                                                                                 |                   |             |  |  |  |  |





TABLE 1-3: PIC18F6XJ5X PINOUT I/O DESCRIPTIONS

| Pin Name              | Pin Number | Pin  | Buffer | Description                                                                                                                                                |  |  |
|-----------------------|------------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Pili Naille           | 64-TQFP    | Type | Type   | Description                                                                                                                                                |  |  |
| MCLR                  | 7          | I    | ST     | Master Clear (Reset) input. This pin is an active-low Reset to the device.                                                                                 |  |  |
| OSC1/CLKI/RA7<br>OSC1 | 39         | I    | ST     | Oscillator crystal or external clock input. Oscillator crystal input or external clock source input. ST buffer when configured in RC mode; CMOS otherwise. |  |  |
| CLKI                  |            | I    | CMOS   | Main oscillator input connection.  External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, OSC2/CLKO pins.)         |  |  |
| RA7 <sup>(3)</sup>    |            | I/O  | TTL    | Main clock input connection.  General purpose I/O pin.                                                                                                     |  |  |
| OSC2/CLKO/RA6<br>OSC2 | 40         | 0    | _      | Oscillator crystal or clock output.  Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode.                               |  |  |
| CLKO                  |            | 0    | _      | Main oscillator feedback output connection. In RC mode, OSC2 pin outputs CLKO which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate.  |  |  |
| RA6 <sup>(3)</sup>    |            | I/O  | TTL    | System cycle clock output (Fosc/4).  General purpose I/O pin.                                                                                              |  |  |

**Legend:** TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

= Input

P = Power OD = Open-Drain (no P diode to VDD)

CMOS

Analog = Analog input

= Output

= CMOS compatible input or output

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

**TABLE 1-3:** PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                             | Pin Number | Pin           | Buffer                  | Paradiation.                                                     |  |  |
|--------------------------------------|------------|---------------|-------------------------|------------------------------------------------------------------|--|--|
| Pin Name                             | 64-TQFP    | Туре          | Type                    | Description                                                      |  |  |
|                                      |            |               |                         | PORTA is a bidirectional I/O port.                               |  |  |
| RA0/AN0<br>RA0<br>AN0                | 24         | I/O<br>I      | TTL<br>Analog           | Digital I/O.<br>Analog input 0.                                  |  |  |
| RA1/AN1<br>RA1<br>AN1                | 23         | I/O<br>I      | TTL<br>Analog           | Digital I/O.<br>Analog input 1.                                  |  |  |
| RA2/AN2/VREF-<br>RA2<br>AN2<br>VREF- | 22         | I/O<br>I<br>I | TTL<br>Analog<br>Analog | Digital I/O. Analog input 2. A/D reference voltage (low) input.  |  |  |
| RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+ | 21         | I/O<br> <br>  | TTL<br>Analog<br>Analog | Digital I/O. Analog input 3. A/D reference voltage (high) input. |  |  |
| RA4/T0CKI<br>RA4<br>T0CKI            | 28         | I/O<br>I      | ST<br>ST                | Digital I/O.<br>Timer0 external clock input.                     |  |  |
| RA5/AN4/C2INA<br>RA5<br>AN4<br>C2INA | 27         | I/O<br>I<br>— | TTL<br>Analog<br>Analog | Digital I/O.<br>Analog input 4.<br>Comparator 2 input A          |  |  |
| RA6                                  | _          | _             | _                       | See the OSC2/CLKO/RA6 pin.                                       |  |  |
| RA7                                  | _          | -             | _                       | See the OSC1/CLKI/RA7 pin.                                       |  |  |

**Legend:** TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

CMOS = CMOS compatible input or output

Analog = Analog input

= Input

0 = Output

= Power

OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

- 2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.
- 3: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.

**TABLE 1-3:** PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                             | Pin Number | Pin             | Buffer           | Deparintion                                                                                                   |  |  |
|--------------------------------------|------------|-----------------|------------------|---------------------------------------------------------------------------------------------------------------|--|--|
| Pin Name                             | 64-TQFP    | Туре            | Туре             | Description                                                                                                   |  |  |
|                                      |            |                 |                  | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. |  |  |
| RB0/FLT0/INT0<br>RB0<br>FLT0<br>INT0 | 48         | I/O<br>I<br>I   | TTL<br>ST<br>ST  | Digital I/O.<br>ECCP1/2/3 Fault input.<br>External interrupt 0.                                               |  |  |
| RB1/INT1/PMA4<br>RB1<br>INT1<br>PMA4 | 47         | I/O<br>I<br>O   | TTL<br>ST        | Digital I/O.<br>External interrupt 1.<br>Parallel Master Port address.                                        |  |  |
| RB2/INT2/PMA3<br>RB2<br>INT2<br>PMA3 | 46         | I/O<br>I<br>O   | TTL<br>ST        | Digital I/O.<br>External interrupt 2.<br>Parallel Master Port address.                                        |  |  |
| RB3/INT3/PMA2<br>RB3<br>INT3<br>PMA2 | 45         | I/O<br>I<br>O   | TTL<br>ST        | Digital I/O.<br>External interrupt 3.<br>Parallel Master Port address.                                        |  |  |
| RB4/KBI0/PMA1<br>RB4<br>KBI0<br>PMA1 | 44         | I/O<br>I<br>I/O | TTL<br>TTL       | Digital I/O.<br>Interrupt-on-change pin.<br>Parallel Master Port address.                                     |  |  |
| RB5/KBI1/PMA0<br>RB5<br>KBI1<br>PMA0 | 43         | I/O<br>I<br>I/O | TTL<br>TTL       | Digital I/O.<br>Interrupt-on-change pin.<br>Parallel Master Port address.                                     |  |  |
| RB6/KBI2/PGC<br>RB6<br>KBI2<br>PGC   | 42         | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>In-Circuit Debugger and ICSP™ programming clock pin.              |  |  |
| RB7/KBI3/PGD<br>RB7<br>KBI3<br>PGD   | 37         | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>In-Circuit Debugger and ICSP programming data pin.                |  |  |

**Legend:** TTL = TTL compatible input

= CMOS compatible input or output CMOS

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

= Input

= Output

= Power

0 = Open-Drain (no P diode to VDD) OD

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

TABLE 1-3: PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Din Name                                                                          | Pin Number | Pin                  | Buffer           | December 1                                                                                                                               |  |  |  |
|-----------------------------------------------------------------------------------|------------|----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Pin Name                                                                          | 64-TQFP    | Type                 | Туре             | Description                                                                                                                              |  |  |  |
|                                                                                   |            |                      |                  | PORTC is a bidirectional I/O port.                                                                                                       |  |  |  |
| RC0/T10S0/T13CKI<br>RC0<br>T10S0<br>T13CKI                                        | 30         | I/O<br>O<br>I        | ST<br>—<br>ST    | Digital I/O.<br>Timer1 oscillator output.<br>Timer1/Timer3 external clock input.                                                         |  |  |  |
| RC1/T1OSI/ECCP2/P2A<br>RC1<br>T1OSI<br>ECCP2 <sup>(1)</sup><br>P2A <sup>(1)</sup> | 29         | I/O<br>I<br>I/O<br>O | ST<br>CMOS<br>ST | Digital I/O. Timer1 oscillator input. Capture 2 input/Compare 2 output/PWM2 output. ECCP2 PWM output A.                                  |  |  |  |
| RC2/ECCP1/P1A<br>RC2<br>ECCP1<br>P1A                                              | 33         | I/O<br>I/O<br>O      | ST<br>ST         | Digital I/O. Capture 1 input/Compare 1 output/PWM1 output. ECCP1 PWM output A.                                                           |  |  |  |
| RC3/SCK1/SCL1<br>RC3<br>SCK1<br>SCL1                                              | 34         | I/O<br>I/O<br>I/O    | ST<br>ST<br>ST   | Digital I/O.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C™ mode. |  |  |  |
| RC4/SDI1/SDA1<br>RC4<br>SDI1<br>SDA1                                              | 35         | I/O<br>I<br>I/O      | ST<br>ST<br>ST   | Digital I/O.<br>SPI data in.<br>I <sup>2</sup> C data I/O.                                                                               |  |  |  |
| RC5/SDO1/C2OUT<br>RC5<br>SDO1<br>C2OUT                                            | 36         | I/O<br>O<br>O        | ST<br>—<br>TTL   | Digital I/O.<br>SPI data out.<br>Comparator 2 output.                                                                                    |  |  |  |
| RC6/TX1/CK1<br>RC6<br>TX1<br>CK1                                                  | 31         | I/O<br>O<br>I/O      | ST<br>—<br>ST    | Digital I/O.<br>EUSART1 asynchronous transmit.<br>EUSART1 synchronous clock (see related RX1/DT1).                                       |  |  |  |
| RC7/RX1/DT1<br>RC7<br>RX1<br>DT1                                                  | 32         | I/O<br> <br> /O      | ST<br>ST<br>ST   | Digital I/O. EUSART1 asynchronous receive. EUSART1 synchronous data (see related TX1/CK1).                                               |  |  |  |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

I = Input

O = Output

P = Power

OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

TABLE 1-3: PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Din Name                                          | Pin Number | Pin                    | Buffer                | Description                                                                                                                                                  |
|---------------------------------------------------|------------|------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name                                          | 64-TQFP    | Type Type              |                       | Description                                                                                                                                                  |
|                                                   |            |                        |                       | PORTD is a bidirectional I/O port.                                                                                                                           |
| RD0/PMD0<br>RD0<br>PMD0                           | 58         | I/O<br>I/O             | ST<br>TTL             | Digital I/O.<br>Parallel Master Port data.                                                                                                                   |
| RD1/PMD1<br>RD1<br>PMD1                           | 55         | I/O<br>I/O             | ST<br>TTL             | Digital I/O.<br>Parallel Master Port data.                                                                                                                   |
| RD2/PMD2<br>RD2<br>PMD2                           | 54         | I/O<br>I/O             | ST<br>TTL             | Digital I/O.<br>Parallel Master Port data.                                                                                                                   |
| RD3/PMD3<br>RD3<br>PMD3                           | 53         | I/O<br>I/O             | ST<br>TTL             | Digital I/O.<br>Parallel Master Port data.                                                                                                                   |
| RD4/PMD4/SDO2<br>RD4<br>PMD4<br>SDO2              | 52         | I/O<br>I/O<br>O        | ST<br>TTL             | Digital I/O.<br>Parallel Master Port data.<br>SPI data out.                                                                                                  |
| RD5/PMD5/SDI2/SDA2<br>RD5<br>PMD5<br>SDI2<br>SDA2 | 51         | I/O<br>I/O<br>I<br>I/O | ST<br>TTL<br>ST<br>ST | Digital I/O.<br>Parallel Master Port data.<br>SPI data in.<br>I <sup>2</sup> C™ data I/O.                                                                    |
| RD6/PMD6/SCK2/SCL2<br>RD6<br>PMD6<br>SCK2<br>SCL2 | 50         | I/O<br>I/O<br>I/O      | ST<br>TTL<br>ST<br>ST | Digital I/O. Parallel Master Port data. Synchronous serial clock input/output for SPI mode. Synchronous serial clock input/output for I <sup>2</sup> C mode. |
| RD7/PMD7/SS2<br>RD7<br>PMD7<br>SS2                | 49         | I/O<br>I/O<br>I        | ST<br>TTL<br>TTL      | Digital I/O.<br>Parallel Master Port data.<br>SPI slave select input.                                                                                        |

**Legend:** TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

P = Power

evels Analog = Analog input

O = Output

CMOS = CMOS compatible input or output

ower OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

TABLE 1-3: PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Din Nama                                                                        | Pin Number | Pin                  | Buffer             | Description                                                                                                  |  |  |
|---------------------------------------------------------------------------------|------------|----------------------|--------------------|--------------------------------------------------------------------------------------------------------------|--|--|
| Pin Name                                                                        | 64-TQFP    | Туре                 | Type               | Description                                                                                                  |  |  |
|                                                                                 |            |                      |                    | PORTE is a bidirectional I/O port.                                                                           |  |  |
| RE0/PMRD/P2D<br>RE0<br>PMRD<br>P2D                                              | 2          | I/O<br>I/O<br>O      | ST<br>_<br>_       | Digital I/O. Parallel Master Port read strobe. ECCP2 PWM output D.                                           |  |  |
| RE1/PMWR/P2C<br>RE1<br>PMWR<br>P2C                                              | 1          | I/O<br>I/O<br>O      | ST<br>—<br>—       | Digital I/O. Parallel Master Port write strobe. ECCP2 PWM output C.                                          |  |  |
| RE2/PMBE/P2B<br>RE2<br>PMBE<br>P2B                                              | 64         | I/O<br>O<br>O        | ST<br>_<br>_       | Digital I/O.<br>Parallel Master Port byte enable<br>ECCP2 PWM output B.                                      |  |  |
| RE3/PMA13/P3C/REFO<br>RE3<br>PMA13<br>P3C<br>REFO                               | 63         | I/O<br>O<br>O        | ST<br>—<br>—       | Digital I/O. Parallel Master Port address. ECCP3 PWM output C. Reference clock out.                          |  |  |
| RE4/PMA12/P3B<br>RE4<br>PMA12<br>P3B                                            | 62         | I/O<br>O<br>O        | ST<br>—<br>—       | Digital I/O.<br>Parallel Master Port address.<br>ECCP3 PWM output B.                                         |  |  |
| RE5/PMA11/P1C<br>RE5<br>PMA11<br>P1C                                            | 61         | I/O<br>O<br>O        | ST<br>—<br>—       | Digital I/O.<br>Parallel Master Port address.<br>ECCP1 PWM output C.                                         |  |  |
| RE6/PMA10/P1B<br>RE6<br>PMA10<br>P1B                                            | 60         | I/O<br>O<br>O        | ST<br>—<br>—       | Digital I/O.<br>Parallel Master Port address.<br>ECCP1 PWM output B.                                         |  |  |
| RE7/PMA9/ECCP2/P2A<br>RE7<br>PMA9<br>ECCP2 <sup>(2)</sup><br>P2A <sup>(2)</sup> | 59         | I/O<br>O<br>I/O<br>O | ST<br>—<br>ST<br>— | Digital I/O. Parallel Master Port address. Capture 2 input/Compare 2 output/PWM2 output. ECCP2 PWM output A. |  |  |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

I = Input

O = Output

P = Power

OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

**2:** Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

**TABLE 1-3:** PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Din Nama              | Pin Number | Pin      | Buffer       | Description.                                              |  |  |
|-----------------------|------------|----------|--------------|-----------------------------------------------------------|--|--|
| Pin Name              | 64-TQFP    | Туре     | Type         | Description                                               |  |  |
|                       |            |          |              | PORTF is a bidirectional I/O port.                        |  |  |
| RF2/PMA5/AN7/C2INB    | 16         |          |              | 5, ,, ,,,,                                                |  |  |
| RF2                   |            | 1/0      | ST           | Digital I/O.                                              |  |  |
| PMA5<br>AN7           |            | 0<br>1   | —<br>Analog  | Parallel Master Port address. Analog input 7.             |  |  |
| C2INB                 |            | i<br>I   | Analog       | Comparator 2 input B.                                     |  |  |
|                       |            | '        | Allalog      | Comparator 2 input B.                                     |  |  |
| RF3/D-<br>RF3         | 15         | 1        | ST           | Digital input.                                            |  |  |
| D-                    |            | 1/0      | 31           | USB differential minus line (input/output).               |  |  |
|                       |            | 1/0      |              | OOD differential minus line (inputodiput).                |  |  |
| RF4/D+                | 14         |          | СТ           | Digital input                                             |  |  |
| RF4<br>D+             |            | I<br>I/O | ST           | Digital input. USB differential plus line (input/output). |  |  |
| _                     |            | 1/0      |              | 000 differential plus liffe (input/output).               |  |  |
| RF5/AN10/C1INB/CVREF  | 13         |          | ОТ           | Birthia                                                   |  |  |
| RF5<br>AN10           |            | !        | ST<br>Analog | Digital input. Analog input 10.                           |  |  |
| C1INB                 |            | 1        | Analog       | Comparator 1 input B.                                     |  |  |
| CVREF                 |            | Ó        | Analog       | Comparator reference voltage output.                      |  |  |
|                       | 40         | •        | 7            | - Comparator rotorono rotago catpati                      |  |  |
| RF6/AN11/C1INA<br>RF6 | 12         | I/O      | ST           | Digital I/O.                                              |  |  |
| AN11                  |            | 1/0      | Analog       | Analog input 11.                                          |  |  |
| C1INA                 |            | i        | Analog       | Comparator 1 input A.                                     |  |  |
| RF7/SS1/C1OUT         | 11         | •        |              |                                                           |  |  |
| RF7/551/C1001         | 11         | I/O      | ST           | Digital I/O.                                              |  |  |
| SS1                   |            | 1/0      | TTL          | SPI slave select input.                                   |  |  |
| C1OUT                 |            | Ö        | TTL          | Comparator 1 output.                                      |  |  |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

0

= Input = Power

= Output OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

- 2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.
- 3: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.

TABLE 1-3: PIC18F6XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                                          | Pin Number    | Pin                  | Buffer              | Description                                                                                                                                                                                |
|---------------------------------------------------|---------------|----------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name                                          | 64-TQFP       | Type                 | Type                | Description                                                                                                                                                                                |
|                                                   |               |                      |                     | PORTG is a bidirectional I/O port.                                                                                                                                                         |
| RG0/PMA8/ECCP3/P3A<br>RG0<br>PMA8<br>ECCP3<br>P3A | 3             | I/O<br>O<br>I/O<br>O | ST<br>—<br>—        | Digital I/O. Parallel Master Port address. Capture 3 input/Compare 3 output/PWM3 output. ECCP3 PWM output A.                                                                               |
| RG1/PMA7/TX2/CK2<br>RG1<br>PMA7<br>TX2<br>CK2     | 4             | I/O<br>O<br>O<br>I/O | ST<br>—<br>—<br>ST  | Digital I/O. Parallel Master Port address. EUSART2 asynchronous transmit. EUSART2 synchronous clock (see related RX2/DT2).                                                                 |
| RG2/PMA6/RX2/DT2<br>RG2<br>PMA6<br>RX2<br>DT2     | 5             | I/O<br>O<br>I<br>I/O | ST<br>—<br>ST<br>ST | Digital I/O. Parallel Master Port address. EUSART2 asynchronous receive. EUSART2 synchronous data (see related TX2/CK2).                                                                   |
| RG3/PMCS1/CCP4/P3D<br>RG3<br>PMCS1<br>CCP4<br>P3D | 6             | I/O<br>O<br>I/O<br>O | ST<br>—<br>ST<br>—  | Digital I/O. Parallel Master Port chip select 1. Capture 4 input/Compare 4 output/PWM4 output. ECCP3 PWM output D.                                                                         |
| RG4/PMCS2/CCP5/P1D<br>RG4<br>PMCS2<br>CCP5<br>P1D | 8             | I/O<br>O<br>I/O<br>O | ST<br>—<br>ST<br>—  | Digital I/O. Parallel Master Port chip select 2. Capture 5 input/Compare 5 output/PWM5 output. ECCP1 PWM output D.                                                                         |
| Vss                                               | 9, 25, 41, 56 | Р                    | _                   | Ground reference for logic and I/O pins.                                                                                                                                                   |
| VDD                                               | 26, 38, 57    | Р                    | _                   | Positive supply for peripheral digital logic and I/O pins.                                                                                                                                 |
| AVss                                              | 20            | Р                    | _                   | Ground reference for analog modules.                                                                                                                                                       |
| AVDD                                              | 19            | Р                    | _                   | Positive supply for analog modules.                                                                                                                                                        |
| ENVREG                                            | 18            | I                    | ST                  | Enable for on-chip voltage regulator.                                                                                                                                                      |
| VDDCORE/VCAP<br>VDDCORE<br>VCAP                   | 10            | P<br>P               | _                   | Core logic power or external filter capacitor connection.  Positive supply for microcontroller core logic (regulator disabled).  External filter capacitor connection (regulator enabled). |
| Vusb                                              | 17            | Р                    | _                   | USB voltage input pin.                                                                                                                                                                     |

Legend: TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

I = Input

O = Output

P = Power

OD = Open-Drain (no P diode to VDD)

Note 1: Default assignment for ECCP2/P2A when CCP2MX Configuration bit is set.

2: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared.

TABLE 1-4: PIC18F8XJ5X PINOUT I/O DESCRIPTIONS

| Pin Name              | Pin Number | Pin<br>Type | Buffer<br>Type | Description                                                                                                                                                |
|-----------------------|------------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | 80-TQFP    |             |                |                                                                                                                                                            |
| MCLR                  | 9          | I           | ST             | Master Clear (Reset) input. This pin is an active-low Reset to the device.                                                                                 |
| OSC1/CLKI/RA7<br>OSC1 | 49         | I           | ST             | Oscillator crystal or external clock input. Oscillator crystal input or external clock source input. ST buffer when configured in RC mode; CMOS otherwise. |
| CLKI                  |            | I           | CMOS           | Main oscillator input connection.  External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, OSC2/CLKO pins.)         |
| RA7 <sup>(8)</sup>    |            | I/O         | TTL            | Main clock input connection.  General purpose I/O pin.                                                                                                     |
| OSC2/CLKO/RA6         | 50         |             |                | Oscillator crystal or clock output.                                                                                                                        |
| OSC2                  |            | 0           | _              | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode.                                                                    |
| CLKO                  |            | 0           | _              | Main oscillator feedback output connection. In RC mode, OSC2 pin outputs CLKO which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate.  |
| RA6 <sup>(8)</sup>    |            | I/O         | TTL            | System cycle clock output (Fosc/4).  General purpose I/O pin.                                                                                              |

**Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels Analog = Analog input
I = Input O = Output

P = Power OD = Open-Drain (no P diode to VDD)

**Note 1:** Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared (Extended Microcontroller mode).

- 2: Default assignment for ECCP2/P2A for all devices in all operating modes (CCP2MX is set).
- 3: Default assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is set).
- 4: Alternate assignment for ECCP2/P2A when CCP2MX is cleared (Microcontroller mode).
- **5:** Alternate assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is cleared).
- **6:** Pin placement when PMPMX = 1.
- 7: Pin placement when PMPMX = 0.
- 8: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.

**TABLE 1-4:** PIC18F8XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                                                         | Pin Number | Pin<br>Type     | Buffer<br>Type                 | Description                                                                            |
|------------------------------------------------------------------|------------|-----------------|--------------------------------|----------------------------------------------------------------------------------------|
|                                                                  | 80-TQFP    |                 |                                |                                                                                        |
|                                                                  |            |                 |                                | PORTA is a bidirectional I/O port.                                                     |
| RA0/AN0<br>RA0<br>AN0                                            | 30         | I/O<br>I        | TTL<br>Analog                  | Digital I/O.<br>Analog input 0.                                                        |
| RA1/AN1<br>RA1<br>AN1                                            | 29         | I/O<br>I        | TTL<br>Analog                  | Digital I/O.<br>Analog input 1.                                                        |
| RA2/AN2/VREF-<br>RA2<br>AN2<br>VREF-                             | 28         | I/O<br>I<br>I   | TTL<br>Analog<br>Analog        | Digital I/O.<br>Analog input 2.<br>A/D reference voltage (low) input.                  |
| RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+                             | 27         | I/O<br>I<br>I   | TTL<br>Analog<br>Analog        | Digital I/O.<br>Analog input 3.<br>A/D reference voltage (high) input.                 |
| RA4/PMD5/T0CKI<br>RA4<br>PMD5 <sup>(7)</sup><br>T0CKI            | 34         | I/O<br>I/O<br>I | ST<br>TTL<br>ST                | Digital I/O.<br>Parallel Master Port data.<br>Timer0 external clock input.             |
| RA5/PMD4/AN4/C2INA<br>RA5<br>PMD4 <sup>(7)</sup><br>AN4<br>C2INA | 33         | I/O<br>I/O<br>I | TTL<br>TTL<br>Analog<br>Analog | Digital I/O.<br>Parallel Master Port data.<br>Analog input 4.<br>Comparator 2 input A. |
| RA6                                                              | _          | _               | _                              | See the OSC2/CLKO/RA6 pin.                                                             |
| RA7                                                              | _          | _               | _                              | See the OSC1/CLKI/RA7 pin.                                                             |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

= Input

= Output 0

= Power

OD = Open-Drain (no P diode to VDD)

- Note 1: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared (Extended Microcontroller
  - 2: Default assignment for ECCP2/P2A for all devices in all operating modes (CCP2MX is set).
  - 3: Default assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is set).
  - 4: Alternate assignment for ECCP2/P2A when CCP2MX is cleared (Microcontroller mode).
  - 5: Alternate assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is cleared).
  - **6:** Pin placement when PMPMX = 1.
  - 7: Pin placement when PMPMX = 0.
  - 8: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.

**TABLE 1-4:** PIC18F8XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                                                                                         | Pin Number | Pin<br>Type          | Buffer<br>Type       | Description                                                                                                                        |
|--------------------------------------------------------------------------------------------------|------------|----------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                  | 80-TQFP    |                      |                      |                                                                                                                                    |
|                                                                                                  |            |                      |                      | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs.                      |
| RB0/FLT0/INT0<br>RB0<br>FLT0<br>INT0                                                             | 58         | I/O<br>I<br>I        | TTL<br>ST<br>ST      | Digital I/O.<br>ECCP1/2/3 Fault input.<br>External interrupt 0.                                                                    |
| RB1/INT1/PMA4<br>RB1<br>INT1<br>PMA4                                                             | 57         | I/O<br>I<br>O        | TTL<br>ST            | Digital I/O.<br>External interrupt 1.<br>Parallel Master Port address.                                                             |
| RB2/INT2/PMA3<br>RB2<br>INT2<br>PMA3                                                             | 56         | I/O<br>I<br>O        | TTL<br>ST            | Digital I/O.<br>External interrupt 2.<br>Parallel Master Port address.                                                             |
| RB3/INT3/ECCP2/<br>P2A/PMA2<br>RB3<br>INT3<br>ECCP2 <sup>(1)</sup><br>P2A <sup>(1)</sup><br>PMA2 | 55         | I/O<br>I<br>I/O<br>O | TTL<br>ST<br>ST<br>— | Digital I/O. External interrupt 3. Capture 2 input/Compare 2 output/PWM2 output. ECCP2 PWM output A. Parallel Master Port address. |
| RB4/KBI0/PMA1<br>RB4<br>KBI0<br>PMA1                                                             | 54         | I/O<br>I<br>I/O      | TTL<br>TTL           | Digital I/O.<br>Interrupt-on-change pin.<br>Parallel Master Port address.                                                          |
| RB5/KBI1/PMA0<br>RB5<br>KBI1<br>PMA0                                                             | 53         | I/O<br>I<br>I/O      | TTL<br>TTL           | Digital I/O.<br>Interrupt-on-change pin.<br>Parallel Master Port address.                                                          |
| RB6/KBI2/PGC<br>RB6<br>KBI2<br>PGC                                                               | 52         | I/O<br>I<br>I/O      | TTL<br>TTL<br>ST     | Digital I/O.<br>Interrupt-on-change pin.<br>In-Circuit Debugger and ICSP™ programming clock pin.                                   |
| RB7/KBI3/PGD<br>RB7<br>KBI3<br>PGD                                                               | 47         | I/O<br>I<br>I/O      | TTL<br>TTL<br>ST     | Digital I/O. Interrupt-on-change pin. In-Circuit Debugger and ICSP programming data pin.                                           |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels = Input

Analog = Analog input

= Power

0 = Output

OD = Open-Drain (no P diode to VDD)

Note 1: Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared (Extended Microcontroller mode).

- 2: Default assignment for ECCP2/P2A for all devices in all operating modes (CCP2MX is set).
- 3: Default assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is set).
- 4: Alternate assignment for ECCP2/P2A when CCP2MX is cleared (Microcontroller mode).
- 5: Alternate assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is cleared).
- **6:** Pin placement when PMPMX = 1.
- 7: Pin placement when PMPMX = 0.
- 8: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.

TABLE 1-4: PIC18F8XJ5X PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                                                                          | Pin Number | Pin<br>Type          | Buffer<br>Type   | Description                                                                                                                              |
|-----------------------------------------------------------------------------------|------------|----------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                   | 80-TQFP    |                      |                  |                                                                                                                                          |
|                                                                                   |            |                      |                  | PORTC is a bidirectional I/O port.                                                                                                       |
| RC0/T10S0/T13CKI<br>RC0<br>T10S0<br>T13CKI                                        | 36         | I/O<br>O<br>I        | ST<br>—<br>ST    | Digital I/O.<br>Timer1 oscillator output.<br>Timer1/Timer3 external clock input.                                                         |
| RC1/T1OSI/ECCP2/P2A<br>RC1<br>T1OSI<br>ECCP2 <sup>(2)</sup><br>P2A <sup>(2)</sup> | 35         | I/O<br>I<br>I/O<br>O | ST<br>CMOS<br>ST | Digital I/O. Timer1 oscillator input. Capture 2 input/Compare 2 output/PWM2 output. ECCP2 PWM output A.                                  |
| RC2/ECCP1/P1A<br>RC2<br>ECCP1<br>P1A                                              | 43         | I/O<br>I/O<br>O      | ST<br>ST         | Digital I/O. Capture 1 input/Compare 1 output/PWM1 output. ECCP1 PWM output A.                                                           |
| RC3/SCK1/SCL1<br>RC3<br>SCK1<br>SCL1                                              | 44         | I/O<br>I/O<br>I/O    | ST<br>ST<br>ST   | Digital I/O.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C™ mode. |
| RC4/SDI1/SDA1<br>RC4<br>SDI1<br>SDA1                                              | 45         | I/O<br>I<br>I/O      | ST<br>ST<br>ST   | Digital I/O.<br>SPI data in.<br>I <sup>2</sup> C data I/O.                                                                               |
| RC5/SDO1/C2OUT<br>RC5<br>SDO1<br>C2OUT                                            | 46         | I/O<br>O<br>O        | ST<br>—<br>TTL   | Digital I/O.<br>SPI data out.<br>Comparator 2 output.                                                                                    |
| RC6/TX1/CK1<br>RC6<br>TX1<br>CK1                                                  | 37         | I/O<br>O<br>I/O      | ST<br>—<br>ST    | Digital I/O.<br>EUSART1 asynchronous transmit.<br>EUSART1 synchronous clock (see related RX1/DT1).                                       |
| RC7/RX1/DT1<br>RC7<br>RX1<br>DT1                                                  | 38         | I/O<br>I<br>I/O      | ST<br>ST<br>ST   | Digital I/O. EUSART1 asynchronous receive. EUSART1 synchronous data (see related TX1/CK1).                                               |

**Legend:** TTL = TTL compatible input

CMOS = CMOS compatible input or output

ST = Schmitt Trigger input with CMOS levels

Analog = Analog input

I = Input

O = Output

P = Power

OD = Open-Drain (no P diode to VDD)

**Note 1:** Alternate assignment for ECCP2/P2A when CCP2MX Configuration bit is cleared (Extended Microcontroller mode).

- 2: Default assignment for ECCP2/P2A for all devices in all operating modes (CCP2MX is set).
- 3: Default assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is set).
- 4: Alternate assignment for ECCP2/P2A when CCP2MX is cleared (Microcontroller mode).
- 5: Alternate assignments for P1B/P1C/P3B/P3C (ECCPMX Configuration bit is cleared).
- **6:** Pin placement when PMPMX = 1.
- 7: Pin placement when PMPMX = 0.
- 8: RA7 and RA6 will be disabled if OSC1 and OSC2 are used for the clock function.