



#### 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 -</u> <u>Microcontrollers</u>"

#### Details

| 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              | 25                                                                        |
| 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 10x12b                                                                |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                            |
| Supplier Device Package    | 28-SOIC                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic18f2423-i-so |
|                            |                                                                           |

Email: info@E-XFL.COM

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

## **Pin Diagrams (Continued)**



#### **Table of Contents**

| 1.0 Device Overview                                      | . 9 |
|----------------------------------------------------------|-----|
| 2.0 12-Bit Analog-to-Digital Converter (A/D) Module      | 25  |
| 3.0 Special Features of the CPU                          |     |
| 4.0 Electrical Characteristics                           |     |
| 5.0 Packaging Information                                |     |
| Appendix A: Revision History                             | 45  |
| Appendix B: Device Differences                           | 45  |
| Appendix C: Conversion Considerations                    | 46  |
| Appendix D: Migration from Baseline to Enhanced Devices  | 46  |
| Appendix E: Migration from Mid-Range to Enhanced Devices | 47  |
| Appendix F: Migration from High-End to Enhanced Devices  | 47  |
| Index                                                    | 49  |
| The Microchip Web Site                                   | 51  |
| Customer Change Notification Service                     | 51  |
| Customer Support                                         | 51  |
| Reader Response                                          |     |
| Product Identification System                            | 53  |



### FIGURE 1-1: PIC18F2423/2523 (28-PIN) BLOCK DIAGRAM

Note 1: CCP2 is multiplexed with RC1 when Configuration bit, CCP2MX, is set or RB3 when CCP2MX is not set.

2: RE3 is only available when MCLR functionality is disabled.

3: OSC1/CLKI and OSC2/CLKO are only available in select oscillator modes and when these pins are not being used as digital I/O. For additional information, see Section 2.0 "Oscillator Configurations" of the "PIC18F2420/2520/4420/4520 Data Sheet" (DS39631).



- **2:** RE3 is only available when MCLR functionality is disabled.
- 3: OSC1/CLKI and OSC2/CLKO are only available in select oscillator modes and when these pins are not being used as digital I/O. For additional information, see Section 2.0 "Oscillator Configurations" of the "PIC18F2420/2520/4420/4520 Data Sheet" (DS39631).

|                                                                                                                                                                                              |               | umber | Pin  | Buffer |                                                                                                               |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|------|--------|---------------------------------------------------------------------------------------------------------------|--|
| Pin Name                                                                                                                                                                                     | PDIP,<br>SOIC | QFN   | Туре | Туре   | Description                                                                                                   |  |
|                                                                                                                                                                                              |               |       |      |        | PORTB is a bidirectional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. |  |
| RB0/INT0/FLT0/AN12                                                                                                                                                                           | 21            | 18    |      |        |                                                                                                               |  |
| RB0                                                                                                                                                                                          |               | 10    | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| INT0                                                                                                                                                                                         |               |       | I    | ST     | External Interrupt 0.                                                                                         |  |
| FLT0                                                                                                                                                                                         |               |       | I    | ST     | PWM Fault input for CCP1.                                                                                     |  |
| AN12                                                                                                                                                                                         |               |       | I    | Analog | Analog Input 12.                                                                                              |  |
| RB1/INT1/AN10                                                                                                                                                                                | 22            | 19    |      |        |                                                                                                               |  |
| RB1                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| INT1                                                                                                                                                                                         |               |       | I    | ST     | External Interrupt 1.                                                                                         |  |
| AN10                                                                                                                                                                                         |               |       | I    | Analog | Analog Input 10.                                                                                              |  |
| RB2/INT2/AN8                                                                                                                                                                                 | 23            | 20    |      |        |                                                                                                               |  |
| RB2                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| INT2                                                                                                                                                                                         |               |       | I    | ST     | External Interrupt 2.                                                                                         |  |
| AN8                                                                                                                                                                                          |               |       | I    | Analog | Analog Input 8.                                                                                               |  |
| RB3/AN9/CCP2                                                                                                                                                                                 | 24            | 21    |      |        |                                                                                                               |  |
| RB3                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| AN9                                                                                                                                                                                          |               |       | I    | Analog | Analog Input 9.                                                                                               |  |
| CCP2 <sup>(1)</sup>                                                                                                                                                                          |               |       | I/O  | ST     | Capture 2 input/Compare 2 output/PWM2 output.                                                                 |  |
| RB4/KBI0/AN11                                                                                                                                                                                | 25            | 22    |      |        |                                                                                                               |  |
| RB4                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| KBI0                                                                                                                                                                                         |               |       | I    | TTL    | Interrupt-on-change pin.                                                                                      |  |
| AN11                                                                                                                                                                                         |               |       | I    | Analog | Analog Input 11.                                                                                              |  |
| RB5/KBI1/PGM                                                                                                                                                                                 | 26            | 23    |      |        |                                                                                                               |  |
| RB5                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| KBI1                                                                                                                                                                                         |               |       | I    | TTL    | Interrupt-on-change pin.                                                                                      |  |
| PGM                                                                                                                                                                                          |               |       | I/O  | ST     | Low-Voltage ICSP <sup>™</sup> Programming enable pin.                                                         |  |
| RB6/KBI2/PGC                                                                                                                                                                                 | 27            | 24    |      |        |                                                                                                               |  |
| RB6                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| KBI2                                                                                                                                                                                         |               |       | I    | TTL    | Interrupt-on-change pin.                                                                                      |  |
| PGC                                                                                                                                                                                          |               |       | I/O  | ST     | In-Circuit Debugger and ICSP programming clock pin.                                                           |  |
| RB7/KBI3/PGD                                                                                                                                                                                 | 28            | 25    |      |        |                                                                                                               |  |
| RB7                                                                                                                                                                                          |               |       | I/O  | TTL    | Digital I/O.                                                                                                  |  |
| KBI3                                                                                                                                                                                         |               |       | I    | TTL    | Interrupt-on-change pin.                                                                                      |  |
| PGD                                                                                                                                                                                          |               |       | I/O  | ST     | In-Circuit Debugger and ICSP programming data pin.                                                            |  |
| Legend:       TTL = TTL compatible input       CMOS = CMOS compatible input or output         ST = Schmitt Trigger input with CMOS levels       I = Input         O = Output       P = Power |               |       |      |        |                                                                                                               |  |

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

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

| Pin Name                                                                                                                    | Pi   | n Numb | per  | Pin  | Buffer | Description                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------|------|--------|------|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin Name                                                                                                                    | PDIP | QFN    | TQFP | Туре | Туре   | Description                                                                                                                                      |
| MCLR/VPP/RE3<br>MCLR                                                                                                        | 1    | 18     | 18   | I    | ST     | Master Clear (input) or programming voltage (input).<br>Master Clear (Reset) input. This pin is an active-low<br>Reset to the device.            |
| VPP                                                                                                                         |      |        |      | Р    |        | Programming voltage input.                                                                                                                       |
| RE3                                                                                                                         |      |        |      |      | ST     | Digital input.                                                                                                                                   |
| OSC1/CLKI/RA7<br>OSC1                                                                                                       | 13   | 32     | 30   | I    | ST     | Oscillator crystal or external clock input.<br>Oscillator crystal input or external clock source input.<br>ST buffer when configured in RC mode; |
| CLKI                                                                                                                        |      |        |      | I    | CMOS   | analog otherwise.<br>External clock source input. Always associated with<br>pin function, OSC1. (See related OSC1/CLKI,<br>OSC2/CLKO pins.)      |
| RA7                                                                                                                         |      |        |      | I/O  | TTL    | General purpose I/O pin.                                                                                                                         |
| OSC2/CLKO/RA6<br>OSC2                                                                                                       | 14   | 33     | 31   | 0    | _      | Oscillator crystal or clock output.<br>Oscillator crystal output. Connects to crystal<br>or resonator in Crystal Oscillator mode.                |
| CLKO                                                                                                                        |      |        |      | 0    | _      | In RC mode, OSC2 pin outputs CLKO, which has 1/4 the frequency of OSC1 and denotes the instruction cycle rate.                                   |
| RA6                                                                                                                         |      |        |      | I/O  | TTL    | General purpose I/O pin.                                                                                                                         |
| Legend: TTL = TTL compatible input<br>ST = Schmitt Trigger input with CMOS levels<br>O = Output<br>$I^2C = I^2C^{TM}/SMBus$ |      |        |      |      |        | CMOS = CMOS compatible input or output<br>I = Input<br>P = Power                                                                                 |

### TABLE 1-3: PIC18F4423/4523 PINOUT I/O DESCRIPTIONS

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

| Din Nama                                                                                                                                                                 | Pin Number |     |      | Pin Buffer         | Description                         |                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----|------|--------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| Pin Name                                                                                                                                                                 | PDIP       | QFN | TQFP | Туре               | Туре                                | Description                                                                                                          |
|                                                                                                                                                                          |            |     |      |                    |                                     | PORTA is a bidirectional I/O port.                                                                                   |
| RA0/AN0<br>RA0<br>AN0                                                                                                                                                    | 2          | 19  | 19   | I/O<br>I           | TTL<br>Analog                       | Digital I/O.<br>Analog Input 0.                                                                                      |
| RA1/AN1<br>RA1<br>AN1                                                                                                                                                    | 3          | 20  | 20   | I/O<br>I           | TTL<br>Analog                       | Digital I/O.<br>Analog Input 1.                                                                                      |
| RA2/AN2/VREF-/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.<br>Analog Input 2.<br>A/D reference voltage (low) input.<br>Comparator reference voltage 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.<br>Analog Input 3.<br>A/D reference voltage (high) input.                                               |
| RA4/T0CKI/C1OUT<br>RA4<br>T0CKI<br>C1OUT                                                                                                                                 | 6          | 23  | 23   | I/O<br>I<br>O      | ST<br>ST                            | Digital I/O.<br>Timer0 external clock input.<br>Comparator 1 output.                                                 |
| RA5/AN4/SS/HLVDIN/<br>C2OUT<br>RA5<br>AN4<br>SS<br>HLVDIN<br>C2OUT                                                                                                       | 7          | 24  | 24   | I/O<br>I<br>I<br>O | TTL<br>Analog<br>TTL<br>Analog<br>— | Digital I/O.<br>Analog Input 4.<br>SPI slave select input.<br>High/Low-Voltage Detect input.<br>Comparator 2 output. |
| RA6<br>RA7                                                                                                                                                               |            |     |      |                    |                                     | See the OSC2/CLKO/RA6 pin.<br>See the OSC1/CLKI/RA7 pin.                                                             |
| Legend:TTL = TTL compatible inputCMOS = CMOS compatible input or outputST = Schmitt Trigger input with CMOS levelsI= InputO = Output $l^2C$ = $l^2C^{TM}/SMBus$ P= Power |            |     |      |                    |                                     |                                                                                                                      |

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

| Din Nama                                              | Pin Number |     |      | Pin Buffer | Description      |                                                                             |
|-------------------------------------------------------|------------|-----|------|------------|------------------|-----------------------------------------------------------------------------|
| Pin Name                                              | PDIP       | QFN | TQFP | Туре       | Туре             | Description                                                                 |
|                                                       |            |     |      |            |                  | PORTC is a bidirectional I/O port.                                          |
| RC0/T1OSO/T13CKI                                      | 15         | 34  | 32   |            |                  |                                                                             |
| RC0                                                   |            |     |      | I/O        | ST               | Digital I/O.                                                                |
| T1OSO                                                 |            |     |      | 0          | —                | Timer1 oscillator output.                                                   |
| T13CKI                                                |            |     |      | I          | ST               | Timer1/Timer3 external clock input.                                         |
| RC1/T1OSI/CCP2                                        | 16         | 35  | 35   |            |                  |                                                                             |
| RC1                                                   |            |     |      | I/O        | ST               | Digital I/O.                                                                |
| T1OSI                                                 |            |     |      | I          | CMOS             | Timer1 oscillator input.                                                    |
| CCP2 <sup>(2)</sup>                                   |            |     |      | I/O        | ST               | Capture 2 input/Compare 2 output/PWM2 output.                               |
| RC2/CCP1/P1A                                          | 17         | 36  | 36   |            |                  |                                                                             |
| RC2                                                   |            |     |      | I/O        | ST               | Digital I/O.                                                                |
| CCP1                                                  |            |     |      | I/O        | ST               | Capture 1 input/Compare 1 output/PWM1 output.                               |
| P1A                                                   |            |     |      | 0          |                  | Enhanced CCP1 output.                                                       |
| RC3/SCK/SCL                                           | 18         | 37  | 37   |            |                  |                                                                             |
| RC3                                                   |            |     |      | I/O        | ST               | Digital I/O.                                                                |
| SCK                                                   |            |     |      | I/O        | ST               | Synchronous serial clock input/output for<br>SPI mode.                      |
| SCL                                                   |            |     |      | I/O        | l <sup>2</sup> C | Synchronous serial clock input/output for I <sup>2</sup> C <sup>™</sup> mod |
|                                                       | 22         | 42  | 42   | 1/0        | 10               |                                                                             |
| RC4/SDI/SDA<br>RC4                                    | 23         | 42  | 42   | I/O        | ST               | Digital I/O.                                                                |
| SDI                                                   |            |     |      | 10         | ST               | SPI data in.                                                                |
| SDA                                                   |            |     |      | I/O        | I <sup>2</sup> C | $I^2C$ data I/O.                                                            |
| RC5/SDO                                               | 24         | 43  | 43   |            |                  |                                                                             |
| RC5                                                   | 27         | 40  |      | I/O        | ST               | Digital I/O.                                                                |
| SDO                                                   |            |     |      | 0          | _                | SPI data out.                                                               |
| RC6/TX/CK                                             | 25         | 44  | 44   |            |                  |                                                                             |
| RC6                                                   | 20         |     |      | I/O        | ST               | Digital I/O.                                                                |
| ТХ                                                    |            |     |      | 0          |                  | EUSART asynchronous transmit.                                               |
| CK                                                    |            |     |      | I/O        | ST               | EUSART synchronous clock (see related RX/DT).                               |
| RC7/RX/DT                                             | 26         | 1   | 1    |            |                  |                                                                             |
| RC7                                                   |            |     |      | I/O        | ST               | Digital I/O.                                                                |
| RX                                                    |            |     |      | I          | ST               | EUSART asynchronous receive.                                                |
| DT                                                    |            |     |      | I/O        | ST               | EUSART synchronous data (see related TX/CK).                                |
| Legend: TTL = TTL                                     |            |     |      |            |                  | CMOS = CMOS compatible input or output                                      |
| ST = Schmitt Trigger input with CMOS levels I = Input |            |     |      |            |                  |                                                                             |
| O = Out                                               |            |     |      |            |                  | P = Power                                                                   |
| $I^2 C = I^2 C$                                       | ™/SMBเ     | IS  |      |            |                  |                                                                             |

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

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

| Pin Name                                                                                                                | Pin Number |     |      | Pin             | Buffer    | Description                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------|------------|-----|------|-----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fill Name                                                                                                               | PDIP       | QFN | TQFP | Туре            | Туре      | Description                                                                                                                                                                           |
|                                                                                                                         |            |     |      |                 |           | PORTD is a bidirectional I/O port or a Parallel Slave<br>Port (PSP) for interfacing to a microprocessor port.<br>These pins have TTL input buffers when the PSP<br>module is enabled. |
| RD0/PSP0<br>RD0<br>PSP0                                                                                                 | 19         | 38  | 38   | I/O<br>I/O      | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.                                                                                                                                             |
| RD1/PSP1<br>RD1<br>PSP1                                                                                                 | 20         | 39  | 39   | I/O<br>I/O      | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.                                                                                                                                             |
| RD2/PSP2<br>RD2<br>PSP2                                                                                                 | 21         | 40  | 40   | I/O<br>I/O      | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.                                                                                                                                             |
| RD3/PSP3<br>RD3<br>PSP3                                                                                                 | 22         | 41  | 41   | I/O<br>I/O      | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.                                                                                                                                             |
| RD4/PSP4<br>RD4<br>PSP4                                                                                                 | 27         | 2   | 2    | I/O<br>I/O      | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.                                                                                                                                             |
| RD5/PSP5/P1B<br>RD5<br>PSP5<br>P1B                                                                                      | 28         | 3   | 3    | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.<br>Enhanced CCP1 output.                                                                                                                    |
| RD6/PSP6/P1C<br>RD6<br>PSP6<br>P1C                                                                                      | 29         | 4   | 4    | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.<br>Enhanced CCP1 output.                                                                                                                    |
| RD7/PSP7/P1D<br>RD7<br>PSP7<br>P1D                                                                                      | 30         | 5   | 5    | I/O<br>I/O<br>O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port data.<br>Enhanced CCP1 output.                                                                                                                    |
| Legend: TTL = TTL compatible input<br>ST = Schmitt Trigger input with CMOS levels<br>O = Output<br><sup>1</sup> CTN/OND |            |     |      |                 |           |                                                                                                                                                                                       |

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

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

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

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)

**REGISTER 2-1:** 

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

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

ADCON0: A/D CONTROL REGISTER 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) <sup>(1,2)</sup>                                                    |
|         | 0110 = Channel 6 (AN6) <sup>(1,2)</sup>                                                    |
|         | 0111 = Channel 7 (AN7) <sup>(1,2)</sup>                                                    |
|         | 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.                             |
| 2.      | Performing a conversion on unimplemented channels will return a floating input measurement |

**2:** Performing a conversion on unimplemented channels will return a floating input measurement.

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 <u>loaded</u> into the ADRESH:ADRESL register pair, the GO/DONE bit (ADCON0<1>) is cleared and A/D Interrupt Flag bit, ADIF, is set.

The block diagram of the A/D module is shown in Figure 2-1.



#### FIGURE 2-1: A/D BLOCK DIAGRAM

The value in the ADRESH:ADRESL registers is unknown following 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).
- 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

- 6. Read the A/D Result registers (ADRESH:ADRESL) and clear the ADIF bit, if required.
- 7. 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.

#### FIGURE 2-2: A/D TRANSFER FUNCTION





#### FIGURE 2-3: ANALOG INPUT MODEL

### 2.2 Selecting and Configuring Acquisition Time

The ADCON2 register allows the user to select an acquisition time that occurs each time the GO/DONE bit is set. It also gives users the option of having an automatically determined acquisition time.

Acquisition time may be set with the ACQT<2:0> bits (ADCON2<5:3>), which provide a range of 2 to 20 TAD. When the GO/DONE bit is set, the A/D module continues to sample the input for the selected acquisition time, then automatically begins a conversion. Since the acquisition time is programmed, there may be no need to wait for an acquisition time between selecting a channel and setting the GO/DONE bit.

Manual acquisition time is <u>selected</u> when ACQT<2:0> = 0.00. 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 ACQT<2:0> 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
- 32 Tosc
- 4 Tosc
- 64 ToscInternal RC Oscillator
- 8 Tosc
- 16 Tosc

For correct A/D conversions, the A/D conversion clock (TAD) must be as short as possible, but greater than the minimum TAD. (For more information, see parameter 130 on page 41.)

Table 2-2 shows the resultant TAD times derived from the device operating frequencies and the A/D clock source selected.

| A/D Clock So      | urce (TAD) | Assumes TAD Min. = 0.8 $\mu s$ |
|-------------------|------------|--------------------------------|
| Operation         | ADCS<2:0>  | Maximum Fosc                   |
| 2 Tosc            | 000        | 2.50 MHz                       |
| 4 Tosc            | 100        | 5.00 MHz                       |
| 8 Tosc            | 001        | 10.00 MHz                      |
| 16 Tosc           | 101        | 20.00 MHz                      |
| 32 Tosc           | 010        | 40.00 MHz                      |
| 64 Tosc           | 110        | 40.00 MHz                      |
| RC <sup>(2)</sup> | x11        | 1.00 MHz <sup>(1)</sup>        |

#### TABLE 2-2:TAD vs. DEVICE OPERATING FREQUENCIES

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.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 CCP2M<3:0> bits (CCP2CON<3:0>) be programmed as '1011' and that the A/D module is enabled (ADON bit is set). When the trigger occurs, the GO/DONE bit will be set, starting the A/D acquisition and conversion, and the Timer1 (or Timer3) counter will be reset to zero. Timer1 (or Timer3) is reset to automatically repeat the A/D acquisition period with minimal software overhead (moving ADRESH:ADRESL to the desired location). The appropriate analog input channel must be selected and the minimum acquisition period is either timed by the user or an appropriate TACQ time is 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.

| Name                 | Bit 7                                                                             | Bit 6              | Bit 5  | Bit 4   | Bit 3              | Bit 2   | Bit 1        | Bit 0   | Reset<br>Values on<br>page |
|----------------------|-----------------------------------------------------------------------------------|--------------------|--------|---------|--------------------|---------|--------------|---------|----------------------------|
| INTCON               | GIE/GIEH                                                                          | PEIE/GIEL          | TMR0IE | INT0IE  | RBIE               | TMR0IF  | INT0IF       | RBIF    | (Note 4)                   |
| PIR1                 | PSPIF <sup>(1)</sup>                                                              | ADIF               | RCIF   | TXIF    | SSPIF              | CCP1IF  | TMR2IF       | TMR1IF  | (Note 4)                   |
| PIE1                 | PSPIE <sup>(1)</sup>                                                              | ADIE               | RCIE   | TXIE    | SSPIE              | CCP1IE  | TMR2IE       | TMR1IE  | (Note 4)                   |
| IPR1                 | PSPIP <sup>(1)</sup>                                                              | ADIP               | RCIP   | TXIP    | SSPIP              | CCP1IP  | TMR2IP       | TMR1IP  | (Note 4)                   |
| PIR2                 | OSCFIF                                                                            | CMIF               | _      | EEIF    | BCLIF              | HLVDIF  | TMR3IF       | CCP2IF  | (Note 4)                   |
| PIE2                 | OSCFIE                                                                            | CMIE               | _      | EEIE    | BCLIE              | HLVDIE  | TMR3IE       | CCP2IE  | (Note 4)                   |
| IPR2                 | OSCFIP                                                                            | CMIP               | _      | EEIP    | BCLIP              | HLVDIP  | TMR3IP       | CCP2IP  | (Note 4)                   |
| ADRESH               | A/D Result Register High Byte                                                     |                    |        |         |                    |         |              |         | (Note 4)                   |
| ADRESL               | A/D Result Register Low Byte                                                      |                    |        |         |                    |         |              |         | (Note 4)                   |
| ADCON0               | —                                                                                 | —                  | CHS3   | CHS2    | CHS1               | CHS0    | GO/DONE      | ADON    | (Note 4)                   |
| ADCON1               | _                                                                                 | _                  | VCFG1  | VCFG0   | PCFG3              | PCFG2   | PCFG1        | PCFG0   | (Note 4)                   |
| ADCON2               | ADFM                                                                              | —                  | ACQT2  | ACQT1   | ACQT0              | ADCS2   | ADCS1        | ADCS0   | (Note 4)                   |
| PORTA                | RA7 <sup>(2)</sup>                                                                | RA6 <sup>(2)</sup> | RA5    | RA4     | RA3                | RA2     | RA1          | RA0     | (Note 4)                   |
| TRISA                | TRISA7 <sup>(2)</sup> TRISA6 <sup>(2)</sup> PORTA Data Direction Control Register |                    |        |         |                    |         |              |         | (Note 4)                   |
| PORTB                | RB7                                                                               | RB6                | RB5    | RB4     | RB3                | RB2     | RB1          | RB0     | (Note 4)                   |
| TRISB                | PORTB Data Direction Control Register                                             |                    |        |         |                    |         |              |         | (Note 4)                   |
| LATB                 | PORTB Data Latch Register (Read and Write to Data Latch)                          |                    |        |         |                    |         |              |         | (Note 4)                   |
| PORTE <sup>(1)</sup> | —                                                                                 | —                  | _      | _       | RE3 <sup>(3)</sup> | RE2     | RE1          | RE0     | (Note 4)                   |
| TRISE <sup>(1)</sup> | IBF                                                                               | OBF                | IBOV   | PSPMODE | —                  | TRISE2  | TRISE1       | TRISE0  | (Note 4)                   |
| LATE <sup>(1)</sup>  | _                                                                                 | _                  | _      | _       |                    | PORTE D | ata Latch Re | egister | (Note 4)                   |

 TABLE 2-3:
 REGISTERS ASSOCIATED WITH A/D OPERATION

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 PIC18F2423/2523 devices and are read as '0'.

**2:** PORTA<7:6> and their direction bits are individually configured as port pins based on various primary oscillator modes. When disabled, these bits read as '0'.

3: RE3 port bit is available only as an input pin when the MCLRE Configuration bit is '0'.

4: For these Reset values, see Section 4.0 "Reset" of the "PIC18F2420/2520/4420/4520 Data Sheet" (DS39631).

**Device ID Registers** 

The Device ID registers are read-only registers. They identify the device type and revision for device pro-

grammers and can be read by firmware using table

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

#### **TABLE 3-1: DEVICE IDs**

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

3.1

reads.

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

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

# PIC18F2423/2523/4423/4523

#### REGISTER 3-2: DEVID2: DEVICE ID REGISTER 2 FOR PIC18F2423/2523/4423/4523

| R                                      | R                    | R                   | R                                  | R                                   | R                   | R                   | R                   |  |
|----------------------------------------|----------------------|---------------------|------------------------------------|-------------------------------------|---------------------|---------------------|---------------------|--|
| DEV11 <sup>(1)</sup>                   | DEV10 <sup>(1)</sup> | DEV9 <sup>(1)</sup> | DEV8 <sup>(1)</sup>                | DEV7 <sup>(1)</sup>                 | DEV6 <sup>(1)</sup> | DEV5 <sup>(1)</sup> | DEV4 <sup>(1)</sup> |  |
| bit 7                                  |                      |                     |                                    |                                     |                     |                     | bit 0               |  |
|                                        |                      |                     |                                    |                                     |                     |                     |                     |  |
| Legend:                                |                      |                     |                                    |                                     |                     |                     |                     |  |
| R = Read-only bit P = Programmable bit |                      |                     | U = Unimplemented bit, read as '0' |                                     |                     |                     |                     |  |
| -n = Value when device is unprogrammed |                      |                     |                                    | u = Unchanged from programmed state |                     |                     |                     |  |

bit 7-0 **DEV<11:4>:** Device ID bits<sup>(1)</sup> These bits are used with the DEV<3:0> bits in Device ID Register 1 to identify the part number. 0001 0001 = PIC18F2423/2523 devices 0001 0000 = PIC18F4423/4523 devices

**Note 1:** These values for DEV<11:4> may be shared with other devices. The specific device is always identified by using the entire DEV<11:0> bit sequence.

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.

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

#### TABLE B-1:DEVICE DIFFERENCES

# 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