Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Details | | |----------------------------|---------------------------------------------------------------------------| | Product Status | Active | | Core Processor | PIC | | Core Size | 8-Bit | | Speed | 48MHz | | Connectivity | I <sup>2</sup> C, SPI, UART/USART, USB | | Peripherals | Brown-out Detect/Reset, HLVD, POR, PWM, WDT | | Number of I/O | 35 | | Program Memory Size | 24KB (12K x 16) | | Program Memory Type | FLASH | | EEPROM Size | 256 x 8 | | RAM Size | 2K x 8 | | Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V | | Data Converters | A/D 13x12b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 44-VQFN Exposed Pad | | Supplier Device Package | 44-QFN (8x8) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/pic18f4458-i-ml | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong ### **Pin Diagrams** ### 28-Pin SPDIP, SOIC ### 40-Pin PDIP Note 1: RB3 is the alternate pin for CCP2 multiplexing. ### 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). - 2. 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). - 4. 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). - 5. 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 | TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin<br>Number | Pin | Buffer | Description | |---------------------|----------------|------|--------|-----------------------------------------------------| | Fill Name | SPDIP,<br>SOIC | Type | Туре | Description | | | | | | PORTA is a bidirectional I/O port. | | RA0/AN0 | 2 | | | | | RA0 | | I/O | TTL | Digital I/O. | | AN0 | | I | Analog | Analog input 0. | | RA1/AN1 | 3 | | | | | RA1 | | I/O | TTL | Digital I/O. | | AN1 | | 1 | Analog | Analog input 1. | | RA2/AN2/VREF-/CVREF | 4 | | | | | RA2 | | I/O | TTL | Digital I/O. | | AN2 | | I | Analog | Analog input 2. | | VREF- | | I | Analog | A/D reference voltage (low) input. | | CVREF | | 0 | Analog | Analog comparator reference output. | | RA3/AN3/VREF+ | 5 | | | | | RA3 | | I/O | TTL | Digital I/O. | | AN3 | | I | Analog | Analog input 3. | | VREF+ | | I | Analog | A/D reference voltage (high) input. | | RA4/T0CKI/C1OUT/RCV | 6 | | | | | RA4 | | I/O | ST | Digital I/O. | | T0CKI | | I | ST | Timer0 external clock input. | | C1OUT | | 0 | | Comparator 1 output. | | RCV | | ı | TTL | External USB transceiver RCV input. | | RA5/AN4/SS/ | 7 | | | | | HLVDIN/C2OUT | | | | | | RA5 | | I/O | TTL | Digital I/O. | | AN4<br>SS | | ! | Analog | Analog input 4. | | SS<br>HLVDIN | | | TTL | SPI slave select input. | | C2OUT | | 0 | Analog | High/Low-Voltage Detect input. Comparator 2 output. | | | | U | _ | · | | 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 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. TABLE 1-2: PIC18F2458/2553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin<br>Number<br>SPDIP,<br>SOIC | Pin<br>Type | Buffer<br>Type | Description | |--------------------------------------------------------------|---------------------------------|-------------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RB0/AN12/INT0/FLT0/ | 21 | | | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | SDI/SDA RB0 AN12 INT0 FLT0 SDI SDA RB1/AN10/INT1/SCK/ | 22 | I/O<br> <br> <br> <br> <br> <br> <br> <br> <br> | TTL<br>Analog<br>ST<br>ST<br>ST<br>ST | Digital I/O. Analog input 12. External interrupt 0. PWM Fault input (CCP1 module). SPI data in. I <sup>2</sup> C™ data I/O. | | SCL RB1 AN10 INT1 SCK SCL | | 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 | 23 | 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 | 24 | 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<br>RB4<br>AN11<br>KBI0 | 25 | I/O<br>I<br>I | TTL<br>Analog<br>TTL | Digital I/O.<br>Analog input 11.<br>Interrupt-on-change pin. | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 26 | 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 | 27 | 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 | 28 | 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 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 (CONTINUED) | Pin Name | Pi | Pin Number | | | Buffer | Description | |-------------------------------------------------------------------|------|------------|------|------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PIII 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> <br> <br> <br> <br> <br> <br> /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 | | | | 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> <br> <br> <br> <br> | 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 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. **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 | | | | | | | | 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. TABLE 1-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Name | Pi | n Numl | ber | Pin | Buffer | Description | |-------------------------------------------|-----------|-----------------|-------|---------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | PDIP | QFN | TQFP | Туре | Type | Description | | RE0/AN5/CK1SPP<br>RE0 | 8 | 25 | 25 | I/O | ST | PORTE is a bidirectional I/O port. Digital I/O. | | AN5<br>CK1SPP | | | | I<br>О | Analog<br>— | 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 | Digital I/O. Analog input 6. 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 | Digital I/O. Analog input 7. 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 | 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. | | 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> ICRST ICVPP | _ | _ | 33 | I<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 = 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 <u>ICPRT</u> Configuration bit is set. For NC/ICPORTS, the pin is No Connect unless ICPRT is set and the <u>DEBUG</u> 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, 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(2) 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. 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: | | | 1 | 1 | ga.a. | 1 | | | | 1 | | | | | |-----------------|------|------|------|-------|-----|--------------------|--------------------|--------------------|-----|-----|-----|-----|-----| | 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 | bit 7 **ADFM:** A/D Result Format Select bit 1 = Right justified0 = Left justified bit 6 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 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)(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 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 OR - · Waiting for the A/D interrupt - 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-3: ANALOG INPUT MODEL # 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 | 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 | 48.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 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. 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). ### **Revision C (October 2009)** Removed "Preliminary" marking. # 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 | ### **INDEX** | A | M | | |--------------------------------------------------------|----------------------------------------------|-------| | A/D21 | Microchip Internet Web Site | 43 | | A/D Converter Interrupt, Configuring25 | Migration from High-End to Enhanced Devices | | | Acquisition Requirements26 | Migration from Mid-Range to Enhanced Devices | | | ADCON0 Register21 | | | | ADCON1 Register21 | Р | | | ADCON2 Register21 | Packaging Information | 37 | | ADRESH Register21, 24 | Pin Functions | | | ADRESL Register21 | MCLR/VPP/RE3 | 11 | | Analog Port Pins, Configuring28 | MCLR/VPP/RE3 | 15 | | Associated Registers30 | NC/ICCK/ICPGC | 20 | | Calculating the Minimum Required Acquisition Time . 26 | NC/ICDT/ICPGD | 20 | | Configuring the Module25 | NC/ICPORTS | | | Conversion Clock (TAD)27 | NC/ICRST/ICVPP | | | Conversion Status (GO/DONE Bit)24 | OSC1/CLKI1 | 1, 15 | | Conversions29 | OSC2/CLKO/RA61 | 1, 15 | | Converter Characteristics35 | RA0/AN012 | 2, 16 | | Discharge29 | RA1/AN112 | , | | Operation in Power-Managed Modes28 | RA2/AN2/VREF-/CVREF12 | , | | Selecting and Configuring Acquisition Time27 | RA3/AN3/VREF+ | | | Special Event Trigger (CCP)30 | RA4/T0CK <u>I/C</u> 1OUT/RCV12 | | | Use of the CCP2 Trigger30 | RA5/AN4/SS/HLVDIN/C2OUT12 | 2, 16 | | Absolute Maximum Ratings | RB0/AN12/INT0/FLT0/SDI/SDA1 | 3, 17 | | ADCON0 Register21 | RB1/AN10/INT1/SCK/SCL1 | 3, 17 | | GO/DONE Bit24 | RB2/AN8/INT2/VMO1 | 3, 17 | | ADCON1 Register21 | RB3/AN9/CCP2/VPO1 | 3, 17 | | ADCON2 Register21 | RB4/AN11/KBI0 | | | ADRESH Register21 | RB4/AN11/KBI0/CSSPP | 17 | | ADRESL Register21, 24 | RB5/KBI1/PGM1 | 3, 17 | | Analog-to-Digital Converter. See A/D. | RB6/KBI2/PGC1 | 3, 17 | | B | RB7/KBI3/PGD1 | | | В | RC0/T10S0/T13C <u>KI</u> | | | Block Diagrams | RC1/T1OSI/CCP2/ <del>UOE</del> 14 | | | A/D24 | RC2/CCP1 | 14 | | Analog Input Model25 | RC2/CCP1/P1A | 18 | | PIC18F2458/25539 | RC4/D-/VM14 | | | PIC18F4458/455310 | RC5/D+/VP14 | 4, 18 | | C | RC6/TX/CK14 | , | | | RC7/RX/DT/SDO14 | | | Compare (CCP Module) | RD0/SPP0 | | | Special Event Trigger | RD1/SPP1 | | | Customer Change Notification Service43 | RD2/SPP2 | | | Customer Notification Service | RD3/SPP3 | | | Customer Support43 | RD4/SPP4 | | | D | RD5/SPP5/P1B | | | | RD6/SPP6/P1C | | | Device Differences | RD7/SPP7/P1D | | | Device ID Registers | RE0/AN5/CK1SPP | | | Device Overview | RE1/AN6/CK2SPP | | | Other Special Features7 | RE2/AN7/OESPP | | | E | VDD14 | 4, 20 | | | Vss | , - | | Electrical Characteristics | Vusb14 | 4, 20 | | Equations A/D Acquisition Time | Pinout I/O Descriptions | | | A/D Acquisition Time | PIC18F2458/2553 | 11 | | A/D Minimum Charging Time | PIC18F4458/4553 | 15 | | Errata6 | Power-Managed Modes | | | I | and A/D Operation | 28 | | • | R | | | Internet Address | | | | Interrupt Sources A/D Conversion Complete | Reader Response | 44 | | AD Conversion Complete25 | Registers | | | | ADCON0 (A/D Control 0) | 21 | #### 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 ### 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. b) PIC18LF2458-I/SO = Industrial temp., SOIC | |--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------| | 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> , PIC18LF4458/4553T <sup>(2)</sup> ; VDD range 2.0V to 5.5V | package, Extended VpD limits. c) PIC18F4458-I/P = Industrial temp., PDIP package, normal VpD 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) | |