# PIC18F2458/2553/4458/4553 Data Sheet 28/40/44-Pin High-Performance, Enhanced Flash, USB 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 OR 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 OR 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, Accuron, dsPIC, KEELOQ, KEELOQ logo, microID, MPLAB, PIC, PICmicro, PICSTART, PRO MATE, rfPIC and SmartShunt are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. AmpLab, FilterLab, Linear Active Thermistor, Migratable Memory, MXDEV, MXLAB, SEEVAL, SmartSensor 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, ECAN, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, PICkit, PICDEM, PICDEM.net, PICLAB, PICtail, PowerCal, PowerInfo, PowerMate, PowerTool, REAL ICE, rfLAB, Select Mode, Smart Serial, SmartTel, Total Endurance, UNI/O, 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. © 2007, 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. ## 28/40/44-Pin High-Performance, Enhanced Flash, USB Microcontrollers with 12-Bit A/D and nanoWatt Technology #### **Universal Serial Bus Features:** - USB V2.0 Compliant - Low Speed (1.5 Mb/s) and Full Speed (12 Mb/s) - Supports Control, Interrupt, Isochronous and Bulk Transfers - · Supports up to 32 Endpoints (16 bidirectional) - · 1-Kbyte Dual Access RAM for USB - On-Chip USB Transceiver with On-Chip Voltage Regulator - · Interface for Off-Chip USB Transceiver - Streaming Parallel Port (SPP) for USB Streaming Transfers (40/44-pin devices only) #### **Power-Managed Modes:** - · Run: CPU On, Peripherals On - · Idle: CPU Off, Peripherals On - · Sleep: CPU Off, Peripherals Off - Idle mode Currents Down to 5.8 μA Typical - Sleep mode Currents Down to 0.1 μA Typical - Timer1 Oscillator: 1.1 μA Typical, 32 kHz, 2V - Watchdog Timer: 2.1 μA Typical - · Two-Speed Oscillator Start-up #### **Special Microcontroller Features:** - C Compiler Optimized Architecture with Optional Extended Instruction Set - 100,000 Erase/Write Cycle Enhanced Flash Program Memory Typical - 1,000,000 Erase/Write Cycle Data EEPROM Memory Typical - Flash/Data EEPROM Retention: > 40 Years - · Self-Programmable under Software Control - · Priority Levels for Interrupts - 8 x 8 Single-Cycle Hardware Multiplier - Extended Watchdog Timer (WDT): - Programmable period from 41 ms to 131s - · Programmable Code Protection - Single-Supply 5V In-Circuit Serial Programming™ (ICSP™) via Two Pins - · In-Circuit Debug (ICD) via Two Pins - Optional Dedicated ICD/ICSP Port (44-pin TQFP package only) - Wide Operating Voltage Range (2.0V to 5.5V) #### Flexible Oscillator Structure: - Four Crystal modes, Including High-Precision PLL for USB - · Two External Clock modes, up to 48 MHz - · Internal Oscillator Block: - 8 user-selectable frequencies, from 31 kHz to 8 MHz - User-tunable to compensate for frequency drift - Secondary Oscillator using Timer1 @ 32 kHz - Dual Oscillator Options allow Microcontroller and USB module to Run at Different Clock Speeds - · Fail-Safe Clock Monitor: - Allows for safe shutdown if any clock stops #### Peripheral Highlights: - High-Current Sink/Source: 25 mA/25 mA - Three External Interrupts - Four Timer modules (Timer0 to Timer3) - Up to 2 Capture/Compare/PWM (CCP) modules: - Capture is 16-bit, max. resolution 5.2 ns (Tcy/16) - Compare is 16-bit, max. resolution 83.3 ns (Tcy) - PWM output: PWM resolution is 1 to 10-bits - · Enhanced Capture/Compare/PWM (ECCP) module: - Multiple output modes - Selectable polarity - Programmable dead time - Auto-shutdown and auto-restart - Enhanced USART module: - LIN bus support - Master Synchronous Serial Port (MSSP) module supporting 3-wire SPI (all 4 modes) and I<sup>2</sup>C™ Master and Slave modes - 12-Bit, up to 13-Channel Analog-to-Digital Converter module (A/D) with Programmable Acquisition Time - Dual Analog Comparators with Input Multiplexing Note: This document is supplemented by the "PIC18F2455/2550/4455/4550 Data Sheet" (DS39632). See Section 1.0 "Device Overview". | | Prog | ram Memory | Data | Data Memory | | 12-Bit | CODIFOOD | | M | SSP | RT | ō. | Timoro | |------------|------------------|----------------------------|-----------------|----------------|----|--------|-------------------|-----|-----|-----------------------------|------|-----|--------------------| | Device | Flash<br>(bytes) | # Single-Word Instructions | SRAM<br>(bytes) | EEPROM (bytes) | | | CCP/ECCP<br>(PWM) | SPP | SPI | Master<br>I <sup>2</sup> C™ | EUSA | Com | Timers<br>8/16-Bit | | PIC18F2458 | 24K | 12288 | | | 24 | 10 | 2/0 | No | | | | | | | PIC18F2553 | 32K | 16384 | 2048 | 256 | 10 | 2/0 | INO | | V | 4 | 2 | 1/3 | | | PIC18F4458 | 24K | 12288 | 2040 | 250 | 35 | 13 | 4.44 | Yes | " | ľ | ' | 2 | 1/3 | | PIC18F4553 | 32K | 16384 | | | 33 | 13 | 1/1 | 165 | | | | | | ### Pin Diagrams #### 28-Pin SPDIP, SOIC #### 40-Pin PDIP Note 1: RB3 is the alternate pin for CCP2 multiplexing ### Pin Diagrams (Continued) #### **Table of Contents** | 1.0 | Device Overview | 5 | |------|-------------------------------------------------------|----| | 2.0 | 12-Bit Analog-to-Digital Converter (A/D) Module | 19 | | 3.0 | Special Features of the CPU | 29 | | 4.0 | Electrical Characteristics | 31 | | | Packaging Information | | | Appe | endix A: Revision History | 37 | | Appe | endix B: Device Differences | 37 | | Appe | endix C: Migration From Mid-Range to Enhanced Devices | 38 | | Appe | endix D: Migration From High-End to Enhanced Devices | 38 | | Inde | · · · · · · · · · · · · · · · · · · · | 39 | | The | Microchip Web Site | 41 | | Cust | omer Change Notification Service | 41 | | Cust | omer Support | 41 | | Read | der Response | 42 | | Prod | uct Identification System. | 43 | #### 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. #### 1.0 DEVICE OVERVIEW This document contains device-specific information for the following devices: PIC18F2458PIC18F4458PIC18F2553PIC18F4553 Note: This data sheet documents only the devices' features and specifications that are in addition to the features and specifications of the PIC18F2455/2550/4455/4550 devices. For information on the features and specifications shared by the PIC18F2458/2553/4458/4553 and PIC18F2455/2550/4455/4550 devices, see the "PIC18F2455/2550/4455/4550 Data Sheet" (DS39632). The PIC18F4553 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 PIC18F4553 family 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 PIC18F4553 family implements a 12-bit A/D Converter. The A/D Converter incorporates 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 The PIC18F2458/2553/4458/4553 devices are available in 28-pin and 40/44-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 (24 Kbytes for PIC18FX458 devices, 32 Kbytes for PIC18FX553). - A/D channels (10 for 28-pin devices, 13 for 40-pin and 44-pin devices). - 3. I/O ports (3 bidirectional ports and 1 input only port on 28-pin devices, 5 bidirectional ports on 40-pin and 44-pin devices). - CCP and Enhanced CCP implementation (28-pin devices have two standard CCP modules, 40-pin and 44-pin devices have one standard CCP module and one ECCP module). - Streaming Parallel Port (present only on 40/44-pin devices). 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. Members of the PIC18F4553 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 PIC18F2458), accommodate an operating VDD range of 4.2V to 5.5V. Low-voltage parts, designated by "LF" (such as PIC18LF2458), function over an extended VDD range of 2.0V to 5.5V. TABLE 1-1: DEVICE FEATURES | Features | PIC18F2458 | PIC18F2553 | PIC18F4458 | PIC18F4553 | |----------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | Operating Frequency | DC – 48 MHz | DC – 48 MHz | DC – 48 MHz | DC – 48 MHz | | Program Memory (Bytes) | 24576 | 32768 | 24576 | 32768 | | Program Memory<br>(Instructions) | 12288 | 16384 | 12288 | 16384 | | Data Memory (Bytes) | 2048 | 2048 | 2048 | 2048 | | Data EEPROM Memory (Bytes) | 256 | 256 | 256 | 256 | | Interrupt Sources | 19 | 19 | 20 | 20 | | I/O Ports | Ports A, B, C, (E) | Ports A, B, C, (E) | Ports A, B, C, D, E | Ports A, B, C, D, E | | Timers | 4 | 4 | 4 | 4 | | Capture/Compare/PWM<br>Modules | 2 | 2 | 1 | 1 | | Enhanced Capture/<br>Compare/PWM Modules | 0 | 0 | 1 | 1 | | Serial Communications | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | MSSP,<br>Enhanced USART | | Universal Serial Bus (USB)<br>Module | 1 | 1 | 1 | 1 | | Streaming Parallel Port (SPP) | No | No | Yes | Yes | | 12-Bit Analog-to-Digital<br>Converter Module | 10 Input Channels | 10 Input Channels | 13 Input Channels | 13 Input Channels | | Comparators | 2 | 2 | 2 | 2 | | Resets (and Delays) | POR, BOR, WDT, RESET Instruction, Stack Full, Stack Underflow, MCLR (optional), (PWRT, OST) | POR, BOR, WDT, RESET Instruction, Stack Full, Stack Underflow, MCLR (optional), (PWRT, OST) | POR, BOR, WDT, RESET Instruction, Stack Full, Stack Underflow, MCLR (optional), (PWRT, OST) | POR, BOR, WDT, RESET Instruction, Stack Full, Stack Underflow, MCLR (optional), (PWRT, OST) | | Programmable High/<br>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<br>Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>Enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>Enabled | | Packages | 28-Pin SPDIP<br>28-Pin SOIC | 28-Pin SPDIP<br>28-Pin SOIC | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP | | Corresponding Devices with 10-Bit A/D | PIC18F2455 | PIC18F2550 | PIC18F4455 | PIC18F4550 | **Preliminary** FIGURE 1-2: PIC18F4458/4553(40/44-PIN) BLOCK DIAGRAM Data Bus<8> PORTA Table Pointer<21> RA0/AN0 Data Latch RA1/AN1 8 8 inc/dec logic RA2/AN2/VREF-/CVREF Data Memory RA3/AN3/VREF+ (2 Kbytes) PCLATU PCLATH RA4/T0CKI/C1OUT/RCV 21 RA5/AN4/SS/HLVDIN/C2OUT 20 Address Latch OSC2/CLKO/RA6 PCU PCH PCL Program Counter 12 Data Address<12> PORTB 31 Level Stack RB0/AN12/INT0/FLT0/SDI/SDA /12 Address Latch RB1/AN10/INT1/SCK/SCL BSR Access FSR0 RB2/AN8/INT2/VMO Program Memory (24/32 Kbytes) STKPTR Bank RB3/AN9/CCP2<sup>(4)</sup>/VPO FSR1 FSR2 RB4/AN11/KBI0/CSSPP 12 Data Latch RB5/KBI1/PGM RB6/KBI2/PGC RB7/KBI3/PGD logic Table Latch PORTC Address ROM Latch Decode Instruction Bus <16> RC0/T10S0/T13CKI RC1/T10SI/CCP2<sup>(4)</sup>/UOE RC2/CCP1/P1A IR RC4/D-/VM RC5/D+/VP 8 RC6/TX/CK RC7/RX/DT/SDO Instruction State Machine Decode & Control Control Signals PRODH PRODL **PORTD** 8 x 8 Multiply VDD, VSS $\boxtimes$ Internal Power-up Oscillator RD0/SPP0:RD4/SPP4 OSC1<sup>(2)</sup> $\boxtimes$ Timer RD5/SPP5/P1B Block RD6/SPP6/P1C OSC2<sup>(2)</sup> $\boxtimes$ -Oscillator INTRO RD7/SPP7/P1D Start-up Time Oscillator $\boxtimes$ T10SI . 8 Power-on 8 MHz $\boxtimes$ T10S0 Reset ALÚ<8> Oscillator Watchdog 8 ICPGC(3) $\bowtie$ Single-Supply Programming Brown-out ICPGD(3) $\boxtimes \leftrightarrow$ PORTE Reset In-Circuit RE0/AN5/CK1SPP ICPORTS(3) Debugger Fail-Safe RE1/AN6/CK2SPP Clock Monitor Band Gap RE2/AN7/OESPP ICRST(3) $\boxtimes$ MCLR/VPP/RE3<sup>(1)</sup> Reference MCLR<sup>(1)</sup> $\bowtie$ USB Voltage Regulator $\boxtimes$ BOR Data Timer0 Timer1 Timer2 Timer3 HLVD **EEPRON** ADC ECCP1 CCP2 MSSF EUSART Comparator USB RE3 is multiplexed with $\overline{\text{MCLR}}$ and is only available when the $\overline{\text{MCLR}}$ Resets are disabled. OSC1/CLKI and OSC2/CLKO are only available in select oscillator modes and when these pins are not being used as digital I/O. These pins are only available on 44-pin TQFP packages under certain conditions. RB3 is the alternate pin for CCP2 multiplexing. TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS | Pin Name | Pin<br>Number Pin Buffer | | Buffer | Description | | | | | |---------------------------|--------------------------|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Fili Name | SPDIP,<br>SOIC | Type | Туре | Description | | | | | | MCLR/VPP/RE3<br>MCLR | 1 | I | ST | Master Clear (input) or programming voltage (input). Master Clear (Reset) input. This pin is an active-low Reset to the device. | | | | | | VPP | | Р | | Programming voltage input. | | | | | | RE3 | | I | ST | Digital input. | | | | | | OSC1/CLKI<br>OSC1<br>CLKI | 9 | <br> - | Analog<br>Analog | Oscillator crystal or external clock input. Oscillator crystal input or external clock source input. External clock source input. Always associated with pin function OSC1. (See OSC2/CLKO pin.) | | | | | | OSC2/CLKO/RA6<br>OSC2 | 10 | 0 | _ | Oscillator crystal or clock output. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. | | | | | | CLKO | | 0 | _ | In select modes, 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 CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input O = Output P = Power **Note 1:** Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. © 2007 Microchip Technology Inc. Preliminary DS39887B-page 9 TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin<br>Number | Pin Buffer | | Description | |-----------------------------|----------------|------------|----------|-------------------------------------------| | | SPDIP,<br>SOIC | Type | Type | · | | | | | | PORTA is a bidirectional I/O port. | | RA0/AN0 | 2 | | | | | RA0 | | I/O | TTL | Digital I/O. | | AN0 | | - 1 | Analog | Analog input 0. | | RA1/AN1 | 3 | | | | | RA1 | | I/O | TTL | Digital I/O. | | AN1 | | I | Analog | Analog input 1. | | RA2/AN2/VREF-/CVREF | 4 | | | | | RA2 | | I/O | TTL | Digital I/O. | | AN2 | | I | Analog | Analog input 2. | | VREF- | | - | Analog | A/D reference voltage (low) input. | | CVREF | | 0 | Analog | Analog comparator reference output. | | RA3/AN3/VREF+ | 5 | | | 2. 1. 1.10 | | RA3 | | I/O | TTL | Digital I/O. | | AN3<br>VREF+ | | | Analog | Analog input 3. | | | | ı | Analog | A/D reference voltage (high) input. | | RA4/T0CKI/C1OUT/RCV | 6 | 1/0 | ОТ | D::::4-11/O | | RA4<br>T0CKI | | I/O | ST<br>ST | Digital I/O. Timer0 external clock input. | | C1OUT | | 0 | 51 | Comparator 1 output. | | RCV | | - | TTL | External USB transceiver RCV input. | | <u> </u> | 7 | • | 112 | External GOB transceiver NOV impat. | | RA5/AN4/SS/<br>HLVDIN/C2OUT | 7 | | | | | RA5 | | I/O | TTL | Digital I/O. | | AN4 | | 1/0 | Analog | Analog input 4. | | SS | | i | TTL | SPI slave select input. | | HLVDIN | | | Analog | High/Low-Voltage Detect input. | | C2OUT | | 0 | | Comparator 2 output. | | RA6 | _ | _ | _ | See the OSC2/CLKO/RA6 pin. | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS (CONTINUED) | | Pin<br>Number | Pin | D. How | | |----------------------------|----------------|----------|----------------|--------------------------------------------------------------------------------------| | Pin Name | SPDIP,<br>SOIC | Type | Buffer<br>Type | Description | | | | | | PORTB is a bidirectional I/O port. PORTB can be software | | RB0/AN12/INT0/FLT0/ | 21 | | | programmed for internal weak pull-ups on all inputs. | | SDI/SDA | 21 | | | | | RB0 | | I/O | TTL | Digital I/O. | | AN12<br>INT0 | | | Analog<br>ST | Analog input 12. External interrupt 0. | | FLT0 | | i | ST | PWM Fault input (CCP1 module). | | SDI | | İ | ST | SPI data in. | | SDA | | I/O | ST | I <sup>2</sup> C™ data I/O. | | RB1/AN10/INT1/SCK/<br>SCL | 22 | | | | | RB1 | | I/O | TTL | Digital I/O. | | AN10<br>INT1 | | | Analog<br>ST | Analog input 10. External interrupt 1. | | SCK | | I/O | ST | Synchronous serial clock input/output for SPI mode. | | SCL | | I/O | ST | Synchronous serial clock input/output for I <sup>2</sup> C mode. | | RB2/AN8/INT2/VMO | 23 | | | | | RB2 | | I/O | TTL | Digital I/O. | | AN8<br>INT2 | | | Analog<br>ST | Analog input 8. External interrupt 2. | | VMO | | Ö | — | External USB transceiver VMO output. | | RB3/AN9/CCP2/VPO | 24 | | | | | RB3 | | I/O | TTL | Digital I/O. | | AN9<br>CCP2 <sup>(1)</sup> | | 1 | Analog | Analog input 9. | | VPO | | I/O<br>O | ST<br>— | Capture 2 input/Compare 2 output/PWM 2 output. External USB transceiver VPO output. | | RB4/AN11/KBI0 | 25 | | | External GGB trailedgives vi G datpat. | | RB4 | | I/O | TTL | Digital I/O. | | AN11 | | 1 | Analog | Analog input 11. | | KBI0 | | ı | TTL | Interrupt-on-change pin. | | RB5/KBI1/PGM<br>RB5 | 26 | I/O | TTL | Digital I/O. | | KBI1 | | 1/O | TTL | Interrupt-on-change pin. | | PGM | | I/O | ST | Low-Voltage ICSP™ Programming enable pin. | | RB6/KBI2/PGC | 27 | | | | | RB6 | | I/O | TTL | Digital I/O. | | KBI2<br>PGC | | I<br>I/O | TTL<br>ST | Interrupt-on-change pin. In-Circuit Debugger and ICSP programming clock pin. | | RB7/KBI3/PGD | 28 | 1/0 | 31 | In-onealt Debugger and 100F programming Gook pill. | | RB7 | 20 | I/O | TTL | Digital I/O. | | KBI3 | | ı | TTL | Interrupt-on-change pin. | | PGD | | I/O | ST | 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 I = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pin<br>Number | Pin | Buffer | Description | |------------------------------------------------------------------|----------------|--------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | SPDIP,<br>SOIC | Type | Туре | Description | | | | | | PORTC is a bidirectional I/O port. | | RC0/T10SO/T13CKI<br>RC0<br>T10SO<br>T13CKI | 11 | I/O<br>O<br>I | ST<br>—<br>ST | Digital I/O. Timer1 oscillator output. Timer1/Timer3 external clock input. | | RC1/T1OSI/CCP2/UOE<br>RC1<br>T1OSI<br>CCP2 <sup>(2)</sup><br>UOE | 12 | I/O<br>I<br>I/O | ST<br>CMOS<br>ST<br>— | Digital I/O. Timer1 oscillator input. Capture 2 input/Compare 2 output/PWM2 output. External USB transceiver OE output. | | RC2/CCP1<br>RC2<br>CCP1 | 13 | I/O<br>I/O | ST<br>ST | Digital I/O. Capture 1 input/Compare 1 output/PWM1 output. | | RC4/D-/VM<br>RC4<br>D-<br>VM | 15 | <br> <br> <br> <br> | TTL<br>—<br>TTL | Digital input. USB differential minus line (input/output). External USB transceiver VM input. | | RC5/D+/VP<br>RC5<br>D+<br>VP | 16 | <br> <br> <br> <br> <br> | TTL<br>—<br>TTL | Digital input. USB differential plus line (input/output). External USB transceiver VP input. | | RC6/TX/CK<br>RC6<br>TX<br>CK | 17 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART asynchronous transmit. EUSART synchronous clock (see RX/DT). | | RC7/RX/DT/SDO<br>RC7<br>RX<br>DT<br>SDO | 18 | I/O<br>I<br>I/O<br>O | ST<br>ST<br>ST | Digital I/O. EUSART asynchronous receive. EUSART synchronous data (see TX/CK). SPI data out. | | RE3 | _ | _ | | See MCLR/VPP/RE3 pin. | | Vusb | 14 | O<br>P | _<br>_ | Internal USB transceiver power supply. When the internal USB regulator is enabled, Vusb is the regulator output. When the internal USB regulator is disabled, Vusb is the power input for the USB transceiver. | | Vss | 8, 19 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 20 | Р | _ | Positive supply for logic and I/O pins. | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. **2:** Default assignment for CCP2 when CCP2MX Configuration bit is set. TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS | Din Name | Pin Number | | ber | Pin | Buffer | Description | |---------------------------|------------|-----|------|------|------------------|----------------------------------------------------------------------------------------------------------------------------------| | Pili Name | PDIP | QFN | TQFP | Туре | Туре | Description | | MCLR/VPP/RE3<br>MCLR | 1 | 18 | 18 | I | ST | Master Clear (input) or programming voltage (input). Master Clear (Reset) input. This pin is an active-low Reset to the device. | | VPP | | | | Р | ST | Programming voltage input. | | RE3 | | | | ı | 51 | Digital input. | | OSC1/CLKI<br>OSC1<br>CLKI | 13 | 32 | 30 | <br> | Analog<br>Analog | , , | | OSC2/CLKO/RA6<br>OSC2 | 14 | 33 | 31 | 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 CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. 3: These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. © 2007 Microchip Technology Inc. Preliminary DS39887B-page 13 TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pi | n Numl | ber | Pin Buffer | | Description | |--------------------------------------|------|--------|------|----------------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------| | Pili Name | PDIP | QFN | TQFP | Туре | Туре | Description | | | | | | | | PORTA is a bidirectional I/O port. | | RA0/AN0<br>RA0<br>AN0 | 2 | 19 | 19 | I/O<br>I | TTL<br>Analog | Digital I/O.<br>Analog input 0. | | RA1/AN1<br>RA1<br>AN1 | 3 | 20 | 20 | I/O<br>I | TTL<br>Analog | Digital I/O.<br>Analog input 1. | | RA2/AN2/VREF-/<br>CVREF | 4 | 21 | 21 | | | | | RA2<br>AN2<br>VREF-<br>CVREF | | | | I/O<br> <br> <br> <br> <br> <br> | TTL<br>Analog<br>Analog<br>Analog | Digital I/O. Analog input 2. A/D reference voltage (low) input. Analog comparator reference output. | | RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+ | 5 | 22 | 22 | 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/C1OUT/<br>RCV | 6 | 23 | 23 | | | | | RA4<br>T0CKI<br>C1OUT<br>RCV | | | | I/O<br>I<br>O<br>I | ST<br>ST<br>—<br>TTL | Digital I/O. Timer0 external clock input. Comparator 1 output. External USB transceiver RCV input. | | RA5/AN4/SS/<br>HLVDIN/C2OUT | 7 | 24 | 24 | | | | | RA5<br>AN4<br>SS<br>HLVDIN<br>C2OUT | | | | I/O<br> <br> -<br> <br> O | TTL<br>Analog<br>TTL<br>Analog<br>— | Digital I/O. Analog input 4. SPI slave select input. High/Low-Voltage Detect input. Comparator 2 output. | | RA6 | _ | _ | _ | _ | _ | See the OSC2/CLKO/RA6 pin. | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. - 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. - 3: These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pin Number | | | Pin | Buffer | Description | | | |-------------------------------------------------------------------|------------|-----|------|-----------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Pin Name | PDIP | QFN | TQFP | Туре | Туре | Description | | | | RB0/AN12/INT0/ | 33 | 9 | 8 | | | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | | | FLT0/SDI/SDA RB0 AN12 INT0 FLT0 SDI SDA RB1/AN10/INT1/SCK/ | 34 | 10 | 9 | I/O<br>I<br>I<br>I<br>I/O | TTL<br>Analog<br>ST<br>ST<br>ST<br>ST | Digital I/O. Analog input 12. External interrupt 0. Enhanced PWM Fault input (ECCP1 module). SPI data in. I <sup>2</sup> C™ data I/O. | | | | SCL RB1 AN10 INT1 SCK SCL | 5 | 10 | 3 | I/O<br>I<br>I<br>I/O<br>I/O | TTL<br>Analog<br>ST<br>ST<br>ST | Digital I/O. Analog input 10. External interrupt 1. Synchronous serial clock input/output for SPI mode. Synchronous serial clock input/output for I <sup>2</sup> C mode. | | | | RB2/AN8/INT2/VMO<br>RB2<br>AN8<br>INT2<br>VMO | 35 | 11 | 10 | I/O<br>I<br>I<br>O | TTL<br>Analog<br>ST<br>— | Digital I/O. Analog input 8. External interrupt 2. External USB transceiver VMO output. | | | | RB3/AN9/CCP2/VPO<br>RB3<br>AN9<br>CCP2 <sup>(1)</sup><br>VPO | 36 | 12 | 11 | I/O<br>I<br>I/O<br>O | TTL<br>Analog<br>ST<br>— | Digital I/O. Analog input 9. Capture 2 input/Compare 2 output/PWM 2 output. External USB transceiver VPO output. | | | | RB4/AN11/KBI0/CSSPP<br>RB4<br>AN11<br>KBI0<br>CSSPP | 37 | 14 | 14 | I/O<br>I<br>I<br>O | TTL<br>Analog<br>TTL<br>— | Digital I/O. Analog input 11. Interrupt-on-change pin. SPP chip select control output. | | | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 38 | 15 | 15 | 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 | 39 | 16 | 16 | 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 | 40 | 17 | 17 | 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 I = Input O = Output P P = Power **Note 1:** Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. - 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. - **3:** These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pi | n Num | ber | Pin Buffer | | Description | |----------------------------------------------------------------------|------|-------|------|----------------------|------------------|-------------------------------------------------------------------------------------------------------------------------| | Pin Name | PDIP | QFN | TQFP | Туре | Туре | Description | | | | | | | | PORTC is a bidirectional I/O port. | | RC0/T10SO/T13CKI<br>RC0<br>T10SO<br>T13CKI | 15 | 34 | 32 | I/O<br>O<br>I | ST<br>—<br>ST | Digital I/O. Timer1 oscillator output. Timer1/Timer3 external clock input. | | RC1/T1OSI/CCP2/<br>UOE<br>RC1<br>T1OSI<br>CCP2 <sup>(2)</sup><br>UOE | 16 | 35 | 35 | I/O<br>I<br>I/O<br>O | ST<br>CMOS<br>ST | Digital I/O. Timer1 oscillator input. Capture 2 input/Compare 2 output/PWM2 output. External USB transceiver OE output. | | RC2/CCP1/P1A<br>RC2<br>CCP1<br>P1A | 17 | 36 | 36 | I/O<br>I/O<br>O | ST<br>ST<br>TTL | Digital I/O. Capture 1 input/Compare 1 output/PWM1 output. Enhanced CCP1 PWM output, channel A. | | RC4/D-/VM<br>RC4<br>D-<br>VM | 23 | 42 | 42 | <br> /O<br> | TTL<br>—<br>TTL | Digital input. USB differential minus line (input/output). External USB transceiver VM input. | | RC5/D+/VP<br>RC5<br>D+<br>VP | 24 | 43 | 43 | <br> /O<br> | TTL<br>—<br>TTL | Digital input.<br>USB differential plus line (input/output).<br>External USB transceiver VP input. | | RC6/TX/CK<br>RC6<br>TX<br>CK | 25 | 44 | 44 | I/O<br>O<br>I/O | ST<br>—<br>ST | Digital I/O. EUSART asynchronous transmit. EUSART synchronous clock (see RX/DT). | | RC7/RX/DT/SDO<br>RC7<br>RX<br>DT<br>SDO | 26 | 1 | 1 | I/O<br>I/O<br>O | ST<br>ST<br>ST | Digital I/O. EUSART asynchronous receive. EUSART synchronous data (see TX/CK). SPI data out. | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels O = Output I = Input P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. - 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. - 3: These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) **TABLE 1-3:** | Pin Name | Pin Number | | | Pin | Buffer | Description | | | | |------------------------------------|------------|-----|------|-----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pili Name | PDIP | QFN | TQFP | Туре | Туре | Description | | | | | | | | | | | PORTD is a bidirectional I/O port or a Streaming Parallel Port (SPP). PORTD can be software programmed for internal weak pull-ups on all inputs. These pins have TTL input buffers when the SPP module is enabled. | | | | | RD0/SPP0<br>RD0<br>SPP0 | 19 | 38 | 38 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data. | | | | | RD1/SPP1<br>RD1<br>SPP1 | 20 | 39 | 39 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data. | | | | | RD2/SPP2<br>RD2<br>SPP2 | 21 | 40 | 40 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data. | | | | | RD3/SPP3<br>RD3<br>SPP3 | 22 | 41 | 41 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data. | | | | | RD4/SPP4<br>RD4<br>SPP4 | 27 | 2 | 2 | I/O<br>I/O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data. | | | | | RD5/SPP5/P1B<br>RD5<br>SPP5<br>P1B | 28 | 3 | 3 | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data.<br>ECCP1 PWM output, channel B. | | | | | RD6/SPP6/P1C<br>RD6<br>SPP6<br>P1C | 29 | 4 | 4 | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Streaming Parallel Port data.<br>ECCP1 PWM output, channel C. | | | | | RD7/SPP7/P1D<br>RD7<br>SPP7<br>P1D | 30 | 5 | 5 | I/O<br>I/O<br>O | ST<br>TTL<br>— | Digital I/O.<br>Streaming Parallel Port data.<br>ECCP1 PWM output, channel D. | | | | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input Р = Output = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. 3: These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. **Preliminary** © 2007 Microchip Technology Inc. DS39887B-page 17 TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pi | n Numl | ber | Pin | Buffer | Description | |-------------------------------------------------|-----------|-----------------|-------|---------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | PDIP | QFN | TQFP | Type | Type | Description | | RE0/AN5/CK1SPP<br>RE0<br>AN5<br>CK1SPP | 8 | 25 | 25 | /O — O | ST<br>Analog | PORTE is a bidirectional I/O port. Digital I/O. Analog input 5. SPP clock 1 output. | | RE1/AN6/CK2SPP<br>RE1<br>AN6<br>CK2SPP | 9 | 26 | 26 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 6.<br>SPP clock 2 output. | | RE2/AN7/OESPP<br>RE2<br>AN7<br>OESPP | 10 | 27 | 27 | I/O<br>I<br>O | ST<br>Analog<br>— | Digital I/O.<br>Analog input 7.<br>SPP output enable output. | | RE3 | _ | _ | | | _ | See MCLR/VPP/RE3 pin. | | Vss | 12,<br>31 | 6, 30,<br>31 | 6, 29 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 11, 32 | 7, 8,<br>28, 29 | 7, 28 | Р | _ | Positive supply for logic and I/O pins. | | Vusb | 18 | 37 | 37 | О<br>Р | _<br>_ | Internal USB transceiver power supply. When the internal USB regulator is enabled, VUSB is the regulator output. When the internal USB regulator is disabled, VUSB is the power input for the USB transceiver. | | NC/ICCK/ICPGC <sup>(3)</sup> ICCK ICPGC | _ | _ | 12 | I/O<br>I/O | ST<br>ST | No Connect or dedicated ICD/ICSP™ port clock. In-Circuit Debugger clock. ICSP programming clock. | | NC/ICDT/ICPGD <sup>(3)</sup> ICDT ICPGD | _ | _ | 13 | I/O<br>I/O | ST<br>ST | No Connect or dedicated ICD/ICSP port clock. In-Circuit Debugger data. ICSP programming data. | | NC/ICRST/ICVPP <sup>(3)</sup><br>ICRST<br>ICVPP | _ | _ | 33 | l<br>P | _ | No Connect or dedicated ICD/ICSP port Reset. Master Clear (Reset) input. Programming voltage input. | | NC/ICPORTS <sup>(3)</sup><br>ICPORTS | _ | _ | 34 | Р | _ | No Connect or 28-pin device emulation. Enable 28-pin device emulation when connected to Vss. | | NC | _ | 13 | _ | _ | _ | No Connect. | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input O = Output P = Power Note 1: Alternate assignment for CCP2 when CCP2MX Configuration bit is cleared. 2: Default assignment for CCP2 when CCP2MX Configuration bit is set. 3: These pins are No Connect unless the ICPRT Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the DEBUG Configuration bit is cleared. ### 2.0 12-BIT ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE The Analog-to-Digital (A/D) Converter module has 10 inputs for the 28-pin devices and 13 for the 40-pin and 44-pin devices. 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 | t, 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)(1,2) 0110 = Channel 6 (AN6) $^{(1,2)}$ 0111 = Channel 7 (AN7)(1,2) 1000 = Channel 8 (AN8) 1001 = Channel 9 (AN9) 1010 = Channel 10 (AN10) 1011 = Channel 11 (AN11) 1100 = Channel 12 (AN12 1101 = Unimplemented<sup>(2)</sup> 1110 = Unimplemented<sup>(2)</sup> 1111 = Unimplemented<sup>(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 28-pin 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 <sup>(1)</sup> | R/W <sup>(1)</sup> | R/W <sup>(1)</sup> | |-------|-----|-------|-------|-------|--------------------|--------------------|--------------------| | _ | _ | 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 **VCFG1:** Voltage Reference Configuration bit (VREF- source) 1 = VREF- (AN2) 0 = Vss bit 4 VCFG0: Voltage Reference Configuration bit (VREF+ source) 1 = VREF+ (AN3) 0 = VDD bit 3-0 **PCFG3:PCFG0:** A/D Port Configuration Control bits: | PCFG3:<br>PCFG0 | AN12 | AN11 | AN10 | AN9 | AN8 | AN7 <sup>(2)</sup> | AN6 <sup>(2)</sup> | AN5 <sup>(2)</sup> | AN4 | AN3 | AN2 | AN1 | ANO | |-----------------|------|------|------|-----|-----|--------------------|--------------------|--------------------|-----|-----|-----|-----|-----| | 0000(1) | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0001 | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0010 | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0011 | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0100 | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0101 | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0110 | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | Α | | 0111(1) | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | Α | | 1000 | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | Α | | 1001 | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | Α | | 1010 | D | D | D | D | D | D | D | D | Α | Α | Α | Α | Α | | 1011 | D | D | D | D | D | D | D | D | D | Α | Α | Α | Α | | 1100 | D | D | D | D | D | D | D | D | D | D | Α | Α | Α | | 1101 | D | D | D | D | D | D | D | D | D | D | D | Α | Α | | 1110 | 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 | A = Analog input D = Digital I/O **Note 1:** The Reset value of the PCFG bits depends on the value of the PBADEN Configuration bit. When PBADEN = 1, PCFG<3:0> = 0000; when PBADEN = 0, PCFG<3:0> = 0111. 2: AN5 through AN7 are available only on 40-pin and 44-pin 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 justified 0 = Left justified bit 6 Unimplemented: Read as '0' bit 5-3 ACQT2:ACQT0: A/D Acquisition Time Select bits 111 **= 20 T**AD 110 **= 16 T**AD 101 **= 12 T**AD 100 **= 8 T**AD 011 **= 6 T**AD 010 **= 4** TAD 001 **= 2 TAD** 000 = 0 TAD<sup>(1)</sup> 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)<sup>(1)</sup> 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 as 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 register) 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 register) - 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. #### FIGURE 2-2: A/D TRANSFER FUNCTION #### FIGURE 2-3: ANALOG INPUT MODEL #### 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: $\begin{array}{lll} \text{CHOLD} & = & 25 \text{ pF} \\ \text{Rs} & = & 2.5 \text{ k}\Omega \\ \text{Conversion Error} & \leq & 1/2 \text{ LSb} \\ \end{array}$ VDD = $3V \rightarrow Rss = 4 k\Omega$ Temperature = $85^{\circ}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}))}) \\ \text{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** ``` TAMP + TC + TCOFF TACO TAMP 0.2 us 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 µs Temperature coefficient is only required for temperatures > 25°C. Below 25°C, TCOFF = 0 us. 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) \text{ }\mu\text{s} 1.56 \mu s TACO 0.2 \mu s + 1.56 \mu s + 1.2 \mu s 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 provides 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 | Operation ADCS2:ADCS0 | | | | | | | 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 | 48.00 MHz | | | | | | RC <sup>(1)</sup> | ×11 | 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 bits ACQT2:ACQT0 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, TRISB and TRISE 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. - **3:** The PBADEN bit in Configuration Register 3H configures PORTB pins to reset as analog or digital pins by controlling how the PCFG3:PCFG0 bits in ADCON1 are reset. #### 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 and the ACQT2:ACQT0 bits are set to '010', and selecting a 4 TAD acquisition time 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) © 2007 Microchip Technology Inc. Preliminary DS39887B-page 27 #### 2.8 Use of the CCP2 Trigger An A/D conversion can be started by the Special Event Trigger of the CCP2 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 (firmware must move 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<br>on Page: | |----------------------|----------------------------------------------------------|-----------------------|--------------|----------------|--------------------|--------------------|--------------------|--------------------|-----------------------------| | INTCON | GIE/GIEH | PEIE/GIEL | TMR0IE | INT0IE | RBIE | TMR0IF | INT0IF | RBIF | (4) | | PIR1 | SPPIF <sup>(1)</sup> | ADIF | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF | (4) | | PIE1 | SPPIE <sup>(1)</sup> | ADIE | RCIE | TXIE | SSPIE | CCP1IE | TMR2IE | TMR1IE | (4) | | IPR1 | SPPIP <sup>(1)</sup> | ADIP | RCIP | TXIP | SSPIP | CCP1IP | TMR2IP | TMR1IP | (4) | | PIR2 | OSCFIF | CMIF | USBIF | EEIF | BCLIF | HLVDIF | TMR3IF | CCP2IF | (4) | | PIE2 | OSCFIE | CMIE | USBIE | EEIE | BCLIE | HLVDIE | TMR3IE | CCP2IE | (4) | | IPR2 | OSCFIP | CMIP | USBIP | EEIP | BCLIP | HLVDIP | TMR3IP | CCP2IP | (4) | | ADRESH | A/D Result Register High Byte | | | | | | | | | | ADRESL | A/D Result | Register Lov | w Byte | | | | | | (4) | | ADCON0 | _ | _ | CHS3 | CHS2 | CHS1 | CHS0 | GO/DONE | ADON | 19 | | ADCON1 | _ | _ | VCFG1 | VCFG0 | PCFG3 | PCFG2 | PCFG1 | PCFG0 | 20 | | ADCON2 | ADFM | _ | ACQT2 | ACQT1 | ACQT0 | ADCS2 | ADCS1 | ADCS0 | 21 | | PORTA | _ | RA6 <sup>(2)</sup> | RA5 | RA4 | RA3 | RA2 | RA1 | RA0 | (4) | | TRISA | _ | TRISA6 <sup>(2)</sup> | PORTA Da | ta Direction ( | Control Reg | ister | | | (4) | | PORTB | RB7 | RB6 | RB5 | RB4 | RB3 | RB2 | RB1 | RB0 | (4) | | TRISB | PORTB Dat | a Direction ( | Control Regi | ister | | | | | (4) | | LATB | PORTB Data Latch Register (Read and Write to Data Latch) | | | | | | | | | | PORTE <sup>(1)</sup> | RDPU | _ | _ | _ | RE3 <sup>(3)</sup> | RE2 <sup>(1)</sup> | RE1 <sup>(1)</sup> | RE0 <sup>(1)</sup> | (4) | | TRISE <sup>(1)</sup> | _ | _ | _ | _ | _ | TRISE2 | TRISE1 | TRISE0 | (4) | | LATE <sup>(1)</sup> | _ | _ | _ | _ | _ | PORTE Da | ita Latch Re | gister | (4) | **Legend:** — = unimplemented, read as '0'. Shaded cells are not used for A/D conversion. - Note 1: These registers and/or bits are not implemented on 28-pin devices and are read as '0'. - **2:** RA6 and its associated latch and data direction bits are enabled as I/O pins based on oscillator configuration; otherwise, they are read as '0'. - **3:** RE3 port bit is available only as an input pin when the MCLRE Configuration bit is '0'. - 4: For these Reset values, see the "PIC18F2455/2550/4455/4550 Data Sheet". ### 3.0 SPECIAL FEATURES OF THE CPU # Note: For additional details on the Configuration bits, refer to the "PIC18F2455/2550/4455/4550 Data Sheet", Section 25.1 "Configuration Bits". Device ID information presented in this section is for PIC18F2458/2553/4458/4553 only. PIC18F2458/2553/4458/4553 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 | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default/<br>Unprogrammed<br>Value | |---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------------------| | 3FFFEh | DEVID1 | DEV2 | DEV1 | DEV0 | REV4 | REV3 | REV2 | REV1 | REV0 | xxxx xxxx(1) | | 3FFFFFh | DEVID2 | DEV10 | DEV9 | DEV8 | DEV7 | DEV6 | DEV5 | DEV4 | DEV3 | xxxx xxxx <sup>(1)</sup> | **Legend:** x = unknown, u = unchanged Note 1: See Register 3-1 and Register 3-2 for DEVID values. DEVID registers are read-only and cannot be programmed by the © 2007 Microchip Technology Inc. Preliminary DS39887B-page 29 #### REGISTER 3-1: DEVID1: DEVICE ID REGISTER 1 FOR PIC18F2458/2553/4458/4553 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 **REV3:REV0:** Revision ID bits These bits are used to indicate the device revision. #### REGISTER 3-2: DEVID2: DEVICE ID REGISTER 2 FOR PIC18F2458/2553/4458/4553 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 | |-----------------------------|----------------------------|------------| | 0010 1010 | 011 | PIC18F2458 | | 0010 1010 | 010 | PIC18F2553 | | 0010 1010 | 001 | PIC18F4458 | | 0010 1010 | 000 | PIC18F4553 | #### 4.0 ELECTRICAL CHARACTERISTICS ### Absolute Maximum Ratings (†) | 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) | | | 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 $IOK (VO < 0 \text{ 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 IQL) 2: Voltage spikes below Vss at the MCLR/VPP/RE3 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 MCLR/VPP/RE3 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: PIC18F2458/2553/4458/4553 VOLTAGE-FREQUENCY GRAPH (INDUSTRIAL) TABLE 4-1: A/D CONVERTER CHARACTERISTICS: PIC18F2458/2553/4458/4553 (INDUSTRIAL) PIC18LF2458/2553/4458/4553 (INDUSTRIAL) | Param<br>No. | Sym | Characteristic | Min | Тур | Max | 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 VREF \ge 3.0V$ | | | | | _ | _ | ±2.0 | LSB | V <sub>DD</sub> = 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 ΔVREF ≥ 3.0V \ | | | | | _ | _ | ±3 | LSB | VDD = 5.0V | | A07 | Egn | Gain Error | _ | ±1 | ±1.25 | LSB | VDD = 3.0V ΔVREF ≥ 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 | 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 | ٧ _ | 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 | µА<br>µА | 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. 2: VREFH current is from the RA3/AN3/VREF+ pin or VDD, whichever is selected as the VREFH source. 2: 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, whicheven is selected as the VREFL source. © 2007 Microchip Technology Inc. Preliminary DS39887B-page 33 FIGURE 4-3: A/D CONVERSION TIMING TABLE 4-2: A/D CONVERSION REQUIREMENTS | Param<br>No. | Symbol | Characte | ristic | Min | Max | Units | Conditions | |--------------|--------|--------------------------------------------|-----------------|---------------|---------------------|-------|--------------------------------------------------------------------| | 130 | TAD | A/D Clock Period | PIC18FXXXX | 0.8 | 12.5(1) | μS | Tosc based, VREF ≥ 3.0V | | | | | PIC18LFXXXX | 1.4 | 25 <sub>0</sub> (1) | μS | V <sub>DD</sub> = 3.0V;<br>Tosc based, V <sub>REF</sub> full range | | | | | PIC18FXXXX | | 1 | μS | A/D RC mode | | | | | PIC18LFXXXX | $\rightarrow$ | 3 | μS | VDD = 3.0V; A/D RC mode | | 131 | TCNV | Conversion Time (not including acquisition | on time)(2) | 13 | 14 | TAD | | | 132 | TACQ | Acquisition Time <sup>(3)</sup> | | 1.4 | _ | μS | | | 135 | Tswc | Switching Time from Co | onvert → Sample | _ | (Note 4) | | | | 137 | TDIS | Discharge Time | $\wedge$ | 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Ω. 4: On the following cycle of the device clock. #### 5.0 PACKAGING INFORMATION For packaging information, see the "PIC18F2455/2550/4455/4550 Data Sheet" (DS39632). NOTES: **APPENDIX A: REVISION HISTORY** Revision A (May 2007) Original data sheet for the PIC18F2458/2553/4458/4553 devices. Revision B (June 2007) Changes to Figure 4-2: PIC18LF2458/2553/4458/4553 Voltage-Frequency Graph (Industrial). APPENDIX B: DEVICE DIFFERENCES The differences between the devices listed in this data sheet are shown in Table B-1. #### TABLE B-1: DEVICE DIFFERENCES | Features | PIC18F2458 | PIC18F2553 | PIC18F4458 | PIC18F4553 | |------------------------------------------|-----------------------------|-----------------------------|------------------------------------------|------------------------------------------| | Program Memory (Bytes) | 24576 | 32768 | 24576 | 32768 | | Program Memory (Instructions) | 12288 | 16384 | 12288 | 16384 | | Interrupt Sources | 19 | 19 | 20 | 20 | | I/O Ports | Ports A, B, C, (E) | Ports A, B, C, (E) | Ports A, B, C, D, E | Ports A, B, C, D, E | | Capture/Compare/PWM Modules | 2 | 2 | 1 | 1 | | Enhanced Capture/Compare/<br>PWM Modules | 0 | 0 | 1 | 1 | | Parallel Communications (SPP) | No | No | Yes | Yes | | 12-Bit Analog-to-Digital Module | 10 Input Channels | 10 Input Channels | 13 Input Channels | 13 Input Channels | | Packages | 28-Pin SPDIP<br>28-Pin SOIC | 28-Pin SPDIP<br>28-Pin SOIC | 40-Pin PDIP<br>44-Pin TQFP<br>44-Pin QFN | 40-Pin PDIP<br>44-Pin TQFP<br>44-Pin QFN | ## APPENDIX C: 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 as Literature Number DS00716. ### APPENDIX D: 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 as Literature Number DS00726. #### **INDEX** | A | | M | | |--------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------| | A/D | 19 | Microchip Internet Web Site | 41 | | A/D Converter Interrupt, Configuring | 23 | Migration from High-End to | | | Acquisition Requirements | 24 | Enhanced Devices | 38 | | ADCON0 Register | 19 | Migration from Mid-Range to | | | ADCON1 Register | 19 | Enhanced Devices | 38 | | ADCON2 Register | 19 | P | | | ADRESH Register | 19, 22 | • | | | ADRESL Register | 19 | Packaging Information | 35 | | Analog Port Pins, Configuring | 26 | Pin Functions | | | Associated Registers | | MCLR/Vpp/RE3 | 9 | | Calculating the Minimum Required | | MCLR/VPP/RE3 | 13 | | Acquisition Time | 24 | NC/ICCK/ICPGC | 18 | | Configuring the Module | | NC/ICDT/ICPGD | 18 | | Conversion Clock (TAD) | | NC/ICPORTS | 18 | | Conversion Status (GO/DONE Bit) | | NC/ICRST/ICVPP | | | Conversions | | OSC1/CLKI | 9. 13 | | Converter Characteristics | | OSC2/CLKO/RA6 | , | | Discharge | | RA0/AN0 | , | | Operation in Power-Managed Modes | | RA1/AN1 | , | | Selecting and Configuring Acquisition Time | | RA2/AN2/VREF-/CVREF | , | | | | RA3/AN3/VREF+ | | | Special Event Trigger (CCP) | | RA4/T0CKI/C1OUT/RCV | - , | | Use of the CCP2 Trigger | | RA5/AN4/SS/HLVDIN/C2OUT | , | | Absolute Maximum Ratings | | | - , | | ADCON0 Register | | RB0/AN12/INT0/FLT0/SDI/SDA | , | | GO/DONE Bit | | RB1/AN10/INT1/SCK/SCL | | | ADCON1 Register | | RB2/AN8/INT2/VMO | , | | ADCON2 Register | | RB3/AN9/CCP2/VPO | , | | ADRESH Register | 19 | RB4/AN11/KBI0 | | | ADRESL Register | 19, 22 | RB4/AN11/KBI0/CSSPP | | | Analog-to-Digital Converter. See A/D. | | RB5/KBI1/PGM | 11, 15 | | В | | RB6/KBI2/PGC | , | | В | | RB7/KBI3/PGD | , | | Block Diagrams | | RC0/T10S0/T13CKI | , | | A/D | 22 | RC1/T1OSI/CCP2/UOE | | | Analog Input Model | 23 | RC2/CCP1 | 12 | | PIC18F2458/2553 | 7 | RC2/CCP1/P1A | 16 | | PIC18F4458/4553 | 8 | RC4/D-/VM | 12, 16 | | • | | RC5/D+/VP | 12, 16 | | C | | RC6/TX/CK | 12, 16 | | Compare (CCP Module) | | RC7/RX/DT/SDO | 12, 16 | | Special Event Trigger | 28 | RD0/SPP0 | 17 | | Configuration Bits | 29 | RD1/SPP1 | 17 | | Customer Change Notification Service | 41 | RD2/SPP2 | 17 | | Customer Notification Service | | RD3/SPP3 | 17 | | Customer Support | | RD4/SPP4 | | | _ | | RD5/SPP5/P1B | | | D | | RD6/SPP6/P1C | | | Device Differences | 37 | RD7/SPP7/P1D | | | Device ID Registers | | RE0/AN5/CK1SPP | | | Device Overview | | | | | Other Special Features | | RE1/AN6/CK2SPP | | | Other openial reatures | | RE2/AN7/OESPP | | | E | | VDD | , | | Electrical Characteristics | 31 | Vss | , | | Equations | 31 | Vusb | 12, 18 | | • | 24 | Pinout I/O Descriptions | | | A/D Air image Charging Time | | PIC18F2458/2553 | | | A/D Minimum Charging Time | | PIC18F4458/4553 | 13 | | Errata | 4 | Power-Managed Modes | | | | | and A/D Operation | 26 | | Ī | | The state of s | | | I had a second Address as | | | | | Internet Address | 41 | | | | R | | |-----------------------------|----| | Reader Response | 42 | | Registers | | | ADCON0 (A/D Control 0) | 19 | | ADCON1 (A/D Control 1) | 20 | | ADCON2 (A/D Control 2) | 21 | | DEVID1 (Device ID 1) | 30 | | DEVID2 (Device ID 2) | 30 | | Revision History | 37 | | S | | | Special Features of the CPU | 20 | | I | | |------------------------------------|----| | Timing Diagrams | | | A/D Conversion | 34 | | Timing Diagrams and Specifications | | | A/D Conversion Requirements | 34 | | w | | | WWW Address | 41 | | WWW, On-Line Support | 4 | | | | #### 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 Tachnical Dublications Manager #### READER RESPONSE To: 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. | RE: | Reader Response | |-----|------------------------------------------------------------------------------------------| | | m: Name | | | Company | | | Address | | | City / State / ZIP / Country | | | Telephone: ( FAX: () | | App | lication (optional): | | Wou | ıld you like a reply?YN | | Dev | ice: PIC18F2458/2553/4458/4553 Literature Number: DS39887B | | Que | estions: | | 1. | What are the best features of this document? | | | | | | | | 2. | How does this document meet your hardware and software development needs? | | | | | 2 | Do you find the organization of this document easy to follow? If not, why? | | J. | Do you find the organization of this document easy to follow? If not, why? | | | | | 4. | What additions to the document do you think would enhance the structure and subject? | | | | | | | | 5. | What deletions from the document could be made without affecting the overall usefulness? | | | | | • | | | 6. | Is there any incorrect or misleading information (what and where)? | | | | | 7. | How would you improve this document? | | | | | | | | | | #### PRODUCT IDENTIFICATION SYSTEM To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. | PART NO.<br>Device | X /XX XXX<br> <br>Temperature Package Pattern<br>Range | Examples: a) PIC18LF4553-I/P 301 = Industrial temp., PDIP package, Extended VDD limits, QTP pattern #301. | |--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | Device | PIC18F2458/2553 <sup>(1)</sup> , PIC18F4458/4553 <sup>(1)</sup> , PIC18F2458/2553T <sup>(2)</sup> ; PIC18F4458/4553T <sup>(2)</sup> ; VDD range 4.2V to 5.5V PIC18LF2458/2553 <sup>(1)</sup> , PIC18LF4458/4553 <sup>(1)</sup> , PIC18LF2458/2553T <sup>(2)</sup> ; VDD range 2.0V to 5.5V | b) PIC18LF2458-I/SO = Industrial temp., SOIC package, Extended Vpp limits. c) PIC18F4458-I/P = Industrial temp., PDIP package, normal Vpp limits. | | Temperature Range | I = -40°C to +85°C (Industrial)<br>E = -40°C to +125°C (Extended) | | | Package | PT = TQFP (Thin Quad Flatpack) SO = SOIC SP = Skinny PDIP P = PDIP ML = QFN | Note 1: F = Standard Voltage Range LF = Wide Voltage Range 2: T = In tape and reel TQFP packages only. | | Pattern | QTP, SQTP, Code or Special Requirements (blank otherwise) | | © 2007 Microchip Technology Inc. Preliminary DS39887B-page 43 ### 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: 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 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 - Fuzhou** Tel: 86-591-8750-3506 Fax: 86-591-8750-3521 China - Hong Kong SAR Tel: 852-2401-1200 Fax: 852-2401-3431 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 - Shunde Tel: 86-757-2839-5507 Fax: 86-757-2839-5571 China - Wuhan Tel: 86-27-5980-5300 Fax: 86-27-5980-5118 China - Xian Tel: 86-29-8833-7252 Fax: 86-29-8833-7256 ASIA/PACIFIC India - Bangalore Tel: 91-80-4182-8400 Fax: 91-80-4182-8422 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 - Penang Tel: 60-4-646-8870 Fax: 60-4-646-5086 Philippines - Manila Tel: 63-2-634-9065 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-572-9526 Fax: 886-3-572-6459 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 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 06/25/07