Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! ### Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China # PIC18F2221/2321/4221/4321 Family Data Sheet Enhanced Flash Microcontrollers with 10-Bit A/D and nanoWatt Technology #### Note the following details of the code protection feature on Microchip devices: - Microchip products meet the specification contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions. - There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property. - Microchip is willing to work with the customer who is concerned about the integrity of their code. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act. Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION. QUALITY, PERFORMANCE, MERCHANTABILITY FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights. #### **Trademarks** The Microchip name and logo, the Microchip logo, dsPIC, Keeloq, Keeloq logo, MPLAB, PIC, PICmicro, PICSTART, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Octopus, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, PIC<sup>32</sup> logo, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. $\ensuremath{\mathsf{SQTP}}$ is a service mark of Microchip Technology Incorporated in the U.S.A. All other trademarks mentioned herein are property of their respective companies. © 2009, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved. Printed on recycled paper. QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002 Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified. ### MICROCHIP PIC18F2221/2321/4221/4321 FAMILY # 28/40/44-Pin Enhanced Flash Microcontrollers with 10-Bit A/D and nanoWatt Technology #### **Power-Managed Modes:** - · Run: CPU On, Peripherals On - · Idle: CPU Off. Peripherals On - · Sleep: CPU Off, Peripherals Off - Idle mode Currents Down to 2.5 μA Typical - Sleep mode Currents Down to 500 nA Typical - Timer1 Oscillator: 1.8 μA, 32 kHz, 2V Typical - Watchdog Timer: 1.6 μ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: - 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:** - High-Current Sink/Source 25 mA/25 mA - · Three Programmable External Interrupts - · Four Input Change Interrupts - Up to 2 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 4 modes) and I<sup>2</sup>C™ Master and Slave modes - · Enhanced Addressable USART module: - Supports RS-485, RS-232 and LIN/J2602 - Auto-wake-up on Start bit - Auto-Baud Detect - 10-Bit, up to 13-Channel Analog-to-Digital Converter module (A/D): - Auto-acquisition capability - Conversion available during Sleep - Dual Analog Comparators with Input Multiplexing - Programmable 16-Level High/Low-Voltage Detection (HLVD) module: - Supports interrupt on High/Low-Voltage Detection #### **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 5V In-Circuit Serial Programming™ (ICSP™) via Two Pins - · In-Circuit Debug (ICD) via Two Pins - Wide Operating Voltage Range: 2.0V to 5.5V - Programmable Brown-out Reset (BOR) with Software Enable Option) | | Prog | ram Memory | Data Memory | | | 10-Bit | CCP/ | MSSP | | KT | | Timers | |------------|------------------|----------------------------|-----------------|----------------|-----|----------|---------------|------|-----------------------------|------|-------|----------| | Device | Flash<br>(bytes) | # Single-Word Instructions | SRAM<br>(bytes) | EEPROM (bytes) | I/O | A/D (ch) | ECCP<br>(PWM) | SPI | Master<br>I <sup>2</sup> C™ | EUSA | Comp. | 8/16-Bit | | PIC18F2221 | 4K | 2048 | 512 | 256 | 25 | 10 | 2/0 | Υ | Y | 1 | 2 | 1/3 | | PIC18F2321 | 8K | 4096 | 512 | 256 | 25 | 10 | 2/0 | Υ | Υ | 1 | 2 | 1/3 | | PIC18F4221 | 4K | 2048 | 512 | 256 | 36 | 13 | 1/1 | Υ | Υ | 1 | 2 | 1/3 | | PIC18F4321 | 8K | 4096 | 512 | 256 | 36 | 13 | 1/1 | Υ | Υ | 1 | 2 | 1/3 | #### **Pin Diagrams** #### 28-Pin SPDIP, SOIC, SSOP #### 28-Pin QFN Note 1: RB3 is the alternate pin for CCP2 multiplexing. #### Pin Diagrams (Continued) #### Pin Diagrams (Continued) #### **Table of Contents** | 1.0 | Device Overview | 9 | |------|---------------------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with PIC18F Microcontrollers | 25 | | 3.0 | Oscillator Configurations | | | 4.0 | Power-Managed Modes | 39 | | 5.0 | Reset | 47 | | 6.0 | Memory Organization | 59 | | 7.0 | Flash Program Memory | 79 | | 8.0 | Data EEPROM Memory | 89 | | 9.0 | 8 x 8 Hardware Multiplier | 95 | | 10.0 | Interrupts | 97 | | 11.0 | I/O Ports | 111 | | 12.0 | Timer0 Module | 129 | | 13.0 | Timer1 Module | 133 | | | Timer2 Module | | | 15.0 | Timer3 Module | 141 | | 16.0 | Capture/Compare/PWM (CCP) Modules | 145 | | 17.0 | Enhanced Capture/Compare/PWM (ECCP) Module | 153 | | | Master Synchronous Serial Port (MSSP) Module | | | | Enhanced Universal Synchronous Asynchronous Receiver Transmitter (EUSART) | | | 20.0 | 10-Bit Analog-to-Digital Converter (A/D) Module | 233 | | | Comparator Module | | | 22.0 | Comparator Voltage Reference Module | 249 | | 23.0 | High/Low-Voltage Detect (HLVD) | 253 | | 24.0 | Special Features of the CPU | 259 | | 25.0 | Instruction Set Summary | 279 | | 26.0 | Development Support | 329 | | 27.0 | Electrical Characteristics | 333 | | | Packaging Information | | | Appe | endix A: Revision History | 385 | | | endix B: Device Differences | | | | endix C: Conversion Considerations | | | | endix D: Migration from Baseline to Enhanced Devices | | | | endix E: Migration From Mid-Range to Enhanced Devices | | | Appe | endix F: Migration From High-End to Enhanced Devices | 388 | | | X | | | | Microchip Web Site | | | | omer Change Notification Service | | | | omer Support | | | | der Response | 400 | | PIC1 | 8F2221/2321/4221/4321 Product Identification System | 401 | #### TO OUR VALUED CUSTOMERS It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced. If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback. #### **Most Current Data Sheet** To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at: http://www.microchip.com You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000). #### Errata An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies. To determine if an errata sheet exists for a particular device, please check with one of the following: - Microchip's Worldwide Web site; http://www.microchip.com - · Your local Microchip sales office (see last page) When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using. #### **Customer Notification System** Register on our web site at www.microchip.com to receive the most current information on all of our products. #### 1.0 DEVICE OVERVIEW This document contains device specific information for the following devices: PIC18F2221 PIC18F2321 PIC18F2321 PIC18F4221 PIC18F4221 PIC18F4321 PIC18LF4321 This family offers the advantages of all PIC18 microcontrollers – namely, high computational performance at an economical price – with the addition of high-endurance, Enhanced Flash program memory. On top of these features, the PIC18F2221/2321/4221/4321 family introduces design enhancements that make these microcontrollers a logical choice for many high-performance, power sensitive applications. #### 1.1 New Core Features #### 1.1.1 nanoWatt TECHNOLOGY All of the devices in the PIC18F2221/2321/4221/4321 family incorporate a range of features that can significantly reduce power consumption during operation. Key items include: - Alternate Run Modes: By clocking the controller from the Timer1 source or the internal oscillator block, power consumption during code execution can be reduced by as much as 90%. - Multiple Idle Modes: The controller can also run with its CPU core disabled but the peripherals still active. In these states, power consumption can be reduced even further, to as little as 4% of normal operation requirements. - On-the-Fly Mode Switching: The power-managed modes are invoked by user code during operation, allowing the user to incorporate power-saving ideas into their application's software design. - Low Consumption in Key Modules: The power requirements for both Timer1 and the Watchdog Timer are minimized. See Section 27.0 "Electrical Characteristics" for values. ### 1.1.2 MULTIPLE OSCILLATOR OPTIONS AND FEATURES All of the devices in the PIC18F2221/2321/4221/4321 family offer ten different oscillator options, allowing users a wide range of choices in developing application hardware. These include: - Four Crystal modes, using crystals or ceramic resonators. - Two External Clock modes, offering the option of using two pins (oscillator input and a divide-by-4 clock output) or one pin (oscillator input, with the second pin reassigned as general I/O). - Two External RC Oscillator modes with the same pin options as the External Clock modes. - Two Internal Oscillator modes which provide an 8 MHz clock and an INTRC source (approximately 31 kHz), as well as a range of 6 user-selectable clock frequencies, between 125 kHz to 4 MHz, for a total of 8 clock frequencies. One or both of the oscillator pins can be used for general purpose I/O. - A Phase Lock Loop (PLL) frequency multiplier, available to both the high-speed crystal and internal oscillator modes, which allows clock speeds of up to 40 MHz. Used with the internal oscillator, the PLL gives users a complete selection of clock speeds, from 31 kHz to 32 MHz – all without using an external crystal or clock circuit. Besides its availability as a clock source, the internal oscillator block provides a stable reference source that gives the family additional features for robust operation: - Fail-Safe Clock Monitor: This option constantly monitors the main clock source against a reference signal provided by the internal oscillator. If a clock failure occurs, the controller is switched to the internal oscillator block, allowing for continued low-speed operation or a safe application shutdown. - Two-Speed Start-up: This option allows the internal oscillator to serve as the clock source from Power-on Reset, or wake-up from Sleep mode, until the primary clock source is available. #### 1.2 Other Special Features - Memory Endurance: The Enhanced Flash cells for both program memory and data EEPROM are rated to last for many thousands of erase/write cycles – up to 100,000 for program memory and 1,000,000 for EEPROM. Data retention without refresh is conservatively estimated to be greater than 40 years. - Self-Programmability: These devices can write to their own program memory spaces under internal software control. By using a bootloader routine, located in the protected Boot Block at the top of program memory, it becomes possible to create an application that can update itself in the field. - Extended Instruction Set: The PIC18F2221/ 2321/4221/4321 family introduces an optional extension to the PIC18 instruction set, which adds 8 new instructions and an Indexed Addressing mode. This extension, enabled as a device configuration option, has been specifically designed to optimize re-entrant application code originally developed in high-level languages, such as C. - Enhanced CCP Module: In PWM mode, this module provides 1, 2 or 4 modulated outputs for controlling half-bridge and full-bridge drivers. Other features include auto-shutdown, for disabling PWM outputs on interrupt or other select conditions and auto-restart, to reactivate outputs once the condition has cleared. - Enhanced Addressable USART: This serial communication module is capable of standard RS-232 operation and provides support for the LIN/J2602 bus protocol. Other enhancements include automatic baud rate detection and a 16-bit Baud Rate Generator for improved resolution. When the microcontroller is using the internal oscillator block, the EUSART provides stable operation for applications that talk to the outside world without using an external crystal (or its accompanying power requirement). - 10-Bit A/D Converter: This module incorporates programmable acquisition time, allowing for a channel to be selected and a conversion to be initiated without waiting for a sampling period and thus, reducing code overhead. - Extended Watchdog Timer (WDT): This Enhanced version incorporates a 16-bit prescaler, allowing an extended time-out range that is stable across operating voltage and temperature. See Section 27.0 "Electrical Characteristics" for time-out periods. ## 1.3 Details on Individual Family Members Devices in the PIC18F2221/2321/4221/4321 family are available in 28-pin and 40/44-pin packages. Block diagrams for the two groups are shown in Figure 1-1 and Figure 1-2. The devices are differentiated from each other in five ways: - Flash program memory (4 Kbytes for PIC18F2221/4221 devices, 8 Kbytes for PIC18F2321/4321). - 2. A/D channels (10 for 28-pin devices, 13 for 40/44-pin devices). - 3. I/O ports (3 bidirectional ports on 28-pin devices, 5 bidirectional ports on 40/44-pin devices). - CCP and Enhanced CCP implementation (28-pin devices have 2 standard CCP modules, 40/44-pin devices have one standard CCP module and one ECCP module). - Parallel Slave Port (present only on 40/44-pin devices). All other features for devices in this family are identical. These are summarized in Table 1-1. The pinouts for all devices are listed in Table 1-2 and Table 1-3. Like all Microchip PIC18 devices, members of the PIC18F2221/2321/4221/4321 family are available as both standard and low-voltage devices. Standard devices with Enhanced Flash memory, designated with an "F" in the part number (such as PIC18F2321), accommodate an operating VDD range of 4.2V to 5.5V. Low-voltage parts, designated by "LF" (such as PIC18LF2321), function over an extended VDD range of 2.0V to 5.5V. TABLE 1-1: DEVICE FEATURES | Features | PIC18F2221 | PIC18F2321 | PIC18F4221 | PIC18F4321 | |------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | Operating Frequency | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | DC – 40 MHz | | Program Memory (Bytes) | 4096 | 8192 | 4096 | 8192 | | Program Memory (Instructions) | 2048 | 4096 | 2048 | 4096 | | Data Memory (Bytes) | 512 | 512 | 512 | 512 | | 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 Capture/Compare/<br>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 | | 10-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 Low-Voltage<br>Detect | Yes | Yes | Yes | Yes | | Programmable Brown-out Reset | Yes | Yes | Yes | Yes | | Instruction Set | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>enabled | 75 Instructions;<br>83 with Extended<br>Instruction Set<br>enabled | | Packages | 28-pin SPDIP<br>28-pin SOIC<br>28-pin SSOP<br>28-pin QFN | 28-pin SPDIP<br>28-pin SOIC<br>28-pin SSOP<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 | FIGURE 1-1: **PIC18F2221/2321 (28-PIN) BLOCK DIAGRAM** Data Bus<8> Table Pointer<21> Data Latch PORTA 8 8 inc/dec logic RA0/AN0 Data Memory RA1/AN1 (3.9 Kbytes) RA2/AN2/VREF-/CVREF PCLATU PCLATH 21 RA3/AN3/VREF+ Address Latch 20 RA4/T0CKI/C1OUT PCU PCH PCL RA5/AN4/SS/HLVDIN/C2OUT Program Counter **1**2 OSC2/CLKO(3)/RA6 Data Address<12> OSC1/CLKI<sup>(3)</sup>/RA7 31 Level Stack Address Latch 12 BSR Access FSR0 Program Memory STKPTR Bank (4 Kbytes) FSR1 FSR2 12 Data Latch **PORTB** RB0/INT0/FLT0/AN12 inc/dec RB1/INT1/AN10 logic Table Latch RB2/INT2/AN8 RB3/AN9/CCP2<sup>(1)</sup> RB4/KBI0/AN11 Address **ROM Latch** RB5/KBI1/PGM Decode Instruction Bus <16> RB6/KBI2/PGC RB7/KBI3/PGD IR 8 State Machine Instruction Control Signals Decode & Control PRODH PRODL PORTO RC0/T10SO/T13CKI 8 x 8 Multiply 3 RC1/T1OSI/CCP2(1) RC2/CCP1 BITOP RC3/SCK/SCL RC4/SDI/SDA RC5/SDO OSC1<sup>(3)</sup> Internal Power-up RC6/TX/CK 8 Oscillator Timer RC7/RX/DT Block OSC2<sup>(3)</sup> Oscillator ALŮ<8> Start-up Time INTRC Oscillator Power-on T10SI X 8 Reset 8 MHz Watchdog T10S0 Oscillator Timer Precision Brown-out Single-Supply MCLR<sup>(2)</sup> Band Gap PORTE Reset Programming Reference Fail-Safe In-Circuit VDD, VSS Clock Monito Debugger MCLR/Vpp/RE3<sup>(2)</sup> **BOR** Data Timer0 Timer3 Timer1 Timer2 **EEPROM** LVD ADC MSSP Comparato CCP1 CCP2 **EUSART** 10-Bit 1: CCP2 is multiplexed with RC1 when Configuration bit, CCP2MX, is set, or RB3 when CCP2MX is not set. Note RE3 is only available when $\overline{\text{MCLR}}$ functionality is disabled. 2: OSC1/CLKI and OSC2/CLKO are only available in select oscillator modes and when these pins are not being used as digital I/O. Refer to Section 3.0 "Oscillator Configurations" for additional information. FIGURE 1-2: PIC18F4221/4321 (40/44-PIN) BLOCK DIAGRAM Data Bus<8> Table Pointer<21> PORTA RA0/AN0 Data Latch RA1/AN1 inc/dec logic 8 8 RA2/AN2/VREF-/CVREF Data Memory RA3/AN3/VREF+ (3.9 Kbytes) RA4/T0CKI/C1OUT PCLATU PCLATH 21 RA5/AN4/SS/HLVDIN/C2OUT Address Latch 20 OSC2/CLKO<sup>(3)</sup>/RA6 PCU PCH PCL OSC1/CLKI(3)/RA7 Program Counter **1**2 Data Address<12> PORTB 31 Level Stack RB0/INT0/FLT0/AN12 /12 Address Latch RB1/INT1/AN10 BSR Access Bank FSR0 Program Memory RB2/INT2/AN8 STKPTR RB3/AN9/CCP2<sup>(1)</sup> (8 Kbytes) FSR1 FSR2 RB4/KBI0/AN11 Data Latch 12 RB5/KBI1/PGM RB6/KBI2/PGC nc/dec RB7/KBI3/PGD logic Table Latch Address **PORTC ROM Latch** Decode RC0/T10S0/T13CKI Instruction Bus <16> RC1/T1OSI/CCP2(1) RC2/CCP1/P1A IR RC3/SCK/SCL RC4/SDI/SDA RC5/SDO 8 RC6/TX/CK State Machine Instruction RC7/RX/DT Control Signals Decode & Control PRODH PRODL 8 x 8 Multiply PORTD RD0/PSP0:RD4/PSP4 BITOP W RD5/PSP5/P1B RD6/PSP6/P1C RD7/PSP7/P1D OSC1<sup>(3)</sup> Internal Power-up Oscillator 8 8 Timer Block OSC2<sup>(3)</sup> Oscillator ALÚ<8> Start-up Time INTRO Oscillator Power-on 8 T10SI $\times$ Reset 8 MHz Watchdog T10S0 🔀 Oscillator PORTE Timer RE0/RD/AN5 Precision Brown-out RE1/WR/AN6 MCLR<sup>(2)</sup> Single-Supply Band Gap Reset RE2/CS/AN7 Programming Reference Fail-Safe MCLR/VPP/RE3<sup>(2)</sup> In-Circuit VDD, VSS Clock Monitor Debugger BOR Data Timer0 Timer1 Timer2 Timer3 **EEPROM** LVD ADC MSSP ECCP1 CCP2 **EUSART** Comparator 10-Bit 1: CCP2 is multiplexed with RC1 when Configuration bit, CCP2MX, is set, or RB3 when CCP2MX is not set. RE3 is only available when MCLR functionality is disabled. OSC1/CLKI and OSC2/CLKO are only available in select oscillator modes and when these pins are not being used as digital I/O. Refer to Section 3.0 "Oscillator Configurations" for additional information. TABLE 1-2: PIC18F2221/2321 PINOUT I/O DESCRIPTIONS | | Pin Nu | ımber | | | | | | | |-----------------------|-------------------------|-------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pin Name | SPDIP,<br>SOIC,<br>SSOP | QFN | Pin<br>Type | Buffer<br>Type | Description | | | | | MCLR/VPP/RE3 | 1 | 26 | | | Master Clear (input) or programming voltage (input). | | | | | MCLR | | | ı | ST | Master Clear (Reset) input. This pin is an active-low | | | | | VPP | | | Р | | Reset to the device. Programming voltage input. | | | | | RE3 | | | i | ST | Digital input. | | | | | OSC1/CLKI/RA7 | 9 | 6 | | | Oscillator crystal or external clock input. | | | | | OSC1 | | | I | Analog | | | | | | CLKI | | | I | CMOS | ST buffer when configured in RC mode; CMOS otherwise. External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, OSC2/CLKO pins.) | | | | | RA7 | | | I/O | TTL | General purpose I/O pin. | | | | | OSC2/CLKO/RA6<br>OSC2 | 10 | 7 | 0 | _ | Oscillator crystal or clock output. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. | | | | | CLKO | | | 0 | _ | In RC, EC and INTIO modes, OSC2 pin outputs CLKO which has one-fourth the frequency of OSC1 and denotes the instruction cycle rate. | | | | | RA6 | | | I/O | TTL | General purpose I/O pin. | | | | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input P = Power $I^2C = ST \text{ with } I^2C^{TM} \text{ or SMB levels}$ O = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. TABLE 1-2: PIC18F2221/2321 PINOUT I/O DESCRIPTIONS (CONTINUED) | | Pin Nu | ımber | | | | | | | |--------------------------------------------------------------------|-------------------------|-------|-------------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pin Name | SPDIP,<br>SOIC,<br>SSOP | QFN | Pin<br>Type | Buffer<br>Type | Description | | | | | | | | | | PORTA is a bidirectional I/O port. | | | | | RA0/AN0<br>RA0<br>AN0 | 2 | 27 | I/O<br>I | TTL<br>Analog | Digital I/O.<br>Analog Input 0. | | | | | RA1/AN1<br>RA1<br>AN1 | 3 | 28 | 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 | 1 | I/O<br>I<br>I<br>O | TTL<br>Analog<br>Analog<br>Analog | | | | | | RA3/AN3/VREF+<br>RA3<br>AN3<br>VREF+ | 5 | 2 | 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 | 3 | I/O<br>I<br>O | ST<br>ST<br>— | Digital I/O. Open-collector output. Timer0 external clock input. Comparator 1 output. | | | | | RA5/AN4/SS/HLVDIN/<br>C2OUT<br>RA5<br>AN4<br>SS<br>HLVDIN<br>C2OUT | 7 | 4 | I/O<br>I<br>I<br>I<br>O | TTL<br>Analog<br>TTL<br>Analog | SPI slave select input.<br>High/Low-Voltage Detect input.<br>Comparator 2 output. | | | | | | | | | | See the OSC2/CLKO/RA6 pin. | | | | | RA5/AN4/SS/HLVDIN/<br>C2OUT<br>RA5<br>AN4<br>SS<br>HLVDIN | 7 | 4 | I/O<br>I<br>I | Analog<br>TTL | Comparator 1 output. Digital I/O. Analog Input 4. SPI slave select input. High/Low-Voltage Detect input. Comparator 2 output. | | | | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input P = Power $I^2C = ST \text{ with } I^2C^{TM} \text{ or SMB levels}$ O = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. **TABLE 1-2:** PIC18F2221/2321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pi | | Pin Number | | | | | | | | |---------------------------------------------------|-------------------------|------------|-----------------|---------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--| | Pin Name | SPDIP,<br>SOIC,<br>SSOP | QFN | Pin<br>Type | Buffer<br>Type | 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<br>RB0<br>INT0<br>FLT0<br>AN12 | 21 | 18 | I/O<br>I<br>I | TTL<br>ST<br>ST<br>Analog | Digital I/O. External Interrupt 0. PWM Fault input for CCP1. Analog Input 12. | | | | | | RB1/INT1/AN10<br>RB1<br>INT1<br>AN10 | 22 | 19 | I/O<br>I<br>I | TTL<br>ST<br>Analog | Digital I/O. External Interrupt 1. Analog Input 10. | | | | | | RB2/INT2/AN8<br>RB2<br>INT2<br>AN8 | 23 | 20 | I/O<br>I | TTL<br>ST<br>Analog | Digital I/O. External Interrupt 2. Analog Input 8. | | | | | | RB3/AN9/CCP2<br>RB3<br>AN9<br>CCP2 <sup>(2)</sup> | 24 | 21 | I/O<br>I<br>I/O | TTL<br>Analog<br>ST | Digital I/O.<br>Analog Input 9.<br>Capture 2 input/Compare 2 output/PWM2 output. | | | | | | RB4/KBI0/AN11<br>RB4<br>KBI0<br>AN11 | 25 | 22 | I/O<br>I<br>I | TTL<br>TTL<br>Analog | Digital I/O.<br>Interrupt-on-change pin.<br>Analog Input 11. | | | | | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 26 | 23 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>Low-Voltage ICSP™ programming enable pin. | | | | | | RB6/KBI2/PGC<br>RB6<br>KBI2<br>PGC | 27 | 24 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>In-circuit debugger and ICSP programming clock pin. | | | | | | RB7/KBI3/PGD<br>RB7<br>KBI3<br>PGD | 28 | 25 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>In-circuit debugger and ICSP programming data pin. | | | | | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels $I^2C$ = ST with $I^2C^{TM}$ or SMB levels = Input P = Power 1 = Output 0 Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. **TABLE 1-2:** PIC18F2221/2321 PINOUT I/O DESCRIPTIONS (CONTINUED) | | Pin Number | | | | | |-------------------------------------------------------|-------------------------|-------|-------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | Pin Name | SPDIP,<br>SOIC,<br>SSOP | QFN | Pin<br>Type | Buffer<br>Type | Description | | | | | | | PORTC is a bidirectional I/O port. | | RC0/T10S0/T13CKI<br>RC0<br>T10S0<br>T13CKI | 11 | 8 | I/O<br>O<br>I | ST<br>—<br>ST | Digital I/O.<br>Timer1 oscillator analog output.<br>Timer1/Timer3 external clock input. | | RC1/T1OSI/CCP2<br>RC1<br>T1OSI<br>CCP2 <sup>(1)</sup> | 12 | 9 | I/O<br>I<br>I/O | ST<br>Analog<br>ST | Digital I/O.<br>Timer1 oscillator analog input.<br>Capture 2 input/Compare 2 output/PWM2 output. | | RC2/CCP1<br>RC2<br>CCP1 | 13 | 10 | I/O<br>I/O | ST<br>ST | Digital I/O.<br>Capture 1 input/Compare 1 output/PWM1 output. | | RC3/SCK/SCL<br>RC3<br>SCK<br>SCL | 14 | 11 | I/O<br>I/O<br>I/O | ST<br>ST<br>I <sup>2</sup> C | Digital I/O.<br>Synchronous serial clock input/output for SPI mode.<br>Synchronous serial clock input/output for I <sup>2</sup> C™ mode. | | RC4/SDI/SDA<br>RC4<br>SDI<br>SDA | 15 | 12 | 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 | 16 | 13 | I/O<br>O | ST<br>— | Digital I/O.<br>SPI data out. | | RC6/TX/CK<br>RC6<br>TX<br>CK | 17 | 14 | 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 | 18 | 15 | I/O<br>I<br>I/O | ST<br>ST<br>ST | Digital I/O. EUSART asynchronous receive. EUSART synchronous data (see related TX/CK). | | RE3 | | _ | _ | _ | See MCLR/VPP/RE3 pin. | | Vss | 8, 19 | 5, 16 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 20 | 17 | Р | _ | Positive supply for logic and I/O pins. | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ı ST = Schmitt Trigger input with CMOS levels $I^2C$ = ST with $I^2C^{TM}$ or SMB levels P = Power = Input 0 = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. **TABLE 1-3:** PIC18F4221/4321 PINOUT I/O DESCRIPTIONS | Pin Name | Piı | Pin Number | | Pin | Buffer | Description | |-----------------------|------|------------|------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------| | Pili Name | PDIP | QFN | TQFP | Туре | Type | Description | | MCLR/VPP/RE3<br>MCLR | 1 | 18 | 18 | ı | ST | Master Clear (input) or programming voltage (input). Master Clear (Reset) input. This pin is an active-low Reset to the device. | | VPP<br>RE3 | | | | P<br>I | ST | Programming voltage input. Digital input. | | OSC1/CLKI/RA7<br>OSC1 | 13 | 32 | 30 | ı | Analog | ST buffer when configured in RC mode; | | CLKI | | | | I | Analog | analog otherwise. External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKI, 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. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. | | CLKO | | | | 0 | _ | In RC, EC and INTIO modes, OSC2 pin outputs CLKO which has one-fourth the frequency of OSC1 and denotes the instruction cycle rate. | | RA6 | | | | I/O | TTL | General purpose I/O pin. | Legend: TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels $I^2C$ = ST with $I^2C^{TM}$ or SMB levels CMOS = CMOS compatible input or output 1 = Input P = Power = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. **TABLE 1-3:** PIC18F4221/4321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | | | Pin | Buffer | Description | | | |--------------------------------------------------------------------|------------|-----|------|---------------------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------|--|--| | Pin Name | PDIP | QFN | TQFP | Туре | Туре | Description | | | | DAO/ANO | 2 | 19 | 19 | | | 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. Analog Input 2. A/D reference voltage (low) input. 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<br>— | 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> <br> <br> <br> <br> <br> <br> | TTL<br>Analog<br>TTL<br>Analog<br>— | Digital I/O. Analog Input 4. SPI slave select input. High/Low-Voltage Detect input. Comparator 2 output. | | | | 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^2C$ = ST with $I^2C^{TM}$ or SMB levels P = Power = Input 0 = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. TABLE 1-3: PIC18F4221/4321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Nama | Pi | n Numb | er | | Buffer | Description | | | | | |---------------------------------------------------|------|--------|------|--------------------|---------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--| | Pin Name | PDIP | QFN | TQFP | Туре | Туре | 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<br>RB0<br>INT0<br>FLT0<br>AN12 | 33 | 9 | 8 | I/O<br>I<br>I<br>I | TTL<br>ST<br>ST<br>Analog | Digital I/O. External Interrupt 0. PWM Fault input for Enhanced CCP1. Analog input 12. | | | | | | RB1/INT1/AN10<br>RB1<br>INT1<br>AN10 | 34 | 10 | 9 | I/O<br>I<br>I | TTL<br>ST<br>Analog | Digital I/O.<br>External Interrupt 1.<br>Analog Input 10. | | | | | | RB2/INT2/AN8<br>RB2<br>INT2<br>AN8 | 35 | 11 | 10 | I/O<br>I<br>I | TTL<br>ST<br>Analog | Digital I/O.<br>External Interrupt 2.<br>Analog Input 8. | | | | | | RB3/AN9/CCP2<br>RB3<br>AN9<br>CCP2 <sup>(2)</sup> | 36 | 12 | 11 | I/O<br>I<br>I/O | TTL<br>Analog<br>ST | Digital I/O. Analog Input 9. Capture 2 input/Compare 2 output/PWM2 output. | | | | | | RB4/KBI0/AN11<br>RB4<br>KBI0<br>AN11 | 37 | 14 | 14 | I/O<br>I<br>I | TTL<br>TTL<br>Analog | Digital I/O.<br>Interrupt-on-change pin.<br>Analog input 11. | | | | | | RB5/KBI1/PGM<br>RB5<br>KBI1<br>PGM | 38 | 15 | 15 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>Low-Voltage ICSP™ Programming enable pin. | | | | | | RB6/KBI2/PGC<br>RB6<br>KBI2<br>PGC | 39 | 16 | 16 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O. Interrupt-on-change pin. In-circuit debugger and ICSP programming clock pin. | | | | | | RB7/KBI3/PGD<br>RB7<br>KBI3<br>PGD | 40 | 17 | 17 | I/O<br>I<br>I/O | TTL<br>TTL<br>ST | Digital I/O.<br>Interrupt-on-change pin.<br>In-circuit debugger and ICSP programming<br>data pin. | | | | | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input P = Power $I^2C = ST \text{ with } I^2C^{TM} \text{ or SMB levels}$ O = Output 1 Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. TABLE 1-3: PIC18F4221/4321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Din Name | Pin Number | | | Pin B | Buffer | Description | | | |-------------------------------------------------------|------------|-----|------|-----------------|------------------------------|--------------------------------------------------------------------------------------------------|--|--| | Pin Name | PDIP | QFN | TQFP | Туре | 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. Timer1 oscillator analog output. Timer1/Timer3 external clock input. | | | | RC1/T1OSI/CCP2<br>RC1<br>T1OSI<br>CCP2 <sup>(1)</sup> | 16 | 35 | 35 | I/O<br>I<br>I/O | ST<br>CMOS<br>ST | Digital I/O.<br>Timer1 oscillator analog 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. Synchronous serial clock input/output for 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. EUSART asynchronous receive. EUSART synchronous data (see related TX/CK). | | | Legend: TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input P = Power $I^2C = ST$ with $I^2C^{TM}$ or SMB levels O = Output I Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. TABLE 1-3: PIC18F4221/4321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | | Pin | Buffer | Description | | | | | |------------------------------------|------------|-----|------|-----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Pili Name | PDIP | QFN | TQFP | Туре | Type | Description | | | | | | | | | | | PORTD is a bidirectional I/O port or a Parallel Slave Port (PSP) for interfacing to a microprocessor port. These pins have TTL input buffers when the PSP 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<br>— | 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<br>— | Digital I/O. Parallel Slave Port data. 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. Parallel Slave Port data. Enhanced CCP1 output. | | | | **Legend:** TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels $I^2C = ST \text{ with } I^2C^{TM} \text{ or SMB levels}$ CMOS = CMOS compatible input or output = Input P = Power O = Output Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. TABLE 1-3: PIC18F4221/4321 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin Number | | | Pin | Buffer | Description | |-------------------|------------|--------------|---------|-------|------------|-----------------------------------------------| | | PDIP | QFN | TQFP | 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 | | AN5 | | | | | Analog | (see also WR and CS pins).<br>Analog Input 5. | | | | | | ' | Allalog | Analog Input 5. | | RE1/WR/AN6<br>RE1 | 9 | 26 | 26 | I/O | ST | Digital I/O. | | WR | | | | 1/0 | TTL | Write control for Parallel Slave Port | | | | | | - | | (see CS and RD pins). | | AN6 | | | | I | Analog | Analog Input 6. | | RE2/CS/AN7 | 10 | 27 | 27 | | | | | RE2 | | | | I/O | ST | Digital I/O. | | CS | | | | I | TTL | Chip Select control for Parallel Slave Port | | AN7 | | | | ı | Analog | (see related RD and WR). Analog Input 7. | | RE3 | | | | | 7 ti lalog | See MCLR/VPP/RE3 pin. | | Vss | 12. 31 | 6 30 | 6 20 | <br>Р | _ | · | | V55 | 12, 31 | 6, 30,<br>31 | 6, 29 | Р | _ | Ground reference for logic and I/O pins. | | VDD | 11, 32 | 7, 8, | 7, 28 | Р | _ | Positive supply for logic and I/O pins. | | | | 28, 29 | | | | | | NC | _ | 13 | 12, 13, | _ | _ | No Connect. | | | | | 33, 34 | | | | **Legend:** TTL = TTL compatible input CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels = Input P = Power $I^2C = ST \text{ with } I^2C^{TM} \text{ or SMB levels}$ = Output 1 0 Note 1: Default assignment for CCP2 when Configuration bit, CCP2MX, is set. NOTES: # 2.0 GUIDELINES FOR GETTING STARTED WITH PIC18F MICROCONTROLLERS #### 2.1 Basic Connection Requirements Getting started with the PIC18F2221/2321/4221/4321 family family of 8-bit microcontrollers requires attention to a minimal set of device pin connections before proceeding with development. The following pins must always be connected: - All VDD and Vss pins (see Section 2.2 "Power Supply Pins") - All AVDD and AVSS pins, regardless of whether or not the analog device features are used (see Section 2.2 "Power Supply Pins") - MCLR pin (see Section 2.3 "Master Clear (MCLR) Pin") These pins must also be connected if they are being used in the end application: - PGC/PGD pins used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see Section 2.4 "ICSP Pins") - OSCI and OSCO pins when an external oscillator source is used (see Section 2.5 "External Oscillator Pins") Additionally, the following pins may be required: VREF+/VREF- pins used when external voltage reference for analog modules is implemented **Note:** The AVDD and AVss pins must always be connected, regardless of whether any of the analog modules are being used. The minimum mandatory connections are shown in Figure 2-1. ### FIGURE 2-1: RECOMMENDED MINIMUM CONNECTIONS #### Key (all values are recommendations): C1 through C6: 0.1 $\mu$ F, 20V ceramic C7: 10 $\mu$ F, 16V tantalum or ceramic R1: 10 kΩ R2: 100Ω to 470Ω Note 1: The example shown is for a PIC18F device with five VDD/VSs and AVDD/AVSs pairs. Other devices may have more or less pairs; adjust the number of decoupling capacitors appropriately.