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 ### **High Performance Microcontrollers with 10-bit A/D** ### **High Performance RISC CPU:** - · C compiler optimized architecture/instruction set - Source code compatible with the PIC16CXX instruction set - Linear program memory addressing to 2 Mbytes - · Linear data memory addressing to 4 Kbytes | | On-Chip P | On-Chip | | | |-----------|------------------|-------------------------------|----------------|--| | Device | EPROM<br>(bytes) | # Single Word<br>Instructions | RAM<br>(bytes) | | | PIC18C242 | 16K | 8192 | 512 | | | PIC18C252 | 32K | 16384 | 1536 | | | PIC18C442 | 16K | 8192 | 512 | | | PIC18C452 | 32K | 16384 | 1536 | | - Up to 10 MIPs operation: - DC 40 MHz osc./clock input - 4 MHz 10 MHz osc./clock input with PLL active - · 16-bit wide instructions, 8-bit wide data path - · Priority levels for interrupts - 8 x 8 Single Cycle Hardware Multiplier ### **Peripheral Features:** - · High current sink/source 25 mA/25 mA - Three external interrupt pins - Timer0 module: 8-bit/16-bit timer/counter with 8-bit programmable prescaler - Timer1 module: 16-bit timer/counter - Timer2 module: 8-bit timer/counter with 8-bit period register (time-base for PWM) - · Timer3 module: 16-bit timer/counter - Secondary oscillator clock option Timer1/Timer3 - Two Capture/Compare/PWM (CCP) modules. CCP pins that can be configured as: - Capture input: capture is 16-bit, max. resolution 6.25 ns (Tcy/16) - Compare is 16-bit, max. resolution 100 ns (Tcy) - PWM output: PWM resolution is 1- to 10-bit. Max. PWM freq. @: 8-bit resolution = 156 kHz 10-bit resolution = 39 kHz - · Master Synchronous Serial Port (MSSP) module. Two modes of operation: - 3-wire SPI (supports all 4 SPI modes) - I<sup>2</sup>C™ master and slave mode - · Addressable USART module: - Supports interrupt on Address bit - · Parallel Slave Port (PSP) module ### Pin Diagrams Note: Pin compatible with 40-pin PIC16C7X devices. ### **Analog Features:** - · Compatible 10-bit Analog-to-Digital Converter module (A/D) with: - Fast sampling rate - Conversion available during SLEEP - DNL = ±1 LSb, INL = ±1 LSb - Programmable Low Voltage Detection (LVD) module - Supports interrupt-on-low voltage detection - Programmable Brown-out Reset (BOR) #### **Special Microcontroller Features:** - Power-on Reset (POR), Power-up Timer (PWRT) and Oscillator Start-up Timer (OST) - · Watchdog Timer (WDT) with its own on-chip RC oscillator for reliable operation - · Programmable code protection - · Power saving SLEEP mode - Selectable oscillator options including: - 4X Phase Lock Loop (of primary oscillator) - Secondary Oscillator (32 kHz) clock input - In-Circuit Serial Programming (ICSP™) via two pins ### **CMOS Technology:** - Low power, high speed EPROM technology - · Fully static design - Wide operating voltage range (2.5V to 5.5V) - · Industrial and Extended temperature ranges - · Low power consumption #### **Pin Diagrams** ### Pin Diagrams (Cont.'d) Note: Pin compatible with 40-pin PIC16C7X devices. ### DIP, SOIC, JW <sup>\*</sup> RB3 is the alternate pin for the CCP2 pin multiplexing. Note: Pin compatible with 28-pin PIC16C7X devices. ### **Table of Contents** | 1.0 | Device Overview | 7 | |-------|-------------------------------------------------------------------------------|-----| | 2.0 | Oscillator Configurations | 17 | | 3.0 | Reset | 25 | | 4.0 | Memory Organization | 35 | | 5.0 | Table Reads/Table Writes | 55 | | 6.0 | 8 X 8 Hardware Multiplier | 61 | | 7.0 | Interrupts | 63 | | 8.0 | I/O Ports | 77 | | 9.0 | Timer0 Module | 93 | | 10.0 | 0 Timer1 Module | 97 | | 11.0 | 0 Timer2 Module | 101 | | 12.0 | 0 Timer3 Module | 103 | | 13.0 | 0 Capture/Compare/PWM (CCP) Modules | 107 | | 14.0 | 0 Master Synchronous Serial Port (MSSP) Module | 115 | | 15.0 | 0 Addressable Universal Synchronous Asynchronous Receiver Transmitter (USART) | 149 | | 16.0 | 0 Compatible 10-bit Analog-to-Digital Converter (A/D) Module | 165 | | 17.0 | 0 Low Voltage Detect | 173 | | 18.0 | 0 Special Features of the CPU | 179 | | 19.0 | 0 Instruction Set Summary | 187 | | 20.0 | 0 Development Support | 229 | | 21.0 | 0 Electrical Characteristics | 235 | | 22.0 | 0 DC and AC Characteristics Graphs and Tables | 263 | | 23.0 | 0 Packaging Information | 277 | | Apper | pendix A: Revision History | 287 | | Appei | pendix B: Device Differences | 287 | | Apper | pendix C: Conversion Considerations | 288 | | Apper | pendix D: Migration from Baseline to Enhanced Devices | 288 | | Apper | pendix E: Migration from Mid-Range to Enhanced Devices | 289 | | Appei | pendix F: Migration from High-End to Enhanced Devices | 289 | | Index | ex | 291 | | On-Li | -Line Support | 299 | | Read | ader Response | 300 | | DIC19 | 219CVV2 Product Identification System | 201 | ### 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@mail.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) - The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277 When contacting a sales office or the literature center, 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/cn to receive the most current information on all of our products. **NOTES:** ### 1.0 DEVICE OVERVIEW This document contains device specific information for the following four devices: - 1. PIC18C242 - 2. PIC18C252 - 3. PIC18C442 - 4. PIC18C452 These devices come in 28-pin and 40-pin packages. The 28-pin devices do not have a Parallel Slave Port (PSP) implemented and the number of Analog-to-Digital (A/D) converter input channels is reduced to 5. An overview of features is shown in Table 1-1. The following two figures are device block diagrams sorted by pin count: 28-pin for Figure 1-1 and 40-pin for Figure 1-2. The 28-pin and 40-pin pinouts are listed in Table 1-2 and Table 1-3, respectively. **TABLE 1-1: DEVICE FEATURES** | Features | PIC18C242 | PIC18C252 | PIC18C442 | PIC18C452 | |------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | Operating Frequency | DC - 40 MHz | DC - 40 MHz | DC - 40 MHz | DC - 40 MHz | | Program Memory (Bytes) | 16K | 32K | 16K | 32K | | Program Memory (Instructions) | 8192 | 16384 | 8192 | 16384 | | Data Memory (Bytes) | 512 | 1536 | 512 | 1536 | | Interrupt Sources | 16 | 16 | 17 | 17 | | I/O Ports | Ports A, B, C | Ports A, B, C | Ports A, B, C, D, E | Ports A, B, C, D, E | | Timers | 4 | 4 | 4 | 4 | | Capture/Compare/PWM Modules | 2 | 2 | 2 | 2 | | Serial Communications | MSSP,<br>Addressable<br>USART | MSSP,<br>Addressable<br>USART | MSSP,<br>Addressable<br>USART | MSSP,<br>Addressable<br>USART | | Parallel Communications | _ | _ | PSP | PSP | | 10-bit Analog-to-Digital Module | 5 input channels | 5 input channels | 8 input channels | 8 input channels | | RESETS (and Delays) | POR, BOR,<br>RESET Instruction,<br>Stack Full,<br>Stack Underflow<br>(PWRT, OST) | POR, BOR,<br>RESET Instruction,<br>Stack Full,<br>Stack Underflow<br>(PWRT, OST) | POR, BOR,<br>RESET Instruction,<br>Stack Full,<br>Stack Underflow<br>(PWRT, OST) | POR, BOR,<br>RESET Instruction,<br>Stack Full,<br>Stack Underflow<br>(PWRT, OST) | | Programmable Low Voltage<br>Detect | Yes | Yes | Yes | Yes | | Programmable Brown-out Reset | Yes | Yes | Yes | Yes | | Instruction Set | 75 Instructions | 75 Instructions | 75 Instructions | 75 Instructions | | Packages | 28-pin DIP<br>28-pin SOIC<br>28-pin JW | 28-pin DIP<br>28-pin SOIC<br>28-pin JW | 40-pin DIP<br>44-pin PLCC<br>44-pin TQFP<br>40-pin JW | 40-pin DIP<br>44-pin PLCC<br>44-pin TQFP<br>40-pin JW | FIGURE 1-1: PIC18C2X2 BLOCK DIAGRAM 3: Many of the general purpose I/O pins are multiplexed with one or more peripheral module functions. The multiplexing combinations are device dependent. FIGURE 1-2: PIC18C4X2 BLOCK DIAGRAM Data Bus<8> **PORTA** RA0/AN0 Data Latch Table Pointer <2> RA1/AN1 RA2/AN2/VRFF-Data RAM 8 (up to 4K RA3/AN3/VREF+ inc/dec logic address reach) RA4/T0CKI 21 RA5/AN4/SS/LVDIN Address Latch RA6 PCLATU PCLATH 12(2) Address Latch Program Memory (up to 2M Bytes) Address<12> PCU PCH PCL **PORTB** Program Counter 12 4 Data Latch BSR Bank0, F <del>2</del> + } FSR0 RB0/INT0 FSR1 31 Level Stack RB1/INT1 FSR2 12 RB2/INT2 RB3/CCP2<sup>(1)</sup> 16 inc/dec RB7:RB4 Decode logic Table Latch **∦**8 **PORTC** ROM Latch RC0/T1OSO/T1CKI RC1/T1OSI/CCP2(1) RC2/CCP1 Instruction Register RC3/SCK/SCL RC4/SDI/SDA 8 RC5/SDO Instruction RC6/TX/CK Decode & Control RC7/RX/DT PRODH PRODL OSC2/CLKO OSC1/CLKI 8 x 8 Multiply Power-up **PORTD** $\boxtimes \subseteq$ Timer RD0/PSP0 Timing Generation Oscillator RD1/PSP1 BIT OP WREG Start-up Timer RD2/PSP2 T10SI T10SO RD3/PSP3 Power-on RD4/PSP4 Reset RD5/PSP5 Watchdog 4X PLL RD6/PSP6 ALU<sup>v</sup><8: Timer RD7/PSP7 8 Precision Brown-out **PORTE** Voltage Reference Reset RE0/AN5/RD MCLR RE1/AN6/WR VDD, VSS RE2/AN7/CS A/D Converter Timer0 Timer1 Timer2 Timer3 ŢĹ Щ Щ Master Addressable CCP1 Synchronous CCP2 Parallel Slave Port USART Serial Port 1: Optional multiplexing of CCP2 input/output with RB3 is enabled by selection of configuration bit. Note 2: The high order bits of the Direct Address for the RAM are from the BSR register (except for the MOVFF instruction). Many of the general purpose I/O pins are multiplexed with one or more peripheral module functions. The multiplexing combinations PIC18C2X2 PINOUT I/O DESCRIPTIONS **TABLE 1-2:** | Pin Name | Pin Number | | Pin | Buffer | Description | |----------------------|------------|------|------|--------------|-------------------------------------------------------------------------------------------------| | Till Name | DIP | SOIC | Туре | Туре | Description | | MCLR/VPP | 1 | 1 | | | Master clear (input) or programming voltage (input). | | MCLR | | | ı | ST | Master Clear (Reset) input. This pin is an active low RESET to the device. | | VPP | | | Р | | Programming voltage input. | | NC | l | | | _ | These pins should be left unconnected. | | OSC1/CLKI | 9 | 9 | | | Oscillator crystal or external clock input. | | OSC1 | | | - 1 | ST | Oscillator crystal input or external clock source input. | | 01.14 | | | | 01400 | ST buffer when configured in RC mode. CMOS otherwise. | | CLKI | | | ı | CMOS | External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKIN, | | | | | | | OSC2/CLKOUT pins.) | | OSC2/CLKO/RA6 | 10 | 10 | | | Oscillator crystal or clock output. | | OSC2 | | | 0 | _ | Oscillator crystal output. Connects to crystal or | | | | | | | resonator in Crystal Oscillator mode. | | CLKO | | | 0 | _ | In RC mode, OSC2 pin outputs CLKOUT which has 1/4 | | | | | | | the frequency of OSC1, and denotes the instruction | | RA6 | | | I/O | TTL | cycle rate.<br>General Purpose I/O pin. | | nao | | | 1/0 | IIL | · · · · · · · · · · · · · · · · · · · | | RA0/AN0 | 2 | 2 | | | PORTA is a bi-directional I/O port. | | RAO/ANO | 2 | 2 | I/O | TTL | Digital I/O. | | AN0 | | | ı, O | Analog | Analog input 0. | | RA1/AN1 | 3 | 3 | | J | | | RA1 | | | I/O | TTL | Digital I/O. | | AN1 | | | - 1 | Analog | Analog input 1. | | RA2/AN2/VREF- | 4 | 4 | | | | | RA2 | | | I/O | TTL | Digital I/O. | | AN2 | | | | Analog | Analog input 2. | | VREF- | _ | _ | ' | Analog | A/D Reference Voltage (Low) input. | | RA3/AN3/VREF+<br>RA3 | 5 | 5 | I/O | TTL | Digital I/O. | | AN3 | | | 1/0 | Analog | Analog input 3. | | VREF+ | | | i | Analog | A/D Reference Voltage (High) input. | | RA4/T0CKI | 6 | 6 | | J | | | RA4 | - | | I/O | ST/OD | Digital I/O. Open drain when configured as output. | | T0CKI | | | - 1 | ST | Timer0 external clock input. | | RA5/AN4/SS/LVDIN | 7 | 7 | | | | | RA5 | | | I/O | TTL | Digital I/O. | | AN4 | | | | Analog | Analog input 4. | | SS<br>LVDIN | | | | ST<br>Analog | SPI Slave Select input. Low Voltage Detect Input. | | | | | ' | Alialog | See the OSC2/CLKO/RA6 pin. | | RA6 | | | | | See the USUZ/ULNU/NAO pm. | CMOS = CMOS compatible input or output O = Output P = Power **TABLE 1-2:** PIC18C2X2 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Number | | Pin Buffer | | Dogovintion | | | |------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | DIP | SOIC | Туре | Туре | Description | | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | | | 21 | 21 | | | | | | | | | I/O | TTL | Digital I/O. | | | | | | I | ST | External Interrupt 0. | | | | 22 | 22 | | | | | | | | | I/O | | | | | | | | I | ST | External Interrupt 1. | | | | 23 | 23 | | | | | | | | | 1/0 | | Digital I/O. | | | | | | ı | SI | External Interrupt 2. | | | | 24 | 24 | | | B: :: 11/0 | | | | | | | | Digital I/O. | | | | 0.5 | 0.5 | | | Capture2 input, Compare2 output, PWM2 output. | | | | 25 | 25 | I/O | IIL | Digital I/O. | | | | 00 | 00 | 1/0 | TT: | Interrupt-on-change pin. | | | | 26 | 26 | 1/0 | IIL | Digital I/O. | | | | 07 | 07 | | TT: | Interrupt-on-change pin. | | | | 27 | 27 | 1/0 | IIL | Digital I/O. | | | | | | | ст | Interrupt-on-change pin. ICSP programming clock. | | | | 20 | 20 | 1/0 | _ | | | | | ∠ŏ | ∠δ | 1/0 | IIL | Digital I/O. Interrupt-on-change pin. | | | | | | 1/0 | ST | ICSP programming data. | | | | | <b>DIP</b> 21 | DIP SOIC 21 21 22 22 23 23 24 24 25 25 26 26 27 27 | DIP SOIC Type 21 21 | DIP SOIC Type Type 21 21 I/O TTL ST 22 22 I/O TTL ST 23 23 I/O TTL ST 24 24 I/O ST 25 25 I/O TTL 26 26 I/O TTL 27 27 I/O TTL 28 28 I/O TTL | | | CMOS = CMOS compatible input or output P = Power O = Output **TABLE 1-2:** PIC18C2X2 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pin N | umber | Pin | Buffer | Docavintian | | |-----------------|-------|-------|------|--------|------------------------------------------------------------------|--| | Pin Name | DIP | SOIC | Туре | Туре | Description | | | | | | | | PORTC is a bi-directional I/O port. | | | RC0/T1OSO/T1CKI | 11 | 11 | | | | | | RC0 | | | I/O | ST | Digital I/O. | | | T1OSO | | | 0 | _ | Timer1 oscillator output. | | | T1CKI | | | - 1 | ST | Timer1/Timer3 external clock input. | | | RC1/T1OSI/CCP2 | 12 | 12 | | | | | | RC1 | | | I/O | ST | Digital I/O. | | | T1OSI | | | - 1 | CMOS | Timer1 oscillator input. | | | CCP2 | | | I/O | ST | Capture2 input, Compare2 output, PWM2 output. | | | RC2/CCP1 | 13 | 13 | | | | | | RC2 | | | I/O | ST | Digital I/O. | | | CCP1 | | | I/O | ST | Capture1 input/Compare1 output/PWM1 output. | | | RC3/SCK/SCL | 14 | 14 | | | | | | RC3 | | | I/O | ST | Digital I/O. | | | SCK | | | I/O | ST | Synchronous serial clock input/output for SPI mode. | | | SCL | | | I/O | ST | Synchronous serial clock input/output for I <sup>2</sup> C mode. | | | RC4/SDI/SDA | 15 | 15 | | | | | | RC4 | | | I/O | ST | Digital I/O. | | | SDI | | | - 1 | ST | SPI Data In. | | | SDA | | | I/O | ST | I <sup>2</sup> C Data I/O. | | | RC5/SDO | 16 | 16 | | | | | | RC5 | | | I/O | ST | Digital I/O. | | | SDO | | | 0 | _ | SPI Data Out. | | | RC6/TX/CK | 17 | 17 | | | | | | RC6 | | | I/O | ST | Digital I/O. | | | TX | | | 0 | _ | USART Asynchronous Transmit. | | | CK | | | I/O | ST | USART Synchronous Clock (see related RX/DT). | | | RC7/RX/DT | 18 | 18 | | | | | | RC7 | | | I/O | ST | Digital I/O. | | | RX | | | - 1 | ST | USART Asynchronous Receive. | | | DT | | | I/O | ST | USART Synchronous Data (see related TX/CK). | | | Vss | 8, 19 | 8, 19 | Р | _ | Ground reference for logic and I/O pins. | | | VDD | 20 | 20 | Р | | Positive supply for logic and I/O pins. | | P = Power ST = Schmitt Trigger input with CMOS levels I = Input O = Output OD = Open Drain (no P diode to VDD) CMOS = CMOS compatible input or output TABLE 1-3: PIC18C4X2 PINOUT I/O DESCRIPTIONS | Dia Nama | Pi | n Numb | er | Pin | Buffer | D | | |-----------------------------------------------|-----|--------|------|-----------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Pin Name | DIP | PLCC | TQFP | Туре | Type | Description | | | MCLR/VPP<br>MCLR | 1 | 2 | 18 | I | ST | Master clear (input) or programming voltage (input). Master Clear (Reset) input. This pin is an active low RESET to the device. | | | VPP | | | | Р | | Programming voltage input. | | | NC | _ | | | _ | _ | These pins should be left unconnected. | | | OSC1/CLKI<br>OSC1 | 13 | 14 | 30 | _ | ST | Oscillator crystal or external clock input. Oscillator crystal input or external clock source input. ST buffer when configured in RC mode, CMOS otherwise. | | | CLKI | | | | I | CMOS | External clock source input. Always associated with pin function OSC1. (See related OSC1/CLKIN, OSC2/CLKOUT pins.) | | | OSC2/CLKO/RA6<br>OSC2 | 14 | 15 | 31 | 0 | _ | Oscillator crystal output. Oscillator crystal output. Connects to crystal | | | CLKO | | | | 0 | _ | or resonator in Crystal Oscillator mode. In RC mode, OSC2 pin outputs CLKOUT, which has 1/4 the frequency of OSC1 and denotes the instruction | | | RA6 | | | | I/O | TTL | cycle rate.<br>General Purpose I/O pin. | | | | | | | | | PORTA is a bi-directional I/O port. | | | RA0/AN0<br>RA0<br>AN0 | 2 | 3 | 19 | I/O<br>I | TTL<br>Analog | Digital I/O. Analog input 0. | | | RA1/AN1<br>RA1<br>AN1 | 3 | 4 | 20 | I/O<br>I | TTL<br>Analog | Digital I/O. Analog input 1. | | | RA2/AN2/VREF-<br>RA2<br>AN2 | 4 | 5 | 21 | I/O<br> | TTL<br>Analog | Digital I/O. Analog input 2. | | | VREF-<br>RA3/AN3/VREF+<br>RA3<br>AN3 | 5 | 6 | 22 | I/O<br>I | Analog<br>TTL<br>Analog | A/D Reference Voltage (Low) input. Digital I/O. Analog input 3. | | | VREF+<br>RA4/T0CKI<br>RA4 | 6 | 7 | 23 | I/O | Analog<br>ST/OD | A/D Reference Voltage (High) input. Digital I/O. Open drain when configured as output. | | | T0CKI | | | | -1 | ST | Timer0 external clock input. | | | RA5/AN4/SS/LVDIN<br>RA5<br>AN4<br>SS<br>LVDIN | 7 | 8 | 24 | I/O<br> -<br> - | TTL<br>Analog<br>ST<br>Analog | Digital I/O. Analog input 4. SPI Slave Select input. Low Voltage Detect Input. | | | RA6 | | | | ' | Allalog | See the OSC2/CLKO/RA6 pin. | | | Lagandi TTI TTI | | | | | CM | · | | CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input P = Power O = Output TABLE 1-3: PIC18C4X2 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pi | n Numb | er | Pin | Buffer | Description | |-------------------------|-----|--------|------|------------|-----------|----------------------------------------------------------------------------------------------------------------| | Pili Naille | DIP | PLCC | TQFP | Туре | Type | Description | | | | | | | | PORTB is a bi-directional I/O port. PORTB can be software programmed for internal weak pull-ups on all inputs. | | RB0/INT0<br>RB0<br>INT0 | 33 | 36 | 8 | I/O<br>I | TTL<br>ST | Digital I/O. External Interrupt 0. | | RB1/INT1<br>RB1<br>INT1 | 34 | 37 | 9 | I/O<br>I | TTL<br>ST | External Interrupt 1. | | RB2/INT2<br>RB2<br>INT2 | 35 | 38 | 10 | I/O<br>I | TTL<br>ST | Digital I/O.<br>External Interrupt 2. | | RB3/CCP2<br>RB3<br>CCP2 | 36 | 39 | 11 | I/O<br>I/O | TTL<br>ST | Digital I/O. Capture2 input, Compare2 output, PWM2 output. | | RB4 | 37 | 41 | 14 | I/O | TTL | Digital I/O. Interrupt-on-change pin. | | RB5 | 38 | 42 | 15 | I/O | TTL | Digital I/O. Interrupt-on-change pin. | | RB6 | 39 | 43 | 16 | I/O<br>I | TTL<br>ST | Digital I/O. Interrupt-on-change pin. ICSP programming clock. | | RB7 | 40 | 44 | 17 | I/O<br>I/O | TTL<br>ST | Digital I/O. Interrupt-on-change pin. ICSP programming data. | CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input O = Output P = Power **TABLE 1-3:** PIC18C4X2 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin | | Pin Number | | Pin Buffer | Description | | |-----------------|-----|------------|------|------------|-------------|-----------------------------------------------| | Pin Name | DIP | PLCC | TQFP | Туре | Type | Description | | | | | | | | PORTC is a bi-directional I/O port. | | RC0/T1OSO/T1CKI | 15 | 16 | 32 | | | | | RC0 | | | | I/O | ST | Digital I/O. | | T1OSO | | | | 0 | | Timer1 oscillator output. | | T1CKI | | | | ı | ST | Timer1/Timer3 external clock input. | | RC1/T1OSI/CCP2 | 16 | 18 | 35 | | | | | RC1 | | | | I/O | ST | Digital I/O. | | T1OSI | | | | - 1 | CMOS | Timer1 oscillator input. | | CCP2 | | | | I/O | ST | Capture2 input, Compare2 output, PWM2 output. | | RC2/CCP1 | 17 | 19 | 36 | | | | | RC2 | | | | I/O | ST | Digital I/O. | | CCP1 | | | | I/O | ST | Capture1 input/Compare1 output/PWM1 output. | | RC3/SCK/SCL | 18 | 20 | 37 | | | | | RC3 | | | | I/O | ST | Digital I/O. | | SCK | | | | I/O | ST | Synchronous serial clock input/output for | | | | | | | | SPI mode. | | SCL | | | | I/O | ST | Synchronous serial clock input/output for | | | | | | | | I <sup>2</sup> C mode. | | RC4/SDI/SDA | 23 | 25 | 42 | | | | | RC4 | | | | I/O | ST | Digital I/O. | | SDI | | | | - 1 | ST | SPI Data In. | | SDA | | | | I/O | ST | I <sup>2</sup> C Data I/O. | | RC5/SDO | 24 | 26 | 43 | | | | | RC5 | | | | I/O | ST | Digital I/O. | | SDO | | | | 0 | _ | SPI Data Out. | | RC6/TX/CK | 25 | 27 | 44 | | | | | RC6 | | | | I/O | ST | Digital I/O. | | TX | | | | 0 | _ | USART Asynchronous Transmit. | | CK | | | | I/O | ST | USART Synchronous Clock (see related RX/DT). | | RC7/RX/DT | 26 | 29 | 1 | | | | | RC7 | | | | I/O | ST | Digital I/O. | | RX | | | | - 1 | ST | USART Asynchronous Receive. | | DT | | | | I/O | ST | USART Synchronous Data (see related TX/CK). | CMOS = CMOS compatible input or output O = Output OD = Open Drain (no P diode to VDD) P = Power TABLE 1-3: PIC18C4X2 PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name | Pi | n Numb | er | Pin | Buffer | Description | |--------------------------|--------|--------|-------|------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Fill Name | DIP | PLCC | TQFP | Туре | Type | Description | | | | | | | | PORTD is a bi-directional I/O port, or a Parallel Slave Port (PSP) for interfacing to a microprocessor port. These pins have TTL input buffers when PSP module is enabled. | | RD0/PSP0 | 19 | 21 | 38 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD1/PSP1 | 20 | 22 | 39 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD2/PSP2 | 21 | 23 | 40 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD3/PSP3 | 22 | 24 | 41 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD4/PSP4 | 27 | 30 | 2 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD5/PSP5 | 28 | 31 | 3 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD6/PSP6 | 29 | 32 | 4 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RD7/PSP7 | 30 | 33 | 5 | I/O | ST<br>TTL | Digital I/O.<br>Parallel Slave Port Data. | | RE0/RD/AN5<br>RE0<br>RD | 8 | 9 | 25 | I/O | ST<br>TTL | PORTE is a bi-directional I/O port. Digital I/O. Read control for parallel slave port (see also WR | | AN5<br>RE1/WR/AN6<br>RE1 | 9 | 10 | 26 | I/O | Analog<br>ST | and $\overline{CS}$ pins). Analog input 5. Digital I/O. | | WR | | | | | TTL | Write control for parallel slave port (see $\overline{\text{CS}}$ and $\overline{\text{RD}}$ pins). | | AN6<br>RE2/CS/AN7<br>RE2 | 10 | 11 | 27 | I/O | Analog<br>ST | Analog input 6. Digital I/O. | | CS | | | | | TTL | Chip Select control for parallel slave port (see related RD and WR). | | AN7 | 10.04 | 10.01 | 0.00 | | Analog | Analog input 7. | | Vss | | 13, 34 | 6, 29 | P - | _ | Ground reference for logic and I/O pins. | | VDD | 11, 32 | 12, 35 | 7, 28 | Р | _ | Positive supply for logic and I/O pins. | CMOS = CMOS compatible input or output ST = Schmitt Trigger input with CMOS levels I = Input P = Power O = Output on Drain (no D diada ta VDD) # 2.0 OSCILLATOR CONFIGURATIONS ### 2.1 Oscillator Types The PIC18CXX2 can be operated in eight different oscillator modes. The user can program three configuration bits (FOSC2, FOSC1, and FOSC0) to select one of these eight modes: | 1. | LP | Low Power Crystal | |----|----------|------------------------------------------------------| | 2. | XT | Crystal/Resonator | | 3. | HS | High Speed Crystal/Resonator | | 4. | HS + PLL | High Speed Crystal/Resonator with x 4 PLL enabled | | 5. | RC | External Resistor/Capacitor | | 6. | RCIO | External Resistor/Capacitor with RA6 I/O pin enabled | | 7. | EC | External Clock | | 8. | ECIO | External Clock with RA6 I/O pin enabled | ## 2.2 Crystal Oscillator/Ceramic Resonators In XT, LP, HS or HS-PLL oscillator modes, a crystal or ceramic resonator is connected to the OSC1 and OSC2 pins to establish oscillation. Figure 2-1 shows the pin connections. The PIC18CXX2 oscillator design requires the use of a parallel cut crystal. **Note:** Use of a series cut crystal may give a frequency out of the crystal manufacturers specifications. # FIGURE 2-1: CRYSTAL/CERAMIC RESONATOR OPERATION (HS, XT OR LP OSC CONFIGURATION) Note 1: See Table 2-1 and Table 2-2 for recommended values of C1 and C2. - 2: A series resistor (Rs) may be required for AT strip cut crystals. - 3: RF varies with the osc mode chosen. TABLE 2-1: CAPACITOR SELECTION FOR CERAMIC RESONATORS | Ranges Tested: | | | | | | | | | |----------------|-----------------------------------------|-------------------------|-------------|--|--|--|--|--| | Mode | Freq | C2 | | | | | | | | XT | 455 kHz | 68 - 100 pF | 68 - 100 pF | | | | | | | | 2.0 MHz | 15 - 68 pF | 15 - 68 pF | | | | | | | | 4.0 MHz | 15 - 68 pF | 15 - 68 pF | | | | | | | HS | 8.0 MHz | 10 - 68 pF | 10 - 68 pF | | | | | | | | 16.0 MHz | 10 - 22 pF | 10 - 22 pF | | | | | | | | <b>les are for de</b><br>following this | sign guidance<br>table. | only. | | | | | | | | Resona | itors Used: | | | | | | | | 455 kHz | Panasonic E | FO-A455K04B | ± 0.3% | | | | | | | 2.0 MHz | Murata Erie | CSA2.00MG | ± 0.5% | | | | | | | 4.0 MHz | Murata Erie CSA4.00MG ± 0.5% | | | | | | | | | 8.0 MHz | Murata Erie CSA8.00MT ± 0.5% | | | | | | | | | 16.0 MHz | Murata Erie | CSA16.00MX | ± 0.5% | | | | | | | All resonat | ors used did r | ot have built-in | capacitors. | | | | | | - **Note 1:** Higher capacitance increases the stability of the oscillator, but also increases the start-up time. - 2: When operating below 3V VDD, it may be necessary to use high gain HS mode on lower frequency ceramic resonators. - **3:** Since each resonator/crystal has its own characteristics, the user should consult the resonator/crystal manufacturer for appropriate values of external components or verify oscillator performance. TABLE 2-2: CAPACITOR SELECTION FOR CRYSTAL OSCILLATORS | Ranges Tested: | | | | |----------------|-------------|----------|----------| | Mode | Freq | C1 | C2 | | LP | 32.0 kHz | 33 pF | 33 pF | | | 200 kHz | 15 pF | 15 pF | | XT | 200 kHz | 47-68 pF | 47-68 pF | | | 1.0 MHz | 15 pF | 15 pF | | | 4.0 MHz | 15 pF | 15 pF | | HS | 4.0 MHz | 15 pF | 15 pF | | | 8.0 MHz | 15-33 pF | 15-33 pF | | | 20.0<br>MHz | 15-33 pF | 15-33 pF | | | 25.0<br>MHz | 15-33 pF | 15-33 pF | These values are for design guidance only. See notes following this table. | coo notes renoving the table. | | | | |-------------------------------|------------------------|----------|--| | Crystals Used | | | | | 32.0 kHz | Epson C-001R32.768K-A | ± 20 PPM | | | 200 kHz | STD XTL 200.000kHz | ± 20 PPM | | | 1.0 MHz | ECS ECS-10-13-1 | ± 50 PPM | | | 4.0 MHz | ECS ECS-40-20-1 | ± 50 PPM | | | 8.0 MHz | Epson CA-301 8.000M-C | ± 30 PPM | | | 20.0 MHz | Epson CA-301 20.000M-C | ± 30 PPM | | - **Note 1:** Higher capacitance increases the stability of the oscillator, but also increases the start-up time. - 2: Rs may be required in HS mode, as well as XT mode, to avoid overdriving crystals with low drive level specification. - **3:** Since each resonator/crystal has its own characteristics, the user should consult the resonator/crystal manufacturer for appropriate values of external components or verify oscillator performance. An external clock source may also be connected to the OSC1 pin in these modes, as shown in Figure 2-2. FIGURE 2-2: EXTERNAL CLOCK INPUT OPERATION (HS, XT OR LP CONFIGURATION) #### 2.3 RC Oscillator For timing insensitive applications, the "RC" and "RCIO" device options offer additional cost savings. The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values and the operating temperature. In addition to this, the oscillator frequency will vary from unit to unit due to normal process parameter variation. Furthermore, the difference in lead frame capacitance between package types will also affect the oscillation frequency, especially for low CEXT values. The user also needs to take into account variation due to tolerance of external R and C components used. Figure 2-3 shows how the R/C combination is connected. In the RC oscillator mode, the oscillator frequency divided by 4 is available on the OSC2 pin. This signal may be used for test purposes or to synchronize other logic. FIGURE 2-3: RC OSCILLATOR MODE The RCIO oscillator mode functions like the RC mode, except that the OSC2 pin becomes an additional general purpose I/O pin. The I/O pin becomes bit 6 of PORTA (RA6). ### 2.4 External Clock Input The EC and ECIO oscillator modes require an external clock source to be connected to the OSC1 pin. The feedback device between OSC1 and OSC2 is turned off in these modes to save current. There is no oscillator start-up time required after a Power-on Reset or after a recovery from SLEEP mode. In the EC oscillator mode, the oscillator frequency divided by 4 is available on the OSC2 pin. This signal may be used for test purposes or to synchronize other logic. Figure 2-4 shows the pin connections for the EC oscillator mode. FIGURE 2-4: EXTERNAL CLOCK INPUT OPERATION (EC OSC CONFIGURATION) The ECIO oscillator mode functions like the EC mode, except that the OSC2 pin becomes an additional general purpose I/O pin. The I/O pin becomes bit 6 of PORTA (RA6). Figure 2-5 shows the pin connections for the ECIO oscillator mode. FIGURE 2-5: EXTERNAL CLOCK INPUT OPERATION (ECIO CONFIGURATION) ### 2.5 HS/PLL A Phase Locked Loop circuit is provided as a programmable option for users that want to multiply the frequency of the incoming crystal oscillator signal by 4. For an input clock frequency of 10 MHz, the internal clock frequency will be multiplied to 40 MHz. This is useful for customers who are concerned with EMI due to high frequency crystals. The PLL can only be enabled when the oscillator configuration bits are programmed for HS mode. If they are programmed for any other mode, the PLL is not enabled and the system clock will come directly from OSC1. The PLL is one of the modes of the FOSC<2:0> configuration bits. The oscillator mode is specified during device programming. A PLL lock timer is used to ensure that the PLL has locked before device execution starts. The PLL lock timer has a time-out that is called TPLL. FIGURE 2-6: PLL BLOCK DIAGRAM ### 2.6 Oscillator Switching Feature The PIC18CXX2 devices include a feature that allows the system clock source to be switched from the main oscillator to an alternate low frequency clock source. For the PIC18CXX2 devices, this alternate clock source is the Timer1 oscillator. If a low frequency crystal (32 kHz, for example) has been attached to the Timer1 oscillator pins and the Timer1 oscillator has been enabled, the device can switch to a low power execution mode. Figure 2-7 shows a block diagram of the system clock sources. The clock switching feature is enabled by programming the Oscillator Switching Enable (OSCSEN) bit in Configuration Register1H to a '0'. Clock switching is disabled in an erased device. See Section 9.0 for further details of the Timer1 oscillator. See Section 18.0 for Configuration Register details. FIGURE 2-7: DEVICE CLOCK SOURCES #### 2.6.1 SYSTEM CLOCK SWITCH BIT The system clock source switching is performed under software control. The system clock switch bit, SCS (OSCCON<0>) controls the clock switching. When the SCS bit is'0', the system clock source comes from the main oscillator that is selected by the FOSC configuration bits in Configuration Register1H. When the SCS bit is set, the system clock source will come from the Timer1 oscillator. The SCS bit is cleared on all forms of RESET. The Timer1 oscillator must be enabled and operating to switch the system clock source. The Timer1 oscillator is enabled by setting the T1OSCEN bit in the Timer1 control register (T1CON). If the Timer1 oscillator is not enabled, then any write to the SCS bit will be ignored (SCS bit forced cleared) and the main oscillator will continue to be the system clock source. ### REGISTER 2-1: OSCCON REGISTER | U-0 R/W-1 | |-------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | - | _ | SCS | | bit 7 | • | | • | • | • | • | bit 0 | Note: ### bit 7-1 Unimplemented: Read as '0' bit 0 SCS: System Clock Switch bit When OSCSEN configuration bit = '0' and T1OSCEN bit is set: - 1 = Switch to Timer1 oscillator/clock pin - 0 = Use primary oscillator/clock input pin When OSCSEN and T1OSCEN are in other states: bit is forced clear | Legend: | | | | |--------------------------|------------------|----------------------|--------------------| | R = Readable bit | W = Writable bit | U = Unimplemented | l bit, read as '0' | | - n = Value at POR reset | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | #### 2.6.2 OSCILLATOR TRANSITIONS The PIC18CXX2 devices contain circuitry to prevent "glitches" when switching between oscillator sources. Essentially, the circuitry waits for eight rising edges of the clock source that the processor is switching to. This ensures that the new clock source is stable and that it's pulse width will not be less than the shortest pulse width of the two clock sources. A timing diagram indicating the transition from the main oscillator to the Timer1 oscillator is shown in Figure 2-8. The Timer1 oscillator is assumed to be running all the time. After the SCS bit is set, the processor is frozen at the next occurring Q1 cycle. After eight synchronization cycles are counted from the Timer1 oscillator, operation resumes. No additional delays are required after the synchronization cycles. FIGURE 2-8: TIMING DIAGRAM FOR TRANSITION FROM OSC1 TO TIMER1 OSCILLATOR The sequence of events that takes place when switching from the Timer1 oscillator to the main oscillator will depend on the mode of the main oscillator. In addition to eight clock cycles of the main oscillator, additional delays may take place. If the main oscillator is configured for an external crystal (HS, XT, LP), then the transition will take place after an oscillator start-up time (TOST) has occurred. A timing diagram indicating the transition from the Timer1 oscillator to the main oscillator for HS, XT and LP modes is shown in Figure 2-9. If the main oscillator is configured for HS-PLL mode, an oscillator start-up time (TOST) plus an additional PLL time-out (TPLL) will occur. The PLL time-out is typically 2 ms and allows the PLL to lock to the main oscillator frequency. A timing diagram, indicating the transition from the Timer1 oscillator to the main oscillator for HS-PLL mode, is shown in Figure 2-10. FIGURE 2-10: TIMING FOR TRANSITION BETWEEN TIMER1 AND OSC1 (HS WITH PLL) If the main oscillator is configured in the RC, RCIO, EC or ECIO modes, there is no oscillator start-up time-out. Operation will resume after eight cycles of the main oscillator have been counted. A timing diagram, indi- cating the transition from the Timer1 oscillator to the main oscillator for RC, RCIO, EC and ECIO modes, is shown in Figure 2-11. FIGURE 2-11: TIMING FOR TRANSITION BETWEEN TIMER1 AND OSC1 (RC, EC) # 2.7 Effects of SLEEP Mode on the On-chip Oscillator When the device executes a SLEEP instruction, the on-chip clocks and oscillator are turned off and the device is held at the beginning of an instruction cycle (Q1 state). With the oscillator off, the OSC1 and OSC2 signals will stop oscillating. Since all the transistor switching currents have been removed, SLEEP mode achieves the lowest current consumption of the device (only leakage currents). Enabling any on-chip feature that will operate during SLEEP will increase the current consumed during SLEEP. The user can wake from SLEEP through external RESET, Watchdog Timer Reset, or through an interrupt. TABLE 2-3: OSC1 AND OSC2 PIN STATES IN SLEEP MODE | OSC Mode | OSC1 Pin | OSC2 Pin | | |----------------|--------------------------------------------------------|--------------------------------------------------------|--| | RC | Floating, external resistor should pull high | At logic low | | | RCIO | Floating, external resistor should pull high | Configured as PORTA, bit 6 | | | ECIO | Floating | Configured as PORTA, bit 6 | | | EC | Floating | At logic low | | | LP, XT, and HS | Feedback inverter disabled, at quiescent voltage level | Feedback inverter disabled, at quiescent voltage level | | Note: See Table 3-1, in Section 3.0 RESET, for time-outs due to SLEEP and MCLR Reset. ### 2.8 Power-up Delays Power up delays are controlled by two timers, so that no external RESET circuitry is required for most applications. The delays ensure that the device is kept in RESET until the device power supply and clock are stable. For additional information on RESET operation, see the "RESET" section. The first timer is the Power-up Timer (PWRT), which optionally provides a fixed delay of 72 ms (nominal) on power-up only (POR and BOR). The second timer is the Oscillator Start-up Timer, OST, intended to keep the chip in RESET until the crystal oscillator is stable. With the PLL enabled (HS/PLL oscillator mode), the time-out sequence following a Power-on Reset is different from other oscillator modes. The time-out sequence is as follows: First, the PWRT time-out is invoked after a POR time delay has expired. Then, the Oscillator Start-up Timer (OST) is invoked. However, this is still not a sufficient amount of time to allow the PLL to lock at high frequencies. The PWRT timer is used to provide an additional fixed 2ms (nominal) time-out to allow the PLL ample time to lock to the incoming clock frequency. **NOTES:** #### 3.0 RESET The PIC18CXX2 differentiates between various kinds of RESET: - Power-on Reset (POR) - MCLR Reset during normal operation - MCLR Reset during SLEEP - Watchdog Timer (WDT) Reset (during normal operation) - Programmable Brown-out Reset (BOR) - f) **RESET Instruction** - Stack Full Reset - Stack Underflow Reset h) Most registers are unaffected by a RESET. Their status is unknown on POR and unchanged by all other RESETS. The other registers are forced to a "RESET state" on Power-on Reset, MCLR, WDT Reset, Brownout Reset, MCLR Reset during SLEEP, and by the RESET instruction. Most registers are not affected by a WDT wake-up, since this is viewed as the resumption of normal operation. Status bits from the RCON register, RI, TO, PD, POR and BOR, are set or cleared differently in different RESET situations, as indicated in Table 3-2. These bits are used in software to determine the nature of the RESET. See Table 3-3 for a full description of the RESET states of all registers. A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 3-1. The Enhanced MCU devices have a MCLR noise filter in the MCLR Reset path. The filter will detect and ignore small pulses. MCLR pin is not driven low by any internal RESETS, including WDT. FIGURE 3-1: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT