# PIC18F8723 Family Data Sheet 64/80-Pin, 1-Mbit, Enhanced Flash Microcontrollers with 12-Bit A/D and 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, 1-Mbit, Enhanced Flash Microcontrollers with 12-Bit A/D and nanoWatt Technology ### Peripheral Highlights: - 12-Bit, Up to 16-Channel Analog-to-Digital Converter module (A/D): - Auto-acquisition capability - Conversion available during Sleep - Two Master Synchronous Serial Port (MSSP) modules supporting 2/3/4-Wire SPI (all four modes) and I<sup>2</sup>C™ Master and Slave modes - 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 Enhanced Addressable USART modules: - Supports RS-485, RS-232 and LIN 1.2 - Auto-wake-up on Start bit - Auto-Baud Detect - · Dual Analog Comparators with Input Multiplexing - · High-Current Sink/Source 25 mA/25 mA - · Four Programmable External Interrupts - · Four Input Change Interrupts #### **External Memory Interface:** - · Address Capability of Up to 2 Mbytes - · 8-Bit or 16-Bit Interface - · 8, 12, 16 and 20-Bit Address modes #### **Power-Managed Modes:** - · Run: CPU on, Peripherals on - · Idle: CPU off, Peripherals on - · Sleep: CPU off, Peripherals off - Idle mode Currents Down to 15 μA Typical - Sleep Current Down to 0.2 μA Typical - Timer1 Oscillator: 1.8 μA, 32 kHz, 2V - Watchdog Timer: 2.1 μA #### **Special Microcontroller Features:** - · C Compiler Optimized Architecture: - Optional extended instruction set designed to optimize re-entrant code - 100,000 Erase/Write Cycle Enhanced Flash Program Memory Typical - 1,000,000 Erase/Write Cycle Data EEPROM Memory Typical - Flash/Data EEPROM Retention: 100 Years Typical - · Self-Programmable under Software Control - · Priority Levels for Interrupts - 8 x 8 Single-Cycle Hardware Multiplier - Extended Watchdog Timer (WDT): - Programmable period from 4 ms to 131s - Single-Supply In-Circuit Serial Programming™ (ICSP™) via Two Pins - · In-Circuit Debug (ICD) via Two Pins - · Wide Operating Voltage Range: 2.0V to 5.5V - · Fail-Safe Clock Monitor - · Two-Speed Oscillator Start-up - · nanoWatt Technology Note: This document is supplemented by the "PIC18F8722 Family Data Sheet" (DS39646). See Section 1.0 "Device Overview". | | Prog | ram Memory | Data | Data Memory | | | CCP/ | MSSP | | RT | rators | , ± | <u> </u> | | |------------|------------------|-------------------------------|-----------------|-------------------|-----|--------------------|---------------|------|-----|-----------------------------|--------|---------|--------------------|----------------| | Device | Flash<br>(bytes) | # Single-Word<br>Instructions | SRAM<br>(bytes) | EEPROM<br>(bytes) | I/O | 12-Bit<br>A/D (ch) | ECCP<br>(PWM) | | SPI | Master<br>I <sup>2</sup> C™ | EUSAR | Compara | Timers<br>8/16-Bit | Externa<br>Bus | | PIC18F6628 | 96K | 49152 | 3936 | 1024 | 54 | 12 | 2/3 | 2 | Υ | Υ | 2 | 2 | 2/3 | N | | PIC18F6723 | 128K | 65536 | 3936 | 1024 | 54 | 12 | 2/3 | 2 | Υ | Υ | 2 | 2 | 2/3 | N | | PIC18F8628 | 96K | 49152 | 3936 | 1024 | 70 | 16 | 2/3 | 2 | Υ | Υ | 2 | 2 | 2/3 | Υ | | PIC18F8723 | 128K | 65536 | 3936 | 1024 | 70 | 16 | 2/3 | 2 | Υ | Υ | 2 | 2 | 2/3 | Υ | ### PIC18F8723 ### **Table of Contents** | 1.0 | Device Overview | 9 | |-------|-------------------------------------------------------|----| | 2.0 | 12-Bit Analog-to-Digital Converter (A/D) Module | 31 | | 3.0 | Special Features of the CPU | 41 | | 4.0 | Electrical Characteristics | 43 | | 5.0 | Packaging Information | | | Appe | endix A: Revision History | 51 | | | endix B: Device Differences | | | Appe | endix C: Conversion Considerations | 52 | | Appe | endix D: Migration From Baseline to Enhanced Devices | 52 | | Appe | endix E: Migration From Mid-Range to Enhanced Devices | 53 | | Appe | endix F: Migration From High-End to Enhanced Devices | 53 | | | C | | | The I | Microchip Web Site | 57 | | Cust | omer Change Notification Service | 57 | | Cust | omer Support | 57 | | Read | omer Supportler Response | 58 | | | 8F8723 family Product Identification System | | ### 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. ### PIC18F8723 NOTES: #### 1.0 DEVICE OVERVIEW This document contains device-specific information for the following devices: PIC18F6628 PIC18F6628 PIC18F6723 PIC18F8628 PIC18F8628 PIC18F8723 PIC18LF8723 Note: This data sheet documents only the devices' features and specifications that are in addition to the features and specifications of the PIC18F8722 family devices. For information on the features and specifications shared by the PIC18F8723 family and PIC18F8722 family devices, see the "PIC18F8722 Family Data Sheet" (DS39646). The PIC18F8723 family of devices offers the advantages of all PIC18 microcontrollers – namely, high computational performance at an economical price – with the addition of high-endurance, Enhanced Flash program memory. In addition to these features, the PIC18F8723 introduces design enhancements that make these microcontrollers a logical choice for many high-performance, power-sensitive applications. #### 1.1 Special Features 12-Bit A/D Converter: The PIC18F8723 family implements a 12-bit A/D Converter. A/D Converters in both families incorporate programmable acquisition time. This allows for a channel to be selected and a conversion to be initiated, without waiting for a sampling period and thus, reducing code overhead. ### 1.2 Details on Individual Family Members Devices in the PIC18F8723 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 the following ways: - Flash program memory (96 Kbytes for PIC18FX628 devices and 128 Kbytes for PIC18FX723). - A/D channels (12 for PIC18F6628/6723 devices and 16 for PIC18F8628/8723 devices). - I/O ports (seven bidirectional ports on PIC18F6628/6723 devices and nine bidirectional ports on PIC18F8628/8723 devices). - External Memory Bus, configurable for 8 and 16-bit operation All other features for devices in this family are identical. These are summarized in Table 1-1. The pinouts for all devices are listed in Table 1-2 and Table 1-3. Like all Microchip PIC18 devices, members of the PIC18F8723 family are available as both standard and low-voltage devices. Standard devices with Enhanced Flash memory, designated with an "F" in the part number (such as PIC18F6628), accommodate an operating VDD range of 4.2V to 5.5V. Low-voltage parts, designated by "LF" (such as PIC18LF6628), function over an extended VDD range of 2.0V to 5.5V. TABLE 1-1: DEVICE FEATURES | Features | PIC18F6628 | PIC18F6723 | PIC18F8628 | PIC18F8723 | | | |------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|--| | Operating Frequency | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | | | | Program Memory (Bytes) | 96K | 128K | 96K | 128K | | | | Program Memory (Instructions) | 49152 | 65536 | 49152 | 65536 | | | | Data Memory (Bytes) | 3936 | 3936 | 3936 | 3936 | | | | Data EEPROM Memory (Bytes) | 1024 | 1024 | 1024 | 1024 | | | | Interrupt Sources | 28 | 28 | 29 | 29 | | | | I/O Ports | Ports A, B, C, D, E, F, G | Ports A, B, C, D, E, F, G | Ports A, B, C, D, E,<br>F, G, H, J | Ports A, B, C, D, E,<br>F, G, H, J | | | | Timers | 5 | 5 | 5 | 5 | | | | Capture/Compare/PWM<br>Modules | 2 | 2 | 2 | 2 | | | | Enhanced Capture/Compare/<br>PWM Modules | · | | 3 | 3 | | | | Enhanced USART | 2 | 2 | 2 | 2 | | | | Serial Communications | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | | | | Parallel Communications (PSP) | Yes | Yes | Yes | Yes | | | | 12-Bit Analog-to-Digital Module | 12 Input Channels | 12 Input Channels | 16 Input Channels | 16 Input Channels | | | | Resets (and Delays) | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | | | | Programmable<br>High/Low-Voltage Detect | Yes | Yes | Yes | Yes | | | | Programmable Brown-out<br>Reset | Yes | Yes | Yes | Yes | | | | Instruction Set | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set Enabled | | | | Packages | 64-Pin TQFP | 64-Pin TQFP | 80-Pin TQFP | 80-Pin TQFP | | | © 2009 Microchip Technology Inc. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS | Pin Name | Pin Number | Pin | Buffer | Description | |-----------------------------|------------|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pili Name | TQFP | Туре | Туре | Description | | RG5/MCLR/VPP<br>RG5<br>MCLR | 7 | <br> | ST<br>ST | Master Clear (input) or programming voltage (input). Digital input. Master Clear (Reset) input. This pin is an active-low Reset to the device. | | VPP | | Р | | Programming voltage input. | | 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 | External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, OSC2/CLKO pins.) | | RA7 | | I/O | TTL | 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 | _ | In RC mode, OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate. | | RA6 | | I/O | TTL | General purpose I/O pin. | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Dire Nove | Pin Number | Pin | Buffer | D | | | |----------------------------------------|------------|---------------|-------------------------|-------------------------------------------------------------------|--|--| | Pin Name | 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>I<br>I | 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/HLVDIN<br>RA5<br>AN4<br>HLVDIN | 27 | I/O<br>I<br>I | TTL<br>Analog<br>Analog | Digital I/O.<br>Analog input 4.<br>High/Low-Voltage Detect input. | | | | 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 I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | | |--------------------------------------|------------|-----------------|------------------|---------------------------------------------------------------------------------------------------------------|--|--|--| | Pili Name | TQFP | Type | Туре | Description | | | | | | | | | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | | | | RB0/INT0/FLT0<br>RB0<br>INT0<br>FLT0 | 48 | I/O<br> <br> | TTL<br>ST<br>ST | Digital I/O.<br>External interrupt 0.<br>PWM Fault input for ECCPx. | | | | | RB1/INT1<br>RB1<br>INT1 | 47 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External interrupt 1. | | | | | RB2/INT2<br>RB2<br>INT2 | 46 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External interrupt 2. | | | | | RB3/INT3<br>RB3<br>INT3 | 45 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External interrupt 3. | | | | | RB4/KBI0<br>RB4<br>KBI0 | 44 | I/O<br>I | TTL<br>TTL | Digital I/O.<br>Interrupt-on-change pin. | | | | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 43 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>Low-Voltage ICSP™ Programming enable pin. | | | | | 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 = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input I = Input O = Output P = Power $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | | |--------------------------------------------|------------|-------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pin Name | TQFP | Type | 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. Timer1 oscillator output. Timer1/Timer3 external clock input. | | | | | RC1/T1OSI/ECCP2/<br>P2A | 29 | | | | | | | | RC1<br>T1OSI<br>ECCP2 <sup>(1)</sup> | | I/O<br>I<br>I/O | ST<br>CMOS<br>ST | Digital I/O. Timer1 oscillator input. Enhanced Capture 2 input/Compare 2 output/ PWM2 output. | | | | | P2A <sup>(1)</sup> | | 0 | _ | ECCP2 PWM output A. | | | | | RC2/ECCP1/P1A<br>RC2<br>ECCP1 | 33 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 1 input/Compare 1 output/ PWM1 output. | | | | | P1A | | 0 | _ | 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<br>RC5<br>SDO1 | 36 | I/O<br>O | ST<br>— | Digital I/O.<br>SPI data out. | | | | | RC6/TX1/CK1<br>RC6<br>TX1<br>CK1 | 31 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART1 asynchronous transmit. EUSART1 synchronous clock (see related RX1/DT1). | | | | | RC7/RX1/DT1<br>RC7<br>RX1<br>DT1 | 32 | 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 I = Input Analog = Analog input P = Power O = Output $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | |-------------------------------------------------------|------------|-------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Pili Name | TQFP | Type | Туре | Description | | | | | | | | PORTD is a bidirectional I/O port. | | | | RD0/PSP0<br>RD0<br>PSP0 | 58 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data. | | | | RD1/PSP1<br>RD1<br>PSP1 | 55 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data. | | | | RD2/PSP2<br>RD2<br>PSP2 | 54 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data. | | | | RD3/PSP3<br>RD3<br>PSP3 | 53 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data. | | | | RD4/PSP4/SDO2<br>RD4<br>PSP4<br>SDO2 | 52 | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.<br>SPI data out. | | | | RD5/PSP5/SDI2/<br>SDA2<br>RD5<br>PSP5<br>SDI2<br>SDA2 | 51 | I/O<br>I/O<br>I | ST<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>Parallel Slave Port data.<br>SPI data in.<br>I <sup>2</sup> C™ data I/O. | | | | RD6/PSP6/SCK2/<br>SCL2<br>RD6<br>PSP6<br>SCK2<br>SCL2 | 50 | I/O<br>I/O<br>I/O | ST<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>Parallel Slave Port data.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C mode. | | | | RD7/PSP7/SS2<br>RD7<br>PSP7<br>SS2 | 49 | I/O<br>I/O<br>I | ST<br>TTL<br>TTL | Digital I/O.<br>Parallel Slave Port data.<br>SPI slave select input. | | | 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 $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nome | Pin Number | Pin | Buffer | Description | | | |----------------------------------------------|------------|---------------|----------------|-------------------------------------------------------------------------------------|--|--| | Pin Name | TQFP | Type | Туре | | | | | | | | | PORTE is a bidirectional I/O port. | | | | RE0/RD/P2D<br>RE0<br>RD<br>P2D | 2 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O.<br>Read control for Parallel Slave Port.<br>ECCP2 PWM output D. | | | | RE1/WR/P2C<br>RE1<br>WR<br>P2C | 1 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O. Write control for Parallel Slave Port. ECCP2 PWM output C. | | | | RE2/CS/P2B<br>RE2<br>CS<br>P2B | 64 | I/O<br>I<br>O | ST<br>TTL<br>— | Digital I/O.<br>Chip select control for Parallel Slave Port.<br>ECCP2 PWM output B. | | | | RE3/P3C<br>RE3<br>P3C | 63 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP3 PWM output C. | | | | RE4/P3B<br>RE4<br>P3B | 62 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP3 PWM output B. | | | | RE5/P1C<br>RE5<br>P1C | 61 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP1 PWM output C. | | | | RE6/P1B<br>RE6<br>P1B | 60 | I/O<br>O | ST<br>— | Digital I/O.<br>ECCP1 PWM output B. | | | | RE7/ECCP2/P2A<br>RE7<br>ECCP2 <sup>(2)</sup> | 59 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 2 input/Compare 2 output/ PWM2 output. | | | | P2A <sup>(2)</sup> | | 0 | _ | 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 P = Power O = Output $I^2C^{TM}$ = $I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | | |----------------------------------------|------------|---------------|------------------------|--------------------------------------------------------------------------|--|--|--| | Pin Name | TQFP | Туре | Туре | Description | | | | | | | | | PORTF is a bidirectional I/O port. | | | | | RF0/AN5<br>RF0<br>AN5 | 18 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 5. | | | | | RF1/AN6/C2OUT<br>RF1<br>AN6<br>C2OUT | 17 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 6.<br>Comparator 2 output. | | | | | RF2/AN7/C1OUT<br>RF2<br>AN7<br>C1OUT | 16 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O. Analog input 7. Comparator 1 output. | | | | | RF3/AN8<br>RF3<br>AN8 | 15 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 8. | | | | | RF4/AN9<br>RF4<br>AN9 | 14 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 9. | | | | | RF5/AN10/CVREF<br>RF5<br>AN10<br>CVREF | 13 | I/O<br>I<br>O | ST<br>Analog<br>Analog | Digital I/O.<br>Analog input 10.<br>Comparator reference voltage output. | | | | | RF6/AN11<br>RF6<br>AN11 | 12 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 11. | | | | | RF7/SS1<br>RF7<br>SS1 | 11 | I/O<br>I | ST<br>TTL | Digital I/O.<br>SPI slave select input. | | | | **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 $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F6628/6723 (64-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | | |------------------------------------|----------------|-----------------|----------------|----------------------------------------------------------------------------------------------|--|--|--| | Pin Name | TQFP | Туре | Type | Description | | | | | | | | | PORTG is a bidirectional I/O port. | | | | | RG0/ECCP3/P3A<br>RG0<br>ECCP3 | 3 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 3 input/Compare 3 output/ PWM3 output. | | | | | P3A | | 0 | _ | ECCP3 PWM output A. | | | | | RG1/TX2/CK2<br>RG1<br>TX2<br>CK2 | 4 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART2 asynchronous transmit. EUSART2 synchronous clock (see related RX2/DT2). | | | | | RG2/RX2/DT2<br>RG2<br>RX2<br>DT2 | 5 | I/O<br>I<br>I/O | ST<br>ST<br>ST | Digital I/O. EUSART2 asynchronous receive. EUSART2 synchronous data (see related TX2/CK2). | | | | | RG3/CCP4/P3D<br>RG3<br>CCP4<br>P3D | 6 | I/O<br>I/O<br>O | ST<br>ST | Digital I/O. Capture 4 input/Compare 4 output/PWM4 output. ECCP3 PWM output D. | | | | | RG4/CCP5/P1D<br>RG4<br>CCP5<br>P1D | 8 | I/O<br>I/O<br>O | ST<br>ST | Digital I/O.<br>Capture 5 input/Compare 5 output/PWM5 output.<br>ECCP1 PWM output D. | | | | | RG5 | | | | See RG5/MCLR/VPP pin. | | | | | Vss | 9, 25, 41, 56 | Р | _ | Ground reference for logic and I/O pins. | | | | | VDD | 10, 26, 38, 57 | Р | _ | Positive supply for logic and I/O pins. | | | | | AVss | 20 | Р | | Ground reference for analog modules. | | | | | AVDD | 19 | Р | _ | Positive supply for analog modules. | | | | **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 $I^2C^{TM} = I^2C/SMBus$ input buffer Note 1: Default assignment for ECCP2 when Configuration bit, CCP2MX, is set. TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS | Pin Name | Pin Number | Pin | Buffer | Description | | | |-----------------------|------------|------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Pili Name | TQFP | Type | Туре | Description | | | | RG5/MCLR/Vpp<br>RG5 | 9 | ı | ST | Master Clear (input) or programming voltage (input). Digital input. | | | | MCLR | | I | ST | Master Clear (Reset) input. This pin is an active-low Reset to the device. | | | | VPP | | Р | | Programming voltage input. | | | | 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 | | | | CLKI | | I | CMOS | otherwise. External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, | | | | RA7 | | I/O | TTL | OSC2/CLKO pins.) General purpose I/O pin. | | | | OSC2/CLKO/RA6<br>OSC2 | 50 | 0 | _ | Oscillator crystal or clock output. Oscillator crystal output. Connects to crystal or | | | | CLKO | | 0 | _ | resonator in Crystal Oscillator mode. In RC mode, OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate. | | | | RA6 | | I/O | TTL | General purpose I/O pin. | | | Legend:TTL =TTL compatible inputCMOS =CMOS compatible input or outputST =Schmitt Trigger input with CMOS levelsAnalog =Analog inputI =InputO =OutputP =Power $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). **TABLE 1-3:** PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Die Name | Pin Number | Pin Buffer | | B | | | |----------------------------------------|------------|---------------|-------------------------|------------------------------------------------------------------------|--|--| | Pin Name | TQFP Type | | Type | Description | | | | | | | | 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. Analog input 2. 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/T0CKI<br>RA4<br>T0CKI | 34 | I/O<br>I | ST<br>ST | Digital I/O.<br>Timer0 external clock input. | | | | RA5/AN4/HLVDIN<br>RA5<br>AN4<br>HLVDIN | 33 | I/O<br>I<br>I | TTL<br>Analog<br>Analog | Digital I/O.<br>Analog input 4.<br>High/Low-Voltage Detect input. | | | | 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 = Input = Power CMOS = CMOS compatible input or output Analog = Analog input = Output $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - **5:** Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). **TABLE 1-3:** PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | 11010101010101 | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | |-----------------------------------------------------------|------------|-----------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------|--| | Pin Name | Pin Number | Pin | Buffer | Description | | | 1 III Name | TQFP | Type | Туре | Description | | | | | | | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | | RB0/INT0/FLT0<br>RB0<br>INT0<br>FLT0 | 58 | I/O<br>I<br>I | TTL<br>ST<br>ST | Digital I/O. External interrupt 0. PWM Fault input for ECCPx. | | | RB1/INT1<br>RB1<br>INT1 | 57 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External interrupt 1. | | | RB2/INT2<br>RB2<br>INT2 | 56 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External interrupt 2. | | | RB3/INT3/ECCP2/P2A<br>RB3<br>INT3<br>ECCP2 <sup>(1)</sup> | 55 | I/O<br>I<br>O | TTL<br>ST<br>— | Digital I/O. External interrupt 3. Enhanced Capture 2 input/Compare 2 output/ PWM2 output. | | | P2A <sup>(1)</sup> | | 0 | _ | ECCP2 PWM output A. | | | RB4/KBI0<br>RB4<br>KBI0 | 54 | I/O<br>I | TTL<br>TTL | Digital I/O.<br>Interrupt-on-change pin. | | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 53 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>Low-Voltage ICSP™ Programming enable pin. | | | 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 input Analog = Output $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer = Power - Note 1: Alternate assignment for ECCP2 when Configuration bit, CCP2MX, is cleared (all operating modes except Microcontroller mode). - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - **4:** Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | | Pin Buffer | | Description | | | |--------------------------------------------|------|-------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Pin Name | TQFP | Туре | Type | Description | | | | | | | | PORTC is a bidirectional I/O port. | | | | RC0/T10SO/T13CKI<br>RC0<br>T10SO<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/<br>P2A | 35 | | | | | | | RC1<br>T1OSI<br>ECCP2 <sup>(2)</sup> | | I/O<br>I<br>I/O | ST<br>CMOS<br>ST | Digital I/O. Timer1 oscillator input. Enhanced Capture 2 input/Compare 2 output/ PWM2 output. | | | | P2A <sup>(2)</sup> | | 0 | _ | ECCP2 PWM output A. | | | | RC2/ECCP1/P1A<br>RC2<br>ECCP1 | 43 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 1 input/Compare 1 output/ PWM1 output. | | | | P1A | | 0 | _ | 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<br>RC5<br>SDO1 | 46 | I/O<br>O | ST<br>— | Digital I/O.<br>SPI data out. | | | | RC6/TX1/CK1<br>RC6<br>TX1<br>CK1 | 37 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART1 asynchronous transmit. 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 I = Input Analog = Analog input O = Output P = Power I<sup>2</sup>C™/SMB = I<sup>2</sup>C/SMBus input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Dis Nove | Pin Number | Pin | Buffer | Donatistics. | |------------------------------------------------------------------|------------|--------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | TQFP | Туре | Туре | Description | | | | | | PORTD is a bidirectional I/O port. | | RD0/AD0/PSP0<br>RD0<br>AD0<br>PSP0 | 72 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 0.<br>Parallel Slave Port data. | | RD1/AD1/PSP1<br>RD1<br>AD1<br>PSP1 | 69 | I/O<br>I/O<br>I/O | ST Digital I/O. TTL External memory address/data 1. TTL Parallel Slave Port data. | | | RD2/AD2/PSP2<br>RD2<br>AD2<br>PSP2 | 68 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 2.<br>Parallel Slave Port data. | | RD3/AD3/PSP3<br>RD3<br>AD3<br>PSP3 | 67 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 3.<br>Parallel Slave Port data. | | RD4/AD4/PSP4/SDO2<br>RD4<br>AD4<br>PSP4<br>SDO2 | 66 | I/O<br>I/O<br>I/O<br>O | ST<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 4.<br>Parallel Slave Port data.<br>SPI data out. | | RD5/AD5/PSP5/<br>SDI2/SDA2<br>RD5<br>AD5<br>PSP5<br>SDI2<br>SDA2 | 65 | I/O<br>I/O<br>I/O<br>I | ST<br>TTL<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>External memory address/data 5.<br>Parallel Slave Port data.<br>SPI data in.<br>I <sup>2</sup> C™ data I/O. | | RD6/AD6/PSP6/<br>SCK2/SCL2<br>RD6<br>AD6<br>PSP6<br>SCK2<br>SCL2 | 64 | I/O<br>I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL<br>ST<br>I <sup>2</sup> C/SMB | Digital I/O.<br>External memory address/data 6.<br>Parallel Slave Port data.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C mode. | | RD7/AD7/PSP7/SS2<br>RD7<br>AD7<br>PSP7<br>SS2 | 63 | I/O<br>I/O<br>I/O | ST<br>TTL<br>TTL<br>TTL | Digital I/O.<br>External memory address/data 7.<br>Parallel Slave Port data.<br>SPI slave select input. | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog I = Input O O = Output P = Power $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer = Analog input - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - **5:** Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Die Nous | Pin Number | Pin | Buffer | Description | | | |---------------------------------------------------------------|------------|----------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------|--|--| | Pin Name | TQFP | Туре | Type | Description | | | | RE0/AD8/RD/P2D<br>RE0<br>AD8<br>RD | 4 | I/O<br>I/O<br>I | ST<br>TTL<br>TTL | PORTE is a bidirectional I/O port. Digital I/O. External memory address/data 8. Read control for Parallel Slave Port. | | | | P2D RE1/AD9/WR/P2C RE1 AD9 WR P2C | 3 | O<br> I/O<br> I/O<br> O | ST<br>TTL<br>TTL | ECCP2 PWM output D. Digital I/O. External memory address/data 9. Write control for Parallel Slave Port. ECCP2 PWM output C. | | | | RE2/AD10/CS/P2B<br>RE2<br>AD10<br>CS<br>P2B | 78 | I/O<br>I/O<br>I<br>O | ST<br>TTL<br>TTL | Digital I/O. External memory address/data 10. Chip select control for Parallel Slave Port. ECCP2 PWM output B. | | | | RE3/AD11/P3C<br>RE3<br>AD11<br>P3C <sup>(4)</sup> | 77 | I/O<br>I/O<br>O | ST<br>TTL<br>— | Digital I/O.<br>External memory address/data 11.<br>ECCP3 PWM output C. | | | | RE4/AD12/P3B<br>RE4<br>AD12<br>P3B <sup>(4)</sup> | 76 | I/O<br>I/O<br>O | ST<br>TTL<br>— | Digital I/O.<br>External memory address/data 12.<br>ECCP3 PWM output B. | | | | RE5/AD13/P1C<br>RE5<br>AD13<br>P1C <sup>(4)</sup> | 75 | I/O<br>I/O<br>O | ST<br>TTL<br>— | Digital I/O.<br>External memory address/data 13.<br>ECCP1 PWM output C. | | | | RE6/AD14/P1B<br>RE6<br>AD14<br>P1B <sup>(4)</sup> | 74 | I/O<br>I/O<br>O | ST<br>TTL<br>— | Digital I/O.<br>External memory address/data 14.<br>ECCP1 PWM output B. | | | | RE7/AD15/ECCP2/<br>P2A<br>RE7<br>AD15<br>ECCP2 <sup>(3)</sup> | 73 | I/O<br>I/O<br>I/O | ST<br>TTL<br>ST | Digital I/O. External memory address/data 15. Enhanced 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 $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - **4:** Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pin Number | | Buffer | Description | | |----------------------------------------|------------|---------------|------------------------|--------------------------------------------------------------------------|--| | Pin Name | TQFP | Туре | Type | Description | | | | | | | PORTF is a bidirectional I/O port. | | | RF0/AN5<br>RF0<br>AN5 | 24 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 5. | | | RF1/AN6/C2OUT<br>RF1<br>AN6<br>C2OUT | 23 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 6.<br>Comparator 2 output. | | | RF2/AN7/C1OUT<br>RF2<br>AN7<br>C1OUT | 18 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 7.<br>Comparator 1 output. | | | RF3/AN8<br>RF3<br>AN8 | 17 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 8. | | | RF4/AN9<br>RF4<br>AN9 | 16 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 9. | | | RF5/AN10/CVREF<br>RF5<br>AN10<br>CVREF | 15 | I/O<br>I<br>O | ST<br>Analog<br>Analog | Digital I/O.<br>Analog input 10.<br>Comparator reference voltage output. | | | RF6/AN11<br>RF6<br>AN11 | 14 | I/O<br>I | ST<br>Analog | Digital I/O.<br>Analog input 11. | | | RF7/SS1<br>RF7<br>SS1 | 13 | I/O<br>I | ST<br>TTL | Digital I/O.<br>SPI slave select input. | | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels Analog = Analog input O = Output P = Power $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - **3:** Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - **4:** Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - **5:** Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | | | |------------------------------------|------------|-----------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--|--| | Pili Name | TQFP | Type | Туре | Description | | | | | | | | PORTG is a bidirectional I/O port. | | | | RG0/ECCP3/P3A<br>RG0<br>ECCP3 | 5 | I/O<br>I/O | ST<br>ST | Digital I/O. Enhanced Capture 3 input/Compare 3 output/ PWM3 output. | | | | P3A | | 0 | _ | ECCP3 PWM output A. | | | | RG1/TX2/CK2<br>RG1<br>TX2<br>CK2 | 6 | I/O<br>O<br>I/O | ST Digital I/O. — EUSART2 asynchronous transmit. ST EUSART2 synchronous clock (see related RX2/D | | | | | RG2/RX2/DT2<br>RG2<br>RX2<br>DT2 | 7 | I/O<br>I<br>I/O | ST<br>ST<br>ST | Digital I/O. EUSART2 asynchronous receive. EUSART2 synchronous data (see related TX2/CK2). | | | | RG3/CCP4/P3D<br>RG3<br>CCP4<br>P3D | 8 | I/O<br>I/O<br>O | ST<br>ST | Digital I/O. Capture 4 input/Compare 4 output/PWM4 output. ECCP3 PWM output D. | | | | RG4/CCP5/P1D<br>RG4<br>CCP5<br>P1D | 10 | I/O<br>I/O<br>O | ST<br>ST<br>— | Digital I/O.<br>Capture 5 input/Compare 5 output/PWM5 output.<br>ECCP1 PWM output D. | | | | RG5 | | | | See RG5/MCLR/VPP pin. | | | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^{2}C^{TM}/SMB = I^{2}C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | Pin | Buffer | Description | |---------------------------------------------------|------------|-------------------|-------------------|---------------------------------------------------------| | Pin Name | TQFP | Туре | Туре | Description | | | | | | PORTH is a bidirectional I/O port. | | RH0/A16<br>RH0<br>A16 | 79 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>External memory address/data 16. | | RH1/A17<br>RH1<br>A17 | 80 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>External memory address/data 17. | | RH2/A18<br>RH2<br>A18 | 1 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>External memory address/data 18. | | RH3/A19<br>RH3<br>A19 | 2 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>External memory address/data 19. | | RH4/AN12/P3C<br>RH4<br>AN12<br>P3C <sup>(5)</sup> | 22 | I/O<br> <br> <br> | ST<br>Analog<br>— | Digital I/O.<br>Analog input 12.<br>ECCP3 PWM output C. | | RH5/AN13/P3B<br>RH5<br>AN13<br>P3B <sup>(5)</sup> | 21 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 13.<br>ECCP3 PWM output B. | | RH6/AN14/P1C<br>RH6<br>AN14<br>P1C <sup>(5)</sup> | 20 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 14.<br>ECCP1 PWM output C. | | RH7/AN15/P1B<br>RH7<br>AN15<br>P1B <sup>(5)</sup> | 19 | I/O<br>- o | ST<br>Analog<br>— | Digital I/O.<br>Analog input 15.<br>ECCP1 PWM output B. | **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 $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). TABLE 1-3: PIC18F8628/8723 (80-PIN) PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pin Number | | Buffer | Description | | |--------------------------------------------|----------------|----------|---------|---------------------------------------------------------|--| | Pin Name | TQFP | Type | Type | Description | | | | | | | PORTJ is a bidirectional I/O port. | | | RJ0/ALE<br>RJ0<br>ALE | 62 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory address latch enable. | | | RJ1/OE<br>RJ1<br>OE | 61 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory output enable. | | | RJ2/WRL<br>RJ2<br>WRL | 60 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory write low control. | | | RJ3/WRH<br>RJ3<br>WRH | 59 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory write high control. | | | RJ4/BA0<br>RJ4<br>BA0 | 39 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory byte address 0 control. | | | RJ5/CE<br>RJ4<br>CE | 40 | I/O<br>O | ST<br>— | Digital I/O<br>External memory chip enable control. | | | RJ6/LB<br>RJ6<br>LB | 41 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory low byte control. | | | RJ7/ <del>UB</del><br>RJ7<br><del>UB</del> | 42 | I/O<br>O | ST<br>— | Digital I/O.<br>External memory high byte control. | | | Vss | 11, 31, 51, 70 | Р | _ | Ground reference for logic and I/O pins. | | | VDD | 12, 32, 48, 71 | Р | _ | Positive supply for logic and I/O pins. | | | AVss | 26 | Р | _ | Ground reference for analog modules. | | | AVDD | 25 | Р | 1 | Positive supply for analog modules. | | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels I = Input P = Power CMOS = CMOS compatible input or output Analog = Analog input O = Output $I^2C^{TM}/SMB = I^2C/SMBus$ input buffer - 2: Default assignment for ECCP2 in all operating modes (CCP2MX is set). - 3: Alternate assignment for ECCP2 when CCP2MX is cleared (Microcontroller mode only). - 4: Default assignment for P1B/P1C/P3B/P3C (ECCPMX is set). - 5: Alternate assignment for P1B/P1C/P3B/P3C (ECCPMX is clear). ### 2.0 12-BIT ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE The Analog-to-Digital (A/D) Converter module has 12 inputs for the 64-pin devices (PIC18F6628/6723) and 16 for the 80-pin devices (PIC18F8628/8723). This module allows conversion of an analog input signal to a corresponding 12-bit digital number. The module has five registers: - A/D Result High Register (ADRESH) - A/D Result Low Register (ADRESL) - A/D Control Register 0 (ADCON0) - A/D Control Register 1 (ADCON1) - A/D Control Register 2 (ADCON2) The ADCON0 register, shown in Register 2-1, controls the operation of the A/D module. The ADCON1 register, shown in Register 2-2, configures the functions of the port pins. The ADCON2 register, shown in Register 2-3, configures the A/D clock source, programmed acquisition time and justification. #### REGISTER 2-1: ADCON0: A/D CONTROL REGISTER 0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|---------|-------| | _ | _ | CHS3 | CHS2 | CHS1 | CHS0 | GO/DONE | ADON | | 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-2 CHS3:CHS0: Analog Channel Select bits 0000 = Channel 0 (AN0) 0001 = Channel 1 (AN1) 0010 = Channel 2 (AN2) 0011 = Channel 3 (AN3) 0100 = Channel 4 (AN4) 0101 = Channel 5 (AN5) 0110 = Channel 6 (AN6) 0111 = Channel 7 (AN7) 1000 = Channel 8 (AN8) 1001 = Channel 9 (AN9) 1010 = Channel 10 (AN10) 1011 = Channel 11 (AN11) 1100 = Channel 12 (AN12)(1,2) 1101 = Channel 13 (AN13)<sup>(1,2)</sup> 1110 = Channel 14 (AN14)<sup>(1,2)</sup> 1111 = Channel 15 (AN15)<sup>(1,2)</sup> bit 1 **GO/DONE**: A/D Conversion Status bit When ADON = 1: 1 = A/D conversion in progress 0 = A/D Idle bit 0 ADON: A/D On bit 1 = A/D Converter module is enabled 0 = A/D Converter module is disabled Note 1: These channels are not implemented on PIC18F6628/6723 devices. 2: Performing a conversion on unimplemented channels will return a floating input measurement. #### REGISTER 2-2: ADCON1: A/D CONTROL REGISTER 1 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|-------|-------| | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | | 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-4 VCFG1:VCFG0: Voltage Reference Configuration bits | | A/D VREF+ | A/D VREF- | |-----|----------------|----------------| | 0.0 | AVDD | AVss | | 01 | External VREF+ | AVss | | 10 | AVDD | External VREF- | | 11 | External VREF+ | External VREF- | #### bit 3-0 **PCFG3:PCFG0:** A/D Port Configuration Control bits: | PCFG<3:0> | AN15 <sup>(1)</sup> | AN14 <sup>(1)</sup> | AN13 <sup>(1)</sup> | AN12 <sup>(1)</sup> | AN11 | AN10 | AN9 | AN8 | AN7 | AN6 | AN5 | AN4 | AN3 | AN2 | AN1 | ANO | |-----------|---------------------|---------------------|---------------------|---------------------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----| | 0000 | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0001 | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0010 | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0011 | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0100 | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0101 | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0110 | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0111 | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | | 1000 | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | | 1001 | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | | 1010 | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | | 1011 | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | | 1100 | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | | 1101 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | Α | | 1110 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | Α | | 1111 | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | D | A = Analog input D = Digital I/O Note 1: AN15 through AN12 are available only on PIC18F8628/8723 devices. #### REGISTER 2-3: ADCON2: A/D CONTROL REGISTER 2 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-------|-------|-------|-------|-------|-------| | ADFM | _ | ACQT2 | ACQT1 | ACQT0 | ADCS2 | ADCS1 | ADCS0 | | 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 **ADFM:** A/D Result Format Select bit 1 = Right justified0 = Left justified Unimplemented: Read as '0' bit 5-3 ACQT2:ACQT0: A/D Acquisition Time Select bits 111 = 20 TAD 110 = 16 TAD 101 = 12 TAD 100 = 8 TAD 011 = 6 TAD 010 = 4 TAD bit 6 001 = 2 TAD $000 = 0 \text{ TAD}^{(1)}$ bit 2-0 ADCS2:ADCS0: A/D Conversion Clock Select bits 111 = FRC (clock derived from A/D RC oscillator)(1) 110 = Fosc/64 101 = Fosc/16 100 = Fosc/4 011 = FRC (clock derived from A/D RC oscillator)(1) 010 = Fosc/32 001 = Fosc/8 000 = Fosc/2 **Note 1:** If the A/D FRC clock source is selected, a delay of one Tcy (instruction cycle) is added before the A/D clock starts. This allows the SLEEP instruction to be executed before starting a conversion. The analog reference voltage is software selectable to either the device's positive and negative supply voltage (VDD and VSS), or the voltage level on the RA3/AN3/ VREF+ and RA2/AN2/VREF-/CVREF pins. The A/D Converter has a unique feature of being able to operate while the device is in Sleep mode. To operate in Sleep, the A/D conversion clock must be derived from the A/D's internal RC oscillator. The output of the sample and hold is the input into the converter, which generates the result via successive approximation. A device Reset forces all registers to their Reset state. This forces the A/D module to be turned off and any conversion in progress is aborted. Each port pin associated with the A/D Converter can be configured as an analog input or a digital I/O. The ADRESH and ADRESL registers contain the result of the A/D conversion. When the A/D conversion is complete, the result is loaded into the ADRESH:ADRESL register pair, the GO/DONE bit (ADCON0<1>) is cleared and the A/D Interrupt Flag bit, ADIF, is set. The block diagram of the A/D module is shown in Figure 2-1. FIGURE 2-1: A/D BLOCK DIAGRAM The value in the ADRESH:ADRESL registers is unknown following Power-on and Brown-out Resets and is not affected by any other Reset. After the A/D module has been configured as desired, the selected channel must be acquired before the conversion is started. The analog input channels must have their corresponding TRIS bits selected as an input. To determine acquisition time, see **Section 2.1** "A/D Acquisition Requirements". After this acquisition time has elapsed, the A/D conversion can be started. An acquisition time can be programmed to occur between setting the GO/DONE bit and the actual start of the conversion. The following steps should be followed to perform an A/D conversion: - 1. Configure the A/D module: - Configure analog pins, voltage reference and digital I/O (ADCON1) - · Select A/D input channel (ADCON0) - · Select A/D acquisition time (ADCON2) - · Select A/D conversion clock (ADCON2) - Turn on A/D module (ADCON0) - 2. Configure A/D interrupt (if desired): - · Clear ADIF bit - · Set ADIE bit - · Set GIE bit - 3. Wait the required acquisition time (if required). - 4. Start conversion: - Set GO/DONE bit (ADCON0<1>) - 5. Wait for A/D conversion to complete by either: - Polling for the GO/DONE bit to be cleared - · Waiting for the A/D interrupt - 6. Read A/D Result registers (ADRESH:ADRESL); clear bit, ADIF, if required. - For next conversion, go to step 1 or step 2, as required. The A/D conversion time per bit is defined as TAD. A minimum wait of 2 TAD is required before the next acquisition starts. #### 2.1 A/D Acquisition Requirements For the A/D Converter to meet its specified accuracy, the charge holding capacitor (Chold) must be allowed to fully charge to the input channel voltage level. The analog input model is shown in Figure 2-3. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor, Chold. The sampling switch (Rss) impedance varies over the device voltage (Vdd). The source impedance affects the offset voltage at the analog input (due to pin leakage current). The maximum recommended impedance for analog sources is 2.5 k $\Omega$ . After the analog input channel is selected (changed), the channel must be sampled for at least the minimum acquisition time before starting a conversion. Note: When the conversion is started, the holding capacitor is disconnected from the input pin. To calculate the minimum acquisition time, Equation 2-1 may be used. This equation assumes that 1/2 LSb error is used (4096 steps for the 12-bit A/D). The 1/2 LSb error is the maximum error allowed for the A/D to meet its specified resolution. Example 2-3 shows the calculation of the minimum required acquisition time, TACQ. This calculation is based on the following application system assumptions: CHOLD = 25 pF Rs = $2.5 \text{ k}\Omega$ Conversion Error $\leq$ 1/2 LSb VDD = $3V \rightarrow Rss = 4 k\Omega$ Temperature = 85°C (system max.) #### **EQUATION 2-1: ACQUISITION TIME** ``` TACQ = Amplifier Settling Time + Holding Capacitor Charging Time + Temperature Coefficient = TAMP + TC + TCOFF ``` #### **EQUATION 2-2: A/D MINIMUM CHARGING TIME** ``` \begin{array}{lll} V_{HOLD} & = & (V_{REF} - (V_{REF}/4096)) \bullet (1 - e^{(-T_C/C_{HOLD}(R_{IC} + R_{SS} + R_S))}) \\ or \\ T_C & = & - (C_{HOLD})(R_{IC} + R_{SS} + R_S) \ln(1/4096) \end{array} ``` #### **EQUATION 2-3: CALCULATING THE MINIMUM REQUIRED ACQUISITION TIME** ``` TACQ TAMP + TC + TCOFF TAMP 0.2~\mu s TCOFF (Temp - 25^{\circ}C)(0.02 \mu s/^{\circ}C) (85^{\circ}C - 25^{\circ}C)(0.02 \mu s/^{\circ}C) 1.2 us Temperature coefficient is only required for temperatures > 25°C. Below 25°C, TCOFF = 0 \mus. TC -(CHOLD)(RIC + RSS + RS) ln(1/4096) \mu s -(25 \text{ pF}) (1 \text{ k}\Omega + 4 \text{ k}\Omega + 2.5 \text{ k}\Omega) \ln(0.0002441) \,\mu\text{s} 1.56 \mu s 0.2 \mu s + 1.56 \mu s + 1.2 \mu s TACO 2.96 us ``` # 2.2 Selecting and Configuring Acquisition Time The ADCON2 register allows the user to select an acquisition time that occurs each time the GO/DONE bit is set. It also gives users the option to use an automatically determined acquisition time. Acquisition time may be set with the ACQT2:ACQT0 bits (ADCON2<5:3>), which provide a range of 2 to 20 TAD. When the GO/DONE bit is set, the A/D module continues to sample the input for the selected acquisition time, then automatically begins a conversion. Since the acquisition time is programmed, there may be no need to wait for an acquisition time between selecting a channel and setting the GO/DONE bit. Manual acquisition is selected when ACQT2:ACQT0 = 000. When the GO/DONE bit is set, sampling is stopped and a conversion begins. The user is responsible for ensuring the required acquisition time has passed between selecting the desired input channel and setting the GO/DONE bit. This option is also the default Reset state of the ACQT2:ACQT0 bits and is compatible with devices that do not offer programmable acquisition times. In either case, when the conversion is completed, the GO/DONE bit is cleared, the ADIF flag is set and the A/D begins sampling the currently selected channel again. If an acquisition time is programmed, there is nothing to indicate if the acquisition time has ended or if the conversion has begun. # 2.3 Selecting the A/D Conversion Clock The A/D conversion time per bit is defined as TAD. The A/D conversion requires 13 TAD per 12-bit conversion. The source of the A/D conversion clock is software selectable. There are seven possible options for TAD: - 2 Tosc - 4 Tosc - 8 Tosc - 16 Tosc - 32 Tosc - 64 Tosc - Internal RC Oscillator For correct A/D conversions, the A/D conversion clock (TAD) must be as short as possible, but greater than the minimum TAD (see parameter 130 for more information). Table 2-1 shows the resultant TAD times derived from the device operating frequencies and the A/D clock source selected. TABLE 2-1: TAD vs. DEVICE OPERATING FREQUENCIES | A/D Clock So | A/D Clock Source (TAD) | | | |-------------------|------------------------|-------------------------|--| | Operation | ADCS2:ADCS0 | Maximum Fosc | | | 2 Tosc | 000 | 2.50 MHz | | | 4 Tosc | 100 | 5.00 MHz | | | 8 Tosc | 001 | 10.00 MHz | | | 16 Tosc | 101 | 20.00 MHz | | | 32 Tosc | 010 | 40.00 MHz | | | 64 Tosc | 110 | 40.00 MHz | | | RC <sup>(1)</sup> | x11 | 1.00 MHz <sup>(2)</sup> | | - **Note 1:** The RC source has a typical TAD time of 2.5 $\mu$ s. - 2: For device frequencies above 1 MHz, the device must be in Sleep for the entire conversion or a Fosc divider should be used instead; otherwise, the A/D accuracy specification may not be met. # 2.4 Operation in Power-Managed Modes The selection of the automatic acquisition time and A/D conversion clock is determined in part by the clock source and frequency while in a power-managed mode. If the A/D is expected to operate while the device is in a power-managed mode, the ADCS2:ADCS0 bits in ADCON2 should be updated in accordance with the clock source to be used. The ACQT2:ACQT0 bits do not need to be adjusted as the ADCS2:ADCS0 bits adjust the TAD time for the new clock speed. After entering the mode, an A/D acquisition or conversion may be started. Once started, the device should continue to be clocked by the same clock source until the conversion has been completed. If desired, the device may be placed into the corresponding Idle mode during the conversion. If the device clock frequency is less than 1 MHz, the A/D RC clock source should be selected. Operation in Sleep mode requires the A/D FRC clock to be selected. If the ACQT2:ACQT0 bits are set to '000' and a conversion is started, the conversion will be delayed one instruction cycle to allow execution of the SLEEP instruction and entry to Sleep mode. The IDLEN bit (OSCCON<7>) must have already been cleared prior to starting the conversion. ## 2.5 Configuring Analog Port Pins The ADCON1, TRISA, TRISF and TRISH registers all configure the A/D port pins. The port pins needed as analog inputs must have their corresponding TRIS bits set (input). If the TRIS bit is cleared (output), the digital output level (VOH or VOL) will be converted. The A/D operation is independent of the state of the CHS3:CHS0 bits and the TRIS bits. - Note 1: When reading the PORT register, all pins configured as analog input channels will read as cleared (a low level). Analog conversion on pins configured as digital pins can be performed. The voltage on the pin will be accurately converted. - 2: Analog levels on any pin defined as a digital input may cause the digital input buffer to consume current out of the device's specification limits. #### 2.6 A/D Conversions Figure 2-4 shows the operation of the A/D Converter after the GO/DONE bit has been set and the ACQT2:ACQT0 bits are cleared. A conversion is started after the following instruction to allow entry into Sleep mode before the conversion begins. Figure 2-5 shows the operation of the A/D Converter after the GO/DONE bit has been set, the ACQT2:ACQT0 bits are set to '010' and a 4 TAD acquisition time has been selected before the conversion starts. Clearing the GO/DONE bit during a conversion will abort the current conversion. The A/D Result register pair will NOT be updated with the partially completed A/D conversion sample. This means the ADRESH:ADRESL registers will continue to contain the value of the last completed conversion (or the last value written to the ADRESH:ADRESL registers). After the A/D conversion is completed or aborted, a 2 Tcy wait is required before the next acquisition can be started. After this wait, acquisition on the selected channel is automatically started. Note: The GO/DONE bit should NOT be set in the same instruction that turns on the A/D. Code should wait at least 2 μs after enabling the A/D before beginning an acquisition and conversion cycle. #### 2.7 Discharge The discharge phase is used to initialize the value of the holding capacitor. The array is discharged before every sample. This feature helps to optimize the unity gain amplifier, as the circuit always needs to charge the capacitor array, rather than charge/discharge based on previous measure values. #### FIGURE 2-4: A/D CONVERSION TAD CYCLES (ACQT<2:0> = 000, TACQ = 0) #### FIGURE 2-5: A/D CONVERSION TAD CYCLES (ACQT<2:0> = 010, TACQ = 4 TAD) #### 2.8 Use of the ECCP2 Trigger An A/D conversion can be started by the Special Event Trigger of the ECCP2 module. This requires that the CCP2M3:CCP2M0 bits (CCP2CON<3:0>) be programmed as '1011' and that the A/D module is enabled (ADON bit is set). When the trigger occurs, the GO/DONE bit will be set, starting the A/D acquisition and conversion, and the Timer1 (or Timer3) counter will be reset to zero. Timer1 (or Timer3) is reset to automatically repeat the A/D acquisition period with minimal software overhead (moving ADRESH:ADRESL to the desired location). The appropriate analog input channel must be selected and the minimum acquisition period is either timed by the user, or an appropriate TACQ time selected before the Special Event Trigger sets the GO/DONE bit (starts a conversion). If the A/D module is not enabled (ADON is cleared), the Special Event Trigger will be ignored by the A/D module but will still reset the Timer1 (or Timer3) counter. TABLE 2-2: REGISTERS ASSOCIATED WITH A/D OPERATION | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset<br>Values | |----------------------|-----------------------|-----------------------|--------|--------|--------|--------|---------|--------|-----------------| | INTCON | GIE/GIEH | PEIE/GIEL | TMR0IE | INT0IE | RBIE | TMR0IF | INT0IF | RBIF | (3) | | PIR1 | PSPIF | ADIF | RC1IF | TX1IF | SSP1IF | CCP1IF | TMR2IF | TMR1IF | (3) | | PIE1 | PSPIE | ADIE | RC1IE | TX1IE | SSP1IE | CCP1IE | TMR2IE | TMR1IE | (3) | | IPR1 | PSPIP | ADIP | RC1IP | TX1IP | SSP1IP | CCP1IP | TMR2IP | TMR1IP | (3) | | PIR2 | OSCFIF | CMIF | _ | EEIF | BCL1IF | HLVDIF | TMR3IF | CCP2IF | (3) | | PIE2 | OSCFIE | CMIE | _ | EEIE | BCL1IE | HLVDIE | TMR3IE | CCP2IE | (3) | | IPR2 | OSCFIP | CMIP | _ | EEIP | BCL1IP | HLVDIP | TMR3IP | CCP2IP | (3) | | ADRESH | A/D Result | Register Hig | h Byte | | | | | | (3) | | ADRESL | A/D Result | Register Lov | w Byte | | | | | | (3) | | ADCON0 | _ | _ | CHS3 | CHS2 | CHS1 | CHS0 | GO/DONE | ADON | (3) | | ADCON1 | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | (3) | | ADCON2 | ADFM | _ | ACQT2 | ACQT1 | ACQT0 | ADCS2 | ADCS1 | ADCS0 | (3) | | TRISA | TRISA7 <sup>(1)</sup> | TRISA6 <sup>(1)</sup> | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | (3) | | TRISF | TRISF7 | TRISF6 | TRISF5 | TRISF4 | TRISF3 | TRISF2 | TRISF1 | TRISF0 | (3) | | TRISH <sup>(2)</sup> | TRISH7 | TRISH6 | TRISH5 | TRISH4 | TRISH3 | TRISH2 | TRISH1 | TRISH0 | (3) | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used for A/D conversion. **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'. - 2: These registers are not implemented on PIC18F6628/6723 devices. - 3: For these Reset values, see the "PIC18F8722 Family Data Sheet" (DS39646). #### 3.0 SPECIAL FEATURES OF THE **CPU** Note: For additional details on the Configuration bits, refer to Section 25.1 "Configuration Bits" in the "PIC18F8722 Family Data Sheet" (DS39646). Device ID information presented in this section is for the PIC18F8723 family only. PIC18F8723 family devices include several features intended to maximize reliability and minimize cost through elimination of external components. These include: · Device ID Registers #### 3.1 **Device ID Registers** The Device ID registers are "read-only" registers. They identify the device type and revision to device programmers and can be read by firmware using table reads. #### **TABLE 3-1: DEVICE IDs** | File N | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default/<br>Unprogrammed<br>Value | |---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------------------| | 3FFFFEh | DEVID1 | DEV2 | DEV1 | DEV0 | REV4 | REV3 | REV2 | REV1 | REV0 | xxxx xxxx(1) | | 3FFFFFh | DEVID2 | DEV10 | DEV9 | DEV8 | DEV7 | DEV6 | DEV5 | DEV4 | DEV3 | XXXX XXXX(1) | Legend: x = unknown Note 1: See Register 3-1 and Register 3-2 for DEVID values. DEVID registers are read-only and cannot be programmed by the #### REGISTER 3-1: DEVID1: DEVICE ID REGISTER 1 FOR PIC18F8723 FAMILY DEVICES | R | R | R | R | R | R | R | R | |-------|------|------|------|------|------|------|-------| | DEV2 | DEV1 | DEV0 | REV4 | REV3 | REV2 | REV1 | REV0 | | bit 7 | | | | | | | bit 0 | Legend: R = Read-only bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state bit 7-5 **DEV2:DEV0:** Device ID bits See Register 3-2 for a complete listing. bit 4-0 **REV4:REV0:** Revision ID bits These bits are used to indicate the device revision. #### REGISTER 3-2: DEVID2: DEVICE ID REGISTER 2 FOR PIC18F8723 FAMILY DEVICES | R | R | R | R | R | R | R | R | |-------|------|------|------|------|------|------|-------| | DEV10 | DEV9 | DEV8 | DEV7 | DEV6 | DEV5 | DEV4 | DEV3 | | bit 7 | | | | | | | bit 0 | Legend: R = Read-only bit P = Programmable bit U = Unimplemented bit, read as '0' -n = Value when device is unprogrammed u = Unchanged from programmed state ### bit 7-0 **DEV10:DEV3:** Device ID bits | DEV10:DEV3<br>(DEVID2<7:0>) | DEV2:DEV0<br>(DEVID1<7:5>) | Device | |-----------------------------|----------------------------|------------| | 0100 1001 | 110 | PIC18F6628 | | 0100 1010 | 000 | PIC18F6723 | | 0100 1001 | 111 | PIC18F8628 | | 0100 1010 | 001 | PIC18F8723 | #### 4.0 ELECTRICAL CHARACTERISTICS **Note:** Other than some basic data, this section documents only the PIC18F8723 family's specifications that differ from those of the PIC18F8722 family devices. For detailed information on the electrical specifications shared by the PIC18F8723 family and PIC18F8722 family devices, see the "PIC18F8722 Family Data Sheet" (DS39646). ## Absolute Maximum Ratings<sup>(†)</sup> | Ambient temperature under bias | 40°C to +125°C | |--------------------------------------------------------------|----------------------| | Storage temperature | 65°C to +150°C | | Voltage on any pin with respect to Vss (except VDD and MCLR) | 0.3V to (VDD + 0.3V) | | Voltage on VDD with respect to Vss | 0.3V to +7.5V | | Voltage on MCLR with respect to Vss (Note 2) | 0V to +13.25V | | Total power dissipation (Note 1) | 1.0W | | Maximum current out of Vss pin | 300 mA | | Maximum current into VDD pin | 250 mA | | Input clamp current, lik (Vi < 0 or Vi > VDD) | ±20 mA | | Output clamp current, lok (Vo < 0 or Vo > VDD) | ±20 mA | | Maximum output current sunk by any I/O pin | 25 mA | | Maximum output current sourced by any I/O pin | 25 mA | | Maximum current sunk by all ports | 200 mA | | Maximum current sourced by all ports | 200 mA | - Note 1: Power dissipation is calculated as follows: Pdis = VDD x {IDD $\Sigma$ IOH} + $\Sigma$ {(VDD VOH) x IOH} + $\Sigma$ (VOL x IOL) - 2: Voltage spikes below Vss at the RG5/MCLR/VPP pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the RG5/MCLR/VPP pin, rather than pulling this pin directly to Vss. **† 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 to maximum rating conditions for extended periods may affect device reliability. FIGURE 4-1: PIC18F8723 FAMILY VOLTAGE-FREQUENCY GRAPH (INDUSTRIAL) FIGURE 4-2: PIC18F8723 FAMILY VOLTAGE-FREQUENCY GRAPH (EXTENDED) TABLE 4-1: A/D CONVERTER CHARACTERISTICS: PIC18F8723 FAMILY (INDUSTRIAL) | Param<br>No. | Sym | Characteristic | Min | Тур | Мах | Units | | Conditions | |--------------|-------|------------------------------------------------------|------------|----------|------------------|----------|------------|-------------------------------------------------------| | A01 | NR | Resolution | _ | _ | 12 | bit | | $\Delta V$ REF $\geq 3.0V$ | | A03 | EIL | Integral Linearity Error | _ | <±1 | ±2.0 | LSB | VDD = 3.0V | $\Delta V$ REF $\geq 3.0V$ | | | | | _ | _ | ±2.0 | LSB | VDD = 5.0V | | | A04 | EDL | Differential Linearity Error | _ | <±1 | +1.5/-1.0 | LSB | VDD = 3.0V | $\Delta VREF \ge 3.0V$ | | | | | _ | _ | +1.5/-1.0 | LSB | VDD = 5.0V | | | A06 | Eoff | Offset Error | _ | <±1 | ±5 | LSB | VDD = 3.0V | $\Delta VREF \ge 3.0V$ | | | | | _ | _ | ±3 | LSB | VDD = 5.0V | | | A07 | Egn | Gain Error | _ | <±1 | ±1.25 | LSB | VDD = 3.0V | $\Delta VREF \ge 3.0V$ | | | | | _ | _ | ±2.00 | LSB | VDD = 5.0V | | | A10 | _ | Monotonicity | Gı | uarantee | d <sup>(1)</sup> | _ | | VSS ≤ VAIN ≤ VREF | | A20 | ΔVREF | Reference Voltage Range<br>(VREFH – VREFL) | 3 | _ | VDD – VSS | V | | For 12-bit resolution | | A21 | VREFH | Reference Voltage High | Vss + 3.0V | _ | VDD + 0.3V | V | | For 12-bit resolution | | A22 | VREFL | Reference Voltage Low | Vss - 0.3V | _ | VDD - 3.0V | V | | For 12-bit resolution | | A25 | VAIN | Analog Input Voltage | VREFL | _ | VREFH | V | | | | A30 | ZAIN | Recommended<br>Impedance of Analog<br>Voltage Source | _ | _ | 2.5 | kΩ | | | | A50 | IREF | VREF Input Current <sup>(2)</sup> | | _ | 5<br>150 | μA<br>μA | | During VAIN acquisition. During A/D conversion cycle. | Note 1: The A/D conversion result never decreases with an increase in the input voltage and has no missing codes. <sup>2:</sup> VREFH current is from the RA3/AN3/VREF+ pin or VDD, whichever is selected as the VREFH source. VREFL current is from the RA2/AN2/VREF-/CVREF pin or VSS, whichever is selected as the VREFL source. FIGURE 4-4: A/D CONVERSION TIMING TABLE 4-2: A/D CONVERSION REQUIREMENTS | Param<br>No. | Symbol | Characteristic | | Min | Max | Units | Conditions | |--------------|--------|--------------------------------------------|-------------------------|-----|---------------------|-------|--------------------------------------------------------------------| | 130 | TAD | A/D Clock Period | PIC18 <b>F</b> XXXX | 0.8 | 12.5 <sup>(1)</sup> | μS | Tosc based, VREF ≥ 3.0V | | | | | PIC18 <b>LF</b> XXXX | 1.4 | 25.0 <sup>(1)</sup> | μS | V <sub>DD</sub> = 3.0V;<br>Tosc based, V <sub>REF</sub> full range | | | | | PIC18FXXXX | _ | 1 | μS | A/D RC mode | | | | | PIC18 <b>LF</b> XXXX | _ | 3 | μS | VDD = 3.0V; A/D RC mode | | 131 | TCNV | Conversion Time (not including acquisition | on time) <sup>(2)</sup> | 13 | 14 | TAD | | | 132 | TACQ | Acquisition Time <sup>(3)</sup> | | 1.4 | _ | μS | | | 135 | Tswc | Switching Time from Convert → Sample | | _ | (Note 4) | | | | 137 | TDIS | Discharge Time | | 0.2 | _ | μS | | Note 1: The time of the A/D clock period is dependent on the device frequency and the TAD clock divider. - 2: ADRES registers may be read on the following Tcy cycle. - 3: The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to Vss or Vss to VDD). The source impedance (Rs) on the input channels is $50\Omega$ . - 4: On the following cycle of the device clock. NOTES: ## 5.0 PACKAGING INFORMATION For packaging information, see the "PIC18F8722 Family Data Sheet" (DS39646). NOTES: ## **APPENDIX A: REVISION HISTORY** ## Revision A (August 2007) Original data sheet for the PIC18F8723 family of devices. ## **Revision B (October 2009)** Updated to remove Preliminary status. # APPENDIX B: DEVICE DIFFERENCES The differences between the devices listed in this data sheet are shown in Table B-1. TABLE B-1: PIC18F8723 FAMILY DEVICE DIFFERENCES | Features | PIC18F6628 | PIC18F6723 | PIC18F8628 | PIC18F8723 | |--------------------------------------|---------------------------|------------------------------|------------------------------------|------------------------------------| | Program Memory (Bytes) | 96K | 128K | 96K | 128K | | Program Memory (Instructions) | 49152 | 65536 | 49152 | 65536 | | Interrupt Sources | 28 | 28 | 29 | 29 | | I/O Ports | Ports A, B, C, D, E, F, G | Ports A, B, C, D, E,<br>F, G | Ports A, B, C, D, E,<br>F, G, H, J | Ports A, B, C, D, E,<br>F, G, H, J | | Capture/Compare/PWM Modules | 2 | 2 | 2 | 2 | | Enhanced Capture/Compare/PWM Modules | 3 | 3 | 3 | 3 | | Parallel Communications (PSP) | Yes | Yes | Yes | Yes | | External Memory Bus | No | No | Yes | Yes | | 12-Bit Analog-to-Digital Module | 12 Input Channels | 12 Input Channels | 16 Input Channels | 16 Input Channels | | Packages | 64-Pin TQFP | 64-Pin TQFP | 80-Pin TQFP | 80-Pin TQFP | # APPENDIX C: CONVERSION CONSIDERATIONS This appendix discusses the considerations for converting from previous versions of a device to the ones listed in this data sheet. Typically, these changes are due to the differences in the process technology used. An example of this type of conversion is from a PIC16C74A to a PIC16C74B. **Not Applicable** # APPENDIX D: MIGRATION FROM BASELINE TO ENHANCED DEVICES This section discusses how to migrate from a Baseline device (i.e., PIC16C5X) to an Enhanced MCU device (i.e., PIC18FXXX). The following are the list of modifications over the PIC16C5X microcontroller family: **Not Currently Available** # APPENDIX E: MIGRATION FROM MID-RANGE TO ENHANCED DEVICES A detailed discussion of the differences between the mid-range MCU devices (i.e., PIC16CXXX) and the enhanced devices (i.e., PIC18FXXX) is provided in AN716, "Migrating Designs from PIC16C74A/74B to PIC18C442". The changes discussed, while device specific, are generally applicable to all mid-range to enhanced device migrations. This Application Note is available on our web site, www.microchip.com, as Literature Number DS00716. ## APPENDIX F: MIGRATION FROM HIGH-END TO ENHANCED DEVICES A detailed discussion of the migration pathway and differences between the high-end MCU devices (i.e., PIC17CXXX) and the enhanced devices (i.e., PIC18FXXX) is provided in AN726, "PIC17CXXX to PIC18CXXX Migration". This Application Note is available on our web site, www.microchip.com, as Literature Number DS00726. NOTES: ## **INDEX** | A | | F | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------|--------| | A/D | 31 | Features Summary Table | 3 | | A/D Converter Interrupt, Configuring | 35 | 1 | | | Acquisition Requirements | 36 | ı | | | ADCON0 Register | 31 | Internet Address | 57 | | ADCON1 Register | 31 | Interrupt Sources | | | ADCON2 Register | 31 | A/D Conversion Complete | 35 | | ADRESH Register | 31, 34 | M | | | ADRESL Register | 31 | М | | | Analog Port Pins, Configuring | | Microchip Internet Web Site | 57 | | Associated Registers | | Migration From Baseline to Enhanced Devices | | | Configuring the Module | | Migration From High-End to Enhanced Devices | | | Conversion Clock (TAD) | | Migration From Mid-Range to Enhanced Devices | 53 | | Conversion Status (GO/DONE Bit) | | More Information | 7 | | Conversions | | Customer Notification System | 7 | | Converter Characteristics | 46 | Errata | 7 | | Discharge | 39 | • | | | Operation in Power-Managed Modes | | 0 | | | Selecting and Configuring Acquisition Time | | Overview | | | Special Event Trigger (ECCP2) | | External Memory Interface | 3 | | Transfer Function | | Features Summary Table | 3 | | Use of the ECCP2 Trigger | | Peripheral Highlights | 3 | | Absolute Maximum Ratings | | Power-Managed Modes | 3 | | ADCON0 Register | | Special Microcontroller Features | | | GO/DONE Bit | | | | | ADCON1 Register | | Р | | | ADCON1 Register | | Packaging Information | 49 | | • | | Peripheral Highlights | | | ADREST Register | | Pin Diagrams | | | Applies to Digital Convertor, See A/D | 31, 34 | 64-Pin TQFP | 4 | | Analog-to-Digital Converter. See A/D. | | 80-Pin TQFP | 5 | | В | | Pin Functions | | | Block Diagrams | | AVDD (64-pin) | 20 | | A/D | 24 | AVDD (80-pin) | | | Analog Input Model | | AVss (64-pin) | | | PIC18F6628/6723 | | AVss (80-pin) | | | PIC18F8628/8723 | | OSC1/CLKI/RA7 | | | FIG 10F 0020/0723 | 12 | OSC2/CLKO/RA6 | | | C | | RA0/AN0 | 14. 22 | | Compare (ECCP2 Module) | | RA1/AN1 | - | | Special Event Trigger | 40 | RA2/AN2/VREF | | | Conversion Considerations | | RA3/AN3/VREF+ | 14. 22 | | Customer Change Notification Service | | RA4/T0CKI | | | Customer Notification Service | | RA5/AN4/HLVDIN | | | Customer Notification System | | RB0/INT0/FLT0 | | | , and the second | | RB1/INT1 | | | Customer Support | 37 | RB2/INT2 | | | D | | RB3/INT3 | , | | Device Differences | 51 | RB3/INT3/ECCP2/P2A | | | Device ID Registers | | RB4/KBI0 | | | • | 41 | RB5/KBI1/PGM | , | | Device Overview | 10 | RB6/KBI2/PGC | - | | Features (table) | | RB7/KBI3/PGD | | | Special Features | 9 | RC0/T10S0/T13CKI | | | E | | | | | Floatrical Characteristics | 42 | RC1/T1OSI/ECCP2/P2A | | | Electrical Characteristics | 43 | RC2/ECCP1/P1A | | | Equations | 00 | RC3/SCK1/SCL1 | , | | A/D Acquisition Time | | RC4/SDI1/SDA1 | , | | A/D Minimum Charging Time | | RC5/SD01 | | | Calculating the Minimum Required Acquisition | | RC6/TX1/CK1 | | | Errata | | RC7/RX1/DT1 | | | External Memory Interface | 3 | RD0/AD0/PSP0 | | | | | RD0/PSP0 | 17 | | RD1/AD1/PSP1 | 25 | |------------------------|--------| | RD1/PSP1 | | | | | | RD2/AD2/PSP2 | | | RD2/PSP2 | 17 | | RD3/AD3/PSP3 | 25 | | RD3/PSP3 | | | RD4/AD4/PSP4/SDO2 | | | | | | RD4/PSP4/SDO2 | | | RD5/AD5/PSP5/SDI2/SDA2 | 25 | | RD5/PSP5/SDI2/SDA2 | 17 | | RD6/AD6/PSP6/SCK2/SCL2 | | | RD6/PSP6/SCK2/SCL2 | | | RD0/P3P0/3CK2/3CL2 | 17 | | RD7/AD7/PSP7/SS2 | | | RD7/PSP7/SS2 | | | RE0/AD8/RD/P2D | 26 | | RE0/RD/P2D | | | RE1/AD9/WR/P2C | | | | | | RE1/WR/P2C | 18 | | RE2/AD10/CS/P2B | 26 | | RE2/CS/P2D | 18 | | RE3/AD11/P3C | | | RE3/P3C | | | | | | RE4/AD12/P3B | | | RE4/P3B | | | RE5/AD13/P1C | 26 | | RE5/P1C | 18 | | RE6/AD14/P1B | 26 | | RE6/P1B | | | RE7/AD15/ECCP2/P2A | | | | | | RE7/ECCP2/P2A | | | RF0/AN5 | | | RF1/AN6/C2OUT | 19, 27 | | RF2/AN7/C1OUT | 19, 27 | | RF3/AN8 | | | RF4/AN9 | | | | | | RF5/AN10/CVREF | | | RF6/AN11 | , | | RF7/SS1 | | | RG0/ECCP3/P3A | 20, 28 | | RG1/TX2/CK2 | 20. 28 | | RG2/RX2/DT2 | 20 28 | | RG3/CCP4/P3D | | | | | | RG4/CCP5/P1D | | | RG5 | | | RG5/MCLR/VPP | 13, 21 | | RH0/A16 | 29 | | RH1/A17 | 29 | | RH2/A18 | | | RH3/A19 | | | RH4/AN12/P3C | | | | | | RH5/AN13/P3B | | | RH6/AN14/P1C | | | RH7/AN15/P1B | 29 | | RJ0/ALE | 30 | | RJ1/ <del>OE</del> | 30 | | RJ2/WRL | | | RJ3/WRH | | | | | | RJ4/BA0 | | | RJ5/ <u>CE</u> | | | RJ6/ <u>LB</u> | 30 | | RJ7/ <del>UB</del> | 30 | | VDD | 20 | | VDD | | | Vss | | | Vss | | | v 00 | ວ∪ | | Pinout I/O Descriptions | | |------------------------------------|------| | PIC18F6628/6723 | . 13 | | PIC18F8628/8723 | . 21 | | Power-Managed Modes | 3 | | and A/D Operation | . 38 | | Product Identification System | . 59 | | R | | | Reader Response | . 58 | | Registers | | | ADCON0 (A/D Control 0) | . 31 | | ADCON1 (A/D Control 1) | . 32 | | ADCON2 (A/D Control 2) | . 33 | | DEVID1 (Device ID 1) | . 42 | | DEVID2 (Device ID 2) | . 42 | | Revision History | . 51 | | S | | | Special Features of the CPU | . 41 | | Device ID Registers | . 41 | | Special Microcontroller Features | 3 | | Т | | | Timing Diagrams | | | A/D Conversion | . 47 | | Timing Diagrams and Specifications | | | A/D Conversion Requirements | . 47 | | V | | | Voltage-Frequency Graphs | | | Extended (PIC18F8723) | . 44 | | Industrial (PIC18F8723) | | | Industrial (PIC18LF8723) | | | w | | | WWW Address | 57 | | MMM On Line Support | | #### THE MICROCHIP WEB SITE Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing - 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 Microchip's 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 web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions. #### **CUSTOMER SUPPORT** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - · Technical Support - · Development Systems Information Line Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the web site at: http://support.microchip.com ### **READER RESPONSE** It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150. Please list the following information, and use this outline to provide us with your comments about this document. | lo: | Technical Publications Manager | Total Pages Sent | | |-----------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------|--| | RE: | Reader Response | | | | Fron | m: Name | | | | | · • | | | | | | | | | | | FAV. ( | | | Δnn | Telephone: ()<br>lication (optional): | FAX: () | | | | ıld you like a reply?YN | | | | | · — · — | Liv. A. N. J. Boosse (B. | | | Devi | ice: PIC18F8723 Family | Literature Number: DS39894B | | | Que | stions: | | | | 1. ' | What are the best features of this do | cument? | | | • | | | | | | | | | | 2. | How does this document meet your h | nardware and software development needs? | | | | | | | | | | | | | 3. | Oo you find the organization of this document easy to follow? If not, why? | | | | • | | | | | | | | | | 4. | what additions to the document do y | ou think would enhance the structure and subject? | | | | | | | | 5. | What deletions from the document or | ould be made without affecting the overall usefulness? | | | J. | what deletions from the document of | ould be made without affecting the overall decidiness: | | | • | | | | | 6. Is there any incorrect or misleading information (what and where)? | | nformation (what and where)? | | | • | g | | | | - | | | | | 7. | How would you improve this docume | ent? | | | | | | | | • | | | | | | - | | | ## PIC18F8723 FAMILY PRODUCT IDENTIFICATION SYSTEM To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. | PART N<br>Device | - $+$ $+$ $+$ | Examples: a) PIC18LF6723-I/PT 301 = Industrial temp., TQFP package, Extended VDD limits, QTP pattern #301. | |---------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------| | Device <sup>(1) (2)</sup> | PIC18F6628/6723, PIC18F8628/8723,<br>VDD range 4.2V to 5.5V<br>PIC18LF6628/6723, PIC18LF6628/6723 <sup>(</sup><br>VDD range 2.0V to 5.5V | b) PIC18F6723-E/PT = Extended temp., TQFP package, standard VDD limits. | | Temperature<br>Range | I = -40°C to +85°C (Industrial)<br>E = -40°C to +125°C (Extended) | | | Package | PT = TQFP (Thin Quad Flatpack) | | | Pattern | QTP, SQTP, Code or Special Requirements (blank otherwise) | Note 1: F = Standard Voltage Range LF = Wide Voltage Range 2: T = in tape and reel TQFP packages only. | ## WORLDWIDE SALES AND SERVICE #### **AMERICAS** **Corporate Office** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://support.microchip.com Web Address: www.microchip.com Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455 **Boston** Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088 Chicago Itasca. IL Tel: 630-285-0071 Fax: 630-285-0075 Cleveland Independence, OH Tel: 216-447-0464 Fax: 216-447-0643 **Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924 Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260 Kokomo Kokomo, IN Tel: 765-864-8360 Fax: 765-864-8387 Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445 Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509 #### ASIA/PACIFIC **Asia Pacific Office** Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 **Australia - Sydney** Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 China - Beijing Tel: 86-10-8528-2100 Fax: 86-10-8528-2104 China - Chengdu Tel: 86-28-8665-5511 Fax: 86-28-8665-7889 China - Hong Kong SAR Tel: 852-2401-1200 Fax: 852-2401-3431 China - Nanjing Tel: 86-25-8473-2460 Fax: 86-25-8473-2470 China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205 China - Shanghai Tel: 86-21-5407-5533 Fax: 86-21-5407-5066 China - Shenyang Tel: 86-24-2334-2829 Fax: 86-24-2334-2393 China - Shenzhen Tel: 86-755-8203-2660 Fax: 86-755-8203-1760 China - Wuhan Tel: 86-27-5980-5300 Fax: 86-27-5980-5118 China - Xiamen Tel: 86-592-2388138 Fax: 86-592-2388130 China - Xian Tel: 86-29-8833-7252 Fax: 86-29-8833-7256 China - Zhuhai Tel: 86-756-3210040 Fax: 86-756-3210049 #### ASIA/PACIFIC India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4080 India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632 India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513 Japan - Yokohama Tel: 81-45-471- 6166 Fax: 81-45-471-6122 Korea - Daegu Tel: 82-53-744-4301 Fax: 82-53-744-4302 Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934 Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859 Malaysia - Penang Tel: 60-4-227-8870 Fax: 60-4-227-4068 Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069 Singapore Tel: 65-6334-8870 Fax: 65-6334-8850 Taiwan - Hsin Chu Tel: 886-3-6578-300 Fax: 886-3-6578-370 Taiwan - Kaohsiung Tel: 886-7-536-4818 Fax: 886-7-536-4803 Taiwan - Taipei Tel: 886-2-2500-6610 Fax: 886-2-2508-0102 Thailand - Bangkok Tel: 66-2-694-1351 Fax: 66-2-694-1350 #### **EUROPE** Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4450-2828 Fax: 45-4485-2829 France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 **Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44 Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781 Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340 Spain - Madrid Tel: 34-91-708-08-90 Fax: 34-91-708-08-91 **UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820 03/26/09