



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              | 34                                                                        |
| Program Memory Size        | 32KB (16K x 16)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 2K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                 |
| Data Converters            | A/D 13x12b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                  |
| Supplier Device Package    | 40-PDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18lf4553-i-p |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



# 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  $\mu$ 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".

|            | Program Memory   |                            | Data Memory     |                |     | 12-Bit | CCD/ECCD          |     | М   | 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  | Y   | Y                           | 1    | 2   |                    |
| PIC18F2553 | 32K              | 16384                      | 2048            | 256            |     | 24 10  |                   |     |     |                             |      |     | 1/3                |
| PIC18F4458 | 24K              | 12288                      | 2040            | 250            | 0.5 | - 40   | 4.44              | Yes |     |                             |      |     | 1/3                |
| PIC18F4553 | 32K              | 16384                      |                 |                | 35  | 13     | 1/1               | res |     |                             |      |     |                    |

### **Pin Diagrams**

#### 28-Pin SPDIP, SOIC



#### 40-Pin PDIP



Note 1: RB3 is the alternate pin for CCP2 multiplexing.

TABLE 1-1: DEVICE FEATURES

| Features                                     | PIC18F2458                                                                                  | PIC18F2553                                                                                  | PIC18F4458                                                                                  | PIC18F4553                                                                                  |
|----------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| Operating Frequency                          | 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 Reset                 | Yes                                                                                         | Yes                                                                                         | Yes                                                                                         | Yes                                                                                         |
| Instruction Set                              | 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-3: PIC18F4458/4553 PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name                                                           | Pi   | n Num | ber  | Pin                                        | Buffer                              | Description                                                                                              |
|--------------------------------------------------------------------|------|-------|------|--------------------------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------|
| Pin Name                                                           | PDIP | QFN   | TQFP | Туре                                       | Type                                | 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<br>RA2<br>AN2<br>VREF-<br>CVREF            | 4    | 21    | 21   | I/O<br>I<br>I<br>O                         | 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<br>RA4<br>T0CKI<br>C1OUT<br>RCV            | 6    | 23    | 23   | 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<br>RA5<br>AN4<br>SS<br>HLVDIN<br>C2OUT | 7    | 24    | 24   | I/O<br> <br> <br> <br> <br> <br> <br> <br> | 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. |
| SS<br>HLVDIN                                                       | _    | _     | _    | I                                          | TTL                                 | SPI slave select input. High/Low-Voltage Detect input.                                                   |

**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                                                                                                                     |
|--------------------------------------------|------|-------|------|----------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Pili Name                                  | PDIP | QFN   | TQFP | Туре                 | Type                  | 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                     | 16   | 35    | 35   |                      |                       |                                                                                                                                 |
| RC1<br>T1OSI<br>CCP2 <sup>(2)</sup><br>UOE |      |       |      | I/O<br>I<br>I/O<br>O | ST<br>CMOS<br>ST<br>— | Digital I/O. Timer1 oscillator input. Capture 2 input/Compare <u>2 o</u> utput/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> <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               | 24   | 43    | 43   | I<br>I/O<br>I        | 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               | 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<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

= 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.

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



# 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      | ource (TAD) | Assumes TAD Min. = 0.8 $\mu$ s |  |  |
|-------------------|-------------|--------------------------------|--|--|
| 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.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)



### 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               | 21                          |  |  |  |
| ADCON1               | _                             | _                                                        | VCFG1        | VCFG0          | PCFG3              | PCFG2              | PCFG1              | PCFG0              | 22                          |  |  |  |
| ADCON2               | ADFM                          | _                                                        | ACQT2        | ACQT1          | ACQT0              | ADCS2              | ADCS1              | ADCS0              | 23                          |  |  |  |
| 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 | ster           |                    |                    |                    |                    | (4)                         |  |  |  |
| LATB                 | PORTB Dat                     | 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".

FIGURE 4-3: A/D CONVERSION TIMING



TABLE 4-2: A/D CONVERSION REQUIREMENTS

| Param<br>No. | Symbol | Characte                        | eristic                 | Min | Max                 | Units | Conditions                   |
|--------------|--------|---------------------------------|-------------------------|-----|---------------------|-------|------------------------------|
| 110.         |        |                                 | 1                       |     |                     |       |                              |
| 130          | TAD    | A/D Clock Period                | PIC18FXXXX              | 8.0 | 12.5 <sup>(1)</sup> | μS    | Tosc based, VREF $\geq 3.0V$ |
|              |        |                                 | PIC18 <b>LF</b> XXXX    | 1.4 | 25.0 <sup>(1)</sup> | μS    | V <sub>DD</sub> = 3.0V;      |
|              |        |                                 |                         |     |                     |       | Tosc based, VREF full range  |
|              |        |                                 | PIC18FXXXX              | _   | 1                   | μS    | A/D RC mode                  |
|              |        |                                 | PIC18 <b>LF</b> XXXX    | _   | 3                   | μS    | VDD = 3.0V; A/D RC mode      |
| 131          | TCNV   | Conversion Time                 |                         | 13  | 14                  | TAD   |                              |
|              |        | (not including acquisition      | on time) <sup>(2)</sup> |     |                     |       |                              |
| 132          | TACQ   | Acquisition Time <sup>(3)</sup> |                         | 1.4 | _                   | μS    |                              |
| 135          | Tswc   | Switching Time from Co          | onvert → Sample         | _   | (Note 4)            |       |                              |
| 137          | TDIS   | Discharge Time                  |                         | 0.2 | _                   | μS    |                              |

**Note 1:** The time of the A/D clock period is dependent on the device frequency and the TAD clock divider.

- 2: ADRES registers may be read on the following TcY cycle.
- 3: The time for the holding capacitor to acquire the "New" input voltage when the voltage changes full scale after the conversion (VDD to Vss or Vss to VDD). The source impedance (Rs) on the input channels is 50Ω.
- 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).

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

# 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.

| 22 |
|----|
| 23 |
| 32 |
| 32 |
| 39 |
|    |
| 31 |
|    |
|    |
| 36 |
|    |
| 36 |
|    |
| 43 |
| 6  |
|    |

#### THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com, click on Customer Change Notification and follow the registration instructions.

#### **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- · Distributor or Representative
- · Local Sales Office
- Field Application Engineer (FAE)
- · Technical Support
- · Development Systems Information Line

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://support.microchip.com

### **READER RESPONSE**

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150.

Please list the following information, and use this outline to provide us with your comments about this document.

| RE:  | Reader Response                                                                          |  |  |  |  |
|------|------------------------------------------------------------------------------------------|--|--|--|--|
| Froi | Name                                                                                     |  |  |  |  |
| Арр  | lication (optional):                                                                     |  |  |  |  |
| Wo   | ıld you like a reply?YN                                                                  |  |  |  |  |
| Dev  | ice: PIC18F2458/2553/4458/4553 Literature Number: DS39887C                               |  |  |  |  |
| Que  | stions:                                                                                  |  |  |  |  |
| 1.   | What are the best features of this document?                                             |  |  |  |  |
| 2.   | 2. How does this document meet your hardware and software development needs?             |  |  |  |  |
| 3.   | 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.  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)                                                                                                                                                                                                                                                                     |                                                                                                                                                          |