



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                      | 40MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, HLVD, POR, PWM, WDT                              |
| Number of I/O              | 36                                                                       |
| Program Memory Size        | 16KB (8K x 16)                                                           |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | 256 x 8                                                                  |
| RAM Size                   | 768 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4.2V ~ 5.5V                                                              |
| Data Converters            | A/D 13x12b                                                               |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 125°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/pic18f4423-e-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, Enhanced Flash Microcontrollers with 12-Bit A/D and nanoWatt Technology

#### **Power Management Features:**

- · Run: CPU on, Peripherals on
- · Idle: CPU off, Peripherals on
- · Sleep: CPU off, Peripherals off
- Ultra Low 50 nA Input Leakage
- Run mode Currents Down to 11 μA Typical
- Idle mode Currents Down to 2.5 μA Typical
- Sleep mode Current Down to 100 μA Typical
- · Timer1 Oscillator: 900 nA, 32 kHz, 2V
- Watchdog Timer: 1.4 μA, 2V Typical
- Two-Speed Oscillator Start-up

#### Flexible Oscillator Structure:

- · Four Crystal modes, up to 40 MHz
- 4x Phase Lock Loop (PLL) Available for Crystal and Internal Oscillators
- · Two External RC modes, up to 4 MHz
- Two External Clock modes, up to 40 MHz
- · Internal Oscillator Block:
  - Fast wake from Sleep and Idle, 1 μs typical
  - 8 user-selectable frequencies, from 31 kHz to 8 MHz
  - Provides a complete range of clock speeds, from 31 kHz to 32 MHz, when used with PLL
- User-tunable to Compensate for Frequency Drift
- Secondary Oscillator using Timer1 @ 32 kHz
- Fail-Safe Clock Monitor:
  - Allows for safe shutdown if peripheral clock stops

#### Peripheral Highlights:

- 12-Bit, Up to 13-Channel Analog-to-Digital Converter module (A/D):
  - Auto-acquisition capability
  - Conversion available during Sleep mode
- Dual Analog Comparators with Input Multiplexing
- High-Current Sink/Source 25 mA/25 mA
- Three Programmable External Interrupts
- Four Input Change Interrupts
- Up to Two Capture/Compare/PWM (CCP) modules, One with Auto-Shutdown (28-pin devices)
- Enhanced Capture/Compare/PWM (ECCP) module (40/44-pin devices only):
  - One, two or four PWM outputs
  - Selectable polarity
  - Programmable dead time
- Auto-shutdown and auto-restart

#### **Peripheral Highlights (Continued):**

- Master Synchronous Serial Port (MSSP) module Supporting 3-Wire SPI (all four modes) and I<sup>2</sup>C™ Master and Slave modes
- · Enhanced USART module:
  - Support for RS-485, RS-232 and LIN/J2602
  - RS-232 operation using internal oscillator block (no external crystal required)
  - Auto-wake-up on Start bit
  - Auto-Baud Detect (ABD)

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

- C Compiler Optimized Architecture: Optional Extended Instruction Set Designed to Optimize Re-Entrant Code
- 100,000 Erase/Write Cycle, Enhanced Flash Program Memory Typical
- 1,000,000 Erase/Write Cycle, Data EEPROM Memory Typical
- Flash/Data EEPROM Retention: 100 Years Typical
- · Self-Programmable under Software Control
- · Priority Levels for Interrupts
- 8 x 8 Single-Cycle Hardware Multiplier
- Extended Watchdog Timer (WDT): Programmable Period, from 4 ms to 131s
- Single-Supply In-Circuit Serial Programming™ (ICSP™) via Two Pins
- · In-Circuit Debug (ICD) via Two Pins
- Operating Voltage Range: 2.0V to 5.5V
- Programmable, 16-Level High/Low-Voltage Detection (HLVD) module: Supports Interrupt on High/Low-Voltage Detection
- Programmable Brown-out Reset (BOR): With Software-Enable Option

Note: This document is supplemented by the "PIC18F2420/2520/4420/4520 Data Sheet" (DS39631). See Section 1.0 "Device Overview".

|            | Prog             | ram Memory                 | Data            | Memory         |     | 40 0''             | CCP/          | MS  | SSP                         | RT   |       | <b>T</b>           |
|------------|------------------|----------------------------|-----------------|----------------|-----|--------------------|---------------|-----|-----------------------------|------|-------|--------------------|
| Device     | Flash<br>(bytes) | # Single-Word Instructions | SRAM<br>(bytes) | EEPROM (bytes) | I/O | 12-Bit<br>A/D (ch) | ECCP<br>(PWM) | SPI | Master<br>I <sup>2</sup> C™ | EUSA | Comp. | Timers<br>8/16-Bit |
| PIC18F2423 | 16K              | 8192                       | 768             | 256            | 25  | 10                 | 2/0           | Υ   | Υ                           | 1    | 2     | 1/3                |
| PIC18F2523 | 32K              | 16384                      | 1536            | 256            | 25  | 10                 | 2/0           | Υ   | Υ                           | 1    | 2     | 1/3                |
| PIC18F4423 | 16K              | 8192                       | 768             | 256            | 36  | 13                 | 1/1           | Υ   | Υ                           | 1    | 2     | 1/3                |
| PIC18F4523 | 32K              | 16384                      | 1536            | 256            | 36  | 13                 | 1/1           | Υ   | Υ                           | 1    | 2     | 1/3                |

#### **Table of Contents**

| 1.0   | Device Overview                                      | 9  |
|-------|------------------------------------------------------|----|
| 2.0   | 12-Bit Analog-to-Digital Converter (A/D) Module      |    |
| 3.0   | Special Features of the CPU                          |    |
| 4.0   | Electrical Characteristics                           |    |
| 5.0   | Packaging Information                                | 43 |
| Appe  | ndix A: Revision History                             |    |
|       | ndix B: Device Differences                           |    |
| Appe  | ndix C: Conversion Considerations                    | 46 |
|       | ndix D: Migration from Baseline to Enhanced Devices  |    |
| Appe  | ndix E: Migration from Mid-Range to Enhanced Devices | 47 |
|       | ndix F: Migration from High-End to Enhanced Devices  |    |
|       |                                                      |    |
| The N | /licrochip Web Site                                  | 51 |
| Custo | omer Change Notification Service                     | 51 |
| Custo | omer Support                                         | 51 |
| Read  | er Response                                          | 52 |
|       | uct Identification System                            |    |

#### TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- · Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

TABLE 1-1: DEVICE FEATURES

| Features                                | PIC18F2423                                                                                 | PIC18F2523                                                                                 | PIC18F4423                                                                                 | PIC18F4523                                                                                 |
|-----------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|
| Operating Frequency                     | DC – 40 MHz                                                                                |
| Program Memory (Bytes)                  | 16,384                                                                                     | 32,768                                                                                     | 16,384                                                                                     | 32,768                                                                                     |
| Program Memory (Instructions)           | 8,192                                                                                      | 16,384                                                                                     | 8,192                                                                                      | 16,384                                                                                     |
| Data Memory (Bytes)                     | 768                                                                                        | 1,536                                                                                      | 768                                                                                        | 1,536                                                                                      |
| 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 Modules             | 2                                                                                          | 2                                                                                          | 1                                                                                          | 1                                                                                          |
| Enhanced<br>Capture/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                                                                    |
| Parallel Communications (PSP)           | No                                                                                         | No                                                                                         | Yes                                                                                        | Yes                                                                                        |
| 12-Bit Analog-to-Digital Module         | 10 Input Channels                                                                          | 10 Input Channels                                                                          | 13 Input Channels                                                                          | 13 Input Channels                                                                          |
| Resets (and Delays)                     | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT | POR, BOR, RESET Instruction, Stack Full, Stack Underflow (PWRT, OST), MCLR (optional), WDT |
| Programmable<br>High/Low-Voltage Detect | Yes                                                                                        | Yes                                                                                        | Yes                                                                                        | Yes                                                                                        |
| Programmable Brown-out Reset            | Yes                                                                                        | Yes                                                                                        | Yes                                                                                        | Yes                                                                                        |
| Instruction Set                         | 75 Instructions;<br>83 with Extended<br>Instruction Set enabled                            |
| Packages                                | 28-Pin PDIP<br>28-Pin SOIC<br>28-Pin QFN                                                   | 28-Pin PDIP<br>28-Pin SOIC<br>28-Pin QFN                                                   | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP                                                   | 40-Pin PDIP<br>44-Pin QFN<br>44-Pin TQFP                                                   |



TABLE 1-2: PIC18F2423/2523 PINOUT I/O DESCRIPTIONS (CONTINUED)

|                     | Pin N         | umber | Pin  | Buffer |                                      |
|---------------------|---------------|-------|------|--------|--------------------------------------|
| Pin Name            | PDIP,<br>SOIC | QFN   | Туре | Type   | Description                          |
|                     |               |       |      |        | PORTA is a bidirectional I/O port.   |
| RA0/AN0             | 2             | 27    |      |        |                                      |
| RA0                 |               |       | I/O  | TTL    | Digital I/O.                         |
| AN0                 |               |       | I    | Analog | Analog Input 0.                      |
| RA1/AN1             | 3             | 28    |      |        |                                      |
| RA1                 |               |       | I/O  | TTL    | Digital I/O.                         |
| AN1                 |               |       | I    | Analog | Analog Input 1.                      |
| RA2/AN2/VREF-/CVREF | 4             | 1     |      |        |                                      |
| 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 | Comparator reference voltage output. |
| RA3/AN3/VREF+       | 5             | 2     |      |        |                                      |
| 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     | 6             | 3     |      |        |                                      |
| RA4                 |               |       | I/O  | ST     | Digital I/O.                         |
| T0CKI               |               |       | I    | ST     | Timer0 external clock input.         |
| C1OUT               |               |       | 0    | _      | Comparator 1 output.                 |
| RA5/AN4/SS/HLVDIN/  | 7             | 4     |      |        |                                      |
| C2OUT               |               |       |      |        |                                      |
| RA5                 |               |       | I/O  | TTL    | Digital I/O.                         |
| AN4                 |               |       | 1    | Analog | Analog Input 4.                      |
| SS                  |               |       | !    | TTL    | SPI slave select input.              |
| HLVDIN              |               |       |      | Analog |                                      |
| C2OUT               |               |       | 0    | _      | Comparator 2 output.                 |
| RA6                 |               |       |      |        | See the OSC2/CLKO/RA6 pin.           |
| RA7                 |               |       |      |        | See the OSC1/CLKI/RA7 pin.           |

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

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

 $I^2C = I^2C^{\dagger M}/SMBus$ 

Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set.

**2:** Alternate assignment for CCP2 when Configuration bit, CCP2MX, is cleared.

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

| Pin Name                                              | Piı  | n Numb | er   | Pin             | Buffer                       | Description                                                                                  |
|-------------------------------------------------------|------|--------|------|-----------------|------------------------------|----------------------------------------------------------------------------------------------|
| riii Naille                                           | PDIP | QFN    | TQFP | Type            | Type                         | Description                                                                                  |
|                                                       |      |        |      |                 |                              | PORTC is a bidirectional I/O port.                                                           |
| RC0/T10S0/T13CKI<br>RC0<br>T10S0<br>T13CKI            | 15   | 34     | 32   | I/O<br>O<br>I   | ST<br>—<br>ST                | Digital I/O.<br>Timer1 oscillator output.<br>Timer1/Timer3 external clock input.             |
| RC1/T1OSI/CCP2<br>RC1<br>T1OSI<br>CCP2 <sup>(2)</sup> | 16   | 35     | 35   | I/O<br>I<br>I/O | ST<br>CMOS<br>ST             | Digital I/O.<br>Timer1 oscillator input.<br>Capture 2 input/Compare 2 output/PWM2 output.    |
| RC2/CCP1/P1A<br>RC2<br>CCP1<br>P1A                    | 17   | 36     | 36   | I/O<br>I/O<br>O | ST<br>ST                     | Digital I/O. Capture 1 input/Compare 1 output/PWM1 output. Enhanced CCP1 output.             |
| RC3/SCK/SCL<br>RC3<br>SCK                             | 18   | 37     | 37   | I/O<br>I/O      | ST<br>ST                     | Digital I/O.<br>Synchronous serial clock input/output for<br>SPI mode.                       |
| SCL                                                   |      |        |      | I/O             | I <sup>2</sup> C             | Synchronous serial clock input/output for I <sup>2</sup> C™ mode.                            |
| RC4/SDI/SDA<br>RC4<br>SDI<br>SDA                      | 23   | 42     | 42   | I/O<br>I<br>I/O | ST<br>ST<br>I <sup>2</sup> C | Digital I/O.<br>SPI data in.<br>I <sup>2</sup> C data I/O.                                   |
| RC5/SDO<br>RC5<br>SDO                                 | 24   | 43     | 43   | I/O<br>O        | ST<br>—                      | Digital I/O.<br>SPI data out.                                                                |
| 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 related RX/DT).     |
| RC7/RX/DT<br>RC7<br>RX<br>DT                          | 26   | 1      | 1    | I/O<br>I<br>I/O | ST<br>ST<br>ST               | Digital I/O.<br>EUSART asynchronous receive.<br>EUSART synchronous data (see related TX/CK). |

**Legend:** TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

s I = Input P = Power

CMOS = CMOS compatible input or output

O = Output

 $I^2C = I^2C^{TM}/SMBus$ 

Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set.

2: Alternate assignment for CCP2 when Configuration bit, CCP2MX, is cleared.

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

| Pin Name    | Pi     | n Numb       | er      | Pin  | Buffer     | Description                                                          |
|-------------|--------|--------------|---------|------|------------|----------------------------------------------------------------------|
| Fill Name   | PDIP   | QFN          | TQFP    | Type | Type       | Description                                                          |
|             |        |              |         |      |            | PORTE is a bidirectional I/O port.                                   |
| RE0/RD/AN5  | 8      | 25           | 25      |      |            |                                                                      |
| RE0         |        |              |         | I/O  | ST         | Digital I/O.                                                         |
| RD          |        |              |         | I    | TTL        | Read control for Parallel Slave Port                                 |
|             |        |              |         |      |            | (see also WR and CS pins).                                           |
| AN5         |        |              |         | I    | Analog     | Analog Input 5.                                                      |
| RE1/WR/AN6  | 9      | 26           | 26      |      |            |                                                                      |
| RE1         |        |              |         | I/O  | ST         | Digital I/O.                                                         |
| WR          |        |              |         | ı    | TTL        | Write control for Parallel Slave Port                                |
| AN6         |        |              |         |      | Analaa     | (see CS and RD pins).                                                |
|             |        |              |         | I    | Analog     | Analog Input 6.                                                      |
| RE2/CS/AN7  | 10     | 27           | 27      |      |            |                                                                      |
| RE2<br>CS   |        |              |         | 1/0  | ST         | Digital I/O.                                                         |
| CS          |        |              |         | ı    | TTL        | Chip select control for Parallel Slave Port (see related RD and WR). |
| AN7         |        |              |         | 1    | Analog     | Analog Input 7.                                                      |
|             |        |              |         | •    | 7 ti lalog |                                                                      |
| RE3         |        |              |         |      | _          | See MCLR/VPP/RE3 pin.                                                |
| Vss         | 12, 31 | 6, 30,<br>31 | 6, 29   | Р    | _          | Ground reference for logic and I/O pins.                             |
| VDD         | 11, 32 |              | 7, 28   | Р    |            | Positive supply for logic and I/O pins.                              |
| <b>V</b> DD | 11, 02 | 28, 29       | 7,20    | '    |            | 1 odiave supply for logic and 1/0 pins.                              |
| NC          | _      | 13           | 12, 13, | _    | _          | No connect.                                                          |
|             |        |              | 33, 34  |      |            |                                                                      |

**Legend:** TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

CMOS = CMOS compatible input or output I = Input

O = Output

P = Power

 $I^2C = I^2C^{TM}/SMBus$ 

Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set.

2: Alternate assignment for CCP2 when Configuration bit, CCP2MX, is cleared.

NOTES:

#### 2.0 12-BIT ANALOG-TO-DIGITAL **CONVERTER (A/D) MODULE**

The Analog-to-Digital (A/D) Converter module has 10 inputs for the PIC18F2423/2523 devices and 13 for the PIC18F4423/4523 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)

Of the ADCONx registers:

- ADCON0 (shown in Register 2-1) Controls the module's operation
- · ADCON1 (Register 2-2) Configures the functions of the port pins
- ADCON2 (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 CHS<3:0>: Analog Channel Select bits

0000 = Channel 0 (AN0)

0001 = Channel 1 (AN1)

0010 = Channel 2 (AN2)

0011 = Channel 3 (AN3)

0100 = Channel 4 (AN4)

0101 = Channel 5 (AN5)(1,2) 0110 = Channel 6 (AN6)(1,2)

0111 = Channel 7 (AN7)(1,2)

1000 = Channel 8 (AN8)

1001 = Channel 9 (AN9)

1010 = Channel 10 (AN10)

1011 = Channel 11 (AN11)

1100 = Channel 12 (AN12

1101 = Unimplemented<sup>(2)</sup>

1110 = Unimplemented<sup>(2)</sup> 1111 = Unimplemented<sup>(2)</sup>

bit 1 GO/DONE: A/D Conversion Status bit

When ADON = 1:

1 = A/D conversion in progress

0 = A/D Idle

bit 0 ADON: A/D On bit

1 = A/D Converter module is enabled

0 = A/D Converter module is disabled

**Note 1:** These channels are not implemented on PIC18F2423/2523 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 <sup>(1)</sup> | 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 **= V**ss

bit 4 VCFG0: Voltage Reference Configuration bit (VREF+ source)

1 = VREF+ (AN3)

0 = VDD

bit 3-0 **PCFG<3:0>:** A/D Port Configuration Control bits:

| PCFG<3:0> | AN12 | AN11 | AN10 | 6NA | AN8 | AN7 <sup>(2)</sup> | AN6 <sup>(2)</sup> | AN5 <sup>(2)</sup> | AN4 | AN3 | AN2 | AN1 | ANO |
|-----------|------|------|------|-----|-----|--------------------|--------------------|--------------------|-----|-----|-----|-----|-----|
|           | ٧    | ∢    | ٧    | ⋖   | 4   | ⋖                  | ⋖                  | ٧                  | ٧   | ٧   | ٧   | ٧   | ٧   |
| 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 POR 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 only available on PIC18F4423/4523 devices.

The value in the ADRESH:ADRESL registers is unknown following POR and BOR 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 inputs. 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 the A/D module (ADCON0)
- 2. Configure the 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 by setting the GO/DONE bit (ADCON0<1>).

- 5. Wait for the A/D conversion to complete by either:
  - Polling for the GO/DONE bit to be cleared OR
  - · Waiting for the A/D interrupt
- Read the A/D Result registers (ADRESH:ADRESL) and clear the ADIF bit, if required.
- For the next conversion, go to step 1 or step 2, as required.

The A/D conversion time per bit is defined as TAD. A minimum wait of 2 TAD is required before the next acquisition starts.









#### 2.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 ACQT<2:0> bits are cleared. A conversion is started after the following instruction to allow entry into Sleep mode before the conversion begins.

Figure 2-5 shows the operation of the A/D Converter after the GO/DONE bit has been set, the ACQT<2:0> bits have been set to '010' and a 4 TAD acquisition time has been selected before the conversion starts.

Clearing the GO/DONE bit during a conversion will abort the current conversion. The A/D Result register pair will NOT be updated with the partially completed A/D conversion sample. This means, the ADRESH:ADRESL registers will continue to contain the value of the last completed conversion (or the last value written to the ADRESH:ADRESL registers).

After the A/D conversion is completed or aborted, a 2 Tcy wait is required before the next acquisition can be started. After this wait, acquisition on the selected channel is automatically started.

Note: The GO/DONE bit should NOT be set in the same instruction that turns on the A/D. Code should wait at least 3 TAD 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 unitygain 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)



# 3.0 SPECIAL FEATURES OF THE CPU

## Note: For additional details on the Configuration bits, refer to Section 23.1 "Configuration

**Bits"** in the "PIC18F2420/2520/4420/4520 Data Sheet" (DS39631). Device ID information presented in this section is for the PIC18F2423/2523/4423/4523 devices only.

#### 3.1 Device ID Registers

The Device ID registers are read-only registers. They identify the device type and revision for device programmers and can be read by firmware using table reads.

#### TABLE 3-1: DEVICE IDs

| File Name |                       | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Default/<br>Unprogrammed<br>Value |
|-----------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------------------|
| 3FFFEh    | DEVID1 <sup>(1)</sup> | DEV3  | DEV2  | DEV1  | DEV0  | REV3  | REV2  | REV1  | REV0  | XXXX XXXX(2)                      |
| 3FFFFFh   | DEVID2 <sup>(1)</sup> | DEV11 | DEV10 | DEV9  | DEV8  | DEV7  | DEV6  | DEV5  | DEV4  | ×××× ××××(2)                      |

**Legend:** x = unknown, u = unchanged, — = unimplemented. Shaded cells are unimplemented, read as '0'.

Note 1: DEVID registers are read-only and cannot be programmed by the user.

2: See Register 3-1 and Register 3-2 for DEVID1 and DEVID2 values.

#### REGISTER 3-1: DEVID1: DEVICE ID REGISTER 1 FOR PIC18F2423/2523/4423/4523

| R     | R    | R    | R    | R    | R    | R    | R     |
|-------|------|------|------|------|------|------|-------|
| DEV3  | DEV2 | DEV1 | DEV0 | REV3 | REV2 | REV1 | REV0  |
| bit 7 |      |      |      |      |      |      | bit 0 |

#### Legend:

R = Read-only bit P = Programmable bit U = Unimplemented bit, read as '0'
-n = Value when device is unprogrammed u = Unchanged from programmed state

bit 7-4 **DEV<3:0>:** Device ID bits

1101 = PIC18F4423 1001 = PIC18F4523 0101 = PIC18F2423 0001 = PIC18F2523

bit 3-0 REV<3:0>: Revision ID bits

These bits are used to indicate the device revision.

TABLE 4-1: A/D CONVERTER CHARACTERISTICS: PIC18F2423/2523/4423/4523 (INDUSTRIAL) PIC18LF2423/2523/4423/4523 (INDUSTRIAL)

| Param<br>No. | Sym   | Characteristic                                       | Min                       | Тур    | Max        | Units    |                         | Conditions                                            |
|--------------|-------|------------------------------------------------------|---------------------------|--------|------------|----------|-------------------------|-------------------------------------------------------|
| A01          | NR    | Resolution                                           | _                         | _      | 12         | bit      |                         | $\Delta V$ REF $\geq 3.0V$                            |
| A03          | EIL   | Integral Linearity Error                             | _                         | <±1    | ±2.0       | LSB      | VDD = 3.0V              | $\Delta VREF \ge 3.0V$                                |
|              |       |                                                      | _                         | _      | ±2.0       | LSB      | VDD = 5.0V              |                                                       |
| A04          | EDL   | Differential Linearity Error                         | _                         | <±1    | +1.5/-1.0  | LSB      | VDD = 3.0V              | $\Delta V$ REF $\geq 3.0V$                            |
|              |       |                                                      | _                         | _      | +1.5/-1.0  | LSB      | VDD = 5.0V              |                                                       |
| A06          | Eoff  | Offset Error                                         | _                         | <±1    | ±5         | LSB      | VDD = 3.0V              | $\Delta V$ REF $\geq 3.0V$                            |
|              |       |                                                      | _                         | _      | ±3         | LSB      | VDD = 5.0V              |                                                       |
| A07          | Egn   | Gain Error                                           | _                         | <±1    | ±1.25      | LSB      | VDD = 3.0V              | $\Delta V$ REF $\geq 3.0V$                            |
|              |       |                                                      | _                         | _      | ±2.00      | LSB      | VDD = 5.0V              |                                                       |
| A10          | _     | Monotonicity                                         | Guaranteed <sup>(1)</sup> |        | _          |          | $Vss \le Vain \le Vref$ |                                                       |
| A20          | ΔVREF | Reference Voltage Range<br>(VREFH – VREFL)           | 3                         | _      | VDD - VSS  | V        |                         | For 12-bit resolution.                                |
| A21          | VREFH | Reference Voltage High                               | Vss + 3.0V                | _      | VDD + 0.3V | V        |                         | For 12-bit resolution.                                |
| A22          | VREFL | Reference Voltage Low                                | Vss - 0.3V                | _      | VDD - 3.0V | V        |                         | For 12-bit resolution.                                |
| A25          | Vain  | Analog Input Voltage                                 | VREFL                     | _      | VREFH      | V        |                         |                                                       |
| A30          | ZAIN  | Recommended<br>Impedance of Analog<br>Voltage Source | _                         | _      | 2.5        | kΩ       |                         |                                                       |
| A50          | IREF  | VREF Input Current <sup>(2)</sup>                    |                           | _<br>_ | 5<br>150   | μA<br>μA |                         | During VAIN acquisition. During A/D conversion cycle. |

Note 1: The A/D conversion result never decreases with an increase in the input voltage and has no missing codes.

<sup>2:</sup> VREFH current is from the RA3/AN3/VREF+ pin or VDD, whichever is selected as the VREFH source. VREFL current is from the RA2/AN2/VREF-/CVREF pin or VSs, whichever is selected as the VREFL source.

NOTES:

#### **APPENDIX A: REVISION HISTORY**

#### Revision A (June 2006)

Original data sheet for PIC18F2423/2523/4423/4523 devices.

#### **Revision B (January 2007)**

This revision includes updates to the packaging diagrams.

#### Revision C (September 2009)

Electrical specifications updated. Preliminary condition status removed. Converted document to the "mini data sheet" format.

# 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                             | PIC18F2423                               | PIC18F2523                               | PIC18F4423                               | PIC18F4523                               |
|--------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|
| Program Memory (Bytes)               | 16384                                    | 32768                                    | 16384                                    | 32768                                    |
| Program Memory (Instructions)        | 8192                                     | 16384                                    | 8192                                     | 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/PWM Modules | 0                                        | 0                                        | 1                                        | 1                                        |
| Parallel Communications (PSP)        | 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 PDIP<br>28-Pin SOIC<br>28-Pin QFN | 28-Pin PDIP<br>28-Pin SOIC<br>28-Pin QFN | 40-Pin PDIP<br>44-Pin TQFP<br>44-Pin QFN | 40-Pin PDIP<br>44-Pin TQFP<br>44-Pin QFN |

# APPENDIX E: MIGRATION FROM MID-RANGE TO ENHANCED DEVICES

A detailed discussion of the differences between the mid-range MCU devices (i.e., PIC16CXXX) and the enhanced devices (i.e., PIC18FXXX) is provided in AN716, "Migrating Designs from PIC16C74A/74B to PIC18C442". The changes discussed, while device specific, are generally applicable to all mid-range to enhanced device migrations.

This Application Note is available as Literature Number DS00716.

# APPENDIX F: MIGRATION FROM HIGH-END TO ENHANCED DEVICES

A detailed discussion of the migration pathway and differences between the high-end MCU devices (i.e., PIC17CXXX) and the enhanced devices (i.e., PIC18FXXX) is provided in *AN726, "PIC17CXXX to PIC18CXXX Migration*". This Application Note is available as Literature Number DS00726.

| R                           |    |
|-----------------------------|----|
| Reader Response             | 52 |
| Registers                   |    |
| ADCON0 (A/D Control 0)      | 25 |
| ADCON1 (A/D Control 1)      | 26 |
| ADCON2 (A/D Control 2)      | 27 |
| DEVID1 (Device ID 1)        | 35 |
| DEVID2                      |    |
| (Device ID 2)               | 36 |
| Revision History            | 45 |
| S                           |    |
| Special Features of the CPU | 35 |

| I                                       |    |
|-----------------------------------------|----|
| Timing Diagrams                         |    |
| A/D Conversion                          | 41 |
| Timing Diagrams and Specifications      |    |
| A/D Conversion Requirements             | 41 |
| V                                       |    |
| Voltage-Frequency Graphics              |    |
| PIC18F2423/2523/4423/4523 (Extended)    | 38 |
| PIC18F2423/2523/4423/4523 (Industrial)  | 38 |
| PIC18LF2423/2523/4423/4523 (Industrial) | 39 |
| W                                       |    |
| WWW Address                             | 51 |
| WWW On-Line Support                     | 8  |

#### 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>Temperature Package Pattern<br>Range                                                                                                                                                                                                                                 | Examples:  a) PIC18F4523-I/P 301 = Industrial temp., PDIP package, Extended VDD limits, QTP pattern #301.                                                                   |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device             | PIC18F2423 <sup>(1)</sup> , PIC18F2523 <sup>(1)</sup> , PIC18F4423T <sup>(2)</sup> , PIC18F4523T <sup>(2)</sup> ; VDD range 4.2V to 5.5V PIC18F2423 <sup>(1)</sup> , PIC18F2523 <sup>(1)</sup> , PIC18F4423T <sup>(2)</sup> , PIC18F4523T <sup>(2)</sup> ; VDD range 2.0V to 5.5V | <ul> <li>b) PIC18F4523-I/PT = Industrial temp., TQFP package, Extended VDD limits.</li> <li>c) PIC18F4523-E/P = Extended temp., PDIP package, normal VDD limits.</li> </ul> |
| Temperature Range  | I = -40°C to +85°C (Industrial)<br>E = -40°C to +125°C (Extended)                                                                                                                                                                                                                 |                                                                                                                                                                             |
| Package            | PT = TQFP (Thin Quad Flat pack) ML = QFN SO = SOIC SP = Skinny Plastic DIP P = PDIP                                                                                                                                                                                               | Note 1: F = Standard Voltage Range  LF = Wide Voltage Range  2: T = In tape and reel PLCC, and TQFP packages only.                                                          |
| Pattern            | QTP, SQTP, Code or Special Requirements (blank otherwise)                                                                                                                                                                                                                         |                                                                                                                                                                             |