# PIC16F18015/25/44/45 # PIC16F18015/25/44/45 Full-Featured, 8/14/20-Pin Microcontrollers # Introduction The PIC16F180 microcontroller family has a suite of digital and analog peripherals that enable cost-sensitive sensor and real-time control applications. This product family is available from 8 to 44-pin packages in a memory range of 3.5 KB to 28 KB, with speeds up to 32 MHz. The family includes a 10-bit Analog-to-Digital Converter with Computation (ADCC), automated Capacitive Voltage Divider (CVD) techniques for advanced capacitive touch sensing, an 8-bit Digital-to-Analog Converter (DAC) module, and many more waveform control and communication peripherals. This small form factor, feature-rich device is well suited for low-cost sensor and control applications. # PIC16F180 Family Summary Table 1. Devices Included in This Data Sheet | Device | Program Flash Memory<br>(bytes) | Data Flash Memory (EEPROM)(bytes) | Data SRAM<br>(bytes) | Memory Access Partition/<br>Device Information Area | I/O Pins <sup>(1)</sup> /<br>Peripheral Pin Select | 8-Bit Timers with HLT/<br>16-Bit Timers <sup>(2)</sup> | 10-Bit PWM/<br>CCP | 10-Bit ADC Channels<br>(External/Internal) | Charge Pump | l <sup>2</sup> C/SPI | EUSART | NCO | cwg | CLC | FVR | CMP | 8-bit DAC | ZCD | SMBus Compatible I/O Pads | External Interrupt Pins | Interrupt-on-Change Pins | Watchdog Timer | |-------------|---------------------------------|-----------------------------------|----------------------|-----------------------------------------------------|----------------------------------------------------|--------------------------------------------------------|--------------------|--------------------------------------------|-------------|----------------------|--------|-----|-----|-----|-----|-----|-----------|-----|---------------------------|-------------------------|--------------------------|----------------| | PIC16F18015 | 14k | 128 | 1024 | Y/Y | 6/Y | 3/3 | 3/2 | 5/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 6 | Y | | PIC16F18025 | 14k | 128 | 1024 | Y/Y | 12/Y | 3/3 | 3/2 | 11/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 12 | Υ | | PIC16F18044 | 7k | 128 | 512 | Y/Y | 18/Y | 3/3 | 3/2 | 17/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 18 | Υ | | PIC16F18045 | 14k | 128 | 1024 | Y/Y | 18/Y | 3/3 | 3/2 | 17/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 18 | Υ | Table 2. Devices Not Included in This Data Sheet | Device | Program Flash Memory<br>(bytes) | Data Flash Memory (EEPROM)(bytes) | Data SRAM<br>(bytes) | Memory Access Partition/<br>Device Information Area | I/O Pins <sup>(1)</sup> /<br>Peripheral Pin Select | 8-Bit Timers with HLT/<br>16-Bit Timers <sup>(2)</sup> | 10-Bit PWM/<br>CCP | 10-Bit ADC Channels<br>(External/Internal) | Charge Pump | MSSP | EUSART | NCO | CWG | CLC | FVR | CMP | 8-bit DAC | ZCD | SMBus Compatible I/O Pads | External Interrupt Pins | Interrupt-on-Change Pins | Watchdog Timer | |----------------------|---------------------------------|-----------------------------------|----------------------|-----------------------------------------------------|----------------------------------------------------|--------------------------------------------------------|--------------------|--------------------------------------------|-------------|------|--------|-----|-----|-----|-----|-----|-----------|-----|---------------------------|-------------------------|--------------------------|----------------| | PIC16F18013 | 3.5k | 128 | 256 | Y/Y | 6/Y | 3/3 | 3/2 | 5/4 | 1 | 1 | 1 | 1 | 0 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 6 | Υ | | P <b>I</b> C16F18014 | 7k | 128 | 512 | Y/Y | 6/Y | 3/3 | 3/2 | 5/4 | 1 | 1 | 1 | 1 | 0 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 6 | Υ | | P <b>I</b> C16F18023 | 3.5k | 128 | 256 | Y/Y | 12/Y | 3/3 | 3/2 | 11/4 | 1 | 1 | 1 | 1 | 0 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 12 | Υ | | P <b>I</b> C16F18024 | 7k | 128 | 512 | Y/Y | 12/Y | 3/3 | 3/2 | 11/4 | 1 | 1 | 1 | 1 | 0 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 12 | Υ | | P <b>I</b> C16F18026 | 28k | 256 | 2048 | Y/Y | 12/Y | 3/3 | 3/2 | 11/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 12 | Υ | | P <b>I</b> C16F18046 | 28k | 256 | 2048 | Y/Y | 18/Y | 3/3 | 3/2 | 17/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 18 | Υ | | P <b>I</b> C16F18054 | 7k | 128 | 512 | Y/Y | 25/Y | 3/3 | 3/2 | 24/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Y | | P <b>I</b> C16F18055 | 14k | 128 | 1024 | Y/Y | 25/Y | 3/3 | 3/2 | 24/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Y | | P <b>I</b> C16F18056 | 28k | 256 | 2048 | Y/Y | 25/Y | 3/3 | 3/2 | 24/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Υ | | P <b>I</b> C16F18074 | 7k | 128 | 512 | Y/Y | 36/Y | 3/3 | 3/2 | 35/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Υ | | PIC16F18075 | 14k | 128 | 1024 | Y/Y | 36/Y | 3/3 | 3/2 | 35/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Y | | PIC16F18076 | 28k | 256 | 2048 | Y/Y | 36/Y | 3/3 | 3/2 | 35/4 | 1 | 2 | 2 | 1 | 1 | 4 | 2 | 1 | 1 | 1 | Υ | 1 | 25 | Y | #### Notes: - 1. Total I/O count includes one input-only pin (MCLR). - 2. Timer0 can be configured as either an 8 or 16-bit timer. # **Core Features** - · C Compiler Optimized RISC Architecture - Operating Speed: - DC 32 MHz clock input - 125 ns minimum instruction time - 16-Level Deep Hardware Stack - Low-Current Power-on Reset (POR) - Configurable Power-up Timer (PWRT) - Brown-out Reset (BOR) - Watchdog Timer (WDT) # **Memory** - Up to 28 KB of Program Flash Memory - Up to 2 KB of Data SRAM Memory - Up to 256 Bytes of Data EEPROM Memory - · Memory Access Partition (MAP) with Program Flash Memory Partitioned into: - Application block - Boot block - Storage Area Flash (SAF) block - Programmable Code Protection and Write Protection - · Device Information Area (DIA) Stores: - Fixed Voltage Reference (FVR) measurement data - Microchip Unique Identifier (MUI) - Device Characteristics Area (DCI) Stores: - Program/erase row sizes - Pin count details - · Direct, Indirect, and Relative Addressing Modes # **Operating Characteristics** - · Operating Voltage Range: - 1.8V to 5.5V - · Temperature Range: - Industrial: -40°C to 85°C - Extended: -40°C to 125°C # **Power-Saving Functionality** - Sleep: - Reduce device power consumption - Reduce system electrical noise while performing ADC conversions - Low Power Mode Features: - Sleep: - < 900 nA typical @ 3V/25°C (WDT enabled)</li> - < 600 nA typical @ 3V/25°C (WDT disabled)</li> - Operating current: - 48 µA typical @ 32 kHz, 3V/25°C - < 1 mA typical @ 4 MHz, 5V/25°C</li> # **Digital Peripherals** - Two Capture/Compare/PWM (CCP) Modules: - 16-bit resolution for Capture/Compare modes - 10-bit resolution for Pulse-Width Modulator (PWM) mode - Three Pulse-Width Modulators (PWM): - 10-bit resolution - · Four Configurable Logic Cells (CLC): - Integrated combinational and sequential logic - One Complimentary Waveform Generator (CWG): - Rising and falling edge dead-band control - Full-bridge, half-bridge, and 1-channel drive - Multiple signal sources - Programmable dead band - Fault-shutdown input - One Configurable 8/16-Bit Timer (TMR0) - · Two 16-Bit Timers (TMR1/3) with Gate Control - Three 8-Bit Timers (TMR2/4/6) with Hardware Limit Timer (HLT) - One Numerically Controlled Oscillator (NCO): - Generates true linear frequency control and increased frequency resolution - Input clock up to 64 MHz - Up to Two Enhanced Universal Synchronous Asynchronous Receiver Transmitters (EUSART): - RS-232, RS-485, and LIN compatible - Auto wake-up on Start - Up to Two Host Synchronous Serial Ports (MSSP): - Serial Peripheral Interface (SPI) mode: - · Client select synchronization - Inter-Integrated Circuit (I<sup>2</sup>C) mode: - · 7/10-bit Addressing modes - · Peripheral Pin Select (PPS): - Enables pin mapping of digital I/O - Device I/O Port Features: - Up to 35 I/O pins - One input-only pin - Individual I/O direction, open-drain, input threshold, slew rate, and weak pull-up control - Interrupt-on-Change (IOC) on up to 25 pins - One external interrupt pin # **Analog Peripherals** - Analog-to-Digital Converter with Computation (ADCC): - 10-bit resolution - Up to 35 external input channels - Four internal input channels - Internal ADC oscillator (ADCRC) - Operates in Sleep - Selectable auto-conversion trigger sources - Charge Pump Module: - Improves accuracy of analog modules at low voltages - 8-Bit Digital-to-Analog Converter (DAC): - Output available on one I/O pin - Internal connections to ADC and comparators - One Comparator (CMP): - Up to four external inputs - Configurable output polarity - External output via Peripheral Pin Select - Zero-Cross Detect (ZCD): - Detect when AC signal on pin crosses ground - · Two Fixed Voltage References (FVR): - Selectable 1.024V, 2.048V, and 4.096V output levels - FVR1 internally connected to ADC - FVR2 internally connected to comparator # **Clocking Structure** - High-Precision Internal Oscillator Block (HFINTOSC): - Selectable frequencies up to 32 MHz - ±2% at calibration - Internal 31 kHz Oscillator (LFINTOSC) - External High-Frequency Clock Input: - Two External Clock (EC) Power modes - Secondary Oscillator (SOSC) # **Programming/Debug Features** - In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) via Two Pins - · In-Circuit Debug (ICD) with Three Breakpoints via Two Pins - · Debug Integrated On-Chip # **Block Diagram** Figure 1. PIC16F18015/25/44/45 Block Diagram # Notes: - 1. Available on 20-pin devices only. - 2. Available on 14/20-pin devices only. # **Table of Contents** | Intro | oduction | 1 | |-------|----------------------------------------------------------------|-------| | PIC | 16F180 Family Summary | 1 | | Cor | e Features | 2 | | 1. | Packages | 9 | | 2. | Pin Diagrams | 10 | | 3. | Pin Allocation Tables | 12 | | 4. | Guidelines for Getting Started with PIC16F180 Microcontrollers | 17 | | 5. | Register and Bit Naming Conventions | 20 | | 6. | Register Legend | 22 | | 7. | Enhanced Mid-Range CPU | 23 | | 8. | Device Configuration | 25 | | 9. | Memory Organization | 35 | | 10. | Resets | 70 | | 11. | OSC - Oscillator Module | 82 | | 12. | INT - Interrupts | 98 | | 13. | Sleep Mode | . 116 | | 14. | WDT - Watchdog Timer | . 118 | | 15. | NVM - Nonvolatile Memory Control | .122 | | 16. | I/O Ports | . 146 | | 17. | IOC - Interrupt-on-Change | 162 | | 18. | PPS - Peripheral Pin Select Module | 168 | | 19. | TMR0 - Timer0 Module | 178 | | 20. | TMR1 - Timer1 Module with Gate Control | .186 | | 21. | TMR2 - Timer2 Module | 201 | | 22. | NCO - Numerically Controlled Oscillator Module | . 222 | | 23. | CWG - Complementary Waveform Generator Module | .231 | | 24. | CCP - Capture/Compare/PWM Module | 258 | | 25. | Capture, Compare, and PWM Timers Selection | 271 | | 26. | PWM - Pulse-Width Modulation | 274 | | 27. | PWM Timers Selection | 282 | |------|---------------------------------------------------------------------------|-------| | 28. | CLC - Configurable Logic Cell | 285 | | 29. | MSSP - Host Synchronous Serial Port Module | 305 | | 30. | EUSART - Enhanced Universal Synchronous Asynchronous Receiver Transmitter | . 366 | | 31. | ADC - Analog-to-Digital Converter with Computation Module | . 395 | | 32. | DAC - Digital-to-Analog Converter Module | . 441 | | 33. | CMP - Comparator Module | . 447 | | 34. | FVR - Fixed Voltage Reference | . 458 | | 35. | Temperature Indicator Module | . 462 | | 36. | ZCD - Zero-Cross Detection Module | 467 | | 37. | Charge Pump | 474 | | 38. | Instruction Set Summary | 478 | | 39. | ICSP <sup>™</sup> - In-Circuit Serial Programming <sup>™</sup> | . 498 | | 40. | Register Summary | . 501 | | 41. | Electrical Specifications | . 509 | | 42. | DC and AC Characteristics Graphs and Tables | 537 | | 43. | Packaging Information | . 538 | | 44. | Appendix A: Revision History | 567 | | The | Microchip Website | 568 | | Pro | duct Change Notification Service | 568 | | Cus | tomer Support | 568 | | Pro | duct Identification System | 569 | | Mic | rochip Devices Code Protection Feature | 569 | | Leg | al Notice | . 570 | | Tra | demarks | . 570 | | Qua | ality Management System | 571 | | ۱۸/۵ | ddwide Sales and Service | 572 | # 1. Packages # Table 1-1. Packages | Device | 8-Pin<br>PDIP | 8-Pin<br>SOIC | 14-Pin<br>PDIP | 14-Pin<br>SOIC | 14-Pin<br>TSSOP | 16-Pin<br>VQFN | 20-Pin<br>PDIP | 20-Pin<br>SOIC | 20-Pin<br>SSOP | 20-Pin<br>QFN | |-------------|---------------|---------------|----------------|----------------|-----------------|----------------|----------------|----------------|----------------|---------------| | PIC16F18015 | • | • | | | | | | | | | | PIC16F18025 | | | • | • | • | • | | | | | | PIC16F18044 | | | | | | | • | • | • | • | | PIC16F18045 | | | | | | | • | • | • | • | # 2. Pin Diagrams Figure 2-1. 8-Pin PDIP, SOIC Figure 2-2. 14-Pin PDIP, SOIC, TSSOP Figure 2-3. 16-Pin VQFN **Note:** It is recommended that the exposed bottom pad be connected to $V_{SS}$ , however, it must not be the only $V_{SS}$ connection to the device. Figure 2-4. 20-Pin PDIP, SOIC, SSOP Figure 2-5. 20-Pin QFN **Note:** It is recommended that the exposed bottom pad be connected to $V_{SS}$ , however, it must not be the only $V_{SS}$ connection to the device. #### 3. **Pin Allocation Tables** ICSPCLK ICDCLK CLKOUT ICSPDAT ICDDAT sosco MCLR VPP CLKIN Basic SOSCI V<sub>DD</sub> <u>N</u>(1) Ī OCA0 IOCA1 IOCA2 IOCA3 <u>ဗ</u> I CK1(1,3) CK2(1,3,4) DT2(1,3,4) RX2(1,4) RX1<sup>(1)</sup> DT1<sup>(1,3)</sup> TX2(4) DT2(4) X F S SCL2(1,3,4) SCK2(1,3,4) SDA2(1,3,4) SDI2(1,3,4) SCL1(1,3) SCK1(1,3) SDA1(1,3) SDI1(1,3) SS2(1,4) SCL2(4) SCK2(4) SDA2(4) SDO2(4) SS1(1) SDA1 SD01 MSSP SCL1 1 Ī CLCIN1(1) CLCIN0 (1) CLC2OUT CLCIN2(1) CLC3OUT CLC10UT CLC40UT CLCIN3(1) CLC Ī CWG1(1,4) CWG1A(4) CWG1B<sup>(4)</sup> CWG1C<sup>(4)</sup> CWG1D(4) Ī CCP/PWM CCP1 CCP2 PWM3 PWM4 PWM5 T0CKI(1) T1CKI<sup>(1)</sup> T2IN<sup>(1)</sup> T3CKI(1) T3G(1) F4IN(1) T6IN(1) T1G(1) TMR0 ı 1 ZCD1 CCD 1 I C1IN0+ C1IN0-CMP1 1 VREF+ (ADC) DAC1REF0+ DAC10UT1 DAC1REF0ı ANA5 ADACT(1) ADGRDA ADGRDB ANA1 ANA2 ANA4 ADC I 1 8-Pin PDIP SOIC 9 OUT(2) VbD VSS RA0 RA1 RA2 RA4 <u>0</u> Table 3-1. 8-Pin Allocation Table This is a PPS remappable input signal. The input function may be moved from the default location shown to any PORTx pin. - 7 E 4 All output signals shown in this row are PPS remappable. This is a bidirectional signal. For normal operation, user software must map this signal to the same pin via the PPS input and PPS output registers. Only available on the 8-pin PIC16F18015. VDD ICSPCLK ICDCLK ICSPDAT ICDDAT CLKOUT sosco INT(1) 1 I I 1 1 IOCA0 IOCA2 IOCA3 IOCA5 IOCC2 10003 10CC4 0000 Ι CK1(1,3) CK2(1,3) DT2(1,3) RX1(1) DT1(1,3) I SDA1(1,3,4) SDI1(1,3,4) SCL1(1,3,4) SCK1(1,3,4) SCL2(1,3,4) SCK2(1,3,4) SDI2(1,3,4) SDA2(1,3,4) SS1(1) SS2(1) MSSP I CLCIN1(1) CLC I CWG1(1) CWG ١ Ī CCP1(1) CCP2(1) CCP I 1 T0CKI(1) T1CKI<sup>(1)</sup> T2IN<sup>(1)</sup> T1G(1) T3G(1) ₹ | E 16 E 1 I ZCD1 ZCD 1 l 1 Τ Comparator C1IN0+ ı VREF+(ADC) DAC1REF0-DAC10UT1 DAC1REF0+ 1 1 Table 3-2, 14/16-Pin Allocation Table ANC2 ADACT<sup>(1)</sup> ANC3 ANA0 ANA5 ANA2 ANA1 ANA4 ANC1 I 16-Pin VQFN 12 9 13 Ξ က 6 ∞ 2 7 9 13 12 9 4 7 VbD RC2 Vss RA0 RA3 RA4 RC0 RC3 RC4 RC5 RC1 RA1 CLKIN MCLR VPP Basic | 1/O 14-P | | | | | | | | | | | | | | | |----------|--------------------------------------------------------------------------------|------------------|-----------|------------|-----|--------|------------------------------|-------------------------|------------------------------------------|------------------------------------------------------|--------|----------|-----------|-------| | TSSOP | 14-Pin 16-Pin PDIP VQFN SOIC TSSOP | in ADC | Reference | Comparator | ZCD | Timers | CCP | CWG | CLC | MSSP | EUSART | <u> </u> | Interrupt | Basic | | OUT(2) | | ADGRDB<br>ADGRDB | <br> | CMP1 | I | TMR0 | CCP1<br>CCP2<br>PWM3<br>PWM4 | CWG1B<br>CWG1B<br>CWG1D | CLC10UT<br>CLC20UT<br>CLC30UT<br>CLC40UT | SCL1<br>SCK1<br>SDA1<br>SCL2<br>SCK2<br>SDA2<br>SDO2 | XX | ı | I | I | This is a PPS remappable input signal. The input function may be moved from the default location shown to any PORTx pin. This is a bidirectional signal. For normal operation, user software must map this signal to the same pin via the PPS input and PPS output registers. 2 8 4 These pins can be configured for I<sup>2</sup>C or SMBus logic levels via the RxyI2C registers. The SCL1/SDA1 signals may be assigned to these pins for expected operation. PPS assignments of these signals to other pins will operate; however, the logic levels will be standard TTL/ST as selected by the INLVL register. ICSPCLK ICDCLK ICSPDAT ICDDAT CLKOUT sosco CLKIN Basic MCLR VDD Ī Ι 1 Ī Ī Τ 1 IOCA0 IOCC2 10003 10004 10006 10006 IOCA3 IOCB4 10001 IOCB7 <u>၁၀</u> 1 CK1(1,3) CK2(1,3) RX2(1) DT2(1,3) 1 1 1 SDA1(1,3,4) SDI1(1,3,4) SCK2(1,3,4) SCL1(1,3,4) SCK1(1,3,4) SDA2(1,3,4) SDI2(1,3,4) SCL2(1,3,4) SS2(1) MSSP 1 CLCIN3(1) CLCIN1(1) CLCIN2(1) CLC I 1 CWG1(1) CWG 1 Ī Ī 1 1 CCP2(1) CCP1(1) CCP 1 1 T0CKI(1) T1CKI<sup>(1)</sup> T2IN<sup>(1)</sup> T3CKI(1) T3G(1) T6IN(1) T1G(1) T4IN(1) Ī 1 1 ZCD 1 Ī I 1 1 Ī Comparator C1IN0+ C1|N1-1 1 VREF+(ADC) DAC1REF0+ DAC1REF0-DAC10UT1 I ANC2 ADACT(1) ANA0 ANC0 ANC1 ANC3 ANC4 ANC5 ANC6 ANC7 ANA2 ANA5 ANB6 ANB7 ANA4 ANB4 ANA1 ADC 1 20-Pin QFN 16 5 4 20 6 9 6 ω 13 Ξ က 7 2 9 9 20-Pin PDIP SOIC 19 9 17 3 12 10 15 4 20 7 9 2 8 6 က RC4 RC5 RC6 RC6 VDD RA5 RC0 RC1 RA0 RB6 RA4 RB4 RB5 RA1 RB7 Table 3-3, 20-Pin Allocation Table | continued | ntinued | | | | | | | | | | | | | | | |-----------|----------------|---------------|--------|-----------|------------|-----|--------|------|-------|---------|------|---------|----------|-----------|-------| | 0/1 | 20-Pin<br>PDIP | 20-Pin<br>QFN | ADC | Reference | Comparator | ZCD | Timers | ССР | CWG | CLC | MSSP | EUSART | <u>8</u> | Interrupt | Basic | | | SOIC | | | | | | | | | | | | | | | | | SSOP | | | | | | | | | | | | | | | | OUT(2) | | ı | ADGRDA | ı | CMP1 | 1 | TMR0 | CCP1 | CWG1A | CLC10UT | SCL1 | TX1 | ı | ı | | | | | | ADGRDB | | | | | CCP2 | CWG1B | CLC2OUT | SCK1 | DT1 | | | | | | | | | | | | | PWM3 | CWG1C | CLC3OUT | SDA1 | CK<br>1 | | | | | | | | | | | | | PWM4 | CWG1D | CLC40UT | SD01 | TX2 | | | | | | | | | | | | | PWM5 | | | SCL2 | DT2 | | | | | | | | | | | | | | | | SCK2 | CK2 | | | | | | | | | | | | | | | | SDA2 | | | | | | | | | | | | | | | | | SD02 | | | | | | | | | | | | | | | | | | | | | | 1. This is a PPS remappable input signal. The input function may be moved from the default location shown to any PORTx pin. # 4. Guidelines for Getting Started with PIC16F180 Microcontrollers ### 4.1 Basic Connection Requirements Getting started with the PIC16F180 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 V<sub>DD</sub> and V<sub>SS</sub> pins (see 4.2. Power Supply Pins) - MCLR pin (see 4.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<sup>™</sup> (ICSP<sup>™</sup>) and debugging purposes (see 4.4. In-Circuit Serial Programming (ICSP) Pins) - · CLKIN pin when an external clock source is used. Additionally, the following may be required: V<sub>RFF</sub>+/V<sub>RFF</sub>- pins are used when external voltage reference for analog modules is implemented The minimum recommended connections are shown in the figure below. Figure 4-1. Minimum Recommended Connections Key (all values are recommendations): C1: 10 nF, 16V ceramic C2: 0.1 µF, 16V ceramic R1: $10 \text{ k}\Omega$ R2: $100\Omega$ to $470\Omega$ # 4.2 Power Supply Pins #### 4.2.1 Decoupling Capacitors The use of decoupling capacitors on every pair of power supply pins ( $V_{DD}$ and $V_{SS}$ ) is required. Consider the following criteria when using decoupling capacitors: - Value and type of capacitor: A 0.1 µF (100 nF), 10-25V capacitor is recommended. The capacitor may be a low-ESR device, with a resonance frequency in the range of 200 MHz and higher. Ceramic capacitors are recommended. - Placement on the printed circuit board: The decoupling capacitors may be placed as close to the pins as possible. It is recommended to place the capacitors on the same side of the board as the device. If space is constricted, the capacitor can be placed on another layer on the PCB using a via; however, ensure that the trace length from the pin to the capacitor is no greater than 0.25 inch (6 mm). # Guidelines for Getting Started with PIC16F180 Micr... - Handling high-frequency noise: If the board is experiencing high-frequency noise (upward of tens of MHz), add a second ceramic type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01 μF to 0.001 μF. Place this second capacitor next to each primary decoupling capacitor. In high-speed circuit designs, consider implementing a decade pair of capacitances as close to the power and ground pins as possible (e.g., 0.1 μF in parallel with 0.001 μF). - Maximizing performance: On the board layout from the power supply circuit, run the power and return traces to the decoupling capacitors first, and then to the device pins. This ensures that the decoupling capacitors are first in the power chain. Equally important is to keep the trace length between the capacitor and the power pins to a minimum, thereby reducing PCB trace inductance. ### 4.2.2 Tank Capacitors With on boards with power traces running longer than six inches in length, it is suggested to use a tank capacitor for integrated circuits, including microcontrollers, to supply a local power source. The value of the tank capacitor may be determined based on the trace resistance that connects the power supply source to the device, and the maximum current drawn by the device in the application. In other words, select the tank capacitor that meets the acceptable voltage sag at the device. Typical values range from $4.7 \, \mu F$ to $47 \, \mu F$ . # 4.3 Master Clear (MCLR) Pin The $\overline{MCLR}$ pin provides two specific device functions: Device Reset, and device programming and debugging. If programming and debugging are not required in the end application, a direct connection to $V_{DD}$ may be all that is required. The addition of other components, to help increase the application's resistance to spurious Resets from voltage sags, may be beneficial. A typical configuration is shown in Figure 4-1. Other circuit designs may be implemented, depending on the application's requirements. During programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the $\overline{MCLR}$ pin. Consequently, specific voltage levels (V<sub>IH</sub> and V<sub>IL</sub>) and fast signal transitions must not be adversely affected. Therefore, specific values of R1 and C1 will need to be adjusted based on the application and PCB requirements. For example, it is recommended that the capacitor, C1, be isolated from the $\overline{MCLR}$ pin during programming and debugging operations by using a jumper (Figure 4-2). The jumper is replaced for normal run-time operations. Any components associated with the MCLR pin may be placed within 0.25 inch (6 mm) of the pin. Figure 4-2. Example of MCLR Pin Connections #### Notes: - 1. R1 ≤ 10 kΩ is recommended. A suggested starting value is 10 kΩ. Ensure that the $\overline{MCLR}$ pin V<sub>IH</sub> and V<sub>IL</sub> specifications are met. - R2 ≤ 470Ω will limit any current flowing into MCLR from the extended capacitor, C1, in the event of MCLR pin breakdown, due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). Ensure that the MCLR pin V<sub>IH</sub> and V<sub>IL</sub> specifications are met. # 4.4 In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) Pins The ICSPCLK and ICSPDAT pins are used for ICSP and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of ohms, not to exceed $100\Omega$ . # PIC16F18015/25/44/45 # **Guidelines for Getting Started with PIC16F180 Micr...** Pull-up resistors, series diodes and capacitors on the ICSPCLK and ICSPDAT pins are not recommended as they can interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they may be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits, and pin input voltage high $(V_{IH})$ and input low $(V_{IL})$ requirements. For device emulation, ensure that the Communication Channel Select (i.e., ICSPCLK/ICSPDAT pins), programmed into the device, matches the physical connections for the ICSP to the Microchip debugger/emulator tool. # 4.5 Unused I/Os Unused I/O pins may be configured as outputs and driven to a Logic Low state. Alternatively, connect a 1 k $\Omega$ to 10 k $\Omega$ resistor to V<sub>SS</sub> on unused pins to drive the output to Logic Low. # 5. Register and Bit Naming Conventions # 5.1 Register Names When there are multiple instances of the same peripheral in a device, the Peripheral Control registers will be depicted as the concatenation of a peripheral identifier, peripheral instance, and control identifier. The Control registers section will show just one instance of all the register names with an 'x' in the place of the peripheral instance number. This naming convention may also be applied to peripherals when there is only one instance of that peripheral in the device to maintain compatibility with other devices in the family that contain more than one. #### 5.2 Bit Names There are two variants for bit names: - · Short name: Bit function abbreviation - · Long name: Peripheral abbreviation + short name #### 5.2.1 Short Bit Names Short bit names are an abbreviation for the bit function. For example, some peripherals are enabled with the EN bit. The bit names shown in the registers are the short name variant. Short bit names are useful when accessing bits in C programs. The general format for accessing bits by the short name is RegisterNamebits. ShortName. For example, the enable bit, ON, in the ADCON0 register can be set in C programs with the instruction ADCON0bits.ON = 1. Short names are not useful in assembly programs because the same name may be used by different peripherals in different bit positions. When it occurs, during the include file generation, the short bit name instances are appended with an underscore plus the name of the register where the bit resides, to avoid naming contentions. ### 5.2.2 Long Bit Names Long bit names are constructed by adding a peripheral abbreviation prefix to the short name. The prefix is unique to the peripheral, thereby making every long bit name unique. The long bit name for the ADC enable bit is the ADC prefix, AD, appended with the enable bit short name, ON, resulting in the unique bit name ADON. Long bit names are useful in both C and assembly programs. For example, in C the ADCON0 enable bit can be set with the ADON = 1 instruction. In assembly, this bit can be set with the BSF ADCON0, ADON instruction. #### 5.2.3 Bit Fields Bit fields are two or more adjacent bits in the same register. Bit fields adhere only to the short bit naming convention. For example, the three Least Significant bits of the ADCON2 register contain the ADC Operating Mode Selection bit. The short name for this field is MD and the long name is ADMD. Bit field access is only possible in C programs. The following example demonstrates a C program instruction for setting the ADC to operate in Accumulate mode: ``` ADCON2bits.MD = 0b001; ``` Individual bits in a bit field can also be accessed with long and short bit names. Each bit is the field name appended with the number of the bit position within the field. For example, the Most Significant MODE bit has the short bit name MD2 and the long bit name is ADMD2. The following two examples demonstrate assembly program sequences for setting the ADC to operate in Accumulate mode: ``` MOVLW ~ (1<<MD2 | 1<<MD1) ANDWF ADCON2,F MOVLW 1<<MD0 IORWF ADCON2,F ``` # **Register and Bit Naming Conventions** BCF ADCON2,ADMD2 BCF ADCON2,ADMD1 BSF ADCON2,ADMD0 # 5.3 Register and Bit Naming Exceptions # 5.3.1 Status, Interrupt and Mirror Bits Status, Interrupt enables, Interrupt flags and Mirror bits are contained in registers that span more than one peripheral. In these cases, the bit name shown is unique so there is no prefix or short name variant. # 6. Register Legend Table 6-1. Register Legend | Symbol | Definition | |-------------|--------------------------------| | R | Readable bit | | W | Writable bit | | HS | Hardware settable bit | | НС | Hardware clearable bit | | S | Set only bit | | С | Clear only bit | | U | Unimplemented bit, read as '0' | | <b>'1'</b> | Bit value is set | | <b>'</b> 0' | Bit value is cleared | | X | Bit value is unknown | | u | Bit value is unchanged | | q | Bit value depends on condition | | m | Bit value is predefined | # 7. Enhanced Mid-Range CPU This family of devices contains an enhanced mid-range 8-bit CPU core. The CPU has 50 instructions. Interrupt capability includes automatic context saving. The hardware stack is 16-level deep and has overflow and underflow Reset capability. Direct, Indirect, and Relative Addressing modes are available. Two File Select Registers (FSR) provide the ability to read program and data memory. Figure 7-1. Core Data Path Diagram # 7.1 Automatic Interrupt Context Saving During interrupts, certain registers are automatically saved in shadow registers and restored when returning from the interrupt. This saves stack space and user code. # 7.2 16-Level Stack with Overflow and Underflow These devices have a hardware stack memory 15 bits wide and 16 words deep. A Stack Overflow or Underflow will set the appropriate bit (STKOVF or STKUNF), and if enabled, will cause a software Reset. # 7.3 File Select Registers There are two 16-bit File Select Registers (FSR). FSRs can access all file registers and program memory, which allows one Data Pointer for all memory. When an FSR points to program memory, there is one additional instruction cycle in instructions using INDF to allow the data to be fetched. General purpose memory can also be addressed linearly, providing the ability to access contiguous data larger than 80 bytes. # 7.4 Instruction Set There are 50 instructions for the enhanced mid-range CPU to support the features of the CPU. See the "Instruction Set Summary" section for more details. # 8. Device Configuration Device configuration consists of the Configuration Words, User ID, Device ID, Device Information Area (DIA) and the Device Configuration Information (DCI) regions. # 8.1 Configuration Words There are five Configuration Words that allow the user to select the device oscillator, Reset and memory protection options. These are implemented at addresses 0x8007 - 0x800B. **Note:** The DEBUG bit in the Configuration Words is managed automatically by device development tools, including debuggers and programmers. For normal device operation, this bit needs to be maintained as a '1'. #### 8.2 Code Protection Program memory code protection is controlled using the $\overline{CP}$ bit while data EEPROM memory code protection is controlled using the $\overline{CPD}$ bit. When code protection is enabled, all program memory and Data EEPROM locations read as '0'. Further programming is disabled for the program memory and Data EEPROM until a Bulk Erase operation is performed on the configuration memory region. Program memory and Data EEPROM can still be programmed and read during program execution. The User ID locations and Configuration Bytes can be programmed and read out regardless of the code protection settings. The only way to disable code protection is to use the Bulk Erase Program Memory command with bit 4 of the payload set to '1'. This will disable code protection and also erase all the memory locations. # 8.3 Write Protection Write protection allows the device to be protected from unintended self-writes. Applications, such as bootloader software, can be protected while allowing other regions of the program memory to be modified. The WRTn Configuration bits determine which of the program memory blocks are protected. #### 8.4 User ID Four words in the memory space (8000h-8003h) are designated as ID locations where the user can store checksum or other code identification numbers. These locations are readable and writable during normal execution. See the "NVMREG Access to DIA, DCI, User ID, DEV/REV ID, and Configuration Words" section for more information on accessing these memory locations. See the "Memory Programming Specification" section in the "Electrical Specifications" chapter for information on the electrical parameters required to program these memory locations. For more information on checksum calculation, see the "Family Programming Specification". #### 8.5 Device ID and Revision ID The 14-bit Device ID word is located at address 8006h and the 14-bit Revision ID is located at 8005h. These locations are read-only and cannot be erased or modified. Development tools, such as device programmers and debuggers, may be used to read the Device ID, Revision ID and Configuration Words. Refer to the "**NVM - Nonvolatile Memory Control**" section for more information on accessing these locations. # 8.6 Register Definitions: Configuration Settings ### 8.6.1 **CONFIG1** Name: CONFIG1 Offset: 0x8007 Configuration Word 1 # Bit 12 - VDDAR V<sub>DD</sub> Analog Range Calibration Selection | Value | Description | |-------|------------------------------------------------------------------------------------------| | 1 | Internal analog systems are calibrated for operation between V <sub>DD</sub> = 2.3V-5.5V | | 0 | Internal analog systems are calibrated for operation between V <sub>DD</sub> = 1.8V-3.6V | ### Bit 8 - CLKOUTEN Clock Out Enable | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | CLKOUT function is disabled; I/O function on CLKOUT pin | | 0 | CLKOUT function is enabled; F <sub>OSC</sub> /4 clock appears on CLKOUT pin | # Bits 6:4 - RSTOSC[2:0] Power-up Default Value for the COSC bits Selects the oscillator source used by user software. | Value | Description | |-------|---------------------------------------| | 111 | EXTOSC operating per the FEXTOSC bits | | 110 | HFINTOSC = 1 MHz (FRQ = 1 MHz) | | 101 | LFINTOSC | | 100 | SOSC | | 011 | Reserved | | 010 | Reserved | | 001 | Reserved | | 000 | HFINTOSC = 32 MHz (FRQ = 32 MHz) | # Bits 1:0 - FEXTOSC[1:0] External Oscillator Mode Selection | Value | Description | |-------|-------------------------| | 11 | ECH (16 MHz and higher) | | 10 | Reserved | | 01 | ECL (below 16 MHz) | | 00 | Oscillator not enabled | ### 8.6.2 **CONFIG2** Name: CONFIG2 Offset: 0x8008 Configuration Word 2 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------|--------|-------|--------|---------|------|--------|-----------| | | | | DEBUG | STVREN | PPS1WAY | ZCD | BORV | DACAUTOEN | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | BORE | N[1:0] | | WDT | Ē[1:0] | PWRT | S[1:0] | MCLRE | | Access | R/W | R/W | | R/W | R/W | R/W | R/W | R/W | | Reset | 1 | 1 | | 0 | 1 | 1 | 1 | 1 | # Bit 13 - DEBUG Debugger Enable<sup>(1)</sup> | Value | Description | |-------|------------------------------| | 1 | Background debugger disabled | | 0 | Background debugger enabled | #### Bit 12 - STVREN Stack Overflow/Underflow Reset Enable | Value | Description | |-------|----------------------------------------------------| | 1 | Stack Overflow or Underflow will cause a Reset | | 0 | Stack Overflow or Underflow will not cause a Reset | ### Bit 11 - PPS1WAY PPSLOCKED One-Way Set Enable | Value | Description | |-------|--------------------------------------------------------------------------------------| | 1 | The PPSLOCKED bit can only be set once after an unlocking sequence is executed; once | | | PPSLOCKED is set, all future changes to PPS registers are prevented | | 0 | The PPSLOCKED bit can be set and cleared as needed (unlocking sequence is required) | ### Bit 10 - ZCD Zero-Cross Detect Disable | Valu | ie | Description | |------|----|----------------------------------------------------------------------| | 1 | | ZCD disabled, ZCD can be enabled by setting the ZCDSEN bit of ZCDCON | | 0 | | ZCD always enabled, the PMDx [ZCDMD] bit is ignored | ### Bit 9 - BORV Brown-Out Reset (BOR) Voltage Selection(2) | | | , , | <del>_</del> | |------|--------------------|------------------------|-------------------------------| | Valu | ue Description | | | | 1 | Brown-out Reset vo | oltage (V <sub>B</sub> | <sub>SOR</sub> ) set to 1.9V | | 0 | Brown-out Reset vo | oltage (V <sub>B</sub> | <sub>BOR</sub> ) set to 2.65V | ### Bit 8 – DACAUTOEN DAC Buffer Automatic Range Select Enable | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | DAC Buffer reference range is determined by the REFRNG bit of DACxCON | | 0 | DAC Buffer reference range is automatically determined by module hardware | # Bits 7:6 - BOREN[1:0] Brown-Out Reset (BOR) Enable(3) | Value | Description | |-------|-------------------------------------------------------------------------------------| | 11 | Brown-out Reset enabled, the SBOREN bit is ignored | | 10 | Brown-out Reset enabled while running, disabled in Sleep; the SBOREN bit is ignored | | 01 | Brown-out Reset enabled according to SBOREN | | 00 | Brown-out Reset disabled | ### Bits 4:3 - WDTE[1:0] Watchdog Timer (WDT) Enable # **Device Configuration** | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 11 | WDT enabled regardless of Sleep; the SEN bit of WDTCON is ignored | | 10 | WDT enabled while Sleep = 0, suspended when Sleep = 1; the SEN bit of WDTCON is ignored | | 01 | WDT enabled/disabled by the SEN bit of WDTCON | | 00 | WDT disabled; SEN bit of WDTCON is ignored | ### Bits 2:1 - PWRTS[1:0] Power-Up Timer (PWRT) Selection | Value | Description | |-------|----------------------| | 11 | PWRT disabled | | 10 | PWRT is set at 64 ms | | 01 | PWRT is set at 16 ms | | 00 | PWRT is set at 1 ms | # Bit 0 - MCLRE Master Clear (MCLR) Enable | Value | Condition | Description | |-------|------------|--------------------------------------------| | X | If LVP = 1 | MCLR pin is MCLR | | 1 | If LVP = 0 | MCLR pin is MCLR | | 0 | If LVP = 0 | MCLR pin function is port-defined function | #### Notes: - 1. The DEBUG bit is managed automatically by device development tools including debuggers and programmers. For normal device operation, this bit needs to be maintained as a '1'. - 2. The higher voltage selection is recommended for operation at or above 16 MHz. - 3. When enabled, Brown-out Reset voltage ( $V_{BOR}$ ) is set by the BORV bit. # PIC16F18015/25/44/45 # **Device Configuration** # 8.6.3 **CONFIG3** Name: CONFIG3 Offset: 0x8009 Configuration Word 3 Note: This register is reserved. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|----|----|----|----|----|----|---|---| | Access<br>Reset | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Access Reset ### 8.6.4 **CONFIG4** Name: CONFIG4 Offset: 0x800A Configuration Word 4 | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|--------|----|-----|-------|--------|------|-------------|------| | [ | | | LVP | | WRTSAF | WRTD | WRTC | WRTB | | Access | | | R/W | | R/W | R/W | R/W | R/W | | Reset | | | 1 | | 1 | 1 | 1 | 1 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | WRTAPP | | | SAFEN | BBEN | | BBSIZE[2:0] | | | Access | R/W | | | R/W | R/W | R/W | R/W | R/W | | Reset | 1 | | | 1 | 1 | 1 | 1 | 1 | # Bit 13 – LVP Low-Voltage Programming Enable<sup>(1)</sup> | Value | Description | |-------|----------------------------------------------------------------------------------------------------------| | 1 | Low-Voltage Programming is enabled. MCLR/V <sub>PP</sub> pin function is MCLR. The MCLRE bit is ignored. | | 0 | High voltage (HV) on MCLR/V <sub>PP</sub> must be used for programming. | # Bit 11 - WRTSAF Storage Area Flash (SAF) Write Protection<sup>(2, 3)</sup> | Value | Description | |-------|----------------------------| | 1 | SAF is not write-protected | | 0 | SAF is write-protected | # Bit 10 - WRTD Data EEPROM Write Protection(2) | Value | Description | | | |-------|------------------------------------|--|--| | 1 | Data EEPROM is not write-protected | | | | 0 | Data EEPROM is write-protected | | | ### Bit 9 - WRTC Configuration Registers Write Protection(2) | Value | Description | | |-----------------------------------------------|-------------------------------------------------|--| | 1 | Configuration registers are not write-protected | | | O Configuration registers are write-protected | | | # Bit 8 – WRTB Boot Block Write Protection<sup>(2, 4)</sup> | Value Description | | | |-------------------|---|-----------------------------------| | | 1 | Boot Block is not write-protected | | | 0 | Boot Block is write-protected | # Bit 7 – WRTAPP Application Block Write Protection<sup>(2)</sup> | Value | e Description | | | |--------------------------------------------|--------------------------------------|--|--| | 1 Application Block is not write-protected | | | | | 0 | Application Block is write-protected | | | # Bit 4 - SAFEN Storage Area Flash (SAF) Enable<sup>(2)</sup> | Value | Description | |-------|-----------------| | 1 | SAF is disabled | | 0 | SAF is enabled | ### Bit 3 - BBEN Boot Block Enable(2) | Value | Description | |-------|------------------------| | 1 | Boot Block is disabled | | 0 | Boot Block is enabled | Bits 2:0 - BBSIZE[2:0] Boot Block Size Selection(5, 6) Table 8-1. Boot Block Size | BBEN | BBSIZE | End Address of | Boot Block Size (words) | | | |------|--------|----------------|-------------------------|-------------|--| | DDEN | | Boot Block | PIC16F180x4 | PIC16F180x5 | | | 1 | XXX | _ | - | - | | | 0 | 111 | 01FFh | 5′ | 12 | | | 0 | 110 | 03FFh | 10 | 24 | | | 0 | 101 | 07FFh | 20 | 48 | | | 0 | 100 | 0FFFh | _(6) | 4096 | | | 0 | 011 | 1FFFh | _ | (6) | | | 0 | 010 | 3FFFh | _ | (6) | | | 0 | 001 | 3FFFh | _ | (6) | | | 0 | 000 | 3FFFh | _ | (6) | | #### Notes: - 1. The LVP bit cannot be written (to zero) while operating from the LVP programming interface. The purpose of this rule is to prevent the user from dropping out of the LVP mode while programming from LVP mode, or accidentally eliminating the LVP mode from the Configuration state. - 2. Once protection is enabled through ICSP or a self-write, it can only be reset through a Bulk Erase. - 3. Applicable only if $\overline{SAFEN} = 0$ . - 4. Applicable only if $\overline{BBEN} = 0$ . - 5. BBSIZE[2:0] bits can only be changed when $\overline{BBEN} = 1$ . Once $\overline{BBEN} = 0$ , BBSIZE[2:0] can only be changed through a Bulk Erase. - 6. The maximum Boot Block size is half of the user program memory size. Any selection that will exceed half of a device's program memory will default to a maximum Boot Block size of half PFM. ### 8.6.5 **CONFIG5** Name: CONFIG5 Offset: 0x800B Configuration Word 5<sup>(1)</sup> Bit 1 – CPD Data Flash Memory (EEPROM) Code Protection(2) | | Value | e Description | | |--------------------------------------------------------------------------|-------|------------------------------------|--| | 1 EEPROM code protection is disabled 0 EEPROM code protection is enabled | | EEPROM code protection is disabled | | | | | EEPROM code protection is enabled | | Bit 0 - $\overline{CP}$ Program Flash Memory (PFM) Code Protection<sup>(2)</sup> | | | , · | , | | |------|----------------|----------------|------|--| | Valu | e Description | | | | | 1 | PFM code prote | ection is disa | oled | | | 0 | PFM code prote | ection is enal | led | | ### Notes: - 1. Since device code protection takes effect immediately, this Configuration Word must be written last. - 2. Once code protection is enabled, it can only be removed through a Bulk Erase. # 8.7 Register Definitions: Device ID and Revision ID # 8.7.1 Device ID Name: DEVICEID Offset: 0x8006 Device ID Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----------|----------|----------|----|------|-------|---| | | | | Reserved | Reserved | | DEV[ | 11:8] | | | Access | | | R | R | R | R | R | R | | Reset | | | 1 | 1 | q | q | q | q | | | _ | _ | _ | | | _ | | _ | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 11 | 0 | | | | DEV[7:0] | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | q | q | q | q | q | q | q | q | Bit 13 - Reserved Reserved - Read as '1' Bit 12 - Reserved Reserved - Read as '1' Bits 11:0 - DEV[11:0] Device ID | Device | Device ID | |-------------|-----------| | PIC16F18015 | 30F5h | | PIC16F18025 | 30F6h | | PIC16F18044 | 30F7h | | PIC16F18045 | 30F8h | # 8.7.2 Revision ID Name: REVISIONID Offset: 0x8005 Revision ID Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-------------|-----|----------|-------------|----|-------|---------|---| | | | | Reserved | Reserved | | MJRRI | EV[5:2] | | | Access | | • | R | R | R | R | R | R | | Reset | | | 1 | 0 | q | q | q | q | | Bit | 7 | 6 | 5 | 4 | 2 | 2 | 1 | 0 | | DIL | / | - V | 5 | | 3 | Z | ı | | | | MJRREV[1:0] | | | MNRREV[5:0] | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | q | q | q | q | q | q | q | q | Bit 13 - Reserved Reserved - Read as '1' Bit 12 - Reserved Reserved - Read as '0' # Bits 11:6 - MJRREV[5:0] Major Revision ID These bits are used to identify a major revision (A0, B0, C0, etc.). # Bits 5:0 - MNRREV[5:0] Minor Revision ID These bits are used to identify a minor revision. # 9. Memory Organization There are three types of memory in PIC16F180 microcontroller devices: - Program Memory - Program Flash Memory - Configuration Words - Device ID - Revision ID - User ID - Device Information Area (DIA) - Device Configuration Information (DCI) - · Data Memory - Core Registers - Special Function Registers (FSR) - General Purpose RAM (GPR) - Common RAM - Data EEPROM In Harvard architecture devices, the data and program memories use separate buses that allow for concurrent access of the two memory spaces. The data EEPROM, for practical purposes, can be regarded as a peripheral device, since it is addressed and accessed through a set of control registers. Additional detailed information on the operation of the Program Flash Memory and data EEPROM memory is provided in the "NVM - Nonvolatile Memory Module" section. # 9.1 Program Memory Organization The enhanced mid-range core has a 15-bit Program Counter capable of addressing 32K x 14 program memory space. The table below shows the memory sizes implemented. Accessing a location above these boundaries will cause a wrap-around within the implemented memory space. The Reset vector is at 0000h and the interrupt vector is at 0004h. Refer to the "Interrupts" chapter for more details. Table 9-1. Device Sizes and Addresses | Device | Program Memory Size (Words) | Last Program Memory Address | |-------------|-----------------------------|-----------------------------| | PIC16F18015 | 8,192 | 1FFFh | | PIC16F18025 | 8,192 | 0FFFh | | PIC16F18044 | 4,096 | 1FFFh | | PIC16F18045 | 8,192 | 1FFFh | Figure 9-1. Program Memory and Stack (PIC16F180x4) Figure 9-2. Program Memory and Stack (PIC16F180x5) ## 9.1.1 Reading Program Memory as Data There are three methods of accessing constants in program memory. The first method is to use tables of RETLW instructions, the second, to set an FSR to point to the program memory, and the third is to use the NVMREG interface to access the program memory. ### 9.1.1.1 RETLW Instruction The RETLW instruction can be used to provide access to tables of constants. The recommended way to create such a table is shown in the following example. ``` ;select data RETLW DATAO ;Index0 data RETLW DATA1 ;Index1 data RETLW DATA2 RETLW DATA3 my_function ;... LOTS OF CODE... MOVLW DATA_INDEX call constants ;... THE CONSTANT IS IN W ``` The BRW instruction eases the implementation of this type of table. ### 9.1.1.2 Indirect Read with FSR The program memory can be accessed as data by setting bit 7 of an FSRxH register and reading the matching INDFx register. The MOVIW instruction will place the lower eight bits of the addressed word in the W register. Writes to the program memory cannot be performed via the INDFx registers. Instructions that read the program memory via the FSR require one extra instruction cycle to complete. The following example demonstrates reading the program memory via an FSR. The high directive will set bit 7 if a label points to a location in the program memory. This applies to the assembly code shown below. ``` Example 9-2. Read of Program Memory Using FSR Register constants RETLW DATAO ;Index0 data RETLW DATA1 ;Index1 data RETLW DATA2 RETLW DATA3 my function ;... LOTS OF CODE... MOVLW LOW constants MOVWF FSR1L MOVLW HIGH constants MOVWF FSR1H 2[FSR1] ;DATA2 IS IN W WIVOM ``` ## 9.1.2 Memory Access Partition (MAP) User Flash is partitioned into: - Application Block - Boot Block - Storage Area Flash (SAF) Block The user can allocate the memory usage by setting the BBEN bit, selecting the size of the partition defined by BBSIZE bits and enabling the Storage Area Flash by the SAFEN bit. ### 9.1.2.1 Application Block Default settings of the Configuration bits ( $\overline{BBEN} = 1$ and $\overline{SAFEN} = 1$ ) assign all memory in the user Flash area to the application block. ### 9.1.2.2 Boot Block If BBEN = 1, the Boot Block is enabled and a specific address range is allotted as the Boot Block, based on the value of the BBSIZE bits. ### 9.1.2.3 Storage Area Flash Storage Area Flash (SAF) is enabled by clearing the SAFEN bit. If enabled, the SAF block is placed at the end of memory and spans 128 words. If the Storage Area Flash (SAF) is enabled, the SAF area is not available for program execution. **Important:** Storage Area Flash, when enabled, may be used to store variables or other information, often in devices without EEPROM; however, the SAF is accessed in the same manner as other Flash memory areas. ### 9.1.2.4 Memory Write Protection All the memory blocks have corresponding write protection bits (WRTAPP, WRTB, WRTC, WRTD, and WRTSAF). If write-protected locations are written from NVMCON registers, the memory is not changed and the WRERR bit of the NVMCON1 register is set as explained in the "WRERR Bit" section from the "NVM - Nonvolatile Memory Control" chapter. ### 9.1.2.5 Memory Violation A Memory Execution Violation Reset occurs while executing an instruction that has been fetched from outside a valid execution area, clearing the $\overline{\text{MEMV}}$ bit. Refer to the "**Memory Execution Violation**" section in the "**Resets**" chapter for the available valid program execution areas and the PCON1 register definition for $\overline{\text{MEMV}}$ bit conditions. Table 9-2. Memory Access Partition | | | | Part | ition | | | | | | |--------|----------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------|---------------------------|-------------------------------------|--|--|--|--| | REG | Address | BBEN = 1<br>SAFEN = 1 | BBEN = 1<br>SAFEN = 0 | BBEN = 0<br>SAFEN = 1 | BBEN = 0<br>SAFEN = 0 | | | | | | | 00 0000h Last Block<br>Memory Address | | | Boot Block <sup>(4)</sup> | Boot Block <sup>(4)</sup> | | | | | | PFM | Last Boot Block Memory<br>Address + 1 <sup>(1)</sup><br>Last Program Memory<br>Address - 80h | Application<br>Block <sup>(4)</sup> | Application<br>Block <sup>(4)</sup> | Application | Application<br>Block <sup>(4)</sup> | | | | | | | Last Program Memory<br>Address - 7Fh <sup>(2)</sup><br>Last Program Memory<br>Address | | SAF <sup>(4)</sup> | Block <sup>(4)</sup> | SAF(4) | | | | | | CONFIG | Config Memory<br>Address <sup>(3)</sup> | | CON | NFIG | _ | | | | | | EEPROM | F000h-F0FFh | EEPROM | | | | | | | | ### Notes: - Last Boot Block Memory Address is based on the BBSIZE Configuration bits. - Last Program Memory Address is the Flash size given in the "Program Memory Organization" section in the "NVM - Nonvolatile Memory Control" chapter. - Config Memory Address are the address locations of the Configuration Words given in the "NVMREG Access to DIA, DCI, User ID, DEV/REV ID, and Configuration Words" section in the "NVM Nonvolatile Memory Control" chapter. - 4. Each memory block has a corresponding write protection fuse defined by the WRTAPP, WRTB, WRTC, WRTD, and WRTSAF Configuration bits. ### 9.1.3 Device Information Area (DIA) The Device Information Area (DIA) is a dedicated region in the Program Flash Memory. The data is mapped from address 8100h to 811Fh. These locations are read-only and cannot be erased or modified. The DIA contains the Microchip Unique Identifier words, Temperature Indicator range data, and the Fixed Voltage Reference (FVR) voltage readings in millivolts (mV). The DIA Table holds the DIA information for the PIC16F180 family of microcontrollers. Table 9-3. Device Information Area | Address Range | Name of Region | Standard Device Information | | | | | | | | | |---------------|----------------------|-------------------------------------------------------------|--|--|--|--|--|--|--|--| | | MUI0 | | | | | | | | | | | | MUI1 | | | | | | | | | | | | MUI2 | | | | | | | | | | | | MUI3 | | | | | | | | | | | 8100h - 8108h | MUI4 | Microchip Unique Identifier (9 Words) | | | | | | | | | | | MUI5 | | | | | | | | | | | | MUI6 | | | | | | | | | | | | MUI7 | | | | | | | | | | | | MUI8 | | | | | | | | | | | 8109h | MUI9 | Reserved (1 Word) | | | | | | | | | | | EUI0 | | | | | | | | | | | | EUI1 | | | | | | | | | | | | EUI2 | | | | | | | | | | | 04001 04441 | EUI3 | | | | | | | | | | | 810Ah - 8111h | EUI4 | Optional External Unique Identifier (8 Words) | | | | | | | | | | | EUI5 | | | | | | | | | | | | EUI6 | | | | | | | | | | | | EUI7 | | | | | | | | | | | 8112h | TSLR1 <sup>(1)</sup> | Gain = $\frac{0.1C \times 256}{count}$ (low range setting) | | | | | | | | | | 8113h | TSLR2 <sup>(1)</sup> | Temperature sensor ADC reading at 90°C (low range setting) | | | | | | | | | | 8114h | TSLR3 <sup>(1)</sup> | Offset (low range setting) | | | | | | | | | | 8115h | TSHR1 <sup>(2)</sup> | Gain = $\frac{0.1C \times 256}{count}$ (high range setting) | | | | | | | | | | 8116h | TSHR2 <sup>(2)</sup> | Temperature sensor ADC reading at 90°C (high range setting) | | | | | | | | | | 8117h | TSHR3 <sup>(2)</sup> | Offset (high range setting) | | | | | | | | | | 8118h | FVRA1X | ADC FVR1 output voltage for 1x setting (in mV) | | | | | | | | | | 8119h | FVRA2X | ADC FVR1 output voltage for 2x setting (in mV) | | | | | | | | | | 811Ah | FVRA4X | ADC FVR1 output voltage for 4x setting (in mV) | | | | | | | | | | 811Bh | FVRC1X | Comparator FVR2 output voltage for 1x setting (in mV) | | | | | | | | | | 811Ch | FVRC2X | Comparator FVR2 output voltage for 2x setting (in mV) | | | | | | | | | | 811Dh | FVRC4X | Comparator FVR2 output voltage for 4x setting (in mV) | | | | | | | | | | 811Eh - 811Fh | Reserved | Reserved (2 Words) | | | | | | | | | | continued | | | |---------------|----------------|-----------------------------| | Address Range | Name of Region | Standard Device Information | | NI 4 | | | #### Notes: - TSLR: Addresses 8112h 8114h store the measurements for the low range setting of the temperature sensor at V<sub>DD</sub> = 3.0V, V<sub>REF</sub>+ = 2.048V from FVR1. - 2. TSHR: Addresses 8115h 8117h store the measurements for the high range setting of the temperature sensor at $V_{DD} = 3.0V$ , $V_{REF}$ + = 2.048V from FVR1. ### 9.1.3.1 Microchip Unique Identifier (MUI) The PIC16F180 devices are individually encoded during final manufacturing with a Microchip Unique Identifier (MUI). The MUI cannot be erased by a Bulk Erase command or any other user-accessible means. This feature allows for manufacturing traceability of Microchip Technology devices in applications where this is required. It may also be used by the application manufacturer for a number of functions that require unverified unique identification, such as: - · Tracking the device - · Unique serial number The MUI consists of nine program words. When taken together, these fields form a unique identifier. The MUI is stored in read-only locations, located between 8100h to 8108h in the DIA space. The DIA Table lists the addresses of the identifier words. **Important:** For applications requiring verified unique identification, contact the Microchip Technology sales office to create a serialized quick turn programming option. ### 9.1.3.2 External Unique Identifier (EUI) The EUI data is stored at locations 810Ah to 8111h in the program memory region. This region is an optional space for placing application specific information. The data is coded per customer requirements during manufacturing. The EUI cannot be erased by a Bulk Erase command. **Important:** Data is stored in this address range on receiving a request from the customer. The customer may contact the local sales representative or Field Applications Engineer, and provide them the unique identifier information that is required to be stored in this region. ### 9.1.3.3 Standard Parameters for the Temperature Sensor The purpose of the temperature indicator module is to provide a temperature-dependent voltage that can be measured by an analog module. The DIA Table contains standard parameters for the temperature sensor for low and high range. The values are measured during test and are unique to each device. The calibration data can be used to plot the approximate sensor output voltage, $V_{TSENSE}$ vs. Temperature curve. The "Temperature Indicator Module" chapter explains the operation of the Temperature Indicator module and defines terms such as the low range and high range settings of the sensor. ## 9.1.3.4 Fixed Voltage Reference Data The Fixed Voltage Reference (FVR) is a stable voltage reference, independent of $V_{DD}$ , with 1.024V, 2.048V or 4.096V selectable output levels. The output of the FVR can be configured to supply a reference voltage to the following: - ADC input channel - · ADC positive reference - Comparator positive input - Digital-to-Analog Converter (DAC) For more information on the FVR, refer to the "FVR - Fixed Voltage Reference" chapter. The DIA stores measured FVR voltages for this device in mV for the different buffer settings of 1x, 2x or 4x. FVRA1X stores the value of ADC FVR1 Output Voltage for 1x setting (in mV) - FVRA2X stores the value of ADC FVR1 Output Voltage for 2x setting (in mV) - FVRA4X stores the value of ADC FVR1 Output Voltage for 4x setting (in mV) - FVRC1X stores the value of Comparator FVR2 Output Voltage for 1x setting (in mV) - FVRC2X stores the value of Comparator FVR2 Output Voltage for 2x setting (in mV) - FVRC4X stores the value of Comparator FVR2 Output Voltage for 4x setting (in mV) ## 9.1.4 Device Configuration Information (DCI) The Device Configuration Information (DCI) is a dedicated region in the memory that holds information about the device, which is useful for programming and bootloader applications. The data stored in this region is read-only and cannot be modified/erased. Refer to the table below for complete DCI table addresses and description. Table 9-4. Device Configuration Information | Address | Name | Description | Va | lue | Units | |---------|---------|---------------------------------|-------------|-------------|--------| | Address | INAIIIE | Description | PIC16F180x4 | PIC16F180x5 | Office | | 8200h | ERSIZ | Erase Row Size | 3 | 2 | Words | | 8201h | WLSIZ | Number of write latches per row | 3 | Words | | | 8202h | URSIZ | Number of user erasable rows | 128 | 256 | Rows | | 8203h | EESIZ | Data EEPROM memory size | 12 | Bytes | | | 8204h | PCNT | Pin Count | 8/14 | Pins | | ### 9.1.4.1 DIA and DCI Access The DIA and DCI data are read-only and cannot be erased or modified. See the "NVMREG Access to DIA, DCI, User ID, DEV/REV ID, and Configuration Words" section in the "NVM - Nonvolatile Memory Control" chapter for more information on accessing these memory locations. Development tools, such as device programmers and debuggers, may be used to read the DIA and DCI regions, similar to the Device ID and Revision ID. ## 9.2 Data Memory Organization The data memory is partitioned into up to 64 memory banks with 128 bytes in each bank. Each bank consists of: - 12 core registers - Up to 20 Special Function Registers (SFR) - Up to 80 bytes of General Purpose RAM (GPR) - 16 bytes of common RAM Figure 9-3. Banked Memory Partition ### 9.2.1 Bank Selection The active bank is selected by writing the bank number into the Bank Select Register (BSR). All data memory can be accessed either directly via instructions that use the file registers, or indirectly via the two File Select Registers (FSRs). Data memory uses a 13-bit address. The upper six bits of the address define the Bank Address and the lower seven bits select the registers/RAM in that bank. ## 9.2.2 Core Registers The core registers contain the registers that directly affect the basic operation. The core registers occupy the first 12 addresses of every data memory bank. These registers are listed in the Core Registers table below. Table 9-5. Core Registers | Addresses in BANKx | Core Registers | |--------------------|----------------| | x00h or x80h | INDF0 | | x01h or x81h | INDF1 | | x02h or x82h | PCL | | x03h or x83h | STATUS | | x04h or x84h | FSR0L | | continued | | | | | | | | | | | | | |--------------------|----------------|--|--|--|--|--|--|--|--|--|--|--| | Addresses in BANKx | Core Registers | | | | | | | | | | | | | x05h or x85h | FSR0H | | | | | | | | | | | | | x06h or x86h | FSR1L | | | | | | | | | | | | | x07h or x87h | FSR1H | | | | | | | | | | | | | x08h or x88h | BSR | | | | | | | | | | | | | x09h or x89h | WREG | | | | | | | | | | | | | x0Ah or x8Ah | PCLATH | | | | | | | | | | | | | x0Bh or x8Bh | INTCON | | | | | | | | | | | | ## 9.2.3 Special Function Register The Special Function Registers (SFR) are registers used by the application to control the desired operation of peripheral functions in the device. The SFRs occupy the first 20 bytes of the data banks 0-59 and the first 100 bytes of the data banks 60-63, after the core registers. The SFRs associated with the operation of the peripherals are described in the appropriate peripheral chapter of this data sheet. ## 9.2.4 General Purpose RAM There are up to 80 bytes of GPR in each data memory bank. The general purpose RAM can be accessed in a non-banked method via the FSRs. This can simplify access to large memory structures. Refer to the "Linear Data Memory" section in the "Memory Organization" chapter for details about linear memory accessing. ### 9.2.5 Common RAM There are 16 bytes of common RAM accessible from all banks. ## 9.2.6 Device Memory Maps The memory maps for the devices in this data sheet are listed in the following figures. Figure 9-4. Memory Map Banks 0 - 7 | | BANK 0 | | BANK 1 | | BANK 2 | | BANK 3 | | BANK 4 | | BANK 5 | | BANK 6 | | BANK 7 | |------|----------------------|------|----------------|------|----------------|------|----------------|------|----------------|------|----------------|------|-------------------------|------|-------------------------| | 000h | | 080h | | 100h | | 180h | | 200h | | 280h | | 300h | | 380h | | | | Core Registers | | | | | | | | | | | | | | | | | 00Bh | | 08Bh | | 10Bh | | 18Bh | | 20Bh | | 28Bh | | 30Bh | | 38Bh | | | 00Ch | PORTA | 08Ch | PIR0 | 10Ch | | 18Ch | WDTCON | 20Ch | _ | 28Ch | TMR1L | 30Ch | T2TMR | 38Ch | CCPR1L | | 00Dh | PORTB <sup>(1)</sup> | 08Dh | PIR1 | 10Dh | _ | 18Dh | BORCON | 20Dh | - | 28Dh | TMR1H | 30Dh | T2PR | 38Dh | CCPR1H | | 00Eh | PORTC <sup>(2)</sup> | 08Eh | PIR2 | 10Eh | _ | 18Eh | PCON0 | 20Eh | OSCCON2 | 28Eh | T1CON | 30Eh | T2CON | 38Eh | CCP1CON | | 00Fh | - | 08Fh | PIR3 | 10Fh | - | 18Fh | PCON1 | 20Fh | OSCCON3 | 28Fh | T1GCON | 30Fh | T2HLT | 38Fh | CCP1CAP | | 010h | _ | 090h | PIR4 | 110h | _ | 190h | - | 210h | OSCSTAT | 290h | T1GATE | 310h | T2CLK | 390h | CCPR2L | | 011h | _ | 091h | _ | 111h | _ | 191h | - | 211h | OSCEN | 291h | T1CLK | 311h | T2RST | 391h | CCPR2H | | 012h | TRISA | 092h | - | 112h | _ | 192h | _ | 212h | OSCTUNE | 292h | TMR3L | 312h | T4TMR | 392h | CCP2CON | | 013h | TRISB <sup>(1)</sup> | 093h | _ | 113h | _ | 193h | _ | 213h | OSCFRQ | 293h | TMR3H | 313h | T4PR | 393h | CCP2CAP | | 014h | TRISC <sup>(2)</sup> | 094h | 1 | 114h | 1 | 194h | - | 214h | ACTCON | 294h | T3CON | 314h | T4CON | 394h | _ | | 015h | _ | 095h | _ | 115h | - | 195h | - | 215h | - | 295h | T3GCON | 315h | T4HLT | 395h | _ | | 016h | _ | 096h | PIE0 | 116h | _ | 196h | - | 216h | - | 296h | T3GATE | 316h | T4CLK | 396h | _ | | 017h | _ | 097h | PIE1 | 117h | - | 197h | - | 217h | - | 297h | T3CLK | 317h | T4RST | 397h | _ | | 018h | LATA | 098h | PIE2 | 118h | - | 198h | _ | 218h | - | 298h | 1 | 318h | T6TMR | 398h | _ | | 019h | LATB <sup>(1)</sup> | 099h | PIE3 | 119h | - | 199h | _ | 219h | - | 299h | - | 319h | T6PR | 399h | _ | | 01Ah | LATC <sup>(2)</sup> | 09Ah | PIE4 | 11Ah | - | 19Ah | - | 21Ah | - | 29Ah | - | 31Ah | T6CON | 39Ah | _ | | 01Bh | - | 09Bh | - | 11Bh | - | 19Bh | - | 21Bh | - | 29Bh | _ | 31Bh | T6HLT | 39Bh | _ | | 01Ch | _ | 09Ch | 1 | 11Ch | 1 | 19Ch | TMR0L | 21Ch | _ | 29Ch | _ | 31Ch | T6CLK | 39Ch | _ | | 01Dh | _ | 09Dh | 1 | 11Dh | 1 | 19Dh | TRMOH | 21Dh | - | 29Dh | - | 31Dh | T6RST | 39Dh | _ | | 01Eh | _ | 09Eh | 1 | 11Eh | 1 | 19Eh | T0CON0 | 21Eh | - | 29Eh | - | 31Eh | - | 39Eh | _ | | 01Fh | - | 09Fh | - | 11Fh | _ | 19Fh | T0CON1 | 21Fh | - | 29Fh | - | 31Fh | - | 39Fh | CCPTMRS0 | | 020h | | 0A0h | | 120h | | 1A0h | | 220h | | 2A0h | | 320h | General | 3A0h | | | | | | | | | | | | | | | | Purpose | | | | | | | | | | | | | | | | | Registers | | | | | General | | General | | General | | General | | General | | General | 32Fh | 16 Bytes | | General | | | Purpose | | Purpose | | Purpose | | Purpose | | Purpose | | Purpose | 330h | | | Purpose | | | Registers | | Registers | | Registers | | Registers | | Registers | | Registers | | General | | Registers | | | 80 Bytes | | 80 Bytes | | 80 Bytes | | 80 Bytes | | 80 Bytes | | 80 Bytes | | Purpose | | 80 Bytes <sup>(3)</sup> | | | | | | | | | | | | | | | Registers | | | | | | | | | | | | | | | | | 64 Bytes <sup>(3)</sup> | | | | 06Fh | | 0EFh | | 16Fh | | 1EFh | | 26Fh | | 2EFh | | 36Fh | | 3EFh | L | | 070h | Common RAM | 0F0h | Common RAM | 170h | Common RAM | 1F0h | Common RAM | 270h | Common RAM | 2F0h | Common RAM | 370h | Common RAM | 3F0h | Common RAM | | 075 | (Accesses | OFF | (Accesses | 175 | (Accesses | 155 | (Accesses | 275 | (Accesses | 2557 | (Accesses | 275 | (Accesses | 3FFh | (Accesses | | 07Fh | 70h-7Fh) | 0FFh | 70h-7Fh) | 17Fh | 70h-7Fh) | 1FFh | 70h-7Fh) | 27Fh | 70h-7Fh) | 2FFh | 70h-7Fh) | 37Fh | 70h-7Fh) | 3FFN | 70h-7Fh) | 1. 20-pin devices only 2. 14/16/20-pin devices only 3. Not available on PIC16F18044 Legend: Unimplemented data memory locations, read as '0' Figure 9-5. Memory Map Banks 8 - 15 | | BANK 8 | | BANK 9 | | BANK 10 | | BANK 11 | | BANK 12 | | BANK 13 | | BANK 14 | | BANK 15 | |--------------|-------------------------|--------------|-------------------------|--------------|-------------------------|--------------|-------------------------|--------------|-------------------------|--------------|----------------------|---------------|----------------|--------------|----------------| | 400h | | 480h | | 500h | | 580h | | 600h | | 680h | | 700h | | 780h | | | | Core Registers | | | | | | | | | | | | | | | | | 40Bh | PWM3DCI | 48Bh | NCO1ACCI | 50Bh | CWG1CLK | 58Bh<br>58Ch | CLCnCON | 60Bh | RC1REG | 68Bh | SSP1BUF | 70Bh | | 78Bh | _ | | 40Ch<br>40Dh | PWM3DCL<br>PWM3DCH | 48Ch<br>48Dh | NCO1ACCL<br>NCO1ACCH | 50Ch<br>50Dh | CWG1CLK | 58Ch<br>58Dh | CLCnCON | 60Ch | TX1REG | 68Ch<br>68Dh | SSP1BUF<br>SSP1ADD | 70Ch<br>70Dh | - | 78Ch<br>78Dh | | | 40Dh<br>40Eh | PWM3DCH<br>PWM3CON | 48Dh<br>48Eh | NCO1ACCH<br>NCO1ACCU | 50Dh | CWG1SM<br>CWG1DBR | 58Dh<br>58Eh | CLCNPOL | 60Dh<br>60Eh | SP1BRGL | 68Eh | SSP1ADD<br>SSP1MSK | 70Dh<br>70Eh | | 78Eh | | | 40EH | PWM4DCI | 48Fh | NCO1NCL | 50Fh | CWG1DBR<br>CWG1DBF | 58Fh | CLCHSELU<br>CLCnSFL1 | 60Fh | SP1BRGL<br>SP1BRGH | 68Fh | SSP1NISK<br>SSP1STAT | 70Fh | | 78Fh | | | 40FN<br>410h | PWM4DCL<br>PWM4DCH | 490h | NCO1INCH | 510h | CWG1DBF<br>CWG1CON0 | 590h | CLCnSEL1<br>CLCnSEL2 | 610h | RC1STA | 690h | SSP1STAT<br>SSP1CON1 | 70FII<br>710h | | 790h | | | 411h | PWM4CON | 491h | NCO1INCU | 511h | CWG1CON1 | 591h | CLCnSEL3 | 611h | TX1STA | 691h | SSP1CON1<br>SSP1CON2 | 711h | | 791h | | | 411h | PWM5DCL | 491h | NCO1CON | 511h | CWG1AS0 | 592h | CLCnGLS0 | 612h | BAUD1CON | 692h | SSP1CON2<br>SSP1CON3 | 711h | | 791h | | | 413h | PWM5DCH | 493h | NCO1CLK | 513h | CWG1AS1 | 593h | CLCnGLS1 | 613h | - | 693h | - | 713h | _ | 793h | _ | | 414h | PWM5CON | 494h | - | 514h | CWG1STR | 594h | CLCnGLS2 | 614h | _ | 694h | _ | 714h | _ | 794h | _ | | 415h | _ | 495h | | 515h | - | 595h | CLCnGLS3 | 615h | _ | 695h | _ | 715h | _ | 795h | _ | | 416h | _ | 496h | _ | 516h | _ | 596h | CLCSELECT | 616h | RC2REG | 696h | SSP2BUF | 716h | _ | 796h | _ | | 417h | _ | 497h | _ | 517h | _ | 597h | CLCDATA | 617h | TX2REG | 697h | SSP2ADD | 717h | _ | 797h | _ | | 418h | _ | 498h | _ | 518h | _ | 598h | _ | 618h | SP2BRGL | 698h | SSP2MSK | 718h | _ | 798h | _ | | 419h | _ | 499h | _ | 519h | - | 599h | _ | 619h | SP2BRGH | 699h | SSP2STAT | 719h | _ | 799h | _ | | 41Ah | _ | 49Ah | _ | 51Ah | - | 59Ah | _ | 61Ah | RC2STA | 69Ah | SSP2CON1 | 71Ah | - | 79Ah | - | | 41Bh | _ | 49Bh | - | 51Bh | - | 59Bh | _ | 61Bh | TX2STA | 69Bh | SSP2CON2 | 71Bh | - | 79Bh | - | | 41Ch | _ | 49Ch | - | 51Ch | - | 59Ch | _ | 61Ch | BAUD2CON | 69Ch | SSP2CON3 | 71Ch | - | 79Ch | - | | 41Dh | - | 49Dh | - | 51Dh | - | 59Dh | - | 61Dh | - | 69Dh | _ | 71Dh | - | 79Dh | - | | 41Eh | - | 49Eh | - | 51Eh | - | 59Eh | ı | 61Eh | - | 69Eh | _ | 71Eh | - | 79Eh | _ | | 41Fh | PWMTMRS0 | 49Fh | - | 51Fh | - | 59Fh | 1 | 61Fh | _ | 69Fh | 1 | 71Fh | _ | 79Fh | _ | | 420h | | 4A0h | | 520h | | 5A0h | | 620h | General | 6A0h | | 720h | | 7A0h | | | | | | | | | | | | Purpose | | | | | | | | | General | | General | | General | | General | | Registers | | | | | | | | | Purpose | | Purpose | | Purpose | | Purpose | 64Fh | 48 Bytes <sup>(1)</sup> | | Unimplemented | | Unimplemented | | Unimplemented | | | Registers | | Registers | | Registers | | Registers | 650h | | | Read as '0' | | Read as '0' | | Read as '0' | | | 80 Bytes <sup>(1)</sup> | | 80 Bytes <sup>(1)</sup> | | 80 Bytes <sup>(1)</sup> | | 80 Bytes <sup>(1)</sup> | | Unimplemented | | | | | | | | | | | | | | | | | Read as '0' | | | | | | | | 46Fh | | 4EFh | | 56Fh | | 5EFh | | 66Fh | | 6EFh | | 76Fh | | 7EFh | | | 470h | Common RAM | 4F0h | Common RAM | 570h | Common RAM | 5F0h | Common RAM | 670h | Common RAM | 6F0h | Common RAM | 770h | Common RAM | 7F0h | Common RAM | | | (Accesses 47Fh | 70h-7Fh) | 4FFh | 70h-7Fh) | 57Fh | 70h-7Fh) | 5FFh | 70h-7Fh) | 67Fh | 70h-7Fh) | 6FFh | 70h-7Fh) | 77Fh | 70h-7Fh) | 7FFh | 70h-7Fh) | Note: 1. Not available on PIC16F18044 Figure 9-6. Memory Map Banks 16 - 23 | | BANK 16 | | BANK 17 | | BANK 18 | | BANK 19 | | BANK 20 | | BANK 21 | | BANK 22 | | BANK 23 | |---------|-----------------|------|----------------|-------|-----------------------------------------|--------------|----------------|-------|----------------|------|-----------------------------------------|------|----------------|-------|----------------| | 800h | | 880h | | 900h | | 980h | | A00h | | A80h | | B00h | | B80h | | | | Core Registers | | | | | | | | | | | | | | | | | 80Bh | | 88Bh | | 90Bh | | 98Bh | | A0Bh | | A8Bh | | B0Bh | | B8Bh | | | 80Ch | _ | 88Ch | _ | 90Ch | _ | 98Ch | _ | A0Ch | _ | A8Ch | - | B0Ch | _ | B8Ch | _ | | 80Dh | _ | 88Dh | _ | 90Dh | _ | 98Dh | _ | A0Dh | _ | A8Dh | _ | BODh | _ | B8Dh | _ | | 80Eh | _ | 88Eh | _ | 90Eh | _ | 98Eh | _ | A0Eh | _ | A8Eh | - | B0Eh | _ | B8Eh | _ | | 80Fh | _ | 88Fh | _ | 90Fh | _ | 98Fh | _ | A0Fh | _ | A8Fh | _ | B0Fh | _ | B8Fh | _ | | 810h | _ | 890h | _ | 910h | _ | 990h | _ | A10h | _ | A90h | _ | B10h | _ | B90h | _ | | 811h | _ | 891h | _ | 911h | _ | 991h | _ | A11h | _ | A91h | _ | B11h | _ | B91h | _ | | 812h | _ | 892h | | 912h | _ | 992h | _ | A12h | _ | A92h | _ | B12h | _ | B92h | _ | | 813h | | 893h | | 913h | _ | 993h | | A13h | _ | A93h | _ | B13h | _ | B93h | _ | | 814h | _ | 894h | | 914h | _ | 994h | _ | A14h | _ | A94h | | B14h | _ | B94h | _ | | 815h | _ | 895h | | 915h | _ | 995h | _ | A15h | _ | A95h | | B15h | _ | B95h | _ | | 816h | | 896h | | 916h | _ | 996h | | A16h | _ | A96h | _ | B16h | _ | B96h | _ | | 817h | | 897h | | 917h | _ | 997h | _ | A17h | _ | A97h | | B17h | _ | B97h | _ | | 818h | - | 898h | _ | 918h | _ | 998h | _ | A18h | _ | A98h | _ | B18h | - | B98h | _ | | 819h | | 899h | | 919h | _ | 999h | | A19h | _ | A99h | | B19h | _ | B99h | _ | | 81Ah | | 89Ah | | 91Ah | _ | 99Ah | _ | A1Ah | _ | A9Ah | | B1Ah | _ | B9Ah | _ | | 81Bh | | 89Bh | | 91Bh | _ | 99Bh | _ | A1Bh | _ | A9Bh | - | B1Bh | _ | B9Bh | _ | | 81Ch | | 89Ch | | 91Ch | - | 99Ch | _ | A1Ch | _ | A9Ch | - | B1Ch | _ | B9Ch | _ | | 81Dh | - | 89Dh | <u> </u> | 91Dh | _ | 99Dh | _ | A1Dh | _ | A9Dh | - | B1Dh | _ | B9Dh | _ | | 81Eh | - | 89Eh | | 91Eh | _ | 99Eh<br>99Fh | _ | A1Eh | _ | A9Eh | - | B1Eh | _ | B9Eh | _ | | 81Fh | | 89Fh | _ | 91Fh | _ | | _ | A1Fh | _ | A9Fh | - | B1Fh | _ | B9Fh | _ | | 820h | | 8A0h | | 920h | | 9A0h | | A20h | | AA0h | | B20h | | BA0h | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Unimplemented | Read as '0' | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 86Fh | | 8EFh | | 96Fh | | 9FFh | | A6Fh | | AEFh | | B6Fh | | BEFh | | | 870h | Common RAM | 8F0h | Common RAM | 970h | Common RAM | 9F0h | Common RAM | A70h | Common RAM | AF0h | Common RAM | B70h | Common RAM | BF0h | Common RAM | | 27011 | (Accesses | 2. 0 | (Accesses | 27011 | (Accesses | 2.011 | (Accesses | , 011 | (Accesses | 011 | (Accesses | | (Accesses | 2.011 | (Accesses | | 87Fh | 70h-7Fh) | 8FFh | 70h-7Fh) | 97Fh | 70h-7Fh) | 9FFh | 70h-7Fh) | A7Fh | 70h-7Fh) | AFFh | 70h-7Fh) | B7Fh | 70h-7Fh) | BFFh | 70h-7Fh) | | ١ ٠٠٠٠٠ | , , , , , , , , | J | , , , | 1 3, | , , , , , , , , , , , , , , , , , , , , | 3 | 7511 7111, | | 7011 71117 | 7 | , , , , , , , , , , , , , , , , , , , , | 5, | 7011 71117 | 5 | , , , , , , , | Legend: Unimplemented data memory locations, read as '0' Figure 9-7. Memory Map Banks 24 - 31 | | BANK 24 | | BANK 25 | | BANK 26 | | BANK 27 | | BANK 28 | | BANK 29 | | BANK 30 | | BANK 31 | |------|----------------|------|----------------|------|----------------|------|----------------|------|----------------|------|----------------|------|----------------|------|----------------| | C00h | Core Registers | C80h | Core Registers | D00h | Core Registers | D80h | Core Registers | E00h | Core Registers | E80h | Core Registers | F00h | Core Registers | F80h | Core Registers | | COBh | | C8Bh | | DOBh | | D8Bh | | EOBh | | E8Bh | | FOBh | | F8Bh | | | COCh | - | C8Ch | - | D0Ch | - | D8Ch | - | E0Ch | - | E8Ch | - | F0Ch | - | F8Ch | _ | | CODh | - | C8Dh | - | DODh | _ | D8Dh | _ | EODh | _ | E8Dh | _ | FODh | _ | F8Dh | _ | | C0Eh | - | C8Eh | - | D0Eh | _ | D8Eh | _ | E0Eh | _ | E8Eh | - | F0Eh | - | F8Eh | _ | | C0Fh | - | C8Fh | - | D0Fh | - | D8Fh | - | E0Fh | - | E8Fh | - | F0Fh | - | F8Fh | - | | C10h | - | C90h | - | D10h | _ | D90h | - | E10h | - | E90h | - | F10h | - | F90h | - | | C11h | _ | C91h | _ | D11h | _ | D91h | _ | E11h | - | E91h | _ | F11h | - | F91h | _ | | C12h | _ | C92h | - | D12h | _ | D92h | _ | E12h | 1 | E92h | 1 | F12h | 1 | F92h | _ | | C13h | _ | C93h | - | D13h | - | D93h | - | E13h | - | E93h | - | F13h | _ | F93h | _ | | C14h | _ | C94h | - | D14h | - | D94h | - | E14h | - | E94h | - | F14h | _ | F94h | _ | | C15h | _ | C95h | - | D15h | - | D95h | - | E15h | - | E95h | - | F15h | - | F95h | _ | | C16h | _ | C96h | - | D16h | - | D96h | - | E16h | - | E96h | - | F16h | _ | F96h | _ | | C17h | _ | C97h | - | D17h | - | D97h | - | E17h | _ | E97h | _ | F17h | _ | F97h | _ | | C18h | _ | C98h | - | D18h | - | D98h | - | E18h | _ | E98h | _ | F18h | _ | F98h | _ | | C19h | _ | C99h | - | D19h | - | D99h | - | E19h | _ | E99h | _ | F19h | _ | F99h | _ | | C1Ah | _ | C9Ah | _ | D1Ah | _ | D9Ah | _ | E1Ah | _ | E9Ah | _ | F1Ah | _ | F9Ah | _ | | C1Bh | _ | C9Bh | _ | D1Bh | _ | D9Bh | _ | E1Bh | _ | E9Bh | _ | F1Bh | _ | F9Bh | _ | | C1Ch | _ | C9Ch | _ | D1Ch | _ | D9Ch | _ | E1Ch | _ | E9Ch | _ | F1Ch | _ | F9Ch | _ | | C1Dh | _ | C9Dh | _ | D1Dh | _ | D9Dh | - | E1Dh | _ | E9Dh | _ | F1Dh | _ | F9Dh | _ | | C1Eh | _ | C9Eh | _ | D1Eh | _ | D9Eh | - | E1Eh | _ | E9Eh | _ | F1Eh | _ | F9Eh | _ | | C1Fh | _ | C9Fh | _ | D1Fh | _ | D9Fh | _ | E1Fh | _ | E9Fh | _ | F1Fh | _ | F9Fh | _ | | C20h | | CA0h | | D20h | | DA0h | | E20h | | EA0h | | F20h | | FA0h | | | | Unimplemented | CBFh | Unimplemented | | Read as '0' | CC0h | Read as '0' | | | | | | | | | | | | | | | | | | C6Fh | | CEEh | | D6Fh | | DEFh | | E6Fh | | EEFh | | F6Fh | | FEFh | | | C70h | Common RAM | CF0h | Common RAM | D70h | Common RAM | DF0h | Common RAM | E70h | Common RAM | EF0h | Common RAM | F70h | Common RAM | FF0h | Common RAM | | | (Accesses C7Fh | 70h-7Fh) | CFFh | 70h-7Fh) | D7Fh | 70h-7Fh) | DFFh | 70h-7Fh) | E7Fh | 70h-7Fh) | EFFh | 70h-7Fh) | F7Fh | 70h-7Fh) | FFFh | 70h-7Fh) | Figure 9-8. Memory Map Banks 32 - 39 | | BANK 32 | | BANK 33 | | BANK 34 | | BANK 35 | | BANK 36 | | BANK 37 | | BANK 38 | 1 | BANK 39 | |-------|----------------|-------|----------------|-------|----------------|-------|----------------|-------|----------------|-------|----------------|-------|----------------|-------|----------------| | 1000h | | 1080h | | 1100h | | 1180h | | 1200h | | 1280h | | 1300h | | 1380h | | | | Core Registers | | | | | | | | | | | | | | | | | 100Bh | | 108Bh | | 110Bh | | 118Bh | | 120Bh | | 128Bh | | 130Bh | | 138Bh | | | 100Ch | FVRCON | 108Ch | CM1CON0 | 110Ch | DAC1CON0 | 118Ch | - | 120Ch | - | 128Ch | _ | 130Ch | - | 138Ch | _ | | 100Dh | CPCON | 108Dh | CM1CON1 | 110Dh | DAC1DATL | 118Dh | - | 120Dh | - | 128Dh | - | 130Dh | - | 138Dh | _ | | 100Eh | - | 108Eh | CM1NCH | 110Eh | - | 118Eh | - | 120Eh | - | 128Eh | - | 130Eh | - | 138Eh | _ | | 100Fh | - | 108Fh | CM1PCH | 110Fh | - | 118Fh | - | 120Fh | - | 128Fh | - | 130Fh | - | 138Fh | _ | | 1010h | - | 1090h | - | 1110h | - | 1190h | - | 1210h | - | 1290h | - | 1310h | - | 1390h | - | | 1011h | - | 1091h | - | 1111h | - | 1191h | - | 1211h | - | 1291h | - | 1311h | - | 1391h | - | | 1012h | - | 1092h | - | 1112h | - | 1192h | - | 1212h | - | 1292h | - | 1312h | - | 1392h | - | | 1013h | - | 1093h | - | 1113h | - | 1193h | - | 1213h | - | 1293h | - | 1313h | - | 1393h | - | | 1014h | - | 1094h | - | 1114h | - | 1194h | - | 1214h | - | 1294h | - | 1314h | - | 1394h | - | | 1015h | - | 1095h | - | 1115h | _ | 1195h | _ | 1215h | - | 1295h | _ | 1315h | - | 1395h | _ | | 1016h | - | 1096h | - | 1116h | _ | 1196h | _ | 1216h | - | 1296h | _ | 1316h | - | 1396h | _ | | 1017h | - | 1097h | - | 1117h | _ | 1197h | - | 1217h | - | 1297h | _ | 1317h | - | 1397h | _ | | 1018h | _ | 1098h | _ | 1118h | - | 1198h | _ | 1218h | - | 1298h | _ | 1318h | - | 1398h | - | | 1019h | - | 1099h | - | 1119h | - | 1199h | - | 1219h | - | 1299h | - | 1319h | - | 1399h | - | | 101Ah | - | 109Ah | - | 111Ah | - | 119Ah | - | 121Ah | - | 129Ah | - | 131Ah | - | 139Ah | - | | 101Bh | - | 109Bh | - | 111Bh | - | 119Bh | _ | 121Bh | - | 129Bh | _ | 131Bh | - | 139Bh | _ | | 101Ch | - | 109Ch | - | 111Ch | - | 119Ch | _ | 121Ch | - | 129Ch | _ | 131Ch | - | 139Ch | _ | | 101Dh | - | 109Dh | - | 111Dh | _ | 119Dh | - | 121Dh | - | 129Dh | _ | 131Dh | - | 139Dh | _ | | 101Eh | - | 109Eh | - | 111Eh | _ | 119Eh | - | 121Eh | - | 129Eh | _ | 131Eh | - | 139Eh | _ | | 101Fh | ZCDCON | 109Fh | CMOUT | 111Fh | | 119Fh | | 121Fh | _ | 129Fh | _ | 131Fh | _ | 139Fh | _ | | 1020h | | 10A0h | | 1120h | | 11A0h | | 1220h | | 12A0h | | 1320h | | 13A0h | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Unimplemented | Read as '0' | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 106Fh | | 10EFh | | 116Fh | | 11EFh | | 126Fh | | 12EFh | | 136Fh | | 13EFh | | | 1070h | Common RAM | 10F0h | Common RAM | 1170h | Common RAM | 11F0h | Common RAM | 1270h | Common RAM | 12F0h | Common RAM | 1370h | Common RAM | 13F0h | Common RAM | | | (Accesses 107Fh | 70h-7Fh) | 10FFh | 70h-7Fh) | 117Fh | 70h-7Fh) | 11FFh | 70h-7Fh) | 127Fh | 70h-7Fh) | 12FFh | 70h-7Fh) | 137Fh | 70h-7Fh) | 13FFh | 70h-7Fh) | | | | | | | | | | | | | | | | | | Legend: Unimplemented data memory locations, read as '0' Figure 9-9. Memory Map Banks 40 - 47 | | BANK 40 | | BANK 41 | | BANK 42 | | BANK 43 | | BANK 44 | | BANK 45 | | BANK 46 | 1 | BANK 47 | |--------|------------------------------|--------|------------------------------|--------|------------------------------|--------|------------------------------|--------|------------------------------|--------|------------------------------|--------|------------------------------|--------|------------------------------| | 1400h | Core Registers | 1480h | Core Registers | 1500h | Core Registers | 1580h | Core Registers | 1600h | Core Registers | 1680h | Core Registers | 1700h | Core Registers | 1780h | Core Registers | | 140Bh | | 148Bh | | 150Bh | | 158Bh | | 160Bh | | 168Bh | | 170Bh | | 178Bh | | | 140Ch | - | 148Ch | - | 150Ch | - | 158Ch | - | 160Ch | - | 168Ch | _ | 170Ch | - | 178Ch | - | | 140Dh | _ | 148Dh | - | 150Dh | - | 158Dh | - | 160Dh | _ | 168Dh | - | 170Dh | - | 178Dh | _ | | 140Eh | - | 148Eh | - | 150Eh | _ | 158Eh | _ | 160Eh | _ | 168Eh | - | 170Eh | 1 | 178Eh | _ | | 140Fh | - | 148Fh | ı | 150Fh | 1 | 158Fh | - | 160Fh | ı | 168Fh | 1 | 170Fh | - | 178Fh | _ | | 1410h | - | 1490h | _ | 1510h | _ | 1590h | - | 1610h | - | 1690h | - | 1710h | 1 | 1790h | _ | | 1411h | _ | 1491h | - | 1511h | - | 1591h | - | 1611h | _ | 1691h | - | 1711h | ı | 1791h | _ | | 1412h | - | 1492h | - | 1512h | - | 1592h | - | 1612h | - | 1692h | - | 1712h | - | 1792h | _ | | 1413h | - | 1493h | - | 1513h | _ | 1593h | | 1613h | - | 1693h | _ | 1713h | - | 1793h | _ | | 1414h | _ | 1494h | _ | 1514h | _ | 1594h | | 1614h | _ | 1694h | _ | 1714h | _ | 1794h | _ | | 1415h | _ | 1495h | _ | 1515h | _ | 1595h | | 1615h | _ | 1695h | _ | 1715h | - | 1795h | _ | | 1416h | _ | 1496h | _ | 1516h | _ | 1596h | | 1616h | _ | 1696h | _ | 1716h | - | 1796h | _ | | 1417h | _ | 1497h | _ | 1517h | _ | 1597h | | 1617h | _ | 1697h | _ | 1717h | - | 1797h | _ | | 1418h | _ | 1498h | _ | 1518h | _ | 1598h | | 1618h | _ | 1698h | _ | 1718h | - | 1798h | _ | | 1419h | _ | 1499h | _ | 1519h | _ | 1599h | | 1619h | _ | 1699h | _ | 1719h | - | 1799h | _ | | 141Ah | _ | 149Ah | - | 151Ah | _ | 159Ah | | 161Ah | _ | 169Ah | _ | 171Ah | - | 179Ah | _ | | 141Bh | | 149Bh | _ | 151Bh | _ | 159Bh | | 161Bh | _ | 169Bh | _ | 171Bh | - | 179Bh | | | 141Ch | | 149Ch | _ | 151Ch | _ | 159Ch | | 161Ch | _ | 169Ch | _ | 171Ch | _ | 179Ch | | | 141Dh | | 149Dh | _ | 151Dh | _ | 159Dh | | 161Dh | _ | 169Dh | _ | 171Dh | _ | 179Dh | | | 141Eh | | 149Eh | _ | 151Eh | | 159Eh | | 161Eh | _ | 169Eh | _ | 171Eh | _ | 179Eh | | | 141Fh | | 149Fh | _ | 151Fh | _ | 159Fh | | 161Fh | _ | 169Fh | _ | 171Fh | _ | 179Fh | _ | | 1420h | | 14A0h | | 1520h | | 15A0h | | 1620h | | 16A0h | | 1720h | | 17A0h | | | | Unimplemented<br>Read as '0' 146Fh | | 14EFh | | 156Fh | | 15EFh | | 166Fh | | 16EFh | | 176Fh | | 17EFh | | | 1470h | Common RAM | 14F0h | Common RAM | 1570h | Common RAM | 15F0h | Common RAM | 1670h | Common RAM | 16F0h | Common RAM | 1770h | Common RAM | 17F0h | Common RAM | | 14/011 | (Accesses | 141011 | (Accesses | 137011 | (Accesses | 137011 | (Accesses | 10/011 | (Accesses | 101011 | (Accesses | 177011 | (Accesses | 1,1011 | (Accesses | | 147Fh | 70h-7Fh) | 14FFh | 70h-7Fh) | 157Fh | 70h-7Fh) | 15FFh | 70h-7Fh) | 167Fh | 70h-7Fh) | 16FFh | 70h-7Fh) | 177Fh | 70h-7Fh) | 17FFh | 70h-7Fh) | | 14/11 | 70H-7FH) | TALLU | /UII-/FII) | 13/11 | /UII-/FII) | TOLLII | /UII-/FII) | 10/11 | /UII-/FII) | TOFFII | /UII-/FII) | 1//// | /UII-/FII) | 1/11/ | /UII=/FII) | Figure 9-10. Memory Map Banks 48 - 55 | 1800h | Core Registers | 1880h | | 1900h | | | | | | | | | | | | |-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------|-------------------------|-------------------------------------| | | | | Core Registers | 130011 | Core Registers | 1980h | Core Registers | 1A00h | Core Registers | 1A80h | Core Registers | 1B00h | Core Registers | 1B80h | Core Registers | | 180Bh | | 188Bh | | 190Bh | | 198Bh | | 1A0Bh | | 1A8Bh | | 1B0Bh | | 1B8Bh | | | 180Ch | - | 188Ch | - | 190Ch | _ | 198Ch | _ | 1A0Ch | - | 1A8Ch | _ | 1B0Ch | _ | 1B8Ch | - | | 180Dh | - | 188Dh | _ | 190Dh | 1 | 198Dh | 1 | 1A0Dh | 1 | 1A8Dh | - | 1B0Dh | - | 1B8Dh | _ | | 180Eh | - | 188Eh | - | 190Eh | - | 198Eh | - | 1A0Eh | - | 1A8Eh | - | 1B0Eh | - | 1B8Eh | _ | | 180Fh | - | 188Fh | - | 190Fh | - | 198Fh | - | 1A0Fh | - | 1A8Fh | - | 1B0Fh | - | 1B8Fh | _ | | 1810h | - | 1890h | - | 1910h | - | 1990h | - | 1A10h | 1 | 1A90h | 1 | 1B10h | - | 1B90h | _ | | 1811h | _ | 1891h | _ | 1911h | ı | 1991h | - | 1A11h | ı | 1A91h | 1 | 1B11h | - | 1B91h | _ | | 1812h | - | 1892h | - | 1912h | _ | 1992h | - | 1A12h | - | 1A92h | - | 1B12h | - | 1B92h | _ | | 1813h | _ | 1893h | - | 1913h | _ | 1993h | _ | 1A13h | _ | 1A93h | _ | 1B13h | _ | 1B93h | _ | | 1814h | - | 1894h | - | 1914h | _ | 1994h | _ | 1A14h | _ | 1A94h | _ | 1B14h | _ | 1B94h | _ | | 1815h | - | 1895h | - | 1915h | - | 1995h | - | 1A15h | - | 1A95h | _ | 1B15h | - | 1B95h | _ | | 1816h | - | 1896h | - | 1916h | - | 1996h | - | 1A16h | - | 1A96h | - | 1B16h | - | 1B96h | _ | | 1817h | _ | 1897h | _ | 1917h | ı | 1997h | 1 | 1A17h | ı | 1A97h | 1 | 1B17h | 1 | 1B97h | _ | | 1818h | _ | 1898h | _ | 1918h | ı | 1998h | 1 | 1A18h | ı | 1A98h | 1 | 1B18h | 1 | 1B98h | _ | | 1819h | _ | 1899h | - | 1919h | _ | 1999h | _ | 1A19h | _ | 1A99h | _ | 1B19h | _ | 1B99h | _ | | 181Ah | _ | 189Ah | - | 191Ah | _ | 199Ah | _ | 1A1Ah | _ | 1A9Ah | _ | 1B1Ah | _ | 1B9Ah | _ | | 181Bh | - | 189Bh | - | 191Bh | _ | 199Bh | - | 1A1Bh | - | 1A9Bh | - | 1B1Bh | - | 1B9Bh | _ | | 181Ch | - | 189Ch | - | 191Ch | 1 | 199Ch | 1 | 1A1Ch | 1 | 1A9Ch | - | 1B1Ch | - | 1B9Ch | _ | | 181Dh | _ | 189Dh | - | 191Dh | ı | 199Dh | 1 | 1A1Dh | ı | 1A9Dh | 1 | 1B1Dh | 1 | 1B9Dh | _ | | 181Eh | _ | 189Eh | - | 191Eh | ı | 199Eh | 1 | 1A1Eh | 1 | 1A9Eh | 1 | 1B1Eh | 1 | 1B9Eh | _ | | 181Fh | _ | 189Fh | _ | 191Fh | 1 | 199Fh | - | 1A1Fh | 1 | 1A9Fh | - | 1B1Fh | - | 1B9Fh | _ | | 1820h | | 18A0h | | 1920h | | 19A0h | | 1A20h | | 1AA0h | | 1B20h | | 1BA0h | | | | Unimplemented<br>Read as '0' 186Fh<br>1870h<br>187Fh | Common RAM<br>(Accesses<br>70h-7Fh) | 18EFh<br>18F0h<br>18FFh | Common RAM<br>(Accesses<br>70h-7Fh) | 196Fh<br>1970h<br>197Fh | Common RAM<br>(Accesses<br>70h-7Fh) | 19EFh<br>19F0h<br>19FFh | Common RAM<br>(Accesses<br>70h-7Fh) | 1A6Fh<br>1A70h<br>1A7Fh | Common RAM<br>(Accesses<br>70h-7Fh) | 1AEFh<br>1AF0h<br>1AFFh | Common RAM<br>(Accesses<br>70h-7Fh) | 186Fh<br>1870h<br>187Fh | Common RAM<br>(Accesses<br>70h-7Fh) | 1BEFh<br>1BF0h<br>1BFFh | Common RAM<br>(Accesses<br>70h-7Fh) | Legend: Figure 9-11. Memory Map Banks 56 - 63 | | BANK 56 | | BANK 57 | | BANK 58 | | BANK 59 | | BANK 60 | | BANK 61 | | BANK 62 | | BANK 63 | |-------|-------------------------|-------|------------------------------|----------------|-------------------------|--------|-------------------------|-------|-------------------------------------|-------|-------------------------|-------|-------------------------|----------------|-------------------------| | 1C00h | | 1C80h | | 1D00h | | 1D80h | | 1E00h | | 1E80h | | 1F00h | | 1F80h | | | | Core Registers | | Core Registers | 1D0Bh | Core Registers | | Core Registers | | Core Registers | | Core Registers | | Core Registers | | Core Registers | | 1C0Bh | | 1C8Bh | | 100011 | | 1D8Bh | | 1E0Bh | | 1E8Bh | | 1F0Bh | | 1F8Bh | | | 1C0Ch | | 1C8Ch | NVMADRL | 1D0Ch | ADLTHL | 1D8Ch | RAOPPS | 1E0Ch | | 1E8Ch | | 1F0Ch | UMTOAP | 1F8Ch | | | | | 1C8Dh | NVMADRH | 1D0Dh | ADLTHH | 1D8Dh | RA1PPS | | | | | 1F0Dh | UMTOAL | | | | | | 1C8Eh | NVMDATL | 1D0Eh | ADUTHL | 1D8Eh | RA2PPS | | | | | 1F0Eh | UMTOAH | | | | | | 1C8Fh | NVMDATH | 1D0Fh | ADUTHH | 1D8Fh | _ | | | | | 1F0Fh | | | | | | | 1C90h | NVMCON1 | 1D10h | ADERRL | 1D90h | RA4PPS | | | | | | | | | | | | 1C91h | NVMCON2 | 1D11h<br>1D12h | ADERRH | 1D91h | RA5PPS | | | | | | | | | | | | 1C92h | | 1D12h<br>1D13h | ADSTPTL<br>ADSTPTH | 1D92h | Unimplemented | | | | | | | | | | | | | | 1D13h | ADSTETH | 1D97h | Read as '0' | | | | | | | | | | | | | Unimalamental | 1D15h | ADFLTRH | 1D98h | RB4PPS <sup>(1)</sup> | | | | | | | | | | | | | Unimplemented<br>Read as '0' | 1D16h | ADACCL | 1D99h | RB5PPS <sup>(1)</sup> | | | | | | | | | | | | | Redu as 0 | 1D17h | ADACCH | 1D9Ah | RB6PPS <sup>(1)</sup> | 1 | | | | | | | | | | | | | 1D18h | ADACCU | 1D9Bh | RB7PPS <sup>(1)</sup> | | | | | | | | | | | | 1C99h | | 1D19h | ADCNT | 1D9Ch | RCOPPS <sup>(2)</sup> | | | | | | | | | | | | 1C9Ah | CRCDATAL | 1D13H | ADRPT | 1D9Ch | RC1PPS <sup>(2)</sup> | | | | | | | | Unimplemented | | | | 1C9Bh | CRCDATAL | 1D1Bh | ADREVL | 1D9Eh | RC2PPS <sup>(2)</sup> | | | | | | | | Read as '0' | | | | 1C9Ch | CRCDATAU | 1D1Ch | ADPREVH | 1D9Eh | RC3PPS <sup>(2)</sup> | | | | | | | | | | | | 1C9Dh | CRCDATAT | 1D1Dh | ADRESL | 1DA0h | RC4PPS <sup>(2)</sup> | | | | | | | | | | | | 1C9Eh | CRCOUTL | 1D1Eh | ADRESH | 1DA1h | RC5PPS <sup>(2)</sup> | | | | | | | | | | | Unimplemented | 1C9Fh | CRCOUTH | 1D1Fh | ADRESH | 1DA111 | RC6PPS <sup>(1)</sup> | | Con Table 2 for | | See Table 3 for | | | | | | | Read as '0' | 1CA0h | CRCOUTU | 1D20h | ADNCH | 1DA3h | RC6PPS <sup>(1)</sup> | | See Table 2 for<br>register mapping | | register mapping | | | | | | | neau as u | 1CA1h | CRCOUTT | 1D21h | ADACQL | 1DA3II | RC/PPS17 | | details | | details | | Unimplemented | | | | | | 1CA1h | CRCCONO | 1D21h | ADACQL | 1DA4fi | | | details | | | | Read as '0' | | | | | | 1CA3h | CRCCON1 | 1D23h | ADCAP | | | | | | | | | | | | | | 1CA4h | CRCCON2 | 1D24h | ADPREL | | | | | | | | | | | | | | 1CA5h | | 1D25h | ADPREH | | | | | | | | | | | | | | | | 1D26h | ADCON0 | | | | | | | | | | | | | | | | 1D27h | ADCON1 | | | | | | | | | | | | | | | | 1D28h | ADCON2 | | | | | | | | | | | | | | | | 1D29h | ADCON3 | | | | | | | | | 1FE3h | | | | | | | 1D2Ah<br>1D2Bh | ADSTAT | | Unimplemented | | | | | | | 1FE4h | STATUS_SHAD | | | | | | 1D2Bh | ADREF<br>ADACT | | Read as '0' | | | | | | | 1FE5h<br>1FE6h | WREG_SHAD<br>BSR_SHAD | | | | | Unimplemented | 1DCDh | ADCLK | | | | | | | | | 1FE7h | PCLATH SHAD | | | | | Read as '0' | 1D2Eh | ADCG1A | | | | | | | | | 1FE8h | FSROL_SHAD | | | | | | 1D2Fh | ADCG1B <sup>(1)</sup> | | | | | | | | | 1FE9h | FSROH SHAD | | | | | | 1D30h | ADCG1C <sup>(2)</sup> | | | | | | | | | 1FEAh | FSR1L SHAD | | | | | | 1D31h | | | | | | | | | | 1FEBh | FSR1H_SHAD | | | | | | | Unimplemented | | | | | | | | | 1FECh | _ | | | | | | | Read as '0' | | | | | | | | | 1FEDh | STKPTR | | | | | | | neau as 0 | | | | | | | | | 1FEEh | TOSL | | 1C6Fh | | 1CEFh | | 1D6Fh | | 1DEFh | | 1E6Fh | | 1EEFh | | 1F6Fh | | 1FEFh | TOSH | | 1C70h | Common RAM<br>(Accesses | 1CF0h | Common RAM<br>(Accesses | 1D70h | Common RAM<br>(Accesses | 1DF0h | Common RAM<br>(Accesses | 1E70h | Common RAM<br>(Accesses | 1EF0h | Common RAM<br>(Accesses | 1F70h | Common RAM<br>(Accesses | 1FF0h | Common RAM<br>(Accesses | | 1C7Fh | 70h-7Fh) | 1CFFh | 70h-7Fh) | 1D7Fh | 70h-7Fh) | 1DFFh | 70h-7Fh) | 1E7Fh | 70h-7Fh) | 1EFFh | 70h-7Fh) | 1F7Fh | 70h-7Fh) | 1FFFh | 70h-7Fh) | | | | [ | /// | /[ | | | | | | | | | | | | 1. 20-pin devices only 2. 14/16/20-pin devices only Figure 9-12. Memory Map Bank 61 # **BANK 60** | | DAINK OU | | | |-------|----------------|-------|---------------------| | 1E00h | | 1E3Dh | CLCINOPPS | | | Core Registers | 1E3Eh | CLCIN1PPS | | 1E0Bh | | 1E3Fh | CLCIN2PPS | | 1E0Ch | PPSLOCK | 1E40h | CLCIN3PPS | | 1E0Dh | INTPPS | 1E41h | RX1PPS | | 1E0Eh | TOCKIPPS | 1E42h | CK1PPS | | 1E0Fh | T1CKIPPS | 1E43h | RX2PPS | | 1E10h | T1GPPS | 1E44h | CK2PPS | | 1E11h | T3CKIPPS | 1E45h | _ | | 1E12h | T3GPPS | 1E46h | _ | | 1E13h | Unimplemented | 1E47h | SSP1CLKPPS | | | Read as '0' | 1E48h | SSP1DATPPS | | 1E18h | Redu ds U | 1E49h | SSP1SSPPS | | 1E19h | T2INPPS | 1E4Ah | SSP2CLKPPS | | 1E1Ah | T4INPPS | 1E4Bh | SSP2DATPPS | | 1E1Bh | T6INPPS | 1E4Ch | SSP2SSPPS | | 1E1Ch | | 1E4Dh | Unimplemented | | 1E1Dh | | | Read as '0' | | 1E1Eh | CCP1PPS | 1E4Fh | Neau as U | | 1E1Fh | CCP2PPS | 1E50h | ADACTPPS | | 1E20h | Unimplemented | 1E51h | Unimplemented | | | Read as '0' | | Read as '0' | | 1E38h | Neau as U | 1E6Fh | ineau as U | | 1E39h | CWG1PPS | 1E70h | Common RAM | | 1E3Ah | Unimplemented | | (Accesses 70h-7Fh | | | Read as '0' | 1E7Fh | (Accesses /UII-/FII | | 1E3Ch | Neau as U | | | | | | | | Legend: Figure 9-13. Memory Map Bank 62 ## **BANK 61** | _ | DAINKUI | | | |-------|------------------------|-------|------------------------| | 1E80h | | 1EA3h | SLRCONC <sup>(2)</sup> | | | Core registers | 1EA4h | INLVLC <sup>(2)</sup> | | 1E8Bh | | 1EA5h | IOCCP <sup>(2)</sup> | | 1E8Ch | ANSELA | 1EA6h | IOCCN <sup>(2)</sup> | | 1E8Dh | WPUA | 1EA7h | IOCCF <sup>(2)</sup> | | 1E8Eh | ODCONA | 1EA8h | Unimplemented | | 1E8Fh | SLRCONA | | Read as '0' | | 1E90h | INLVLA | 1EE0h | | | 1E91h | IOCAP | 1EE1h | RA1I2C <sup>(3)</sup> | | 1E92h | IOCAN | 1EE2h | RA2I2C <sup>(3)</sup> | | 1E93h | IOCAF | 1EE3h | _ | | 1E94h | _ | 1EE4h | _ | | 1E95h | _ | 1EE5h | RB4I2C <sup>(1)</sup> | | 1E96h | ANSELB <sup>(1)</sup> | 1EE6h | RB5I2C <sup>(1)</sup> | | 1E97h | WPUB <sup>(1)</sup> | 1EE7h | RB6I2C <sup>(1)</sup> | | 1E98h | ODCONB <sup>(1)</sup> | 1EE8h | RB7I2C <sup>(1)</sup> | | 1E99h | SLRCONB <sup>(1)</sup> | 1EE9h | RC0I2C <sup>(4)</sup> | | 1E9Ah | INLVLB <sup>(1)</sup> | 1EEAh | RC1I2C <sup>(4)</sup> | | 1E9Bh | IOCBP <sup>(1)</sup> | 1EEBh | _ | | 1E9Ch | IOCBN <sup>(1)</sup> | 1EECh | RC4I2C <sup>(4)</sup> | | 1E9Dh | IOCBF <sup>(1)</sup> | 1EEDh | RC5I2C <sup>(4)</sup> | | 1E9Eh | _ | 1EEEh | _ | | 1E9Fh | _ | 1EEFh | _ | | 1EA0h | ANSELC <sup>(2)</sup> | 1EF0h | Common RAM | | 1EA1h | WPUC <sup>(2)</sup> | | (Accesses | | 1EA2h | ODCONC <sup>(2)</sup> | 1EFFh | 70h-7Fh) | Note: 1. 20-pin devices only 2. 14/16/20-pin devices only 3. PIC16F18015 only 4. PIC16F18025 only ## Legend: Unimplemented data memory locations, read as '0' # 9.3 STATUS Register The STATUS register contains: - · the arithmetic status of the ALU - · the Reset status The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then writes to these three bits are disabled. These bits are set or cleared according to the device logic. Furthermore, the $\overline{\text{TO}}$ and $\overline{\text{PD}}$ bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended. For example, CLRF STATUS will clear bits [4:3] and [1:0], and set the Z bit. This leaves the STATUS register as '000u uluu' (where u = unchanged). It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any Status bits. For other instructions not affecting any Status bits, refer to the "Instruction Set Summary" chapter. Important: The C and DC bits operate as Borrow and Digit Borrow out bits, respectively, in subtraction. ## 9.4 PCL and PCLATH The Program Counter (PC) is 15 bits wide. The low byte comes from the PCL register, which is a readable and writable register. The high byte (PC[14:8]) is not directly readable or writable and comes from PCLATH. On any Reset, the PC is cleared. Loading of PC in Different Situations shows the five situations for the loading of the PC. Figure 9-14. Loading of PC in Different Situations ## 9.4.1 Modifying PCL Executing any instruction with the PCL register as the destination simultaneously causes the Program Counter PC[14:8] bits (PCH) to be replaced by the contents of the PCLATH register. This allows the entire contents of the Program Counter to be changed by writing the desired upper seven bits to the PCLATH register. When the lower eight bits are written to the PCL register, all 15 bits of the Program Counter will change to the values contained in the PCLATH register and those being written to the PCL register. ### 9.4.2 Computed GOTO A computed GOTO is accomplished by adding an offset to the Program Counter (ADDWF PCL). When performing a table read using a computed GOTO method, care has to be exercised if the table location crosses a PCL memory boundary (each 256-byte block). Refer to application note *AN556*, "Implementing a Table Read" (DS00556). ### 9.4.3 Computed Function Calls A computed function CALL allows programs to maintain tables of functions and provide another way to execute state machines or Look-up Tables. When performing a table read using a computed function CALL, care has to be exercised if the table location crosses a PCL memory boundary (each 256-byte block). If using the CALL instruction, the PCH[2:0] and PCL registers are loaded with the operand of the CALL instruction. PCH[6:3] is loaded with PCLATH[6:3]. The CALLW instruction enables computed calls by combining PCLATH and W to form the destination address. A computed CALLW is accomplished by loading the W register with the desired address and executing CALLW. The PCL register is loaded with the value of W and PCH is loaded with PCLATH. ## 9.4.4 Branching The branching instructions add an offset to the PC. This allows relocatable code and code that crosses page boundaries. There are two forms of branching, BRW and BRA. The PC will have incremented to fetch the next instruction in both cases. When using either branching instruction, a PCL memory boundary may be crossed. If using BRW, load the W register with the desired unsigned address and execute BRW. The entire PC will be loaded with the address PC + 1 + W. If using BRA, the entire PC will be loaded with PC + 1 + the signed value of the operand of the BRA instruction. ### 9.5 Stack All devices have a 16-level by 15-bit wide hardware stack. The stack space is not part of either program or data space. The PC is PUSHed onto the stack when the CALL or CALLW instructions are executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation. The stack operates as a circular buffer if the STVREN Configuration bit is programmed to '0'. This means that after the stack has been PUSHed sixteen times, the seventeenth PUSH overwrites the value that was stored from the first PUSH. The eighteenth PUSH overwrites the second PUSH, and so on. The STKOVF and STKUNF flag bits will be set on an Overflow/Underflow, regardless of whether the Reset is enabled. If the STVREN bit is programmed to '1', the device will be reset if the stack is PUSHed beyond the sixteenth level or POPed beyond the fist level, setting the appropriate bits (STKOVF or STKUNF, respectively). **Important:** There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, CALLW, RETURN, RETLW and RETFIE instructions or the vectoring to an interrupt address. ### 9.5.1 Accessing the Stack The stack is accessible through the TOSH, TOSL and STKPTR registers. STKPTR is the current value of the Stack Pointer. The TOSH:TOSL register pair points to the TOP of the stack. Both registers are read/writable. TOS is split into TOSH and TOSL due to the 15-bit size of the PC. To access the stack, adjust the value of STKPTR, which will position TOSH:TOSL, then read/write to TOSH:TOSL. STKPTR also allows the detection of Overflow and Underflow condition. ## PIC16F18015/25/44/45 ## **Memory Organization** Important: Care must be taken when modifying STKPTR while interrupts are enabled. During normal program operation, CALL, CALLW and interrupts will increment STKPTR, while RETLW, RETURN and RETFIE will decrement STKPTR. STKPTR can be monitored to obtain the value of stack memory left at any given time. STKPTR always points at the currently used place on the stack. Therefore, a CALLW will increment STKPTR and then write the PC, and a return will unload the PC value from the stack and then decrement STKPTR. Reference the following figures for examples of accessing the stack. Figure 9-15. Accessing the Stack Example 1 Stack Reset Disabled TOSH:TOSL 0x0F STKPTR = 0x1F (STVREN = 0) 0x0E 0x0D 0x0C 0x0B Initial Stack Configuration: 0x0A After Reset, the stack is empty. The 0x09 empty stack is initialized so the Stack 0x08 Pointer is pointing at 0x1F. If the Stack Overflow/Underflow Reset is enabled, the 0x07 TOSH/TOSL register will return '0'. If the 0x06 Stack Overflow/Underflow Reset is disabled, the TOSH/TOSL register will 0x05 return the contents of stack address 0x04 0x0F. 0x03 0x02 0x01 0x00 Stack Reset Enabled STKPTR = 0x1F TOSH:TOSL 0x1F 0x0000 (STVREN = 1) Figure 9-16. Accessing the Stack Example 2 Rev. 10-000043B Figure 9-17. Accessing the Stack Example 3 Rev. 10-000043C 7/30/2013 Figure 9-18. Accessing the Stack Example 4 Rev. 10-000043D 7/30/2013 ### 9.5.2 Overflow/Underflow Reset If the STVREN bit is programmed to '1', the device will be reset if the stack is PUSHed beyond the sixteenth level or POPed beyond the first level, setting the appropriate bits (STKOVF or STKUNF, respectively). ## 9.6 Indirect Addressing The INDFn registers are not physical registers. Any instruction that accesses an INDFn register actually accesses the register at the address specified by the File Select Registers (FSR). If the FSRn address specifies one of the two INDFn registers, the read will return '0' and the write will not occur (though Status bits may be affected). The FSRn register value is created by the pair FSRnH and FSRnL. The FSR registers form a 16-bit address that allows an addressing space with 65536 locations. These locations are divided into three memory regions: - · Traditional/Banked Data Memory - · Linear Data Memory - · Program Flash Memory Figure 9-19. Indirect Addressing ## 9.6.1 Traditional/Banked Data Memory The traditional or banked data memory is a region from FSR address 0x0000 to FSR address 0x1FFF. The addresses correspond to the absolute addresses of all SFR, GPR and common registers. Figure 9-20. Traditional/Banked Data Memory Map ## 9.6.2 Linear Data Memory The linear data memory is the region from FSR address 0x2000 to FSR address 0x2FEF. This region is a virtual region that points back to the 80-byte blocks of GPR memory in all the banks. Refer to Figure 9-21 for the Linear Data Memory Map. Figure 9-21. Linear Data Memory Map **Important:** The address range 0x2000 to 0x2FEF represents the complete addressable Linear Data Memory for PIC<sup>®</sup> devices (up to Bank 50). The actual implemented Linear Data Memory will differ from one device to the other in a family. Unimplemented memory reads as 0x00. Use of the linear data memory region allows buffers to be larger than 80 bytes because incrementing the FSR beyond one bank will go directly to the GPR memory of the next bank. The 16 bytes of common memory are not included in the linear data memory region. ## 9.6.3 Program Flash Memory To make constant data access easier, the entire Program Flash Memory is mapped to the upper half of the FSR address space. When the MSB of FSRnH is set, the lower 15 bits are the address in program memory which will be accessed through INDF. Only the lower eight bits of each memory location are accessible via INDF. Writing to the Program Flash Memory cannot be accomplished via the FSR/INDF interface. All instructions that access Program Flash Memory via the FSR/INDF interface will require one additional instruction cycle to complete. Figure 9-22. Program Flash Memory Map ## 9.6.4 Data EEPROM Memory The EEPROM memory can be read or written through the NVMCON register interface. However, to make access to the EEPROM easier, read-only access to the EEPROM contents are also available through indirect addressing via an FSR. When the MSP of the FSR (ex: FSRxH) is set to 0x70, the lower 8-bit address value (in FSRxL) determines the EEPROM location that may be read via the INDF register). In other words, the EEPROM address range 0x00-0xFF is mapped into the FSR address space between 0x7000 and 0x70FF. Writing to the EEPROM cannot be accomplished via the FSR/INDF interface. Reads from the EEPROM through the FSR/INDF interface will require one additional instruction cycle to complete. # 9.7 Register Definitions: Memory Organization # PIC16F18015/25/44/45 # **Memory Organization** ## 9.7.1 INDF0 Name: INDF0 Offset: 0x0000 Indirect Data Register. This is a virtual register. The GPR/SFR register addressed by the FSR0 register is the target for all operations involving the INDF0 register. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | [ | | | | INDF | 0[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 7:0 - INDF0[7:0] Indirect data pointed to by the FSR0 register # PIC16F18015/25/44/45 # **Memory Organization** ## 9.7.2 INDF1 Name: INDF1 Offset: 0x0001 Indirect Data Register. This is a virtual register. The GPR/SFR register addressed by the FSR1 register is the target for all operations involving the INDF1 register. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | [ | | | | INDF | 1[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bits 7:0 - INDF1[7:0] Indirect data pointed to by the FSR1 register ## 9.7.3 PCL Name: PCL Offset: 0x0002 Low byte of the Program Counter Bits 7:0 - PCL[7:0] Provides direct read and write access to the Program Counter ## 9.7.4 STATUS Name: STATUS Offset: 0x0003 Status Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|----|----|-----|-----|-----| | | | | | TO | PD | Z | DC | С | | Access | | • | • | R | R | R/W | R/W | R/W | | Reset | | | | 1 | 1 | 0 | 0 | 0 | ## Bit 4 - TO Time-Out Reset States: POR/BOR = 1 All Other Resets = q | | 7 III O 11101 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | |-------|----------------------------------------------------------------| | Value | Description | | 1 | Set at power-up or by execution of CLRWDT or SLEEP instruction | | 0 | A WDT time-out occurred | ## Bit 3 – PD Power-Down Reset States: POR/BOR = 1 All Other Resets = q | Value | Description | |-------|-------------------------------------------------------| | 1 | Set at power-up or by execution of CLRWDT instruction | | 0 | Cleared by execution of the SLEEP instruction | ### Bit 2 - Z Zero Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|------------------------------------------------------------| | 1 | The result of an arithmetic or logic operation is zero | | 0 | The result of an arithmetic or logic operation is not zero | ## Bit 1 – DC Digit Carry/Borrow<sup>(1)</sup> ADDWF, ADDLW, SUBLW, SUBWF instructions Reset States: POR/BOR = 0 All Other Resets = u | | 7 th Other redeta to | |-------|---------------------------------------------------------------| | Value | Description | | 1 | A carry-out from the 4th low-order bit of the result occurred | | 0 | No carry-out from the 4th low-order bit of the result | ## Bit 0 - C Carry/Borrow(1) ADDWF, ADDLW, SUBLW, SUBWF instructions Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|-------------------------------------------------------------------| | 1 | A carry-out from the Most Significant bit of the result occurred | | 0 | No carry-out from the Most Significant bit of the result occurred | ## Note: 1. For Borrow, the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For Rotate (RRCF, RLCF) instructions, this bit is loaded with either the high or low-order bit of the Source register. ## 9.7.5 FSR0 Name: FSR0 Offset: 0x0004 Indirect Address Register The FSR0 value is the address of the data to which the INDF0 register points. Bits 15:0 - FSR0[15:0] Address of INDF0 data **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - 1. FSR0H: Accesses the high byte FSR0[15:8]. - 2. FSR0L: Accesses the low byte FSR0[7:0]. ## 9.7.6 FSR1 Name: FSR1 Offset: 0x0006 Indirect Address Register The FSR1 value is the address of the data to which the INDF1 register points. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----|-----|------|--------|-----|-----|-----| | | | | | FSR1 | [15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FSR1[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bits 15:0 - FSR1[15:0] Address of INDF1 data **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - 1. FSR1H: Accesses the high byte FSR1[15:8]. - 2. FSR1L: Accesses the low byte FSR1[7:0]. # PIC16F18015/25/44/45 # **Memory Organization** ## 9.7.7 BSR Name: BSR Offset: 0x0008 ## Bank Select Register The BSR indicates the data memory bank by writing the bank number into the register. All data memory can be accessed directly via instructions, or indirectly via FSRs. ## Bits 5:0 - BSR[5:0] Six Most Significant bits of the data memory address ## 9.7.8 WREG Name: WREG Ox0009 Working Data Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|--------|-----|-----|-----| | [ | | | | WRE | G[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - WREG[7:0] ## 9.7.9 PCLATH Name: PCLATH Offset: 0x000A **Program Counter Latches** Write Buffer for the upper seven bits of the Program Counter | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|-----|-------------|-----|-----|-----|-----|-----| | | | | PCLATH[6:0] | | | | | | | Access | | R/W | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | **Bits 6:0 – PCLATH[6:0]** High PC Latch Register Holding register for Program Counter bits [6:0] # 9.8 Register Summary - Memory Organization | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|----------|-------------|------------|---|----|----|---|----|---| | 0x00 | INDF0 | 7:0 | | INDF0[7:0] | | | | | | | | 0x01 | INDF1 | 7:0 | | INDF1[7:0] | | | | | | | | 0x02 | PCL | 7:0 | | PCL[7:0] | | | | | | | | 0x03 | STATUS | 7:0 | | | | TO | PD | Z | DC | С | | 0x04 | FSR0 | 7:0 | FSR0[7:0] | | | | | | | | | 0004 | | 15:8 | | FSR0[15:8] | | | | | | | | 0x06 | FSR1 | 7:0 | | FSR1[7:0] | | | | | | | | UXUG | FORT | 15:8 | FSR1[15:8] | | | | | | | | | 0x08 | BSR | 7:0 | BSR[5:0] | | | | | | | | | 0x09 | WREG | 7:0 | WREG[7:0] | | | | | | | | | 0x0A | PCLATH | 7:0 | PCLATH[6:0] | | | | | | | | ## 10. Resets There are multiple ways to reset this device: - Power-on Reset (POR) - · Brown-out Reset (BOR) - MCLR Reset - WDT Reset - RESET instruction - Stack Overflow - · Stack Underflow - · Programming mode exit To allow $V_{DD}$ to stabilize, an optional Power-up Timer can be enabled to extend the Reset time after a BOR or POR event. A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 10-1. Figure 10-1. Simplified Block Diagram of On-Chip Reset Circuit # 10.1 Power-on Reset (POR) The POR circuit holds the device in Reset until $V_{DD}$ has reached an acceptable level for minimum operation. Slow rising $V_{DD}$ , fast operating speeds or analog performance may require greater than minimum $V_{DD}$ . The PWRT, BOR or $\overline{MCLR}$ features can be used to extend the start-up period until all device operation conditions have been met. ### 10.1.1 Programming Mode Exit Upon exit of Programming mode, the device will behave as if a POR had just occurred. ## 10.2 Brown-out Reset (BOR) The BOR circuit holds the device in Reset when $V_{DD}$ reaches a selectable minimum level. Between the POR and BOR, complete voltage range coverage for execution protection can be implemented. The Brown-out Reset module has four operating modes controlled by the BOREN bits. The four operating modes are: - · BOR is always on - · BOR is off when in Sleep - · BOR is controlled by software - · BOR is always off Refer to Table 10-1 for more information. The Brown-out Reset voltage level is selectable by configuring the BORV bits. A $V_{DD}$ noise rejection filter prevents the BOR from triggering on small events. If $V_{DD}$ falls below $V_{BOR}$ for a duration greater than parameter $T_{BORDC}$ , the device will reset and the $\overline{BOR}$ bit will be cleared, indicating the Brown-out Reset condition occurred. See Figure 10-2. ## 10.2.1 BOR is Always On When the BOREN bits are programmed to '11', the BOR is always on. The device start-up will be delayed until the BOR is ready and $V_{DD}$ is higher than the BOR threshold. BOR protection is active during Sleep. The BOR does not delay wake-up from Sleep. ### 10.2.2 BOR Is Off in Sleep When the BOREN bits are programmed to '10', the BOR is on, except in Sleep. BOR protection is not active during Sleep, but device wake-up will be delayed until the BOR can determine that $V_{DD}$ is higher than the BOR threshold. The device wake-up will be delayed until the BOR is ready. ## 10.2.3 BOR Controlled by Software When the BOREN bits of Configuration Words are programmed to '01', the BOR is controlled by the SBOREN bit. The device start-up is not delayed by the BOR Ready condition or the $V_{DD}$ level. BOR protection begins as soon as the BOR circuit is ready. The status of the BOR circuit is reflected in the BORRDY bit. BOR protection is unchanged by Sleep. Table 10-1. BOR Operating Modes | | | | | Instruction Execution upon: | | | | |-------|---------------|-------------|--------------|--------------------------------------|--------------------------------------------|--|--| | BOREN | SBOREN | Device Mode | BOR Mode | Release of POR | Wake-up from<br>Sleep | | | | 11(1) | X | Х | Active | Wait for release of BOR (BORRDY = 1) | Begins<br>immediately | | | | | Awake | | Active | Wait for release of BOR (BORRDY = 1) | N/A | | | | 10 | X | Sleep | Hibernate | N/A | Wait for release<br>of BOR<br>(BORRDY = 1) | | | | 01 | 1 | Х | Active | Wait for release of BOR | Begins | | | | 01 | 0 X Hibernate | | (BORRDY = 1) | immediately | | | | | 00 | X | Х | Disabled | Begins imme | diately | | | #### Note: 1. In this specific case, 'Release of POR' and 'Wake-up from Sleep', there is no delay in start-up. The BOR Ready flag (BORRDY = 1) will be set before the CPU is ready to execute instructions because the BOR circuit is forced on by the BOREN bits. Figure 10-2. Brown-Out Situations **Note:** $T_{PWRT}$ delay when the PWRTS bits are enabled ( $\overline{PWRTS} = 00$ ). ### 10.2.4 BOR Is Always Off When the BOREN bits are programmed to '00', the BOR is always disabled. In the configuration, setting the SBOREN bit will have no affect on BOR operations. ## 10.3 MCLR Reset The MCLR is an optional external input that can reset the device. The MCLR function is controlled by the MCLRE bit and the LVP bit (see Table 10-2). The RMCLR bit will be set to '0' if a MCLR has occurred. Table 10-2. MCLR Configuration | MCLRE | LVP | MCLR | |-------|-----|----------| | х | 1 | Enabled | | 1 | 0 | Enabled | | 0 | 0 | Disabled | ### 10.3.1 MCLR Enabled When $\overline{MCLR}$ is enabled and the pin is held low, the device is held in Reset. The $\overline{MCLR}$ pin is connected to $V_{DD}$ through an internal weak pull-up. The device has a noise filter in the MCLR Reset path. The filter will detect and ignore small pulses. **Important:** An internal Reset event (RESET instruction, BOR, WDT, POR, STKOVF, STKUNF) does not drive the MCLR pin low. #### 10.3.2 MCLR Disabled When MCLR is disabled, the MCLR becomes input-only and pin functions such as internal weak pull-ups are under software control. # 10.4 Watchdog Timer (WDT) Reset The Watchdog Timer generates a Reset if the firmware does not issue a CLRWDT instruction within the time-out period. The TO, PD and RWDT bits are changed to indicate a WDT Reset caused by the timer overflowing. ## 10.5 RESET Instruction A RESET instruction will cause a device Reset. The $\overline{RI}$ bit will be set to '0'. See Table 10-4 for default conditions after a RESET instruction has occurred. #### 10.6 Stack Overflow/Underflow Reset The device can reset when the Stack Overflows or Underflows. The STKOVF or STKUNF bits indicate the Reset condition. These Resets are enabled by setting the STVREN bit. # 10.7 Power-Up Timer (PWRT) The Power-up Timer provides up to a 64 ms time-out period on POR or BOR. The device is held in Reset as long as PWRT is active. The PWRT delay allows additional time for the $V_{\rm DD}$ to rise to an acceptable level. The Power-up Timer is controlled by the PWRTS bits. The Power-up Timer starts after the release of the POR and BOR. For additional information, refer to the "Power-up Trouble Shooting" Application Note AN607. ## 10.8 Start-Up Sequence Upon the release of a POR or BOR, the following must occur before the device will begin executing: - 1. Power-up Timer runs to completion (if enabled). - 2. MCLR must be released (if enabled). The Power-up Timer runs independently of MCLR Reset. If MCLR is kept low long enough, the Power-up Timer will expire. Upon bringing MCLR high, the device will begin execution after 10 F<sub>OSC</sub> cycles (see Figure 10-3). This is useful for testing purposes or for synchronizing more than one device operating in parallel. Figure 10-3. Reset Start-Up Sequence #### Note: 1. Code execution begins 10 F<sub>OSC</sub> cycles after the F<sub>OSC</sub> clock is released. # 10.9 Memory Execution Violation A memory execution violation Reset occurs if executing an instruction being fetched from outside the valid execution area. The invalid execution areas are: - Addresses outside implemented program memory. Refer to the "Memory Organization" chapter for details about available Flash size. - 2. Storage Area Flash (SAF) inside program memory, if enabled. When a memory execution violation is generated, the device is reset and the MEMV bit is cleared to signal the cause of the Reset. The MEMV bit must be set in the user code after a memory execution violation Reset has occurred to detect further violation Resets. ## 10.10 Determining the Cause of a Reset Upon any Reset, multiple bits in the STATUS, PCON0 and PCON1 registers are updated to indicate the cause of the Reset. The following tables show the Reset conditions of these registers. Table 10-3. Reset Status Bits and Their Significance | STKOVF | STKUNF | RWDT | RMCLR | RI | POR | BOR | TO | PD | MEMV | Condition | |--------|--------|------|-------|----|-----|-----|----|----|------|---------------------------| | 0 | 0 | 1 | 1 | 1 | 0 | Х | 1 | 1 | 1 | Power-on Reset | | 0 | 0 | 1 | 1 | 1 | 0 | х | 0 | х | u | Illegal, TO is set on POR | | 0 | 0 | 1 | 1 | 1 | 0 | Х | Х | 0 | u | Illegal, PD is set on POR | | con | tinued | | | | | | | | | | |--------|--------|------|-------|----|-----|-----|----|----|------|------------------------------------------| | STKOVF | STKUNF | RWDT | RMCLR | RI | POR | BOR | TO | PD | MEMV | Condition | | 0 | 0 | u | 1 | 1 | u | 0 | 1 | 1 | u | Brown-out Reset | | u | u | 0 | u | u | u | u | 0 | u | u | WDT Reset | | u | u | u | u | u | u | u | 0 | 0 | u | WDT Wake-up<br>from Sleep | | u | u | u | u | u | u | u | 1 | 0 | u | Interrupt Wake-up from Sleep | | u | u | u | 0 | u | u | u | u | u | 1 | MCLR Reset<br>during normal<br>operation | | u | u | u | 0 | u | u | u | 1 | 0 | u | MCLR Reset<br>during Sleep | | u | u | u | u | 0 | u | u | u | u | u | RESET Instruction Executed | | 1 | u | u | u | u | u | u | u | u | u | Stack Overflow<br>Reset (STVREN =<br>1) | | u | 1 | u | u | u | u | u | u | u | u | Stack Underflow<br>Reset (STVREN =<br>1) | | u | u | u | u | u | u | u | u | u | 0 | Memory Violation<br>Reset | Table 10-4. Reset Conditions for Special Registers | Condition | Program<br>Counter | STATUS<br>Register | PCON0 Register | PCON1<br>Register | |------------------------------------|-----------------------|--------------------|----------------|-------------------| | Power-on Reset | 0 | 1 1000 | 0011 110x | 1- | | Brown-out Reset | 0 | 1 1000 | 0011 11u0 | u- | | MCLR Reset during normal operation | 0 | -uuu uuuu | uuuu Ouuu | 1- | | MCLR Reset during Sleep | 0 | 1 Ouuu | uuuu Ouuu | u- | | WDT Time-out Reset | 0 | 0 uuuu | uuu0 uuuu | u- | | WDT Wake-up from Sleep | PC + 1 | 0 Ouuu | uuuu uuuu | u- | | Interrupt Wake-up from Sleep | PC + 1 <sup>(1)</sup> | 1 Ouuu | uuuu uuuu | u- | | RESET Instruction Executed | 0 | u uuuu | uuuu u0uu | u- | | Stack Overflow Reset (STVREN = 1) | 0 | u uuuu | 1uuu uuuu | u- | | Stack Underflow Reset (STVREN = 1) | 0 | u uuuu | u1uu uuuu | u- | | Memory Violation Reset | 0 | -uuu uuuu | uuuu uuuu | 0- | **Legend:** u = unchanged, x = unknown, — = unimplemented bit, reads as '0'. #### Note: 1. When the wake-up is due to an interrupt and Global Interrupt Enable (GIE) bit is set, the return address is pushed on the stack and PC is loaded with the interrupt vector (0004h) after execution of PC + 1. # 10.11 Power Control (PCONx) Register The Power Control (PCONx) registers contain flag bits to differentiate between a: - Brown-out Reset (BOR) - Power-on Reset (POR) - RESET Instruction Reset (RI) - MCLR Reset (RMCLR) - Watchdog Timer Reset (RWDT) - Stack Underflow Reset (STKUNF) - Stack Overflow Reset (STKOVF) - Memory Violation Reset (MEMV) Hardware will change the corresponding register bit during the Reset process; if the Reset was not caused by the condition, the bit remains unchanged. Software may reset the bit to the Inactive state after restart (hardware will not reset the bit). Software may also set any PCONx bit to the Active state, so that user code may be tested, but no Reset action will be generated. # 10.12 Register Definitions: Power Control ## 10.12.1 BORCON Name: BORCON Offset: 0x018D Brown-out Reset Control Register # Bit 7 - SBOREN Software Brown-Out Reset Enable Reset States: POR/BOR = 1 All Other Resets = u | Value | Condition | Description | |-------|---------------|----------------------------------------------------| | _ | If BOREN ≠ 01 | SBOREN is read/write, but has no effect on the BOR | | 1 | If BOREN = 01 | BOR Enabled | | 0 | If BOREN = 01 | BOR Disabled | # Bit 0 - BORRDY Brown-Out Reset Circuit Ready Status Reset States: POR/BOR = q All Other Resets = u | Value | Description | |-------|----------------------------------------------------------| | 1 | The Brown-out Reset circuit is active and armed | | 0 | The Brown-out Reset circuit is disabled or is warming up | ## 10,12,2 PCON0 Name: PCON0 Offset: 0x018E Power Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|---|--------|--------|--------|--------|--------| | [ | STKOVF | STKUNF | | RWDT | RMCLR | RI | POR | BOR | | Access | R/W/HS | R/W/HS | • | R/W/HC | R/W/HC | R/W/HC | R/W/HC | R/W/HC | | Reset | 0 | 0 | | 1 | 1 | 1 | 0 | q | # Bit 7 - STKOVF Stack Overflow Flag Reset States: POR/BOR = 0 All Other Resets = q | Value | Description | |-------|--------------------------------------------------------------| | 1 | A Stack Overflow occurred (more CALLs than fit on the stack) | | 0 | A Stack Overflow has not occurred or set to '0' by firmware | #### Bit 6 - STKUNF Stack Underflow Flag Reset States: POR/BOR = 0 All Other Resets = q | Value | Description | |-------|--------------------------------------------------------------| | 1 | A Stack Underflow occurred (more RETURNS than CALLS) | | 0 | A Stack Underflow has not occurred or set to '0' by firmware | # Bit 4 – RWDT WDT Reset Flag Reset States: POR/BOR = 1 All Other Resets = q | | 7 111 0 11101 1100010 0 | |-------|---------------------------------------------------------------------------------------------| | Value | Description | | 1 | A WDT Overflow/Time-out Reset has not occurred or set to '1' by firmware | | 0 | A WDT Overflow/Time-out Reset has occurred (set to '0' in hardware when a WDT Reset occurs) | ## Bit 3 - RMCLR MCLR Reset Flag Reset States: POR/BOR = 1 All Other Resets = a | | 7 til Othor (Coote q | |-------|-----------------------------------------------------------------------------| | Value | Description | | 1 | A MCLR Reset has not occurred or set to '1' by firmware | | 0 | A MCLR Reset has occurred (set to '0' in hardware when a MCLR Reset occurs) | ## Bit 2 - RI RESET Instruction Flag Reset States: POR/BOR = 1 All Other Resets = q | Value | Description | |-------|---------------------------------------------------------------------------------------------------| | 1 | A RESET instruction has not been executed or set to '1' by firmware | | 0 | A RESET instruction has been executed (set to '0' in hardware upon executing a RESET instruction) | # Bit 1 - POR Power-on Reset Status Reset States: POR/BOR = 0 All Other Resets = u | | Value | Description | |---|-------|---------------------------------------------------------------------------------| | | 1 | No Power-on Reset occurred or set to '1' by firmware | | Ī | 0 | A Power-on Reset occurred (set to '0' in hardware when a Power-on Reset occurs) | ## Bit 0 - BOR Brown-out Reset Status Reset States: POR/BOR = q # PIC16F18015/25/44/45 Resets | | All Other Resets = u | |-------|-----------------------------------------------------------------------------------| | Value | Description | | 1 | No Brown-out Reset occurred or set to '1' by firmware | | 0 | A Brown-out Reset occurred (set to '0' in hardware when a Brown-out Reset occurs) | # 10.12.3 PCON1 Name: PCON1 Offset: 0x018F Power Control Register 1 Bit 1 – MEMV Memory Violation Flag Reset States: POR/BOR = 1 All Other Resets = u | Value | Description | |-------|-------------------------------------------------------------------------------------------| | 1 | No Memory Violation Reset occurred or set to '1' by firmware | | 0 | A Memory Violation Reset occurred (set to '0' in hardware when a Memory Violation occurs) | # 10.13 Register Summary - Power Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|--------|--------|---|------|-------|----|------|--------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x018C | | | | | | | | | | | | 0x018D | BORCON | 7:0 | SBOREN | | | | | | | BORRDY | | 0x018E | PCON0 | 7:0 | STKOVF | STKUNF | | RWDT | RMCLR | RI | POR | BOR | | 0x018F | PCON1 | 7:0 | | | | | | | MEMV | | # 11. OSC - Oscillator Module The oscillator module contains multiple clock sources and selection features that allow it to be used in a wide range of applications while maximizing performance and minimizing power consumption. Clock sources can be supplied either internally or externally. External sources include: - · External clock oscillators - Secondary Oscillator (SOSC) #### Internal sources include: - High-Frequency Internal Oscillator (HFINTOSC) - Low-Frequency Internal Oscillator (LFINTOSC) - · Analog-to-Digital Converter RC Oscillator (ADCRC) Special features of the oscillator module include: - Oscillator Start-up Timer (OST): Ensures stability of the Secondary Oscillator's 32.768 kHz crystal oscillator. - HFINTOSC Frequency Adjustment: Provides the ability to adjust the HFINTOSC frequency. The Reset Oscillator (RSTOSC) Configuration bits determine the type of oscillator that will be used when the device runs after a Reset, including when the device is first powered up (see the table below). Table 11-1. RSTOSC Selection Table | RSTOSC | SF | R Reset Values | Clock Source | | | | |--------|------|--------------------------------|--------------------|--|--|--| | K3103C | cosc | OSCFRQ | Glock Source | | | | | 111 | 111 | | EXTOSC per FEXTOSC | | | | | 110 | 110 | 000 <b>(1 MHz)</b> | HFINTOSC @ 1 MHz | | | | | 101 | 101 | 000 <b>(1 MHz)</b> | LFINTOSC | | | | | 100 | 100 | | SOSC | | | | | 011 | 011 | Reserved | | | | | | 010 | 010 | Reserved | | | | | | 001 | 011 | Reserved | | | | | | 000 | 000 | 101 (32 MHz) HFINTOSC @ 32 MHz | | | | | If an external clock source is selected by the RSTOSC bits, the External Oscillator Mode Select (FEXTOSC) Configuration bits must be used to select the External Clock mode. These modes include: - · ECL: External Clock Low Power mode - · ECH: External Clock High Power mode The ECH and ECL modes rely on an external logic-level signal as the device clock source. Each mode is optimized for a specific frequency range. The internal oscillator block produces both low-frequency and high-frequency clock signals, designated LFINTOSC and HFINTOSC, respectively. Multiple system operating frequencies may be derived from these clock sources. The figure below illustrates a block diagram of the oscillator module. Figure 11-1. Clock Source Block Diagram # 11.1 Clock Source Types Clock sources can be classified as external or internal. External clock sources rely on external circuitry for the clock source to function, such as digital oscillator modules. Internal clock sources are contained within the oscillator module. The internal oscillator block features two internal oscillators that are used to generate internal system clock sources. The High-Frequency Internal Oscillator (HFINTOSC) can produce a wide range of frequencies which are determined via the HFINTOSC Frequency Selection (OSCFRQ) register. The Low-Frequency Internal Oscillator (LFINTOSC) generates a fixed nominal 31 kHz clock signal. The internal oscillator block also features an RC oscillator which is dedicated to the Analog-to-Digital Converter (ADC). **Important:** The PIC16F180 microcontroller family does not allow the system clock source to be changed through clock switching. Once the RSTOSC Configuration bits select the oscillator source, the source cannot be changed via software. If the HFINTOSC is selected as the clock source, the HFINTOSC frequency may be changed by modifying the FRQ bits. The instruction clock ( $F_{OSC}/4$ ) can be routed to the CLKOUT pin when the pin is not in use. The Clock Out Enable ( $\overline{CLKOUTEN}$ ) Configuration bit controls the functionality of the CLKOUT signal. When $\overline{CLKOUTEN}$ is clear ( $\overline{CLKOUTEN}$ = 0), the CLKOUT signal is routed to the CLKOUT pin. When $\overline{CLKOUTEN}$ is set ( $\overline{CLKOUTEN}$ = 1), the CLKOUT pin functions as an I/O pin. #### 11.1.1 External Clock Sources An external clock source can be used as the device system clock by performing the following actions: - Program the RSTOSC Configuration bits to select the external clock source (RSTOSC = 111) - Program the FEXTOSC Configuration bits to select the appropriate External Clock (EC) mode: - ECH mode for oscillators operating at or above 16 MHz (FEXTOSC = 11) - ECL mode for oscillator operating below 16 MHz (FEXTOSC = 01) #### 11.1.1.1 EC Mode The External Clock (EC) mode allows an externally generated logic level signal to be the system clock source. When operating in EC mode, an external clock source is connected to the CLKIN input pin. The CLKOUT pin is available as a general purpose I/O pin or as the CLKOUT signal pin. EC mode provides two Power mode selections: - ECH: High Power mode (16 MHz and above) - ECL: Low Power mode (below 16 MHz) The Oscillator Start-up Timer (OST) is disabled when EC mode is selected; therefore, there is no delay in operation after a Power-on Reset (POR) or wake-up from Sleep. Because the PIC® MCU design is fully static, stopping the external clock input will have the effect of halting the device while leaving all data intact. Upon restarting the external clock, the device will resume operation as if no time had elapsed. The figure below shows the pin connections for EC mode. Figure 11-2. External Clock (EC) Mode Operation #### Note: Output depends on the setting of the CLKOUTEN Configuration bit. #### 11.1.1.2 Secondary Oscillator The Secondary Oscillator (SOSC) is a separate external oscillator block that can be used as an alternate system clock source or as a Timer clock source. The SOSC is optimized for 32.768 kHz, and can be used with either an external quartz crystal connected to the SOSCI and SOSCO pins, or with an external clock source connected to the SOSCI pin as shown in the figures below. Figure 11-3. SOSC 32.768 kHz Quartz Crystal Oscillator Operation Figure 11-4. SOSC 32.768 kHz External Clock Operation The SOSC can be enabled through one of two methods: - · Programming the RSTOSC Configuration bits to select the SOSC as the system clock - · Setting the SOSCEN bit to enable the SOSC for use as a peripheral clock source Two Power modes are available for the secondary oscillator, and are selected using the Secondary Oscillator Power Mode Select (SOSCPWR) bit. When SOSCPWR is clear (SOSCPWR = 0), the oscillator operates in Low Power mode, which is ideal for crystal oscillators with low drive strength. When SOSCPWR is set (SOSCPWR = 1), the oscillator operates in High Power mode, which is ideal for crystal oscillators with high drive strength or high Equivalent Series Resistance (ESR). **Important:** The SOSC module must be disabled before changing Power modes. Changes to the Power mode during operation may result in undefined oscillator behavior. #### 11.1.1.2.1 SOSC Start-Up Timing The SOSC utilizes the Oscillator Start-up Timer (OST) to ensure that the 32.768 kHz crystal oscillator has started and is available for use. Crystal oscillators do not start immediately and may take a few hundred cycles before achieving stable operation. The oscillations must build up until sufficient amplitude is generated to properly toggle between logic states. The OST counts 1024 oscillation periods from the SOSCI input following a Power-on Reset (POR), Brown-out Reset (BOR), or wake-up from Sleep event to ensure that the oscillator has enough time to reach stable and accurate operation. Once the OST completes its count, module hardware sets the Secondary Oscillator Ready (SOR) bit, indicating that the SOSC is stable and ready to use. #### 11.1.2 Internal Clock Sources The internal oscillator block contains two independent oscillators that can produce two internal system clock sources: - High-Frequency Internal Oscillator (HFINTOSC) - · Low-Frequency Internal Oscillator (LFINTOSC) An internal oscillator source can be used as the device system clock by programming the RSTOSC Configuration bits to select one of the INTOSC sources. In INTOSC mode, the CLKIN and CLKOUT pins are available for use as general purpose I/Os, provided that no external oscillator is connected. The function of the CLKOUT pin is determined by the $\overline{\text{CLKOUTEN}}$ Configuration bit. When $\overline{\text{CLKOUTEN}}$ is set $\overline{\text{CLKOUTEN}} = 1$ ), the pin functions as a general purpose I/O. When $\overline{\text{CLKOUTEN}}$ is clear $\overline{\text{CLKOUTEN}} = 0$ ), the system instruction clock (F<sub>OSC</sub>/4) is available as an output signal on the pin. #### 11.1.2.1 HFINTOSC The High-Frequency Internal Oscillator (HFINTOSC) is a factory-calibrated, precision digitally-controlled internal clock source that produces a wide range of stable clock frequencies. The HFINTOSC can be enabled by programming the RSTOSC Configuration bits to select one of two HFINTOSC options upon device Reset or power-up. The HFINTOSC frequency is selected via the HFINTOSC Frequency Selection (FRQ) bits. Fine-tuning of the HFINTOSC is done via the HFINTOSC Frequency Tuning (TUN) bits. #### 11.1.2.1.1 HFINTOSC Frequency Tuning The HFINTOSC frequency can be fine-tuned via the HFINTOSC Tuning (OSCTUNE) register. The OSCTUNE register is used by Active Clock Tuning hardware or user software to provide small adjustments to the HFINTOSC nominal frequency. The OSCTUNE register contains the HFINTOSC Frequency Tuning (TUN) bits. The TUN bits default to a 6-bit, two's compliment value of $0 \times 00$ , which indicates that the oscillator is operating at the selected frequency. When a value between $0 \times 01$ and $0 \times 1F$ is written to the TUN bits, the HFINTOSC frequency is increased. When a value between $0 \times 3F$ and $0 \times 20$ is written to the TUN bits, the HFINTOSC frequency is decreased. When the OSCTUNE register is modified, the oscillator will begin to shift to the new frequency. Code execution continues during this shift. There is no indication that the frequency shift occurred. Important: OSCTUNE tuning does not affect the LFINTOSC frequency. #### 11.1.2.2 MFINTOSC The Medium-Frequency Internal Oscillator (MFINTOSC) generates two constant clock outputs (500 kHz and 31.25 kHz). The MFINTOSC clock signals are created from the HFINTOSC using dynamic divider logic, which provides constant MFINTOSC clock rates regardless of selected HFINTOSC frequency. The MFINTOSC cannot be used as the system clock, but can be used as a clock source for certain peripherals, such as a Timer. #### 11.1.2.3 SFINTOSC The Specified Frequency Internal Oscillator (SFINTOSC) generates a 1 MHz output clock. The SFINTOSC clock signal is created from the HFINTOSC using dynamic divider logic, which provides a constant SFINTOSC clock rate regardless of the selected HFINTOSC frequency. The SFINTOSC cannot be used as the system clock, but may be selected as a clock source for certain peripherals, such as a Timer. #### 11.1.2.4 LFINTOSC The Low-Frequency Internal Oscillator (LFINTOSC) is a factory-calibrated 31 kHz internal clock source. The LFINTOSC can be used as a system clock source, and may be used by certain peripheral modules as a clock source. Additionally, the LFINTOSC provides a time base for the following: - Power-up Timer (PWRT) - Watchdog Timer (WDT) The LFINTOSC is enabled by programming the RSTOSC Configuration bits to select LFINTOSC. #### 11.1.2.5 ADCRC The Analog-to-Digital RC (ADCRC) oscillator is dedicated to the ADC module. This oscillator is also referred to as the FRC clock. The ADCRC operates at a fixed frequency of approximately 600 kHz, and is used as a conversion clock source. The ADCRC allows the ADC module to operate in Sleep mode, which can reduce system noise during the ADC conversion. The ADCRC is automatically enabled when it is selected as the clock source for the ADC module, or when selected as the clock source of any peripheral that may use it. The ADCRC may also be manually enabled via the ADC Oscillator Enable (ADOEN) bit, thereby avoiding start-up delays when this source is used intermittently. #### 11.1.3 Oscillator Status and Manual Enable The Oscillator Status (OSCSTAT) register displays the Ready status for each of the following oscillators: - HFINTOSC - MFINTOSC - LFINTOSC - SOSC - ADCRC - SFINTOSC The HFINTOSC Oscillator Ready (HFOR), MFINTOSC Oscillator Ready (MFOR), LFINTOSC Oscillator Ready (LFOR), ADCRC Oscillator Ready (ADOR), and SFINTOSC Oscillator Ready (SFOR) Status bits indicate whether the respective oscillators are ready for use. These clock sources are available for use at any time, but may require a finite amount of time before they have reached the specified accuracy levels. When the oscillators are ready and have achieved the specified accuracy, module hardware sets the respective bits. When a new value is loaded into the OSCFRQ register, the HFOR bit is cleared by hardware, and will be set again once the HFINTOSC is ready. During pending OSCFRQ changes, the HFINTOSC will stall at either a high or a low state until the oscillator locks in the new frequency and resumes operation. The SOSC Oscillator Ready (SOR) Status bit indicates whether the external clock source is ready for use. The SOSC uses the Oscillator Start-Up Timer (OST) to determine when the oscillator is ready. Once the OST has expired, the external oscillator is ready for use, and module hardware sets the SOR bit. The Oscillator Enable (OSCEN) register can be used to manually enable the following oscillators: - HFINTOSC - MFINTOSC - LFINTOSC - SOSC - ADCRC # 11.2 Active Clock Tuning (ACT) Many applications, such as those using UART communication, require an oscillator with an accuracy of $\pm$ 1% over the full temperature and voltage range. To meet this level of accuracy, the Active Clock Tuning (ACT) feature utilizes the SOSC frequency of 32.768 kHz to adjust the frequency of the HFINTOSC over voltage and temperature. **Important:** Active Clock Tuning requires the use of a 32.768 kHz external oscillator connected to the SOSCI/SOSCO pins. Active Clock Tuning is enabled via the Active Clock Tuning Enable (ACTEN) bit. When ACTEN is set (ACTEN = 1), the ACT module uses the SOSC time base to measure the HFINTOSC frequency, and uses the HFINTOSC Frequency Tuning (TUN) bits to adjust the HFINTOSC frequency. When ACTEN is clear (ACTEN = 0), the ACT feature is disabled, and user software can utilize the TUN bits to adjust the HFINTOSC frequency. **Important:** When the ACT feature is enabled, the TUN bits are controlled directly through module hardware and become read-only bits to user software. Writes to the TUN bits when the ACT feature is enabled are ignored. The figure below shows the Active Clock Tuning block diagram. Figure 11-5. Active Clock Tuning (ACT) Block Diagram #### 11.2.1 ACT Lock Status The Active Clock Tuning Lock Status (ACTLOCK) bit can be used to determine when the HFINTOSC has been tuned. When ACTLOCK is set (ACTLOCK = 1), the HFINTOSC frequency has been locked to within $\pm$ 1% of the nominal frequency. When ACTLOCK is clear (ACTLOCK = 0), the following conditions may be true: - The HFINTOSC frequency has not been locked to within ± 1% - A device Reset occurred - · The ACT feature is disabled **Important**: The ACTLOCK bit is read-only. Writes to ACTLOCK are ignored. ## 11.2.2 ACT Out-Of-Range Status When Active Clock Tuning is enabled, module hardware uses the TUN bits to achieve high accuracy levels. If the module requires a TUN value outside of its range, the ACT Out-of-Range Status (ACTORS) bit is set by hardware (ACTORS = 1). The ACTORS bit will be set when: • The HFINTOSC is tuned to its lowest frequency as determined by the TUN bits, and will require a value lower than the TUN bits can provide to achieve accuracy within ± 1%. # PIC16F18015/25/44/45 **OSC - Oscillator Module** • The HFINTOSC is tuned to its highest frequency as determined by the TUN bits, and will require a value higher than the TUN bits can provide to achieve accuracy within ± 1%. When an ACT out-of-range event occurs, the HFINTOSC will continue to use the last TUN value until the HFINTOSC frequency returns to the tunable range. Once the HFINTOSC returns to the tunable range, module hardware clears the ACTORS bit. **Important:** The ACTORS bit is read-only. Writes to ACTORS are ignored. ## 11.2.3 ACT Update Disable When Active Clock Tuning is enabled, the OSCTUNE register is continuously updated every ACT clock cycle. The ACT Update Disable (ACTUD) bit can be used to suspend updates to the OSCTUNE register. When ACTUD is set (ACTUD = 1), updates to OSCTUNE are suspended, although the module continues to operate. The last value written to OSCTUNE is used for tuning, and the ACTLOCK bit is continually updated for each ACT cycle. When ACTUD is clear (ACTUD = 0), the module updates OSCTUNE register every ACT cycle. ## 11.2.4 ACT Interrupts When Active Clock Tuning is enabled (ACTEN = 1) and either the ACTLOCK or ACTORS bits change state (e.g., from a Locked to an Unlocked state), the ACT Interrupt Flag (ACTIF) of the PIR registers is set (ACTIF = 1). If the ACT Interrupt Enable (ACTIE) bit is set (ACTIE = 1), an interrupt will be generated when ACTIF becomes set. No interrupts are generated for each OSCTUNE update unless the update results in a change of Lock status or Out-of-Range status. # 11.3 Register Definitions: Oscillator Module ## 11.3.1 ACTCON Name: ACTCON Offset: 0x0214 Active Clock Tuning Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|---|---|---------|---|--------|---| | | ACTEN | ACTUD | | | ACTLOCK | | ACTORS | | | Access | R/W | R/W | | | R | | R | | | Reset | 0 | 0 | | | 0 | | 0 | | # Bit 7 - ACTEN Active Clock Tuning Enable | Value | Description | |-------|---------------------------------------------------------------------------------------| | 1 | ACT enabled: HFINTOSC tuning is controlled by the ACT | | 0 | ACT disabled: HFINTOSC tuning is controlled by the OSCTUNE register via user software | ## Bit 6 - ACTUD Active Clock Tuning Update Disable | Value | Condition | Description | |-------|-----------|--------------------------------------------------------------------| | 1 | ACTEN = 1 | Updates to the OSCTUNE register from ACT hardware are disabled | | 0 | ACTEN = 1 | Updates to the OSCTUNE register from ACT hardware are allowed | | 1 | ACTEN = 0 | Updates to the OSCTUNE register through user software are disabled | | 0 | ACTEN = 0 | Updates to the OSCTUNE register through user software are allowed | # Bit 3 – ACTLOCK Active Clock Tuning Lock Status | Value | Description | |-------|-------------------------------------------------------------------------| | 1 | Locked: HFINTOSC is within ± 1% of its nominal value | | 0 | Not locked: HFINTOSC may or may not be within ± 1% of its nominal value | # Bit 1 – ACTORS Active Clock Tuning Out-of-Range Status | Value | Description | |-------|-----------------------------------------------------------| | 1 | Value required for tuning is outside of the OSCTUNE range | | 0 | Value required for tuning is within the OSCTUNE range | ## 11.3.2 OSCCON2 Name: OSCCON2 Offset: 0x020E Oscillator Control Register 2 Bits 6:4 – COSC[2:0] Current Oscillator Source Select (read-only)<sup>(1)</sup> Indicates the current oscillator source per the RSTOSC Selection Table. #### Note: 1. The RSTOSC value is the value present when user code execution begins. Refer to the RSTOSC configuration bits or the RSTOSC selection table for the Reset Oscillator selections. # 11.3.3 OSCCON3 Name: OSCCON3 Offset: 0x020F Oscillator Control Register 3 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---------|---|---|---|---|---|---| | | | SOSCPWR | | | | | | | | Access | | R/W | | • | | • | • | _ | | Reset | | 1 | | | | | | | Bit 6 - SOSCPWR Secondary Oscillator Power Mode Select | Value | Description | |-------|--------------------------------------------------| | 1 | Secondary Oscillator operates in High Power mode | | 0 | Secondary Oscillator operates in Low Power mode | # 11.3.4 OSCTUNE Name: OSCTUNE Offset: 0x0212 HFINTOSC Frequency Tuning Register Bits 5:0 - TUN[5:0] HFINTOSC Frequency Tuning | TUN | Condition | |---------|----------------------------------------------------------------------------------------------| | 01 1111 | Maximum frequency | | • | • | | • | • | | • | • | | 00 0000 | Center frequency. Oscillator is operating at the selected nominal frequency. (Default value) | | • | • | | • | • | | • | • | | 10 0000 | Minimum frequency | # 11.3.5 OSCFRQ Name: OSCFRQ Offset: 0x0213 HFINTOSC Frequency Selection Register Bits 2:0 - FRQ[2:0] HFINTOSC Frequency Selection | FRQ | Nominal Freq (MHz) | |---------|--------------------| | 111-110 | Reserved | | 101 | 32 | | 100 | 16 | | 011 | 8 | | 010 | 4 | | 001 | 2 | | 000 | 1 | ## 11.3.6 OSCSTAT Name: OSCSTAT Offset: 0x0210 Oscillator Status Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|------|------|------|-----|------|------|---| | | | HFOR | MFOR | LFOR | SOR | ADOR | SFOR | | | Access | | R | R | R | R | R | R | _ | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | | ## Bit 6 - HFOR HFINTOSC Ready | | Value | e Description | | |---|-------|---------------------------------------------------------|--| | ſ | 1 | The HFINTOSC is ready for use | | | | 0 | The HFINTOSC is not enabled, or it is not ready for use | | ## Bit 5 - MFOR MFINTOSC Ready | | Value | Description | | |---------------------------------|-------|---------------------------------------------------------|--| | 1 The MFINTOSC is ready for use | | The MFINTOSC is ready for use | | | Ī | 0 | The MFINTOSC is not enabled, or it is not ready for use | | ## Bit 4 - LFOR LFINTOSC Ready | Value | Description | | |-------|------------------------------------------------------|--| | 1 | The LFINTOSC is ready for use | | | 0 | The LFINTOSC is not enabled, or is not ready for use | | # Bit 3 - SOR Secondary Oscillator (SOSC) Ready | Value | Description | |-------|------------------------------------------------------------------| | 1 | The Secondary oscillator is ready for use | | 0 | The Secondary oscillator is not enabled, or is not ready for use | #### Bit 2 - ADOR ADCRC Oscillator Ready | Value | Description | | | |-------|--------------------------------------------------------------|--|--| | 1 | The ADCRC oscillator is ready for use | | | | 0 | The ADCRC oscillator is not enabled, or is not ready for use | | | # Bit 1 - SFOR SFINTOSC Oscillator Ready | Value | Description | |-------|-----------------------------------------------------------------| | 1 | The SFINTOSC oscillator is ready for use | | 0 | The SFINTOSC oscillator is not enabled, or is not ready for use | # 11.3.7 OSCEN Name: OSCEN Offset: 0x0211 Oscillator Enable Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|-------|-------|-------|--------|-------|---|---| | | | HFOEN | MFOEN | LFOEN | SOSCEN | ADOEN | | | | Access | | R/W | R/W | R/W | R/W | R/W | | | | Reset | | 0 | 0 | 0 | 0 | 0 | | | ## Bit 6 - HFOEN HFINTOSC Enable | | Value | Description | | | |--|-------|------------------------------------------------------------------|--|--| | | | HFINTOSC is explicitly enabled, operating as specified by OSCFRQ | | | | | | HFINTOSC can be enabled by a peripheral request | | | #### Bit 5 - MFOEN MFINTOSC Enable | Value | Description | | |-------|-------------------------------------------------|--| | 1 | MFINTOSC is explicitly enabled | | | 0 | MFINTOSC can be enabled by a peripheral request | | ## Bit 4 - LFOEN LFINTOSC Enable | | √alue | Description | | |----|-------|-------------------------------------------------|--| | Γ. | 1 | LFINTOSC is explicitly enabled | | | | ) | LFINTOSC can be enabled by a peripheral request | | # Bit 3 - SOSCEN Secondary Oscillator Enable | Value | Description | | | | | |-------|---------------------------------------------------------------|--|--|--|--| | 1 | SOSC is explicitly enabled, operating as specified by SOSCPWR | | | | | | 0 | SOSC can be enabled by a peripheral request | | | | | ## Bit 2 - ADOEN ADCRC Oscillator Enable | Value | Description | |-------|----------------------------------------------| | 1 | ADCRC is explicitly enabled | | 0 | ADCRC may be enabled by a peripheral request | # 11.4 Register Summary - Oscillator Module | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-------|---------|-----------|-------|---------|--------|----------|---| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x020D | | | | | | | | | | | | 0x020E | OSCCON2 | 7:0 | | | COSC[2:0] | | | | | | | 0x020F | OSCCON3 | 7:0 | | SOSCPWR | | | | | | | | 0x0210 | OSCSTAT | 7:0 | | HFOR | MFOR | LFOR | SOR | ADOR | SFOR | | | 0x0211 | OSCEN | 7:0 | | HFOEN | MFOEN | LFOEN | SOSCEN | ADOEN | | | | 0x0212 | OSCTUNE | 7:0 | | | | | TUN | I[5:0] | | | | 0x0213 | OSCFRQ | 7:0 | | | | | | | FRQ[2:0] | | | 0x0214 | ACTCON | 7:0 | ACTEN | ACTUD | | | ACTLOCK | | ACTORS | | # 12. INT - Interrupts ## 12.1 Overview The interrupt feature allows certain events to preempt normal program flow. Firmware is used to determine the source of the interrupt and act accordingly. Some interrupts can be configured to wake the MCU from Sleep mode. Many peripherals can produce interrupts. Refer to the corresponding chapters for details. A block diagram of the interrupt logic is shown in Figure 12-1. Figure 12-1. Interrupt Logic # 12.2 INTCON Register The Interrupt Control (INTCON) register is readable and writable, and contains the Global Interrupt Enable (GIE), Peripheral Interrupt Enable (PEIE) and External Interrupt Edge Select (INTEDG) bits. # 12.3 PIE Registers The Peripheral Interrupt Enable (PIE) registers contain the individual enable bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are five PIE registers in the PIC16F180 family. # 12.4 PIR Registers The Peripheral Interrupt Request (PIR) registers contain the individual flag bits for the peripheral interrupts. Due to the number of peripheral interrupt sources, there are five PIR registers. # 12.5 Operation Interrupts are disabled upon any device Reset. They are enabled by setting the following bits: - GIE bit - PEIE bit (if the Interrupt Enable bit of the interrupt event is contained in the PIE registers) Interrupt Enable bit(s) for the specific interrupt event(s) The PIR registers record individual interrupts via interrupt flag bits. Interrupt flag bits will be set, regardless of the status of the GIE, PEIE and individual interrupt enable bits. The following events happen when an interrupt event occurs while the GIE bit is set: - Current prefetched instruction is flushed - · GIE bit is cleared - · Current Program Counter (PC) is pushed onto the stack - Critical registers are automatically saved to the shadow registers (see the "Automatic Context Saving" section) - PC is loaded with the interrupt vector 0004h The firmware within the Interrupt Service Routine (ISR) may determine the source of the interrupt by polling the interrupt flag bits. The interrupt flag bits must be cleared before exiting the ISR to avoid repeated interrupts. Because the GIE bit is cleared, any interrupt that occurs while executing the ISR will be recorded through its interrupt flag, but will not cause the processor to redirect to the interrupt vector. The RETFIE instruction exits the ISR by popping the previous address from the stack, restoring the saved context from the shadow registers and setting the GIE bit. For additional information on a specific interrupts operation, refer to its peripheral chapter. #### Important: - 1. Individual interrupt flag bits are set, regardless of the state of any other enable bits. - 2. All interrupts will be ignored while the GIE bit is cleared. Any interrupt occurring while the GIE bit is clear will be serviced when the GIE bit is set again. # 12.6 Interrupt Latency Interrupt latency is defined as the time from when the interrupt event occurs to the time code execution at the interrupt vector begins. The interrupt is sampled during Q1 of the instruction cycle. The actual interrupt latency then depends on the instruction that is executing at the time the interrupt is detected. See the following figures for more details. Figure 12-2. Interrupt Latency #### Notes: - 1. An interrupt may occur at any time during the interrupt window. - 2. Since an interrupt may occur at any time during the interrupt window, the actual latency can vary. Figure 12-3. INT Pin Interrupt Timing #### Notes: - 1. INTF flag is sampled here (every Q1). - 2. Asynchronous interrupt latency = 3-5 T<sub>CY</sub>. Synchronous latency = 3-4 T<sub>CY</sub>, where T<sub>CY</sub> = instruction cycle time. Latency is the same whether Inst (PC) is a single cycle or a two-cycle instruction. - 3. For minimum width of INT pulse, refer to AC specifications in the "Electrical Specifications" chapter. - 4. INTF may be set anytime during the Q4-Q1 cycles. # 12.7 Interrupts During Sleep Interrupts can be used to wake from Sleep. To wake from Sleep, the peripheral must be able to operate without the system clock. The interrupt source must have the appropriate Interrupt Enable bit(s) set prior to entering Sleep. On waking from Sleep, if the GIE bit is also set, the processor will branch to the interrupt vector. Otherwise, the processor will continue executing instructions after the SLEEP instruction. The instruction directly after the SLEEP instruction will always be executed before branching to the ISR. # 12.8 INT Pin The INT pin can be used to generate an asynchronous edge-triggered interrupt. This interrupt is enabled by setting the External Interrupt Enable (INTE) bit. The External Interrupt Edge Select (INTEDG) bit determines on which edge the interrupt will occur. When the INTEDG bit is set, the rising edge will cause the interrupt. When the INTEDG bit is clear, the falling edge will cause the interrupt. The External Interrupt Flag (INTF) bit will be set when a valid edge appears on the INT pin. If the GIE and INTE bits are also set, the processor will redirect program execution to the interrupt vector. # 12.9 Automatic Context Saving Upon entering an interrupt, the return PC address is saved on the stack. Additionally, the following registers are automatically saved in the shadow registers: # PIC16F18015/25/44/45 **INT - Interrupts** - · WREG register - STATUS register (except for TO and PD) - · BSR register - · FSR registers - · PCLATH register Upon exiting the Interrupt Service Routine, these registers are automatically restored. Any modifications to these registers during the ISR will be lost. If modifications to any of these registers are desired, the corresponding shadow register may be modified and the value will be restored when exiting the ISR. The shadow registers are available in Bank 63 and are readable and writable. Depending on the user's application, other registers may also need to be saved. # 12.10 Register Definitions: Interrupt Control ## 12.10.1 INTCON Name: INTCON Offset: 0x000B Interrupt Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|------|---|---|---|---|---|--------| | | GIE | PEIE | | | | | | INTEDG | | Access | R/W | R/W | | | | | | R/W | | Reset | 0 | 0 | | | | | | 1 | ## Bit 7 - GIE Global Interrupt Enable | Value | Description | |-------|-------------------------------| | 1 | Enables all active interrupts | | 0 | Disables all interrupts | #### Bit 6 - PEIE Peripheral Interrupt Enable | | Value | Description | | | |--------------------------------------------|-------|------------------------------------|--|--| | 1 Enables all active peripheral interrupts | | | | | | | 0 | Disables all peripheral interrupts | | | #### Bit 0 - INTEDG External Interrupt Edge Select | Value | Description | |-------|--------------------------------------| | 1 | Interrupt on rising edge of INT pin | | 0 | Interrupt on falling edge of INT pin | **Note:** Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable bit. User software may ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt. This feature allows for software polling. ## 12.10.2 PIE0 Name: PIE0 Offset: 0x0096 Peripheral Interrupt Enable Register 0 #### Bit 5 - TMR0IE Timer0 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | TMR0 interrupts are enabled | | 0 | TMR0 interrupts are disabled | #### Bit 4 - IOCIE Interrupt-on-Change Enable | Value | Description | |-------|-----------------------------| | 1 | IOC interrupts are enabled | | 0 | IOC interrupts are disabled | #### Bit 0 – INTE External Interrupt Enable<sup>(1)</sup> | Value | Description | |-------|----------------------------------| | 1 | External interrupts are enabled | | 0 | External interrupts are disabled | #### Notes: - 1. The External Interrupt INT pin is selected by INTPPS. - 2. Bit PEIE in the INTCON register must be set to enable any peripheral interrupt controlled by registers PIE1 through PIE4. Interrupt sources controlled by the PIE0 register do not require the PEIE bit to be set in order to allow interrupt vectoring (when the GIE bit in the INTCON register is set). ## 12.10.3 PIE1 Name: PIE1 Offset: 0x0097 Peripheral Interrupt Enable Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---------|--------|---------|--------|-------|---|-------| | | TMR2IE | TMR3GIE | TMR3IE | TMR1GIE | TMR1IE | ACTIE | | NVMIE | | Access | R/W | R/W | R/W | R/W | R/W | R/W | | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | ## Bit 7 - TMR2IE TMR2 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | TMR2 interrupts are enabled | | 0 | TMR2 interrupts are disabled | ## Bit 6 - TMR3GIE TMR3 Gate Interrupt Enable | Value | Description | |-------|-----------------------------------| | 1 | TMR3 Gate interrupts are enabled | | 0 | TMR3 Gate interrupts are disabled | # Bit 5 - TMR3IE TMR3 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | TMR3 interrupts are enabled | | 0 | TMR3 interrupts are disabled | ## Bit 4 - TMR1GIE TMR1 Gate Interrupt Enable | Value | Description | |-------|-----------------------------------| | 1 | TMR1 Gate interrupts are enabled | | 0 | TMR1 Gate interrupts are disabled | #### Bit 3 - TMR1IE TMR1 Interrupt Enable | Val | lue | Description | | |-----|-----|------------------------------|--| | 1 | | TMR1 interrupts are enabled | | | 0 | | TMR1 interrupts are disabled | | # Bit 2 – ACTIE Active Clock Tuning Interrupt Enable | 1 | Value | Description | |---|-------|---------------------------------------------| | | 1 | Active Clock Tuning interrupts are enabled | | | 0 | Active Clock Tuning interrupts are disabled | #### Bit 0 - NVMIE NVM Interrupt Enable | Value | Description | |-------|-----------------------------| | 1 | NVM interrupts are enabled | | 0 | NVM interrupts are disabled | **Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt controlled by registers PIE1 through PIE4. ## 12.10.4 PIE2 Name: PIE2 Offset: 0x0098 Peripheral Interrupt Enable Register 2 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | CLC2IE | CLC1IE | CWG1IE | NCO1IE | CCP2IE | CCP1IE | TMR6IE | TMR4IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - CLC2IE CLC2 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | CLC2 interrupts are enabled | | 0 | CLC2 interrupts are disabled | ## Bit 6 - CLC1IE CLC1 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | CLC1 interrupts are enabled | | 0 | CLC1 interrupts are disabled | ## Bit 5 - CWG1IE CWG1 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | CWG1 interrupts are enabled | | 0 | CWG1 interrupts are disabled | #### Bit 4 - NCO1IE NCO1 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | NCO1 interrupts are enabled | | 0 | NCO1 interrupts are disabled | #### Bit 3 - CCP2IE CCP2 Interrupt Enable | Value | Description | | |-------|------------------------------|--| | 1 | CCP2 interrupts are enabled | | | 0 | CCP2 interrupts are disabled | | # Bit 2 - CCP1IE CCP1 Interrupt Enable | Value | Description | | |-------|------------------------------|--| | 1 | CCP1 interrupts are enabled | | | 0 | CCP1 interrupts are disabled | | #### Bit 1 - TMR6IE TMR6 Interrupt Enable | Value Description | | |-------------------|------------------------------| | 1 | TMR6 interrupts are enabled | | 0 | TMR6 interrupts are disabled | ## Bit 0 - TMR4IE TMR4 Interrupt Enable | Value | Description | | |-------|------------------------------|--| | 1 | TMR4 interrupts are enabled | | | 0 | TMR4 interrupts are disabled | | **Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt controlled by registers PIE1 through PIE4. ## 12.10.5 PIE3 Name: PIE3 Offset: 0x0099 Peripheral Interrupt Enable Register 3 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|-------|-------|-------|-------|--------|--------| | Γ | BCL1IE | SSP1IE | RC2IE | TX2IE | RC1IE | TX1IE | CLC4IE | CLC3IE | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 7 - BCL1IE MSSP1 Bus Collision Interrupt Enable | Value | Description | |-------|---------------------------------------------| | 1 | MSSP1 Bus Collision interrupts are enabled | | 0 | MSSP1 Bus Collision interrupts are disabled | # Bit 6 - SSP1IE MSSP1 Interrupt Enable | Value | Description | | | |-------|-------------------------------|--|--| | 1 | MSSP1 interrupts are enabled | | | | 0 | MSSP1 interrupts are disabled | | | #### Bit 5 - RC2|E EUSART2 Receive Interrupt Enable | Value | Description | | | |-------|-----------------------------------------|--|--| | 1 | EUSART2 receive interrupts are enabled | | | | 0 | EUSART2 receive interrupts are disabled | | | #### Bit 4 - TX2IE PWM1 Period Interrupt Enable | Value | Description | |-------|------------------------------------------| | 1 | EUSART2 transmit interrupts are enabled | | 0 | EUSART2 transmit interrupts are disabled | #### Bit 3 - RC1IE EUSART1 Receive Interrupt Enable | Value | Description | | |-------|-----------------------------------------|--| | 1 | EUSART1 receive interrupts are enabled | | | 0 | EUSART1 receive interrupts are disabled | | ## Bit 2 - TX1IE EUSART1 Transmit Interrupt Enable | Value | Description | | | |-------|------------------------------------------|--|--| | 1 | EUSART1 transmit interrupts are enabled | | | | 0 | EUSART1 transmit interrupts are disabled | | | #### Bit 1 - CLC4IE CLC4 Interrupt Enable | Value | Description | |-------|------------------------------| | 1 | CLC4 interrupts are enabled | | 0 | CLC4 interrupts are disabled | #### Bit 0 - CLC3IE CLC3 Interrupt Enable | | 2.10 2.20 interrupt 2.100 in | | | |-------|------------------------------|--|--| | Value | Description | | | | 1 | CLC3 interrupts are enabled | | | | 0 | CLC3 interrupts are disabled | | | #### Note: 1. Bit PEIE in the INTCON register must be set to enable any peripheral interrupt controlled by registers PIE1 through PIE4. # 12.10.6 PIE4 Name: PIE4 Offset: 0x009A Peripheral Interrupt Enable Register 4 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|-------|-------|------|-------|--------|--------| | | | | ZCDIE | ADTIE | ADIE | CM1IE | BCL2IE | SSP2IE | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 5 - ZCDIE Zero-Cross Detect (ZCD) Interrupt Enable | V | alue | Description | |---|------|-----------------------------| | 1 | | ZCD interrupts are enabled | | 0 | | ZCD interrupts are disabled | ## Bit 4 - ADTIE ADC Threshold Interrupt Enable | Value | Description | |-------|---------------------------------------| | 1 | ADC Threshold interrupts are enabled | | 0 | ADC Threshold interrupts are disabled | #### Bit 3 - ADIE ADC Interrupt Enable | Value | Description | |-------|-----------------------------| | 1 | ADC interrupts are enabled | | 0 | ADC interrupts are disabled | # Bit 2 - CM1IE Comparator 1 Interrupt Enable | Value | Description | |-------|--------------------------------------| | 1 | Comparator 1 interrupts are enabled | | 0 | Comparator 1 interrupts are disabled | #### Bit 1 - BCL2IE MSSP2 Bus Collision Interrupt Enable | Value Description | | |-------------------|---------------------------------------------| | 1 | MSSP2 Bus Collision interrupts are enabled | | 0 | MSSP2 Bus Collision interrupts are disabled | # Bit 0 - SSP2IE MSSP2 Interrupt Enable | Value | Description | |-------|-------------------------------| | 1 | MSSP2 interrupts are enabled | | 0 | MSSP2 interrupts are disabled | **Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt controlled by registers PIE1 through PIE4. ## 12.10.7 PIR0 Name: PIR0 Offset: 0x008C Peripheral Interrupt Request Register 0 #### Bit 5 - TMR0IF Timer0 Interrupt Flag | Value | Description | |-------|------------------------------------------------------------| | 1 | TMR0 register has overflowed (must be cleared by software) | | 0 | TMR0 register has not overflowed | ## Bit 4 - IOCIF Interrupt-on-Change Flag<sup>(2)</sup> | Value | Description | |-------|------------------------------------------------------------------------------------------------| | 1 | One or more of the IOCAF-IOCEF register bits are currently set, indicating an enabled edge was | | | detected by the IOC module | | 0 | None of the IOCAF-IOCEF register bits are currently set | ## Bit 0 - INTF External Interrupt Flag<sup>(1)</sup> | | Value | Description | |---|-------|-------------------------------------| | ſ | 1 | External Interrupt has occurred | | | 0 | External Interrupt has not occurred | #### Notes: - 1. The External Interrupt INT pin is selected by INTPPS. - 2. The IOCIF bit is the logical OR of all the IOCAF-IOCEF flags. Therefore, to clear the IOCIF flag, application firmware must clear all of the lower level IOCAF-IOCEF register bits. - 3. Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable (GIE) bit. User software may ensure the appropriate interrupt flag bits are cleared before enabling an interrupt. ## 12.10.8 PIR1 Name: PIR1 Offset: 0x008D Peripheral Interrupt Request Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|---------|--------|---------|--------|--------|---|--------| | | TMR2IF | TMR3GIF | TMR3IF | TMR1GIF | TMR1IF | ACTIF | | NVMIF | | Access | R/W/HS | R/W/HS | R/W/HS | R/W/HS | R/W/HS | R/W/HS | | R/W/HS | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | ## Bit 7 - TMR2IF TMR2 Interrupt Flag | Va | lue | Description | |----|-----|-----------------------------------------------------------| | 1 | | TMR2 interrupt has occurred (must be cleared in software) | | 0 | | TMR2 interrupt event has not occurred | ## Bit 6 - TMR3GIF TMR3 Gate Interrupt Flag | Value | Description | | |-------|---------------------------------------------------------------|--| | 1 | The TMR3 Gate has gone inactive (must be cleared in software) | | | 0 | TMR3 Gate is active | | ## Bit 5 - TMR3IF TMR3 Interrupt Flag | Value | Description | |-------|-----------------------------------------------------------| | 1 | TMR3 interrupt has occurred (must be cleared in software) | | 0 | TMR3 interrupt event has not occurred | ## Bit 4 - TMR1GIF TMR1 Gate Interrupt Flag | Value | Description | |-------|---------------------------------------------------------------| | 1 | The TMR1 Gate has gone inactive (must be cleared in software) | | 0 | TMR1 Gate is active | ## Bit 3 - TMR1IF TMR1 Interrupt Flag | Val | ue | Description | | | |-----|----|-----------------------------------------------------------|--|--| | 1 | | TMR1 interrupt has occurred (must be cleared in software) | | | | 0 | | TMR1 interrupt event has not occurred | | | ## Bit 2 - ACTIF Active Clock Tuning Interrupt Flag | Value | Description | |-------|----------------------------------------------------------------------| | 1 | Active Clock Tuning interrupt occurred (must be cleared in software) | | 0 | Active Clock Tuning interrupt event has not occurred | ## Bit 0 - NVMIF Nonvolatile Memory (NVM) Interrupt Flag | | <u> </u> | |-------|-------------------------------------------------------------------------| | Value | Description | | 1 | The requested NVM operation has completed (must be cleared in software) | | 0 | NVM interrupt event has not occurred | #### Note: 1. Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable (GIE) bit. User software may ensure the appropriate interrupt flag bits are cleared before enabling an interrupt. ## 12.10.9 PIR2 Name: PIR2 Offset: 0x008E Peripheral Interrupt Request Register 2 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|-----------------|--------|--------|--------|--------|--------|--------| | [ | CLC2IF | CLC1 <b>I</b> F | CWG1IF | NCO1IF | CCP2IF | CCP1IF | TMR6IF | TMR4IF | | Access | R/W/HS | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 7 - CLC2IF CLC2 Interrupt Flag | Value | Description | | |-------|-----------------------------------------------------------|--| | 1 | CLC2 interrupt has occurred (must be cleared in software) | | | 0 | CLC2 interrupt event has not occurred | | ## Bit 6 - CLC1IF CLC1 Interrupt Flag | 1 | /alue | Description | | |---|-------|-----------------------------------------------------------|--| | 1 | | CLC1 interrupt has occurred (must be cleared in software) | | | C | ) | CLC1 interrupt event has not occurred | | ## Bit 5 - CWG1IF CWG1 Interrupt Flag | Value | Description | | | |-------|-----------------------------------------------------------|--|--| | 1 | CWG1 interrupt has occurred (must be cleared in software) | | | | 0 | CWG1 interrupt event has not occurred | | | ## Bit 4 - NCO1IF NCO1 Interrupt Flag | Value | Description | | | |-------|-----------------------------------------------------------|--|--| | 1 | NCO1 interrupt has occurred (must be cleared in software) | | | | 0 | NCO1 interrupt event has not occurred | | | ## Bit 3 - CCP2IF CCP2 Interrupt Flag | Value | CCP Mode | | | | | |-------|---------------------------|---------------------------------|-------------------------------------|--|--| | value | Capture | Compare | PWM | | | | 1 | Capture occurred (must be | Compare match occurred (must be | Output trailing edge occurred (must | | | | | cleared in software) | cleared in software) | be cleared in software) | | | | 0 | Capture did not occur | Compare match did not occur | Output trailing edge did not occur | | | ## Bit 2 - CCP1IF CCP1 Interrupt Flag | Value | | CCP Mode | | | |-------|---------------------------|---------------------------------|-------------------------------------|--| | value | Capture | Compare | PWM | | | 1 | Capture occurred (must be | Compare match occurred (must be | Output trailing edge occurred (must | | | | cleared in software) | cleared in software) | be cleared in software) | | | 0 | Capture did not occur | Compare match did not occur | Output trailing edge did not occur | | ## Bit 1 - TMR6IF TMR6 Interrupt Flag | Value | Description | | |-------|-----------------------------------------------------------|--| | 1 | TMR6 interrupt has occurred (must be cleared in software) | | | 0 | TMR6 interrupt event has not occurred | | ## Bit 0 - TMR4IF TMR4 Interrupt Flag | Value | Description | | |-------|-----------------------------------------------------------|--| | 1 | TMR4 interrupt has occurred (must be cleared in software) | | | 0 | TMR4 interrupt event has not occurred | | **Note:** Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable (GIE) bit. User software may ensure the appropriate interrupt flag bits are cleared before enabling an interrupt. ## 12.10.10 PIR3 Name: PIR3 Offset: 0x008F Peripheral Interrupt Request Register 3 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|-------|----------------|-------|-------|-----------------|--------| | | BCL1IF | SSP1IF | RC2IF | TX2 <b>I</b> F | RC1IF | TX1IF | CLC4 <b>I</b> F | CLC3IF | | Access | R/W/HS | R/W/HS | R | R | R | R | R/W/HS | R/W/HS | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 7 - BCL1IF MSSP1 Bus Collision Interrupt Flag | Value | Description | |-------|-------------------------------------------------------------------| | 1 | An MSSP1 Bus Collision was detected (must be cleared in software) | | 0 | No MSSP1 Bus Collision event was detected | ## Bit 6 - SSP1IF MSSP1 Interrupt Flag | Value | ıe Description | | | |-------|------------------------------------------------------------|--|--| | 1 | MSSP1 interrupt has occurred (must be cleared in software) | | | | 0 | MSSP1 interrupt event has not occurred | | | ## Bit 5 - RC2IF EUSART2 Receive Interrupt Flag<sup>(1)</sup> | Value | /alue Description | | |-------|-------------------------------------------------------------------------------|--| | 1 | The EUSART2 receive buffer (RC2REG) is not empty (contains at least one byte) | | | 0 | The EUSART2 receive buffer is empty | | ## Bit 4 - TX2IF EUSART2 Transmit Interrupt Flag<sup>(2)</sup> | Value | Description | | |-------|-----------------------------------------------|--| | 1 | The EUSART2 transmit buffer (TX2REG) is empty | | | 0 | The EUSART2 transmit buffer is not empty | | ## Bit 3 - RC1IF EUSART1 Receive Interrupt Flag<sup>(3)</sup> | Value | Description | |-------|-------------------------------------------------------------------------------| | 1 | The EUSART1 receive buffer (RC1REG) is not empty (contains at least one byte) | | 0 | The EUSART1 receive buffer is empty | ## Bit 2 – TX1IF EUSART1 Transmit Interrupt Flag<sup>(4)</sup> | Value | Description | | |-------|-----------------------------------------------|--| | 1 | The EUSART1 transmit buffer (TX1REG) is empty | | | 0 | The EUSART1 transmit buffer is not empty | | ## Bit 1 - CLC4IF CLC4 Interrupt Flag | Valu | e Description | | |------|------------------|--------------------------------------------| | 1 | CLC4 interrupt h | has occurred (must be cleared in software) | | 0 | CLC4 interrupt e | event has not occurred | ## Bit 0 - CLC3IF CLC3 Interrupt Flag | Value | Description | |-------|-----------------------------------------------------------| | 1 | CLC3 interrupt has occurred (must be cleared in software) | | 0 | CLC3 interrupt event has not occurred | # PIC16F18015/25/44/45 **INT - Interrupts** #### Notes: - 1. RC2IF is read-only. User software must read RC2REG to clear RC2IF. - 2. TX2IF is read-only. User software must load TX2REG to clear TX2IF. TX2IF does not indicate a completed transmission (use TMRT for this purpose instead). - 3. RC1IF is read-only. User software must read RC1REG to clear RC1IF. - 4. TX1IF is read-only. User software must load TX1REG to clear TX1IF. TX1IF does not indicate a completed transmission (use TMRT for this purpose instead). - 5. Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable (GIE) bit. User software may ensure the appropriate interrupt flag bits are cleared before enabling an interrupt. ## 12.10.11 PIR4 Name: PIR4 Offset: 0x0090 Peripheral Interrupt Request Register 4 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|--------|--------|--------|--------|--------|--------| | | | | ZCDIF | ADTIF | ADIF | CM1IF | BCL2IF | SSP2IF | | Access | | | R/W/HS | R/W/HS | R/W/HS | R/W/HS | R/W/HS | R/W/HS | | Reset | | | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 5 - ZCDIF Zero-Cross Detect (ZCD) Interrupt Flag | Value | Description | |-------|--------------------------------------------------------| | 1 | A ZCD interrupt occurred (must be cleared in software) | | 0 | A ZCD interrupt has not occurred | ## Bit 4 - ADTIF ADC Threshold Interrupt Flag | Value | Description | |-------|--------------------------------------------------------------------| | 1 | ADC Threshold interrupt has occurred (must be cleared in software) | | 0 | ADC Threshold interrupt event has not occurred | #### Bit 3 - ADIF ADC Interrupt Flag | Value | Description | |-------|----------------------------------------------------------| | 1 | ADC interrupt has occurred (must be cleared in software) | | 0 | ADC interrupt event has not occurred | ## Bit 2 - CM1IF Comparator 1 Interrupt Flag | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Comparator 1 interrupt has occurred (must be cleared in software) | | 0 | Comparator 1 interrupt event has not occurred | ## Bit 1 - BCL2IF MSSP2 Bus Collision Interrupt Flag | Value | Description | |-------|-----------------------------------------------------------------------------| | 1 | An MSSP2 Bus Collision interrupt has occurred (must be cleared in software) | | 0 | No MSSP2 Bus Collision event was detected | ## Bit 0 - SSP2IF MSSP2 Interrupt Flag | Value | Description | |-------|-------------------------------------------------------------| | 1 | MSSP 2 interrupt has occurred (must be cleared in software) | | 0 | MSSP2 interrupt event has not occurred | ## Note: Interrupt flag bits are set when an Interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Enable (GIE) bit. User software may ensure the appropriate interrupt flag bits are cleared before enabling an interrupt. # 12.11 Register Summary - Interrupt Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|--------|-----------------|--------|---------|--------|--------|--------|--------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0A | | | | | | | | | | | | 0x0B | INTCON | 7:0 | GIE | PEIE | | | | | | INTEDG | | 0x0C | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x8B | | | | | | | | | | | | 0x8C | PIR0 | 7:0 | | | TMR0IF | IOCIF | | | | INTF | | 0x8D | PIR1 | 7:0 | TMR2IF | TMR3GIF | TMR3IF | TMR1GIF | TMR1IF | ACTIF | | NVMIF | | 0x8E | PIR2 | 7:0 | CLC2IF | CLC1IF | CWG1IF | NCO1IF | CCP2IF | CCP1IF | TMR6IF | TMR4IF | | 0x8F | PIR3 | 7:0 | BCL1IF | SSP1 <b>I</b> F | RC2IF | TX2IF | RC1IF | TX1IF | CLC4IF | CLC3IF | | 0x90 | PIR4 | 7:0 | | | ZCDIF | ADTIF | ADIF | CM1IF | BCL2IF | SSP2IF | | 0x91 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x95 | | | | | | | | | | | | 0x96 | PIE0 | 7:0 | | | TMR0IE | IOCIE | | | | INTE | | 0x97 | PIE1 | 7:0 | TMR2IE | TMR3GIE | TMR3IE | TMR1GIE | TMR1IE | ACTIE | | NVMIE | | 0x98 | PIE2 | 7:0 | CLC2IE | CLC1IE | CWG1IE | NCO1IE | CCP2IE | CCP1IE | TMR6IE | TMR4IE | | 0x99 | PIE3 | 7:0 | BCL1IE | SSP1IE | RC2IE | TX2IE | RC1IE | TX1IE | CLC4IE | CLC3IE | | 0x9A | PIE4 | 7:0 | | | ZCDIE | ADTIE | ADIE | CM1IE | BCL2IE | SSP2IE | # 13. Sleep Mode ## 13.1 Sleep Mode Operation Sleep mode is entered by executing the SLEEP instruction. Upon entering Sleep mode, the following conditions exist: - Resets other than WDT are not affected by Sleep mode; WDT will be cleared but keeps running if enabled for operation during Sleep. - The PD bit is cleared. - 3. The $\overline{TO}$ bit is set. - The CPU and the System clocks are disabled. - LFINTOSC and/or HFINTOSC will remain enabled if any peripheral has requested them as a clock source or if the HFOEN, MFOEN or LFOEN bits are set. - ADC is unaffected if the ADCRC oscillator is selected. When the ADC clock is something other than ADCRC, a SLEEP instruction causes the present conversion to be aborted and the ADC module is turned off, although the ADON bit remains active. - 7. I/O ports maintain the status they had before SLEEP was executed (driving high, low, or high-impedance) only if no peripheral connected to the I/O port is active. Refer to individual sections for more details on peripheral operation during Sleep. To minimize current consumption, the following conditions need to be considered: - · I/O pins will not be floating - · External circuitry sinking current from I/O pins - Internal circuitry sourcing current from I/O pins - Current draw from pins with internal weak pull-ups - Modules using any oscillator I/O pins that are high-impedance inputs need to be pulled to $V_{DD}$ or $V_{SS}$ externally to avoid switching currents caused by floating inputs. #### 13.1.1 Wake-Up from Sleep The device can wake up from Sleep through one of the following events: - 1. External Reset input on MCLR pin, if enabled. - 2. BOR Reset, if enabled. - 3. POR Reset. - 4. Watchdog Timer, if enabled. - 5. Any external interrupt. - 6. Interrupts by peripherals capable of running during Sleep (see the individual peripheral for more information). The first three events will cause a device Reset. The last three events are considered a continuation of program execution. To determine whether a device Reset or wake-up event occurred, refer to the "Determining the Cause of a Reset" section in the "Resets" chapter. When the SLEEP instruction is being executed, the next instruction (PC + 1) is prefetched. For the device to wake up through an interrupt event, the corresponding interrupt enable bit must be enabled. Wake-up will occur regardless of the state of the GIE bit. If the GIE bit is disabled, the device continues execution at the instruction after the SLEEP instruction after the SLEEP instruction and will then call the Interrupt Service Routine. In cases where the execution of the instruction following SLEEP is not desirable, the user needs to have a NOP after the SLEEP instruction. The WDT is cleared when the device wakes up from Sleep, regardless of the source of wake-up. ## 13.1.2 Wake-Up Using Interrupts When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur: - If the interrupt occurs before the execution of a SLEEP instruction: - The SLEEP instruction will execute as a NOP - The WDT and WDT prescaler will not be cleared - The TO bit will not be set - The PD bit will not be cleared - If the interrupt occurs during or after the execution of a SLEEP instruction: - The SLEEP instruction will be completely executed - The device will immediately wake up from Sleep - The WDT and WDT prescaler will be cleared - The TO bit will be set - The PD bit will be cleared Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the $\overline{PD}$ bit. If the $\overline{PD}$ bit is set, the SLEEP instruction was executed as a NOP. # 14. WDT - Watchdog Timer The Watchdog Timer (WDT) is a system timer that generates a Reset event if the firmware does not issue a CLRWDT instruction within the time-out period. The Watchdog Timer is typically used to reset the processor in the event of a software malfunction, but can also be used to wake the device when in Sleep mode. The WDT has the following features: - Selectable clock sources - Multiple operating modes: - WDT is always on - WDT is off when in Sleep - WDT is controlled by software - WDT is always off - Configurable time-out period from 1 ms to 256 seconds (nominal) - · Multiple Reset conditions - · Operation during Sleep Figure 14-1. WDT Block Diagram ## 14.1 Selectable Clock Sources The WDT can derive its time base from either the 32.768 SOSC or the 31 kHz LFINTOSC as selected by the WDT Clock Source Select (CS) bit. **Important:** Time intervals detailed in this section are based on a minimum nominal interval of 1 ms generated from the LFINTOSC clock source. # 14.2 WDT Operating Modes The WDT module has four operating modes controlled by the Watchdog Timer Enable (WDTE) bits. See Table 14-1. Table 14-1. WDT Operating Modes | WDTE[1:0] | SEN | Device Mode | WDT Mode | |-----------|-----|-------------|----------| | 11 | Х | Х | Active | | continued | | | | | | | | |-----------|---------------------------|-------|----------|--|--|--|--| | WDTE[1:0] | WDTE[1:0] SEN Device Mode | | | | | | | | 10 | x | Awake | Active | | | | | | 10 | | Sleep | Disabled | | | | | | 01 | 1 | X | Active | | | | | | OI | 0 | X | Disabled | | | | | | 00 | Х | X | Disabled | | | | | ## 14.2.1 WDT is Always On When the WDTE bits are set to '11', the WDT is always on. The WDT protection is active during Sleep mode. ## 14.2.2 WDT Is Off During Sleep When the WDTE bits are set to '10', the WDT is on except during Sleep mode. During Sleep mode, the WDT protection is disabled. ## 14.2.3 WDT Controlled by Software When the WDTE bits are set to '01', the WDT is controlled by the Software Watchdog Timer Enable (SEN) bit. When SEN is set (SEN = 1), WDT protection is active. When SEN is clear (SEN = 0), WDT protection is disabled. #### 14.2.4 WDT Is Off When the WDTE bits are set to '00', the WDT is disabled. In this mode, the SEN bit is ignored. ## 14.3 WDT Time-Out Period The Watchdog Timer Prescale Select (PS) bits set the time-out period from 1 ms to 256 seconds (nominal). After a Reset, the default time-out period is two seconds. ## 14.4 Clearing the WDT The WDT is cleared when any of the following conditions occur: - · Any Reset - Valid CLRWDT instruction is executed - Device enters Sleep - · Devices wakes up from Sleep - · Any write to the WDTCON register ## 14.5 WDT Operation During Sleep When the WDT enters Sleep, the WDT is cleared. If the WDT is enabled during Sleep, the WDT resumes counting. When the WDT exits Sleep, the WDT is cleared again. When a WDT time-out occurs while the device is in Sleep, no Reset is generated. Instead, the device wakes up and resumes operation. The Time-Out $(\overline{TO})$ and Power-Down $(\overline{PD})$ bits are cleared to indicate the event. Additionally, the Watchdog Timer Reset Flag $(\overline{RWDT})$ bit is cleared, indicating a WDT Reset event occurred. ## 14.6 Register Definitions: WDT Control ## 14.6.1 WDTCON Name: WDTCON Offset: 0x018C Watchdog Timer Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|-----|-----|---------|-----|-----|-----| | | CS | | | | PS[4:0] | | | SEN | | Access | R/W | • | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | Bit 7 - CS Watchdog Timer Clock Source Selection | Val | ue | Description | |-----|----|-------------------| | 1 | | SOSC (32.768 kHz) | | 0 | | LFINTOSC (31 kHz) | Bits 5:1 - PS[4:0] Watchdog Timer Prescale Selection<sup>(1)</sup> | | <u> </u> | |---------|----------------------------------------------| | Value | Description | | 11111 - | Reserved. Results in minimum interval (1:32) | | 10011 | | | 10010 | 1:8388608 (Interval 256s nominal) | | 10001 | 1:4194304 (Interval 128s nominal) | | 10000 | 1:2097152 (Interval 64s nominal) | | 01111 | 1:1048576 (Interval 32s nominal) | | 01110 | 1:524288 (Interval 16s nominal) | | | 1:262144 (Interval 8s nominal) | | 01100 | 1:131072 (Interval 4s nominal) | | | 1:65536 (Interval 2s nominal) (Reset value) | | 01010 | 1:32768 (Interval 1s nominal) | | | 1:16384 (Interval 512 ms nominal) | | 01000 | 1:8192 (Interval 256 ms nominal) | | 00111 | 1:4096 (Interval 128 ms nominal) | | 00110 | 1:2048 (Interval 64 ms nominal) | | | 1:1024 (Interval 32 ms nominal) | | 00100 | 1:512 (Interval 16 ms nominal) | | 00011 | 1:256 (Interval 8 ms nominal) | | | 1:128 (Interval 4 ms nominal) | | | 1:64 (Interval 2 ms nominal) | | 00000 | 1:32 (Interval 1 ms nominal) | ## Bit 0 - SEN Software WDT Enable/Disable | Value | Condition | Description | |-------|-------------------|---------------------| | X | If WDTE[1:0] ≠ 01 | This bit is ignored | | 1 | If WDTE[1:0] = 01 | WDT is enabled | | 0 | If WDTE[1:0] = 01 | WDT is disabled | ## Note: 1. Times are approximate and based on the 31 kHz LFINTOSC clock source. # 14.7 Register Summary - WDT Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|----|---|---|---|---------|---|---|-----| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x018B | | | | | | | | | | | | 0x018C | WDTCON | 7:0 | cs | | | | PS[4:0] | • | • | SEN | ## 15. NVM - Nonvolatile Memory Control The Nonvolatile Memory (NVM) module provides run-time read and write access to the Program Flash Memory (PFM), Data Flash Memory (DFM), and Configuration bits. PFM includes the program memory and user ID space. DFM is also referred to as EEPROM which is accessed one byte at a time and the erase before write is automatic. NVM is accessible using both FSR and INDF registers, or through the NVMREG register interface (see Table 15-1). The write time is controlled by an on-chip timer. The write/erase voltages are generated by an on-chip charge pump rated to operate over the operating voltage range of the device. PFM and DFM can be protected in two ways: code protection and write protection. Code protection (Configuration bits $\overline{CP}$ (PFM)/ $\overline{CPD}$ (DFM)) disables PFM/DFM read and write access through an external device programmer. Write protection prevents user software writes to NVM areas tagged for protection by the $\overline{WRTn}$ Configuration bits. Code protection does not affect the self-write and erase functionality, whereas write protection does. Attempts to write a protected location will set the WRERR bit. Code protection and write protection can only be reset on a Bulk Erase performed by an external programmer. The Bulk Erase command is used to completely erase program memory. The Bulk Erase command can only be issued through an external programmer. There is no run time access for this command. If the device is code-protected and a Bulk Erase command for the configuration memory is issued; all other memory regions are also erased. Refer to the "**Programming Specifications**" document for more details. Table 15-1. NVM Organization and Access Information | Main Values | | | | NVMREG Acces | FSR Access | | | | |--------------------|-------------------------|----------------------------------------------------------|--------------------------|-----------------------|-----------------------|----------------|---------------------------|--| | Memory<br>Function | Memory Type | Program<br>Counter<br>(PC), ICSP <sup>™</sup><br>Address | NVMREGS bit<br>(NVMCON1) | NVMADR[14:0] | Allowed<br>Operations | FSR<br>Address | FSR Programming<br>Access | | | Reset Vector | | 0x0000 | 0 | 0x0000 | | 0x8000 | | | | User Memory | | 0x0001 | 0 | 0x0001 | | 0x8001 | | | | Oser Memory | Program Flash | 0x0003 | 0 | 0x0003 | Read/Write | 0x8003 | Read-Only | | | INT Vector | Memory | 0x0004 | 0 | 0x0004 | ineau/vviile | 0x8004 | Reau-Only | | | Heer Memory | | 0x0005 | 0 | 0x0005 | | 0x8005 | | | | User Memory | | 0x3FFF <sup>(1)</sup> | U | 0x3FFF <sup>(1)</sup> | | 0xFFFF | | | | User ID | Program Flash | 0x8000 | 1 | 0x0000 | Read/Write | | | | | Oser ID | Memory | 0x8003 | 1 | 0x0003 | Reau/vviile | | | | | Reserved | _ | _ | _ | 0x0004 | _ | | | | | Revision ID | Hard Coded in | 0x8005 | 1 | 0x0005 | | | | | | Device ID | Program Flash<br>Memory | 0x8006 | 1 | 0x0006 | Read | | | | | CONFIG1 | | 0x8007 | 1 | 0x0007 | | No. A | | | | CONFIG2 | ] | 0x8008 | 1 | 0x0008 | | IN. | o Access | | | CONFIG3 | Program Flash<br>Memory | 0x8009 | 1 | 0x0009 | Read/Write | | | | | CONFIG4 | Wiemory | 0x800A | 1 | 0x000A | | | | | | CONFIG5 | | 0x800B | 1 | 0x000B | | | | | | | Hard Coded in | 0x8100 | 1 | 0x0100 | | | | | | DIA and DCI | Program Flash<br>Memory | 0x82FF | 1 | 0x02FF | Read | | | | | EEPROM | Data Flash | 0xF000 | 1 | 0x7000 | Read/Write | 0x7000 | Pead | | | LLFROW | Memory | 0xF0FF | Τ. | 0x70FF | rveau/vviile | 0x70FF | Read | | #### Note: 1. The maximum Program Flash Memory address for the PIC16F180 family is 0x3FFF. ## 15.1 Program Flash Memory (PFM) The Program Flash Memory (PFM) is readable, writable and erasable over the entire V<sub>DD</sub> range. PFM consists of the following regions: - User program memory (read/write) - · Configuration Words (read/write) - Device ID (read-only) - Revision ID (read-only) - User ID (read-write) - Device Information Area (read-only) - Device Configuration Information (read-only) PFM can be read and/or written to through: - CPU instruction fetch (read-only) - FSR/INDF indirect access (read-only) - NVMREG access (read-write) - In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) (external read-write) It is important to understand the program memory structure for erase and programming operations. Program memory is arranged in rows. A row consists of 32 14-bit program memory words. A row is the minimum size that can be erased by user software. A Bulk Erase command cannot be issued from user code. Read operations return a single word of memory. Write and erase operations are done on a row basis. Program memory will erase to a logic '1' and program to a logic '0'. All or a portion of a row can be programmed. Data to be written into the program memory row is written to 14-bit wide data write latches. These latches are not directly accessible, but may be loaded via sequential writes to the NVMDATH:NVMDATL register pair. **Important:** To modify only a portion of a previously programmed row, the contents of the entire row must be read. Then, the new data and retained data can be written into the write latches to reprogram the row of program memory. However, any unprogrammed locations can be written without first erasing the row. In this case, it is not necessary to save and rewrite the other previously programmed locations. Writing or erasing program memory will cease instruction fetches until the operation is complete. The program memory cannot be accessed during the write or erase, so code cannot execute. An internal programming timer controls the write time of program memory writes and erases. A value written to program memory does not need to be a valid instruction. Executing a program memory location that forms an invalid instruction results in a NOP. #### 15.1.1 FSR and INDF Access The File Select (FSR) and INDF registers allow indirect access to the Program Flash Memory. Indirect addressing is a mode in which the memory address in the instruction is determined by another register. The value of the FSR registers is used to determine the memory address location to be accessed. ## 15.1.1.1 FSR Read The FSRs are used to provide read access to program memory. Program memory is accessed by loading the FSRxH:FSRxL register pair with the address to be read, and setting bit 7 of the FSRxH register to '1'. When a MOVIW instruction, or any instruction that accesses INDFx, is executed, the value loaded into the FSRx register pair points to the location in program memory to be accessed. If the FSRx register pair points to an INDFx register, the read will return '0'. Reading from NVM requires one instruction cycle. The CPU operation is suspended during the read and resumes immediately after. Read operations return a single byte of memory. #### 15.1.1.2 FSR Write Writing/erasing the NVM through the FSR registers (e.g., the MOVWI instruction) is not supported in the PIC16F180 microcontroller family. #### 15.1.2 NVMREG Access The NVMREG interface allows read/write access to all the locations accessible by FSRs, read/write access to the User ID locations, and read-only access to the device identification, revision, and configuration data. Writing or erasing of NVM via the NVMREG interface is prevented when the device is write-protected. #### 15.1.2.1 NVMREG Read Operation To read a NVM location using the NVMREG interface, the user must: - Clear the NVMREGS bit if the user intends to access program memory locations, or set NMVREGS if the user intends to access User ID or configuration locations. - 2. Write the desired address into the NVMADRH:NVMADRL register pair. - 3. Set the RD bit to initiate the read. Once the read control bit is set, the CPU operation is suspended during the read and resumes immediately after. The data is available in the very next cycle, in the NVMDATH:NVMDATL register pair; therefore, it can be read as two bytes in the following instructions. The NVMDATH:NVMDATL register pair will hold this value until another read or until it is written to by the user. Upon completion, the RD bit is cleared by hardware. Figure 15-1. Program Flash Memory Read Sequence ``` Example 15-1. Program Memory Read // This code block will read 1 word of program memory NVMCON1bits.NVMREGS = 0; // Point to PFM NVMADR = PFM ADDRESS; // Load NVMADRL with PFM address NVMCON1bits.RD = 1; // Initiate read cycle PFM DATA_LOW = NVMDATL; // PFM data low byte PFM_DATA_HIGH = NVMDATH; // PFM data high byte ``` #### 15.1.2.2 NVM Unlock Sequence The unlock sequence is a mechanism that protects the NVM from unintended self-write programming or erasing. The sequence must be executed and completed without interruption to successfully complete any of the following operations: - PFM Row Erase - · Write of PFM write latches to PFM memory - · Write of PFM write latches to User IDs - Write to Configuration Words The unlock sequence consists of the following steps and must be completed in order: - Write 55h to NVMCON2 - Write AAh to NMVCON2 - Set the WR bit Once the WR bit is set, the processor will stall internal operations until the operation is complete and then resume with the next instruction. Since the unlock sequence must not be interrupted, global interrupts must be disabled prior to the unlock sequence and re-enabled after the unlock sequence is completed. Figure 15-2. NVM Unlock Sequence ``` Example 15-2. NVM Unlock Sequence NVMCON1bits.WREN = 1; // Enable write/erase INTCONbits.GIE = 0; // Disable global interrupts // The next three steps are the required unlock sequence NVMCON2 = 0x55; // First unlock code NVMCON2 = 0xAA; // Second unlock code // Initiate write/erase cycle NVMCON1bits.WR = 1; INTCONbits.GIE = 1; // Enable global interrupts NVMCON1bits.WREN = 0; // Disable further write/erase cycles ``` ## PIC16F18015/25/44/45 ## **NVM - Nonvolatile Memory Control** **Note:** Sequence begins when NVMCON2 is written; the three unlock steps must occur in the cycle-accurate order shown. If the timing of the sequence is corrupted by an interrupt or a debugger Halt, the action will not take place. ## 15.1.2.3 NVMREG Erase of Program Memory Before writing to program memory, the word(s) to be written must be erased or previously unwritten. Program memory can only be erased one row at a time. No automatic erase occurs upon the initiation of the write to program memory. To erase a program memory row: - Clear the NVMREGS bit to erase program memory locations, or set the NMVREGS bit to erase User ID locations. - 2. Write the desired address into the NVMADRH:NVMADRL register pair. - 3. Set the FREE and WREN bits. - 4. Perform the unlock sequence as described in the NVM Unlock Sequence section. If the program memory address is write-protected, the WR bit will be cleared and the erase operation will not take place. While erasing program memory, the CPU operation is suspended and resumes when the operation is complete. Upon completion, the NVMIF bit is set, and an interrupt will occur if the NVMIE bit is also set. Write latch data is not affected by erase operations, and WREN will remain unchanged. Figure 15-3. NVM Erase Sequence #### Note: 1. See the NVM Unlock Sequence section. #### Example 15-3. Erasing One Row of Program Flash Memory NVMCON1bits.NVMREGS = 0; // Point to PFM // 14-bit PFM address NVMADR = PFM ADD; NVMCON1bits.FREE = 1; // Specify an erase operation NVMCON1bits.WREN = 1; // Enable write/erase cycle INTCONbits.GIE = 0; // Disable interrupts during unlock sequence //The next three steps are the required unlock sequence // First unlock code NVMCON2 = 0x55;NVMCON2 = 0xAA;// Second unlock code // Initiate write/erase cycle NVMCON1bits.WR = 1; // Enable interrupts // Disable writes ## 15.1.2.4 NVMREG Write to Program Memory Program memory is programmed using the following steps: - Load the address of the row to be programmed into NVMADRH:NVMADRL. - Load each write latch with data via the NMVDATH:NVMDATL registers. 2. - 3. Initiate a programming operation. INTCONbits.GIE = 1; NVMCON1bits.WREN = 1; Repeat steps 1 through 3 until all data is written. Before writing to program memory, the word(s) to be written must be erased or previously unwritten. Program memory can only be erased one row at a time. No automatic erase occurs upon the initiation of the write. Program memory can be written one or more words at a time. The maximum number of words written at one time is equal to the number of write latches. See Figure 15-4 for more details. The write latches are aligned to the Flash row address boundary defined by the upper ten bits of NVMADRH:NVMADRL, (NVMADRH[6:0]:NVMADRL[7:5]) with the lower five bits of NVMADRL, (NVMADRL[4:0]) determining the write latch being loaded. Write operations do not cross these boundaries. At the completion of a program memory write operation, the data in the write latches is reset to contain 0x3FFF. The following steps must be completed to load the write latches and program a row of program memory. These steps are divided into two parts. First, each write latch is loaded with data from the NVMDATH:NVMDATL using the unlock sequence with LWLO = 1. When the last word to be loaded into the write latch is ready, the LWLO bit is cleared and the unlock sequence executed. This initiates the programming operation, writing all the latches into Flash program memory. Important: The special unlock sequence is required to load a write latch with data or initiate a Flash programming operation. If the unlock sequence is interrupted, writing to the latches or program memory will not be initiated. - 1. Set the WREN bit. - 2. Clear the NVMREGS bit. - Set the LWLO bit. When the LWLO bit is set (LWLO = 1), the write sequence will only load the write latches and will not initiate the write to Program Flash Memory. - 4. Load the NVMADRH:NVMADRL register pair with the address of the location to be written. - Load the NVMDATH:NVMDATL register pair with the program memory data to be written. - Execute the unlock sequence. The write latch is now loaded. - Increment the NVMADRH:NVMADRL register pair to point to the next location. - 8. Repeat steps 5 through 7 until all except the last write latch has been loaded. - Clear the LWLO bit. When the LWLO bit is clear (LWLO = 0), the write sequence will initiate the write to Program Flash Memory. - Load the NVMDATH:NVMDATL register pair with the program memory data to be written. 11. Execute the unlock sequence. The entire program memory latch content is now written to Flash program memory. **Important:** The program memory write latches are reset to the Blank state (0x3FFF) at the completion of every write or erase operation. As a result, it is not necessary to load all the program memory write latches. Unloaded latches will remain in the Blank state. An example of the complete write sequence is shown in Example 15-4. The initial address is loaded into the NVMADRH:NVMADRL register pair; the data is loaded using indirect addressing. Figure 15-4. NVMREG Writes to Program Flash Memory with 32 Write Latches Figure 15-5. Program Flash Memory Write Sequence #### Note: See the NVM Unlock Sequence section. ``` Example 15-4. Writing to Program Flash Memory // Disable interrupts INTCONbits.GIE = 0; // PFM row must be erased before writes can occur NVMCON1bits.NVMREGS = 0; // Point to PFM NVMADR = PFMStartAddress; // Must start at beginning of PFM row NVMCON1bits.FREE = 1; // Specify an erase operation // Allow erase cycle NVMCON1bits.WREN = 1; // Required unlock sequence NVMCON2 = 0x55; NVMCON2 = 0xAA; NVMCON1bits.WR = 1; NVMCON1bits.LWLO = 1; // Load write latches // Write to the data latches for (i = 0; i < PFM_ROW_SIZE; i++) // Load starting address NVMADR = PFMStartAddress; // Load data NVMDAT = PFM_WRITE_DATA; // Required unlock sequence NVMCON2 = 0x55; NVMCON2 = 0xAA; NVMCON1bits.WR = 1; PFMStartAddress++; // Increment address if(i = (PFM_ROW_SIZE - 1)) // All latches loaded? NVMCON1bits.LWLO = 0; // Start PFM write // Disable writes NVMCON1bits.WREN = 0; INTCONbits.GIE = 1; // Enable interrupts ``` ## 15.1.2.5 Modifying Flash Program Memory When modifying existing data in a program memory, data within the memory row must be read and saved in a RAM image. Program memory is modified using the following steps: - 1. Load the starting address of the row to be modified. - 2. Read the existing data from the row into a RAM image. - 3. Modify the RAM image to contain the new data to be written into program memory. - 4. Load the starting address of the row to be rewritten. - 5. Erase the program memory row. - 6. Load the write latches with data from the RAM image. - 7. Initiate a programming operation. Figure 15-6. Program Flash Memory Modify Sequence #### Notes: - 1. See Figure 15-1. - 2. See Figure 15-3. - 3. See Figure 15-5. ## 15.1.2.6 NVMREG Access to DIA, DCI, User ID, Device ID, Revision ID, and Configuration Words NVMREGS can be used to access the following memory regions: - Device Information Area (DIA) - Device Configuration Information (DCI) - User ID region - · Device ID and Revision ID - · Configuration Words The value of NVMREGS is set to '1' to access these regions. The memory regions listed above will be pointed to by PC[15] = 1, but not all addresses reference valid data. Different access may exist for reads and writes. Refer to the table below. When read access is initiated on an address outside the parameters listed in the following table, the NVMDATH: NVMDATL register pair is cleared, reading back '0's. # Table 15-2. NVMREG Access to DIA, DCI, User ID, Device ID, Revision ID and Configuration Words (NVMREGS = 1) | Address | Function | Read Access | Write Access | |-----------------|-------------------------|-------------|--------------| | 0x8000 - 0x8003 | User IDs | Yes | Yes | | 0x8005 - 0x8006 | Device ID/Revision ID | Yes | No | | 0x8007 - 0x800B | Configuration Words 1-5 | Yes | Yes | | 0x8100 - 0x82FF | DIA and DCI | Yes | No | | 0xF000 - 0xF0FF | EEPROM | Yes | Yes | ## 15.1.2.7 Write Verify It is considered good programming practice to verify that program memory writes agree with the intended value. Since program memory is stored as a full row then the stored program memory contents are compared with the intended data stored in RAM after the last write is complete. Figure 15-7. Program Flash Memory Write Verify Sequence #### Note: 1. See Figure 15-1. #### 15.1.2.8 WRERR Bit The WRERR bit can be used to determine if a write error occurred. WRERR will be set if one of the following conditions occurs: - · If WR is set while the NVMADRH:NMVADRL points to a write-protected address - · A Reset occurs while a self-write operation was in progress - · An unlock sequence was interrupted The WRERR bit is normally set by hardware, but can be set by the user for test purposes. Once set, WRERR must be cleared in software. #### Table 15-3. Actions for PFM When WR = 1 | Free | LWLO | Actions for PFM When WR = 1 | Comments | |------|------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | x | Erase the 32-word row of NVMADRH:NVMADRL location | <ul> <li>If WP is enabled, WR is cleared and WRERR is set</li> <li>All 32 words are erased</li> <li>NVMDATH:NVMDATL is ignored</li> </ul> | | 0 | 1 | Copy NVMDATH:NVMDATL to the write latch corresponding to NVMADR LSBs | <ul><li>Write protection is ignored</li><li>No memory access occurs</li></ul> | | 0 | 0 | Write the write-latch data to PFM row | <ul> <li>If WP is enabled, WR is cleared and WRERR is set</li> <li>Write latches are reset to 0x3FFF</li> <li>NVMDATH:NVMDATL is ignored</li> </ul> | ## 15.2 Data Flash Memory (DFM) The Data Flash Memory is a nonvolatile memory array, also referred to as EEPROM. The DFM is mapped above program memory space. The DFM can be accessed using the FSRs or NVM Special Function Registers (SFRs). The DFM is readable and writable during normal operation over the entire $V_{DD}$ range. The DFM can only be read and written one byte at a time. When interfacing to the data memory block, the NVMDATL register holds the 8-bit data for read/write and the NVMADR register pair holds the address of the DFM location being accessed. The DFM is rated for high erase/write cycle endurance. A byte write automatically erases the location and writes the new data (erase-before-write). The write time is controlled by an internal programming timer; it will vary with voltage and temperature as well as from device-to-device. Refer to the data EEPROM memory parameters in the "Electrical Specifications" chapter for more information. #### 15.2.1 FSR and INDF Access The File Select (FSR) and INDF registers allow read-only access to the DFM. The value of the FSR registers is used to determine the memory address location to be accessed. ## 15.2.1.1 FSR DFM Read DFM is accessed by loading the FSRxH:FSRxL register pair with the address to be read, and loading bits [7-4] of the FSRxH register with a value of '0111'. When a MOVIW instruction, or any instruction that accesses INDFx, is executed, the value loaded into the FSRx register pair points to the location in program memory to be accessed. If the FSRx register pair points to an unimplemented address location, the read will return '0'. ## 15.2.1.2 FSR DFM Write Writing/erasing the DFM through the FSR registers (e.g., the MOVWI instruction) is not supported in the PIC16F180 microcontroller family. ## 15.2.2 NVMREG Access The NVMREG interface allows read/write access to the DFM. Writing or erasing of DFM via the NVMREG interface is prevented when the DFM is write-protected (Configuration bit WRTD = '0'). #### 15.2.2.1 NVMREG Read Operation To read a DFM location using the NVMREG interface, the user must: - 1. Set the NVMREGS bit. - 2. Write the desired address into the NVMADRH:NVMADRL register pair. - 3. Set the RD bit to initiate the read. Once the read control bit is set, the CPU operation is suspended during the read and resumes immediately after. The data is available in the very next cycle, in the NVMDATL register; therefore, it can be read in the following instructions. The NVMDATL register will hold this value until another read or until it is written to by the user. Upon completion, the RD bit is cleared by hardware. Figure 15-8. Program Flash Memory Read Sequence #### 15.2.2.2 NVM Unlock Sequence The unlock sequence is a mechanism that protects the DFM from unintended self-write programming or erasing. The sequence must be executed and completed without interruption to successfully complete an erase or write operation. The unlock sequence consists of the following steps and must be completed in order: - Write 55h to NVMCON2 - Write AAh to NMVCON2 - Set the WR bit Once the WR bit is set, the processor will stall internal operations until the operation is complete and then resume with the next instruction. Since the unlock sequence must not be interrupted, global interrupts must be disabled prior to the unlock sequence and re-enabled after the unlock sequence is completed. Figure 15-9. NVM Unlock Sequence # Example 15-6. NVM Unlock Sequence **Note:** Sequence begins when NVMCON2 is written; the three unlock steps must occur in the cycle-accurate order shown. If the timing of the sequence is corrupted by an interrupt or a debugger Halt, the action will not take place. ## 15.2.2.3 NVMREG Erase of DFM DFM can be erased by writing '0xFF' to all locations that need to be erased. To erase a DFM word: - 1. Set the NVMREGS bit. - 2. Write the desired address into the NVMADRH:NVMADRL register pair. - 3. Set the WREN bit. - 4. Perform the unlock sequence as described in the NVM Unlock Sequence section. - Set the WR bit. A single byte (0xFF) is written into the DFM location. The DFM circuitry automatically erases the memory location before performing the write operation. If the DFM address is write-protected, the WR bit will be cleared and the write operation will not take place. While erasing/writing data memory, CPU operation is suspended and resumes when the operation is complete. Upon completion, hardware clears the WR bit, the NVMIF bit is set, and an interrupt will occur if the NVMIE bit is also set. Figure 15-10. DFM Erase Sequence ``` Example 15-7. Erasing One Byte of Data Flash Memory // Code sequence to erase one byte of DFM NVMCON1bits.NVMREGS = 1; // Point to DFM NVMADR = DFM_ADDR; // NVMADRH = 0x70, NVMADRL = DFM address NVMDATL = 0xFF; // Load NVMDATL with 0xFF ``` ## **NVM - Nonvolatile Memory Control** ``` NVMCON1bits WREN = 1; // Allows program/erase cycles INTCONbits.GIE = 0; // Disable interrupts // Perform required unlock sequence NVMCON2 = 0x55: NVMCON2 = 0xAA; NVMCON1bits.WR = 1; // Begin program/erase cycle // Restore interrupt enable bit value INTCONbits.GIE = 1; NVMCON1bits.WREN = 0; // Disable program/erase Verify byte erase operation success and call the recovery function if needed if (NVMCON1bits.WRERR) ERASE FAULT RECOVERY(); ``` #### 15.2.2.4 NVMREG Write to DFM DFM is programmed using the following steps: - 1. Set the NVMREGS bit. - 2. Load the NVMADRH:NVMADRL registers with the DFM address. - 3. Load the NVMDATL register with the data byte to be written. - 4. Set the WREN bit to allow write/erase cycles. - 5. Disable the GIE bit. - 6. Perform the NVM Unlock Sequence. - 7. Set the WR bit. A single byte (0xFF) is written into the DFM location. The DFM circuitry automatically erases the memory location before performing the write operation. If the DFM address is write-protected, the WR bit will be cleared and the write operation will not take place. While erasing/writing data memory, the CPU operation is suspended and resumes when the operation is complete. Upon completion, hardware clears the WR bit, the NVMIF bit is set, and an interrupt will occur if the NVMIE bit is also set. #### 15.2.2.5 WRERR Bit The WRERR bit can be used to determine if a write error occurred. WRERR will be set if one of the following conditions occurs: - If WR is set while the NVMADRH:NMVADRL points to a write-protected DFM address - A Reset occurs while a self-write operation was in progress - · An unlock sequence was interrupted The WRERR bit is normally set by hardware, but can be set by the user for test purposes. Once set, WRERR must be cleared in software. ## 15.3 Register Definitions: Nonvolatile Memory Control ## 15.3.1 **NVMADR** Name: NVMADR Offset: 0x1C8C Nonvolatile Memory Address Register Bits 14:0 - NVMADR[14:0] NVM Address Bits #### Notes: - 1. The individual bytes in this multibyte register can be accessed with the following register names: - NVMADRH: Accesses the high byte NVMADR[15:8] - NVMADRL: Accesses the low byte NVMADR[7:0]. - 2. Bit [15] is undefined while WR = 1. ## 15.3.2 NVMDAT Name: NVMDAT Offset: 0x1C8E Nonvolatile Memory Data Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-------------|-----|-------|----------|-----|-----| | | | | | | NVMDA | AT[13:8] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | X | X | X | x | x | x | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | NVMDAT[7:0] | | | | | | | Access | R/W | Reset | x | x | x | x | x | x | x | x | All Other Resets = uuuuuuuuuuuuu **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - NVMDATH: Accesses the high byte NVMDAT[13:8] - NVMDATL: Accesses the low byte NVMDAT[7:0] #### 15,3,3 NVMCON1 Name: NVMCON1 Offset: 0x1C90 Nonvolatile Memory Control 1 Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---------|------|--------|--------|------|--------|--------| | | | NVMREGS | LWLO | FREE | WRERR | WREN | WR | RD | | Access | | R/W | R/W | R/S/HC | R/W/HS | R/W | R/S/HC | R/S/HC | | Reset | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 6 - NVMREGS NVM Region Selection | Value | Description | |-------|---------------------------------------------------------------------------------------------| | 1 | Access DFM (EEPROM), DIA, DCI, Configuration, User ID, Revision ID, and Device ID Registers | | 0 | Access Program Flash Memory | ## Bit 5 - LWLO Load Write Latches Only | Value | Condition | Description | |-------|---------------|------------------------------------------------------------------------------| | 1 | When FREE = 0 | The next WR command updates the write latch for this word within the row; no | | | | memory operation is initiated | | 0 | When FREE = 0 | The next WR command writes data or erases | | _ | Otherwise: | This bit is ignored | ## Bit 4 - FREE Program Flash Memory Erase Enable | Value | Description | |-------|---------------------------------------------------------------------------------------------| | 1 | Performs an erase operation with the next WR command; the 32-word pseudo-row containing the | | | indicated address is erased (to all 1s) to prepare for writing | | 0 | The next WR command writes without erasing | ## Bit 3 – WRERR Write-Reset Error Flag(1,2,3) | Time Hood End Flag | | | | | | |--------------------|----------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | A write operation error has occurred | | | | | | 0 | All write operations have completed normally | | | | | ## Bit 2 - WREN Program/Erase Enable | Value | Description | |-------|-----------------------------------------------| | 1 | Allows program/erase cycles | | 0 | Inhibits programming/erasing of program Flash | ## Bit 1 - WR Write Control (4,5,6) | Value | Description | | | | | |-------|-------------------------------------------------------------------------|--|--|--|--| | 1 | Initiates the program/erase operation at the corresponding NVM location | | | | | | 0 | NVM program/erase operation is complete and inactive | | | | | #### Bit 0 - RD Read Control | Va | lue | Description | | | | | |----|-----|---------------------------------------------|--|--|--|--| | 1 | | Initiates a read at address = NVMADR | | | | | | 0 | | NVM read operation is complete and inactive | | | | | # PIC16F18015/25/44/45 # **NVM - Nonvolatile Memory Control** #### Notes: - 1. Bit is undefined while WR = 1. - 2. Bit must be cleared by software; hardware will not clear this bit. - 3. Bit may be written to '1' by the user to implement test sequences. - 4. This bit can only be set by following the sequence described in the "NVM Unlock Sequence" section. - 5. Operations are self-timed and the WR bit is cleared by hardware when complete. - 6. Once a write operation is initiated, setting this bit to zero will have no effect. ## 15.3.4 NVMCON2 Name: NVMCON2 Offset: 0x1C91 Nonvolatile Memory Control 2 Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------------|----|----|----|----|----|----|----| | [ | NVMCON2[7:0] | | | | | | | | | Access | WO | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - NVMCON2[7:0] Flash Memory Unlock Pattern bits **Note:** To unlock writes, a 0x55 must be written first followed by an 0xAA before setting the WR bit of the NVMCON1 register. The value written to this register is used to unlock the writes. # 15.4 Register Summary - NVM Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|--------------|--------------|------|------|-------|----------|----|----| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1C8B | | | | | | | | | | | | 0x1C8C | NVMADR | 7:0 | | NVMADR[7:0] | | | | | | | | | | 15:8 | | NVMADR[14:8] | | | | | | | | 0x1C8E | NVMDAT | 7:0 | | NVMDAT[7:0] | | | | | | | | UXICOE | NVIVIDAT | 15:8 | | | | | NVMDA | AT[13:8] | | | | 0x1C90 | NVMCON1 | 7:0 | | NVMREGS | LWLO | FREE | WRERR | WREN | WR | RD | | 0x1C91 | NVMCON2 | 7:0 | NVMCON2[7:0] | | | | | | | | ## 16. I/O Ports #### 16.1 Overview Table 16-1. Port Availability per Device | Device | PORTA | PORTB | PORTC | |-------------------|-------|-------|-------| | 8-pin devices | • | | | | 14/16-pin devices | • | | • | | 20-pin devices | • | • | • | Each port has eight registers to control the operation. These registers are: - · PORTx registers (reads the levels on the pins of the device) - LATx registers (output latch) - · TRISx registers (data direction) - ANSELx registers (analog select) - WPUx registers (weak pull-up) - INLVLx (input level control) - · SLRCONx registers (slew rate control) - ODCONx registers (open-drain control) In this section, the generic names such as PORTx, LATx, TRISx, etc. can be associated with PORTA, PORTB, PORTC, etc., depending on availability per device. A simplified model of a generic I/O port, without the interfaces to other peripherals, is shown in the following figure: Figure 16-1. Generic I/O Port Operation ## 16.2 PORTx - Data Register PORTx is a bidirectional port, and its corresponding data direction register is TRISx. Reading the PORTx register reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are Read-Modify-Write operations. Therefore, a write to a port implies that the PORT pins are read, and this value is modified, then written to the PORT data latch (LATx). The PORT data latch LATx holds the output port data and contains the latest value of a LATx or PORTx write. The example below shows how to initialize PORTA. ``` Example 16-1. Initializing PORTA in Assembly ; This code example illustrates initializing the PORTA register. ; The other ports are initialized in the same manner. BANKSEL PORTA PORTA ;Clear PORTA CLRF BANKSEL LATA CLRF LATA ;Clear Data Latch BANKSET. ANSELA CLRF ANSELA ;Enable digital drivers BANKSEL TRISA MOVLW B'00111000' ;Set RA[5:3] as inputs MOVWF TRISA ; and set others as outputs ``` **Important:** Most PORT pins share functions with device peripherals, both analog and digital. In general, when a peripheral is enabled on a PORT pin, that pin cannot be used as a general purpose output; however, the pin can still be read. # 16.3 LATx - Output Latch The Data Latch (LATx registers) is useful for Read-Modify-Write operations on the value that the I/O pins are driving. A write operation to the LATx register has the same effect as a write to the corresponding PORTx register. A read of the LATx register reads of the values held in the I/O PORT latches, while a read of the PORTx register reads the actual I/O pin value. **Important:** As a general rule, output operations to a port must use the LAT register to avoid Read-Modify-Write issues. For example, a bit set or clear operation reads the port, modifies the bit, and writes the result back to the port. When two bit operations are executed in succession, output loading on the changed bit may delay the change at the output in which case the bit will be misread in the second bit operation and written to an unexpected level. The LAT registers are isolated from the port loading and therefore changes are not delayed. ## 16.4 TRISx - Direction Control The TRISx register controls the PORTx pin output drivers, even when the pins are being used as analog inputs. The user must ensure the bits in the TRISx register are set when using the pins as analog inputs. I/O pins configured as analog inputs always read '0'. Setting a TRISx bit (TRISx = 1) will make the corresponding PORTx pin an input (i.e., disable the output driver). Clearing a TRISx bit (TRISx = 0) will make the corresponding PORTx pin an output (i.e., it enables output driver and puts the contents of the output latch on the selected pin). ## 16.5 ANSELx - Analog Control Ports that support analog inputs have an associated ANSELx register. The ANSELx register is used to configure the Input mode of an I/O pin to analog. Setting an ANSELx bit high will disable the digital input buffer associated with that bit and cause the corresponding input value to always read '0', whether the value is read in PORTx register or selected by PPS as a peripheral input. Disabling the input buffer prevents analog signal levels on the pin between a logic high and low from causing excessive current in the logic input circuitry. The state of the ANSELx bits has no effect on digital or analog output functions. A pin with TRIS clear and ANSEL set will still operate as a digital output, but the Input mode will be analog. This can cause unexpected behavior when executing Read-Modify-Write instructions on the PORTx register. **Important:** The ANSELx bits default to the Analog mode after Reset. To use any pins as digital general purpose or peripheral inputs, the corresponding ANSEL bits must be changed to '0' by the user. ## 16.6 WPUx - Weak Pull-Up Control The WPUx register controls the individual weak pull-ups for each PORT pin. When a WPUx bit is set (WPUx = 1), the weak pull-up will be enabled for the corresponding pin. When a WPUx bit is cleared (WPUx = 0), the weak pull-up will be disabled for the corresponding pin. #### 16.7 INLVLx - Input Threshold Control The INLVLx register controls the input voltage threshold for each of the available PORTx input pins. A selection between the Schmitt Trigger CMOS or the TTL compatible thresholds is available. If that feature is enabled, the input threshold is important in determining the value of a read of the PORTx register and also all other peripherals which are connected to the input. Refer to the I/O Ports table in the "Electrical Specifications" chapter for more details on threshold levels. **Important:** Changing the input threshold selection must be performed while all peripheral modules are disabled. Changing the threshold level during the time a module is active may inadvertently generate a transition associated with an input pin, regardless of the actual voltage level on that pin. ## 16.8 SLRCONx - Slew Rate Control The SLRCONx register controls the slew rate option for each PORT pin. Slew rate for each PORT pin can be controlled independently. When a SLRCONx bit is set (SLRCONx = 1), the corresponding PORT pin drive is slew rate limited. When a SLRCONx bit is cleared (SLRCONx = 0), the corresponding PORT pin drive slews at the maximum rate possible. ## 16.9 ODCONx - Open-Drain Control The ODCONx register controls the open-drain feature of the port. Open-drain operation is independently selected for each pin. When a ODCONx bit is set (ODCONx = 1), the corresponding port output becomes an open-drain driver capable of sinking current only. When a ODCONx bit is cleared (ODCONx = 0), the corresponding port output pin is the standard push-pull drive capable of sourcing and sinking current. **Important:** It is necessary to set open-drain control when using the pin for I<sup>2</sup>C. ## 16.10 Edge Selectable Interrupt-on-Change An interrupt can be generated by detecting a signal at the PORT pin that has either a rising edge or a falling edge. Individual pins can be independently configured to generate an interrupt. Refer to the "IOC - Interrupt-on-Change" chapter for more details. #### 16.11 I<sup>2</sup>C Pad Control For this family of devices, the I<sup>2</sup>C specific pads are available on RA1 and RA2 (8-pin devices), RB4, RB5, RB6, and RB7 (20-pin devices), and RC0, RC1, RC4, and RC5 (14/16-pin devices) pins. The I<sup>2</sup>C characteristics of each of these pins is controlled by the RxyI2C registers. These characteristics include enabling I<sup>2</sup>C specific slew rate (over standard GPIO slew rate), selecting internal pull-ups for I<sup>2</sup>C pins, and selecting appropriate input threshold as per SMBus specifications. Important: Any peripheral using the I<sup>2</sup>C pins reads the I<sup>2</sup>C input levels when enabled via Rxyl2C. #### 16.12 I/O Priorities Each pin defaults to the data latch after Reset. Other functions are selected with the Peripheral Pin Select logic. Refer to the "PPS - Peripheral Pin Select Module" chapter for more details. Analog input functions, such as ADC and comparator inputs, are not shown in the Peripheral Pin Select lists. These inputs are active when the I/O pin is set for Analog mode using the ANSELx register. Digital output functions may continue to control the pin when it is in Analog mode. Analog outputs, when enabled, take priority over digital outputs and force the digital output driver into a High-Impedance state. The pin function priorities are as follows: - 1. Port functions determined by the Configuration bits. - 2. Analog outputs (input buffers must be disabled). - 3. Analog inputs. - 4. Port inputs and outputs from PPS. ## 16.13 MCLR/V<sub>PP</sub>/RA3 Pin The $\overline{\text{MCLR}}/V_{PP}$ pin is an input-only pin. Its operation is controlled by the MCLRE Configuration bit. When selected as a PORT pin (MCLRE = 0), it functions as a digital input-only pin; as such, it does not have TRISx and LATx bits associated with its operation. Otherwise, it functions as the device's Master Clear input. In either configuration, the $\overline{\text{MCLR}}/V_{PP}$ pin also functions as the programming voltage input pin during high-voltage programming. The $\overline{\text{MCLR}/\text{V}_{PP}}$ pin is a read-only bit and will read '1' when MCLRE = 1 (i.e., Master Clear enabled). **Important:** On a Power-on Reset (POR), the $\overline{MCLR}/V_{PP}$ pin is enabled as a digital input-only if Master Clear functionality is disabled. The $\overline{\text{MCLR}}/\text{V}_{PP}$ pin has an individually controlled internal weak pull-up. When set, the corresponding WPU bit enables the pull-up. When the $\overline{\text{MCLR}}/\text{V}_{PP}$ pin is configured as $\overline{\text{MCLR}}$ (MCLRE = 1 and LVP = 0), or configured for Low-Voltage Programming (MCLRE = x and LVP = 1), the pull-up is always enabled and the WPU bit has no effect. ## 16.14 Register Definitions: Port Control #### 16,14,1 PORTx Name: PORTx PORTx Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|-----|-----|-----|-----| | | Rx7 | Rx6 | Rx5 | Rx4 | Rx3 | Rx2 | Rx1 | Rx0 | | Access | R/W | Reset | X | X | X | X | X | X | X | X | #### Bits 0, 1, 2, 3, 4, 5, 6, 7 - Rxn Port I/O Value Reset States: POR/BOR = xxxxxxxx All Other Resets = uuuuuuuu | Value | Description | |-------|-------------------------------| | 1 | PORT pin is ≥ V <sub>IH</sub> | | 0 | PORT pin is ≤ V <sub>IL</sub> | - Writes to PORTx are actually written to the corresponding LATx register. Reads from PORTx register return actual I/O pin values. - The PORT bit associated with the $\overline{MCLR}$ pin is read-only and will read '1' when the $\overline{MCLR}$ function is enabled (LVP = 1 or (LVP = 0 and MCLRE = 1)) - Refer to the "Pin Allocation Table" for details about MCLR pin and pin availability per port - Unimplemented bits will read back as '0' #### 16.14.2 LATx Name: LATx Output Latch Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | [ | LATx7 | LATx6 | LATx5 | LATx4 | LATx3 | LATx2 | LATx1 | LATx0 | | Access | R/W | Reset | Х | Х | X | X | Х | X | X | X | Bits 0, 1, 2, 3, 4, 5, 6, 7 - LATxn Output Latch Value Reset States: POR/BOR = xxxxxxxx All Other Resets = uuuuuuuu - Writes to LATx are equivalent to writes to the corresponding PORTx register. Reads from LATx register return register values, not I/O pin values. - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' ## 16,14,3 TRISx Name: TRISx Tri-State Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | TRISx7 | TRISx6 | TRISx5 | TRISx4 | TRISx3 | TRISx2 | TRISx1 | TRISx0 | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | #### Bits 0, 1, 2, 3, 4, 5, 6, 7 - TRISxn Port I/O Tri-state Control | Value | Description | |-------|--------------------------------------------------------------------------------| | 1 | PORTx output driver is disabled. PORTx pin configured as an input (tri-stated) | | 0 | PORTx output driver is enabled. PORTx pin configured as an output | - The TRIS bit associated with the $\overline{\text{MCLR}}$ pin is read-only and the value is '1' - Refer to the "Pin Allocation Table" for details about MCLR pin and pin availability per port - Unimplemented bits will read back as '0' #### 16.14.4 ANSELx Name: ANSELx Analog Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | Γ | ANSELx7 | ANSELx6 | ANSELx5 | ANSELx4 | ANSELx3 | ANSELx2 | ANSELx1 | ANSELx0 | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | #### Bits 0, 1, 2, 3, 4, 5, 6, 7 - ANSELxn Analog Select on RX Pin | Value | Description | |-------|-------------------------------------------------------------------------------| | 1 | Analog input. Pin is assigned as analog input. Digital input buffer disabled. | | 0 | Digital I/O. Pin is assigned to port or digital special function. | - When setting a pin as an analog input, the corresponding TRIS bit must be set to Input mode to allow external control of the voltage on the pin - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' #### 16,14,5 WPUx Name: WPUx Weak Pull-Up Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | WPUx7 | WPUx6 | WPUx5 | WPUx4 | WPUx3 | WPUx2 | WPUx1 | WPUx0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 0, 1, 2, 3, 4, 5, 6, 7 - WPUxn Weak Pull-up PORTx Control | √alue | Description | |-------|-----------------------| | 1 | Weak pull-up enabled | | ) | Weak pull-up disabled | - The weak pull-up device is automatically disabled if the pin is configured as an output, but this register remains unchanged - If MCLRE = 1, the weak pull-up on MCLR pin is always enabled and the corresponding WPU bit is not affected - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' ## 16.14.6 INLVLx Name: INLVLx Input Level Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|---------|---------|---------|---------|---------|---------|---------| | | INLVLx7 | INLVLx6 | INLVLx5 | INLVLx4 | INLVLx3 | INLVLx2 | INLVLx1 | INLVLx0 | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | #### Bits 0. 1. 2. 3. 4. 5. 6. 7 - INLVLxn Input Level Select on RX Pin | Die v, 1, 2, v, 1, v, v, 1 Intervent impact cover collect of 1 v v 1 in | | | | | | | | | | |-------------------------------------------------------------------------|-------------------------------------------------------|--|--|--|--|--|--|--|--| | Value | Description | | | | | | | | | | 1 | ST input used for port reads and interrupt-on-change | | | | | | | | | | 0 | TTL input used for port reads and interrupt-on-change | | | | | | | | | - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' #### 16.14.7 SLRCONx Name: SLRCONx Slew Rate Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | Γ | SLRx7 | SLRx6 | SLRx5 | SLRx4 | SLRx3 | SLRx2 | SLRx1 | SLRx0 | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | #### Bits 0, 1, 2, 3, 4, 5, 6, 7 - SLRxn Slew Rate Control on RX Pin | Value | Description | |-------|--------------------------------| | 1 | PORT pin slew rate is limited | | 0 | PORT pin slews at maximum rate | - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' #### 16.14.8 ODCONx Name: ODCONx Open-Drain Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | ODCx7 | ODCx6 | ODCx5 | ODCx4 | ODCx3 | ODCx2 | ODCx1 | ODCx0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 0. 1. 2. 3. 4. 5. 6. 7 - ODCxn Open-Drain Configuration on Rx Pin | , _, | o, i, o, o, i opon brain comigaration of tax in | |-------|-------------------------------------------------------------------------| | Value | Description | | 1 | PORT pin operates as open-drain drive (sink current only) | | 0 | PORT pin operates as standard push-pull drive (source and sink current) | - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' ## 16.14.9 Rxyl2C Name: Rxyl2C I<sup>2</sup>C Pad Rxy Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|------|-----|------|---|---|-----|-------| | | | SLEW | PU[ | 1:0] | | | TH | [1:0] | | Access | | R/W | R/W | R/W | | | R/W | R/W | | Reset | | 0 | 0 | 0 | | | 0 | 0 | ## Bit 6 - SLEW I2C Specific Slew Rate Limiting Control | Value | Description | |-------|-------------------------------------------------------------------------------------------------------------------| | 1 | I <sup>2</sup> C specific slew rate limiting is enabled. Standard pad slew limiting is disabled. The SLRxy bit is | | | ignored | | 0 | Standard GPIO Slew Rate; enabled/disabled via SLRxy bit | ## Bits 5:4 – PU[1:0] I<sup>2</sup>C Pull-Up Selection | Value | Description | |-------|-------------------------------------------------------| | 11 | Reserved | | 10 | 10x current of standard weak pull-up | | 01 | 2x current of standard weak pull-up | | 00 | Standard GPIO weak pull-up, enabled via the WPUxy bit | ## Bits 1:0 - TH[1:0] I<sup>2</sup>C Input Threshold Selection | Value | Description | |-------|----------------------------------------------------------------| | value | Description | | 11 | SMBus 3.0 (1.35V) input threshold | | 10 | SMBus 2.0 (2.1V) input threshold | | 01 | I <sup>2</sup> C-specific input thresholds | | 00 | Standard GPIO Input pull-up, enabled via the INLVLxy registers | - Refer to the "Pin Allocation Table" for details about pin availability per port - Unimplemented bits will read back as '0' # 16.15 Register Summary - IO Ports | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------|----------------|------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0B | | | | | | | | | | | | 0x0C | PORTA | 7:0 | 555 | 222 | RA5 | RA4 | RA3 | RA2 | RA1 | RA0 | | 0x0D | PORTB | 7:0 | RB7 | RB6 | RB5 | RB4 | 200 | | 504 | 500 | | 0x0E | PORTC | 7:0 | RC7 | RC6 | RC5 | RC4 | RC3 | RC2 | RC1 | RC0 | | 0x0F | Reserved | | | | | | | | | | | <br>0x11 | Neserveu | | | | | | | | | | | 0x11 | TRISA | 7:0 | | | TRISA5 | TRISA4 | Reserved | TRISA2 | TRISA1 | TRISA0 | | 0x13 | TRISB | 7:0 | TRISB7 | TRISB6 | TRISB5 | TRISB4 | 110001100 | | | | | 0x14 | TRISC | 7:0 | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | | 0x15 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x17 | | | | | | | | | | | | 0x18 | LATA | 7:0 | | | LATA5 | LATA4 | | LATA2 | LATA1 | LATA0 | | 0x19 | LATB | 7:0 | LATB7 | LATB6 | LATB5 | LATB4 | | | | | | 0x1A | LATC | 7:0 | LATC7 | LATC6 | LATC5 | LATC4 | LATC3 | LATC2 | LATC1 | LATC0 | | 0x1B | _ | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E8B | ANIOE! A | 7.0 | | | 4105145 | ANOE! A 4 | 111051.10 | ANGELAG | 41105144 | 1105110 | | 0x1E8C | ANSELA<br>WPUA | 7:0 | | | ANSELA5 | ANSELA4 | ANSELA3 | ANSELA2 | ANSELA1 | ANSELA0 | | 0x1E8D<br>0x1E8E | ODCONA | 7:0<br>7:0 | | | WPUA5<br>ODCA5 | WPUA4<br>ODCA4 | WPUA3 | WPUA2<br>ODCA2 | WPUA1<br>ODCA1 | WPUA0<br>ODCA0 | | 0x1E8E | SLRCONA | 7:0 | | | SLRA5 | SLRA4 | | SLRA2 | SLRA1 | SLRA0 | | 0x1E81 | INLVLA | 7:0 | | | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2 | INLVLA1 | INLVLA0 | | 0x1E90 | INLVLA | 7.0 | | | INLVEAS | INLVLA | INLVEAS | INLVEAZ | INCVERT | INLVEAU | | | Reserved | | | | | | | | | | | 0x1E95 | 110001104 | | | | | | | | | | | 0x1E96 | ANSELB | 7:0 | ANSELB7 | ANSELB6 | ANSELB5 | ANSELB4 | | | | | | 0x1E97 | WPUB | 7:0 | WPUB7 | WPUB6 | WPUB5 | WPUB4 | | | | | | 0x1E98 | ODCONB | 7:0 | ODCB7 | ODCB6 | ODCB5 | ODCB4 | | | | | | 0x1E99 | SLRCONB | 7:0 | SLRB7 | SLRB6 | SLRB5 | SLRB4 | | | | | | 0x1E9A | INLVLB | 7:0 | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | | | | | | 0x1E9B | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E9F | ANOFLO | 7.0 | ANIOELOZ | ANGELOS | ANIOFICE | ANOFIOA | ANGELOS | ANGELOS | ANGELOA | ANOFICO | | 0x1EA0 | ANSELC | 7:0 | ANSELC7 | ANSELC6 | ANSELC5 | ANSELC4 | ANSELC3 | ANSELC2 | ANSELC1 | ANSELCO | | 0x1EA1<br>0x1EA2 | WPUC ODCONC | 7:0<br>7:0 | WPUC7<br>ODCC7 | WPUC6<br>ODCC6 | WPUC5<br>ODCC5 | WPUC4<br>ODCC4 | WPUC3<br>ODCC3 | WPUC2<br>ODCC2 | WPUC1<br>ODCC1 | WPUC0<br>ODCC0 | | 0x1EA2 | SLRCONC | 7:0 | SLRC7 | SLRC6 | SLRC5 | SLRC4 | SLRC3 | SLRC2 | SLRC1 | SLRC0 | | 0x1EA4 | INLVLC | 7:0 | INLVLC7 | INLVLC6 | INLVLC5 | INLVLC4 | INLVLC3 | INLVLC2 | INLVLC1 | INLVLC0 | | 0x1EA5 | | 7.5 | 11121207 | 11127200 | 11121200 | 11,1,1,1,0,1 | 11127200 | 11127202 | 11127201 | 11,2,200 | | | Reserved | | | | | | | | | | | 0x1EE0 | | | | | | | | | | | | 0x1EE1 | RA1I2C | 7:0 | | SLEW | PU[ | 1:0] | | | THI | 1:0] | | 0x1EE2 | RA2I2C | 7:0 | | SLEW | PU[ | | | | TH | 1:0] | | 0x1EE3 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1EE4 | | | | | | | | | | | | 0x1EE5 | RB4I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE6 | RB5I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE7 | RB6I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE7 | RB7I2C | 7:0 | | SLEW | PU[ | 1:0] | | | TH | [1:0] | | 0x1EE8 | Reserved | 7.0 | | 01 = 111 | | 4 . 01 | | | | 4.01 | | 0x1EE9 | RC0I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EEA | RC1I2C | 7:0 | | SLEW | PU[ | 1:0] | | | ſĦļ | [1:0] | # PIC16F18015/25/44/45 I/O Ports | continued | | | | | | | | | | | |-----------|----------|----------|---|------|----|-------|---|---|----|-------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x1EEB | Reserved | | | | | | | | | | | 0x1EEC | RC4I2C | 7:0 | | SLEW | PU | [1:0] | | | TH | [1:0] | | 0x1EED | RC5I2C | 7:0 | | SLEW | PU | [1:0] | | | TH | [1:0] | # 17. IOC - Interrupt-on-Change #### 17.1 Overview The pins denoted in the table below can be configured to operate as interrupt-on-change (IOC) pins for this device. An interrupt can be generated by detecting a signal that has either a rising edge or a falling edge. Any individual PORT pin, or combination of PORT pins, can be configured to generate an interrupt. Table 17-1. IOC Pin Availability per Device | Device | PORTA | PORTB | PORTC | |-------------------|-------|-------|-------| | 8-pin devices | • | | | | 14/16-pin devices | • | | • | | 20-pin devices | • | • | • | **Important:** If MCLRE = 1 or LVP = 1, the $\overline{\text{MCLR}}$ pin port functionality is disabled and IOC on that pin is not available. The interrupt-on-change module has the following features: - · Interrupt-on-change enable (Host Switch) - · Individual pin configuration - · Rising and falling edge detection - · Individual pin interrupt flags The following figure is a block diagram of the IOC module. Figure 17-1. Interrupt-on-Change Block Diagram (PORTA Example) ## 17.2 Enabling the Module For individual PORT pins to generate an interrupt, the IOC Interrupt Enable (IOCIE) bit of the Peripheral Interrupt Enable (PIEx) register must be set. If the IOC Interrupt Enable bit is disabled, the edge detection on the pin will still occur, but an interrupt will not be generated. ## 17.3 Individual Pin Configuration A rising edge detector and a falling edge detector are present for each PORT pin. To enable a pin to detect a rising edge, the associated bit of the IOCxP register must be set. To enable a pin to detect a falling edge, the associated bit of the IOCxN register must be set. A PORT pin can be configured to detect rising and falling edges simultaneously by setting both associated bits of the IOCxP and IOCxN registers, respectively. ## 17.4 Interrupt Flags The bits located in the IOCxF registers are status flags that correspond to the interrupt-on-change pins of each port. If an expected edge is detected on an appropriately enabled pin, then the status flag for that pin will be set, and an interrupt will be generated if the IOCIE bit is set. The IOCIF bit located in the corresponding Peripheral Interrupt Request (PIRx) register, is all the IOCxF bits ORd together. The IOCIF bit is read-only. All of the IOCxF Status bits must be cleared to clear the IOCIF bit. ## 17.5 Clearing Interrupt Flags The individual status flags (IOCxF register bits) will be cleared by resetting them to zero. If another edge is detected during this clearing operation, the associated status flag will be set at the end of the sequence, regardless of the value actually being written. To ensure that no detected edge is lost while clearing flags, only AND operations masking out known changed bits must be performed. The following sequence is an example of clearing an IOC interrupt flag using this method. ## 17.6 Operation in Sleep An interrupt-on-change event will wake the device from Sleep mode, if the IOCIE bit is set. If an edge is detected while in Sleep mode, the IOCxF register will be updated prior to the first instruction executed out of Sleep. # 17.7 Register Definitions: Interrupt-on-Change Control #### 17.7.1 IOCxF Name: IOCxF Interrupt-on-Change Flag Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | IOCxF7 | IOCxF6 | IOCxF5 | IOCxF4 | IOCxF3 | IOCxF2 | IOCxF1 | IOCxF0 | | Access | R/W/HS | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 0, 1, 2, 3, 4, 5, 6, 7 – IOCxFn Interrupt-on-Change Flag | Value | Condition | Description | |-------|---------------------------------|-----------------------------------------------------------------| | 1 | IOCxP[n] = 1 | A positive edge was detected on the Rx[n] pin | | 1 | IOCxN[n] = 1 | A negative edge was detected on the Rx[n] pin | | 0 | IOCxP[n] = x and $IOCxN[n] = x$ | No change was detected, or the user cleared the detected change | - If MCLRE = 1 or LVP = 1, the MCLR pin port functionality is disabled and IOC on that pin is not available - Refer to the "Pin Allocation Table" for details about pins with configurable IOC per port #### 17.7.2 IOCxN Name: IOCxN Interrupt-on-Change Negative Edge Register Example | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | Γ | IOCxN7 | IOCxN6 | IOCxN5 | IOCxN4 | IOCxN3 | IOCxN2 | IOCxN1 | IOCxN0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 0, 1, 2, 3, 4, 5, 6, 7 - IOCxNn Interrupt-on-Change Negative Edge Enable | Value | Description | | | | | |-------|--------------------------------------------------------------------------------------------------|--|--|--|--| | 1 | Interrupt-on-change enabled on the IOCx pin for a negative-going edge. Associated Status bit and | | | | | | | interrupt flag will be set upon detecting an edge. | | | | | | 0 | Falling edge interrupt-on-change disabled for the associated pin | | | | | - If MCLRE = 1 or LVP = 1, the MCLR pin port functionality is disabled and IOC on that pin is not available - Refer to the "Pin Allocation Table" for details about pins with configurable IOC per port #### 17.7.3 IOCxP Name: IOCxP Interrupt-on-Change Positive Edge Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|--------|--------|--------|--------|--------| | | IOCxP7 | IOCxP6 | IOCxP5 | IOCxP4 | IOCxP3 | IOCxP2 | IOCxP1 | IOCxP0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 0, 1, 2, 3, 4, 5, 6, 7 – IOCxPn Interrupt-on-Change Positive Edge Enable | Value | Description | | | | | | |-------|--------------------------------------------------------------------------------------------------|--|--|--|--|--| | 1 | Interrupt-on-change enabled on the IOCx pin for a positive-going edge. Associated Status bit and | | | | | | | | interrupt flag will be set upon detecting an edge. | | | | | | | 0 | Rising edge interrupt-on-change disabled for the associated pin. | | | | | | - If MCLRE = 1 or LVP = 1, the MCLR pin port functionality is disabled and IOC on that pin is not available - Refer to the "Pin Allocation Table" for details about pins with configurable IOC per port # 17.8 Register Summary - Interrupt-on-Change | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------|----------|----------|--------|--------|--------|--------|--------|--------|--------|--------| | 0x00 | | | | | | | | | | | | <br>0x1E90 | Reserved | | | | | | | | | | | 0x1E91 | IOCAP | 7:0 | | | IOCAP5 | IOCAP4 | IOCAP3 | IOCAP2 | IOCAP1 | IOCAP0 | | 0x1E92 | IOCAN | 7:0 | | | IOCAN5 | IOCAN4 | IOCAN3 | IOCAN2 | IOCAN1 | IOCAN0 | | 0x1E93 | IOCAF | 7:0 | | | IOCAF5 | IOCAF4 | IOCAF3 | IOCAF2 | IOCAF1 | IOCAF0 | | 0x1E94<br><br>0x1E9A | Reserved | | | | | | | | | | | 0x1E9B | IOCBP | 7:0 | IOCBP7 | IOCBP6 | IOCBP5 | IOCBP4 | | | | | | 0x1E9C | IOCBN | 7:0 | IOCBN7 | IOCBN6 | IOCBN5 | IOCBN4 | | | | | | 0x1E9D | IOCBF | 7:0 | IOCBF7 | IOCBF6 | IOCBF5 | IOCBF4 | | | | | | 0x1E9E<br><br>0x1EA4 | Reserved | | | | | | | | | | | 0x1EA5 | IOCCP | 7:0 | IOCCP7 | IOCCP6 | IOCCP5 | IOCCP4 | IOCCP3 | IOCCP2 | IOCCP1 | IOCCP0 | | 0x1EA6 | IOCCN | 7:0 | IOCCN7 | IOCCN6 | IOCCN5 | IOCCN4 | IOCCN3 | IOCCN2 | IOCCN1 | IOCCN0 | | 0x1EA7 | IOCCF | 7:0 | IOCCF7 | IOCCF6 | IOCCF5 | IOCCF4 | IOCCF3 | IOCCF2 | IOCCF1 | IOCCF0 | # 18. PPS - Peripheral Pin Select Module #### 18.1 Overview The Peripheral Pin Select (PPS) module connects peripheral inputs and outputs to the device I/O pins. Only digital signals are included in the selections. **Important:** All analog inputs and outputs remain fixed to their assigned pins and cannot be changed through PPS. Input and output selections are independent as shown in the figure below. Figure 18-1. PPS Block Diagram ## 18.2 PPS Inputs Each digital peripheral has a dedicated PPS Peripheral Input Selection (xxxPPS) register with which the input pin to the peripheral is selected. Devices that have 20 leads or less (8/14/16/20) allow PPS routing to any I/O pin, while devices with 28 leads or more allow PPS routing to I/Os contained within two ports (see the table below). **Important:** The notation "xxx" in the generic register name is a placeholder for the peripheral identifier. For example, xxx = T0CKI for the T0CKIPPS register. Multiple peripherals can operate from the same source simultaneously. Port reads always return the pin level regardless of peripheral PPS selection. If a pin also has analog functions associated, the ANSEL bit for that pin must be cleared to enable the digital input buffer. Table 18-1. PPS Input Selection Table | | | Regis | ster Reset Value a | at POR | Default Pin Selection at POR | | | |---------------------------|---------------------------|-------------------|--------------------|----------------|------------------------------|-----------|---------| | Peripheral | PPS Input Register | 8-Pin Devices | 14/16-Pin | 20-Pin Devices | 8-Pin | 14/16-Pin | 20-Pin | | | | | | | Devices | Devices | Devices | | External Interrupt | INTPPS | | <b>'</b> b000 010 | | | RA2 | | | Timer0 Clock | T0CKIPPS | | <b>'</b> b000 010 | | | RA2 | | | Timer1 Clock | T1CKIPPS | | 'b000 101 | | | RA5 | | | Timer1 Gate | T1GPPS | | <b>'</b> b000 100 | | | RA4 | | | Timer3 Clock | T3CKIPPS | 'b000 000d | <b>'</b> b010 | | RA0 | RO | | | Timer3 Gate | T3GPPS | 'b000 000d' | <b>'</b> b010 | 100 | RA0 | RO | C4 | | Timer2 Input | T2INPPS | | <b>'</b> b000 101 | | | RA5 | | | Timer4 Input | T4INPPS | 000 000d' | <b>'</b> b010 | 001 | RA0 | RO | 21 | | Timer6 Input | T6INPPS | 'b000 001 | <b>'</b> b010 | 010 | RA1 | RO | 22 | | CCP1 | CCP1PPS | 'b000 101 | <b>'</b> b010 | 101 | RA5 | RO | C5 | | CCP2 | CCP2PPS | <b>'</b> b000 101 | <b>'</b> b010 | 011 | RA5 | RO | 23 | | CWG1 | CWG1PPS | | 'b000 010 | | | RA2 | | | CLCIN0 | CLCIN0PPS | <b>'</b> b000 011 | <b>'</b> b010 011 | 'b000 010 | RA3 | RC3 | RA2 | | CLCIN1 | CLCIN1PPS | <b>'</b> b000 101 | <b>'</b> b010 100 | 'b010 011 | RA5 | RC4 | RC3 | | CLCIN2 | CLCIN2PPS | <b>'</b> b000 001 | <b>'</b> b010 001 | 'b001 100 | RA1 | RC1 | RB4 | | CLCIN3 | CLCIN3PPS | 000 000d' | <b>'</b> b000 101 | 'b001 101 | RA0 | RA5 | RB5 | | SCL1/SCK1 | SSP1CLKPPS(1) | <b>'</b> b000 001 | <b>'</b> b010 000 | 'b001 110 | RA1 | RC0 | RB6 | | SDA1/SDI1 | SSP1DATPPS(1) | <b>'</b> b000 010 | <b>'</b> b010 001 | 'b001 100 | RA2 | RC1 | RB4 | | SS1 | SSP1SSPPS | <b>'</b> b000 011 | <b>'</b> b010 011 | 'b010 110 | RA3 | RC3 | RC6 | | SCL2/SCK2 | SSP2CLKPPS <sup>(1)</sup> | 000 000d' | <b>'</b> b010 100 | 'b001 111 | RA0 | RC4 | RB7 | | SDA2/SDI2 | SSP2DATPPS <sup>(1)</sup> | 000 000d' | <b>'</b> b010 101 | 'b001 101 | RA0 | RC5 | RB5 | | SS2 | SSP2SSPPS | <b>'</b> b00 | 000 000 | 'b000 001 | R | A0 | RA1 | | RX1/DT1 | RX1PPS | 'b000 001 | <b>'</b> b010 101 | 'b001 101 | RA1 | RC5 | RB5 | | CK1 | CK1PPS | 000 000d' | 'b010 100 | 'b001 111 | RA0 | RC4 | RB7 | | RX2/DT2 | RX2PPS | 'b000 001 | <b>'</b> b010 | 001 | RA1 | RO | 21 | | CK2 | CK2PPS | 000 000d' | <b>'</b> b010 | 000 | RA0 | RO | 00 | | ADC Conversion<br>Trigger | ADACTPPS | <b>'</b> b000 101 | <b>'</b> b010 | 010 | RA5 | RO | 22 | #### Note: 1. Bidirectional pin. The corresponding output must select the same pin. ## 18.3 PPS Outputs Each digital peripheral has a dedicated Pin Rxy Output Source Selection (RxyPPS) register with which the pin output source is selected. With few exceptions, the port TRIS control associated with that pin retains control over the pin output driver. Peripherals that control the pin output driver as part of the peripheral operation will override the TRIS control as needed. The I<sup>2</sup>C module is an example of such a peripheral. **Important:** The notation 'Rxy' is a placeholder for the pin identifier. The 'x' holds the place of the PORT letter and the 'y' holds the place of the bit number. For example, Rxy = RA0 for the RA0PPS register. The table below shows the output codes for each peripheral, as well as the available Port selections. Table 18-2. PPS Output Selection Table | 0x1C ADGRDB 0x1B ADGRDA 0x1A NCC1 0x19 TMR0 0x18 SDA2/SDO2(1) 0x17 SCL2/SCK2(1) 0x16 SDA1/SDO1(1) 0x15 SCL1/SCK1(1) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x07 CWG1B 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | RxyPPS | Output Source | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------------| | 0x1B ADGRDA 0x1A NCO1 0x19 TMR0 0x18 SDA2/SDO2(1) 0x17 SCL2/SCK2(1) 0x16 SDA1/SDO1(1) 0x15 SCL1/SCK1(1) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x10 DT1 0x0F Reserved 0x1D PWM5 0x1D PWM5 0x1D PWM4 0x1B PWM3 0x0A CCP2 0x0B CCP1 0x0B CWG1D 0x0B CWG1D 0x0C CWG1B 0x0A CLC4_OUT 0x0A CLC4_OUT 0x0A CLC3_OUT 0x0B CLC3_OUT 0x0C CLC3_OUT 0x0C CLC1_OUT | | | | 0x1A NCO1 0x19 TMR0 0x18 SDA2/SDO2(**) 0x17 SCL2/SCK2(**) 0x16 SDA1/SDO1(**) 0x15 SCL1/SCK1(**) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x07 CWG1A 0x04 CLC4_OUT 0x04 CLC4_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x1B | ADGRDA | | 0x18 SDA2/SDO2(1) 0x17 SCL2/SCK2(1) 0x16 SDA1/SDO1(1) 0x15 SCL1/SCK1(1) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PVM5 0x1C PVM4 0x1B PVM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0×1A | | | 0x17 SCL2/SCK2(f) 0x16 SDA1/SDO1(f) 0x15 SCL1/SCK1(f) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x07 CWG1B 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x19 | TMR0 | | 0x16 SDA1/SDO1(1) 0x15 SCL1/SCK1(1) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM8 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x18 | SDA2/SDO2 <sup>(1)</sup> | | 0x15 SCL1/SCK1(1) 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x17 | SCL2/SCK2 <sup>(1)</sup> | | 0x14 C1_OUT 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x16 | SDA1/SDO1 <sup>(1)</sup> | | 0x13 DT2 0x12 Reserved 0x11 TX2/CK2 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x15 | SCL1/SCK1 <sup>(1)</sup> | | 0x12 Reserved 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x14 | C1_OUT | | 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x13 | DT2 | | 0x10 DT1 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x12 | Reserved | | 0x0F Reserved 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x11 | TX2/CK2 | | 0x1E TX1/CK1 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x10 | DT1 | | 0x1D PWM5 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x0F | Reserved | | 0x1C PWM4 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x1E | TX1/CK1 | | 0x1B PWM3 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x1D | PWM5 | | 0x0A CCP2 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x1C | PWM4 | | 0x09 CCP1 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x1B | PWM3 | | 0x08 CWG1D 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x0A | CCP2 | | 0x07 CWG1C 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x09 | CCP1 | | 0x06 CWG1B 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x08 | CWG1D | | 0x05 CWG1A 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x07 | CWG1C | | 0x04 CLC4_OUT 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x06 | CWG1B | | 0x03 CLC3_OUT 0x02 CLC2_OUT 0x01 CLC1_OUT | 0x05 | CWG1A | | 0x02 | 0x04 | CLC4_OUT | | 0x01 CLC1_OUT | 0x03 | _ | | _ | 0x02 | CLC2_OUT | | 0x00 LATxy | 0x01 | CLC1_OUT | | | 0x00 | LATxy | #### Note: 1. Bidirectional pin. The corresponding input must select the same pin. ## 18.4 Bidirectional Pins PPS selections for peripherals with bidirectional signals on a single pin must be made so that the PPS input and PPS output select the same pin. The I<sup>2</sup>C Serial Clock (SCL) and Serial Data (SDA) are examples of such pins. **Important:** The I<sup>2</sup>C default pins and a limited number of other alternate pins are I<sup>2</sup>C and SMBus compatible. SDA and SCL signals can be routed to any pin; however, pins without I<sup>2</sup>C compatibility will operate at standard TTL/ST logic levels as selected by the port's INLVL register. #### 18.5 PPS Lock The PPS module provides an extra layer of protection to prevent inadvertent changes to the PPS selection registers. The PPSLOCKED bit is used in combination with specific code execution blocks to lock/unlock the PPS selection registers. **Important:** The PPSLOCKED bit is clear by default (PPSLOCKED = 0), which allows the PPS selection registers to be modified without an unlock sequence. PPS selection registers are locked when the PPSLOCKED bit is set (PPSLOCKED = 1). Setting the PPSLOCKED bit requires a specific lock sequence as shown in the examples below in both C and assembly languages. PPS selection registers are unlocked when the PPSLOCKED bit is clear (PPSLOCKED = 0). Clearing the PPSLOCKED bit requires a specific unlock sequence as shown in the examples below in both C and assembly languages. **Important:** All interrupts must be disabled before starting the lock/unlock sequence to ensure proper execution. ## Example 18-1. PPS Lock Sequence (assembly language) ``` ; suspend interrupts BCF INTCONO,GIE BANKSEL PPSLOCK ; required sequence, next 5 instructions MOVLW 0x55 MOVWF PPSLOCK MOVLW 0xAA MOVWF PPSLOCK ; Set PPSLOCKED bit BSF PPSLOCK,PPSLOCKED ; restore interrupts BSF INTCONO,GIE ``` #### Example 18-2. PPS Lock Sequence (C language) ``` INTCONObits.GIE = 0; //Suspend interrupts PPSLOCK = 0x55; //Required sequence PPSLOCK = 0xAA; //Required sequence PPSLOCKbits.PPSLOCKED = 1; //Set PPSLOCKED bit INTCONObits.GIE = 1; //Restore interrupts ``` #### Example 18-3. PPS Unlock Sequence (assembly language) ``` ; suspend interrupts BCF INTCONO,GIE BANKSEL PPSLOCK ; required sequence, next 5 instructions MOVLW 0x55 MOVWF PPSLOCK MOVLW 0xAA MOVWF PPSLOCK ; Clear PPSLOCKED bit BCF PPSLOCK, PPSLOCKED ``` #### 18.5.1 PPS One-Way Lock The PPS1WAY Configuration bit can also be used to prevent inadvertent modification to the PPS selection registers. When the PPS1WAY bit is set (PPS1WAY = 1), the PPSLOCKED bit can only be set one time after a device Reset. Once the PPSLOCKED bit has been set, it cannot be cleared again unless a device Reset is executed. When the PPS1WAY bit is clear (PPS1WAY = 0), the PPSLOCKED bit can be set or cleared as needed; however, the PPS lock/unlock sequences must be executed. ## 18.6 Operation During Sleep PPS input and output selections are unaffected by Sleep. ### 18.7 Effects of a Reset A device Power-on Reset (POR) or Brown-out Reset (BOR) returns all PPS input selection registers to their default values and clears all PPS output selection registers. All other Resets leave the selections unchanged. Default input selections are shown in the PPS input register details table. The PPSLOCKED bit is cleared in all Reset conditions. ## 18.8 Register Definitions: Peripheral Pin Select (PPS) #### 18.8.1 xxxPPS Name: xxxPPS Peripheral Input Selection Register #### Bits 5:3 – PORT[2:0] Peripheral Input PORT Selection<sup>(1)</sup> See the PPS Input Selection Table for the list of available Ports and default pin locations. Reset States: POR = mmm All other Resets = uuu | Value | Description | |-------|-------------| | 010 | PORTC | | 001 | PORTB | | 000 | PORTA | #### Bits 2:0 – PIN[2:0] Peripheral Input PORT Pin Selection<sup>(2)</sup> Reset States: POR = mmm All other Resets = uuu | Value | Description | |-------|--------------------------------------------| | 111 | Peripheral input is from PORTx Pin 7 (Rx7) | | 110 | Peripheral input is from PORTx Pin 6 (Rx6) | | 101 | Peripheral input is from PORTx Pin 5 (Rx5) | | 100 | Peripheral input is from PORTx Pin 4 (Rx4) | | 011 | Peripheral input is from PORTx Pin 3 (Rx3) | | 010 | Peripheral input is from PORTx Pin 2 (Rx2) | | 001 | Peripheral input is from PORTx Pin 1 (Rx1) | | 000 | Peripheral input is from PORTx Pin 0 (Rx0) | #### Notes: - 1. The Reset value 'm' is determined by device default locations for that input. - 2. Refer to the "Pin Allocation Table" for details about available pins per port. ## 18.8.2 RxyPPS Name: RxyPPS Pin Rxy Output Source Selection Register Bits 5:0 - RxyPPS[5:0] Pin Rxy Output Source Selection See the PPS Output Selection Table for the list of RxyPPS Output Source codes Reset States: POR = 000000 All other Resets = uuuuuu # PIC16F18015/25/44/45 # **PPS - Peripheral Pin Select Module** ## 18.8.3 **PPSLOCK** Name: PPSLOCK PPS Lock Register ## Bit 0 - PPSLOCKED PPS Locked Reset States: POR = 0 All other Resets = 0 | | Value | Description | |---|-------|-------------------------------------------------------------------------------------------------| | ſ | 1 | PPS is locked. PPS selections cannot be changed. Writes to any PPS register are ignored. | | | 0 | PPS is not locked. PPS selections can be changed, but may require the PPS lock/unlock sequence. | # 18.9 Register Summary - Peripheral Pin Select Module | December | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------|----------|---|---|---|-----------|-------|---------|----------|------------| | Main | 0x00 | | | | | | | | | | | | Ox108B Ox108C RA0PPS 7-0 RA0PPS[5:0] | | Reserved | | | | | | | | | | | MATPPS 70 RATPPS 70 RAPPS R | | | | | | | | | | | | | DATIBOD DATIPOS 7-0 DATIPOS 0 DA | 0x1D8C | RA0PPS | 7:0 | | | | | RA0PI | PS[5:0] | ! | - | | MATURE MASPES 7-0 7 | | | | | | | | | | | | | DATUBER RESERVED RAMPPS 7-0 | | | | | | | | | | | | | DATIBOD RASPPS 7-0 | | | | | | | | | | | | | DAXIDD2 RASPPS 7-0 | | | 7:0 | | | | | RA4PI | PS[5:0] | | | | DAXIDS2 Reserved DAXIDS5 RB4PPS 7:0 RB4PPS 5:0 RB4PS 5 | | | | | | | | | | | | | Reserved | | 10.0.1.0 | | | | | | | O[0.0] | | | | BATIDR7 | | Reserved | | | | | | | | | | | DATIDB8 RBAPPS 7.0 RCAPPS | | 710001100 | | | | | | | | | | | DAT D99 R85PPS 7:0 P81 | | RB4PPS | 7:0 | | | | | RB4PI | PS[5:0] | | | | DATIDAD R86PPS 7-0 R86PPS 7-0 R87PPS P87PS P8 | | | | | | | | | | | | | DATIDBB RBZPPS 7-0 RCOPPS | | | | | | | | | | | | | Ext DOC RCOPPS 7:0 RCOPPS 5:0 RCIPPS RCIP | | | | | | | | | | | | | Dot.1090 R.C.1PPS 7:0 R.C.1PPS[5:0] Dot.109E R.C.2PPS 7:0 R.C.2PPS[5:0] R.C.2PPS 7:0 R.C.2PPS[5:0] R.C.2PPS 7:0 R.C.2PPS[5:0] R.C.2PPS[5:0] Dot.1040 R.C.2PPS 7:0 R.C.2PPS[5:0] R.C.2P | | | | | | - | | | | | | | DATIDDE RC2PPS 7:0 RC3PPS 7:0 RC3PPS[5:0] | | | | | | - | | | | | | | Oxt D9F RC3PPS 7:0 RC3PPS 0 Oxt DAD RC4PPS 7:0 RC4PPS 0 Oxt DAI RC5PPS 7:0 RC5PPS PORT[2:0] PIN[2:0] Oxt E0D INTPPS 7:0 PORT[2:0] PIN[2:0] Oxt E0D TOCKIPPS 7:0 PORT[2:0] PIN[2:0] Oxt E0T TOCKIPPS 7:0 PORT[2:0] PIN[2:0] Oxt E0T TOCKIPPS 7:0 PORT[2:0] PIN[2:0] Oxt E0T TOCKIPPS 7:0 PORT[2:0] PIN[2:0] Oxt E11 T3CKIPPS 7:0 PORT[2:0] PIN[2:0] Oxt E12 T3C5PPS 7:0 PORT[2:0] PIN[2:0] Oxt E13 T2INPPS 7:0 PORT[2:0] PIN[2:0] Oxt E14 T4INPPS 7:0 PORT[2:0] PIN[2:0] Oxt E15 T5INPPS 7:0 PORT[2:0] PIN[2:0] Oxt E16 Reserved PORT[2:0] PIN[2:0] Oxt E17 Reserved PORT[2:0] PIN[2:0] Oxt E18 CCP1PPS 7:0 PORT[2:0] PIN[2:0] Oxt E19 Reserved PORT[2:0] PIN[2:0] Oxt E19 Reserved PORT[2:0] PIN[2:0] Oxt E19 Reserved PORT[2:0] PIN[2:0] Oxt E19 Reserved PORT[2:0] PIN[2:0] Oxt E18 CUCIN1PPS 7:0 PORT[2:0] PIN[2:0] Oxt E30 E40 CUCIN1PPS 7:0 PORT[2:0] PIN[2:0] Oxt E40 CUCIN1PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | Dot.10A0 RC4PPS 7:0 RC5PPS RC7PPS 7:0 RC7PPS 7:0 RC7PPS 7:0 RC7PPS 7:0 PORT[2:0] PIN[2:0] PIN[2: | | | | | | | | | | | | | DXIDA1 RCSPPS 7:0 RCSPPS[5:0] RCSP | | | | | | - | | | | | | | DATIDA2 RCGPPS 7:0 RCGPPS[5:0] | | | | | | - | | | | | | | OxtDA3 | | | | | | | | | | | | | DX1DA4 | | | - | | | | | | | | | | Reserved DXTEOB PPSLOCK 7:0 PPSLOCKED PPSLOCKED | | RC/PPS | 7:0 | | | | | RC/P | PS[5:0] | | | | 0x1E0B PPSLOCK 7:0 PPSLOCKED 0x1E0D INTPPS 7:0 PORT[2:0] PIN[2:0] 0x1E0E TOCKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E0F T1CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E10 T1GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E11 T3CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E12 T3GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E13 Reserved Reserved PORT[2:0] PIN[2:0] 0x1E18 T3INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1F CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3B CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN1PPS 7:0 PORT[2:0] | | Decembed | | | | | | | | | | | 0x1E0C PPSLOCK 7:0 PPSLOCKED 0x1E0D INTPPS 7:0 PORT[2:0] PIN[2:0] 0x1E0F TOCKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E0F T1CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E10 T1CPPS 7:0 PORT[2:0] PIN[2:0] 0x1E11 T3CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E13 Reserved PORT[2:0] PIN[2:0] 0x1E13 Reserved PORT[2:0] PIN[2:0] 0x1E14 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E15 T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E16 Reserved PORT[2:0] PIN[2:0] 0x1E17 Reserved PORT[2:0] PIN[2:0] 0x1E20 Reserved PORT[2:0] PIN[2:0] 0x1E23 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3F CLCIN1PPS | | Reserved | | | | | | | | | | | Ox1E0D | | DDOLOOK | 7.0 | | | | | | | | DDOL GOVED | | 0x1E0E TOCKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E0F T1CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E10 T1GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E11 T3CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E12 T3GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E13 Reserved PORT[2:0] PIN[2:0] 0x1E18 T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E18 T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1B CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3B CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3B CUCINAPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3B CUCINA | | | | | | | DODT'S SI | | | DIVID 01 | PPSLOCKED | | Ox1E0F | | | | | | | | | | | | | Ox1E10 | | | | | | | | | | | | | 0x1E11 T3CKIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E12 T3GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E13 Reserved PORT[2:0] PIN[2:0] 0x1E19 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1D PORT[2:0] PIN[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3B CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3C CLCINOPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3D CLCINIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCINIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCINIPPS 7:0 PORT[2:0] PIN[2:0] </td <td></td> | | | | | | | | | | | | | 0x1E12 T3GPPS 7:0 PORT[2:0] PIN[2:0] 0x1E13 Reserved PORT[2:0] PIN[2:0] 0x1E19 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1B CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E20 Reserved PORT[2:0] PIN[2:0] 0x1E38 Reserved PORT[2:0] PIN[2:0] 0x1E3C PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3C PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3F CLCINIPPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E40 CLCINIPPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] | | | | | | | | | | | | | 0x1E13 Reserved 0x1E18 7:0 PORT[2:0] PIN[2:0] 0x1E19 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1B CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E2D Reserved PORT[2:0] PIN[2:0] 0x1E2O PORT[2:0] PIN[2:0] 0x1E3A PORT[2:0] PIN[2:0] 0x1E3A PORT[2:0] PIN[2:0] 0x1E3D CLCINOPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3D CLCINIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3D CLCINIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCINIPPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCINIPPS | | | | | | | | | | | | | Reserved PORT[2:0] PIN[2:0] | | T3GPPS | 7:0 | | | | PORT[2:0] | I | | PIN[2:0] | | | 0x1E18 0x1E19 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved Reserved PORT[2:0] PIN[2:0] 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved 0x1E38 PORT[2:0] PIN[2:0] 0x1E3A Reserved 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3C CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | 0x1E13 | | | | | | | | | | | | 0x1E19 T2INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved Reserved PORT[2:0] PIN[2:0] 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3B CWG1PPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3C CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3F CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3F CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] PIN[2:0] | | Reserved | | | | | | | | | | | 0x1E1A T4INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1F CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved PORT[2:0] PIN[2:0] 0x1E38 Reserved PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | Tallippo | | | | | DODT'S AL | | | Divis of | | | 0x1E1B T6INPPS 7:0 PORT[2:0] PIN[2:0] 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved PORT[2:0] PIN[2:0] 0x1E39 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCINOPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | - | | | | | | | 0x1E1C Reserved PORT[2:0] PIN[2:0] 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3A Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCINOPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | Reserved 0x1E1D 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved PORT[2:0] PIN[2:0] 0x1E38 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCINOPPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | T6INPPS | 7:0 | | | | PORT[2:0] | 1 | | PIN[2:0] | | | 0x1E1D 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved PORT[2:0] PIN[2:0] 0x1E38 PORT[2:0] PIN[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | 0x1E1C | | | | | | | | | | | | 0x1E1E CCP1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3A Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | Reserved | | | | | | | | | | | 0x1E1F CCP2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E20 Reserved Reserved Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3A Reserved Reserved Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | 0001000 | | | | | | | | | | | 0x1E20 Reserved PORT[2:0] PIN[2:0] 0x1E39 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | Reserved 0x1E38 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | CCP2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E38 0x1E39 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | 0x1E39 CWG1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3A Reserved | | Reserved | | | | | | | | | | | 0x1E3A Reserved 0x1E3C PORT[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PORT[2:0] PIN[2:0] | | | | | | | | | | | | | Reserved PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | CWG1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E3C PORT[2:0] PIN[2:0] 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | _ | | | | | | | | | | | 0x1E3D CLCIN0PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | Reserved | | | | | | | | | | | 0x1E3E CLCIN1PPS 7:0 PORT[2:0] PIN[2:0] 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | 0x1E3F CLCIN2PPS 7:0 PORT[2:0] PIN[2:0] 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | 0x1E40 CLCIN3PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | | | | | | | | | | | | | | 0x1E41 RX1PPS 7:0 PORT[2:0] PIN[2:0] | | | | | | | | | | | | | | 0x1E41 | RX1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | # PIC16F18015/25/44/45 # **PPS - Peripheral Pin Select Module** | continued | | | | | | | | | | | |------------|------------|----------|---|---|-----------|-----------|---|----------|----------|---| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x1E42 | CK1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E43 | RX2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E44 | CK2PPS | 7:0 | | | PORT[2:0] | | | PIN[2:0] | | | | 0x1E45 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E46 | | | | | | | | | | | | 0x1E47 | SSP1CLKPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E48 | SSP1DATPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E49 | SSP1SSPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4A | SSP2CLKPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4B | SSP2DATPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4C | SSP2SSPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4D | | | | | | | | | | | | <br>0x1E4F | Reserved | | | | | | | | | | | 0x1E50 | ADACTPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | # 19. TMR0 - Timer0 Module The Timer0 module has the following features: - · 8-bit timer with programmable period - 16-bit timer - · Selectable clock sources - Synchronous and asynchronous operation - Programmable prescaler (Independent of Watchdog Timer) - · Programmable postscaler - · Interrupt on match or overflow - · Output on I/O pin (via PPS) or to other peripherals - · Operation during Sleep Figure 19-1. Timer0 Block Diagram ## 19.1 Timer0 Operation Timer0 can operate as either an 8-bit or 16-bit timer. The mode is selected with the MD16 bit. #### 19.1.1 8-Bit Mode In this mode, Timer0 increments on the rising edge of the selected clock source. A prescaler on the clock input gives several prescale options (see the prescaler control bits, CKPS). In this mode, as shown in Figure 19-1, a buffered version of TMR0H is maintained. This is compared with the value of TMR0L on each cycle of the selected clock source. When the two values match, the following events occur: - TMR0L is reset - The contents of TMR0H are copied to the TMR0H buffer for next comparison #### 19.1.2 16-Bit Mode In this mode, Timer0 increments on the rising edge of the selected clock source. A prescaler on the clock input gives several prescale options (see the prescaler control bits, CKPS). In this mode, TMR0H:TMR0L form the 16-bit timer value. As shown in Figure 19-1, reads and writes of the TMR0H register are buffered. The TMR0H register is updated with the contents of the high byte of Timer0 when the TMR0L register is read. Similarly, writing the TMR0L register causes a transfer of the TMR0H register value to the Timer0 high byte. This buffering allows all 16 bits of Timer0 to be read and written at the same time. Timer0 rolls over to $0 \times 0000$ on incrementing past $0 \times FFFF$ . This makes the timer free-running. While actively operating in 16-bit mode, the Timer0 value can be read but not written. #### 19.2 Clock Selection Timer0 has several options for clock source selections, the option to operate synchronously/asynchronously and an available programmable prescaler. The CS bits are used to select the clock source for Timer0. ### 19.2.1 Synchronous Mode When the ASYNC bit is clear, Timer0 clock is synchronized to the system clock ( $F_{OSC}/4$ ). When operating in Synchronous mode, Timer0 clock frequency cannot exceed $F_{OSC}/4$ . During Sleep mode, the system clock is not available and Timer0 cannot operate. #### 19.2.2 Asynchronous Mode When the ASYNC bit is set, Timer0 increments with each rising edge of the input source (or output of the prescaler, if used). Asynchronous mode allows Timer0 to continue operation during Sleep mode provided the selected clock source operates during Sleep. #### 19.2.3 Programmable Prescaler Timer0 has 16 programmable input prescaler options ranging from 1:1 to 1:32768. The prescaler values are selected using the CKPS bits. The prescaler counter is not directly readable or writable. The prescaler counter is cleared on the following events: - · A write to the TMR0L register - A write to either the T0CON0 or T0CON1 registers - Any device Reset #### 19.2.4 Programmable Postscaler Timer0 has 16 programmable output postscaler options ranging from 1:1 to 1:16. The postscaler values are selected using the OUTPS bits. The postscaler divides the output of Timer0 by the selected ratio. The postscaler counter is not directly readable or writable. The postscaler counter is cleared on the following events: - A write to the TMR0L register - · A write to either the T0CON0 or T0CON1 registers - Any device Reset ## 19.3 Timer0 Output and Interrupt ### 19.3.1 Timer0 Output TMR0\_out toggles on every match between TMR0L and TMR0H in 8-bit mode, or when TMR0H:TMR0L rolls over in 16-bit mode. If the output postscaler is used, the output is scaled by the ratio selected. The Timer0 output can be routed to an I/O pin via the RxyPPS output selection register, or internally to a number of Core Independent Peripherals. The Timer0 output can be monitored through software via the OUT output bit. ### 19.3.2 Timer0 Interrupt The Timer0 Interrupt Flag (TMR0IF) bit is set when the TMR0\_out toggles. If the Timer0 interrupt is enabled (TMR0IE), the CPU will be interrupted when the TMR0IF bit is set. When the postscaler bits (T0OUTPS) are set to 1:1 operation (no division), the T0IF flag bit will be set with every TMR0 match or rollover. In general, the TMR0IF flag bit will be set every T0OUTPS +1 matches or rollovers. #### 19.3.3 Timer0 Example Timer0 Configuration: - Timer0 mode = 16-bit - Clock Source = F<sub>OSC</sub>/4 (250 kHz) - · Synchronous operation - Prescaler = 1:1 - Postscaler = 1:2 (T0OUTPS = 1) In this case, the TMR0\_out toggles every two rollovers of TMR0H:TMR0L. i.e., (0xFFFF)\*2\*(1/250 kHz) = 524.28 ms ## 19.4 Operation During Sleep When operating synchronously, Timer0 will halt when the device enters Sleep mode. When operating asynchronously and the selected clock source is active, Timer0 will continue to increment and wake the device from Sleep mode if the Timer0 interrupt is enabled. ## 19.5 Register Definitions: Timer0 Control # 19.5.1 T0CON0 Name: T0CON0 Offset: 0x019E Timer0 Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|-----|------|-----|------|--------|-----| | | EN | | OUT | MD16 | | OUTF | S[3:0] | | | Access | R/W | | R | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - EN TMR0 Enable | Value Description | | | |-------------------|-------------------------------------|--| | 1 | The module is enabled and operating | | | 0 | The module is disabled | | # Bit 5 – OUT TMR0 Output # Bit 4 - MD16 16-Bit Timer Operation Select | Value Description | | Description | |-------------------|---|------------------------| | | 1 | TMR0 is a 16-bit timer | | | 0 | TMR0 is an 8-bit timer | # Bits 3:0 - OUTPS[3:0] TMR0 Output Postscaler (Divider) Select | Value | Description | |-------|-----------------| | 1111 | 1:16 Postscaler | | 1110 | 1:15 Postscaler | | 1101 | 1:14 Postscaler | | 1100 | 1:13 Postscaler | | 1011 | 1:12 Postscaler | | 1010 | 1:11 Postscaler | | 1001 | 1:10 Postscaler | | 1000 | 1:9 Postscaler | | 0111 | 1:8 Postscaler | | 0110 | 1:7 Postscaler | | 0101 | 1:6 Postscaler | | 0100 | 1:5 Postscaler | | 0011 | 1:4 Postscaler | | 0010 | 1:3 Postscaler | | 0001 | 1:2 Postscaler | | 0000 | 1:1 Postscaler | # 19.5.2 T0CON1 Name: T0CON1 Offset: 0x019F Timer0 Control Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|-----|-----|-------|-----------|-----|-----|-----| | | CS[2:0] | | | ASYNC | CKPS[3:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:5 - CS[2:0] Timer0 Clock Source Select | Value | Description | |-------|----------------------------------------| | 111 | CLC1_OUT | | 110 | SOSC | | 101 | MFINTOSC (500 kHz) | | 100 | LFINTOSC | | 011 | HFINTOSC | | 010 | F <sub>OSC</sub> /4 | | 001 | Pin selected by T0CKIPPS (Inverted) | | 000 | Pin selected by T0CKIPPS (Noninverted) | Bit 4 - ASYNC TMR0 Input Asynchronization Enable | Value | Description | | | | |-------|--------------------------------------------------------------------|--|--|--| | 1 | The input to the TMR0 counter is not synchronized to system clocks | | | | | 0 | The input to the TMR0 counter is synchronized to Fosc/4 | | | | # Bits 3:0 - CKPS[3:0] Prescaler Rate Select | Value | Description | |-------|-------------| | 1111 | 1:32768 | | 1110 | 1:16384 | | 1101 | 1:8192 | | 1100 | 1:4096 | | 1011 | 1:2048 | | 1010 | 1:1024 | | 1001 | 1:512 | | 1000 | 1:256 | | 0111 | 1:128 | | 0110 | 1:64 | | 0101 | 1:32 | | 0100 | 1:16 | | 0011 | 1:8 | | 0010 | 1:4 | | 0001 | 1:2 | | 0000 | 1:1 | # PIC16F18015/25/44/45 **TMR0 - Timer0 Module** # 19.5.3 TMR0H Name: TMR0H Offset: 0x019D Timer0 Period/Count High Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | [ | | | | TMR0 | H[7:0] | | | | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Bits 7:0 - TMR0H[7:0] TMR0 Most Significant Counter | - | Value | Condition | Description | |---|----------|-----------|----------------------------------------------------------------------------------------| | | | | 8-bit Timer0 Period Value. TMR0L continues counting from 0 when this value is reached. | | ı | 0 to 255 | MD16 = 1 | 16-bit Timer0 Most Significant Byte | # PIC16F18015/25/44/45 **TMR0 - Timer0 Module** # 19.5.4 TMR0L Name: TMR0L Offset: 0x019C Timer0 Period/Count Low Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|--------|-----|-----|-----| | [ | | | | TMR | L[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - TMR0L[7:0] TMR0 Least Significant Counter | Value | Condition | Description | |----------|-----------|--------------------------------------| | 0 to 255 | MD16 = 0 | 8-bit Timer0 Counter bits | | 0 to 255 | MD16 = 1 | 16-bit Timer0 Least Significant Byte | # 19.6 Register Summary - Timer0 | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|---------|---|-------|-----------|--------|------|---------|---| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x019B | | | | | | | | | | | | 0x019C | TMR0L | 7:0 | | • | • | TMR | L[7:0] | : | • | | | 0x019D | TMR0H | 7:0 | | | | TMR | H[7:0] | | | | | 0x019E | T0CON0 | 7:0 | EN | | OUT | MD16 | | OUTF | PS[3:0] | | | 0x019F | T0CON1 | 7:0 | CS[2:0] | | ASYNC | CKPS[3:0] | | | | | # 20. TMR1 - Timer1 Module with Gate Control The Timer1 module is a 16-bit timer/counter with the following features: - 16-bit timer/counter register pair (TMRxH:TMRxL) - · Programmable internal or external clock source - · 2-bit prescaler - Clock source for optional comparator synchronization - · Multiple Timer1 gate (count enable) sources - · Interrupt-on-overflow - Wake-up on overflow (external clock, Asynchronous mode only) - · 16-bit read/write operation - Time base for the capture/compare function with the CCP modules - Special event trigger (with CCP) - · Selectable gate source polarity - · Gate Toggle mode - · Gate Single Pulse mode - · Gate value status - · Gate event interrupt Important: References to the module Timer1 apply to all the odd numbered timers on this device. Figure 20-1. Timer1 Block Diagram #### Notes: - 1. This signal comes from the pin selected by Timer1 PPS register. - 2. TMRx register increments on rising edge. - 3. Synchronize does not operate while in Sleep. - 4. See TxCLK for clock source selections. - 5. See TxGATE for gate source selections. - 6. Synchronized comparator output must not be used in conjunction with synchronized input clock. # 20.1 Timer1 Operation The Timer1 module is a 16-bit incrementing counter accessed through the TMRx register. Writes to TMRx directly update the counter. When used with an internal clock source, the module is a timer that increments on every instruction cycle. When used with an external clock source, the module can be used as either a timer or counter and increments on every selected edge of the external source. Timer1 is enabled by configuring the ON and GE bits. Table 20-1 shows the possible Timer1 enable selections. Table 20-1, Timer1 Enable Selections | ON | GE | Timer1 Operation | |----|----|------------------| | 1 | 1 | Count enabled | | 1 | 0 | Always on | | 0 | 1 | Off | | 0 | 0 | Off | # 20.2 Clock Source Selection The CS bits select the clock source for Timer1. These bits allow the selection of several possible synchronous and asynchronous clock sources. #### 20.2.1 Internal Clock Source When the internal clock source is selected, the TMRx register will increment on multiples of F<sub>OSC</sub> as determined by the Timer1 prescaler. When the $F_{OSC}$ internal clock source is selected, the TMRx register value will increment by four counts every instruction clock cycle. Due to this condition, a two LSB error in resolution will occur when reading the TMRx value. To utilize the full resolution of Timer1, an asynchronous input signal must be used to gate the Timer1 clock input. **Important:** In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge after any one or more of the following conditions: - · Timer1 enabled after POR - · Write to TMRxH or TMRxL - · Timer1 is disabled - Timer1 is disabled (ON = 0) when TxCKI is high, then Timer1 is enabled (ON = 1) when TxCKI is low. Refer to the figure below. Figure 20-2. Timer1 Incrementing Edge #### Notes: - 1. Arrows indicate counter increments. - 2. In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge of the clock. # 20.2.2 External Clock Source When the external clock source is selected, the TMRx module may work as a timer or a counter. When enabled to count, Timer1 is incremented on the rising edge of the external clock input of the TxCKIPPS pin. This external clock source can be synchronized to the system clock or it can run asynchronously. # 20.3 Timer1 Prescaler Timer1 has four prescaler options allowing 1, 2, 4 or 8 divisions of the clock input. The CKPS bits control the prescale counter. The prescale counter is not directly readable or writable; however, the prescaler counter is cleared upon a write to TMRx. # 20.4 Secondary Oscillator A secondary low-power 32.768 kHz oscillator circuit is built-in between pins SOSCI (input) and SOSCO (amplifier output). This internal circuit is to be used in conjunction with an external 32.768 kHz crystal. The secondary oscillator is not dedicated only to Timer1; it can also be used by other modules. The oscillator circuit is enabled by setting the SOSCEN bit of the OSCEN register. This can be used as one of the Timer1 clock sources selected with the CS bits. The oscillator will continue to run during Sleep. **Important:** The oscillator requires a start-up and stabilization time before use. Thus, the SOSCEN bit of the OSCEN register must be set and a suitable delay observed prior to enabling Timer1. A software check can be performed to confirm if the secondary oscillator is enabled and ready to use. This is done by polling the secondary oscillator ready Status bit. Refer to the "OSC - Oscillator Module (with Fail-Safe Clock Monitor)" chapter for more details. # 20.5 Timer1 Operation in Asynchronous Counter Mode When the SYNC Control bit is set, the external clock input is not synchronized. The timer increments asynchronously to the internal phase clocks. If the external clock source is selected, then the timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake up the processor. However, special precautions in software are needed to read/write the timer. **Important:** When switching from synchronous to asynchronous operation, it is possible to skip an increment. When switching from asynchronous to synchronous operation, it is possible to produce an additional increment. #### 20.5.1 Reading and Writing TMRx in Asynchronous Counter Mode Reading TMRxH or TMRxL while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user must keep in mind that reading the 16-bit timer in two 8-bit values itself poses certain problems, since there may be a carry-out of TMRxL to TMRxH between the reads. For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the TMRxH:TMRxL register pair. #### 20.6 Timer1 16-Bit Read/Write Mode Timer1 can be configured to read and write all 16 bits of data to and from the 8-bit TMRxL and TMRxH registers, simultaneously. The 16-bit read and write operations are enabled by setting the RD16 bit. To accomplish this function, the TMRxH register value is mapped to a buffer register called the TMRxH buffer register. While in 16-bit mode, the TMRxH register is not directly readable or writable and all read and write operations take place through the use of this TMRxH buffer register. When a read from the TMRxL register is requested, the value of the TMRxH register is simultaneously loaded into the TMRxH buffer register. When a read from the TMRxH register is requested, the value is provided from the TMRxH buffer register instead. This provides the user with the ability to accurately read all 16 bits of the Timer1 value from a single instance in time (refer to Figure 20-3 for more details). In contrast, when not in 16-bit mode, the user must read each register separately and determine if the values have become invalid due to a rollover that may have occurred between the read operations. When a write request of the TMRxL register is requested, the TMRxH buffer register is simultaneously updated with the contents of the TMRxH register. The value of TMRxH must be preloaded into the TMRxH buffer register prior to the write request for the TMRxL register. This provides the user with the ability to write all 16 bits to the TMRx register at the same time. Any requests to write to TMRxH directly does not clear the Timer1 prescaler value. The prescaler value is only cleared through write requests to the TMRxL register. Figure 20-3. Timer1 16-Bit Read/Write Mode Block Diagram #### 20.7 Timer1 Gate Timer1 can be configured to count freely or the count can be enabled and disabled using Timer1 gate circuitry. This is also referred to as Timer1 gate enable. Timer1 gate can also be driven by multiple selectable sources. #### 20.7.1 Timer1 Gate Enable The Timer1 Gate Enable mode is enabled by setting the GE bit. The polarity of the Timer1 Gate Enable mode is configured using the GPOL bit. When Timer1 Gate Enable mode is enabled, Timer1 will increment on the rising edge of the Timer1 clock source. When Timer1 Gate signal is inactive, the timer will not increment and hold the current count. Enable mode is disabled, no incrementing will occur and Timer1 will hold the current count. See Figure 20-4 for timing details. Table 20-2. Timer1 Gate Enable Selections | TMRxCLK | GPOL | TxG | Timer1 Operation | |----------|------|-----|------------------| | <b>↑</b> | 1 | 1 | Counts | | <b>↑</b> | 1 | 0 | Holds Count | | <b>↑</b> | 0 | 1 | Holds Count | | <b>↑</b> | 0 | 0 | Counts | #### 20.7.2 Timer1 Gate Source Selection The gate source for Timer1 is selected using the GSS bits. The polarity selection for the gate source is controlled by the GPOL bit. Any of the above mentioned signals can be used to trigger the gate. The output of the CMPx can be synchronized to the Timer1 clock or left asynchronous. For more information refer to the "Comparator Output Synchronization" section. #### 20.7.3 Timer1 Gate Toggle Mode When Timer1 Gate Toggle mode is enabled, it is possible to measure the full-cycle length of a Timer1 Gate signal, as opposed to the duration of a single-level pulse. The Timer1 gate source is routed through a flip-flop that changes state on every incrementing edge of the signal. See the figure below for timing details. Timer1 Gate Toggle mode is enabled by setting the GTM bit. When the GTM bit is cleared, the flip-flop is cleared and held clear. This is necessary to control which edge is measured. **Important:** Enabling Toggle mode at the same time as changing the gate polarity may result in indeterminate operation. # 20.7.4 Timer1 Gate Single Pulse Mode When Timer1 Gate Single Pulse mode is enabled, it is possible to capture a single pulse gate event. Timer1 Gate Single Pulse mode is first enabled by setting the GSPM bit. Next, the GGO/DONE must be set. The Timer1 will be fully enabled on the next incrementing edge. On the next trailing edge of the pulse, the GGO/DONE bit will automatically be cleared. No other gate events will be allowed to increment Timer1 until the GGO/DONE bit is once again set in software. Figure 20-6. Timer1 Gate Single Pulse Mode Clearing the GSPM bit will also clear the GGO/DONE bit. See the figure below for timing details. Enabling the Toggle mode and the Single Pulse mode simultaneously will permit both sections to work together. This allows the cycle times on the Timer1 gate source to be measured. See the figure below for timing details. Figure 20-7. Timer1 Gate Single Pulse and Toggle Combined Mode # 20.7.5 Timer1 Gate Value Status When Timer1 gate value status is utilized, it is possible to read the most current level of the gate control value. The value is stored in the GVAL bit in the TxGCON register. The GVAL bit is valid even when the Timer1 gate is not enabled (GE bit is cleared). #### 20.7.6 Timer1 Gate Event Interrupt When Timer1 gate event interrupt is enabled, it is possible to generate an interrupt upon the completion of a gate event. When the falling edge of GVAL occurs, the TMRxGIF flag bit in one of the PIR registers will be set. If the TMRxGIE bit in the corresponding PIE register is set, then an interrupt will be recognized. The TMRxGIF flag bit operates even when the Timer1 gate is not enabled (the GE bit is cleared). # 20.8 Timer1 Interrupt The TMRx register increments to FFFFh and rolls over to 0000h. When TMRx rolls over, the Timer1 interrupt flag bit of the PIRx register is set. To enable the interrupt-on-rollover, the following bits must be set: - · The ON bit of the TxCON register - The TMRxIE bits of the PIEx register - Global interrupts must be enabled The interrupt is cleared by clearing the TMRxIF bit as a task in the Interrupt Service Routine. Important: The TMRx register and the TMRxIF bit must be cleared before enabling interrupts. # 20.9 Timer1 Operation During Sleep Timer1 can only operate during Sleep when configured as an asynchronous counter. In this mode, many clock sources can be used to increment the counter. To set up the timer to wake the device: - · The ON bit must be set - · The TMRxIE bit of the PIEx register must be set - · Global interrupts must be enabled - · The SYNC bit must be set - Configure the TxCLK register for using any clock source other than F<sub>OSC</sub> and F<sub>OSC</sub>/4 The device will wake up on an overflow and execute the next instruction. If global interrupts are enabled, the device will call the IRS. The secondary oscillator will continue to operate in Sleep regardless of the SYNC bit setting. # 20.10 CCP Capture/Compare Time Base The CCP modules use TMRx as the time base when operating in Capture or Compare mode. In Capture mode, the value in TMRx is copied into the CCPRx register on a capture event. In Compare mode, an event is triggered when the value in the CCPRx register matches the value in TMRx. This event can be a Special Event Trigger. # 20.11 CCP Special Event Trigger When any of the CCPs are configured to trigger a special event, the trigger will clear the TMRx register. This special event does not cause a Timer1 interrupt. The CCP module may still be configured to generate a CCP interrupt. In this mode of operation, the CCPRx register becomes the period register for Timer1. Timer1 must be synchronized and $F_{OSC}/4$ must be selected as the clock source to utilize the Special Event Trigger. Asynchronous operation of Timer1 can cause a Special Event Trigger to be missed. In the event that a write to TMRxH or TMRxL coincides with a Special Event Trigger from the CCP, the write will take precedence. # 20.12 Peripheral Module Disable When a peripheral is not used or inactive, the module can be disabled by setting the Module Disable bit in the PMD registers. This will reduce power consumption to an absolute minimum. Setting the PMD bits holds the module in Reset and disconnects the module's clock source. The Module Disable bits for Timer1 (TMR1MD) are in the PMDx register. See the "PMD - Peripheral Module Disable" chapter for more information. # 20.13 Register Definitions: Timer1 Control Long bit name prefixes for the Timer registers are shown in the table below, where 'x' refers to the Timer instance number. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 20-3. Timer1 Register Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | Timer1 | T1 | | Timer3 | Т3 | # 20,13,1 TxCON Name: TxCON **Offset:** 0x028E,0x0294 **Timer Control Register** # Bits 5:4 - CKPS[1:0] Timer Input Clock Prescaler Select Reset States: POR/BOR = 00 All Other Resets = uu | Value | Description | |-------|---------------------| | 11 | 1:8 Prescaler value | | 10 | 1:4 Prescaler value | | 01 | 1:2 Prescaler value | | 00 | 1:1 Prescaler value | # Bit 2 - SYNC Timer External Clock Input Synchronization Control Reset States: POR/BOR = 0 All Other Resets = u | Value | Condition | Description | |-------|----------------------------------------------|-----------------------------------------------------------| | X | CS = F <sub>OSC</sub> /4 or F <sub>OSC</sub> | This bit is ignored. Timer uses the incoming clock as is. | | 1 | All other clock sources | Do not synchronize external clock input | | 0 | All other clock sources | Synchronize external clock input with system clock | # Bit 1 - RD16 16-Bit Read/Write Mode Enable Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|--------------------------------------------------------------| | 1 | Enables register read/write of Timer in one 16-bit operation | | 0 | Enables register read/write of Timer in two 8-bit operations | #### Bit 0 - ON Timer On Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|----------------| | 1 | Enables Timer | | 0 | Disables Timer | # 20.13.2 TxGCON Name: TxGCON Offset: 0x028F,0x0295 Timer Gate Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|------|-----|------|----------|------|---|---| | | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | | | | Access | R/W | R/W | R/W | R/W | R/W | R | | | | Reset | 0 | 0 | 0 | 0 | 0 | X | | | # **Bit 7 – GE** Timer Gate Enable Reset States: POR/BOR = 0 All Other Resets = u | | | · · · · · · | |-------|-----------|---------------------------------------------------------| | Value | Condition | Description | | 1 | ON = 1 | Timer counting is controlled by the Timer gate function | | 0 | ON = 1 | Timer is always counting | | X | ON = 0 | This bit is ignored | # **Bit 6 – GPOL** Timer Gate Polarity Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|------------------------------------------------------------| | 1 | Timer gate is active-high (Timer counts when gate is high) | | 0 | Timer gate is active-low (Timer counts when gate is low) | #### Bit 5 - GTM Timer Gate Toggle Mode Timer Gate flip-flop toggles on every rising edge when Toggle mode is enabled. Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Timer Gate Toggle mode is enabled | | 0 | Timer Gate Toggle mode is disabled and Toggle flip-flop is cleared | # Bit 4 - GSPM Timer Gate Single Pulse Mode Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|-----------------------------------------------------------------------| | 1 | Timer Gate Single Pulse mode is enabled and is controlling Timer gate | | 0 | Timer Gate Single Pulse mode is disabled | # Bit 3 – GGO/DONE Timer Gate Single Pulse Acquisition Status This bit is automatically cleared when TxGSPM is cleared. Reset States: POR/BOR = 0 All Other Resets = u | Value | Description | |-------|---------------------------------------------------------------------------| | 1 | Timer Gate Single Pulse Acquisition is ready, waiting for an edge | | 0 | Timer Gate Single Pulse Acquisition has completed or has not been started | #### Bit 2 - GVAL Timer Gate Current State Indicates the current state of the timer gate that can be provided to TMRxH:TMRxL Unaffected by the Timer Gate Enable (GE) bit # 20,13,3 TxCLK Name: TxCLK **Offset:** 0x0291,0x0297 Timer Clock Source Selection Register Bits 4:0 - CS[4:0] Timer Clock Source Selection # Table 20-4. Timer Clock Sources | CS | Clock | Source | |-------------|--------------------------|--------------------------| | C3 | Timer1 | Timer3 | | 11111-10001 | Rese | erved | | 10000 | CLC4 | _OUT | | 01111 | CLC3 | _OUT | | 01110 | CLC2 | _OUT | | 01101 | CLC1 | _OUT | | 01100 | TMR3_overflow | Reserved | | 01011 | Reserved | TMR1_overflow | | 01010 | TMR0_c | overflow | | 01001 | EXT | OSC | | 01000 | SO | SC | | 00111 | MFINTOS | C (32 kHz) | | 00110 | MFINTOSO | C (500 kHz) | | 00101 | SFINTOS | C (1 MHz) | | 00100 | LFIN <sup>-</sup> | TOSC | | 00011 | HFIN' | TOSC | | 00010 | F <sub>C</sub> | DSC | | 00001 | Fos | sc/4 | | 00000 | Pin selected by T1CKIPPS | Pin selected by T3CKIPPS | Reset States: POR/BOR = 00000 All Other Resets = uuuuu # 20.13.4 TxGATE Name: TxGATE Offset: 0x0290,0x0296 Timer Gate Source Selection Register Bits 4:0 - GSS[4:0] Timer Gate Source Selection # **Table 20-5. Timer Gate Sources** | GSS | Gate S | Source | |-------------|------------------------|------------------------| | 633 | Timer1 | Timer3 | | 11111-10011 | Rese | erved | | 10010 | CLC4 | _OUT | | 10001 | CLC3 | _OUT | | 10000 | CLC2 | _OUT | | 01111 | CLC1 | _OUT | | 01110 | ZCD_ | OUT | | 01101 | C1_( | OUT | | 01100 | NCO1 | _OUT | | 01011 | PWM5 | S_OUT | | 01010 | PWM4 | I_OUT | | 01001 | PWM3 | 3_OUT | | 01000 | CCP2 | _OUT | | 00111 | CCP1 | _OUT | | 00110 | TMR6_Posts | scaled_OUT | | 00101 | TMR4_Posts | scaled_OUT | | 00100 | TMR3_overflow | Reserved | | 00011 | TMR2_Posts | scaled_OUT | | 00010 | Reserved | TMR1_overflow | | 00001 | TMR0_c | overflow | | 00000 | Pin selected by T1GPPS | Pin selected by T3GPPS | # PIC16F18015/25/44/45 # **TMR1 - Timer1 Module with Gate Control** # 20,13,5 TMRx Name: TMRx **Offset:** 0x028C,0x0292 Timer Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----------|-----|-----|------|--------|-----|-----|-----| | [ | | | | TMRx | [15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | [ | TMRx[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 – TMRx[15:0] Timer Register Value Reset States: POR/BOR = 000000000000000 All Other Resets = uuuuuuuuuuuuuuuuuu **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - TMRxH: Accesses the high byte TMRx[15:8] - TMRxL: Accesses the low byte TMRx[7:0] # 20.14 Register Summary - Timer1 | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|----------|----------|----|-----------|-----|----------|----------|----------|------|----| | 0x00<br><br>0x028B | Reserved | | | | | | | | | | | 0x028C | TMR1 | 7:0 | | | • | TMR | 1[7:0] | | • | | | 000260 | BC TWIRT | 15:8 | | | | TMR | [15:8] | | | | | 0x028E | T1CON | 7:0 | | | CKP | S[1:0] | | SYNC | RD16 | ON | | 0x028F | T1GCON | 7:0 | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | | | | 0x0290 | T1GATE | 7:0 | | | | | | GSS[4:0] | | | | 0x0291 | T1CLK | 7:0 | | | | | | CS[4:0] | | | | 0,,0000 | TMD2 | 7:0 | | TMR3[7:0] | | | | | | | | 0x0292 | TMR3 | 15:8 | | | | TMR | B[15:8] | | | | | 0x0294 | T3CON | 7:0 | | | CKP | S[1:0] | | SYNC | RD16 | ON | | 0x0295 | T3GCON | 7:0 | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | | | | 0x0296 | T3GATE | 7:0 | | | | GSS[4:0] | | | | | | 0x0297 | T3CLK | 7:0 | | | | CS[4:0] | | | | | # 21. TMR2 - Timer2 Module The Timer2 module is an 8-bit timer that incorporates the following features: - 8-bit timer and period registers - · Readable and writable - Software programmable prescaler (1:1 to 1:128) - Software programmable postscaler (1:1 to 1:16) - · Interrupt on T2TMR match with T2PR - · One-shot operation - · Full asynchronous operation - Includes Hardware Limit Timer (HLT) - · Alternate clock sources - · External timer Reset signal sources - · Configurable timer Reset operation See figure below for a block diagram of Timer2. **Important:** References to module Timer2 apply to all the even numbered timers on this device (Timer2, Timer4, etc.). Figure 21-1. Timer2 with Hardware Limit Timer (HLT) Block Diagram #### Notes: - 1. Signal to the CCP peripheral for PWM pulse trigger in PWM mode. - 2. See RSEL for external Reset sources. - 3. See CS for clock source selections. # 21.1 Timer2 Operation Timer2 operates in three major modes: - · Free-Running Period - One Shot - Monostable Within each operating mode, there are several options for starting, stopping and Reset. Table 21-1 lists the options. In all modes, the T2TMR count register increments on the rising edge of the clock signal from the programmable prescaler. When T2TMR equals T2PR, a high level output to the postscaler counter is generated. T2TMR is cleared on the next clock input. An external signal from hardware can also be configured to gate the timer operation or force a T2TMR count Reset. In Gate modes, the counter stops when the gate is disabled and resumes when the gate is enabled. In Reset modes, the T2TMR count is reset on either the level or edge from the external source. The T2TMR and T2PR registers are both directly readable and writable. The T2TMR register is cleared and the T2PR register initializes to 0xFF on any device Reset. Both the prescaler and postscaler counters are cleared on the following events: - · A write to the T2TMR register - · A write to the T2CON register - · Any device Reset - External Reset source event that resets the timer **Important:** T2TMR is not cleared when T2CON is written. # 21.1.1 Free-Running Period Mode The value of T2TMR is compared to that of the period register, T2PR, on each clock cycle. When the two values match, the comparator resets the value of T2TMR to $0 \times 00$ on the next cycle and increments the output postscaler counter. When the postscaler count equals the value in the OUTPS bits of the T2CON register then a one clock period wide pulse occurs on the TMR2 postscaled output, and the postscaler count is cleared. #### 21.1.2 One Shot Mode The One Shot mode is identical to the Free-Running Period mode except that the ON bit is cleared and the timer is stopped when T2TMR matches T2PR and will not restart until the ON bit is cycled off and on. Postscaler (OUTPS) values other than zero are ignored in this mode because the timer is stopped at the first period event and the postscaler is reset when the timer is restarted. #### 21.1.3 Monostable Mode Monostable modes are similar to One Shot modes except that the ON bit is not cleared and the timer can be restarted by an external Reset event. # 21.2 Timer2 Output The Timer2 module's primary output is TMR2\_postscaled, which pulses for a single TMR2\_clk period upon each match of the postscaler counter and the OUTPS bits of the T2CON register. The postscaler is incremented each time the T2TMR value matches the T2PR value. This signal can also be selected as an input to other Core Independent Peripherals. In addition, the Timer2 is also used by the CCP module for pulse generation in PWM mode. See the "PWM Overview" and "PWM Period" sections in the "CCP - Capture/Compare/PWM Module" chapter for more details on setting up Timer2 for use with the CCP and PWM modules. # 21.3 External Reset Sources In addition to the clock source, the Timer2 can also be driven by an external Reset source input. This external Reset input is selected for each timer with the corresponding TxRST register. The external Reset input can control starting and stopping of the timer, as well as resetting the timer, depending on the mode used. # 21.4 Timer2 Interrupt Timer2 can also generate a device interrupt. The interrupt is generated when the postscaler counter matches the selected postscaler value (OUTPS bits of T2CON register). The interrupt is enabled by setting the TMR2IE interrupt enable bit. Interrupt timing is illustrated in the figure below. Figure 21-2. Timer2 Prescaler, Postscaler, and Interrupt Timing Diagram **Notes:** 1. Setting the interrupt flag is synchronized with the instruction clock. Synchronization may take as many as two instruction cycles. 2. Cleared by software. #### 21.5 PSYNC Bit Setting the PSYNC bit synchronizes the prescaler output to $F_{OSC}/4$ . Setting this bit is required for reading the Timer2 counter register while the selected Timer clock is asynchronous to $F_{OSC}/4$ . **Note:** Setting PSYNC requires that the output of the prescaler is slower than $F_{OSC}/4$ . Setting PSYNC when the output of the prescaler is greater than or equal to $F_{OSC}/4$ may cause unexpected results. # 21.6 CSYNC Bit All bits in the Timer2 SFRs are synchronized to $F_{OSC}/4$ , it is possible for the Timer2 input clock to transition at the same time as the ON bit is set in software, which may cause undesirable behavior and glitches in the counter. Setting the CSYNC bit remedies this problem by synchronizing the ON bit to the Timer2 input clock instead of $F_{OSC}/4$ . However, as this synchronization uses an edge of the TMR2 input clock, up to one input clock cycle will be consumed and not counted by the Timer2 when CSYNC is set. Conversely, clearing the CSYNC bit synchronizes the ON bit to $F_{OSC}/4$ , which does not consume any clock edges, but has the previously stated risk of glitches. # 21.7 Operating Modes The mode of the timer is controlled by the MODE bits. Edge Triggered modes require six Timer clock periods between external triggers. Level Triggered modes require the triggering level to be at least three Timer clock periods long. External triggers are ignored while in Debug mode. Table 21-1. Operating Modes Table | Mada | MC | DE | Output | Operation | | Timer Control | | | |---------------------|-------|-------|---------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------|---------------|-------------------------------|--| | Mode | [4:3] | [2:0] | Operation | Operation | Start | Reset | Stop | | | | | 000 | | Software gate (Figure 21-3) | ON = 1 | <del>-</del> | ON = 0 | | | | | 001 | Period Pulse | Hardware gate, active-high<br>(Figure 21-4) | ON = 1 and<br>TMRx_ers = 1 | _ | ON = 0 or<br>TMRx_ers = 0 | | | | | 010 | | Hardware gate, active-low | ON = 1 and<br>TMRx_ers = 0 | _ | ON = 0 or<br>TMRx_ers = 1 | | | Free-Running Period | 00 | 011 | | Rising or falling edge Reset | | TMRx_ers | | | | riee-ranning renou | | 100 | | Rising edge Reset (Figure 21-5) | | TMRx_ers ↑ | ON = 0 | | | | | 101 | Period Pulse | Falling edge Reset | | TMRx_ers ↓ | | | | | | 110 | with Hardware Reset | Low-level Reset | <b>ON =</b> 1 | TMRx_ers = 0 | ON = 0 or<br>TMRx_ers = 0 | | | | | 111 | | High-level Reset (Figure 21-6) | | TMRx_ers = 1 | ON = 0 or<br>TMRx_ers = 1 | | | | | 000 | One-shot | Software start (Figure 21-7) | ON = 1 | _ | | | | | | 001 | Edge-Triggered Start (Note 1) Edge-Triggered Start and Hardware Reset (Note 1) | Rising edge start (Figure 21-8) | ON = 1 and<br>TMRx_ers ↑ | _ | | | | | | 010 | | Falling edge start | ON = 1 and<br>TMRx_ers ↓ | _ | | | | | | 011 | | Any edge start | ON = 1 and<br>TMRx_ers ↓ | _ | ON = 0<br>or | | | One Shot | 01 | 100 | | Rising edge start and<br>Rising edge Reset (Figure 21-9) | ON = 1 and<br>TMRx_ers ↑ | TMRx_ers ↑ | Next clock after TxTMR = TxPR | | | | | 101 | | Falling edge start and<br>Falling edge Reset | ON = 1 and<br>TMRx_ers ↓ | TMRx_ers↓ | (Note 2) | | | | | 110 | | Rising edge start and<br>Low-level Reset (Figure 21-10) | ON = 1 and<br>TMRx_ers ↑ | TMRx_ers = 0 | | | | | | 111 | | Falling edge start and<br>High-level Reset | ON = 1 and<br>TMRx_ers ↓ | TMRx_ers = 1 | | | | continued | | | | | | | | | |------------|-------|-------|-------------------------------|--------------------------------------------------------|----------------------------|--------------|----------------------------|--| | Mode | MC | DDE | Output | Operation | Timer Control | | | | | Wiode | [4:3] | [2:0] | Operation | Operation | Start | Reset | Stop | | | | | 000 | | Reserve | ed . | | | | | | | 001 | | Rising edge start<br>(Figure 21-11) | ON = 1 and<br>TMRx_ers ↑ | _ | ON = 0<br>or | | | Monostable | | 010 | Edge-Triggered Start (Note 1) | Falling edge start | ON = 1 and<br>TMRx_ers↓ | _ | Next clock after | | | | 10 | 011 | | Any edge start | ON = 1 and<br>TMRx_ers ↓ | _ | (Note 3) | | | Reserved | | 100 | | Reserve | ed . | | | | | Reserved | | 101 | | Reserve | ed . | | | | | One Shot | | 110 | Level-Triggered Start | High-level start and<br>Low-level Reset (Figure 21-12) | ON = 1 and<br>TMRx_ers = 1 | TMRx_ers = 0 | ON = 0 or<br>Held in Reset | | | One Shot | | 111 | Hardware Reset | Low-level start and<br>High-level Reset | ON = 1 and<br>TMRx_ers = 0 | TMRx_ers = 1 | (Note 2) | | | Reserved | 11 | XXX | Reserved | | | | | | #### Notes: - 1. If ON = 0, then an edge is required to restart the timer after ON = 1. - 2. When T2TMR = T2PR, the next clock clears ON and stops T2TMR at 00h. - 3. When T2TMR = T2PR, the next clock stops T2TMR at 00h but does not clear ON. # 21.8 Operation Examples Unless otherwise specified, the following notes apply to the following timing diagrams: - Both the prescaler and postscaler are set to 1:1 (both the CKPS and OUTPS bits). - The diagrams illustrate any clock except F<sub>OSC</sub>/4 and show clock-sync delays of at least two full cycles for both ON and TMRx\_ers. When using F<sub>OSC</sub>/4, the clock-sync delay is at least one instruction period for TMRx\_ers; ON applies in the next instruction period. - ON and TMRx\_ers are somewhat generalized, and clock-sync delays may produce results that are slightly different than illustrated. - The PWM Duty Cycle and PWM output are illustrated assuming that the timer is used for the PWM function of the CCP module as described in the "PWM Overview" section. The signals are not a part of the Timer2 module. #### 21.8.1 Software Gate Mode This mode corresponds to legacy Timer2 operation. The timer increments with each clock input when ON = 1, and does not increment when ON = 0. When the TxTMR count equals the TxPR period count, the timer resets on the next clock and continues counting from zero. Operation with the ON bit software controlled is illustrated in Figure 21-3. With TxPR = 5, the counter advances until TxTMR = 5, and goes to zero with the next clock. Figure 21-3. Software Gate Mode Timing Diagram (MODE = 'b00000) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. # 21.8.2 Hardware Gate Mode The Hardware Gate modes operate the same as the Software Gate mode, except the TMRx\_ers external signal can also gate the timer. When used with the CCP, the gating extends the PWM period. If the timer is stopped when the PWM output is high, then the duty cycle is also extended. When MODE = \b000001, then the timer is stopped when the external signal is high. When MODE = \b000010, then the timer is stopped when the external signal is low. Figure 21-4 illustrates the Hardware Gating mode for MODE = \bdots000001 in which a high input level starts the counter. Figure 21-4. Hardware Gate Mode Timing Diagram (MODE = 'b00001) # 21.8.3 Edge Triggered Hardware Limit Mode In Hardware Limit mode, the timer can be reset by the TMRx\_ers external signal before the timer reaches the period count. Three types of Resets are possible: - Reset on rising or falling edge (MODE = 'b00011) - Reset on rising edge (MODE = 'b00100) - Reset on falling edge (MODE = `b00101) When the timer is used in conjunction with the CCP in PWM mode then an early Reset shortens the period and restarts the PWM pulse after a two clock delay. Refer to Figure 21-5. Figure 21-5. Edge Triggered Hardware Limit Mode Timing Diagram (MODE = 'b00100) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. #### 21.8.4 Level Triggered Hardware Limit Mode In the Level Triggered Hardware Limit Timer modes the counter is reset by high or low levels of the external signal TMRx\_ers, as shown in Figure 21-6. Selecting MODE = `b00110 will cause the timer to reset on a low-level external signal. Selecting MODE = `b00111 will cause the timer to reset on a high-level external signal. In the example, the counter is reset while TMRx\_ers = 1. ON is controlled by BSF and BCF instructions. When ON = 0, the external signal is ignored. When the CCP uses the timer as the PWM time base, then the PWM output will be set high when the timer starts counting and then set low only when the timer count matches the CCPRx value. The timer is reset when either the timer count matches the TxPR value or two clock periods after the external Reset signal goes true and stays true. The timer starts counting, and the PWM output is set high, on either the clock following the TxPR match or two clocks after the external Reset signal relinquishes the Reset. The PWM output will remain high until the timer counts up to match the CCPRx pulse-width value. If the external Reset signal goes true while the PWM output is high, then the PWM output will remain high until the Reset signal is released allowing the timer to count up to match the CCPRx value. Figure 21-6. Level Triggered Hardware Limit Mode Timing Diagram (MODE = 'b00111) #### 21.8.5 Software Start One Shot Mode In One Shot mode, the timer resets and the ON bit is cleared when the timer value matches the TxPR period value. The ON bit must be set by software to start another timer cycle. Setting MODE = <code>\b01000</code> selects One Shot mode which is illustrated in Figure 21-7. In the example, ON is controlled by BSF and BCF instructions. In the first case, a BSF instruction sets ON and the counter runs to completion and clears ON. In the second case, a BSF instruction starts the cycle, the BCF/BSF instructions turn the counter off and on during the cycle, and then it runs to completion. When One Shot mode is used in conjunction with the CCP PWM operation, the PWM pulse drive starts concurrent with setting the ON bit. Clearing the ON bit while the PWM drive is active will extend the PWM drive. The PWM drive will terminate when the timer value matches the CCPRx pulse-width value. The PWM drive will remain off until the software sets the ON bit to start another cycle. If the software clears the ON bit after the CCPRx match but before the TxPR match, then the PWM drive will be extended by the length of time the ON bit remains cleared. Another timing cycle can only be initiated by setting the ON bit after it has been cleared by a TxPR period count match. Figure 21-7. Software Start One Shot Mode Timing Diagram (MODE = 'b01000) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. # 21.8.6 Edge Triggered One Shot Mode The Edge Triggered One Shot modes start the timer on an edge from the external signal input, after the ON bit is set, and clear the ON bit when the timer matches the TxPR period value. The following edges will start the timer: - Rising edge (MODE = 'b01001) - Falling edge (MODE = \b01010) - Rising or Falling edge (MODE = `b01011) If the timer is halted by clearing the ON bit, then another TMRx\_ers edge is required after the ON bit is set to resume counting. Figure 21-8 illustrates operation in the rising edge One Shot mode. When Edge Triggered One Shot mode is used in conjunction with the CCP, then the edge-trigger will activate the PWM drive and the PWM drive will deactivate when the timer matches the CCPRx pulse-width value and stay deactivated when the timer halts at the TxPR period count match. Figure 21-8. Edge Triggered One Shot Mode Timing Diagram (MODE = 'b01001) #### 21.8.7 Edge Triggered Hardware Limit One Shot Mode In Edge Triggered Hardware Limit One Shot modes, the timer starts on the first external signal edge after the ON bit is set and resets on all subsequent edges. Only the first edge after the ON bit is set is needed to start the timer. The counter will resume counting automatically two clocks after all subsequent external Reset edges. Edge triggers are as follows: - Rising edge start and Reset (MODE = 'b01100) - Falling edge start and Reset (MODE = 'b01101) The timer resets and clears the ON bit when the timer value matches the TxPR period value. External signal edges will have no effect until after software sets the ON bit. Figure 21-9 illustrates the rising edge hardware limit one-shot operation. When this mode is used in conjunction with the CCP, then the first starting edge trigger, and all subsequent Reset edges, will activate the PWM drive. The PWM drive will deactivate when the timer matches the CCPRx pulse-width value and stay deactivated until the timer halts at the TxPR period match unless an external signal edge resets the timer before the match occurs. Figure 21-9. Edge Triggered Hardware Limit One Shot Mode Timing Diagram (MODE = `b01100) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. #### 21,8,8 Level Reset, Edge Triggered Hardware Limit One Shot Modes In Level Triggered One Shot mode, the timer count is reset on the external signal level and starts counting on the rising/falling edge of the transition from Reset level to the active level while the ON bit is set. Reset levels are selected as follows: - Low Reset level (MODE = 'b01110) - High Reset level (MODE = `b01111) When the timer count matches the TxPR period count, the timer is reset and the ON bit is cleared. When the ON bit is cleared by either a TxPR match or by software control, a new external signal edge is required after the ON bit is set to start the counter. When Level-Triggered Reset One Shot mode is used in conjunction with the CCP PWM operation, the PWM drive goes active with the external signal edge that starts the timer. The PWM drive goes inactive when the timer count equals the CCPRx pulse-width count. The PWM drive does not go active when the timer count clears at the TxPR period count match. Figure 21-10. Low Level Reset, Edge Triggered Hardware Limit One Shot Mode Timing Diagram (MODE = \b01110) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. #### 21.8.9 Edge Triggered Monostable Modes The Edge Triggered Monostable modes start the timer on an edge from the external Reset signal input, after the ON bit is set, and stop incrementing the timer when the timer matches the TxPR period value. The following edges will start the timer: - Rising edge (MODE = 'b10001) - Falling edge (MODE = 'b10010) - Rising or Falling edge (MODE = 'b10011) When an Edge Triggered Monostable mode is used in conjunction with the CCP PWM operation, the PWM drive goes active with the external Reset signal edge that starts the timer, but will not go active when the timer matches the TxPR value. While the timer is incrementing, additional edges on the external Reset signal will not affect the CCP PWM. Figure 21-11. Rising Edge Triggered Monostable Mode Timing Diagram (MODE = \b10001) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. # 21.8.10 Level Triggered Hardware Limit One Shot Modes The Level Triggered Hardware Limit One Shot modes hold the timer in Reset on an external Reset level and start counting when both the ON bit is set and the external signal is not at the Reset level. If one of either the external signal is not in Reset or the ON bit is set, then the other signal being set/made active will start the timer. Reset levels are selected as follows: - Low Reset level (MODE = 'b10110) - High Reset level (MODE = `b10111) When the timer count matches the TxPR period count, the timer is reset and the ON bit is cleared. When the ON bit is cleared by either a TxPR match or by software control, the timer will stay in Reset until both the ON bit is set and the external signal is not at the Reset level. When Level Triggered Hardware Limit One Shot modes are used in conjunction with the CCP PWM operation, the PWM drive goes active with either the external signal edge or the setting of the ON bit, whichever of the two starts the timer. Figure 21-12. Level Triggered Hardware Limit One Shot Mode Timing Diagram (MODE = 'b10110) Note: 1. BSF and BCF represent Bit-Set File and Bit-Clear File instructions executed by the CPU to set or clear the ON bit of TxCON. CPU execution is asynchronous to the timer clock input. # 21.9 Timer2 Operation During Sleep When PSYNC = 1, Timer2 cannot be operated while the processor is in Sleep mode. The contents of the T2TMR and T2PR registers will remain unchanged while the processor is in Sleep mode. When PSYNC = 0, Timer2 will operate in Sleep as long as the clock source selected is also still running. If any internal oscillator is selected as the clock source, it will stay active during Sleep mode. # 21.10 Register Definitions: Timer2 Control Long bit name prefixes for the Timer2 peripherals are shown in the table below. Refer to the "Long Bit Names" section of the "Register and Bit Naming Conventions" chapter for more information. Table 21-2. Timer2 Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | Timer2 | T2 | | Timer4 | T4 | | Timer6 | T6 | **Important:** References to module Timer2 apply to all the even numbered timers on this device (Timer2, Timer4, etc.). # PIC16F18015/25/44/45 **TMR2 - Timer2 Module** # 21.10.1 TxTMR Name: TxTMR **Offset:** 0x030C,0x0312,0x0318 Timer Counter Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|-----|-----|-----|-----|-----|-----|-----| | | TxTMR[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - TxTMR[7:0] Timerx Counter # PIC16F18015/25/44/45 **TMR2 - Timer2 Module** # 21.10.2 TxPR Name: TxPR **Offset:** 0x030D,0x0313,0x0319 Timer Period Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|-----------|-----|-----|-----|-----|-----|-----|-----|--| | | TxPR[7:0] | | | | | | | | | | Access | R/W | | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | Bits 7:0 - TxPR[7:0] Timer Period Register | Value | Description | |----------|-------------------------------------------------------------| | o to 255 | The timer restarts at '0' when TxTMR reaches the TxPR value | ## 21,10,3 TxCON Name: TxCON **Offset:** 0x030E,0x0314,0x031A Timerx Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|--------------|-----|-----|------------|-----|-----|-----|-----|--| | | ON CKPS[2:0] | | | OUTPS[3:0] | | | | | | | Access | R/W/HC | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | # Bit 7 - ON Timer On(1) | Value | Description | |-------|---------------------------------------------------------| | 1 | Timer is on | | 0 | Timer is off: All counters and state machines are reset | ## Bits 6:4 - CKPS[2:0] Timer Clock Prescale Select | Value | Description | |-------|-----------------| | 111 | 1:128 Prescaler | | 110 | 1:64 Prescaler | | 101 | 1:32 Prescaler | | 100 | 1:16 Prescaler | | 011 | 1:8 Prescaler | | 010 | 1:4 Prescaler | | 001 | 1:2 Prescaler | | 000 | 1:1 Prescaler | # Bits 3:0 - OUTPS[3:0] Timer Output Postscaler Select | Value | Description | |-------|-----------------| | 1111 | 1:16 Postscaler | | 1110 | 1:15 Postscaler | | 1101 | 1:14 Postscaler | | 1100 | 1:13 Postscaler | | 1011 | 1:12 Postscaler | | 1010 | 1:11 Postscaler | | 1001 | 1:10 Postscaler | | 1000 | 1:9 Postscaler | | 0111 | 1:8 Postscaler | | 0110 | 1:7 Postscaler | | 0101 | 1:6 Postscaler | | 0100 | 1:5 Postscaler | | 0011 | 1:4 Postscaler | | 0010 | 1:3 Postscaler | | 0001 | 1:2 Postscaler | | 0000 | 1:1 Postscaler | ## Note: 1. In certain modes, the ON bit will be auto-cleared by hardware. See Table 21-1. ## 21.10.4 TxHLT Name: TxHLT **Offset:** 0x030F,0x0315,0x031B Timer Hardware Limit Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|------|-------|-----|-----|-----------|-----|-----| | [ | PSYNC | CPOL | CSYNC | | | MODE[4:0] | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 7 - PSYNC Timer Prescaler Synchronization Enable (1, 2) | Value | Description | |-------|-------------------------------------------------------------------| | 1 | Timer Prescaler Output is synchronized to F <sub>OSC</sub> /4 | | 0 | Timer Prescaler Output is not synchronized to F <sub>OSC</sub> /4 | ### Bit 6 - CPOL Timer Clock Polarity Selection(3) | Value | Description | |-------|----------------------------------------------------| | 1 | Falling edge of input clock clocks timer/prescaler | | 0 | Rising edge of input clock clocks timer/prescaler | # Bit 5 - CSYNC Timer Clock Synchronization Enable (4, 5) | Value | Description | |-------|-------------------------------------------------| | 1 | ON bit is synchronized to timer clock input | | 0 | ON bit is not synchronized to timer clock input | ## Bits 4:0 - MODE[4:0] Timer Control Mode Selection<sup>(6, 7)</sup> | Value | Description | |----------|----------------| | 00000 to | See Table 21-1 | | 11111 | | #### Notes: - 1. Setting this bit ensures that reading TxTMR will return a valid data value. - 2. When this bit is '1', the Timer cannot operate in Sleep mode. - 3. CKPOL must not be changed while ON = 1. - 4. Setting this bit ensures glitch-free operation when the ON is enabled or disabled. - 5. When this bit is set, then the timer operation will be delayed by two input clocks after the ON bit is set. - 6. Unless otherwise indicated, all modes start upon ON = 1 and stop upon ON = 0 (stops occur without affecting the value of TxTMR). - 7. When TxTMR = TxPR, the next clock clears TxTMR, regardless of the operating mode. # 21.10.5 TxCLKCON Name: TxCLKCON **Offset:** 0x0310,0x0316,0x031C Timer Clock Source Selection Register Bits 3:0 - CS[3:0] Timer Clock Source Selection ## Table 21-3. Clock Source Selection | cs | | Clock Source | | |------|-------------------------|-------------------------|-------------------------| | CS | Timer2 | Timer4 | Timer6 | | 1111 | | Reserved | | | 1110 | | CLC4_OUT | | | 1101 | | CLC3_OUT | | | 1100 | | CLC2_OUT | | | 1011 | | CLC1_OUT | | | 1010 | | ZCD_OUT | | | 1001 | | NCO1_OUT | | | 1000 | | EXTOSC | | | 0111 | | SOSC | | | 0110 | | MFINTOSC (32 kHz) | | | 0101 | | MFINTOSC (500 kHz) | | | 0100 | | LFINTOSC | | | 0011 | | HFINTOSC | | | 0010 | | F <sub>osc</sub> | | | 0001 | | F <sub>OSC</sub> /4 | | | 0000 | Pin selected by T2INPPS | Pin selected by T4INPPS | Pin selected by T6INPPS | # 21.10.6 TxRST Name: TxRST **Offset:** 0x0311,0x0317,0x031D Timer External Reset Signal Selection Register Bits 3:0 - RSEL[3:0] External Reset Source Selection ## Table 21-4. External Reset Sources | RSEL | Reset Source | | | | | | | | | |------|-------------------------|-------------------------|-------------------------|--|--|--|--|--|--| | KSEL | TMR2 | TMR4 | TMR6 | | | | | | | | 1111 | | Reserved | | | | | | | | | 1110 | | CLC4_OUT | | | | | | | | | 1101 | | CLC3_OUT | | | | | | | | | 1100 | | CLC2_OUT | | | | | | | | | 1011 | | CLC1_OUT | | | | | | | | | 1010 | | ZCD_OUT | | | | | | | | | 1001 | C1_OUT | | | | | | | | | | 1000 | | PWM5_OUT | | | | | | | | | 0111 | | PWM4_OUT | | | | | | | | | 0110 | | PWM3_OUT | | | | | | | | | 0101 | | CCP2_OUT | | | | | | | | | 0100 | | CCP1_OUT | | | | | | | | | 0011 | TMR6_Post | Reserved | | | | | | | | | 0010 | TMR4_Postscaled_OUT | Reserved | TMR4_Postscaled_OUT | | | | | | | | 0001 | Reserved | TMR2_Post | scaled_OUT | | | | | | | | 0000 | Pin selected by T2INPPS | Pin selected by T4INPPS | Pin selected by T6INPPS | | | | | | | # 21.11 Register Summary - Timer2 | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-------|------|-----------|------|------------|-----------|---------|---| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x030B | | | | | | | | | | | | 0x030C | T2TMR | 7:0 | | : | | T2TM | IR[7:0] | - | - | | | 0x030D | T2PR | 7:0 | | | | T2PI | R[7:0] | | | | | 0x030E | T2CON | 7:0 | ON | | CKPS[2:0] | | | OUTF | PS[3:0] | | | 0x030F | T2HLT | 7:0 | PSYNC | CPOL | CSYNC | | • | MODE[4:0] | | | | 0x0310 | T2CLKCON | 7:0 | | | | | | cs | [3:0] | | | 0x0311 | T2RST | 7:0 | | | | | RSEL[3:0] | | | | | 0x0312 | T4TMR | 7:0 | | : | • | T4TM | IR[7:0] | | | | | 0x0313 | T4PR | 7:0 | | | | T4PI | R[7:0] | | | | | 0x0314 | T4CON | 7:0 | ON | | CKPS[2:0] | | | OUTF | PS[3:0] | | | 0x0315 | T4HLT | 7:0 | PSYNC | CPOL | CSYNC | | MODE[4:0] | | | | | 0x0316 | T4CLKCON | 7:0 | | | | | | cs | [3:0] | | | 0x0317 | T4RST | 7:0 | | | | | | RSE | L[3:0] | | | 0x0318 | T6TMR | 7:0 | | : | • | T6TM | IR[7:0] | | | | | 0x0319 | T6PR | 7:0 | | | | T6PI | R[7:0] | | | | | 0x031A | T6CON | 7:0 | ON | | CKPS[2:0] | | OUTPS[3:0] | | | | | 0x031B | T6HLT | 7:0 | PSYNC | CPOL | CSYNC | | MODE[4:0] | | | | | 0x031C | T6CLKCON | 7:0 | | | | | CS[3:0] | | | | | 0x031D | T6RST | 7:0 | | | | | | RSE | L[3:0] | | # 22. NCO - Numerically Controlled Oscillator Module The Numerically Controlled Oscillator (NCO) module is a timer that uses overflow from the addition of an increment value to divide the input frequency. The advantage of the addition method over a simple counter driven timer is that the output frequency resolution does not vary with the divider value. The NCO is most useful for applications that require frequency accuracy and fine resolution at a fixed duty cycle. Features of the NCO include: - 20-Bit Increment Function - · Fixed Duty Cycle (FDC) mode - · Pulse Frequency (PF) mode - · Output Pulse-Width Control - · Multiple Clock Input Sources - · Output Polarity Control - · Interrupt Capability The following figure is a simplified block diagram of the NCO module. Figure 22-1. Numerically Controlled Oscillator Module Simplified Block Diagram **Note 1:** The increment registers are double-buffered to allow for value changes to be made without first disabling the NCO module. The full increment value is loaded into the buffer registers on the second rising edge of the NCOx\_clk signal that occurs immediately after a write to the NCOxINCL register. The buffers are not user-accessible and are shown here for reference. # 22.1 NCO Operation The NCO operates by repeatedly adding a fixed value to an accumulator. Additions occur at the input clock rate. The accumulator will overflow with a carry periodically, which is the raw NCO output (NCO\_overflow). This effectively reduces the input clock by the ratio of the addition value to the maximum accumulator value. See the following equation. ## **Equation 22-1. NCO Overflow Frequency** $$F_{OVERFLOW} = \frac{NCO\ Clock\ Frequency\ imes\ Increment\ Value}{2^{20}}$$ It is apparent from the equation that there is a linear relationship between the increment value and the overflow frequency. This linear advantage over divide-by-n timers comes at the cost of output jitter. However, the jitter is always plus or minus one NCO clock period that occurs periodically, depending on the division remainder. For example, there is no jitter when there is no division remainder, whereas a division remainder of 0.5 will result in a jitter frequency one half of the overflow frequency. #### 22.1.1 NCO Clock Sources The NCO can be clocked from a variety of sources including the system clock, internal timers, and other peripherals. The NCO clock source is selected by configuring the CKS bits. #### 22.1.2 Accumulator The accumulator is a 20-bit register. Read and write access to the accumulator is available through three registers: - NCOxACCL - NCOxACCH - NCOxACCU #### 22.1.3 Adder The NCO adder is a full adder, which operates synchronously from the source clock. The addition of the previous result and the increment value replaces the accumulator value on the rising edge of each input clock. ## 22.1.4 Increment Registers The increment value is stored in three registers making up a 20-bit word. In order of LSB to MSB, they are: - NCOxINCL - NCOxINCH - NCOxINCU The increment registers are readable and writable and are double-buffered to allow value changes to be made without first disabling the NCO module. When the NCO module is enabled, the NCOxINCU and NCOxINCH registers will be written first, then the NCOxINCL register. Writing to the NCOxINCL register initiates the increment buffer registers to be loaded simultaneously on the second rising edge of the NCO\_clk signal. When the NCO module is disabled, the increment buffers are loaded immediately after a write to the increment registers. Important: The increment buffer registers are not user-accessible. # 22.2 Fixed Duty Cycle Mode In Fixed Duty Cycle (FDC) mode, every time the accumulator overflows, the output is toggled. This provides a 50% duty cycle at half the F<sub>OVERFLOW</sub> frequency, provided that the increment value remains constant. For more information, see the figure below. The FDC mode is selected by clearing the PFM bit. Figure 22-2, FDC Output Mode Timing Diagram # 22.3 Pulse Frequency Mode In Pulse Frequency (PF) mode, the output becomes active on the rising clock edge immediately following the overflow event, and goes inactive 1 to 128 clock periods later, determined by the PWS bits. This provides a pulsed output at the $F_{OVERFLOW}$ frequency. For more information, refer to the figure above. **Important:** When the selected pulse width is greater than the accumulator overflow time frame, then the NCO output does not toggle. The level of the Active and Inactive states is determined by the POL bit. PF mode is selected by setting the PFM bit. # 22.4 Output Polarity Control The last stage in the NCO module is the output polarity. The POL bit selects the output polarity. The active level of the Pulse Frequency mode is high true when the POL bit is cleared. Changing the polarity while the interrupts are enabled will cause an interrupt for the resulting output transition. The NCO output signal (NCOx out) is available by internal routing to several other peripherals. # 22.5 Interrupts When the accumulator overflows, the NCO Interrupt Flag bit, NCOxIF, in the associated PIR register is set. To enable interrupt service on this event, the following bits must be set: - EN bit - · NCOxIE bit in the associated PIE register - · Peripheral and Global Interrupt Enable bits The interrupt must be cleared by software by clearing the NCOxIF bit in the Interrupt Service Routine. #### 22.6 Effects of a Reset All of the NCO registers are cleared to zero as the result of any Reset. # 22.7 Operation in Sleep The NCO module operates independently from the system clock and will continue to run during Sleep, provided that the clock source selected remains active. The HFINTOSC remains active during Sleep when the NCO module is enabled and the HFINTOSC is selected as the clock source, regardless of the system clock source selected. In other words, if the HFINTOSC is simultaneously selected as the system clock and the NCO clock source, when the NCO is enabled, the CPU will go Idle during Sleep, but the NCO will continue to operate and the HFINTOSC will remain active. With a clock running, it will have a direct effect on the Sleep mode current. # 22.8 Register Definitions: NCO Long bit name prefixes for the NCO peripherals are shown in the table below. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 22-1. NCO Long Bit Name Prefixes | Peripheral | Bit Name Prefix | | | |------------|-----------------|--|--| | NCO1 | NCO1 | | | ## 22.8.1 NCOxCON Name: NCOxCON Offset: 0x0492 NCO Control Register # Bit 7 - EN NCO Enable | Value | Description | |-------|------------------------| | 1 | NCO module is enabled | | 0 | NCO module is disabled | #### Bit 5 – OUT NCO Output Displays the current logic level of the NCO module output. ## Bit 4 - POL NCO Polarity | Value | Description | |-------|-----------------------------------| | 1 | NCO output signal is inverted | | 0 | NCO output signal is not inverted | # Bit 0 - PFM NCO Pulse Frequency Mode | Value | Description | |-------|------------------------------------------------------------------------------------------------| | 1 | NCO operates in Pulse Frequency mode. Output frequency is F <sub>OVERFLOW</sub> . | | 0 | NCO operates in Fixed Duty Cycle mode. Output frequency is F <sub>OVERFLOW</sub> divided by 2. | ## 22.8.2 NCOxCLK Name: NCOxCLK Offset: 0x0493 NCO Input Clock Control Register Bits 7:5 - PWS[2:0] NCO Output Pulse-Width Select(1) | Value | Description | |-------|--------------------------------------------------| | 111 | NCO output is active for 128 input clock periods | | 110 | NCO output is active for 64 input clock periods | | 101 | NCO output is active for 32 input clock periods | | 100 | NCO output is active for 16 input clock periods | | 011 | NCO output is active for 8 input clock periods | | 010 | NCO output is active for 4 input clock periods | | 001 | NCO output is active for 2 input clock periods | | 000 | NCO output is active for 1 input clock periods | Bits 3:0 - CKS[3:0] NCO Clock Source Select | CKS | Clock Source | Active in Sleep | | | |-----------|---------------------|-----------------|--|--| | Value | NCO1 | Active in Sleep | | | | 1111-1110 | Reserved | - | | | | 1101 | CLC4_OUT | No | | | | 1100 | CLC3_OUT | No | | | | 1011 | CLC2_OUT | No | | | | 1010 | CLC1_OUT | - | | | | 1001 | TMR6_postscaled_OUT | No | | | | 1000 | TMR4_postscaled_OUT | No | | | | 0111 | TMR2_postscaled_OUT | No | | | | 0110 | EXTOSC | Yes | | | | 0101 | SOSC | Yes | | | | 0100 | MFINTOSC (32 kHz) | Yes | | | | 0011 | MFINTOSC (500 kHz) | Yes | | | | 0010 | LFINTOSC | Yes | | | | 0001 | HFINTOSC | Yes | | | | 0000 | F <sub>osc</sub> | No | | | #### Note: 1. PWS applies only when operating in Pulse Frequency mode. #### 22,8,3 NCOxACC Name: NCOxACC Offset: 0x048C NCO Accumulator Register Bits 19:0 - ACC[19:0] Accumulated sum of NCO additions #### Notes: - 1. The individual bytes in this multibyte register can be accessed with the following register names: - NCOxACCU: Accesses the upper byte ACC[23:16] - NCOxACCH: Accesses the high byte ACC[15:8] - NCOxACCL: Accesses the low byte ACC[7:0]. - 2. The accumulator spans registers NCOxACCU:NCOxACCH:NCOxACCL. The 24 bits are reserved, but not all are used. This register updates in real-time, asynchronously to the CPU; there is no provision to ensure atomic access to this 24-bit space using an 8-bit bus. Writing to this register while the module is operating will produce undefined results. ## **22.8.4 NCOxINC** Name: NCOxINC Offset: 0x048F NCO Increment Register Bits 19:0 - INC[19:0] Value by which the NCOxACC is increased by each NCO clock #### Notes: - 1. The individual bytes in this multibyte register can be accessed with the following register names: - NCOxINCU: Accesses the upper byte INC[19:16] - NCOxINCH: Accesses the high byte INC[15:8] - NCOxINCL: Accesses the low byte INC[7:0]. - 2. The logical increment spans NCOxINCU:NCOxINCH:NCOxINCL. - 3. NCOxINC is double-buffered as INCBUF: - INCBUF is updated on the next falling edge of NCOxCLK after writing to NCOxINCL - NCOxINCU and NCOxINCH will be written prior to writing NCOxINCL. # 22.9 Register Summary - NCO | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-----------|----------|-----|------|-------|-------|--------|-----| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x048B | | | | | | | | | | | | | | 7:0 | | | | ACC | [7:0] | | | | | 0x048C | NCO1ACC | 15:8 | ACC[15:8] | | | | | | | | | | | 23:16 | | | | | | ACC[ | 19:16] | | | | | 7:0 | | INC[7:0] | | | | | | | | 0x048F | NCO1INC | 15:8 | | | | INC[ | 15:8] | | | | | | | 23:16 | | | | | | INC[1 | 19:16] | | | 0x0492 | NCO1CON | 7:0 | EN | | OUT | POL | | | | PFM | | 0x0493 | NCO1CLK | 7:0 | | PWS[2:0] | | | | CKS | [3:0] | | # 23. CWG - Complementary Waveform Generator Module The Complementary Waveform Generator (CWG) produces half-bridge, full-bridge, and steering of PWM waveforms. It is backwards compatible with previous CCP functions. The CWG has the following features: - · Six Operating modes: - Synchronous Steering mode - Asynchronous Steering mode - Full Bridge mode, Forward - Full Bridge mode, Reverse - Half Bridge mode - Push-Pull mode - Output Polarity Control - · Output Steering - Independent 6-bit Rising and Falling Event Dead-Band Timers: - Clocked dead band - Independent rising and falling dead-band enables - Auto-Shutdown Control with: - Selectable shutdown sources - Auto-restart option - Auto-shutdown pin override control # 23.1 Fundamental Operation The CWG generates two output waveforms from the selected input source. The off-to-on transition of each output can be delayed from the on-to-off transition of the other output, thereby creating a time delay immediately where neither output is driven. This is referred to as dead time and is covered in the Dead-Band Control section. It may be necessary to guard against the possibility of circuit faults or a feedback event arriving too late or not at all. In this case, the active drive must be terminated before the Fault condition causes damage. This is referred to as auto-shutdown and is covered in the Auto-Shutdown section. # 23.2 Operating Modes The CWG module can operate in six different modes, as specified by the MODE bits: - · Half Bridge mode - Push-Pull mode - · Asynchronous Steering mode - · Synchronous Steering mode - Full Bridge mode, Forward - Full Bridge mode, Reverse All modes accept a single pulse input, and provide up to four outputs as described in the following sections. All modes include auto-shutdown control as described in the Auto-Shutdown section. Important: Except as noted for Full Bridge mode, mode changes must only be performed while EN = 0. # 23.2.1 Half Bridge Mode In Half Bridge mode, two output signals are generated as true and inverted versions of the input as illustrated in Figure 23-1. A nonoverlap (dead band) time is inserted between the two outputs to prevent shoot-through current in various power supply applications. Dead-band control is described in the Dead-Band Control section. The output steering feature cannot be used in this mode. A basic block diagram of this mode is shown in Figure 23-2. The unused outputs CWGxC and CWGxD drive similar signals as CWGxA and CWGxB, with polarity independently controlled by the POLC and POLD bits, respectively. Figure 23-1. CWG Half Bridge Mode Operation Figure 23-2. Simplified CWG Block Diagram (Half Bridge Mode, MODE = 'b100) ## 23,2,2 Push-Pull Mode In Push-Pull mode, two output signals are generated, alternating copies of the input as illustrated in Figure 23-3. This alternation creates the Push-Pull effect required for driving some transformer-based power supply designs. Steering modes are not used in Push-Pull mode. A basic block diagram for the Push-Pull mode is shown in Figure 23-4. The Push-Pull sequencer is reset whenever EN = 0 or if an auto-shutdown event occurs. The sequencer is clocked by the first input pulse, and the first output appears on CWGxA. The unused outputs CWGxC and CWGxD drive copies of CWGxA and CWGxB, respectively, but with polarity controlled by the POLC and POLD bits, respectively. Figure 23-3. CWG Push-Pull Mode Operation Figure 23-4. Simplified CWG Block Diagram (Push-Pull Mode, MODE = 'b101) # 23.2.3 Full Bridge Mode In Forward and Reverse Full Bridge modes, three outputs drive static values while the fourth is modulated by the input data signal. The mode selection may be toggled between forward and reverse by toggling the MODE[0] bit of the CWGxCON0 register while keeping the MODE[2:1] bits static, without disabling the CWG module. When connected, as shown in Figure 23-5, the outputs are appropriate for a full-bridge motor driver. Each CWG output signal has independent polarity control, so the circuit can be adapted to high-active and low-active drivers. A simplified block diagram for the Full Bridge modes is shown in Figure 23-6. Figure 23-5. Example of Full-Bridge Application Figure 23-6. Simplified CWG Block Diagram (Forward and Reverse Full Bridge Modes) In Forward Full Bridge mode (MODE = \b010), CWGxA is driven to its Active state, CWGxB and CWGxC are driven to their Inactive state, and CWGxD is modulated by the input signal, as shown in Figure 23-7. In Reverse Full Bridge mode (MODE = <code>\b011</code>), CWGxC is driven to its Active state, CWGxA and CWGxD are driven to their Inactive states, and CWGxB is modulated by the input signal, as shown in Figure 23-7. In Full Bridge mode, the dead-band period is used when there is a switch from forward to reverse or vice versa. This dead-band control is described in the Dead-Band Control section, with additional details in the Rising Edge and Reverse Dead Band and Falling Edge and Forward Dead Band sections. Steering modes are not used with either of the Full Bridge modes. Figure 23-7. Example of Full-Bridge Output ## Notes: - 1. A rising CWG data input creates a rising event on the modulated output. - 2. Output signals shown as active-high; all POLy bits are clear. #### 23.2.3.1 Direction Change in Full Bridge Mode In Full Bridge mode, changing the MODE[0] bit controls the forward/reverse direction. Direction changes occur on the next rising edge of the modulated input. The sequence, described as follows, is illustrated in Figure 23-8. - The associated active output CWGxA and the inactive output CWGxC are switched to drive in the opposite direction. - 2. The previously modulated output CWGxD is switched to the Inactive state, and the previously inactive output CWGxB begins to modulate. - 3. CWG modulation resumes after the direction-switch dead band has elapsed. Figure 23-8. Example of PWM Direction Change at Near 100% Duty Cycle #### 23.2.3.2 Dead-Band Delay in Full Bridge Mode Dead-band delay is important when either of the following conditions is true: - The direction of the CWG output changes when the duty cycle of the data input is at or near 100%. - The turn-off time of the power switch, including the power device and driver circuit, is greater than the turn-on time. The dead-band delay is inserted only when changing directions, and only the modulated output is affected. The statically-configured outputs (CWGxA and CWGxC) are not afforded dead band, and switch essentially simultaneously. Figure 23-8 shows an example of the CWG outputs changing directions from forward to reverse, at near 100% duty cycle. In this example, at time t1, the output of CWGxA and CWGxD becomes inactive, while the output of CWGxC becomes active. Since the turn-off time of the power devices is longer than the turn-on time, a shoot-through current will flow through the power devices QC and QD for the duration of 'T'. The same phenomenon will occur to power devices QA and QB for the CWG direction change from reverse to forward. When changing the CWG direction at high duty cycle is required for an application, two possible solutions for eliminating the shoot-through current are: - 1. Reduce the CWG duty cycle for one period before changing directions. - 2. Use switch drivers that can drive the switches off faster than they can drive them on. # 23.2.4 Steering Modes In both Synchronous and Asynchronous Steering modes, the CWG Data can be steered to any combination of four CWG outputs. A fixed value will be presented on all the outputs not used for the PWM output. Each output has independent polarity, steering, and shutdown options. Dead-band control is not used in either Steering mode. For example, when STRA = 0, the corresponding pin is held at the level defined by OVRA. When STRA = 1, the pin is driven by the CWG Data signal. The POLy bits control the signal polarity only when STRy = 1. The CWG auto-shutdown operation also applies in Steering modes as described in the Auto-Shutdown section. An auto-shutdown event will only affect pins that have STRy = 1. Figure 23-9. Simplified CWG Block Diagram (Output Steering Modes) ### 23.2.4.1 Synchronous Steering Mode In Synchronous Steering mode (MODE = <code>\b001</code>), the changes to steering selection registers take effect on the next rising edge of CWG Data (see the figure below). In Synchronous Steering mode, the output will always produce a complete waveform. **Important:** Only the STRx bits are synchronized; the OVRx bits are not synchronized. Figure 23-10. Example of Synchronous Steering (MODE = 'b001) ### 23.2.4.2 Asynchronous Steering Mode In Asynchronous mode (MODE = \b000), steering takes effect at the end of the instruction cycle that writes to STRx. In Asynchronous Steering mode, the output signal may be an incomplete waveform (see the figure below). This operation may be useful when the user firmware needs to immediately remove a signal from the output pin. Figure 23-11. Example of Asynchronous Steering (MODE = 'b000) #### 23.2.4.3 Start-Up Considerations The application hardware must use the proper external pull-up and/or pull-down resistors on the CWG output pins. This is required because all I/O pins are forced to high-impedance at Reset. The Polarity Control (POLy) bits allow the user to choose whether the output signals are active-high or active-low. #### 23.3 Clock Source The clock source is used to drive the dead-band timing circuits. The CWG module allows the following clock sources to be selected: - F<sub>OSC</sub> (system clock) - HFINTOSC When the HFINTOSC is selected, the HFINTOSC will be kept running during Sleep. Therefore, the CWG modes requiring dead band can operate in Sleep, provided that the CWG data input is also active during Sleep. The clock sources are selected using the CS bit. The system clock F<sub>OSC</sub> is disabled in Sleep and thus dead-band control cannot be used. # 23.4 Selectable Input Sources The CWG generates the output waveforms from the input sources which are selected with the ISM bits. Refer to the CWGxISM register for more details. # 23.5 Output Control #### 23.5.1 CWG Output Each CWG output can be routed to a Peripheral Pin Select (PPS) output via the RxyPPS register. Refer to the "PPS - Peripheral Pin Select Module" chapter for more details. # 23.5.2 Polarity Control The polarity of each CWG output can be selected independently. When the output polarity bit is set, the corresponding output is active-high. Clearing the output polarity bit configures the corresponding output as active-low. However, polarity does not affect the override levels. Output polarity is selected with the POLy bits. Auto-shutdown and steering options are unaffected by polarity. #### 23.6 Dead-Band Control The dead-band control provides nonoverlapping complementary outputs to prevent shoot-through current when the outputs switch. Dead-band operation is employed for Half Bridge and Full Bridge modes. The CWG contains two 6-bit dead-band counters. One is used for the rising edge of the input source control in Half Bridge mode or for reverse direction change dead band in Full Bridge mode. The other is used for the falling edge of the input source control in Half Bridge mode or for forward direction change dead band in Full Bridge mode. Dead band is timed by counting CWG clock periods from zero up to the value in the rising or falling dead-band counter registers. #### 23.6.1 Dead-Band Functionality in Half Bridge Mode In Half Bridge mode, the dead-band counters dictate the delay between the falling edge of the normal output and the rising edge of the inverted output. This can be seen in Figure 23-1. #### 23.6.2 Dead-Band Functionality in Full Bridge Mode In Full Bridge mode, the dead-band counters are used when undergoing a direction change. The MODE[0] bit can be set or cleared while the CWG is running, allowing for changes from Forward to Reverse mode. The CWGxA and CWGxC signals will change immediately upon the first rising input edge following a direction change, but the modulated signals (CWGxB or CWGxD, depending on the direction of the change) will experience a delay dictated by the dead-band counters. # 23.7 Rising Edge and Reverse Dead Band In Half Bridge mode, the rising edge dead band delays the turn-on of the CWGxA output after the rising edge of the CWG data input. In Full Bridge mode, the reverse dead-band delay is only inserted when changing directions from Forward mode to Reverse mode, and only the modulated output, CWGxB, is affected. The CWGxDBR register determines the duration of the dead-band interval on the rising edge of the input source signal. This duration is from 0 to 64 periods of the CWG clock. The following figure illustrates different dead-band delays for rising and falling CWG Data events. Figure 23-12. Dead-Band Operation, CWGxDBR = 0x01, CWGxDBF = 0x02 Dead band is always initiated on the edge of the input source signal. A count of zero indicates that no dead band is present. If the input source signal reverses polarity before the dead-band count is completed, then no signal will be seen on the respective output. The CWGxDBR register value is double-buffered. When EN = 0, the buffer is loaded when CWGxDBR is written. When EN = 1, the buffer will be loaded at the rising edge following the first falling edge of the CWG Data, after the LD bit is set. # 23.8 Falling Edge and Forward Dead Band In Half Bridge mode, the falling edge dead band delays the turn-on of the CWGxB output at the falling edge of the CWG data input. In Full Bridge mode, the forward dead-band delay is only inserted when changing directions from Reverse mode to Forward mode, and only the modulated output, CWGxD, is affected. The CWGxDBF register determines the duration of the dead-band interval on the falling edge of the input source signal. This duration is from 0 to 64 periods of the CWG clock. Dead-band delay is always initiated on the edge of the input source signal. A count of zero indicates that no dead band is present. If the input source signal reverses polarity before the dead-band count is completed, then no signal will be seen on the respective output. Figure 23-13. Dead-Band Operation, CWGxDBR = 0x03, CWGxDBF = 0x06, Source Shorter Than Dead Band The CWGxDBF register value is double-buffered. When EN = 0, the buffer is loaded when CWGxDBF is written. When EN = 1, the buffer will be loaded at the rising edge following the first falling edge of the data input after the LD bit is set. #### 23.9 Dead-Band Jitter When the rising and falling edges of the input source are asynchronous to the CWG clock, it creates jitter in the dead-band time delay. The maximum jitter is equal to one CWG clock period. Refer to the equations below for more details. ## Equation 23-1. Dead-Band Delay Time Calculation $$\begin{split} T_{DEAD-BAND\_MIN} &= \frac{1}{F_{CWG\_CLOCK}} \bullet DBx \\ T_{DEAD-BAND\_MAX} &= \frac{1}{F_{CWG\_CLOCK}} \bullet (DBx+1) \\ T_{IITTER} &= T_{DEAD-BAND\_MAX} - T_{DEAD-BAND\_MIN} \end{split}$$ $$T_{JITTER} = \frac{1}{F_{CWG,CLOCK}}$$ $$T_{DEAD-BAND\_MAX} = T_{DEAD-BAND\_MIN} + T_{JITTER}$$ #### **Dead-Band Delay Example Calculation** $$DBx = 0x0A = 10$$ $F_{CWG\_CLOCK} = 8 \, MHz$ $T_{JITTER} = \frac{1}{8 \, MHz} = 125 \, ns$ $T_{DEAD} - B_{AND\_MIN} = 125 \, ns \bullet 10 = 1.25 \, \mu s$ $T_{DEAD} - B_{AND\_MAX} = 1.25 \, \mu s + 0.125 \, \mu s = 1.37 \, \mu s$ ## 23.10 Auto-Shutdown Auto-shutdown is a method to immediately override the CWG output levels with specific overrides that allow for safe shutdown of the circuit. The Shutdown state can be either cleared automatically or held until cleared by software. The auto-shutdown circuit is illustrated in the following figure. #### Figure 23-14. CWG Shutdown Block Diagram #### 23.10.1 Shutdown The Shutdown state can be entered by either of the following two methods: - · Software Generated - · External Input #### 23.10.2 Software Generated Shutdown Setting the SHUTDOWN bit will force the CWG into the Shutdown state. When the auto-restart is disabled, the Shutdown state will persist as long as the SHUTDOWN bit is set. When auto-restart is enabled, the SHUTDOWN bit will clear automatically and resume operation on the next rising edge event. The SHUTDOWN bit indicates when a Shutdown condition exists. The bit may be set or cleared in software or by hardware. # 23.10.3 External Input Source External shutdown inputs provide the fastest way to safely suspend CWG operation in the event of a Fault condition. When any of the selected shutdown inputs goes active, the CWG outputs will immediately go to the selected override levels without software delay. The override levels are selected by the LSBD and LSAC bits. Several input sources can be selected to cause a Shutdown condition. All input sources are active-low. The shutdown input sources are individually enabled by the ASyE bits. **Important:** Shutdown inputs are level sensitive, not edge sensitive. The Shutdown state cannot be cleared, except by disabling auto-shutdown, as long as the shutdown input level persists. #### 23.10.4 Pin Override Levels The levels driven to the CWG outputs during an auto-shutdown event are controlled by the LSBD and LSAC bits. The LSBD bits control CWGxB/D output levels, while the LSAC bits control the CWGxA/C output levels. ## 23.10.5 Auto-Shutdown Interrupts When an auto-shutdown event occurs, either by software or hardware setting SHUTDOWN, the CWGxIF flag bit of the PIRx register is set. ### 23.11 Auto-Shutdown Restart After an auto-shutdown event has occurred, there are two ways to resume operation: - · Software controlled - Auto-restart In either case, the shutdown source must be cleared before the restart can take place. That is, either the Shutdown condition must be removed, or the corresponding ASyE bit must be cleared. #### 23.11.1 Software-Controlled Restart When the REN bit is clear (REN = 0), the CWG module must be restarted after an auto-shutdown event through software. Once all auto-shutdown sources are removed, the software must clear the SHUTDOWN bit. Once SHUTDOWN is cleared, the CWG module will resume operation upon the first rising edge of the CWG data input. **Important**: The SHUTDOWN bit cannot be cleared in software if the Auto-Shutdown condition is still present. Figure 23-15. Shutdown Functionality, Auto-Restart Disabled (REN = 0, LSAC = 'b01, LSBD = 'b01) #### 23.11,2 Auto-Restart When the REN bit is set (REN = 1), the CWG module will restart from the Shutdown state automatically. # **CWG - Complementary Waveform Generator Mod...** Once all Auto-Shutdown conditions are removed, the hardware will automatically clear the SHUTDOWN bit. Once SHUTDOWN is cleared, the CWG module will resume operation upon the first rising edge of the CWG data input. **Important:** The SHUTDOWN bit cannot be cleared in software if the Auto-Shutdown condition is still present. Figure 23-16. Shutdown Functionality, Auto-Restart Enabled (REN = 1, LSAC = 'b01, LSBD = 'b01) # 23.12 Operation During Sleep The CWG module operates independently from the system clock and will continue to run during Sleep, provided that the clock and input sources selected remain active. The HFINTOSC remains active during Sleep when all the following conditions are met: - · CWG module is enabled - · Input source is active - HFINTOSC is selected as the clock source, regardless of the system clock source selected. In other words, if the HFINTOSC is simultaneously selected as the system clock and the CWG clock source, when the CWG is enabled and the input source is active, then the CPU will go Idle during Sleep, but the HFINTOSC will remain active and the CWG will continue to operate. This will have a direct effect on the Sleep mode current. # 23.13 Configuring the CWG - Ensure that the TRIS control bits corresponding to CWG outputs are set so that all are configured as inputs, ensuring that the outputs are inactive during setup. External hardware must ensure that pin levels are held to safe levels. - 2. Clear the EN bit, if not already cleared. - 3. Configure the MODE bits to set the output operating mode. - 4. Configure the POLy bits to set the output polarities. - 5. Configure the ISM bits to select the data input source. - 6. If a Steering mode is selected, configure the STRy bits to select the desired output on the CWG outputs. - 7. Configure the LSBD and LSAC bits to select the Auto-Shutdown Output Override states (this is necessary even if not using auto-shutdown, because start-up will be from a Shutdown state). - 8. If auto-restart is desired, set the REN bit. - 9. If auto-shutdown is desired, configure the ASyE bits to select the shutdown source. - Set the desired rising and falling dead-band times with the CWGxDBR and CWGxDBF registers. - 11. Select the clock source with the CS bit. # **CWG - Complementary Waveform Generator Mod...** - 12. Set the EN bit to enable the module. - 13. Clear the TRIS bits that correspond to the CWG outputs to set them as outputs. If auto-restart is to be used, set the REN bit and the SHUTDOWN bit will be cleared automatically. Otherwise, clear the SHUTDOWN bit in software to start the CWG. # 23.14 Register Definitions: CWG Control Long bit name prefixes for the CWG peripherals are shown in the table below. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 23-1. CWG Long Bit Name Prefixes | Peripheral | Bit Name Prefix | | | |------------|-----------------|--|--| | CWG1 | CWG1 | | | ## 23.14.1 CWGxCON0 Name: CWGxCON0 Offset: 0x0510 CWG Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|--------|---|---|---|-----|-----------|-----| | | EN | LD | | | | | MODE[2:0] | | | Access | R/W | R/W/HC | | | | R/W | R/W | R/W | | Reset | 0 | 0 | | | | 0 | 0 | 0 | ## Bit 7 - EN CWG Enable | Value | Description | |-------|--------------------| | 1 | Module is enabled | | 0 | Module is disabled | ## Bit 6 - LD CWG1 Load Buffers(1) | Value | Description | |-------|-----------------------------------------------------------------------------------------------------------| | 1 | Dead-band count buffers to be loaded on CWG data rising edge, following first falling edge after this bit | | | is set | | 0 | Buffers remain unchanged | # Bits 2:0 - MODE[2:0] CWG Mode | DIG 2.0 - I | Bits 2.0 - MODE[2.0] OVIO Mode | | | | | | |-------------|---------------------------------------------------|--|--|--|--|--| | Value | Description | | | | | | | 111 | Reserved | | | | | | | 110 | Reserved | | | | | | | 101 | CWG outputs operate in Push-Pull mode | | | | | | | 100 | CWG outputs operate in Half Bridge mode | | | | | | | 011 | CWG outputs operate in Reverse Full Bridge mode | | | | | | | 010 | CWG outputs operate in Forward Full Bridge mode | | | | | | | 001 | CWG outputs operate in Synchronous Steering mode | | | | | | | 000 | CWG outputs operate in Asynchronous Steering mode | | | | | | #### Note: 1. This bit can only be set after EN = 1; it cannot be set in the same cycle when EN is set. ## 23.14.2 CWGxCON1 Name: CWGxCON1 Offset: 0x0511 CWG Control Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|----|---|------|------|------|------| | | | | IN | | POLD | POLC | POLB | POLA | | Access | | | R | | R/W | R/W | R/W | R/W | | Reset | | | x | | 0 | 0 | 0 | 0 | # Bit 5 – IN CWG Input Value (read-only) | V | alue | Description | |---|------|-------------------------------| | 1 | | CWG data input is a logic '1' | | 0 | | CWG data input is a logic '0' | # Bits 0, 1, 2, 3 - POLy CWG Output 'y' Polarity | | Value Description | | | |--------|-------------------|------------------------------------|--| | 1 Sign | | Signal output is inverted polarity | | | | 0 | Signal output is normal polarity | | # 23.14.3 CWGxCLK Name: CWGxCLK Offset: 0x050C CWG Clock Input Selection Register Bit 0 - CS CWG Clock Source Selection Select | Value | Description | | | |-------|-------------------------------------------|--|--| | 1 | HFINTOSC (remains operating during Sleep) | | | | 0 | Fosc | | | # 23.14.4 CWGxISM Name: CWGxISM Offset: 0x050D CWGx Input Selection Register Bits 3:0 - ISM[3:0] CWG Data Input Source Select | ISM | Input Selection | | | | |-----------|-------------------------|--|--|--| | ISIVI | CWG1 | | | | | 1111-1100 | Reserved | | | | | 1011 | CLC4_OUT | | | | | 1010 | CLC3_OUT | | | | | 1001 | CLC2_OUT | | | | | 1000 | CLC1_OUT | | | | | 0111 | C1_OUT | | | | | 0110 | NCO1_OUT | | | | | 0101 | PWM5_OUT | | | | | 0100 | PWM4_OUT | | | | | 0011 | PWM3_OUT | | | | | 0010 | CCP2_OUT | | | | | 0001 | CCP1_OUT | | | | | 0000 | Pin selected by CWG1PPS | | | | ## 23.14.5 CWGxSTR Name: CWGxSTR Offset: 0x0514 CWG Steering Control Register<sup>(1)</sup> | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|------|------|------|------|------|------|------| | | OVRD | OVRC | OVRB | OVRA | STRD | STRC | STRB | STRA | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 4. 5. 6. 7 - OVRv Steering Data OVR'v' | Value | Condition | Description | | | |------------|--------------------------------|---------------------------------------------------------------------------|--|--| | x STRy = 1 | | CWGx'y' output has the CWG data input waveform with polarity control from | | | | | | POLy bit | | | | 1 | STRy = $0$ and POLy = $\times$ | CWGx'y' output is high | | | | 0 | STRy = $0$ and POLy = $x$ | CWGx'y' output is low | | | ## Bits 0, 1, 2, 3 – STRy STR'y' Steering Enable<sup>(2)</sup> | Value | Description | า | | | |-------|-------------|-----------|----------------|-----------------------------------------------------------| | 1 | CWGx'y' ou | tput has | the CWG dat | ta input waveform with polarity control from the POLy bit | | 0 | CWGx'y' ou | tput is a | ssigned to val | lue of the OVRy bit | #### Notes: - 1. The bits in this register apply only when MODE = `b00x (CWGxCON0, Steering modes). - 2. This bit is double-buffered when MODE = 'b001. #### 23.14.6 CWGxAS0 Name: CWGxAS0 Offset: 0x0512 CWG Auto-Shutdown Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|-----|-----------|-----|-----------|-----|---|---| | | SHUTDOWN | REN | LSBD[1:0] | | LSAC[1:0] | | | | | Access | R/W/HS/HC | R/W | R/W | R/W | R/W | R/W | | | | Reset | 0 | 0 | 0 | 1 | 0 | 1 | | | ## Bit 7 – SHUTDOWN Auto-Shutdown Event Status<sup>(1,2)</sup> | Va | alue | Description | |----|------|-------------------------------------| | 1 | | An Auto-Shutdown state is in effect | | 0 | | No auto-shutdown event has occurred | #### Bit 6 - REN Auto-Restart Enable | Value | Description | |-------|--------------------------| | 1 | Auto-restart is enabled | | 0 | Auto-restart is disabled | #### Bits 5:4 - LSBD[1:0] CWGxB and CWGxD Auto-Shutdown State Control | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 11 | A logic '1' is placed on CWGxB/D when an auto-shutdown event occurs | | 10 | A logic '0' is placed on CWGxB/D when an auto-shutdown event occurs | | 01 | Pin is tri-stated on CWGxB/D when an auto-shutdown event occurs | | 00 | The Inactive state of the pin, including polarity, is placed on CWGxB/D after the required dead-band | | | interval when an auto-shutdown event occurs | #### Bits 3:2 - LSAC[1:0] CWGxA and CWGxC Auto-Shutdown State Control | Value | Description | |-------|------------------------------------------------------------------------------------------------------| | 11 | A logic '1' is placed on CWGxA/C when an auto-shutdown event occurs | | 10 | A logic '0' is placed on CWGxA/C when an auto-shutdown event occurs | | 01 | Pin is tri-stated on CWGxA/C when an auto-shutdown event occurs | | 00 | The Inactive state of the pin, including polarity, is placed on CWGxA/C after the required dead-band | | | interval when an auto-shutdown event occurs | #### Notes: - 1. This bit may be written while EN = 0, to place the outputs into the shutdown configuration. - The outputs will remain in Auto-Shutdown state until the next rising edge of the CWG data input after this bit is cleared. #### 23.14.7 CWGxAS1 Name: CWGxAS1 Offset: 0x0513 CWG Auto-Shutdown Control Register 1 Bits 0, 1, 2, 3, 4, 5, 6, 7 – ASyE CWG Auto-Shutdown Source Enable<sup>(1,2)</sup> | ASyE | Auto-Shutdown Source | |------|-------------------------| | ASYL | CWG1 | | AS7E | CLC3_OUT | | AS6E | CLC2_OUT | | AS5E | CLC1_OUT | | AS4E | C1_OUT | | AS3E | TMR6_Postscaled_OUT | | AS2E | TMR4_Postscaled_OUT | | AS1E | TMR2_Postscaled_OUT | | AS0E | Pin selected by CWG1PPS | #### Notes: - 1. This bit may be written while EN = 0, to place the outputs into the shutdown configuration. - 2. The outputs will remain in Auto-Shutdown state until the next rising edge of the CWG data input after this bit is cleared. #### 23,14,8 CWGxDBR Name: CWGxDBR Offset: 0x050E CWG Rising Dead-Band Count Register Bits 5:0 - DBR[5:0] CWG Rising Edge-Triggered Dead-Band Count Reset States: POR/BOR = xxxxxx All Other Resets = uuuuuu | Valu | e Description | | |------|---------------|------------------------------------------------------------------------------------| | n | Dead band is | active no less than n and no more than n+1 CWG clock periods after the rising edge | | 0 | 0 CWG clock | periods. Dead-band generation is bypassed. | #### 23.14.9 CWGxDBF Name: CWGxDBF Offset: 0x050F CWG Falling Dead-Band Count Register Bits 5:0 - DBF[5:0] CWG Falling Edge-Triggered Dead-Band Count Reset States: POR/BOR = xxxxxx All Other Resets = uuuuuu | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | n | Dead band is active no less than n and no more than n+1 CWG clock periods after the falling edge | | 0 | 0 CWG clock periods. Dead-band generation is bypassed. | # 23.15 Register Summary - CWG | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|----------|------|---------------------|------|------|--------|-----------|------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x050B | | | | | | | | | | | | 0x050C | CWG1CLK | 7:0 | | | | | | | | CS | | 0x050D | CWG1ISM | 7:0 | | | ISM[3:0] | | | | | | | 0x050E | CWG1DBR | 7:0 | | | | | DBR | R[5:0] | | | | 0x050F | CWG1DBF | 7:0 | | | | | DBF | [5:0] | | | | 0x0510 | CWG1CON0 | 7:0 | EN | LD | | | | | MODE[2:0] | | | 0x0511 | CWG1CON1 | 7:0 | | | IN | | POLD | POLC | POLB | POLA | | 0x0512 | CWG1AS0 | 7:0 | SHUTDOWN | REN | LSBD[1:0] LSAC[1:0] | | | | | | | 0x0513 | CWG1AS1 | 7:0 | AS7E | AS6E | AS5E | AS4E | AS3E | AS2E | AS1E | AS0E | | 0x0514 | CWG1STR | 7:0 | OVRD | OVRC | OVRB | OVRA | STRD | STRC | STRB | STRA | ## 24. CCP - Capture/Compare/PWM Module The Capture/Compare/PWM module is a peripheral that allows the user to time and control different events, and to generate Pulse-Width Modulation (PWM) signals. In Capture mode, the peripheral allows the timing of the duration of an event. The Compare mode allows the user to trigger an external event when a predetermined amount of time has expired. The PWM mode can generate Pulse-Width Modulated signals of varying frequency and duty cycle. Each individual CCP module can select the timer source that controls the module. The default timer selection is Timer1 when using Capture/Compare mode and Timer2 when using PWM mode in the CCPx module. Note that the Capture/Compare mode operation is described with respect to Timer1 and the PWM mode operation is described with respect to Timer2 in the following sections. The Capture and Compare functions are identical for all CCP modules. **Important:** In devices with more than one CCP module, it is very important to pay close attention to the register names used. Throughout this section, the prefix "CCPx" is used as a generic replacement for specific numbering. A number placed where the "x" is in the prefix is used to distinguish between separate modules. For example, CCP1CON and CCP2CON control the same operational aspects of two completely different CCP modules. ## 24.1 CCP Module Configuration Each Capture/Compare/PWM module is associated with a control register (CCPxCON), a capture input selection register (CCPxCAP) and a data register (CCPRx). The data register, in turn, is comprised of two 8-bit registers: CCPRxL (low byte) and CCPRxH (high byte). ### 24.1.1 CCP Modules and Timer Resources The CCP modules utilize Timers 1 through 6 that vary with the selected mode. Various timers are available to the CCP modules in Capture, Compare or PWM modes, as shown in the table below. Table 24-1. CCP Mode - Timer Resources | CCP Mode | Timer Resource | | | | | | |----------|------------------------|--|--|--|--|--| | Capture | Timer1, Timer3 | | | | | | | Compare | Timeri, Timers | | | | | | | PWM | Timer2, Timer4, Timer6 | | | | | | The assignment of a particular timer to a module is selected as shown in the "Capture, Compare, and PWM Timers Selection" chapter. All of the modules may be active at once and may share the same timer resource if they are configured to operate in the same mode (Capture/Compare or PWM) at the same time. #### 24.1.2 Open-Drain Output Option When operating in Output mode (the Compare or PWM modes), the drivers for the CCPx pins can be optionally configured as open-drain outputs. This feature allows the voltage level on the pin to be pulled to a higher level through an external pull-up resistor and allows the output to communicate with external circuits without the need for additional level shifters. ## 24.2 Capture Mode Capture mode makes use of the 16-bit odd numbered timer resources (Timer1, Timer3, etc.). When an event occurs on the capture source, the 16-bit CCPRx register captures and stores the 16-bit value of the TMRx register. An event is defined as one of the following and is configured by the MODE bits: - · Every falling edge of CCPx input - · Every rising edge of CCPx input - Every 4<sup>th</sup> rising edge of CCPx input - Every 16<sup>th</sup> rising edge of CCPx input - Every edge of CCPx input (rising or falling) When a capture is made, the Interrupt Request Flag bit CCPxIF of the PIRx register is set. The interrupt flag must be cleared in software. If another capture occurs before the value in the CCPRx register is read, the old captured value is overwritten by the new captured value. The following figure shows a simplified diagram of the capture operation. **Important:** If an event occurs during a 2-byte read, the high and low-byte data will be from different events. It is recommended while reading the CCPRx register pair to either disable the module or read the register pair twice for data integrity. Figure 24-1. Capture Mode Operation Block Diagram ### 24.2.1 Capture Sources The capture source is selected with the CTS bits. In Capture mode, the CCPx pin must be configured as an input by setting the associated TRIS control bit. **Important:** If the CCPx pin is configured as an output, a write to the port can cause a capture event. #### 24.2.2 Timer1 Mode for Capture Timer1 must be running in Timer mode or Synchronized Counter mode for the CCP module to use the capture feature. In Asynchronous Counter mode, the capture operation may not work. See the "TMR1 - Timer1 Module with Gate Control" chapter for more information on configuring Timer1. #### 24.2.3 Software Interrupt Mode When the Capture mode is changed, a false capture interrupt may be generated. The user will keep the CCPxIE Interrupt Enable bit of the PIEx register clear to avoid false interrupts. Additionally, the user will clear the CCPxIF Interrupt Flag bit of the PIRx register following any change in Operating mode. ## **CCP - Capture/Compare/PWM Module** **Important:** Clocking Timer1 from the system clock ( $F_{OSC}$ ) must not be used in Capture mode. For Capture mode to recognize the trigger event on the CCPx pin, Timer1 must be clocked from the instruction clock ( $F_{OSC}/4$ ) or from an external clock source. #### 24.2.4 CCP Prescaler There are four prescaler settings specified by the MODE bits. Whenever the CCP module is turned off, or the CCP module is not in Capture mode, the prescaler counter is cleared. Any Reset will clear the prescaler counter. Switching from one capture prescaler to another does not clear the prescaler and may generate a false interrupt. To avoid this unexpected operation, turn the module off by clearing the CCPxCON register before changing the prescaler. The example below demonstrates the code to perform this function. # Example 24-1. Changing between Capture Prescalers BANKSEL CCP1CON ; only needed when CCP1CON is not in ACCESS space CLRF CCP1CON ; Turn CCP module off MOVLW NEW\_CAPT\_PS ;CCP ON and Prescaler select → W MOVWF CCP1CON ;Load CCP1CON with this value ## 24.2.5 Capture During Sleep Capture mode depends upon the Timer1 module for proper operation. There are two options for driving the Timer1 module in Capture mode. It can be driven by the instruction clock (F<sub>OSC</sub>/4), or by an external clock source. When Timer1 is clocked by $F_{OSC}/4$ , Timer1 will not increment during Sleep. When the device wakes from Sleep, Timer1 will continue from its previous state. Capture mode will operate during Sleep when Timer1 is clocked by an external clock source. ### 24.3 Compare Mode The Compare mode function described in this section is available and identical for all CCP modules. Compare mode makes use of the 16-bit odd numbered Timer resources (Timer1, Timer3, etc.). The 16-bit value of the CCPRx register is constantly compared against the 16-bit value of the TMRx register. When a match occurs, one of the following events can occur: - · Toggle the CCPx output and clear TMRx - Toggle the CCPx output without clearing TMRx - · Set the CCPx output - Clear the CCPx output - Generate a Pulse output - Generate a Pulse output and clear TMRx The action on the pin is based on the value of the MODE control bits. All Compare modes can generate an interrupt. When MODE = `b0001 or `b1011, the CCP resets the TMRx register. The following figure shows a simplified diagram of the compare operation. Figure 24-2. Compare Mode Operation Block Diagram ## 24.3.1 CCPx Pin Configuration The CCPx pin must be configured as an output in software by clearing the associated TRIS bit and defining the appropriate output pin through the RxyPPS registers. See the "PPS - Peripheral Pin Select Module" section for more details. The CCP output can also be used as an input for other peripherals. **Important:** Clearing the CCPxCON register will force the CCPx compare output latch to the default low level. This is not the PORT I/O data latch. #### 24.3.2 Timer1 Mode for Compare In Compare mode, Timer1 must be running in either Timer mode or Synchronized Counter mode. The compare operation may not work in Asynchronous Counter mode. See the "TMR1 - Timer1 Module with Gate Control" section for more information on configuring Timer1. **Important:** Clocking Timer1 from the system clock ( $F_{OSC}$ ) must not be used in Compare mode. For Compare mode to recognize the trigger event on the CCPx pin, Timer1 must be clocked from the instruction clock ( $F_{OSC}$ /4) or from an external clock source. ### 24.3.3 Compare During Sleep Since $F_{OSC}$ is shut down during Sleep mode, the Compare mode will not function properly during Sleep, unless the timer is running. The device will wake on interrupt (if enabled). ### 24.4 PWM Overview Pulse-Width Modulation (PWM) is a scheme that controls power to a load by switching quickly between fully ON and fully OFF states. The PWM signal resembles a square wave where the high portion of the signal is considered the ON state and the low portion of the signal is considered the OFF state. The high portion, also known as the pulse width, can vary in time and is defined in steps. A larger number of steps applied, which lengthens the pulse width, also supplies more power to the load. Lowering the number of steps applied, which shortens the pulse width, supplies less power. The PWM period is defined as the duration of one complete cycle or the total amount of ON and OFF time combined. PWM resolution defines the maximum number of steps that can be present in a single PWM period. A higher resolution allows for more precise control of the power applied to the load. The term duty cycle describes the proportion of the ON time to the OFF time and is expressed in percentages, where 0% is fully OFF and 100% is fully ON. A lower duty cycle corresponds to less power applied and a higher duty cycle corresponds to more power applied. The figure below shows a typical waveform of the PWM signal. Figure 24-3, CCP PWM Output Signal #### 24.4.1 Standard PWM Operation The standard PWM function described in this section is available and identical for all CCP modules. It generates a Pulse-Width Modulation (PWM) signal on the CCPx pin with up to ten bits of resolution. The period, duty cycle, and resolution are controlled by the following registers: - Even numbered TxPR registers (T2PR, T4PR, etc.) - · Even numbered TxCON registers (T2CON, T4CON, etc.) - · 16-bit CCPRx registers - · CCPxCON registers It is required to have $F_{OSC}/4$ as the clock input to TxTMR for correct PWM operation. The following figure shows a simplified block diagram of the PWM operation. Figure 24-4. Simplified PWM Block Diagram Notes - An 8-bit timer is concatenated with two bits generated by Fosc or two bits of the internal prescaler to create 10-bit time base. - 2. The alignment of the 10 bits from the CCPR register is determined by the CCPxFMT bit. Important: The corresponding TRIS bit must be cleared to enable the PWM output on the CCPx pin. #### 24.4.2 Setup for PWM Operation The following steps illustrate how to configure the CCP module for standard PWM operation: - 1. Select the desired output pin with the RxyPPS control to select CCPx as the source. Disable the selected pin output driver by setting the associated TRIS bit. The output will be enabled later at the end of the PWM setup. - 2. Load the selected timer TxPR period register with the PWM period value. - 3. Configure the CCP module for the PWM mode by loading the CCPxCON register with the appropriate values. - 4. Load the CCPRx register with the PWM duty cycle value and configure the FMT bit to set the proper register alignment. - 5. Configure and start the selected timer: - Clear the TMRxIF Interrupt Flag bit of the PIRx register. See the Note below. - Select the timer clock source to be as F<sub>OSC</sub>/4. This is required for correct operation of the PWM module. - Configure the TxCKPS bits of the TxCON register with the desired timer prescale value. - Enable the timer by setting the TxON bit. - 6. Enable the PWM output: - Wait until the timer overflows and the TMRxIF bit of the PIRx register is set. See the Note below. - Enable the CCPx pin output driver by clearing the associated TRIS bit. **Important:** To send a complete duty cycle and period on the first PWM output, the above steps must be included in the setup sequence. If it is not critical to start with a complete PWM signal on the first output, then step 6 may be ignored. #### 24.4.3 Timer2 Timer Resource The PWM Standard mode makes use of the 8-bit Timer2 timer resources to specify the PWM period. #### 24.4.4 PWM Period The PWM period is specified by the T2PR register of Timer2. The PWM period can be calculated using the formula in the equation below. #### Equation 24-1. PWM Period $PWM\ Period = [(T2PR + 1)] \cdot 4 \cdot T_{OSC} \cdot (TMR2\ Prescale\ Value)$ where $T_{OSC} = 1/F_{OSC}$ When T2TMR is equal to T2PR, the following three events occur on the next increment event: - · T2TMR is cleared - The CCPx pin is set (Exception: If the PWM duty cycle = 0%, the pin will not be set) - The PWM duty cycle is transferred from the CCPRx register into a 10-bit buffer **Important:** The Timer postscaler (see the "Timer2 Interrupt" section) is not used in the determination of the PWM frequency. #### 24.4.5 PWM Duty Cycle The PWM duty cycle is specified by writing a 10-bit value to the CCPRx register. The alignment of the 10-bit value is determined by the FMT bit (see Figure 24-5). The CCPRx register can be written to at any time. However, the duty cycle value is not latched onto the 10-bit buffer until after a match between T2PR and T2TMR. The equations below are used to calculate the PWM pulse width and the PWM duty cycle ratio. #### Figure 24-5. PWM 10-Bit Alignment #### Equation 24-2. Pulse Width $Pulse\ Width = (CCPRxH: CCPRxL\ register\ value) \bullet T_{OSC} \bullet (TMR2\ Prescale\ Value)$ #### Equation 24-3. Duty Cycle $$DutyCycleRatio = \frac{(CCPRxH:CCPRxL register value)}{4(T2PR + 1)}$$ The CCPRx register is used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation. The 8-bit timer T2TMR register is concatenated with either the 2-bit internal system clock (F<sub>OSC</sub>), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1. When the 10-bit time base matches the CCPRx register, then the CCPx pin is cleared (see Figure 24-4). #### 24.4.6 PWM Resolution The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles. The maximum PWM resolution is 10 bits when T2PR is <code>0xff</code>. The resolution is a function of the T2PR register value, as shown below. #### Equation 24-4. PWM Resolution $$Resolution = \frac{\log[4(T2PR + 1)]}{\log(2)}bits$$ **Important:** If the pulse-width value is greater than the period, the assigned PWM pin(s) will remain unchanged. Table 24-2. Example PWM Frequencies and Resolutions ( $F_{OSC} = 20 \text{ MHz}$ ) | PWM Frequency | 1.22 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz | |---------------------------|----------|----------|-----------|-----------|-----------|-----------| | Timer Prescale | 16 | 4 | 1 | 1 | 1 | 1 | | T2PR Value | 0xFF | 0xFF | 0xFF | 0x3F | 0x1F | 0x17 | | Maximum Resolution (bits) | 10 | 10 | 10 | 8 | 7 | 6.6 | Table 24-3. Example PWM Frequencies and Resolutions ( $F_{OSC} = 8 \text{ MHz}$ ) | PWM Frequency | 1.22 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz | |---------------------------|----------|----------|-----------|-----------|------------|-----------| | Timer Prescale | 16 | 4 | 1 | 1 | 1 | 1 | | T2PR Value | 0x65 | 0x65 | 0x65 | 0x19 | 0x0C | 0x09 | | Maximum Resolution (bits) | 8 | 8 | 8 | 6 | 5 | 5 | #### 24.4.7 Operation in Sleep Mode In Sleep mode, the T2TMR register will not increment and the state of the module will not change. If the CCPx pin is driving a value, it will continue to drive that value. When the device wakes up, T2TMR will continue from the previous state. #### 24.4.8 Changes in System Clock Frequency The PWM frequency is derived from the system clock frequency. Any changes in the system clock frequency will result in changes to the PWM frequency. See the "OSC - Oscillator Module (with Fail-Safe Clock Monitor)" chapter for additional details. #### 24.4.9 Effects of Reset Any Reset will force all ports to Input mode and the CCP registers to their Reset states. #### 24.5 Register Definitions: CCP Control Long bit name prefixes for the CCP peripherals are shown in the following table. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. # PIC16F18015/25/44/45 # **CCP - Capture/Compare/PWM Module** ## Table 24-4. CCP Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | CCP1 | CCP1 | | CCP2 | CCP2 | #### 24.5.1 CCPxCON Name: CCPxCON Offset: 0x038E,0x0392 **CCP Control Register** | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------|-----|---|-----|-----|-----------|-----|-----|-----|--| | | EN | | OUT | FMT | MODE[3:0] | | | | | | Access | R/W | | R | R/W | R/W | R/W | R/W | R/W | | | Reset | 0 | | X | 0 | 0 | 0 | 0 | 0 | | #### Bit 7 - EN CCP Module Enable | 1 | /alue | Description | |---|-------|-----------------| | | - | CCP is enabled | | ( | ) | CCP is disabled | ## Bit 5 – OUT CCP Output Data (read-only) #### Bit 4 – FMT CCPxRH:L Value Alignment (PWM mode) | Value | Condition | Description | |-------|--------------|----------------------| | Х | Capture mode | Not used | | Х | Compare mode | Not used | | 1 | PWM mode | Left aligned format | | 0 | PWM mode | Right aligned format | #### Bits 3:0 - MODE[3:0] CCP Mode Select #### Table 24-5, CCPx Mode Select | MODE Value | Operating Mode | Operation | Set CCPxIF | |------------|----------------|-------------------------------------------------|------------| | 11xx | PWM | PWM operation | Yes | | 1011 | | Pulse output; clear TMR1 <sup>(2)</sup> | Yes | | 1010 | Compare | Pulse output | Yes | | 1001 | Compare | Clear output <sup>(1)</sup> | Yes | | 1000 | _ | Set output <sup>(1)</sup> | Yes | | 0111 | | Every 16th rising edge of CCPx input | Yes | | 0110 | | Every 4 <sup>th</sup> rising edge of CCPx input | Yes | | 0101 | Capture | Every rising edge of CCPx input | Yes | | 0100 | | Every falling edge of CCPx input | Yes | | 0011 | | Every edge of CCPx input | Yes | | 0010 | Compare | Toggle output | Yes | | 0001 | Compare | Toggle output; clear TMR1 <sup>(2)</sup> | Yes | | 0000 | Disabled | | _ | #### Notes: - 1. The set and clear operations of the Compare mode are reset by setting MODE = \b00000 or EN = 0. - 2. When MODE = \b00001 or \b1011, then the timer associated with the CCP module is cleared. TMR1 is the default selection for the CCP module, so it is used for indication purposes only. ## 24.5.2 CCPxCAP Name: CCPxCAP Offset: 0x038F,0x0393 Capture Trigger Input Selection Register Bits 3:0 - CTS[3:0] Capture Trigger Input Selection ## **Table 24-6. Capture Trigger Sources** | CTS Value | Source | |-----------|-------------------------| | 1111-0111 | Reserved | | 0110 | CLC4_OUT | | 0101 | CLC3_OUT | | 0100 | CLC2_OUT | | 0011 | CLC1_OUT | | 0010 | IOC Interrupt | | 0001 | C1_OUT | | 0000 | Pin selected by CCPxPPS | #### 24,5,3 CCPRx Name: CCPRx **Offset:** 0x038C,0x0390 Capture/Compare/Pulse-Width Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | |--------|------------|-----|-----|------|--------|-----|-----|-----|--|--|--|--|--| | | CCPR[15:8] | | | | | | | | | | | | | | Access | R/W | | | | | | Reset | x | X | x | x | x | x | x | X | | | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | | CCPI | ₹[7:0] | | | | | | | | | | Access | R/W | | | | | | Reset | X | x | x | x | X | x | x | X | | | | | | Bits 15:0 - CCPR[15:0] Capture/Compare/Pulse-Width All other Resets = uuuuuuuuuuuuuuu Notes: The individual bytes in this multibyte register can be accessed with the following register names: - When MODE = Capture or Compare - CCPRxH: Accesses the high byte CCPR[15:8] - CCPRxL: Accesses the low byte CCPR[7:0] - When MODE = PWM and FMT = 0 - CCPRx[15:10]: Not used - CCPRxH[1:0]: Accesses the two Most Significant bits CCPR[9:8] - CCPRxL: Accesses the eight Least Significant bits CCPR[7:0] - When MODE = PWM and FMT = 1 - CCPRxH: Accesses the eight Most Significant bits CCPR[9:2] - CCPRxL[7:6]: Accesses the two Least Significant bits CCPR[1:0] - CCPRx[5:0]: Not used # 24.6 Register Summary - CCP Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|----------|----------|----|------------|-----|---------------|--------|-----|--------|---|--|--| | 0x00 | | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | | 0x038B | | | | | | | | | | | | | | 0x038C | CCPR1 | 7:0 | | | | CCP | R[7:0] | | | | | | | UXUSOC | CCPRI | 15:8 | | CCPR[15:8] | | | | | | | | | | 0x038E | CCP1CON | 7:0 | EN | | OUT | FMT | | MOD | E[3:0] | | | | | 0x038F | CCP1CAP | 7:0 | | | | | | CTS | [3:0] | | | | | 0x0390 | CCPR2 | 7:0 | | • | | CCP | R[7:0] | | | | | | | 0x0390 | COPRZ | 15:8 | | | | CCPR[15:8] | | | | | | | | 0x0392 | CCP2CON | 7:0 | EN | | OUT | FMT MODE[3:0] | | | | | | | | 0x0393 | CCP2CAP | 7:0 | | CTS[3:0] | | | | | | | | | ## 25. Capture, Compare, and PWM Timers Selection Each of these modules has an independent timer selection which can be accessed using the timer selection register. The default timer selection is Timer1 for capture or compare functions and Timer2 for PWM functions. 25.1 Register Definitions: Capture, Compare, and PWM Timers Selection ## 25.1.1 CCPTMRS0 Name: CCPTMRS0 Offset: 0x039F **CCP Timers Selection Register** Bits 0:1, 2:3 - CnTSEL CCPn Timer Selection | CnTSEL Value | Capture/Compare | PWM | |--------------|-----------------|--------| | 11 | Reserved | Timer6 | | 10 | Timer3 | Timer4 | | 01 | Timer1 | Timer2 | | 00 | Reserved | | # 25.2 Register Summary - Capture, Compare, and PWM Timers Selection | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|---|---|---|---|------|---------|-------|---------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x039E | | | | | | | | | | | | 0x039F | CCPTMRS0 | 7:0 | | | | | C2TS | EL[1:0] | C1TSI | EL[1:0] | ## 26. PWM - Pulse-Width Modulation The PWM module generates a Pulse-Width Modulated signal determined by the duty cycle, period, and resolution that are configured by the following registers: - TxPR - TxCON - PWMxDC - PWMxCON Important: The corresponding TRIS bit must be cleared to enable the PWM output on the PWMx pin. Each PWM module uses the same timer source, Timer2, to control each module. Figure 26-1 shows a simplified block diagram of PWM operation. Figure 26-2 shows a typical waveform of the PWM signal. Figure 26-1. Simplified PWM Block Diagram #### Note: 8-bit timer is concatenated with two bits generated by F<sub>OSC</sub> or two bits of the internal prescaler to create 10-bit time base. Figure 26-2. PWM Output For a step-by-step procedure on how to set up this module for PWM operation, refer to 26.9. Setup for PWM Operation Using PWMx Output Pins. ## 26.1 Fundamental Operation The PWM module produces a 10-bit resolution output. The timer selection for PWMx is TMRx. TxTMR and TxPR set the period of the PWM. The PWMxDCL and PWMxDCH registers configure the duty cycle. The period is common to all PWM modules, whereas the duty cycle is independently controlled. **Important**: The Timerx postscaler is not used in the determination of the PWM frequency. The postscaler might be used to have a servo update rate at a different frequency than the PWM output. All PWM outputs associated with Timerx are set when TxTMR is cleared. Each PWMx is cleared when TxTMR is equal to the value specified in the corresponding PWMxDCH (8 MSb) and PWMxDCL[7:6] (2 LSb) registers. When the value is greater than or equal to TxPR, the PWM output is never cleared (100% duty cycle). **Important:** The PWMxDCH and PWMxDCL registers are double-buffered. The buffers are updated when TxTMR matches TxPR. Care has to be taken to update both registers before the timer match occurs. ## 26.2 PWM Output Polarity The output polarity is inverted by setting the POL bit. #### 26.3 PWM Period The PWM period is specified by the TxPR register. The PWM period can be calculated using the formula of Equation 26-1. It is required to have $F_{OSC}/4$ as the selected clock input to the timer for correct PWM operation. ### Equation 26-1. PWM Period $PWM\ Period = [(T2PR) + 1] \bullet 4 \bullet Tosc \bullet (TMR2\ Prescale\ Value)$ Note: $T_{OSC} = 1/F_{OSC}$ When TxTMR is equal to TxPR, the following three events occur on the next increment cycle: TxTMR is cleared - The PWM output is active (Exception: When the PWM duty cycle = 0%, the PWM output will remain inactive) - The PWMxDCH and PWMxDCL register values are latched into the buffers **Important**: The Timer2 postscaler has no effect on the PWM operation. ## 26.4 PWM Duty Cycle The PWM duty cycle is specified by writing a 10-bit value to the PWMxDCH and PWMxDCL register pair. The PWMxDCH register contains the eight MSbs and the two LSbs, PWMxDCL[7:6]. The PWMxDCH and PWMxDCL registers can be written to at any time. The equations below are used to calculate the PWM pulse width and the PWM duty cycle ratio. #### Equation 26-2. Pulse Width $Pulse\ Width = (PWMxDCH: PWMxDCL[7:6]) \bullet Tosc \bullet (TMR2\ Prescale\ Value)$ Note: $T_{OSC} = 1/F_{OSC}$ ### Equation 26-3. Duty Cycle Ratio $$DutyCycleRatio = \frac{(PWMxDCH: PWMxDCL[7:6])}{4(T2PR+1)}$$ The 8-bit timer T2TMR register is concatenated with the two Least Significant bits of $1/F_{OSC}$ , adjusted by the Timer2 prescaler to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1. ### 26.5 PWM Resolution The resolution determines the number of available duty cycles for a given period. For example, a 10-bit resolution will result in 1024 discrete duty cycles, whereas an 8-bit resolution will result in 256 discrete duty cycles. The maximum PWM resolution is 10 bits when T2PR is 255. The resolution is a function of the T2PR register value as shown below. #### Equation 26-4. PWM Resolution $$Resolution = \frac{\log[4(T2PR + 1)]}{\log(2)}bits$$ **Important:** If the pulse-width value is greater than the period, the assigned PWM pin(s) will remain unchanged. #### Table 26-1. Example PWM Frequencies and Resolutions (F<sub>OSC</sub> = 20 MHz) | PWM Frequency | 0.31 kHz | 4.88 kHz | 19.53 kHz | 78.12 kHz | 156.3 kHz | 208.3 kHz | |---------------------------|----------|----------|-----------|-----------|-----------|-----------| | Timer Prescale | 64 | 4 | 1 | 1 | 1 | 1 | | T2PR Value | 0xFF | 0xFF | 0xFF | 0x3F | 0x1F | 0x17 | | Maximum Resolution (bits) | 10 | 10 | 10 | 8 | 7 | 6.6 | Table 26-2. Example PWM Frequencies and Resolutions ( $F_{OSC} = 8 \text{ MHz}$ ) | PWM Frequency | 0.31 kHz | 4.90 kHz | 19.61 kHz | 76.92 kHz | 153.85 kHz | 200.0 kHz | |---------------------------|----------|----------|-----------|-----------|------------|-----------| | Timer Prescale | 64 | 4 | 1 | 1 | 1 | 1 | | T2PR Value | 0x65 | 0x65 | 0x65 | 0x19 | 0x0C | 0x09 | | Maximum Resolution (bits) | 8 | 8 | 8 | 6 | 5 | 5 | #### **Operation in Sleep Mode** 26.6 In Sleep mode, the T2TMR register will not increment and the state of the module will not change. If the PWMx pin is driving a value, it will continue to drive that value. When the device wakes up, T2TMR will continue from its previous state. #### 26.7 **Changes in System Clock Frequency** The PWM frequency is derived from the system clock frequency (F<sub>OSC</sub>). Any changes in the system clock frequency will result in changes to the PWM frequency. #### 26.8 Effects of Reset Any Reset will force all ports to Input mode and the PWM registers to their Reset states. #### 26.9 Setup for PWM Operation Using PWMx Output Pins Follow the next steps when configuring the module for PWM operation using the PWMx pins: - Disable the PWMx pin output driver(s) by setting the associated TRIS bit(s). - 2. Clear the PWMxCON register. - 3 Load the TxPR register with the PWM period value. - Load the PWMxDCH register and bits [7:6] of the PWMxDCL register with the PWM duty cycle value. - Configure and start Timerx: - Clear the TMRxIF Interrupt Flag bit of the PIRx register.<sup>(1)</sup> - Select the timer clock source to be as F<sub>OSC</sub>/4 using the TxCLKCON register. This is required for correct operation of the PWM module. - Configure the CKPS bits of the TxCON register with the Timerx prescale value. - Enable Timerx by setting the ON bit of the TxCON register. - Enable the PWM output pin and wait until Timerx overflows; the TMRxIF bit of the PIRx register is set. (2) - Enable the PWMx pin output driver(s) by clearing the associated TRIS bit(s) and setting the desired pin PPS control bits. - 8. Configure the PWM module by loading the PWMxCON register with the appropriate values. #### Notes: - To send a complete duty cycle and period on the first PWM output, the above steps must be followed in the given order. If it is not critical to start with a complete PWM signal, then move step 8 to replace step 4. - 2. For operation with other peripherals only, disable PWMx pin outputs. #### 26.9.1 **PWMx Pin Configuration** All PWM outputs are multiplexed with the PORT data latch. The user must configure the pins as outputs by clearing the associated TRIS bits. ## 26.10 Setup for PWM Operation to Other Device Peripherals Follow the next steps when configuring the module for PWM operation to be used by other device peripherals: - 1. Disable the PWMx pin output driver(s) by setting the associated TRIS bit(s). - 2. Clear the PWMxCON register. - 3. Load the TxPR register with the PWM period value. - 4. Load the PWMxDCH register and bits [7:6] of the PWMxDCL register with the PWM duty cycle value. - Configure and start Timerx: - Clear the TMRxIF Interrupt Flag bit of the PIRx register.<sup>(1)</sup> - Select the timer clock source to be as F<sub>OSC</sub>/4 using the TxCLKCON register. This is required for correct operation of the PWM module. - Configure the CKPS bits of the TxCON register with the Timerx prescale value. - Enable Timerx by setting the ON bit of the TxCON register. - 6. Wait until Timerx overflows; the TMRxIF bit of the PIRx register is set. (1) - 7. Configure the PWM module by loading the PWMxCON register with the appropriate values. #### Note: 1. To send a complete duty cycle and period on the first PWM output, the above steps must be included in the setup sequence. If it is not critical to start with a complete PWM signal on the first output, then step 6 may be ignored. ## 26.11 Register Definitions: PWM Control Long bit name prefixes for the PWM peripherals are shown in the table below. Refer to the "Long Bit Names" section for more information. Table 26-3. PWM Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | PWM3 | PWM3 | | PWM4 | PWM4 | | PWM5 | PWM5 | ## 26.11.1 PWMxCON Name: PWMxCON **Offset:** 0x40E,0x0411,0x0414 **PWM Control Register** | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|-----|-----|---|---|---|---| | | EN | | OUT | POL | | | | | | Access | R/W | | R | R/W | | | | | | Reset | 0 | | 0 | 0 | | | | | ## Bit 7 - EN PWM Module Enable bit | | Value | Description | |---|-------|------------------------| | ſ | 1 | PWM module is enabled | | | 0 | PWM module is disabled | # Bit 5 – OUT PWM Module Output Level Indicates PWM module output level when bit is read ### Bit 4 – POL PWM Output Polarity Select bit | N | /alue | Description | |---|-------|------------------------| | 1 | | PWM output is inverted | | C | ) | PWM output is normal | #### 26.11.2 PWMxDC Reset Name: PWMxDC **Offset:** 0x040C,0x040F,0x0412 PWM Duty Cycle Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----------------|-----|-------|----|-----|--------|----|---|---| | | | | | DCH | I[7:0] | | | | | Access<br>Reset | | | | | | | | _ | | Reset | x | x | x | x | x | x | x | x | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DCL | [1:0] | | | | | | | | Access | | | - | | • | | | | Bits 15:8 - DCH[7:0] PWM Duty Cycle Most Significant bits These bits are the MSbs of the PWM duty cycle. Х Reset States: POR/BOR = xxxxxxxx All Other Resets = uuuuuuuu Bits 7:6 - DCL[1:0] PWM Duty Cycle Least Significant bits These bits are the LSbs of the PWM duty cycle. Reset States: POR/BOR = xx All Other Resets = uu # 26.12 Register Summary - PWM | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------------|----------|-----|--------|----------|-----|--------|---|---|---| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x040B | | | | | | | | | | | | 0x040C | PWM3DC | 7:0 | DCL | .[1:0] | | | | | | | | 000400 | PVVIVISDC | 15:8 | | | | DCF | I[7:0] | • | • | | | 0x040E | PWM3CON | 7:0 | EN | | OUT | POL | | | | | | 0x040F | PWM4DC | 7:0 | DCL | [1:0] | | | | | | | | 000406 | P VVIVI4DC | 15:8 | | | • | DCF | I[7:0] | • | • | | | 0x0411 | PWM4CON | 7:0 | EN | | OUT | POL | | | | | | 0x0412 | PWM5DC | 7:0 | DCL | [1:0] | | | | | | | | 0x0412 | 15:8 | | | | DCH[7:0] | | | • | | | | 0x0414 | PWM5CON | 7:0 | EN | | OUT | POL | | | | | ## 27. PWM Timers Selection Each of the PWM modules has an independent timer selection which can be accessed using the timer selection register. The default timer selection is Timer2 for PWM functions. 27.1 Register Definitions: Capture, Compare, and PWM Timers Selection ## 27.1.1 PWMTMRS0 Name: PWMTMRS0 Offset: 0x041F PWM Timers Selection Register Bits 0:1, 2:3, 4:5 - PnTSEL PWMn Timer Selection | PnTSEL Value | PWM | |--------------|----------| | 11 | Timer6 | | 10 | Timer4 | | 01 | Timer2 | | 00 | Reserved | # 27.2 Register Summary - Capture, Compare, and PWM Timers Selection | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|---|---|-------|---------|-------|---------|-------|---------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x041E | | | | | | | | | | | | 0x041F | PWMTMRS0 | 7:0 | | | P5TSE | EL[1:0] | P4TSI | EL[1:0] | P3TSE | EL[1:0] | ## 28. CLC - Configurable Logic Cell The Configurable Logic Cell (CLC) module provides programmable logic that operates outside the speed limitations of software execution. The logic cell takes up to 256 input signals and, through the use of configurable gates, reduces those inputs to four logic lines that drive one of eight selectable single-output logic functions. Input sources are a combination of the following: - I/O pins - Internal clocks - Peripherals - · Register bits The output can be directed internally to peripherals and to an output pin. The following figure is a simplified diagram showing signal flow through the CLC. Possible configurations include: - · Combinatorial Logic - AND - NAND - AND-OR - AND-OR-INVERT - OR-XOR - OR-XNOR - Latches - SR - Clocked D with Set and Reset - Transparent D with Set and Reset Figure 28-1. CLC Simplified Block Diagram #### Notes: - 1. See Figure 28-2 for input data selection and gating. - 2. See Figure 28-3 for programmable logic functions. ## 28.1 CLC Setup Programming the CLC module is performed by configuring the four stages in the logic signal flow. The four stages are: - Data selection - Data gating - Logic function selection - · Output polarity Each stage is set up at run time by writing to the corresponding CLC Special Function Registers. This has the added advantage of permitting logic reconfiguration on-the-fly during program execution. #### 28.1.1 Data Selection Data inputs are selected with CLCnSEL0 through CLCnSEL3 registers. **Important**: Data selections are undefined at power-up. Depending on the number of bits implemented in the CLCnSELy registers, there can be as many as 256 sources available as inputs to the configurable logic. Four multiplexers are used to independently select these inputs to pass on to the next stage as indicated on the left side of the following diagram. Data inputs in the figure are identified by a generic numbered input name. Figure 28-2. Input Data Selection and Gating Note: All controls are undefined at power-up. The CLC Input Selection table correlates the generic input name to the actual signal for each CLC module. The table column labeled 'DyS Value' indicates the MUX selection code for the selected data input. DyS is an abbreviation for the MUX select input codes, D1S through D4S, where 'y' is the gate number. ### 28.1.2 Data Gating Outputs from the input multiplexers are directed to the desired logic function input through the data gating stage. Each data gate can direct any combination of the four selected inputs. The gate stage is more than just signal direction. The gate can be configured to direct each input signal as inverted or noninverted data. Directed signals are ANDed together in each gate. The output of each gate can be inverted before going on to the logic function stage. The gating is in essence a 1-to-4 input AND/NAND/OR/NOR gate. When every input is inverted and the output is inverted, the gate is an AND of all enabled data inputs. When the inputs and output are not inverted, the gate is an OR or all enabled inputs. Table 28-1 summarizes the basic logic that can be obtained in gate 1 by using the gate logic select bits. The table shows the logic of four input variables, but each gate can be configured to use less than four. If no inputs are selected, the output will be '0' or '1', depending on the gate output polarity bit. Table 28-1. Data Gating Logic | CLCnGLSy | GyPOL | Gate Logic | |----------|-------|------------| | 0x55 | 1 | AND | | 0x55 | 0 | NAND | | 0xAA | 1 | NOR | | 0xAA | 0 | OR | | 0x00 | 0 | Logic '0' | | 0x00 | 1 | Logic '1' | It is possible (but not recommended) to select both the true and negated values of an input. When this is done, the gate output is '0', regardless of the other inputs, but may emit logic glitches (transient-induced pulses). If the output of the channel must be '0' or '1', the recommended method is to set all gate bits to '0' and use the gate polarity bit to set the desired level. Data gating is configured with the logic gate select registers as follows: - · Gate 1: CLCnGLS0 - · Gate 2: CLCnGLS1 - Gate 3: CLCnGLS2 - Gate 4: CLCnGLS3 **Note:** Register number suffixes are different than the gate numbers because other variations of this module have multiple gate selections in the same register. Data gating is indicated in the right side of Figure 28-2. Only one gate is shown in detail. The remaining three gates are configured identically, except when the data enables correspond to the enables for that gate. ## 28.1.3 Logic Function There are eight available logic functions including: - · AND-OR - OR-XOR - AND - SR Latch - · D Flip-Flop with Set and Reset - D Flip-Flop with Reset - · J-K Flip-Flop with Reset - · Transparent Latch with Set and Reset Logic functions are shown in the following diagram. Each logic function has four inputs and one output. The four inputs are the four data gate outputs of the previous stage. The output is fed to the inversion stage and from there to other peripherals, an output pin, and back to the CLC itself. Figure 28-3. Programmable Logic Functions Rev. 10-000122B 9/13/2016 ## 28.1.4 Output Polarity The last stage in the Configurable Logic Cell is the output polarity. Setting the POL bit inverts the output signal from the logic stage. Changing the polarity while the interrupts are enabled will cause an interrupt for the resulting output transition. ## 28.2 CLC Interrupts An interrupt will be generated upon a change in the output value of the CLCx when the appropriate interrupt enables are set. A rising edge detector and a falling edge detector are present in each CLC for this purpose. The CLCxIF bit of the associated PIR register will be set when either edge detector is triggered and its associated enable bit is set. The INTP bit enables rising edge interrupts and the INTN bit enables falling edge interrupts. To fully enable the interrupt, set the following bits: - The CLCxIE bit of the respective PIE register - The INTP bit (for a rising edge detection) - The INTN bit (for a falling edge detection) If priority interrupts are not used: - Clear the IPEN bit of the INTCON register. - Set the GIE bit of the INTCON register. - Set the GIEL bit of the INTCON register. If the CLC is a high-priority interrupt: - Set the IPEN bit of the INTCON register. - 2. Set the CLCxIP bit of the respective IPR register. - 3. Set the GIEH bit of the INTCON register. If the CLC is a low-priority interrupt: - 1. Set the IPEN bit of the INTCON register. - Clear the CLCxIP bit of the respective IPR register. - Set the GIEL bit of the INTCON register. The CLCxIF bit of the respective PIR register must be cleared in software as part of the interrupt service. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence. #### 28.3 Effects of a Reset The CLCnCON register is cleared to '0' as the result of a Reset. All other selection and gating values remain unchanged. ## 28.4 Output Mirror Copies Mirror copies of all CLCxOUT bits are contained in the CLCDATA register. Reading this register reads the outputs of all CLCs simultaneously. This prevents any reading skew introduced by testing or reading the OUT bits in the individual CLCnCON registers. ## 28.5 Operation During Sleep The CLC module operates independently from the system clock and will continue to run during Sleep, provided that the input sources selected remain Active. The HFINTOSC remains Active during Sleep when the CLC module is enabled and the HFINTOSC is selected as an input source, regardless of the system clock source selected. In other words, if the HFINTOSC is simultaneously selected as both the system clock and as a CLC input source then, when the CLC is enabled, the CPU will go Idle during Sleep, but the CLC will continue to operate and the HFINTOSC will remain Active. This will have a direct effect on the Sleep mode current. ## 28.6 CLC Setup Steps These steps need to be followed when setting up the CLC: - 1. Disable the CLC by clearing the EN bit. - Select the desired inputs using the CLCnSEL0 through CLCnSEL3 registers. - Clear any ANSEL bits associated with CLC input pins. - 4. Set all TRIS bits associated with inputs. However, a CLC input will also operate if the pin is configured as an output, in which case the TRIS bits must be cleared. ## **CLC - Configurable Logic Cell** - 5. Enable the chosen inputs through the four gates using the CLCnGLS0 through CLCnGLS3 registers. - 6. Select the gate output polarities with the GyPOL bits. - 7. Select the desired logic function with the MODE bits. - Select the desired polarity of the logic output with the POL bit (this step may be combined with the previous gate output polarity step). - If driving a device pin, configure the associated pin PPS control register and also clear the TRIS bit corresponding to that output. - 10. Configure the interrupts (optional). See the CLC Interrupts section. - 11. Enable the CLC by setting the EN bit. ## 28.7 Register Overlay All CLCs in this device share the same set of registers. Only one CLC instance is accessible at a time. The value in the CLCSELECT register is one less than the selected CLC instance. For example, a CLCSELECT value of '0' selects CLC1. ## 28.8 Register Definitions: Configurable Logic Cell ## **28.8.1 CLCSELECT** Name: CLCSELECT Offset: 0x0596 **CLC Instance Selection Register** Selects which CLC instance is accessed by the CLC registers Bits 2:0 - SLCT[2:0] CLC instance selection | Value | Description | |-------|---------------------------------------------------------------------------------| | n | Shared CLC registers of instance n+1 are selected for read and write operations | ## 28.8.2 CLCnCON Name: CLCnCON Offset: 0x058C Configurable Logic Cell Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|-----|------|------|-----|-----------|-----| | | EN | | OUT | INTP | INTN | | MODE[2:0] | | | Access | R/W | | R | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | | 0 | 0 | 0 | 0 | 0 | 0 | ## Bit 7 - EN CLC Enable | Value | Description | |-------|---------------------------------------------------------------| | 1 | Configurable logic cell is enabled and mixing signals | | 0 | Configurable logic cell is disabled and has logic zero output | Bit 5 - OUT Logic cell output data, after LCPOL. Sampled from CLCxOUT. Bit 4 – INTP Configurable Logic Cell Positive Edge Going Interrupt Enable | Value | Description | |-------|---------------------------------------------------------| | 1 | CLCxIF will be set when a rising edge occurs on CLCxOUT | | 0 | Rising edges on CLCxOUT have no effect on CLCxIF | Bit 3 – INTN Configurable Logic Cell Negative Edge Going Interrupt Enable | Value | Description | |-------|----------------------------------------------------------| | 1 | CLCxIF will be set when a falling edge occurs on CLCxOUT | | 0 | Falling edges on CLCxOUT have no effect on CLCxIF | Bits 2:0 - MODE[2:0] Configurable Logic Cell Functional Mode Selection | Value | Description | |-------|------------------------------------------------------| | 111 | Cell is 1-input transparent latch with Set and Reset | | 110 | Cell is J-K flip-flop with Reset | | 101 | Cell is 2-input D flip-flop with Reset | | 100 | Cell is 1-input D flip-flop with Set and Reset | | 011 | Cell is SR latch | | 010 | Cell is 4-input AND | | 001 | Cell is OR-XOR | | 000 | Cell is AND-OR | ## 28.8.3 CLCnPOL Name: CLCnPOL Offset: 0x058D Signal Polarity Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|---|---|-------|-------|-------|-------| | | POL | | | | G4POL | G3POL | G2POL | G1POL | | Access | R/W | | | | R/W | R/W | R/W | R/W | | Reset | 0 | | | | X | X | X | X | Bit 7 - POL CLCxOUT Output Polarity Control | Value | Description | |-------|----------------------------------------------| | 1 | The output of the logic cell is inverted | | 0 | The output of the logic cell is not inverted | Bits 0, 1, 2, 3 – GyPOL Gate Output Polarity Control Reset States: POR/BOR = xxxx | Value | Description | |-------|------------------------------------------------------------| | 1 | The gate output is inverted when applied to the logic cell | | 0 | The output of the gate is not inverted | ## 28,8,4 CLCnSEL0 Name: CLCnSEL0 Offset: 0x058E Generic CLCn Data 1 Select Register Bits 5:0 - D1S[5:0] CLCn Data1 Input Selection ## Table 28-2. CLC Input Selection | DyS | Input Source | DyS (cont.) | Input Source (cont.) | | |----------------------|---------------------|---------------------------------|----------------------|--| | [0] 0000 0000 | CLCINOPPS | <b>[21]</b> 0001 0101 | PWM3_OUT | | | [1] 0000 0001 | CLCIN1PPS | [22] 0001 0110 | PWM4_OUT | | | [2] 0000 0010 | CLCIN2PPS | [23] 0001 0111 | PWM5_OUT | | | [3] 0000 0011 | CLCIN3PPS | [24] 0001 1000 | NCO1_OUT | | | [4] 0000 0100 | Fosc | [25] 0001 1001 | C1_OUT | | | <b>[5]</b> 0000 0101 | HFINTOSC | [26] 0001 1010 | ZCD_OUT | | | <b>[6]</b> 0000 0110 | LFINTOSC | [27] 0001 1011 | IOC | | | [7] 0000 0111 | MFINTOSC (500 kHz) | [28] 0001 1100 | CLC1_OUT | | | [8] 0000 1000 | MFINTOSC (32 kHz) | [29] 0001 1101 | CLC2_OUT | | | <b>[9]</b> 0000 1001 | SFINTOSC (1 MHz) | [30] 0001 1110 | CLC3_OUT | | | [10] 0000 1010 | SOSC | [31] 0001 1111 | CLC4_OUT | | | [11] 0000 1011 | EXTOSC | [32] 0010 0000 | TX1/CK1 | | | [12] 0000 1100 | ADCRC | [33] 0010 0001 | TX2/CK2 | | | [13] 0000 1101 | TMR0_overflow | <b>[34]</b> 0010 0010 | SDA1/SDO1 | | | [14] 0000 1110 | TMR1_overflow | <b>[35]</b> 0010 0011 | SCL1/SCK1 | | | [15] 0000 1111 | TMR2_Postscaled_OUT | <b>[36]</b> 0010 0100 | SDA2/SDO2 | | | [16] 0001 0000 | TMR3_overflow | [37] 0010 0101 | SCL2/SCK2 | | | [17] 0001 0001 | TMR4_Postscaled_OUT | [38] 0010 0110 | CWG1A_OUT | | | [18] 0001 0010 | TMR6_Postscaled_OUT | <b>[39]</b> 0010 0111 | CWG1B_OUT | | | [19] 0001 0011 | CCP1_OUT | [40] 0010 1000 [62] 0011 1444 | Decembed | | | [20] 0001 0100 | CCP2_OUT | [40] 0010 1000 - [63] 0011 1111 | Reserved | | Reset States: POR/BOR = xxxxxx All Other Resets = uuuuuu ## 28,8,5 CLCnSEL1 Name: CLCnSEL1 Offset: 0x058F Generic CLCn Data 1 Select Register Bits 5:0 - D2S[5:0] CLCn Data2 Input Selection Reset States: POR/BOR = xxxxxx | Value | Description | |-------|-------------------------------------------------------------| | n | Refer to the CLC Input Selection table for input selections | ## 28,8,6 CLCnSEL2 Name: CLCnSEL2 Offset: 0x0590 Generic CLCn Data 1 Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|-----|-----|-----|-------|-----|-----| | [ | | | | | D3S | [5:0] | | | | Access | | | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | | | X | X | X | X | X | X | Bits 5:0 - D3S[5:0] CLCn Data3 Input Selection Reset States: POR/BOR = xxxxxx | Value | Description | |-------|-------------------------------------------------------------| | n | Refer to the CLC Input Selection table for input selections | ## 28.8.7 CLCnSEL3 Name: CLCnSEL3 Offset: 0x0591 Generic CLCn Data 4 Select Register Bits 5:0 - D4S[5:0] CLCn Data4 Input Selection Reset States: POR/BOR = xxxxxx | Value | Description | |-------|-------------------------------------------------------------| | n | Refer to the CLC Input Selection table for input selections | ## 28.8.8 CLCnGLS0 Name: CLCnGLS0 Offset: 0x0592 CLCn Gate1 Logic Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | Access | R/W | Reset | x | x | x | x | x | x | x | x | ## Bits 1, 3, 5, 7 – G1DyT dyT: Gate1 Data 'y' True (noninverted) Reset States: POR/BOR = xxxx All Other Resets = uuuu | Value | Description | |-------|--------------------------| | 1 | dyT is gated into g1 | | 0 | dyT is not gated into g1 | ## Bits 0, 2, 4, 6 – G1DyN dyN: Gate1 Data 'y' Negated (inverted) Reset States: POR/BOR = xxxx | Value | Description | |-------|--------------------------| | 1 | dyN is gated into g1 | | 0 | dyN is not gated into g1 | ## 28,8,9 CLCnGLS1 Name: CLCnGLS1 Offset: 0x0593 CLCn Gate2 Logic Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | Access | R/W | Reset | X | X | X | X | X | X | X | X | ## Bits 1, 3, 5, 7 – G2DyT dyT: Gate2 Data 'y' True (noninverted) Reset States: POR/BOR = xxxx All Other Resets = uuuu | Value | Description | |-------|--------------------------| | 1 | dyT is gated into g2 | | 0 | dyT is not gated into g2 | ## Bits 0, 2, 4, 6 – G2DyN dyN: Gate2 Data 'y' Negated (inverted) Reset States: POR/BOR = xxxx | Value | Description | |-------|--------------------------| | 1 | dyN is gated into g2 | | 0 | dyN is not gated into g2 | ## 28.8.10 CLCnGLS2 Name: CLCnGLS2 Offset: 0x0594 CLCn Gate3 Logic Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | Access | R/W | Reset | x | x | x | x | x | x | x | x | ## Bits 1, 3, 5, 7 – G3DyT dyT: Gate3 Data 'y' True (noninverted) Reset States: POR/BOR = xxxx All Other Resets = uuuu | Value | Description | |-------|--------------------------| | 1 | dyT is gated into g3 | | 0 | dyT is not gated into g3 | ## Bits 0, 2, 4, 6 – G3DyN dyN: Gate3 Data 'y' Negated (inverted) Reset States: POR/BOR = xxxx | Value | Description | |-------|--------------------------| | 1 | dyN is gated into g3 | | 0 | dyN is not gated into g3 | ## 28.8.11 CLCnGLS3 Name: CLCnGLS3 Offset: 0x0595 CLCn Gate4 Logic Select Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-------|-------|-------|-------|-------|-------|-------|-------| | | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | Access | R/W | Reset | X | X | X | X | X | X | X | X | ## Bits 1, 3, 5, 7 – G4DyT dyT: Gate4 Data 'y' True (noninverted) Reset States: POR/BOR = xxxx All Other Resets = uuuu | Value | Description | |-------|--------------------------| | 1 | dyT is gated into g4 | | 0 | dyT is not gated into g4 | ## Bits 0, 2, 4, 6 – G4DyN dyN: Gate4 Data 'y' Negated (inverted) Reset States: POR/BOR = xxxx | Value | Description | |-------|--------------------------| | 1 | dyN is gated into g4 | | 0 | dyN is not gated into g4 | ## 28.8.12 CLCDATA Name: CLCDATA Offset: 0x0597 CLC Data Output Register Mirror copy of CLC outputs | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---|---|---|---|---------|---------|---------|---------| | | | | | | CLC4OUT | CLC3OUT | CLC2OUT | CLC1OUT | | Access | | | | | R/W | R/W | R/W | R/W | | Reset | | | | | 0 | 0 | 0 | 0 | Bits 0, 1, 2, 3 - CLCxOUT Mirror copy of CLCx\_out | Value | Description | |-------|---------------| | 1 | CLCx_out is 1 | | 0 | CLCx_out is 0 | # 28.9 Register Summary - CLC Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------|-----------|----------|-------|-------|-----------|-------|---------|---------|-----------|---------| | 0x00<br><br>0x058B | Reserved | | | | | | | | | | | 0x058C | CLCnCON | 7:0 | EN | | OUT | INTP | INTN | | MODE[2:0] | | | 0x058D | CLCnPOL | 7:0 | POL | | | | G4POL | G3POL | G2POL | G1POL | | 0x058E | CLCnSEL0 | 7:0 | | | D1S[5:0] | | | | | | | 0x058F | CLCnSEL1 | 7:0 | | | D2S[5:0] | | | | | | | 0x0590 | CLCnSEL2 | 7:0 | | | D3S[5:0] | | | | | | | 0x0591 | CLCnSEL3 | 7:0 | | | D4S[5:0] | | | | | | | 0x0592 | CLCnGLS0 | 7:0 | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | 0x0593 | CLCnGLS1 | 7:0 | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | 0x0594 | CLCnGLS2 | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | 0x0595 | CLCnGLS3 | 7:0 | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | 0x0596 | CLCSELECT | 7:0 | | | SLCT[2:0] | | | | | | | 0x0597 | CLCDATA | 7:0 | | | | | CLC4OUT | CLC3OUT | CLC2OUT | CLC1OUT | ## 29. MSSP - Host Synchronous Serial Port Module The Host Synchronous Serial Port (MSSP) module is a serial interface useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D converters, etc. The MSSP module can operate in one of two modes: - · Serial Peripheral Interface (SPI) - Inter-Integrated Circuit (I<sup>2</sup>C) The SPI interface can operate in Host or Client mode and supports the following features: - Selectable clock parity - Client select synchronization (Client mode only) - · Daisy-chain connection of client devices The I<sup>2</sup>C interface can operate in Host or Client mode and supports the following modes and features: - · Byte NACKing (Client mode) - · Limited multi-host support - · 7-bit and 10-bit addressing - Start and stop interrupts - Interrupt masking - Clock stretching - · Bus collision detection - · General call address matching - · Address masking - · Address Hold and Data Hold modes - · Selectable SDA hold times ### 29.1 SPI Mode Overview The Serial Peripheral Interface (SPI) is a synchronous serial data communication bus that operates in Full Duplex mode. Devices communicate in a host/client environment where the host device initiates the communication. A client device is selected for communication using the Client Select feature. The SPI bus specifies four signal connections: - Serial Clock (SCK) - Serial Data Out (SDO) - Serial Data In (SDI) - Client Select (SS) Figure 29-1 shows the block diagram of the MSSP module when operating in SPI mode. Figure 29-1. MSSP Block Diagram (SPI Mode) Notes: 1. Output selection for Host mode. 2. Input selection for Client and Host modes. The SPI bus operates with a single host device and one or more client devices. When multiple client devices are used, an independent Client Select connection is required from the host device to each client device. The host selects only one client at a time. Most client devices have tri-state outputs, so their output signal appears disconnected from the bus when they are not selected. Figure 29-2 shows a typical connection between a host device and multiple client devices. Figure 29-2. SPI Host and Multiple Client Connection Transmissions involve two shift registers, eight bits in size: One in the host and one in the client. Data is always shifted out one bit at a time, with the Most Significant bit (MSb) shifted out first. At the same time, a new Least Significant bit (LSb) is shifted into the same register. Figure 29-3 shows a typical connection between two processors configured as host and client devices. Figure 29-3. SPI Host/Client Connection Data is shifted out of both shift registers on the programmed clock edge and latched on the opposite edge of the clock. The host device transmits information out on its SDO output pin, which is connected to and received by the client's SDI input pin. The client device transmits information out on its SDO output pin, which is connected to and received by the host's SDI input pin. To begin communication, the host device transmits both the MSb from its shift register and the clock signal. Both the host and client devices need to be configured for the same clock polarity. During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the host device is sending out the MSb from its shift register (on its SDO pin) and the client device is reading this bit and saving it as the LSb of its shift register, the client device is also sending out the MSb from its shift register (on its SDO pin) and the host device is reading this bit and saving it as the LSb of its shift register. After eight bits have been shifted out, the host and client have exchanged register values. If there is more data to exchange, the shift registers are loaded with new data and the process repeats itself. Whether the data is meaningful or not (dummy data) depends on the application software. This leads to three scenarios for data transmission: - · Host sends useful data and client sends dummy data. - · Host sends useful data and client sends useful data. - · Host sends dummy data and client sends useful data. Transmissions must be performed in multiples of eight clock cycles. When there is no more data to be transmitted, the host stops sending the clock signal and it deselects the client. Every client device connected to the bus that has not been selected through its Client Select line must disregard the clock and transmission signals and must not transmit out any data of its own. #### 29.1.1 SPI Mode Registers The MSSP module has six registers for SPI mode operation. They are: - MSSP Status Register (SSPxSTAT) - MSSP Control Register 1 (SSPxCON1) - MSSP Control Register 3 (SSPxCON3) - MSSP Data Buffer Register (SSPxBUF) ## **MSSP - Host Synchronous Serial Port Module** - MSSP Address Register (SSPxADD) - MSSP Shift (SSPSR) register (not directly accessible) SSPxCON1 and SSPxSTAT are the control and status registers for SPI mode operation. The SSPxCON1 register is readable and writable. The lower six bits of the SSPxSTAT are read-only. The upper two bits of the SSPxSTAT are read/write. One of the five SPI Host modes uses the SSPxADD value to determine the Baud Rate Generator clock frequency. More information on the Baud Rate Generator is available in 29.3. Baud Rate Generator. SSPSR is the shift register used for shifting data in and out. SSPxBUF provides indirect access to the SSPSR register. SSPxBUF is the buffer register to which data bytes are written, and from which data bytes are read. In receive operations, SSPSR and SSPxBUF together create a buffered receiver. When SSPSR receives a complete byte, it is transferred to SSPxBUF and the SSPxIF interrupt is set. During transmission, the SSPxBUF is not buffered. A write to SSPxBUF will write to both SSPxBUF and SSPSR. #### 29.1.2 SPI Mode Operation When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits (SSPxCON1[5:0] and SSPxSTAT[7:6]). These control bits allow the following to be specified: - Host mode (SCK is the clock output) - · Client mode (SCK is the clock input) - Clock Polarity (Idle state of SCK) - · Data Input Sample Phase (middle or end of data output time) - · Clock Edge (output data on rising/falling edge of SCK) - Clock Rate (Host mode only) - · Client Select mode (Client mode only) To enable the serial port, the SSP Enable (SSPEN) bit must be set. To reset or reconfigure SPI mode, clear the SSPEN bit, re-initialize the SSPxCONy registers and then set the SSPEN bit. The SDI, SDO, SCK and SS serial port pins are selected with the PPS controls. For the pins to behave as the serial port function, some must have their data direction bits (in the TRIS register) appropriately programmed as follows: - · SDI must have the corresponding TRIS bit set - SDO must have the corresponding TRIS bit cleared - · SCK (Host mode) must have the corresponding TRIS bit cleared - · SCK (Client mode) must have the corresponding TRIS bit set - The RxyPPS and SSPxCLKPPS controls must select the same pin - SS must have the corresponding TRIS bit set Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. The MSSP consists of a Transmit/Receive Shift Register (SSPSR) and a buffer register (SSPxBUF). The SSPSR shifts the data in and out of the device, MSb first. The SSPxBUF holds the data that was written to the SSPSR until the received data is ready. Once the eight bits of data have been received, that byte is moved to the SSPxBUF register. Then, the Buffer Full Status (BF) bit and the MSSP Interrupt Flag (SSPxIF) bit are set. This double-buffering of the received data allows the next byte to start reception before reading the data that was just received. Any write to the SSPxBUF register during transmission/reception of data will be ignored and the Write Collision Detect (WCOL) bit will be set. User software must clear the WCOL bit to allow the following write(s) to the SSPxBUF register to complete successfully. When the application software is expecting to receive valid data, the SSPxBUF must be read before the next byte of data to be transferred is written to the SSPxBUF. The BF bit indicates when SSPxBUF has been loaded with the received data (transmission is complete). When the SSPxBUF is read, the BF bit is cleared. This data may be irrelevant if the SPI is only a transmitter. The MSSP interrupt is used to determine when the transmission/reception has completed. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur. ## **MSSP - Host Synchronous Serial Port Module** **Important:** The SSPSR is not directly readable or writable and can only be accessed by addressing the SSPxBUF register. #### 29.1.2.1 SPI Host Mode The Host can initiate the data transfer at any time because it controls the SCK line. The Host determines when the client (Processor 2, Figure 29-3) is to broadcast data by the software protocol. In Host mode, the data is transmitted/received as soon as the SSPxBUF register is written to. If the SPI is only going to receive, the SDO output may be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPxBUF register (interrupts and Status bits appropriately set). The clock polarity is selected by appropriately programming the Clock Polarity Select (CKP) and SPI Clock Edge Select (CKE) bits. Figure 29-4 shows the four clocking configurations. When the CKE bit is set, the SDO data is valid one half of a clock cycle before a clock edge appears on SCK, and transmission occurs on the transition from the Active to Idle clock state. When CKE is clear, the SDO data is valid at the same time as the clock edge appears on SCK, and transmission occurs on the transition from the Idle to Active clock states. The SPI Data Input Sample (SMP) bit determines when the SDI input is sampled. When SMP is set, input data is sampled at the end of the data output time. When SMP is clear, input data is sampled at the middle of the data output time. The SPI clock rate (bit rate) is user-programmable to be one of the following: - F<sub>OSC</sub>/4 (or T<sub>CY</sub>) - F<sub>OSC</sub>/16 (or 4 \* T<sub>CY</sub>) - F<sub>OSC</sub>/64 (or 16 \* T<sub>CY</sub>) - · Timer2 output/2 - F<sub>OSC</sub>/(4 \* (SSPxADD + 1)) **Important:** In Host mode, the clock signal output to the SCK pin is also the clock signal input to the peripheral. The pin selected for output with the RxyPPS register must also be selected as the peripheral input with the SSPxCLKPPS register. Figure 29-4. SPI Mode Waveform (Host Mode) #### 29.1.2.2 SPI Client Mode In Client mode, the data is transmitted and received as external clock pulses appear on SCK. When the last bit is latched, the SSPxIF Interrupt Flag bit is set. Before enabling the module in SPI Client mode, the clock line must match the proper Idle state. The clock line can be observed by reading the SCK pin. The Idle state is determined by the CKP bit. While in Client mode, the external clock is supplied by the external clock source on the SCK pin. This external clock must meet the minimum high and low times as specified in Electrical Specifications. While in Sleep mode, the client can transmit/receive data. The shift register is clocked from the SCK pin input and when a byte is received, the device will generate an interrupt. If enabled, the device will wake up from Sleep. #### 29.1.2.3 Daisy-Chain Configuration The SPI bus can sometimes be connected in a daisy-chain configuration. The first client output is connected to the second client input, the second client output is connected to the third client input, and so on. The final client output is connected to the host input. Each client sends out, during a second group of clock pulses, an exact copy of what was received during the first group of clock pulses. The whole chain acts as one large communication shift register. The daisy-chain feature only requires a single Client Select line from the host device. In a daisy-chain configuration, only the most recent byte on the bus is required by the client. Setting the Buffer Overwrite Enable (BOEN) bit will enable writes to the SSPxBUF register, even if the previous byte has not been read. This allows the software to ignore data that may not apply to it. Figure 29-5 shows the block diagram of a typical daisy-chain connection when operating in SPI mode. Figure 29-5. SPI Daisy-Chain Connection ## 29.1.2.4 Client Select Synchronization The Client Select can also be used to synchronize communication (see Figure 29-6). The Client Select line is held high until the host device is ready to communicate. When the Client Select line is pulled low, the client knows that a new transmission is starting. If the client fails to receive the communication properly, it will be reset at the end of the transmission, when the Client Select line returns to a High state. The client is then ready to receive a new transmission when the Client Select line is pulled low again. If the Client Select line is not used, there is a risk that the client will eventually become out of sync with the host. If the client misses a bit, it will always be one bit off in future transmissions. Use of the Client Select line allows the client and host to align themselves at the beginning of each transmission. The $\overline{SS}$ pin allows a Synchronous Client mode. The SPI must be in Client mode with $\overline{SS}$ pin control enabled (MSSP Mode Select (SSPM) bits = 0100). When the SS pin is low, transmission and reception are enabled and the SDO pin is driven. When the $\overline{SS}$ pin goes high, the SDO pin is no longer driven, even if in the middle of a transmitted byte, and becomes a floating output. External pull-up/pull-down resistors may be desirable depending on the application. When the SPI module resets, the bit counter is forced to '0'. This can be done by either forcing the $\overline{SS}$ pin to a high level or clearing the SSPEN bit. #### Important: - 1. When the SPI is in Client mode with $\overline{SS}$ pin control enabled (SSPM = 0100), the SPI module will reset if the $\overline{SS}$ pin is set to $V_{DD}$ . - 2. When the SPI is used in Client mode with CKE set, the user must enable $\overline{SS}$ pin control (see Figure 29-8). If CKE is clear, $\overline{SS}$ pin control is optional (see Figure 29-7). - 3. While operated in SPI Client mode, the SMP bit must remain clear. Figure 29-6. Client Select Synchronous Waveform Figure 29-8. SPI Mode Waveform (Client Mode with CKE = 1) ## 29.1.2.5 SPI Operation in Sleep Mode In SPI Host mode, when the Sleep mode is selected, all module clocks are halted and the transmission/reception will remain in that state until the device wakes. After the device returns to Run mode, the module will resume transmitting and receiving data. In SPI Client mode, the SPI Transmit/Receive Shift register operates asynchronously to the device. This allows the device to be placed in Sleep mode and data to be shifted into the SPI Transmit/Receive Shift register. When all eight bits have been received, the MSSP Interrupt Flag bit will be set and if enabled, will wake the device. ## 29.2 I<sup>2</sup>C Mode Overview The Inter-Integrated Circuit (I<sup>2</sup>C) bus is a multi-host serial data communication bus. Devices communicate in a host/client environment where the host devices initiate the communication. A client device is controlled through addressing. Figure 29-9 and Figure 29-10 show block diagrams of the I<sup>2</sup>C Host and Client modes, respectively. Figure 29-9. MSSP Block Diagram (I<sup>2</sup>C Host Mode) Notes: 1. SDA pin selections must be the same for input and output. SCL pin selections must be the same for input and output. Figure 29-10. MSSP Block Diagram (I<sup>2</sup>C Client Mode) Notes: 1.SDA pin selections must be the same for input and output. 2. SCL pin selections must be the same for input and output. The I<sup>2</sup>C bus specifies two signal connections: - · Serial Clock (SCL) - Serial Data (SDA) Both the SCL and SDA connections are bidirectional open-drain lines, each requiring pull-up resistors for the supply voltage. Pulling the line to ground is considered a logical zero and letting the line float is considered a logical one. Figure 29-11 shows a typical connection between two processors configured as host and client devices. Figure 29-11. I<sup>2</sup>C Host/Client Connection The I<sup>2</sup>C bus can operate with one or more host devices and one or more client devices. There are four potential modes of operation for a given device: - Host Transmit mode (host is transmitting data to a client) - Host Receive mode (host is receiving data from a client) - Client Transmit mode (client is transmitting data to a host) - Client Receive mode (client is receiving data from the host) To begin communication, the host device transmits a Start condition followed by the address byte of the client it intends to communicate with. A Start condition is indicated by a high-to-low transition of the SDA line while the SCL ## **MSSP - Host Synchronous Serial Port Module** line is held high. Address and data bytes are sent out, MSb first. This is followed by a single Read/Write Information $(R/\overline{W})$ bit, which determines whether the host intends to transmit to or receive data from the client device. The $R/\overline{W}$ bit is sent out as a logical one when the host intends to read data from the client, and is sent out as a logical zero when it intends to write data to the client. If the requested client exists on the bus, it will respond with an Acknowledge sequence, otherwise known as an $\overline{ACK}$ . The Acknowledge sequence is an active-low signal, which holds the SDA line low to indicate to the transmitter that the client device has received the transmitted data and is ready to receive more. The host then continues to either transmit to or receive data from the client. The transition of a data bit is always performed while the SCL line is held low. Transitions that occur while the SCL line is held high are used to indicate Start and Stop conditions. If the host intends to write to the client, then it repeatedly sends out a byte of data, with the client responding after each byte with an $\overline{\mathsf{ACK}}$ sequence. In this example, the host device is in Host Transmit mode and the client is in Client Receive mode. If the host intends to read from the client, then it repeatedly receives a byte of data from the client, and responds after each byte with an $\overline{\mathsf{ACK}}$ sequence. In this example, the host device is in Host Receive mode and the client is in Client Transmit mode. On the last byte of data communicated, the host device may end the transmission by sending a Stop condition. If the host device is in Receive mode, it sends the Stop condition in place of the last $\overline{ACK}$ sequence. A Stop condition is indicated by a low-to-high transition of the SDA line while the SCL line is held high. In some cases, the host may want to maintain control of the bus and re-initiate another transmission. If so, the host device may send a Restart condition in place of the Stop condition or last $\overline{ACK}$ sequence when it is in Receive mode. The I<sup>2</sup>C bus specifies three message protocols: - · Single message where a host writes data to a client. - · Single message where a host reads data from a client. - Combined message where a host initiates a minimum of two writes, or two reads, or a combination of writes and reads, to one or more clients. ## 29.2.1 I<sup>2</sup>C Mode Registers The MSSP module has eight registers for I<sup>2</sup>C operation. #### These are: - MSSP Status Register (SSPxSTAT) - MSSP Control 1 Register (SSPxCON1) - MSSP Control 2 Register (SSPxCON2) - MSSP Control 3 Register (SSPxCON3) - Serial Receive/Transmit Buffer Register (SSPxBUF) - MSSP Address Register (SSPxADD) - I<sup>2</sup>C Client Address Mask Register (SSPxMSK) - MSSP Shift (SSPSR) register not directly accessible SSPxCON1, SSPxCON2, SSPxCON3 and SSPxSTAT are the Control and Status registers in I<sup>2</sup>C mode operation. The SSPxCON1, SSPxCON2 and SSPxCON3 registers are readable and writable. The lower six bits of the SSPxSTAT are read-only. The upper two bits of the SSPxSTAT are read/write. SSPxMSK holds the client address mask value used in address comparison. SSPxADD contains the client device address when the MSSP is configured in I<sup>2</sup>C Client mode. When the MSSP is configured in Host mode, SSPxADD acts as the Baud Rate Generator reload value. SSPSR is the shift register used for shifting data in or out. SSPxBUF is the buffer register to which data bytes are written to or read from. In receive operations, SSPSR and SSPxBUF together, create a double-buffered receiver. When SSPSR receives a complete byte, it is transferred to SSPxBUF and the SSPxIF interrupt is set. During transmission, the SSPxBUF is not double-buffered. A write to SSPxBUF will write to both SSPxBUF and SSPSR. ## 29.2.2 I<sup>2</sup>C Mode Operation All MSSP I<sup>2</sup>C communication is byte oriented and shifted out MSb first. Eight SFR registers and two interrupt flags interface the module with the PIC<sup>®</sup> microcontroller and user software. Two pins, SDA and SCL, are exercised by the module to communicate with other external I<sup>2</sup>C devices. ## 29.2.2.1 Definition of I<sup>2</sup>C Terminology There is language and terminology in the description of I<sup>2</sup>C communication that have definitions specific to I<sup>2</sup>C. That word usage is defined below and may be used in the rest of this document without explanation. This table was adapted from the Philips/NXP I<sup>2</sup>C Specification. Table 29-1. I<sup>2</sup>C Terminology | Term | Description | | | | | | | |---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Transmitter | The device that shifts data out onto the bus | | | | | | | | Receiver | The device that shifts data in from the bus | | | | | | | | Host | The device that initiates a transfer, generates clock signals, and terminates a transfer | | | | | | | | Client The device addressed by the host | | | | | | | | | Multi-Host | A bus with more than one device that can initiate data transfers | | | | | | | | Arbitration | Procedure to ensure that only one host at a time controls the bus. Winning arbitration ensures that the message is not corrupted. | | | | | | | | Synchronization Procedure to synchronize the clocks of two or more devices on the bus | | | | | | | | | Idle No host is controlling the bus, and both SDA and SCL lines are high | | | | | | | | | Active | Any time one or more host devices are controlling the bus | | | | | | | | Addressed Client | Client device that has received a matching address and is actively being clocked by a host | | | | | | | | Matching Address | Address byte that is clocked into a client that matches the value stored in SSPxADD | | | | | | | | Write Request | Client receives a matching address with the R/W bit clear, and is ready to clock in data | | | | | | | | Read Request | Host sends an address byte with the $R/\overline{W}$ bit set, indicating that it wishes to clock data out of the client. This data is the next and all following bytes until a Restart or Stop. | | | | | | | | Clock Stretching | When a device on the bus hold SCL low to stall communication | | | | | | | | Bus Collision | Any time the SDA line is sampled low by the module while it is outputting and expected High state | | | | | | | ## **29.2.2.2** Byte Format All communication in $I^2C$ is done in 9-bit segments. A byte is sent from a host to a client or vice versa, followed by an Acknowledge sequence sent back. After the eighth falling edge of the SCL line, the device outputting data on the SDA changes that pin to an input and reads the Acknowledge value on the next clock pulse. The clock signal, SCL, is provided by the host. Data is valid to change while the SCL signal is low, and sampled on the rising edge of the clock. Changes on the SDA line while the SCL line is high define special conditions on the bus, such as a Start or Stop condition. #### 29.2.2.3 SDA and SCL Pins Selection of any I<sup>2</sup>C mode with the SSPEN bit set forces the SCL and SDA pins to be open-drain. These pins must be configured as inputs by setting the appropriate TRIS bits. ## **MSSP - Host Synchronous Serial Port Module** **Important:** Any device pin can be selected for SDA and SCL functions with the PPS peripheral. These functions are bidirectional. The SDA input is selected with the SSPxDATPPS registers. The SCL input is selected with the SSPxCLKPPS registers. Outputs are selected with the RxyPPS registers. It is the user's responsibility to make the selections so that both the input and the output for each function is on the same pin. #### 29.2.2.4 SDA Hold Time The hold time of the SDA pin is selected by the SDA Hold Time Selection (SDAHT) bit. Hold time is the time SDA is held valid after the falling edge of SCL. Setting the SDAHT bit selects a longer 300 ns minimum hold time and may help buses with large capacitance. #### 29.2.2.5 Clock Stretching Clock stretching occurs when a device on the bus holds the SCL line low, effectively pausing communication. The client may stretch the clock to allow more time to handle data or prepare a response for the host device. A host device is not concerned with stretching as anytime it is active on the bus and not transferring data it is stretching. Any stretching done by a client is invisible to the host software and handled by the hardware that generates SCL. The CKP bit is used to control stretching in software. Any time the CKP bit is cleared, the module will wait for the SCL line to go low and then hold it. Setting CKP will release SCL and allow more communication. ## 29.2.2.6 Arbitration Each host device must monitor the bus for Start and Stop conditions. If the device detects that the bus is busy, it cannot begin a new message until the bus returns to an Idle state. However, two host devices may try to initiate a transmission on or about the same time. When this occurs, the process of arbitration begins. Each transmitter checks the level of the SDA data line and compares it to the level that it expects to find. The first transmitter to observe that the two levels do not match, loses arbitration, and must stop transmitting on the SDA line. For example, if one transmitter holds the SDA line to a logical one (lets SDA float) and a second transmitter holds it to a logical zero (pulls SDA low), the result is that the SDA line will be low. The first transmitter then observes that the level of the line is different than expected and concludes that another transmitter is communicating. The first transmitter to notice this difference is the one that loses arbitration and must stop driving the SDA line. If this transmitter is also a host device, it also must stop driving the SCL line. It then can monitor the lines for a Stop condition before trying to reissue its transmission. In the meantime, the other device that has not noticed any difference between the expected and actual levels on the SDA line continues with its original transmission. It can do so without any complications, because so far, the transmission appears exactly as expected with no other transmitter disturbing the message. Client Transmit mode can also be arbitrated, when a host addresses multiple clients, but this is less common. #### 29.2.2.7 Start Condition The I<sup>2</sup>C Specification defines a Start condition as a transition of SDA from a High to a Low state while SCL line is high. A Start condition is always generated by the host and signifies the transition of the bus from an Idle to an Active state. Figure 29-12 shows wave forms for Start and Stop conditions. A bus collision can occur on a Start condition if the module samples the SDA line low before asserting it low. This does not conform to the I<sup>2</sup>C Specification that states no bus collision can occur on a Start. #### 29.2.2.8 Stop Condition A Stop condition is a transition of the SDA line from Low-to-High state while the SCL line is high. **Important:** At least one SCL low time must appear before a Stop is valid, therefore, if the SDA line goes low then high again while the SCL line stays high, only the Start condition is detected. Figure 29-12. I<sup>2</sup>C Start and Stop Conditions #### 29.2.2.9 Start/Stop Condition Interrupt Masking The Start Condition Interrupt Enable (SCIE) and Stop Condition Interrupt Enable (PCIE) bits can enable the generation of an interrupt in Client modes that do not typically support this function. These bits will have no effect in Client modes where interrupt on Start and Stop detect are already enabled. #### 29.2.2.10 Restart Condition A Restart condition is valid any time that a Stop is valid. A host can issue a Restart if it wishes to hold the bus after terminating the current transfer. A Restart has the same effect on the client that a Start would, resetting all client logic and preparing it to clock in an address. The host may want to address the same or another client. Figure 29-13 shows the waveform for a Restart condition. In 10-bit Addressing Client mode, a Restart is required for the host to clock data out of the addressed client. Once a client has been fully addressed, matching both high and low address bytes, the host can issue a Restart and the high address byte with the R/W bit set. The client logic will then hold the clock and prepare to clock out data. Figure 29-13, I<sup>2</sup>C Restart Condition #### 29.2.2.11 Acknowledge Sequence The ninth SCL pulse for any transferred byte in $I^2C$ is dedicated as an Acknowledge sequence ( $\overline{ACK}$ ). It allows receiving devices to respond back to the transmitter by pulling the SDA line low. The transmitter must release control of the line during this time to shift in the response. The Acknowledge ( $\overline{ACK}$ ) is an active-low signal, pulling the SDA line low indicates to the transmitter that the device has received the transmitted data and is ready to receive more. The result of an ACK is placed in the Acknowledge Status (ACKSTAT) bit. The client software, when the Address Hold Enable (AHEN) and Data Hold Enable (DHEN) bits are set, allows the user to select the $\overline{ACK}$ value sent back to the transmitter. The Acknowledge Data (ACKDT) bit is set/cleared to determine the response. The client hardware will generate an $\overline{ACK}$ response under most circumstances. However, if the BF bit or the Receive Overflow Indicator (SSPOV) bit are set when a byte is received then the $\overline{ACK}$ will not be sent by the client. ## **MSSP - Host Synchronous Serial Port Module** When the module is addressed, after the eighth falling edge of SCL on the bus, the Acknowledge Time Status (ACKTIM) bit is set. The ACKTIM bit indicates the acknowledge time of the active bus. The ACKTIM bit is only active when either the AHEN bit or DHEN bit is enabled. ### 29.2.3 I<sup>2</sup>C Client Mode Operation The MSSP Client mode operates in one of four modes selected by the MSSP Mode Select (SSPM) bits. The modes can be divided into 7-bit and 10-bit Addressing mode. 10-bit Addressing modes operate the same as 7-bit with some additional overhead for handling the larger addresses. Modes with Start and Stop condition interrupts operate the same as the other modes with SSPxIF additionally getting set upon detection of a Start, Restart, or Stop condition. #### 29.2.3.1 Client Mode Addresses The SSPxADD register contains the Client mode address. The first byte received after a Start or Restart condition is compared against the value stored in this register. If the byte matches, the value is loaded into the SSPxBUF register and an interrupt is generated. If the value does not match, the module goes Idle and no indication is given to the software that anything happened. The SSPxMSK register affects the address matching process. See 29.2.3.5. SSP Mask Register for more information. #### 29.2.3.1.1 I<sup>2</sup>C Client 7-Bit Addressing Mode In 7-bit Addressing mode, the LSb of the received data byte is ignored when determining if there is an address match. ### 29.2.3.1.2 I<sup>2</sup>C Client 10-Bit Addressing Mode In 10-bit Addressing mode, the first received byte is compared to the binary value of '1 1 1 1 0 A9 A8 0'. A9 and A8 are the two MSbs of the 10-bit address and stored in bits 2 and 1 of the SSPxADD register. After the acknowledge of the high byte the Update Address (UA) bit is set and SCL is held low until the user updates SSPxADD with the low address. The low address byte is clocked in and all eight bits are compared to the low address value in SSPxADD. Even if there is not an address match; SSPxIF and UA are set, and SCL is held low until SSPxADD is updated to receive a high byte again. When SSPxADD is updated the UA bit is cleared. This ensures the module is ready to receive the high address byte on the next communication. A high and low address match as a write request is required at the start of all 10-bit addressing communication. A transmission can be initiated by issuing a Restart once the client is addressed and clocking in the high address with the R/W bit set. The client hardware will then acknowledge the read request and prepare to clock out data. This is only valid for a client after it has received a complete high and low address byte match. ## 29.2.3.2 Clock Stretching Clock stretching occurs when a device on the bus holds the SCL line low, effectively pausing communication. The client may stretch the clock to allow more time to handle data or prepare a response for the host device. A host device is not concerned with stretching as anytime it is active on the bus and not transferring data it is stretching. Any stretching done by a client is invisible to the host software and handled by the hardware that generates SCL. The CKP bit is used to control stretching in software. Any time the CKP bit is cleared, the module will wait for the SCL line to go low and then hold it. Setting CKP will release SCL and allow more communication. #### 29.2.3.2.1 Normal Clock Stretching Following an $\overline{ACK}$ if the R/W bit is set (a read request), the client hardware will clear CKP. This allows the client time to update SSPxBUF with data to transfer to the host. If the Stretch Enable (SEN) bit is set, the client hardware will always stretch the clock after the $\overline{ACK}$ sequence. Once the client is ready; CKP is set by software and communication resumes. #### 29.2.3.2.2 10-Bit Addressing Mode In 10-bit Addressing mode, when the UA bit is set, the clock is always stretched. This is the only time the SCL is stretched without CKP being cleared. SCL is released immediately after a write to SSPxADD. #### 29.2.3.2.3 Byte NACKing When the AHEN bit is set, CKP is cleared by hardware after the eighth falling edge of SCL for a received matching address byte. When the DHEN bit is set, CKP is cleared after the eighth falling edge of SCL for received data. ## **MSSP - Host Synchronous Serial Port Module** Stretching after the eighth falling edge of SCL allows the client to look at the received address or data and decide if it wants to acknowledge (ACK) the received address or data, or not acknowledge (NACK) the address or data. #### 29.2.3.3 Clock Synchronization and the CKP Bit Any time the CKP bit is cleared, the module will wait for the SCL line to go low and then hold it. However, clearing the CKP bit will not assert the SCL output low until the SCL output is already sampled low. Therefore, the CKP bit will not assert the SCL line until an external I<sup>2</sup>C host device has already asserted the SCL line. The SCL output will remain low until the CKP bit is set and all other devices on the I<sup>2</sup>C bus have released SCL. #### 29.2.3.4 General Call Address Support The addressing procedure for the $I^2C$ bus is such that the first byte after the Start condition usually determines which device will be the client addressed by the host device. The exception is the General Call address that can address all devices. When this address is used, all devices must, in theory, respond with an $\overline{ACK}$ . The general call address is a reserved address in the $I^2C$ protocol, defined as address 0x00. When the General Call Enable (GCEN) bit is set, the client module will automatically $\overline{ACK}$ the reception of this address regardless of the value stored in SSPxADD. After the client clocks in an address of all zeros with the $R/\overline{W}$ bit clear, an interrupt is generated and client software can read SSPxBUF and respond. Figure 29-14 shows a General Call reception sequence. Figure 29-14. Client Mode General Call Address Sequence In 10-bit Address mode, the UA bit will not be set on the reception of the general call address. The client will prepare to receive the second byte as data, just as it would in 7-bit mode. If the AHEN bit is set, just as with any other address reception, the client hardware will stretch the clock after the eighth falling edge of SCL. The client must then set its Acknowledge Sequence Enable (ACKEN) bit and release the clock. ### 29.2.3.5 SSP Mask Register The MSSP Mask (SSPxMSK) register is available in I<sup>2</sup>C Client mode as a mask for the value held in the SSPSR register during an address comparison operation. A zero ('0') bit in the SSPxMSK register has the effect of making the corresponding bit of the received address a "don't care". This register is reset to all '1's upon any Reset condition and, therefore, has no effect on standard MSSP operation until written with a mask value. SSPxMSK is active during: - 7-bit Address mode: Address compare of A[7:1] - 10-bit Address mode: Address compare of A[7:0] only. The MSSP mask has no effect during the reception of the first (high) byte of the address. #### 29.2.3.6 Client Reception When the R/ $\overline{W}$ bit of a matching received address byte is clear, the R/ $\overline{W}$ bit is cleared. The received address is loaded into the SSPxBUF register and acknowledged. When the Overflow condition exists for a received address, a Not Acknowledge (NACK) is transmitted and the Receive Overflow Indicator (SSPOV) bit is set. The Buffer Override Enable (BOEN) bit modifies this operation. ## PIC16F18015/25/44/45 ## **MSSP - Host Synchronous Serial Port Module** An MSSP interrupt is generated for each transferred data byte. The SSPxIF flag bit must be cleared by software. When the SEN bit is set, SCL will be held low (clock stretch) following each received byte. The clock must be released by setting the CKP bit, except sometimes in 10-bit mode. See 29.2.3.2.2. 10-Bit Addressing Mode for more details. #### 29.2.3.6.1 7-Bit Addressing Reception This section describes a standard sequence of events for the MSSP module configured as an I<sup>2</sup>C client in 7-bit Addressing mode. Figure 29-15 and Figure 29-16 are used as a visual reference for this description. This is a step by step process of what typically must be done to accomplish I<sup>2</sup>C communication. - 1. Start condition detected. - 2. The Start (S) bit is set; SSPxIF is set if the Start Condition Interrupt Enable (SCIE) bit is set. - 3. Matching address with R/W bit clear is received. - 4. The client pulls SDA low, sending an ACK to the host, and sets SSPxIF bit. - 5. Software clears the SSPxIF bit. - 6. Software reads received address from SSPxBUF, clearing the BF flag. - 7. If SEN = 1; Client software sets the CKP bit to release the SCL line. - 8. The host clocks out a data byte. - 9. Client drives SDA low, sending an ACK to the host, and sets SSPxIF bit. - 10. Software clears SSPxIF. - 11. Software reads the received byte from SSPxBUF, clearing BF. - 12. Steps 8-12 are repeated for all received bytes from the host. - 13. Host sends Stop condition, setting the Stop (P) bit, and the bus goes Idle. Figure 29-15. I<sup>2</sup>C Client, 7-Bit Address, Reception (SEN = 0, AHEN = 0, DHEN = 0) Figure 29-16. I<sup>2</sup>C Client, 7-Bit Address, Reception (SEN = 1, AHEN = 0, DHEN = 0) ### 29.2.3.6.2 7-Bit Reception with AHEN and DHEN Client device reception with AHEN and DHEN set operate the same as without these options with extra interrupts and clock stretching added after the eighth falling edge of SCL. These additional interrupts allow the client software to decide whether it wants to $\overline{\mathsf{ACK}}$ the receive address or data byte, rather than the hardware. This functionality adds support for PMBus<sup>™</sup> that was not present on previous versions of this module. This list describes the steps that need to be taken by client software to use these options for I<sup>2</sup>C communication. Figure 29-17 displays a module using both address and data holding. Figure 29-18 includes the operation with the SEN bit set. - The Start (S) bit is set; SSPxIF is set if SCIE is set. - 2. Matching address with the R/W bit clear is clocked in. SSPxIF is set and CKP cleared after the eighth falling edge of SCL. - 3. Software clears the SSPxIF. - 4. Client can look at the ACKTIM bit to determine if the SSPxIF was after or before the ACK. - 5. Client reads the address value from SSPxBUF, clearing the BF flag. - 6. Client transmits an ACK to the host by clearing ACKDT. - 7. Client releases the clock by setting CKP. - 8. SSPxIF is set after an ACK, not after a NACK. - 9. If SEN = 1, the client hardware will stretch the clock after the $\overline{ACK}$ . - 10. Client clears SSPxIF. **Important:** SSPxIF is still set after the ninth falling edge of SCL even if there is no clock stretching and BF has been cleared. Only if a NACK is sent to the host is SSPxIF not set. - 11. SSPxIF is set and CKP cleared after eighth falling edge of SCL for a received data byte. - 12. Client looks at the ACKTIM bit to determine the source of the interrupt. - 13. Client reads the received data from SSPxBUF, clearing BF. - 14. Steps 7-14 are the same for each received data byte. - 15. Communication is ended by either the client sending a NACK, or the host sending a Stop condition. If a Stop is sent and the Stop Condition Interrupt Enable (PCIE) bit is clear, the client will only know by polling the Stop (P) bit. Figure 29-17. I<sup>2</sup>C Client, 7-Bit Address, Reception (SEN = 0, AHEN = 1, DHEN = 1) Figure 29-18. I<sup>2</sup>C Client, 7-Bit Address, Reception (SEN = 1, AHEN = 1, DHEN = 1) ## 29.2.3.6.3 Client Mode 10-Bit Address Reception This section describes a standard sequence of events for the MSSP module configured as an I<sup>2</sup>C client in 10-bit Addressing mode. Figure 29-19 shows a standard waveform for a client receiver in 10-bit Addressing mode with clock stretching enabled. This is a step-by-step process of what must be done by the client software to accomplish I<sup>2</sup>C communication. - Bus starts Idle. - 2. Host sends Start condition; S bit is set; SSPxIF is set if SCIE is set. - 3. Host sends matching high address with the R/W bit clear; the UA bit is set. - 4. Client sends ACK and SSPxIF is set. - Software clears the SSPxIF bit. - 6. Software reads received address from SSPxBUF, clearing the BF flag. - 7. Client loads low address into SSPxADD, releasing SCL. - 8. Host sends matching low address byte to the client; UA bit is set. Important: Updates to the SSPxADD register are not allowed until after the ACK sequence. Client sends ACK and SSPxIF is set. **Important:** If the low address does not match, SSPxIF and UA are still set so that the client software can set SSPxADD back to the high address. BF is not set because there is no match. CKP is unaffected. - 10. Client clears SSPxIF. - 11. Client reads the received matching address from SSPxBUF, clearing BF. - 12. Client loads high address into SSPxADD. - 13. Host clocks a data byte to the client and clocks out the client ACK on the ninth SCL pulse; SSPxIF is set. - 14. If the SEN bit is set, CKP is cleared by hardware and the clock is stretched. - 15. Client clears SSPxIF. - 16. Client reads the received byte from SSPxBUF, clearing BF. - 17. If SEN is set the client software sets CKP to release the SCL. - 18. Steps 13-17 repeat for each received byte. - 19. Host sends Stop to end the transmission. Figure 29-19. I<sup>2</sup>C Client, 10-Bit Address, Reception (SEN = 1, AHEN = 0, DHEN = 0) # PIC16F18015/25/44/45 # **MSSP - Host Synchronous Serial Port Module** # 29.2.3.6.4 10-Bit Addressing with Address or Data Hold Reception using 10-bit addressing with AHEN or DHEN set is the same as with 7-bit modes. The only difference is the need to update the SSPxADD register using the UA bit. All functionality, specifically when the CKP bit is cleared and SCL line is held low, are the same. Figure 29-20 can be used as a reference of a client in 10-bit addressing with AHEN set. Figure 29-21 shows a standard waveform for a client transmitter in 10-bit Addressing mode. ## 29.2.3.7 Client Transmission When the RW bit of the incoming address byte is set and an address match occurs, the RW bit is set. The received address is loaded into the SSPxBUF register, and an ACK pulse is sent by the client on the ninth bit. Following the $\overline{ACK}$ , client hardware clears the CKP bit and the SCL pin is held low (see 29.2.2.5. Clock Stretching for more details). By stretching the clock, the host will be unable to assert another clock pulse until the client is done preparing the transmit data. The transmit data must be loaded into the SSPxBUF register, which also loads the SSPSR register. Then the SCL pin will be released by setting the CKP bit. The eight data bits are shifted out on the falling edge of the SCL input. This ensures that the SDA signal is valid during the SCL high time. The $\overline{ACK}$ pulse from the host receiver is latched on the rising edge of the ninth SCL input pulse. This $\overline{ACK}$ value is copied to the ACKSTAT bit. If ACKSTAT is set (NACK), then the data transfer is complete. In this case, when the NACK is latched by the client, the client goes Idle and waits for another occurrence of a Start condition. If the SDA line was low ( $\overline{ACK}$ ), the next transmit data must be loaded into the SSPxBUF register. Again, the SCL pin must be released by setting bit CKP. An MSSP interrupt is generated for each data transfer byte. The SSPxIF bit must be cleared by software and the SSPxSTAT register is used to determine the status of the byte. The SSPxIF bit is set on the falling edge of the ninth clock pulse. #### 29.2.3.7.1 Client Mode Bus Collision A client receives a read request and begins shifting data out on the SDA line. If a bus collision is detected and the Client Mode Bus Collision Detect Enable (SBCDE) bit is set, the Bus Collision Interrupt Flag (BCLxIF) bit of the PIRx register is set. Once a bus collision is detected, the client goes Idle and waits to be addressed again. User software can use the BCLxIF bit to handle a client bus collision. #### 29.2.3.7.2 7-Bit Transmission A host device can transmit a read request to a client, and then clock data out of the clien. The list below outlines what software for a client will need to do to accomplish a standard transmission. Figure 29-22 can be used as a reference to this list. - 1. Host sends a Start condition. - 2. The Start (S) bit is set; SSPxIF is set if SCIE is set. - 3. Matching address with R/W bit set is received by the Client, setting SSPxIF bit. - 4. Client hardware generates an ACK and sets SSPxIF. - 5. The SSPxIF bit is cleared by software. - 6. Software reads the received address from SSPxBUF, clearing BF. - 7. R/W is set so CKP was automatically cleared after the ACK. - 8. The client software loads the transmit data into SSPxBUF. - 9. CKP bit is set by software, releasing SCL, allowing the host to clock the data out of the client. - 10. SSPxIF is set after the ACK response from the host is loaded into the ACKSTAT bit. - 11. SSPxIF bit is cleared. - 12. The client software checks the ACKSTAT bit to see if the host wants to clock out more data. ### Important: - 1. If the host $\overline{ACK}$ s then the clock will be stretched. - 2. ACKSTAT is the only bit updated on the rising edge of the ninth SCL clock instead of the falling edge. - 13. Steps 9-13 are repeated for each transmitted byte. - 14. If the host sends a not ACK; the clock is not held, but SSPxIF is still set. - 15. The host sends a Restart condition or a Stop. Figure 29-22. I<sup>2</sup>C Client, 7-Bit Address, Transmission (AHEN = 0) ### 29.2.3.7.3 7-Bit Transmission with Address Hold Enabled Setting the AHEN bit enables additional clock stretching and interrupt generation after the eighth falling edge of a received matching address. Once a matching address has been clocked in, CKP is cleared and the SSPxIF interrupt is set. Figure 29-23 displays a standard waveform of a 7-bit address client transmission with AHEN enabled. - 1. Bus starts Idle. - 2. Host sends Start condition: the S bit is set: SSPxIF is set if SCIE is set. - 3. Host sends matching address with the R/W bit set. After the eighth falling edge of the SCL line the CKP bit is cleared and SSPxIF interrupt is generated. - 4. Client software clears SSPxIF. - Client software reads the ACKTIM, R\overline{W} and D\overline{A} bits to determine the source of the interrupt. - 6. Client reads the address value from the SSPxBUF register, clearing the BF bit. - 7. Client software decides from this information if it wishes to ACK or NACK and sets the ACKDT bit accordingly. - Client software sets the CKP bit, releasing SCL. - Host clocks in the ACK value from the client. - 10. Client hardware automatically clears the CKP bit and sets SSPxIF after $\overline{ACK}$ if the R/W bit is set. - 11. Client software clears SSPxIF. - 12. Client loads value to transmit to the host into SSPxBUF, setting the BF bit. **Important:** SSPxBUF cannot be loaded until after the ACK. - 13. Client software sets the CKP bit, releasing the clock. - 14. Host clocks out the data from the client and sends an ACK value on the ninth SCL pulse. - 15. Client hardware copies the ACK value into the ACKSTAT bit. - 16. Steps 10-15 are repeated for each byte transmitted to the host from the client. - 17. If the host sends a not ACK, the client releases the bus allowing the host to send a Stop and end the communication. **Important:** Host must send a not $\overline{ACK}$ on the last byte to ensure that the client releases the SCL line to receive a Stop. ### 29,2,4 I<sup>2</sup>C Host Mode Host mode is enabled by configuring the appropriate SSPM bits and setting the SSPEN bit. In Host mode, the SDA and SCL pins must be configured as inputs. The MSSP peripheral hardware will override the output driver TRIS controls when necessary to drive the pins low. Host mode of operation is supported by interrupt generation on the detection of the Start and Stop conditions. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the I<sup>2</sup>C bus may be taken when the P bit is set, or the bus is Idle. In Firmware Controlled Host mode, user code conducts all I<sup>2</sup>C bus operations based on Start and Stop condition detection. Start and Stop condition detection is the only active circuitry in this mode. All other communication is done by the user software directly manipulating the SDA and SCL lines. The following events will cause the MSSP Interrupt Flag (SSPxIF) bit to be set (MSSP interrupt, if enabled): - · Start condition detected - · Stop condition detected - Data transfer byte transmitted/received - · Acknowledge transmitted/received - · Repeated Start generated #### Important: - The MSSP module, when configured in I<sup>2</sup>C Host mode, does not allow queuing of events. For instance, the user is not allowed to initiate a Start condition and immediately write the SSPxBUF register to initiate transmission before the Start condition is complete. In this case, SSPxBUF will not be written to and the Write Collision Detect (WCOL) bit will be set, indicating that a write to SSPxBUF did not occur. - Host mode suspends Start/Stop detection when sending the Start/Stop condition by means of the SEN/PEN control bits. The SSPxIF bit is set at the end of the Start/Stop generation when hardware clears the control bit. ## 29.2.4.1 I<sup>2</sup>C Host Mode Operation The host device generates all of the serial clock pulses and the Start and Stop conditions. A transfer is ended with a Stop condition or with a Repeated Start condition. Since the Repeated Start condition is also the beginning of the next serial transfer, the $I^2C$ bus will not be released. In Host Transmitter mode, serial data is output through SDA, while SCL outputs the serial clock. The first byte transmitted contains the client address of the receiving device (seven bits) and the $R\overline{W}$ bit. In this case, the $R\overline{W}$ bit will be logic '0'. Serial data is transmitted eight bits at a time. After each byte is transmitted, an Acknowledge bit is received. Start and Stop conditions are output to indicate the beginning and the end of a serial transfer. In Host Receive mode, the first byte transmitted contains the client address of the transmitting device (seven bits) and the $R/\overline{W}$ bit. In this case, the $R/\overline{W}$ bit will be logic '1'. Thus, the first byte transmitted is a 7-bit client address followed by a '1' to indicate the receive bit. Serial data is received via SDA, while SCL outputs the serial clock. Serial data is received eight bits at a time. After each byte is received, an Acknowledge sequence is transmitted. Start and Stop conditions indicate the beginning and end of transmission. A Baud Rate Generator is used to set the clock frequency output on SCL. See 29.3. Baud Rate Generator for more details. ## 29.2.4.1.1 Clock Arbitration Clock arbitration occurs when the host, during any receive, transmit or Repeated Start/Stop condition, releases the SCL pin (SCL allowed to float high). When the SCL pin is allowed to float high, the Baud Rate Generator (BRG) is suspended from counting until the SCL pin is actually sampled high. When the SCL pin is sampled high, the Baud Rate Generator is reloaded with the contents of SSPxADD and begins counting. This ensures that the SCL high time will always be at least one BRG rollover count in the event that the clock is held low by an external device as shown in Figure 29-24. Figure 29-24. Baud Rate Generator Timing with Clock Arbitration ## 29.2.4.1.2 WCOL Status Flag If the user writes the SSPxBUF when a Start, Restart, Stop, Receive or Transmit sequence is in progress, the Write Collision Detect (WCOL) bit is set and the contents of the buffer are unchanged (the write does not occur). Any time the WCOL bit is set it indicates that an action on SSPxBUF was attempted while the module was not Idle. **Important:** Because queuing of events is not allowed, writing to the lower five bits of SSPxCON2 is disabled until the Start condition is complete. ## 29.2.4.1.3 I<sup>2</sup>C Host Mode Start Condition Timing To initiate a Start condition (see Figure 29-25), the user sets the Start Condition Enable (SEN) bit. If the SDA and SCL pins are sampled high, the Baud Rate Generator is reloaded with the contents of SSPxADD and starts its count. If SCL and SDA are both sampled high when the Baud Rate Generator times out ( $T_{BRG}$ ), the SDA pin is driven low. The action of the SDA being driven low while SCL is high is the Start condition and causes the Start (S) bit to be set. Following this, the Baud Rate Generator is reloaded with the contents of SSPxADD and resumes its count. When the Baud Rate Generator times out ( $T_{BRG}$ ), the SEN bit will be automatically cleared by hardware; the Baud Rate Generator is suspended, leaving the SDA line held low and the Start condition is complete. ### Important: - 1. If at the beginning of the Start condition, the SDA and SCL pins are already sampled low, or if during the Start condition, the SCL line is sampled low before the SDA line is driven low, a bus collision occurs, the Bus Collision Interrupt Flag (BCLxIF) is set, the Start condition is aborted and the I<sup>2</sup>C module is reset into its Idle state. - 2. The Philips I<sup>2</sup>C Specification states that a bus collision cannot occur on a Start. Figure 29-25. First Start Bit Timing # 29.2.4.1.4 I<sup>2</sup>C Host Mode Repeated Start Condition Timing A Repeated Start condition (see Figure 29-26) occurs when the Repeated Start Condition Enable (RSEN) bit is programmed high and the host state machine is Idle. When the RSEN bit is set, the SCL pin is asserted low. When the SCL pin is sampled low, the Baud Rate Generator is loaded and begins counting. The SDA pin is released (brought high) for one Baud Rate Generator count ( $T_{BRG}$ ). When the Baud Rate Generator times out, if SDA is sampled high, the SCL pin will be deasserted (brought high). When SCL is sampled high, the Baud Rate Generator is reloaded and begins counting. SDA and SCL must remain high for one $T_{BRG}$ . Module hardware then pulls the SDA line low (while SCL remains high) for one $T_{BRG}$ , and then pulls the SCL line low. Following this, the RSEN bit will be automatically cleared and the Baud Rate Generator will not be reloaded, leaving the SDA pin held low. As soon as a Start condition is detected on the SDA and SCL pins, the S bit will be set. The SSPxIF bit will not be set until the Baud Rate Generator has timed out. #### Important: - 1. If RSEN is programmed while any other event is in progress, it will not take effect. - 2. A bus collision during the Repeated Start condition occurs if: - SDA is sampled low when SCL goes from low-to-high. - SCL goes low before SDA is asserted low. This may indicate that another host is attempting to transmit a data '1'. Figure 29-26. Repeated Start Condition Waveform ### 29.2.4.1.5 Acknowledge Sequence Timing An Acknowledge sequence (see Figure 29-27) is enabled by setting the Acknowledge Sequence Enable (ACKEN) bit. When this bit is set, the SCL pin is pulled low and the contents of the Acknowledge Data (ACKDT) bit are presented on the SDA pin. If the user wishes to generate an Acknowledge, then the ACKDT bit must be cleared. If not, the user must set the ACKDT bit before starting an Acknowledge sequence. The Baud Rate Generator then counts for one rollover period ( $T_{BRG}$ ) and the SCL pin is deasserted (pulled high). When the SCL pin is sampled high (clock arbitration), the Baud Rate Generator counts for $T_{BRG}$ . The SCL pin is then pulled low. Following this, the ACKEN bit is automatically cleared, the Baud Rate Generator is turned off and the MSSP module then goes into Idle mode. Figure 29-27. Acknowledge Sequence Waveform Note: TBRG = one Baud Rate Generator period. ### Acknowledge Write Collision If the user writes the SSPxBUF when an Acknowledge sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur). # 29.2.4.1.6 Stop Condition Timing A Stop condition (see Figure 29-28) is asserted on the SDA pin at the end of a receive/transmit by setting the Stop Condition Enable (PEN) bit. At the end of a receive/transmit, the SCL line is held low after the falling edge of the ninth clock. When the PEN bit is set, the host will assert the SDA line low. When the SDA line is sampled low, the Baud Rate Generator is reloaded and counts down to '0'. When the Baud Rate Generator times out, the SCL pin will be brought high and one $T_{BRG}$ (Baud Rate Generator rollover count) later, the SDA pin will be deasserted. When the SDA pin is sampled high while SCL is high, the P bit is set. One $T_{BRG}$ later, the PEN bit is cleared and the SSPxIF bit is set. Figure 29-28. Stop Condition in Receive or Transmit Mode ### Write Collision on Stop If the user writes the SSPxBUF when a Stop sequence is in progress, then the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur). #### 29.2.4.1.7 Sleep Operation While in Sleep mode, the I<sup>2</sup>C client module can receive addresses or data and when an address match or complete byte transfer occurs, wake the processor from Sleep (if the MSSP interrupt is enabled). #### 29.2.4.1.8 Effects of a Reset A Reset disables the MSSP module and terminates the current transfer. #### 29.2.4.2 I<sup>2</sup>C Host Mode Transmission Transmission of a data byte, a 7-bit address or the other half of a 10-bit address is accomplished by simply writing a value to the SSPxBUF register. This action will set the Buffer Full Status (BF) bit and allow the Baud Rate Generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDA pin after the falling edge of SCL is asserted. SCL is held low for one Baud Rate Generator rollover count ( $T_{BRG}$ ). Data must be valid before SCL is released high. When the SCL pin is released high, it is held that way for $T_{BRG}$ . The data on the SDA pin must remain stable for that duration and some hold time after the next falling edge of SCL. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the host releases SDA. This allows the client device being addressed to respond with an $\overline{ACK}$ sequence during the ninth bit time if an address match occurred, or if data was received properly. The status of $\overline{ACK}$ is written into the Acknowledge Status (ACKSTAT) bit on the rising edge of the ninth clock. If the host receives an $\overline{ACK}$ , the ACKSTAT bit is cleared. If a NACK is received, ACKSTAT is set. After the ninth clock, the SSPxIF bit is set and the host clock (Baud Rate Generator) is suspended until the next data byte is loaded into the SSPxBUF, leaving SCL low and SDA unchanged (see Figure 29-29). After the write to the SSPxBUF, each bit of the address will be shifted out on the falling edge of SCL until all seven address bits and the $R/\overline{W}$ bit are completed. On the falling edge of the eighth clock, the host will release the SDA pin, allowing the client to respond with an $\overline{ACK}$ . On the falling edge of the ninth clock, the host will sample the SDA pin to see if the address was recognized by a client. The status of the $\overline{ACK}$ bit is loaded into the ACKSTAT bit. Following the falling edge of the ninth clock transmission of the address, the SSPxIF is set, the BF flag is cleared and the Baud Rate Generator is turned off until another write to the SSPxBUF takes place, holding SCL low and allowing SDA to float. #### 29.2.4.2.1 BF Status Flag In Transmit mode, the Buffer Full Status (BF) bit is set when the CPU writes to SSPxBUF, and is cleared when all eight bits are shifted out. #### 29.2.4.2.2 WCOL Status Flag If the user writes the SSPxBUF when a transmit is already in progress (i.e., SSPSR is still shifting out a data byte), the Write Collision Detect (WCOL) bit is set and the contents of the buffer are unchanged (the write does not occur). The WCOL bit must be cleared by software before the next transmission. #### 29.2.4.2.3 ACKSTAT Status Flag In Transmit mode, the Acknowledge Status (ACKSTAT) bit is cleared when the client has sent an Acknowledge (ACK = 0), and is set when the client issues a NACK. A client sends an ACK when it has recognized its address (including a General Call), or when the client has properly received its data. #### 29.2.4.2.4 Typical Transmit Sequence - 1. The Host generates a Start condition by setting the SEN bit. - 2. SSPxIF is set by hardware on completion of the Start. - 3. SSPxIF is cleared by software. - 4. The MSSP module will wait the required start time before any other operation takes place. - 5. Software loads the SSPxBUF with the client address and the R/W bit. In Host Transmit mode, the R/W value is zero. - Address is shifted out the SDA pin until all eight bits are transmitted. Transmission begins as soon as SSPxBUF is written to. - 7. The MSSP module shifts in the ACK value from the client device and writes its into the ACKSTAT bit. - 8. The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPxIF bit. - 9. Software loads the SSPxBUF with eight bits of data. - 10. Data is shifted out the SDA pin until all eight bits are transmitted. - 11. The MSSP module shifts in the ACK bit from the client device and writes its value into the ACKSTAT bit. - 12. Steps 8-11 are repeated for all transmitted data bytes. - 13. The user generates a Stop or Restart condition by setting the PEN or RSEN bits, respectively. An Interrupt is generated once the Stop/Restart condition is complete. Figure 29-29. I<sup>2</sup>C Host Mode Waveform (Transmission, 7-Bit Address) Figure 29-30. I<sup>2</sup>C Host Mode Waveform (Transmission, 10-Bit Address) # 29.2.4.3 I<sup>2</sup>C Host Mode Reception Host mode reception (see Figure 29-31) is enabled by setting the Receive Enable (RCEN) bit. **Important:** The MSSP module must be in an Idle state before the RCEN bit is set or the RCEN bit will be disregarded. The Baud Rate Generator begins counting and on each rollover, the state of the SCL pin changes (high-to-low/low-to-high) and data is shifted into the SSPxSR. After the falling edge of the eighth clock all the following events occur: - · RCEN is automatically cleared by hardware. - The contents of the SSPxSR are loaded into the SSPxBUF. - · The BF flag bit is set. - The SSPxIF flag bit is set. - The Baud Rate Generator is suspended from counting. - · The SCL pin is held low. The MSSP is now in Idle state awaiting the next command. When the buffer is read by the CPU, the BF flag bit is automatically cleared. The Host can then send an Acknowledge sequence at the end of reception by setting the Acknowledge Sequence Enable (ACKEN) bit. ### 29.2.4.3.1 BF Status Flag In receive operation, the BF bit is set when an address or data byte is loaded into SSPxBUF from SSPSR. It is cleared when the SSPxBUF register is read. ### 29.2.4.3.2 SSPOV Status Flag In receive operation, the SSPOV bit is set when eight bits are received into SSPxSR while the BF flag bit is already set from a previous reception. ## 29.2.4.3.3 WCOL Status Flag If the user writes the SSPxBUF when a receive is already in progress (i.e., SSPxSR is still shifting in a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur). ### 29.2.4.3.4 Typical Receive Sequence - 1. The Host generates a Start condition by setting the SEN bit. - 2. SSPxIF is set by hardware on completion of the Start. - 3. SSPxIF is cleared by software. - 4. Software writes SSPxBUF with the client address to transmit and the R/W bit set. - Address is shifted out the SDA pin until all eight bits are transmitted. Transmission begins as soon as SSPxBUF is written to. - 6. The MSSP module shifts in the ACK value from the client device and writes it into the ACKSTAT bit. - 7. The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPxIF bit. - 8. Software sets the RCEN bit and the host clocks in a byte from the client. - 9. After the eighth falling edge of SCL, SSPxIF and BF are set. - 10. Host clears SSPxIF and reads the received byte from SSPxBUF, which clears BF. - 11. Host clears the ACKDT bit and initiates the ACK sequence by setting the ACKEN bit. - 12. Host's ACK is clocked out to the client and SSPxIF is set. - 13. User clears SSPxIF. - 14. Steps 8-13 are repeated for each received byte from the client. - 15. Host sends a NACK or Stop to end communication. Figure 29-31. I<sup>2</sup>C Host Mode Waveform (Reception, 7-Bit Address) Figure 29-32. I<sup>2</sup>C Host Mode Waveform (Reception, 10-Bit Address) ### 29.2.5 Multi-Host Mode In Multi-Host mode, the interrupt generation on the detection of the Start and Stop conditions allows the determination of when the bus is free. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the $I^2C$ bus may be taken when the P bit is set, or the bus is Idle, with both the S and P bits cleared. When the bus is busy, enabling the MSSP interrupt will generate an interrupt when the Stop condition occurs. In Multi-Host operation, the SDA line must be monitored for arbitration to see if the signal level is the expected output level. This check is performed by hardware with the result placed in the BCLxIF bit. The states where arbitration can be lost are: - · Address Transfer - Data Transfer - A Start Condition - A Repeated Start Condition - · An Acknowledge Condition #### 29.2.5.1 Multi-Host Communication. Bus Collision and Bus Arbitration Multi-Host mode support is achieved by bus arbitration. When the host outputs address/data bits onto the SDA pin, arbitration takes place when the host outputs a '1' on SDA, by letting SDA float high and another host asserts a '0'. When the SCL pin floats high, data may be stable. If the expected data on SDA is a '1' and the data sampled on the SDA pin is '0', then a bus collision has taken place. The host will set the Bus Collision Interrupt Flag (BCLxIF) and reset the I<sup>2</sup>C port to its Idle state (see Figure 29-33). If a transmit was in progress when the bus collision occurred, the transmission is halted, the BF flag is cleared, the SDA and SCL lines are deasserted, and the SSPxBUF can be written to. When software services the bus collision Interrupt Service Routine, and if the $I^2C$ bus is free, software can resume communication by asserting a Start condition. If a Start, Repeated Start, Stop or Acknowledge condition was in progress when the bus collision occurred, the condition is aborted, the SDA and SCL lines are deasserted, and the respective control bits in the SSPxCON2 register are cleared. When software services the bus collision Interrupt Service Routine, and if the I<sup>2</sup>C bus is free, software can resume communication by asserting a Start condition. The host will continue to monitor the SDA and SCL pins. If a Stop condition occurs, the SSPxIF bit will be set. A write to the SSPxBUF will start the transmission of data at the first data bit, regardless of where the transmitter left off when the bus collision occurred. In Multi-Host mode, the interrupt generation on the detection of Start and Stop conditions allows the determination of when the bus is free. Control of the I<sup>2</sup>C bus can be taken when the P bit is set, or the bus is Idle and the S and P bits are cleared. Figure 29-33. Bus Collision Timing for Transmit and Acknowledge # 29.2.5.1.1 Bus Collision During a Start Condition During a Start condition, a bus collision occurs if: - 1. SDA or SCL are sampled low at the beginning of the Start condition (see Figure 29-34). - 2. SCL is sampled low before SDA is asserted low (see Figure 29-35). During a Start condition, both the SDA and the SCL pins are monitored. If the SDA pin is already low, or the SCL pin is already low, then all of the following occur: - the Start condition is aborted, - the BCLxIF flag is set and - the MSSP module is reset to its Idle state (see Figure 29-34). The Start condition begins with the SDA and SCL pins deasserted. When the SDA pin is sampled high, the Baud Rate Generator is loaded and counts down. If the SCL pin is sampled low while SDA is high, a bus collision occurs because it is assumed that another host is attempting to drive a data '1' during the Start condition. Figure 29-35. Bus Collision During Start Condition (SCL = 0) If the SDA pin is sampled low during this count, the BRG is reset and the SDA line is asserted early (see Figure 29-36). If, however, a '1' is sampled on the SDA pin, the SDA pin is asserted low at the end of the BRG count. The Baud Rate Generator is then reloaded and counts down to zero; if the SCL pin is sampled as '0' during this time, a bus collision does not occur. At the end of the BRG count, the SCL pin is asserted low. Figure 29-36. BRG Reset Due to SDA Arbitration During Start Condition **Important:** The reason that a bus collision is not a factor during a Start condition is that no two bus hosts can assert a Start condition at the exact same time. Therefore, one host will always assert SDA before the other. This condition does not cause a bus collision because the two hosts must be allowed to arbitrate the first address following the Start condition. If the address is the same, arbitration must be allowed to continue into the data portion, Repeated Start or Stop conditions. # 29.2.5.1.2 Bus Collision During a Repeated Start Condition During a Repeated Start condition, a bus collision occurs if: - 1. A low level is sampled on SDA when SCL goes from low level to high level (see Figure 29-37). - 2. SCL goes low before SDA is asserted low, indicating that another host is attempting to transmit a data '1' (see Figure 29-38). When the user releases SDA and the pin is allowed to float high, the BRG is loaded with SSPxADD and counts down to zero. The SCL pin is then deasserted and when sampled high, the SDA pin is sampled. If SDA is low, a bus collision has occurred (i.e., another host is attempting to transmit a data '0', see Figure 29-37). If SDA is sampled high, the BRG is reloaded and begins counting. If SDA goes from high-to-low before the BRG times out, no bus collision occurs because no two hosts can assert SDA at exactly the same time. Figure 29-37. Bus Collision During a Repeated Start Condition (Case 1) If SCL goes from high-to-low before the BRG times out and SDA has not already been asserted, a bus collision occurs. In this case, another host is attempting to transmit a data '1' during the Repeated Start condition (see Figure 29-38). If, at the end of the BRG time-out, both SCL and SDA are still high, the SDA pin is driven low and the BRG is reloaded and begins counting. At the end of the count, regardless of the status of the SCL pin, the SCL pin is driven low and the Repeated Start condition is complete. Figure 29-38. Bus Collision During Repeated Start Condition (Case 2) #### 29.2.5.1.3 Bus Collision During a Stop Condition Bus collision occurs during a Stop condition if: - After the SDA pin has been deasserted and allowed to float high, SDA is sampled low after the BRG has timed out (see Figure 29-39). - 2. After the SCL pin is deasserted, SCL is sampled low before SDA goes high (see Figure 29-40). The Stop condition begins with SDA asserted low. When SDA is sampled low, the SCL pin is allowed to float. When the pin is sampled high (clock arbitration), the Baud Rate Generator is loaded with SSPxADD and counts down to zero. After the BRG times out, SDA is sampled. If SDA is sampled low, a bus collision has occurred. This is due to another host attempting to drive a data '0' (see Figure 29-39). If the SCL pin is sampled low before SDA is allowed to float high, a bus collision occurs. This is another case of another host attempting to drive a data '0' (Figure 29-40). Figure 29-39. Bus Collision During a Stop Condition (Case 1) Figure 29-40. Bus Collision During a Stop Condition (Case 2) ## 29.3 Baud Rate Generator The MSSP module has a Baud Rate Generator (BRG) available for clock generation in both I<sup>2</sup>C and SPI Host modes. The BRG reload value is placed in the SSPxADD register. When a write occurs to SSPxBUF, the BRG will automatically begin counting down. Example 29-1 shows how the value for SSPxADD is calculated. Once the given operation is complete, the internal clock will automatically stop counting and the clock pin will remain in its last state. An internal Reload signal, shown in Figure 29-41, triggers the value from SSPxADD to be loaded into the BRG counter. This occurs twice for each oscillation of the module clock line. Table 29-2 illustrates clock rates based on instruction cycles and the BRG value loaded into SSPxADD. Example 29-1. MSSP Baud Rate Generator Frequency Equation $$F_{CLOCK} = \frac{F_{OSC}}{4 \times (SSPxADD + 1)}$$ Figure 29-41. Baud Rate Generator Block Diagram SSPM[3:0] SSPxADD[7:0] SSPM[3:0] Reload Reload Control SSPCLK BRG Down Counter Fosc/2 **Important:** Values of $0 \times 00$ , $0 \times 01$ and $0 \times 02$ are not valid for SSPxADD when used as a Baud Rate Generator for $I^2C$ . This is an implementation limitation. Table 29-2. MSSP Clock Rate w/BRG | Fosc | F <sub>CY</sub> | BRG Value | F <sub>CLOCK</sub><br>(2 Rollovers of BRG) | |--------|-----------------|-----------|--------------------------------------------| | 32 MHz | 8 MHz | 13h | 400 kHz | | 32 MHz | 8 MHz | 19h | 308 kHz | | 32 MHz | 8 MHz | 4Fh | 100 kHz | | 16 MHz | 4 MHz | 09h | 400 kHz | | 16 MHz | 4 MHz | 0Ch | 308 kHz | | 16 MHz | 4 MHz | 27h | 100 kHz | | 4 MHz | 1 MHz | 09h | 100 kHz | **Note:** Refer to the I/O port electrical specifications in the "**Electrical Specifications**" chapter, Internal Oscillator Parameters, to ensure the system is designed to support all requirements. # 29.4 Register Definitions: MSSP Control # 29.4.1 SSPxBUF Name: SSPxBUF Offset: 0x068C,0x0696 MSSP Data Buffer Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|-------|-----|-----|-----| | [ | | | | BUF | [7:0] | | | | | Access | R/W | Reset | X | x | x | x | X | x | X | X | Bits 7:0 - BUF[7:0] MSSP Input and Output Data Buffer bits # 29.4.2 SSPxADD Name: SSPxADD Offset: 0x068D,0x0697 MSSP Baud Rate Divider and Address Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|-----|-------|-----|-----|-----| | | | | | ADD | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bits 7:0 - ADD[7:0] - SPI and I<sup>2</sup>C Host: Baud rate divider - I<sup>2</sup>C Client: Address bits | Value | Mode | Description | |-----------|-----------------------------------|---------------------------------------------------------------------------------------| | 11111111 | SPI and I <sup>2</sup> C Host | Baud rate divider. SCK/SCL pin clock period = ((n + 1) * 4)/F <sub>OSC</sub> . Values | | _ | | less than 3 are not valid. | | 00000011 | | | | xxxxx11x | I <sup>2</sup> C 10-bit Client MS | Bits [7:3] and Bit 0 are not used and are don't care. Bits [2:1] are bits [9:8] | | - | Address | of the 10-bit Client Most Significant Address. | | xxxxx00x | | | | 11111111 | I <sup>2</sup> C 10-bit Client LS | Bits [7:0] of 10-bit Client Least Significant Address | | _ | Address | | | 00000000 | | | | 11111111x | I <sup>2</sup> C 7-bit Client | Bit 0 is not used and is don't care. Bits [7:1] are the 7-bit Client Address. | | - | | | | 0000000x | | | # 29.4.3 SSPxMSK Name: SSPxMSK Offset: 0x068E,0x0698 MSSP Address Mask Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|----------|-----|-----|-----|------| | | | | | MSK[6:0] | | | | MSK0 | | Access | R/W | Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | # Bits 7:1 - MSK[6:0] Mask bits | Value | | Description | |-------|-------------------------|--------------------------------------------------------------------------------------------------| | 1 | I <sup>2</sup> C Client | The received address bit n is compared to SSPxADD bit n to detect I <sup>2</sup> C address match | | 0 | I <sup>2</sup> C Client | The received address bit n is not used to detect I <sup>2</sup> C address match | #### Bit 0 - MSK0 Mask bit for I<sup>2</sup>C 10-bit Client mode | Value | Mode | Description | |-------|--------------------------------|--------------------------------------------------------------------------------------------------| | X | SPI or I <sup>2</sup> C 7-bit | This bit is not used | | 1 | I <sup>2</sup> C 10-bit Client | The received address bit 0 is compared to SSPxADD bit 0 to detect I <sup>2</sup> C address match | | 0 | I <sup>2</sup> C 10-bit Client | The received address bit 0 is not used to detect I <sup>2</sup> C address match | # 29.4.4 SSPxSTAT Name: SSPxSTAT 0x068F,0x0699 MSSP Status Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|---|---|-----|----|----| | | SMP | CKE | D/Ā | Р | S | R/W | UA | BF | | Access | R/W | R/W | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - SMP Slew Rate Control bit | Value | Mode | Description | |-------|------------------|---------------------------------------------------------------------------| | 1 | SPI Host | Input data is sampled at the end of data output time | | 0 | SPI Host | Input data is sampled at the middle of data output time | | 0 | SPI Client | Bit must be cleared in SPI Client mode | | 1 | I <sup>2</sup> C | Slew rate control is disabled for Standard Speed mode (100 kHz and 1 MHz) | | 0 | I <sup>2</sup> C | Slew rate control is enabled for High Speed mode (400 kHz) | # Bit 6 - CKE SPI: Clock Select bit<sup>(4)</sup>; I<sup>2</sup>C: SMBus Select bit | Value | Mode | Description | |-------|------------------|-------------------------------------------------------------------| | 1 | SPI | Transmit occurs on the transition from Active to Idle clock state | | 0 | SPI | Transmit occurs on the transition from Idle to Active clock state | | 1 | I <sup>2</sup> C | Enables SMBus-specific inputs | | 0 | I <sup>2</sup> C | Disables SMBus-specific inputs | # Bit 5 - D/A Data/Address bit | Value | Mode | Description | |-------|------------------------------|------------------------------------------------------------------| | Х | SPI or I <sup>2</sup> C Host | This bit is not used | | 1 | I <sup>2</sup> C Client | Indicates that the last byte received or transmitted was data | | 0 | I <sup>2</sup> C Client | Indicates that the last byte received or transmitted was address | # Bit 4 - P Stop bit(1) | Value | Mode | Description | |-------|------------------|--------------------------------| | X | SPI | This bit is not used | | 1 | I <sup>2</sup> C | Stop bit was detected last | | 0 | I <sup>2</sup> C | Stop bit was not detected last | # Bit 3 - S Start bit(1) | Value | Mode | Description | |-------|------------------|---------------------------------| | X | SPI | This bit is not used | | 1 | I <sup>2</sup> C | Start bit was detected last | | 0 | I <sup>2</sup> C | Start bit was not detected last | # Bit 2 - R/W Read/Write Information bit(2,3) | Value | Mode | Description | |-------|-------------------------|-----------------------------| | Х | SPI | This bit is not used | | 1 | I <sup>2</sup> C Client | Read | | 0 | I <sup>2</sup> C Client | Write | | 1 | I <sup>2</sup> C Host | Transmit is in progress | | 0 | I <sup>2</sup> C Host | Transmit is not in progress | # Bit 1 – UA Update Address bit (10-bit I<sup>2</sup>C Client mode only) | Value | Mode | Description | | |-------|-----------------|----------------------|--| | X | All other modes | This bit is not used | | | Value | Mode | Description | |-------|--------------------------------|-----------------------------------------------------------------------------| | 1 | I <sup>2</sup> C 10-bit Client | Indicates that the user needs to update the address in the SSPxADD register | | 0 | I <sup>2</sup> C 10-bit Client | Address does not need to be updated | # Bit 0 - BF Buffer Full Status bit(5) | Value | Mode | Description | |-------|----------------------------------|----------------------------------------| | 1 | I <sup>2</sup> C Transmit | Transmit in progress, SSPxBUF is full | | 0 | I <sup>2</sup> C Transmit | Transmit complete; SSPxBUF is empty | | 1 | SPI and I <sup>2</sup> C Receive | Receive complete, SSPxBUF is full | | 0 | SPI and I <sup>2</sup> C Receive | Receive not complete, SSPxBUF is empty | #### Notes: - 1. This bit is cleared on Reset and when SSPEN is cleared. - 2. In I<sup>2</sup>C Client mode, this bit holds the R/W bit information following the last address match. This bit is only valid from the address match to the next Start bit, Stop bit or not ACK bit. - 3. ORing this bit with SEN, RSEN, PEN, RCEN or ACKEN will indicate if the MSSP is in Active mode. - 4. Polarity of clock state is set by the CKP bit. - 5. I<sup>2</sup>C receive status does not include ACK and Stop bits. # 29.4.5 SSPxCON1 **Name:** SSPxCON1 **Offset:** 0x0690,0x069A MSSP Control Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|-------|-----|-----|------|----------------|-----| | | WCOL | SSPOV | SSPEN | CKP | | SSPN | <b>Л</b> [3:0] | | | Access | R/W/HS | R/W/HS | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ### Bit 7 - WCOL Write Collision Detect bit | Value | Mode | Description | |-------|-------------------------------------------------|--------------------------------------------------------------------| | X | Host or Client receive | This bit is not used | | 1 | SPI or I <sup>2</sup> C Host or Client transmit | The SSPxBUF register is written while it is still transmitting the | | | | previous word (must be cleared in software) | | 0 | SPI or I <sup>2</sup> C Host or Client transmit | No collision | # Bit 6 - SSPOV Receive Overflow Indicator bit(1) | Value | Mode | Description | |-------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Х | SPI Host or I <sup>2</sup> C Host transmit | This bit is not used | | 1 | SPI Client | A byte is received while the SSPxBUF register is still holding the previous byte. Data contained in the shift register will be discarded. The user must read SSPxBUF, even if only transmitting data, to avoid setting overflow (must be cleared in software). | | 1 | I <sup>2</sup> C Receive | A byte is received while the SSPxBUF register is still holding the previous byte (must be cleared in software) | | 0 | SPI Client or I <sup>2</sup> C<br>Receive | No overflow | #### Bit 5 - SSPEN Host Synchronous Serial Port Enable bit.(2) | Valu | ıe | Description | |------|----|-----------------------------------------------------------------| | 1 | | Enables the serial port | | 0 | | Disables serial port and configures these pins as I/O PORT pins | ### Bit 4 - CKP SCK Release Control bit | Value | Mode | Description | |-------|-------------------------|-----------------------------------------------------------------| | X | I <sup>2</sup> C Host | This bit is not used | | 1 | SPI | Idle state for the clock is a high level | | 0 | SPI | Idle state for the clock is a low level | | 1 | I <sup>2</sup> C Client | Releases clock | | 0 | I <sup>2</sup> C Client | Holds clock low (clock stretch), used to ensure data setup time | # Bits 3:0 - SSPM[3:0] Host Synchronous Serial Port Mode Select bits<sup>(4)</sup> | Value | Description | |-------|-----------------------------------------------------------------------------------------| | 1111 | I <sup>2</sup> C Client mode: 10-bit address with Start and Stop bit interrupts enabled | | 1110 | I <sup>2</sup> C Client mode: 7-bit address with Start and Stop bit interrupts enabled | | 1101 | Reserved - do not use | | 1100 | Reserved - do not use | | 1011 | I <sup>2</sup> C Firmware Controlled Host mode (client Idle) | | Value | Description | |-------|----------------------------------------------------------------------------------------------------------| | 1010 | SPI Host mode: Clock = F <sub>OSC</sub> /(4*(SSPxADD+1)). SSPxADD must be greater than 0. <sup>(3)</sup> | | 1001 | Reserved - do not use | | 1000 | I <sup>2</sup> C Host mode: Clock = F <sub>OSC</sub> /(4 * (SSPxADD + 1)) | | 0111 | I <sup>2</sup> C Client mode: 10-bit address | | 0110 | I <sup>2</sup> C Client mode: 7-bit address | | 0101 | SPI Client mode: Clock = SCKx pin. SSx pin control is disabled | | 0100 | SPI Client mode: Clock = SCKx pin. SSx pin control is enabled | | 0011 | SPI Host mode: Clock = TMR2 output/2 | | 0010 | SPI Host mode: Clock = F <sub>OSC</sub> /64 | | 0001 | SPI Host mode: Clock = F <sub>OSC</sub> /16 | | 0000 | SPI Host mode: Clock = F <sub>OSC</sub> /4 | ### Notes: - 1. In Host mode, the overflow bit is not set since each new reception (and transmission) is initiated by writing to the SSPxBUF register. - 2. When enabled, these pins must be properly configured as inputs or outputs. - 3. SSPxADD = 0 is not supported. - 4. Bit combinations not specifically listed here are either reserved or implemented in I<sup>2</sup>C mode only. ### 29,4,6 SSPxCON2 Name: SSPxCON2 Offset: 0x0691,0x069B MSSP Control Register 2 Control Register for I<sup>2</sup>C Operation Only | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|---------|-------|-------|------|-----|------|-----| | | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | Access | R/W | R/W/HC | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - GCEN General Call Enable bit (Client mode only) | Value | Mode | Description | |-------|-------------|-----------------------------| | X | Host mode | Don't care | | 1 | Client mode | General Call is enabled | | 0 | Client mode | General Call is not enabled | ### Bit 6 – ACKSTAT Acknowledge Status bit (Host Transmit mode only) | Value | Description | |-------|------------------------------------------| | 1 | Acknowledge was not received from client | | 0 | Acknowledge was received from client | ### Bit 5 - ACKDT Acknowledge Data bit (Host Receive mode only)(1) | Value | Description | | | |-------|-----------------|--|--| | 1 | Not Acknowledge | | | | 0 | Acknowledge | | | ### Bit 4 - ACKEN Acknowledge Sequence Enable bit(2) | ACKITOWIC | Acknowledge dequence Enable bit. | | | | | |-----------|------------------------------------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Initiates Acknowledge sequence on SDAx and SCLx pins and transmits ACKDT data bit; | | | | | | | automatically cleared by hardware | | | | | | 0 | Acknowledge sequence is Idle | | | | | ### Bit 3 - RCEN Receive Enable bit (Host Receive mode only)(2) | Value | Description | |-------|-------------------------------------------| | 1 | Enables Receive mode for I <sup>2</sup> C | | 0 | Receive is Idle | # Bit 2 – PEN Stop Condition Enable bit (Host mode only)(2) | | Value | Description | |---|-------|-----------------------------------------------------------------------------------| | | 1 | Initiates Stop condition on SDAx and SCLx pins; automatically cleared by hardware | | Ì | 0 | Stop condition is Idle | ### Bit 1 - RSEN Repeated Start Condition Enable bit (Host mode only)(2) | Value | Description | |-------|---------------------------------------------------------------------------------------------| | 1 | Initiates Repeated Start condition on SDAx and SCLx pins; automatically cleared by hardware | | 0 | Repeated Start condition is Idle | # **MSSP - Host Synchronous Serial Port Module** # Bit 0 - SEN Start Condition Enable bit(2) | Value | Mode | Description | |-------|--------|------------------------------------------------------------------------------------| | 1 | Host | Initiates Start condition on SDAx and SCLx pins; automatically cleared by hardware | | 0 | Host | Start condition is Idle | | 1 | Client | Clock stretching is enabled | | 0 | Client | Clock stretching is disabled | #### Notes: - 1. The value that will be transmitted when the user initiates an Acknowledge sequence at the end of a receive. - 2. If the I<sup>2</sup>C module is active, these bits may not be set (no spooling) and the SSPxBUF may not be written (or writes to the SSPxBUF are disabled). # 29.4.7 SSPxCON3 Name: SSPxCON3 Offset: 0x0692,0x069C MSSP Control Register 3 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|---------|------|------|------|-------|-------|------|------| | | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | Access | R/HS/HC | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - ACKTIM Acknowledge Time Status bit | | neumentouge rime etaitae an | | | | | | |-------|--------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--| | Value | Mode | Description | | | | | | X | SPI or I <sup>2</sup> C Host | This bit is not used | | | | | | 1 | I <sup>2</sup> C Client and AHEN = 1 or DHEN = 1 | Eighth falling edge of SCL has occurred and the ACK/NACK state is Active | | | | | | 0 | I <sup>2</sup> C Client | ACK/NACK state is not Active. Transitions low on ninth rising edge of SCL. | | | | | ### Bit 6 - PCIE Stop Condition Interrupt Enable bit | Value | Mode | Description | |-------|-----------------------------|-------------------------------------------------| | X | SPI or SSPM = 1111 or 1110 | This bit is not used | | 1 | SSPM ≠ 1111 and SSPM ≠ 1110 | Enable interrupt on detection of Stop condition | | 0 | SSPM ≠ 1111 and SSPM ≠ 1110 | Stop detection interrupts are disabled | ### Bit 5 - SCIE Start Condition Interrupt Enable bit | Value | Mode | Description | |-------|-----------------------------|--------------------------------------------------| | X | SPI or SSPM = 1111 or 1110 | This bit is not used | | 1 | SSPM ≠ 1111 and SSPM ≠ 1110 | Enable interrupt on detection of Start condition | | 0 | SSPM ≠ 1111 and SSPM ≠ 1110 | Start detection interrupts are disabled | ### Bit 4 – BOEN Buffer Overwrite Enable bit(1) | Value | Mode | Description | |-------|------------------|--------------------------------------------------------------------------------------------------------------| | 1 | SPI | SSPxBUF is updated every time a new data byte is available, ignoring the BF bit | | 0 | SPI | If a new byte is receive with BF set then SSPOV is set and SSPxBUF is not updated | | 1 | I <sup>2</sup> C | SSPxBUF is updated every time a new data byte is available, ignoring the SSPOV effect on updating the buffer | | 0 | I <sup>2</sup> C | SSPxBUF is only updated when SSPOV is clear | # Bit 3 - SDAHT SDA Hold Time Selection bit | Value | Mode | Description | |-------|------------------|------------------------------------------------------------------| | X | SPI | Not used in SPI mode | | 1 | I <sup>2</sup> C | Minimum of 300 ns hold time on SDA after the falling edge of SCL | | 0 | I <sup>2</sup> C | Minimum of 100 ns hold time on SDA after the falling edge of SCL | # Bit 2 - SBCDE Client Mode Bus Collision Detect Enable bit Unused in Host mode. | 011400411 | | | |-----------|------------------------------|----------------------------------------| | Value | Mode | Description | | X | SPI or I <sup>2</sup> C Host | This bit is not used | | 1 | I <sup>2</sup> C Client | Bus Collision detection is enabled | | 0 | I <sup>2</sup> C Client | Bus Collision detection is not enabled | # **MSSP - Host Synchronous Serial Port Module** # Bit 1 - AHEN Address Hold Enable bit | Value | Mode | Description | |-------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Х | SPI or I <sup>2</sup> C Host | This bit is not used | | 1 | I <sup>2</sup> C Client | Address hold is enabled. As a result, CKP is cleared after the eighth falling SCL edge of an address byte reception. Software must set the CKP bit to resume operation. | | 0 | I <sup>2</sup> C Client | Address hold is not enabled | ### Bit 0 - DHEN Data Hold Enable bit | Value | Mode | Description | |-------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------| | x | SPI or I <sup>2</sup> C Host | This bit is not used | | 1 | I <sup>2</sup> C Client | Data hold is enabled. As a result, CKP is cleared after the eighth falling SCL edge of a data byte reception. Software must set the CKP bit to resume operation. | | 0 | I <sup>2</sup> C Client | Data hold is not enabled | #### Note: 1. For daisy-chained SPI operation; allows the user to ignore all except the last received byte. SSPOV is still set when a new byte is received and BF = 1, but hardware continues to write the most recent byte to SSPxBUF. # 29.5 Register Summary - MSSP Control | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----------|----------|--------|---------|-------|----------|--------|-------|--------|------| | 0x00 | | | | | | | | | | | | <br>0x068B | Reserved | | | | | | | | | | | 0x068C | SSP1BUF | 7:0 | | | | BUF | [7:0] | | | | | 0x068D | SSP1ADD | 7:0 | | | | | 0[7:0] | | | | | 0x068E | SSP1MSK | 7:0 | | | | MSK[6:0] | | | | MSK0 | | 0x068F | SSP1STAT | 7:0 | SMP | CKE | D/Ā | Р | s | R/W | UA | BF | | 0x0690 | SSP1CON1 | 7:0 | WCOL | SSPOV | SSPEN | CKP | | SSPI | M[3:0] | Į. | | 0x0691 | SSP1CON2 | 7:0 | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x0692 | SSP1CON3 | 7:0 | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 0x0693 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x0695 | | | | | | | | | | | | 0x0696 | SSP2BUF | 7:0 | | | | BUF | [7:0] | | | | | 0x0697 | SSP2ADD | 7:0 | | | | ADD | [7:0] | | | | | 0x0698 | SSP2MSK | 7:0 | | | | MSK[6:0] | | | | MSK0 | | 0x0699 | SSP2STAT | 7:0 | SMP | CKE | D/Ā | Р | S | R/W | UA | BF | | 0x069A | SSP2CON1 | 7:0 | WCOL | SSPOV | SSPEN | CKP | | SSPI | M[3:0] | | | 0x069B | SSP2CON2 | 7:0 | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x069C | SSP2CON3 | 7:0 | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | # 30. EUSART - Enhanced Universal Synchronous Asynchronous Receiver Transmitter The Enhanced Universal Synchronous Asynchronous Receiver Transmitter (EUSART) module is a serial I/O communications peripheral. It contains all the clock generators, shift registers and data buffers necessary to perform an input or output serial data transfer independent of device program execution. The EUSART, also known as a Serial Communications Interface (SCI), can be configured as a full-duplex asynchronous system or half-duplex synchronous system. Full Duplex mode is useful for communications with peripheral systems, such as CRT terminals and personal computers. Half Duplex Synchronous mode is intended for communications with peripheral devices, such as A/D or D/A integrated circuits, serial EEPROMs or other microcontrollers. These devices typically do not have internal clocks for baud rate generation and require the external clock signal provided by a host synchronous device. The EUSART module includes the following capabilities: - Full-duplex asynchronous transmit and receive - · Two-character input buffer - · One-character output buffer - Programmable 8-bit or 9-bit character length - · Address detection in 9-bit mode - · Input buffer overrun error detection - · Received character framing error detection - Half-duplex synchronous host - Half-duplex synchronous client - · Programmable clock polarity in Synchronous modes - Sleep operation The EUSART module implements the following additional features, making it ideally suited for use in Local Interconnect Network (LIN) bus systems: - · Automatic detection and calibration of the baud rate - Wake-up on Break reception - · 13-bit Break character transmit Block diagrams of the EUSART transmitter and receiver are shown in Figure 30-1 and Figure 30-2. The operation of the EUSART module consists of six registers: - · Transmit Status and Control (TXxSTA) - · Receive Status and Control (RCxSTA) - Baud Rate Control (BAUDxCON) - · Baud Rate Value (SPxBRG) - Receive Data Register (RCxREG) - Transmit Data Register (TXxREG) The RXx/DTx and TXx/CKx input pins are selected with the RXxPPS and TXxPPS registers, respectively. TXx, CKx, and DTx output pins are selected with each pin's RxyPPS register. Since the RX input is coupled with the DT output in Synchronous mode, it is the user's responsibility to select the same pin for both of these functions when operating in Synchronous mode. The EUSART control logic will control the data direction drivers automatically. Figure 30-1. EUSART Transmit Block Diagram Rev. 10-000 113C 2/15/201 7 **Notes:** 1. In Synchronous mode, the DT output and RX input PPS selections will enable the same pin. <sup>2.</sup> In Host Synchronous mode, the TX output and CK input PPS selections will enable the same pin. Figure 30-2. EUSART Receive Block Diagram Notes: 1. In Synchronous mode, the DT output and RX input PPS selections will enable the same pin. 2. In Host Synchronous mode, the TX output and CK input PPS selections will enable the same pin. # 30.1 EUSART Asynchronous Mode The EUSART transmits and receives data using the standard non-return-to-zero (NRZ) format. NRZ is implemented with two levels: a $V_{OH}$ Mark state which represents a '1' data bit, and a $V_{OL}$ Space state which represents a '0' data bit. NRZ refers to the fact that consecutively transmitted data bits of the same value stay at the output level of that bit without returning to a neutral level between each bit transmission. An NRZ transmission port idles in the Mark state. Each character transmission consists of one Start bit followed by eight or nine data bits and is always terminated by one or more Stop bits. The Start bit is always a space and the Stop bits are always marks. The most common data format is eight bits. Each transmitted bit persists for a period of 1/(Baud Rate). An on-chip dedicated 8-bit/16-bit Baud Rate Generator is used to derive standard baud rate frequencies from the system oscillator. See Table 30-2 for examples of baud rate configurations. The EUSART transmits and receives the LSb first. The EUSART's transmitter and receiver are functionally independent, but share the same data format and baud rate. Parity is not supported by the hardware, but can be implemented in software and stored as the ninth data bit. # 30.1.1 EUSART Asynchronous Transmitter Figure 30-1 is a simplified representation of the transmitter. The heart of the transmitter is the serial Transmit Shift Register (TSR), which is not directly accessible by software. The TSR obtains its data from the transmit buffer, which is the TXxREG register. ### 30.1.1.1 Enabling the Transmitter The EUSART transmitter is enabled for asynchronous operations by configuring the following three control bits: - The Transmit Enable (TXEN) bit is set to '1' to enable the transmitter circuitry of the EUSART - The EUSART Mode Select (SYNC) bit is set to '0' to configure the EUSART for asynchronous operation • The Serial Port Enable (SPEN) bit is set to '1' to enable the EUSART interface and to enable automatically the output drivers for the RxyPPS selected as the TXx/CKx output All other EUSART control bits are assumed to be in their default state. If the TXx/CKx pin is shared with an analog peripheral, the analog I/O function must be disabled by clearing the corresponding ANSEL bit. **Important:** The TXxIF Transmitter Interrupt Flag in the PIRx register is set when the TXEN enable bit is set and the Transmit Shift Register (TSR) is Idle. ### 30.1.1.2 Transmitting Data A transmission is initiated by writing a character to the TXxREG register. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TXxREG is immediately transferred to the TSR register. If the TSR still contains all or part of a previous character, the new character data is held in the TXxREG until the Stop bit of the previous character has been transmitted. The pending character in the TXxREG is then transferred to the TSR in one $T_{CY}$ immediately following the Stop bit transmission. The transmission of the Start bit, data bits and Stop bit sequence commences immediately following the transfer of the data to the TSR from the TXxREG. ### 30.1.1.3 Transmit Data Polarity The polarity of the transmit data can be controlled with the Clock/Transmit Polarity Select (SCKP) bit. The default state of this bit is '0', which selects high true transmit Idle and data bits. Setting the SCKP bit to '1' will invert the transmit data resulting in low true Idle and data bits. The SCKP bit controls transmit data polarity in Asynchronous mode only. In Synchronous mode, the SCKP bit has a different function. See 30.4.1.2. Clock Polarity for more details. # 30.1.1.4 Transmit Interrupt Flag The EUSART Transmit Interrupt Flag (TXxIF) bit of the PIRx register is set whenever the EUSART transmitter is enabled and no character is being held for transmission in the TXxREG. In other words, the TXxIF bit is only cleared when the TSR is busy with a character and a new character has been queued for transmission in the TXxREG. The TXxIF flag bit is not cleared immediately upon writing TXxREG. TXxIF becomes valid in the second instruction cycle following the write execution. Polling TXxIF immediately following the TXxREG write will return invalid results. The TXxIF bit is read-only, it cannot be set or cleared by software. The TXxIF interrupt can be enabled by setting the EUSART Transmit Interrupt Enable (TXxIE) bit of the PIEx register. However, the TXxIF flag bit will be set whenever the TXxREG is empty, regardless of the state of TXxIE enable bit. To use interrupts when transmitting data, set the TXxIE bit only when there is more data to send. Clear the TXxIE interrupt enable bit upon writing the last character of the transmission to the TXxREG. # 30.1.1.5 TSR Status The Transmit Shift Register Status (TRMT) bit indicates the status of the TSR register. This is a read-only bit. The TRMT bit is set when the TSR register is empty and is cleared when a character is transferred to the TSR register from the TXxREG. The TRMT bit remains clear until all bits have been shifted out of the TSR register. No interrupt logic is tied to this bit, so the user needs to poll this bit to determine the TSR status. Important: The TSR register is not mapped in data memory, so it is not available to the user. ### 30.1.1.6 Transmitting 9-Bit Characters The EUSART supports 9-bit character transmissions. When the 9-Bit Transmit Enable (TX9) bit is set, the EUSART will shift nine bits out for each character transmitted. The TX9D bit is the ninth and Most Significant data bit. When transmitting 9-bit data, the TX9D data bit must be written before writing the eight Least Significant bits into the TXxREG. All nine bits of data will be transferred to the TSR register immediately after the TXxREG is written. A special 9-bit Address mode is available for use with multiple receivers. See 30.1.2.7. Address Detection for more information on the Address mode. #### 30.1.1.7 Asynchronous Transmission Setup - 1. Initialize the SPxBRGH:SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see 30.3. EUSART Baud Rate Generator (BRG)). - 2. Select the transmit output pin by writing the appropriate value to the RxyPPS register. - 3. Enable the asynchronous serial port by clearing the SYNC bit and setting the SPEN bit. - 4. If 9-bit transmission is desired, set the TX9 control bit. That will indicate that the eight Least Significant data bits are an address when the receiver is set for address detection. - Set SCKP bit if inverted transmit is desired. - 6. Enable the transmission by setting the TXEN control bit. This will cause the TXxIF interrupt bit to be set. - 7. If interrupts are desired, set the TXxIE interrupt enable bit of the PIEx register. - 8. An interrupt will occur immediately provided that the GIE and PEIE bits of the INTCON register are also set. - 9. If 9-bit transmission is selected, the ninth bit will be loaded into the TX9D data bit. - 10. Load 8-bit data into the TXxREG register. This will start the transmission. Figure 30-3. Asynchronous Transmission Figure 30-4. Asynchronous Transmission (Back-to-Back) ### 30.1.2 EUSART Asynchronous Receiver The Asynchronous mode is typically used in RS-232 systems. A simplified representation of the receiver is shown in Figure 30-2. The data is received on the RXx/DTx pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all eight or nine bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCxREG register. #### 30.1.2.1 Enabling the Receiver The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits: - The Continuous Receive Enable (CREN) bit is set to '1' to enables the receiver circuitry of the EUSART - The EUSART Mode Select (SYNC) bit is set to '0' to configure the EUSART for asynchronous operation - The Serial Port Enable (SPEN) bit is set to '1' to enable the EUSART interface All other EUSART control bits are assumed to be in their default state. The user must set the RXxPPS register to select the RXx/DTx I/O pin and set the corresponding TRIS bit to configure the pin as an input. **Important:** If the RX/DT function is on an analog pin, the corresponding ANSEL bit must be cleared for the receiver to function. ### 30.1.2.2 Receiving Data The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero, then the data recovery circuit aborts character reception without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds, then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position, then a framing error is set for this character, otherwise the framing error is cleared for this character. See 30.1.2.4. Receive Framing Error for more information on framing errors. Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO, and the EUSART Receive Interrupt Flag (RCxIF) bit of the PIRx register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCxREG register. **Important:** If the receive FIFO is overrun, no additional characters will be received until the Overrun condition is cleared. See 30.1.2.4. Receive Framing Error for more information. # 30.1.2.3 Receive Interrupts The EUSART Receive Interrupt Flag (RCxIF) bit of the PIRx register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCxIF Interrupt Flag bit is read-only, it cannot be set or cleared by software. RCxIF interrupts are enabled by setting all of the following bits: - · RCxIE, Interrupt Enable bit of the PIEx register - · PEIE, Peripheral Interrupt Enable bit of the INTCON register - · GIE, Global Interrupt Enable bit of the INTCON register The RCxIF Interrupt Flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits. ### 30.1.2.4 Receive Framing Error Each character in the receive FIFO buffer has a corresponding framing error Status bit. A framing error indicates that a Stop bit was not seen at the expected time. The framing error status is accessed via the Framing Error (FERR) bit. The FERR bit represents the status of the top unread character in the receive FIFO. Therefore, the FERR bit must be read before reading the RCxREG register. The FERR bit is read-only and only applies to the top unread character in the receive FIFO. A framing error (FERR = 1) does not preclude reception of additional characters. It is not necessary to clear the FERR bit. Reading the next character from the FIFO buffer will advance the FIFO to the next character and the next corresponding framing error. The FERR bit can be forced clear by clearing the SPEN bit, which resets the EUSART. Clearing the CREN bit does not affect the FERR bit. A framing error by itself does not generate an interrupt. **Important:** If all receive characters in the receive FIFO have framing errors, repeated reads of the RCxREG register will not clear the FERR bit. #### 30.1.2.5 Receive Overrun Error The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the Overrun Error (OERR) bit is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit or by resetting the EUSART by clearing the SPEN bit. # 30.1.2.6 Receiving 9-Bit Characters The EUSART supports 9-bit character reception. When the 9-Bit Receive Enable (RX9) bit is set, the EUSART will shift nine bits into the RSR for each character received. The RX9D bit is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCxREG register. #### 30.1.2.7 Address Detection A special Address Detection mode is available for use when multiple receivers share the same transmission line, such as in RS-485 systems. Address detection is enabled by setting the Address Detect Enable (ADDEN) bit. Address detection requires 9-bit character reception. When address detection is enabled, only characters with the ninth data bit set will be transferred to the receive FIFO buffer, thereby setting the RCxIF interrupt bit. All other characters will be ignored. Upon receiving an address character, user software determines if the address matches its own. Upon address match, user software must disable address detection by clearing the ADDEN bit before the next Stop bit occurs. When user software detects the end of the message, determined by the message protocol used, software places the receiver back into the Address Detection mode by setting the ADDEN bit. ### 30.1.2.8 Asynchronous Reception Setup - 1. Initialize the SPxBRGH:SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see 30.3. EUSART Baud Rate Generator (BRG)). - 2. Set the RXxPPS register to select the RXx/DTx input pin. - 3. Clear the ANSEL bit for the RXx pin (if applicable). - 4. Enable the serial port by setting the SPEN bit. The SYNC bit must be cleared for asynchronous operation. - 5. If interrupts are desired, set the RCxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 6. If 9-bit reception is desired, set the RX9 bit. - 7. Enable reception by setting the CREN bit. - 8. The RCxIF Interrupt Flag bit will be set when a character is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCxIE interrupt enable bit was also set. - 9. Read the RCxSTA register to get the Error flags and, if 9-bit data reception is enabled, the ninth data bit. - 10. Get the received eight Least Significant data bits from the receive buffer by reading the RCxREG register. - 11. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit. # 30.1.2.9 9-Bit Address Detection Mode Setup This mode is typically used in RS-485 systems. To set up an Asynchronous Reception with Address Detect Enable, follow these steps: 1. Initialize the SPxBRGH:SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see 30.3. EUSART Baud Rate Generator (BRG)). - 2. Set the RXxPPS register to select the RXx input pin. - 3. Clear the ANSEL bit for the RXx pin (if applicable). - 4. Enable the serial port by setting the SPEN bit. The SYNC bit must be cleared for asynchronous operation. - If interrupts are desired, set the RCxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 6. Enable 9-bit reception by setting the RX9 bit. - 7. Enable address detection by setting the ADDEN bit. - 8. Enable reception by setting the CREN bit. - 9. The RCxIF Interrupt Flag bit will be set when a character with the ninth bit set is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCxIE interrupt enable bit is also set. - 10. Read the RCxSTA register to get the Error flags. The ninth data bit will always be set. - 11. Get the received eight Least Significant data bits from the receive buffer by reading the RCxREG register. Software determines if this is the device's address. - 12. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit. - 13. If the device has been addressed, clear the ADDEN bit to allow all received data into the receive buffer and generate interrupts. Figure 30-5. Asynchronous Reception **Note:** This timing diagram shows three bytes appearing on the RXx input. The OERR flag is set because the RCxREG register is not read before the third word is received. # 30.2 Clock Accuracy with Asynchronous Operation The factory calibrates the internal oscillator block output (INTOSC). However, the INTOSC frequency may drift as $V_{DD}$ or temperature changes, and this directly affects the asynchronous baud rate. Two methods may be used to adjust the baud rate clock, but both require a reference clock source of some kind. The first (preferred) method uses the OSCTUNE register to adjust the INTOSC output. Adjusting the value in the OSCTUNE register allows for fine resolution changes to the system clock source. The other method adjusts the value in the Baud Rate Generator. This can be done automatically with the Auto-Baud Detect feature (see 30.3.1. Auto-Baud Detect). There may not be fine enough resolution when adjusting the Baud Rate Generator to compensate for a gradual change in the peripheral clock frequency. # 30.3 EUSART Baud Rate Generator (BRG) The Baud Rate Generator (BRG) is an 8-bit or 16-bit timer that is dedicated to the support of both the asynchronous and synchronous EUSART operations. By default, the BRG operates in 8-bit mode. Setting the BRG16 bit selects 16-bit mode. The SPxBRGH:SPxBRGL register pair determines the period of the free-running baud rate timer. In Asynchronous mode, the multiplier of the baud rate period is determined by both the BRGH and the BRG16 bits. In Synchronous mode, the BRGH bit is ignored. Table 30-1 contains the formulas for determining the baud rate. Equation 30-1 provides a sample calculation for determining the baud rate and baud rate error. Typical baud rates and error values for various Asynchronous modes have been computed and are shown in the table below. It may be advantageous to use the high baud rate (BRGH = 1), or the 16-bit BRG (BRG16 = 1) to reduce the baud rate error. The 16-bit BRG mode is used to achieve slow baud rates for fast oscillator frequencies. The BRGH bit is used to achieve very high baud rates. Writing a new value to the SPxBRGH:SPxBRGL register pair causes the BRG timer to be reset (or cleared). This ensures that the BRG does not wait for a timer overflow before outputting the new baud rate. If the system clock is changed during an active receive operation, a receive error or data loss may result. To avoid this, check the status of the Receive Idle Flag (RCIDL) bit to make sure the receive operation is idle before changing the system clock. #### Equation 30-1. Calculating Baud Rate Error For a device with F<sub>OSC</sub> of 16 MHz, desired baud rate of 9600, Asynchronous mode, 8-bit BRG: $$DesiredBaudrate = \frac{F_{OSC}}{64 \times (SPxBRG + 1)}$$ Solving for SPxBRG: $$SPxBRG = \frac{F_{OSC}}{64 \times DesiredBaudrate} - 1$$ $$SPxBRG = \frac{16000000}{64 \times 9600} - 1$$ $$SPxBRG = 25.042 \approx 25$$ $$CalculatedBaudrate = \frac{16000000}{64 \times (25 + 1)}$$ CalculatedBaudrate = 9615 $$Error = \frac{CalculatedBaudrate - DesiredBaudrate}{DesiredBaudrate}$$ $$Error = \frac{9615 - 9600}{9600}$$ *Error* = 0.16 % ### Table 30-1. Baud Rate Formulas | С | onfiguration B | its | BRG/EUSART Mode | Baud Rate Formula | | | | | |------|----------------|------|---------------------|------------------------------|--|--|--|--| | SYNC | BRG16 | BRGH | BRG/EGSART Wode | Daud Nate i Officia | | | | | | 0 | 0 | 0 | 8-bit/Asynchronous | F <sub>OSC</sub> /[64 (n+1)] | | | | | | 0 | 0 | 1 | 8-bit/Asynchronous | F /[16 (p+1)] | | | | | | 0 | 1 | 0 | 16-bit/Asynchronous | F <sub>OSC</sub> /[16 (n+1)] | | | | | | contir | nued | | | | | | | | | |-------------------------------------------------------------------|----------------|------|---------------------|-----------------------------|--|--|--|--|--| | С | onfiguration B | its | BRG/EUSART Mode | Based Bata Farmania | | | | | | | SYNC | BRG16 | BRGH | BRG/EUSART Moue | Baud Rate Formula | | | | | | | 0 | 1 | 1 | 16-bit/Asynchronous | | | | | | | | 1 | 0 | х | 8-bit/Synchronous | F <sub>OSC</sub> /[4 (n+1)] | | | | | | | 1 | 1 | х | 16-bit/Synchronous | | | | | | | | Note: x = Don't care, n = value of SPxBRGH:SPxBRGL register pair. | | | | | | | | | | Table 30-2. Sample Baud Rates for Asynchronous Modes | | | <b>SYNC</b> = 0, <b>BRGH</b> = 0, <b>BRG16</b> = 0 | | | | | | | | | | | | |-----------|-------------------------------|----------------------------------------------------|-----------------------------|----------------|-------------------------------|-----------------------------|----------------|-------------------------------|-----------------------------|----------------|--------------------------------|-----------------------------|--| | Baud Rate | F <sub>OSC</sub> = 32.000 MHz | | | Fosc | F <sub>OSC</sub> = 20.000 MHz | | | F <sub>OSC</sub> = 18.432 MHz | | | F <sub>OSC</sub> = 11.0592 MHz | | | | | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | | 300 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | 1200 | _ | _ | _ | 1221 | 1.73 | 255 | 1200 | 0.00 | 239 | 1200 | 0.00 | 143 | | | 2400 | 2404 | 0.16 | 207 | 2404 | 0.16 | 129 | 2400 | 0.00 | 119 | 2400 | 0.00 | 71 | | | 9600 | 9615 | 0.16 | 51 | 9470 | -1.36 | 32 | 9600 | 0.00 | 29 | 9600 | 0.00 | 17 | | | 10417 | 10417 | 0.00 | 47 | 10417 | 0.00 | 29 | 10286 | -1.26 | 27 | 10165 | -2.42 | 16 | | | 19.2k | 19.23k | 0.16 | 25 | 19.53k | 1.73 | 15 | 19.20k | 0.00 | 14 | 19.20k | 0.00 | 8 | | | 57.6k | 55.55k | -3.55 | 3 | _ | _ | _ | 57.60k | 0.00 | 7 | 57.60k | 0.00 | 2 | | | 115.2k | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | | | | SYNC | C = 0, BRGI | <b>⊣</b> = 0, <b>B</b> F | RG16 = | 0 | | | | | |-----------|----------------|--------------------|-----------------------------|----------------|------------------------------|-----------------------------|--------------------------|-------------------------------|-----------------------------|----------------|------------------------------|-----------------------------|--| | Baud Rate | Foso | <sub>C</sub> = 8.0 | 00 MHz | Foso | F <sub>OSC</sub> = 4.000 MHz | | | F <sub>OSC</sub> = 3.6864 MHz | | | F <sub>OSC</sub> = 1.000 MHz | | | | | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | | 300 | _ | _ | _ | 300 | 0.16 | 207 | 300 | 0.00 | 191 | 300 | 0.16 | 51 | | | 1200 | 1202 | 0.16 | 103 | 1202 | 0.16 | 51 | 1200 | 0.00 | 47 | 1202 | 0.16 | 12 | | | 2400 | 2404 | 0.16 | 51 | 2404 | 0.16 | 25 | 2400 | 0.00 | 23 | _ | _ | _ | | | 9600 | 9615 | 0.16 | 12 | _ | _ | _ | 9600 | 0.00 | 5 | _ | _ | _ | | | 10417 | 10417 | 0.00 | 11 | 10417 | 0.00 | 5 | _ | _ | _ | _ | _ | _ | | | 19.2k | _ | _ | _ | _ | _ | _ | 19.20k | 0.00 | 2 | _ | _ | _ | | | 57.6k | _ | _ | _ | _ | | _ | 57.60k | 0.00 | 0 | _ | _ | _ | | | 115.2k | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | | | SYNC = 0, BRGH = 1, BRG16 = 0 | | | | | | | | | | | | |--------|-------------------------------|-------------------------------|-----------------------------|-------------------------------|------------|-----------------------------|-------------------------------|------------|-----------------------------|--------------------------------|------------|-----------------------------|--| | Baud | F <sub>OSC</sub> = 32.000 MHz | | | F <sub>OSC</sub> = 20.000 MHz | | | F <sub>OSC</sub> = 18.432 MHz | | | F <sub>OSC</sub> = 11.0592 MHz | | | | | Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | | 300 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | <del>-</del> | | | 1200 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | 2400 | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | 9600 | 9615 | 0.16 | 207 | 9615 | 0.16 | 129 | 9600 | 0.00 | 119 | 9600 | 0.00 | 71 | | | 10417 | 10417 | 0.00 | 191 | 10417 | 0.00 | 119 | 10378 | -0.37 | 110 | 10473 | 0.53 | 65 | | | 19.2k | 19.23k | 0.16 | 103 | 19.23k | 0.16 | 64 | 19.20k | 0.00 | 59 | 19.20k | 0.00 | 35 | | | 57.6k | 57.14k | -0.79 | 34 | 56.82k | -1.36 | 21 | 57.60k | 0.00 | 19 | 57.60k | 0.00 | 11 | | | 115.2k | 117.64k | 2.12 | 16 | 113.64k | -1.36 | 10 | 115.2k | 0.00 | 9 | 115.2k | 0.00 | 5 | | | | | | | | SYNC | = 0, BRGH | H = 1, BF | RG16 = | 0 | | | | |-----------|----------------|------------------------------|-----------------------------|----------------|------------|-----------------------------|----------------|------------|-----------------------------|------------------------------|------------|-----------------------------| | | Foso | F <sub>OSC</sub> = 8.000 MHz | | | = 4.00 | 00 MHz | Fosc | = 3.68 | 64 MHz | F <sub>OSC</sub> = 1.000 MHz | | | | Baud Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | _ | _ | _ | _ | _ | _ | _ | _ | _ | 300 | 0.16 | 207 | | 1200 | _ | _ | _ | 1202 | 0.16 | 207 | 1200 | 0.00 | 191 | 1202 | 0.16 | 51 | | 2400 | 2404 | 0.16 | 207 | 2404 | 0.16 | 103 | 2400 | 0.00 | 95 | 2404 | 0.16 | 25 | | 9600 | 9615 | 0.16 | 51 | 9615 | 0.16 | 25 | 9600 | 0.00 | 23 | _ | _ | _ | | 10417 | 10417 | 0.00 | 47 | 10417 | 0.00 | 23 | 10473 | 0.53 | 21 | 10417 | 0.00 | 5 | | 19.2k | 19231 | 0.16 | 25 | 19.23k | 0.16 | 12 | 19.2k | 0.00 | 11 | _ | _ | _ | | 57.6k | 55556 | -3.55 | 8 | _ | _ | _ | 57.60k | 0.00 | 3 | _ | _ | _ | | 115.2k | _ | _ | _ | | _ | _ | 115.2k | 0.00 | 1 | | _ | _ | | | | | | | SYNC | = 0, BRGH | = 0, BR | G16 = | 1 | | | | |-------|----------------|------------|-----------------------------|-------------------------------|------------|-----------------------------|----------------|------------|-----------------------------|--------------------------------|------------|-----------------------------| | Baud | Fosc | = 32.0 | 00 MHz | F <sub>OSC</sub> = 20.000 MHz | | | Fosc | = 18.4 | 32 MHz | F <sub>OSC</sub> = 11.0592 MHz | | | | Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | 300.0 | 0.00 | 6666 | 300.0 | -0.01 | 4166 | 300.0 | 0.00 | 3839 | 300.0 | 0.00 | 2303 | | 1200 | 1200 | -0.02 | 3332 | 1200 | -0.03 | 1041 | 1200 | 0.00 | 959 | 1200 | 0.00 | 575 | | 2400 | 2401 | -0.04 | 832 | 2399 | -0.03 | 520 | 2400 | 0.00 | 479 | 2400 | 0.00 | 287 | | 9600 | 9615 | 0.16 | 207 | 9615 | 0.16 | 129 | 9600 | 0.00 | 119 | 9600 | 0.00 | 71 | | 10417 | 10417 | 0.00 | 191 | 10417 | 0.00 | 119 | 10378 | -0.37 | 110 | 10473 | 0.53 | 65 | | 19.2k | 19.23k | 0.16 | 103 | 19.23k | 0.16 | 64 | 19.20k | 0.00 | 59 | 19.20k | 0.00 | 35 | # PIC16F18015/25/44/45 # **EUSART - Enhanced Universal Synchronous Asyn...** | 57.6k | 57.14k | -0.79 | 34 | 56.818 | -1.36 | 21 | 57.60k | 0.00 | 19 | 57.60k | 0.00 | 11 | |--------|--------|-------|----|---------|-------|----|--------|------|----|--------|------|----| | 115.2k | 117.6k | 2.12 | 16 | 113.636 | -1.36 | 10 | 115.2k | 0.00 | 9 | 115.2k | 0.00 | 5 | | | SYNC = 0, BRGH = 0, BRG16 = 1 | | | | | | | | | | | | |-----------|-------------------------------|------------|-----------------------------|----------------|------------|-----------------------------|----------------|------------|-----------------------------|------------------------------|------------|-----------------------------| | D 10 ( | Foso | = 8.00 | 00 MHz | Foso | = 4.00 | 00 MHz | Fosc | = 3.68 | 64 MHz | F <sub>OSC</sub> = 1.000 MHz | | | | Baud Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | 299.9 | -0.02 | 1666 | 300.1 | 0.04 | 832 | 300.0 | 0.00 | 767 | 300.5 | 0.16 | 207 | | 1200 | 1199 | -0.08 | 416 | 1202 | 0.16 | 207 | 1200 | 0.00 | 191 | 1202 | 0.16 | 51 | | 2400 | 2404 | 0.16 | 207 | 2404 | 0.16 | 103 | 2400 | 0.00 | 95 | 2404 | 0.16 | 25 | | 9600 | 9615 | 0.16 | 51 | 9615 | 0.16 | 25 | 9600 | 0.00 | 23 | _ | _ | _ | | 10417 | 10417 | 0.00 | 47 | 10417 | 0.00 | 23 | 10473 | 0.53 | 21 | 10417 | 0.00 | 5 | | 19.2k | 19.23k | 0.16 | 25 | 19.23k | 0.16 | 12 | 19.20k | 0.00 | 11 | _ | _ | _ | | 57.6k | 55556 | -3.55 | 8 | | _ | _ | 57.60k | 0.00 | 3 | | | _ | | 115.2k | _ | _ | _ | _ | _ | _ | 115.2k | 0.00 | 1 | _ | _ | _ | | | | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1 | | | | | | | | | | | |-----------|----------------|------------------------------------------------------|-----------------------------|----------------|------------|-----------------------------|----------------|------------|-----------------------------|--------------------------------|------------|-----------------------------| | DI D-4- | Fosc | = 32.0 | 00 MHz | Fosc | = 20.0 | 00 MHz | Fosc | = 18.4 | 32 MHz | F <sub>OSC</sub> = 11.0592 MHz | | | | Baud Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | 300 | 300.0 | 0.00 | 26666 | 300.0 | 0.00 | 16665 | 300.0 | 0.00 | 15359 | 300.0 | 0.00 | 9215 | | 1200 | 1200 | 0.00 | 6666 | 1200 | -0.01 | 4166 | 1200 | 0.00 | 3839 | 1200 | 0.00 | 2303 | | 2400 | 2400 | 0.01 | 3332 | 2400 | 0.02 | 2082 | 2400 | 0.00 | 1919 | 2400 | 0.00 | 1151 | | 9600 | 9604 | 0.04 | 832 | 9597 | -0.03 | 520 | 9600 | 0.00 | 479 | 9600 | 0.00 | 287 | | 10417 | 10417 | 0.00 | 767 | 10417 | 0.00 | 479 | 10425 | 0.08 | 441 | 10433 | 0.16 | 264 | | 19.2k | 19.18k | -0.08 | 416 | 19.23k | 0.16 | 259 | 19.20k | 0.00 | 239 | 19.20k | 0.00 | 143 | | 57.6k | 57.55k | -0.08 | 138 | 57.47k | -0.22 | 86 | 57.60k | 0.00 | 79 | 57.60k | 0.00 | 47 | | 115.2k | 115.9k | 0.64 | 68 | 116.3k | 0.94 | 42 | 115.2k | 0.00 | 39 | 115.2k | 0.00 | 23 | | | | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1 | | | | | | | | | | | | | |------------|------------------------------|------------------------------------------------------|------------------------------|----------------|-------------------------------|-----------------------------|----------------|------------------------------|-----------------------------|----------------|------------|-----------------------------|--|--| | David Data | F <sub>OSC</sub> = 8.000 MHz | | F <sub>OSC</sub> = 4.000 MHz | | F <sub>OSC</sub> = 3.6864 MHz | | | F <sub>OSC</sub> = 1.000 MHz | | | | | | | | Baud Rate | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | | | | 300 | 300.0 | 0.00 | 6666 | 300.0 | 0.01 | 3332 | 300.0 | 0.00 | 3071 | 300.1 | 0.04 | 832 | | | | 1200 | 1200 | -0.02 | 1666 | 1200 | 0.04 | 832 | 1200 | 0.00 | 767 | 1202 | 0.16 | 207 | | | | 2400 | 2401 | 0.04 | 832 | 2398 | 0.08 | 416 | 2400 | 0.00 | 383 | 2404 | 0.16 | 103 | | | | - | | | | | | | | | | | | | | |---|--------|--------|-------|-----|--------|-------|-----|--------|------|----|--------|------|----| | | 9600 | 9615 | 0.16 | 207 | 9615 | 0.16 | 103 | 9600 | 0.00 | 95 | 9615 | 0.16 | 25 | | | 10417 | 10417 | 0 | 191 | 10417 | 0.00 | 95 | 10473 | 0.53 | 87 | 10417 | 0.00 | 23 | | | 19.2k | 19.23k | 0.16 | 103 | 19.23k | 0.16 | 51 | 19.20k | 0.00 | 47 | 19.23k | 0.16 | 12 | | | 57.6k | 57.14k | -0.79 | 34 | 58.82k | 2.12 | 16 | 57.60k | 0.00 | 15 | _ | | _ | | | 115.2k | 117.6k | 2.12 | 16 | 111.1k | -3.55 | 8 | 115.2k | 0.00 | 7 | _ | _ | _ | #### 30.3.1 Auto-Baud Detect The EUSART module supports automatic detection and calibration of the baud rate. In the Auto-Baud Detect (ABD) mode, the clock to the BRG is reversed. Rather than the BRG clocking the incoming RX signal, the RX signal is timing the BRG. The Baud Rate Generator is used to time the period of a received 55h (ASCII "U") which is the Sync character for the LIN bus. The unique feature of this character is that it has five rising edges, including the Stop bit edge. Setting the Auto-Baud Detect Enable (ABDEN) bit starts the auto-baud calibration sequence. While the ABD sequence takes place, the EUSART state machine is held in Idle. On the first rising edge of the receive line, after the Start bit, the SPxBRG register begins counting up using the BRG counter clock as shown in Figure 30-6. The fifth rising edge will occur on the RXx pin at the end of the eighth bit period. At that time, an accumulated value totaling the proper BRG period is left in the SPxBRGH:SPxBRGL register pair, the ABDEN bit is automatically cleared, and the RCxIF interrupt flag is set. The value in the RCxREG register needs to be read to clear the RCxIF interrupt. RCxREG content may be discarded. When calibrating for modes that do not use the SPxBRGH register, the user can verify that the SPxBRGL register did not overflow by checking for 00h in the SPxBRGH register. The BRG auto-baud clock is determined by the BRG16 and BRGH bits, as shown in Table 30-3. During ABD, both the SPxBRGH and SPxBRGL registers are used as a 16-bit counter, independent of the BRG16 bit setting. While calibrating the baud rate period, the SPxBRGH and SPxBRGL registers are clocked at 1/8<sup>th</sup> the BRG base clock rate. The resulting byte measurement is the average bit time when clocked at full speed. #### Notes: - 1. If the Wake-Up Enable (WUE) bit is set with the ABDEN bit, auto-baud detection will occur on the byte following the Break character (see 30.3.3. Auto-Wake-Up on Break). - It is up to the user to determine that the incoming character baud rate is within the range of the selected BRG clock source. Some combinations of oscillator frequency and EUSART baud rates are not possible. - 3. During the auto-baud process, the auto-baud counter starts counting at one. Upon completion of the auto-baud sequence, to achieve maximum accuracy, subtract 1 from the SPxBRGH:SPxBRGL register pair. Table 30-3. BRG Counter Clock Rates | BRG16 | BRGH | BRG Base Clock | BRG ABD Clock | |-------|------|----------------------|-----------------------| | 1 | 1 | F <sub>OSC</sub> /4 | F <sub>OSC</sub> /32 | | 1 | 0 | F <sub>OSC</sub> /16 | F <sub>OSC</sub> /128 | | 0 | 1 | F <sub>OSC</sub> /16 | F <sub>OSC</sub> /128 | | 0 | 0 | F <sub>OSC</sub> /64 | F <sub>OSC</sub> /512 | **Note:** During the ABD sequence, the SPxBRGL and SPxBRGH registers are both used as a 16-bit counter, independent of the BRG16 setting. Figure 30-6. Automatic Baud Rate Calibration #### 30.3.2 Auto-Baud Overflow During the course of automatic baud detection, the Auto-Baud Detect Overflow (ABDOVF) bit will be set if the baud rate counter overflows before the fifth rising edge is detected on the RXx pin. The ABDOVF bit indicates that the counter has exceeded the maximum count that can fit in the 16 bits of the SPxBRGH:SPxBRGL register pair. After the ABDOVF bit has been set, the counter continues to count until the fifth rising edge is detected on the RXx pin. Upon detecting the fifth RX edge, the hardware will set the RCxIF interrupt flag and clear the ABDEN bit. The RCxIF flag can be subsequently cleared by reading the RCxREG register. The ABDOVF bit can be cleared by software directly. To terminate the auto-baud process before the RCxIF flag is set, clear the ABDEN bit then clear the ABDOVF bit. The ABDOVF bit will remain set if the ABDEN bit is not cleared first. ### 30.3.3 Auto-Wake-Up on Break During Sleep mode, all clocks to the EUSART are suspended. Because of this, the Baud Rate Generator is inactive and a proper character reception cannot be performed. The Auto-Wake-Up feature allows the controller to wake up due to activity on the RX/DT line. This feature is available only in Asynchronous mode. The Auto-Wake-Up feature is enabled by setting the WUE bit. Once set, the normal receive sequence on RX/DT is disabled, and the EUSART remains in an Idle state, monitoring for a wake-up event independent of the CPU mode. A wake-up event consists of a high-to-low transition on the RX/DT line. This coincides with the start of a Sync Break or a wake-up signal character for the LIN protocol. The EUSART module generates an RCxIF interrupt coincident with the wake-up event. The interrupt is generated synchronously to the Q clocks in normal CPU operating modes as shown in Figure 30-7, and asynchronously if the device is in Sleep mode, as shown in Figure 30-8. The Interrupt condition is cleared by reading the RCxREG register. The WUE bit is automatically cleared by the low-to-high transition on the RX line at the end of the Break. This signals to the user that the Break event is over. At this point, the EUSART module is in Idle mode waiting to receive the next character. ### 30.3.3.1 Special Considerations ### **Break Character** To avoid character errors or character fragments during a wake-up event, the wake-up character must be all zeros. When the wake-up is enabled, the function works independent of the low time on the data stream. If the WUE bit is set and a valid nonzero character is received, the low time from the Start bit to the first rising edge will be interpreted as the wake-up event. The remaining bits in the character will be received as a fragmented character and subsequent characters can result in framing or overrun errors. Therefore, the initial character in the transmission must be all '0's. This must be 10 or more bit times, 13-bit times recommended for LIN bus, or any number of bit times for standard RS-232 devices. #### **WUE Bit** The wake-up event causes a receive interrupt by setting the RCxIF bit. The WUE bit is cleared in hardware by a rising edge on RX/DT. The Interrupt condition is then cleared in software by reading the RCxREG register and discarding its contents. To ensure that no actual data is lost, check the RCIDL bit to verify that a receive operation is not in process before setting the WUE bit. If a receive operation is not occurring, the WUE bit may then be set just prior to entering the Sleep mode. Figure 30-7. Auto-Wake-Up (WUE) Bit Timing During Normal Operation Note: The EUSART remains in Idle while the WUE bit is set. Figure 30-8. Auto-Wake-Up (WUE) Bit Timings During Sleep Note: The EUSART remains in Idle while the WUE bit is set. ### 30.3.4 Break Character Sequence The EUSART module has the capability of sending the special Break character sequences that are required by the LIN bus standard. A Break character consists of a Start bit, followed by 12 '0' bits and a Stop bit. To send a Break character, set the Send Break Character (SENDB) and Transmit Enable (TXEN) bits. The Break character transmission is then initiated by a write to the TXxREG. The value of data written to TXxREG will be ignored and all '0's will be transmitted. The SENDB bit is automatically reset by hardware after the corresponding Stop bit is sent. This allows the user to preload the transmit FIFO with the next transmit byte following the Break character (typically, the Sync character in the LIN specification). The Transmit Shift Register Status (TRMT) bit indicates when the transmit operation is Active or Idle, just as it does during normal transmission. See Figure 30-9 for more details. #### 30.3.4.1 Break and Sync Transmit Sequence The following sequence will start a message frame header made up of a Break, followed by an auto-baud Sync byte. This sequence is typical of a LIN bus host. - 1. Configure the EUSART for the desired mode. - 2. Set the TXEN and SENDB bits to enable the Break sequence. - 3. Load the TXxREG with a dummy character to initiate transmission (the value is ignored). - 4. Write '55h' to TXxREG to load the Sync character into the transmit FIFO buffer. - 5. After the Break has been sent, the SENDB bit is reset by hardware and the Sync character is then transmitted. When the TXxREG becomes empty, as indicated by TXxIF, the next data byte can be written to TXxREG. ### 30.3.5 Receiving a Break Character The EUSART module can receive a Break character in two ways. The first method to detect a Break character uses the Framing Error (FERR) bit and the received data as indicated by RCxREG. The Baud Rate Generator is assumed to have been initialized to the expected baud rate. A Break character has been received when all three of the following conditions are true: - RCxIF bit is set - FERR bit is set - RCxREG = 00h The second method uses the Auto-Wake-Up feature described in 30.3.3. Auto-Wake-Up on Break. By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RCxIF interrupt, and receive the next data byte followed by another interrupt. Note that following a Break character, the user will typically want to enable the Auto-Baud Detect feature. For both methods, the user can set the ABDEN bit before placing the EUSART in Sleep mode. Figure 30-9. Send Break Character Sequence # 30.4 EUSART Synchronous Mode Synchronous serial communications are typically used in systems with a single host and one or more clients. The host device contains the necessary circuitry for baud rate generation and supplies the clock for all devices in the system. Client devices can take advantage of the host clock by eliminating the internal clock generation circuitry. There are two signal lines in Synchronous mode: A bidirectional data line (DT) and a clock line (CK). The clients use the external clock supplied by the host to shift the serial data into and out of their respective receive and transmit shift registers. Since the data line is bidirectional, synchronous operation is half-duplex only. Half-duplex refers to the fact that host and client devices can receive and transmit data but not both simultaneously. The EUSART can operate as either a host or client device. Start and Stop bits are not used in synchronous transmissions. #### 30.4.1 **Synchronous Host Mode** The following bits are used to configure the EUSART for synchronous host operation: - The SYNC bit is set to '1' to configure the EUSART for synchronous operation - The Clock Source Select (CSRC) bit is set to '1' to configure the EUSART as the host - The Single Receive Enable (SREN) bit is set to '0' for transmit; SREN = 1 for receive (recommended setting to receive 1 byte) - The Continuous Receive Enable (CREN) bit is set to '0' for transmit; CREN = 1 to receive continuously - The SPEN bit is set to '1' to enable the EUSART interface Important: Clearing the SREN and CREN bits ensure that the device is in the Transmit mode, otherwise the device will be configured to receive. #### 30.4.1.1 Host Clock Synchronous data transfers use a separate clock line, which is synchronous with the data. A device configured as a host transmits the clock on the TX/CK line. The TXx/CKx pin output driver is automatically enabled when the EUSART is configured for synchronous transmit or receive operation. Serial data bits change on the leading edge to ensure they are valid at the trailing edge of each clock. One clock cycle is generated for each data bit. Only as many clock cycles are generated as there are data bits. ### 30.4.1.2 Clock Polarity A clock polarity option is provided for Microwire compatibility. Clock polarity is selected with the Clock/Transmit Polarity Select (SCKP) bit. Setting the SCKP bit sets the clock Idle state as high. When the SCKP bit is set, the data changes on the falling edge of each clock. Clearing the SCKP bit sets the Idle state as low. When the SCKP bit is cleared, the data changes on the rising edge of each clock. ### 30.4.1.3 Synchronous Host Transmission Data is transferred out of the device on the RXx/DTx pin. The RXx/DTx and TXx/CKx pin output drivers are automatically enabled when the EUSART is configured for synchronous host transmit operation. A transmission is initiated by writing a character to the TXxREG register. If the TSR still contains all or part of a previous character the new character data is held in the TXxREG until the last bit of the previous character has been transmitted. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TXxREG is immediately transferred to the TSR. The transmission of the character commences immediately following the transfer of the data to the TSR from the TXxREG. Each data bit changes on the leading edge of the host clock and remains valid until the subsequent leading clock edge. Note: The TSR register is not mapped in data memory, so it is not available to the user. ### 30.4.1.4 Synchronous Host Transmission Setup - 1. Initialize the SPxBRGH;SPxBRGL register pair and the BRG16 bit to achieve the desired baud rate (see 30.3. EUSART Baud Rate Generator (BRG)). - Select the transmit output pin by writing the appropriate values to the RxyPPS register and RXxPPS register. Both selections may enable the same pin. - Select the clock output pin by writing the appropriate values to the RxyPPS register and TXxPPS register. Both selections may enable the same pin. - 4. Enable the synchronous host serial port by setting bits SYNC, SPEN and CSRC. - 5. Disable Receive mode by clearing the SREN and CREN bits. - 6. Enable Transmit mode by setting the TXEN bit. - 7. If 9-bit transmission is desired, set the TX9 bit. - If interrupts are desired, set the TXxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 9. If 9-bit transmission is selected, the ninth bit will be loaded in the TX9D bit. - 10. Start transmission by loading data to the TXxREG register. ### Figure 30-10. Synchronous Transmission ### 30.4.1.5 Synchronous Host Reception Data is received at the RXx/DTx pin. The RXx/DTx pin output driver is automatically disabled when the EUSART is configured for synchronous host receive operation. In Synchronous mode, reception is enabled by setting either the Single Receive Enable (SREN) bit or the Continuous Receive Enable (CREN) bit. When SREN is set and CREN is clear, only as many clock cycles are generated as there are data bits in a single character. The SREN bit is automatically cleared at the completion of one character. When CREN is set, clocks are continuously generated until CREN is cleared. If CREN is cleared in the middle of a character the CK clock stops immediately and the partial character is discarded. If SREN and CREN are both set, then SREN is cleared at the completion of the first character and CREN takes precedence. To initiate reception, set either SREN or CREN. Data is sampled at the RXx/DTx pin on the trailing edge of the TX/CK clock pin and is shifted into the Receive Shift Register (RSR). When a complete character is received into the RSR, the RCxIF bit is set and the character is automatically transferred to the two character receive FIFO. The eight Least Significant bits of the top character in the receive FIFO are available in RCxREG. The RCxIF bit remains set as long as there are unread characters in the receive FIFO. **Note:** If the RX/DT function is on an analog pin, the corresponding ANSEL bit must be cleared for the receiver to function. #### 30.4.1.6 Client Clock Synchronous data transfers use a separate clock line, which is synchronous with the data. A device configured as a client receives the clock on the TX/CK line. The TXx/CKx pin output driver is automatically disabled when the device is configured for synchronous client transmit or receive operation. Serial data bits change on the leading edge to ensure they are valid at the trailing edge of each clock. One data bit is transferred for each clock cycle. Only as many clock cycles may be received as there are data bits. **Important:** If the device is configured as a client and the TX/CK function is on an analog pin, the corresponding ANSEL bit must be cleared. #### 30.4.1.7 Receive Overrun Error The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the Overrun Error (OERR) bit is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit or by resetting the EUSART by clearing the SPEN bit. ### 30.4.1.8 Receiving 9-Bit Characters The EUSART supports 9-bit character reception. When the 9-Bit Receive Enable (RX9) bit is set, the EUSART will shift nine bits into the RSR for each character received. The RX9D bit is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCxREG register. ### 30.4.1.9 Synchronous Host Reception Setup - Initialize the SPxBRGH:SPxBRGL register pair and set or clear the BRG16 bit, as required, to achieve the desired baud rate. - 2. Select the receive input pin by writing the appropriate values to the RxyPPS and RXxPPS registers. Both selections may enable the same pin. - 3. Select the clock output pin by writing the appropriate values to the RxyPPS and TXxPPS registers. Both selections may enable the same pin. - 4. Clear the ANSEL bit for the RXx pin (if applicable). - 5. Enable the synchronous host serial port by setting the SYNC, SPEN and CSRC bits. - 6. Ensure that the CREN and SREN bits are cleared. - 7. If interrupts are desired, set the RCxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 8. If 9-bit reception is desired, set the RX9 bit. - 9. Start reception by setting the SREN bit, or for continuous reception set the CREN bit. - 10. The RCxIF Interrupt Flag bit will be set when reception of a character is complete. An interrupt will be generated if the RCxIE enable bit was set. - 11. Read the RCxSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception. - 12. Read the 8-bit received data by reading the RCxREG register. - 13. If an overrun error occurs, clear the error by either clearing the CREN bit or by clearing the SPEN bit which resets the EUSART. Figure 30-11. Synchronous Reception (Host Mode, SREN) ### 30.4.2 Synchronous Client Mode The following bits are used to configure the EUSART for synchronous client operation: - SYNC = 1 (configures the EUSART for synchronous operation) - CSRC = 0 (configures the EUSART as a client) - SREN = 0 (for transmit); SREN = 1 (for single byte receive) - CREN = 0 (for transmit); CREN = 1 (recommended setting for continuous receive) - SPEN = 1 (enables the EUSART) **Important:** Clearing the SREN and CREN bits ensure that the device is in Transmit mode, otherwise the device will be configured to receive. ### 30.4.2.1 EUSART Synchronous Client Transmit The operation of the Synchronous Host and Client modes are identical (see 30.4.1.3. Synchronous Host Transmission), except in the case of the Sleep mode. If two words are written to the TXxREG and then the SLEEP instruction is executed, the following will occur: - 1. The first character will immediately transfer to the TSR register and transmit. - The second word will remain in the TXxREG register. - 3. The TXxIF bit will not be set. - 4. After the first character has been shifted out of TSR, the TXxREG register will transfer the second character to the TSR and the TXxIF bit will now be set. - 5. If the PEIE and TXxIE bits are set, the interrupt will wake the device from Sleep and execute the next instruction. If the GIE bit is also set, the program will call the Interrupt Service Routine. ### 30.4.2.2 Synchronous Client Transmission Setup - 1. Set the SYNC and SPEN bits and clear the CSRC bit. - 2. Select the transmit output pin by writing the appropriate values to the RxyPPS register and RXxPPS register. Both selections may enable the same pin. - 3. Select the clock input pin by writing the appropriate value to the TXxPPS register. - 4. Clear the ANSEL bit for the CKx pin (if applicable). - 5. Clear the CREN and SREN bits. - 6. If interrupts are desired, set the TXxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 7. If 9-bit transmission is desired, set the TX9 bit. - Enable transmission by setting the TXEN bit. - If 9-bit transmission is selected, insert the Most Significant bit into the TX9D bit. - 10. Prepare for transmission by writing the eight Least Significant bits to the TXxREG register. The word will be transmitted in response to the Host clocks at the CKx pin. #### 30.4.2.3 EUSART Synchronous Client Reception The operation of the Synchronous Host and Client modes is identical (see 30.4.1.5. Synchronous Host Reception), with the following exceptions: - Sleep - CREN bit is always set, therefore the receiver is never Idle - · SREN bit, which is a "don't care" in Client mode A character may be received while in Sleep mode by setting the CREN bit prior to entering Sleep. Once the word is received, the RSR register will transfer the data to the RCxREG register. If the RCxIE enable bit is set, the interrupt generated will wake the device from Sleep and execute the next instruction. If the GIE bit is also set, the program will branch to the interrupt vector. ### 30.4.2.4 Synchronous Client Reception Setup - 1. Set the SYNC and SPEN bits and clear the CSRC bit. - Select the receive input pin by writing the appropriate value to the RXxPPS register. - 3. Select the clock input pin by writing the appropriate values to the TXxPPS register. - 4. Clear the ANSEL bit for both the TXx/CKx and RXx/DTx pins (if applicable). - If interrupts are desired, set the RCxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - 6. If 9-bit reception is desired, set the RX9 bit. - 7. Set the CREN bit to enable reception. - 8. The RCxIF bit will be set when reception is complete. An interrupt will be generated if the RCxIE bit was set. - 9. If 9-bit mode is enabled, retrieve the Most Significant bit from the RX9D bit. - 10. Retrieve the eight Least Significant bits from the receive FIFO by reading the RCxREG register. - 11. If an overrun error occurs, clear the error by either clearing the CREN bit or by clearing the SPEN bit which resets the EUSART. # 30.5 EUSART Operation During Sleep The EUSART will remain active during Sleep only in the Synchronous Client mode. All other modes require the system clock and therefore cannot generate the necessary signals to run the Transmit or Receive Shift registers during Sleep. Synchronous Client mode uses an externally generated clock to run the Transmit and Receive Shift registers. # 30.5.1 Synchronous Receive During Sleep To receive during Sleep, all the following conditions must be met before entering Sleep mode: - RCxSTA and TXxSTA Control registers must be configured for Synchronous Client Reception (see 30.4.2.4. Synchronous Client Reception Setup). - If interrupts are desired, set the RCxIE bit of the PIEx register and the GIE and PEIE bits of the INTCON register. - The RCxIF interrupt flag must be cleared by reading RCxREG to unload any pending characters in the receive buffer. Upon entering Sleep mode, the device will be ready to accept data and clocks on the RXx/DTx and TXx/CKx pins, respectively. When the data word has been completely clocked in by the external device, the RCxIF Interrupt Flag bit of the PIRx register will be set. Thereby, waking the processor from Sleep. Upon waking from Sleep, the instruction following the SLEEP instruction will be executed. If the Global Interrupt Enable (GIE) bit of the INTCON register is also set, then the Interrupt Service Routine (ISR) will be called. #### 30.5.2 Synchronous Transmit During Sleep To transmit during Sleep, all the following conditions must be met before entering Sleep mode: - The RCxSTA and TXxSTA Control registers must be configured for synchronous client transmission (see 30.4.2.2. Synchronous Client Transmission Setup). - The TXxIF interrupt flag must be cleared by writing the output data to the TXxREG, thereby filling the TSR and transmit buffer. - The TXxIE interrupt enable bits of the PIEx register and PEIE of the INTCON register must be written to '1'. - If interrupts are desired, set the GIE bit of the INTCON register. Upon entering Sleep mode, the device will be ready to accept clocks on the TXx/CKx pin and transmit data on the RXx/DTx pin. When the data word in the TSR register has been completely clocked out by the external device, the pending byte in the TXxREG will transfer to the TSR and the TXxIF flag will be set. Thereby, waking the processor from Sleep. At this point, the TXxREG is available to accept another character for transmission. Writing TXxREG will clear the TXxIF flag. Upon waking from Sleep, the instruction following the SLEEP instruction will be executed. If the Global Interrupt Enable (GIE) bit is also set then the Interrupt Service Routine (ISR) will be called. # PIC16F18015/25/44/45 **EUSART - Enhanced Universal Synchronous Asyn...** | 30.6 | Register | <b>Definitions:</b> | <b>EUSART</b> | <b>Control</b> | |------|----------|---------------------|---------------|----------------| |------|----------|---------------------|---------------|----------------| ### 30.6.1 TXxSTA Name: TXxSTA Offset: 0x0611,0x061B Transmit Status and Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|-----|------|------|-------|------|------|------| | [ | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | | Access | R/W | R/W | R/W | R/W | R/W | R/W | R | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | # Bit 7 - CSRC Clock Source Select | Value | Condition | Description | |-------|-----------|-------------------------------------------------| | 1 | SYNC = 1 | Host mode (clock generated internally from BRG) | | 0 | SYNC = 1 | Client mode (clock from external source) | | X | SYNC = 0 | Don't care | # Bit 6 - TX9 9-Bit Transmit Enable | Value | Description | |-------|----------------------------| | 1 | Selects 9-bit transmission | | 0 | Selects 8-bit transmission | # Bit 5 - TXEN Transmit Enable Enables transmitter<sup>(1)</sup> | Value | Description | | | |-------|-------------------|--|--| | 1 | Transmit enabled | | | | 0 | Transmit disabled | | | #### Bit 4 - SYNC EUSART Mode Select | Value | alue Description | | | |-------|-------------------|--|--| | 1 | Synchronous mode | | | | 0 | Asynchronous mode | | | # Bit 3 - SENDB Send Break Character | Value | Condition | Description | |-------|-----------|----------------------------------------------------------------------------| | 1 | SYNC = 0 | Send Sync Break on next transmission (cleared by hardware upon completion) | | 0 | SYNC = 0 | Sync Break transmission disabled or completed | | X | SYNC = 1 | Don't care | ### Bit 2 - BRGH High Baud Rate Select | Value | Condition | Description | |-------|-----------|-------------------------------------------------------------------| | 1 | SYNC = 0 | High speed, if BRG16 = 1, baud rate is baudclk/4; else baudclk/16 | | 0 | SYNC = 0 | Low speed | | X | SYNC = 1 | Don't care | #### Bit 1 - TRMT Transmit Shift Register (TSR) Status | | The first transfer of the great ( ) or y existing | | | |-------|---------------------------------------------------|--|--| | Value | Description | | | | 1 | TSR is empty | | | | 0 | TSR is not empty | | | # Bit 0 - TX9D Ninth Bit of Transmit Data Can be address/data bit or a parity bit. Note: 1. The SREN and CREN bits override TXEN in Sync mode. ### 30,6,2 RCxSTA Name: RCxSTA Offset: 0x0610,0x061A Receive Status and Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|-----|--------|------|-------|------|------|------| | | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | Access | R/W | R/W | R/W/HC | R/W | R/W | R | R/HC | R/HC | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | # Bit 7 - SPEN Serial Port Enable | Value | Description | | |-------|--------------------------------------|--| | 1 | Serial port enabled | | | 0 | Serial port disabled (held in Reset) | | #### Bit 6 - RX9 9-Bit Receive Enable | Value | Description | | |-------|-------------------------|--| | 1 | Selects 9-bit reception | | | 0 | Selects 8-bit reception | | # Bit 5 - SREN Single Receive Enable Controls reception. This bit is cleared by hardware when reception is complete | Value | lue Condition Description | | | |-------|---------------------------|----------------------------|--| | 1 | SYNC = 1 AND CSRC = 1 | Start single receive | | | 0 | SYNC = 1 AND CSRC = 1 | Single receive is complete | | | X | SYNC = 0 OR CSRC = 0 | Don't care | | # Bit 4 - CREN Continuous Receive Enable | Value | Condition | Description | |-------|-----------|-----------------------------------------------------------------------------------| | 1 | SYNC = 1 | Enables continuous receive until enable bit CREN is cleared (CREN overrides SREN) | | 0 | SYNC = 1 | Disables continuous receive | | 1 | SYNC = 0 | Enables receiver | | 0 | SYNC = 0 | Disables receiver | ### Bit 3 - ADDEN Address Detect Enable | Value | Condition | Description | |-------|-------------------------------------|------------------------------------------------------------------------------| | 1 | SYNC = 0 AND RX9 = 1 | The receive buffer is loaded and the interrupt occurs only when the ninth | | | | received bit is set | | 0 | <b>SYNC = </b> 0 <b>AND RX9 =</b> 1 | All bytes are received and interrupt always occurs. Ninth bit can be used as | | | | parity bit | | X | <b>RX9</b> = 0 <b>OR SYNC</b> = 1 | Don't care | # Bit 2 - FERR Framing Error | Value | Description | |-------|-----------------------------------------------------| | 1 | Unread byte in RCxREG has a framing error | | 0 | Unread byte in RCxREG does not have a framing error | #### Bit 1 - OERR Overrun Error | 1 | /alue | Description | |---|-------|--------------------------------------------------------------------| | - | _ | Overrun error (can be cleared by clearing either SPEN or CREN bit) | | ( | ) | No overrun error | # Bit 0 - RX9D Ninth bit of Received Data This can be address/data bit or a parity bit which is determined by user firmware. # 30.6.3 BAUDxCON Name: BAUDxCON Offset: 0x0612,0x061C # **Baud Rate Control Register** | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|-------|---|------|-------|---|-----|-------| | | ABDOVF | RCIDL | | SCKP | BRG16 | | WUE | ABDEN | | Access | R | R | | R/W | R/W | | R/W | R/W | | Reset | 0 | 0 | | 0 | 0 | | 0 | 0 | # Bit 7 - ABDOVF Auto-Baud Detect Overflow | Value | Condition | Description | |-------|-----------|----------------------------------| | 1 | SYNC = 0 | Auto-baud timer overflowed | | 0 | SYNC = 0 | Auto-baud timer did not overflow | | X | SYNC = 1 | Don't care | ### Bit 6 - RCIDL Receive Idle Flag | Value | Condition | Description | |-------|-----------|-----------------------------------------------------------| | 1 | SYNC = 0 | Receiver is Idle | | 0 | SYNC = 0 | Start bit has been received and the receiver is receiving | | X | SYNC = 1 | Don't care | ### Bit 4 – SCKP Clock/Transmit Polarity Select | Value | Condition | Description | |-------|-----------|-----------------------------------------------------------------------------| | 1 | SYNC = 0 | Idle state for transmit (TX) is a low level (transmit data inverted) | | 0 | SYNC = 0 | Idle state for transmit (TX) is a high level (transmit data is noninverted) | | 1 | SYNC = 1 | Data is clocked on rising edge of the clock | | 0 | SYNC = 1 | Data is clocked on falling edge of the clock | # Bit 3 - BRG16 16-bit Baud Rate Generator Select | Value | Description | |-------|------------------------------------| | 1 | 16-bit Baud Rate Generator is used | | 0 | 8-bit Baud Rate Generator is used | # Bit 1 - WUE Wake-Up Enable | Value | Condition | Description | |-------|-----------|----------------------------------------------------------------------------------------------| | 1 | SYNC = 0 | Receiver is waiting for a falling edge. Upon falling edge, no character will be received and | | | | the RCxIF flag will be set. WUE will automatically clear after RCxIF is set. | | 0 | SYNC = 0 | Receiver is operating normally | | X | SYNC = 1 | Don't care | #### Bit 0 - ABDEN Auto-Baud Detect Enable | Value | Condition | Description | | | | | | | | | |-------|-----------|----------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 1 | SYNC = 0 | Auto-Baud Detect mode is enabled (clears when auto-baud is complete) | | | | | | | | | | 0 | SYNC = 0 | Auto-Baud Detect is complete or mode is disabled | | | | | | | | | | X | SYNC = 1 | Don't care | | | | | | | | | # 30.6.4 RCxREG Name: RCxREG Offset: 0x060C,0x0616 Receive Data Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|------------|---|---|---|---|---|---|---|--|--| | | RCREG[7:0] | | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 7:0 - RCREG[7:0] Receive data # 30.6.5 TXxREG Name: TXxREG Offset: 0x060D,0x0617 Transmit Data Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |--------|------------|-----|-----|-----|-----|-----|-----|-----|--|--| | [ | TXREG[7:0] | | | | | | | | | | | Access | R/W | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Bits 7:0 - TXREG[7:0] Transmit Data # 30.6.6 SPxBRG Name: SPxBRG Offset: 0x060E,0x0618 **EUSART Baud Rate Generator** | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |--------|-----|-------------|-----|------|--------|-----|-------------------------|-----|--|--|--|--| | | | SPBRG[15:8] | | | | | | | | | | | | Access | R/W R/W R/W 0 0 0 0 0 0 | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | | SPBR | G[7:0] | | | | | | | | | Access | R/W | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Bits 15:0 - SPBRG[15:0] Baud Rate Register Notes: The individual bytes in this multibyte register can be accessed with the following register names: - SPxBRGH: Accesses the high byte SPBRG[15:8] - SPxBRGL: Accesses the low byte SPBRG[7:0] # 30.7 Register Summary - EUSART | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|----------|----------|--------|------------|------|------|---------|------|------|-------| | 0x00 | | | | | | | | | | | | <br>0x060B | Reserved | | | | | | | | | | | 0x060C | RC1REG | 7:0 | | | : | RCRE | G[7:0] | • | | - | | 0x060D | TX1REG | 7:0 | | | | TXRE | :G[7:0] | | | | | 0x060E | SD1DDC | 7:0 | | SPBRG[7:0] | | | | | | | | UXUOUE | SP1BRG | 15:8 | | | | SPBR | G[15:8] | | | | | 0x0610 | RC1STA | 7:0 | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | 0x0611 | TX1STA | 7:0 | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | | 0x0612 | BAUD1CON | 7:0 | ABDOVF | RCIDL | | SCKP | BRG16 | | WUE | ABDEN | | 0x0613 | Reserved | | | | | | | | | | | <br>0x0615 | Neserveu | | | | | | | | | | | 0x0616 | RC2REG | 7:0 | | | | RCRE | G[7:0] | | | | | 0x0617 | TX2REG | 7:0 | | | | TXRE | :G[7:0] | | | | | 0x0618 | SP2BRG | 7:0 | | | | SPBR | RG[7:0] | | | | | 030018 | SFZBRG | 15:8 | | | | SPBR | G[15:8] | | | | | 0x061A | RC2STA | 7:0 | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | 0x061B | TX2STA | 7:0 | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | | 0x061C | BAUD2CON | 7:0 | ABDOVF | RCIDL | | SCKP | BRG16 | | WUE | ABDEN | # 31. ADC - Analog-to-Digital Converter with Computation Module The Analog-to-Digital Converter with Computation module allows conversion of single-ended analog input signals to a 10-bit binary representation of that signal. This device uses analog inputs that are multiplexed into a single Sample-and-Hold circuit. The output of the Sample-and-Hold (S/H) circuit is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers. In single-ended conversions, the ADC measures the voltage between the selected analog input and $V_{SS}$ (0V). The selected ADC input channels can either be from an internal source, such as the Fixed Voltage Reference (FVR), or from external analog input pins. Additionally, the following features are provided within the ADC module: - Acquisition Timer - · Hardware Capacitive Voltage Divider (CVD) support: - Precharge timer - Adjustable Sample-and-Hold capacitor array - Guard ring digital output drive - · Automatic Repeat and Sequencing: - Automated double sample conversion for CVD - Two sets of Result registers (Current Result and Previous Result) - Auto-conversion trigger - Internal retrigger - Channel Grouping: - Allows multiple input channels to be grouped together into a single input channel - Computation Features: - Averaging and low-pass filter functions - Reference comparison - 2-level threshold comparison - Selectable interrupts Figure 43-1 shows the block diagram of the ADC. The ADC positive voltage reference is software selectable to be either internally generated or externally supplied. The ADC negative voltage reference is internally connected to V<sub>SS</sub>. The ADC can generate an interrupt upon completion of a conversion and upon threshold comparison. These interrupts can be used to wake up the device from Sleep. Figure 31-1. ADC Block Diagram #### **Positive Input Selection Multiplexers** **Note 1:** The internal input channel selections vary. The inputs shown are all possible input selections. Refer to the "**ADC Positive Input Channel Selection**" table for device-specific selection options. ### 31.1 ADC Configuration When configuring the ADC the following functions must be considered: - · Port Configuration - · Channel Selection - ADC Voltage Reference Selection - ADC Conversion Clock Source - Interrupt Control - · Result Formatting - · Conversion Trigger Selection - · ADC Acquisition Time - · ADC Precharge Time - · Additional Sample-and-Hold Capacitor - · Single/Double Sample Conversion - · Guard Ring Outputs ### 31.1.1 Port Configuration The ADC will convert the voltage level on a pin, whether or not the ANSEL bit is set. When converting analog signals, the I/O pin may be configured for analog by setting the associated TRIS and ANSEL bits. Refer to the "I/O Ports" chapter for more information. **Important:** Analog voltages on any pin defined as a digital input may cause the input buffer to conduct excess current. #### 31.1.2 Channel Selection The ADPCH register determines which input channels are connected to the Sample-and-Hold circuit for conversion. When switching channels, it is recommended to have some acquisition time (ADACQ register) before starting the next conversion. Refer to the ADC Operation section for more information. **Important:** To reduce the chance of measurement error, it is recommended to discharge the Sample-and-Hold capacitor when switching between ADC channels by starting a conversion on a channel connected to $V_{SS}$ and terminating the conversion after the acquisition time has elapsed. If the ADC does not have a dedicated $V_{SS}$ input channel, the $V_{SS}$ selection through the DAC output channel can be used. If the DAC is in use (or the device does not have a DAC), a free input channel can be connected to $V_{SS}$ , and can be used in place of the DAC. ### 31.1.2.1 Channel Grouping Channel grouping allows multiple, simultaneous input connections to the ADC. The ADC Channel Group Selection (ADCGxp, x = Group number, p = PORT) registers are used to enable each I/O port's analog input channels. A channel group includes all enabled inputs from each of the group's selection registers. All of the group's input signals are wire-OR'd into a single ADC positive input channel, ADCGx, which can be selected by the ADC Positive Input Channel Selection (PCH) bits. The example below illustrates the configuration of one channel group. #### 31.1.3 ADC Voltage Reference The PREF bits provide control of the positive voltage reference. Refer to the ADREF register for the list of available positive sources. #### 31.1.4 Conversion Clock The conversion clock source is selected with the CS bit. When CS = 1, the ADC clock source is an internal fixed-frequency clock referred to as ADCRC. When CS = 0, the ADC clock source is derived from $F_{OSC}$ . # ADC - Analog-to-Digital Converter with ... **Important:** When CS = 0, the clock can be divided using the ADCLK register to meet the ADC clock period requirements. The time to complete one bit conversion is defined as the $T_{AD}$ . Refer to Figure 31-2 for the complete timing details of the ADC conversion. For correct conversion, the appropriate T<sub>AD</sub> specification must be met. Refer to the ADC Timing Specifications table in the "**Electrical Specifications**" chapter of the device data sheet for more details. The table below gives examples of appropriate ADC clock selections. Table 31-1. ADC Clock Period (T<sub>AD</sub>) vs. Device Operating Frequencies<sup>(1,3)</sup> | ADC Clock | ADCLK | | ADC Clock Per | riod (T <sub>AD</sub> ) for Dif | ferent Device Fr | equency (F <sub>OSC</sub> ) | | |-----------------------|-------------------|-------------------------|-----------------------|---------------------------------|------------------------|-----------------------------|-------------------------| | Source | ADCLK | 32 MHz | 20 MHz | 16 MHz | 8 MHz | 4 MHz | 1 MHz | | F <sub>OSC</sub> /2 | <b>'</b> b0000000 | 62.5 ns <sup>(2)</sup> | 100 ns <sup>(2)</sup> | 125 ns <sup>(2)</sup> | 250 ns <sup>(2)</sup> | 500 ns | 2.0 µs | | F <sub>OSC</sub> /4 | <b>'</b> b000001 | 125 ns <sup>(2)</sup> | 200 ns <sup>(2)</sup> | 250 ns <sup>(2)</sup> | 500 ns | 1.0 µs | 4.0 µs | | F <sub>OSC</sub> /6 | <b>'</b> b000010 | 187.5 ns <sup>(2)</sup> | 300 ns <sup>(2)</sup> | 375 ns <sup>(2)</sup> | 750 ns | 1.5 µs | 6.0 µs | | F <sub>OSC</sub> /8 | <b>'</b> b000011 | 250 ns <sup>(2)</sup> | 400 ns <sup>(2)</sup> | 500 ns | 1.0 µs | 2.0 µs | 8.0 µs | | | | | | | | | | | F <sub>OSC</sub> /16 | <b>'</b> b000111 | 500 ns | 800 ns | 1.0 µs | 2.0 µs | 4.0 µs | 16.0 µs <sup>(2)</sup> | | | | | | | | | | | F <sub>OSC</sub> /32 | <b>'</b> b001111 | 1.0 µs | 1.6 µs | 2.0 µs | 4.0 µs | 8.0 µs | 32.0 μs <sup>(2)</sup> | | | | | | | | | | | F <sub>OSC</sub> /64 | <b>'</b> b0111111 | 2.0 µs | 3.2 µs | 4.0 µs | 8.0 µs | 16.0 µs <sup>(2)</sup> | 64.0 µs <sup>(2)</sup> | | | | | | | | | | | F <sub>OSC</sub> /128 | <b>'</b> b111111 | 4.0 µs | 6.4 µs | 8.0 µs | 16.0 μs <sup>(2)</sup> | 32.0 µs <sup>(2)</sup> | 128.0 µs <sup>(2)</sup> | | ADCRC | <b>CS</b> = 1 | 1.0-6.0 µs | 1.0-6.0 µs | 1.0-6.0 µs | 1.0-6.0 µs | 1.0-6.0 µs | 1.0-6.0 µs | #### Notes: - Refer to the "Electrical Specifications" chapter of the device data sheet to see the T<sub>AD</sub> parameter for the ADCRC source typical T<sub>AD</sub> value. - 2. These values violate the required T<sub>AD</sub> time. - 3. The ADC clock period (T<sub>AD</sub>) and total ADC conversion time can be minimized when the ADC clock is derived from the system clock F<sub>OSC</sub>. However, the ADCRC oscillator source must be used when conversions are to be performed with the device in Sleep mode. #### Important: - Except for the ADCRC clock source, any changes in the system clock frequency will change the ADC clock frequency, which may adversely affect the ADC result. - The internal control logic of the ADC runs off of the clock selected by the CS bit. When the CS bit is set to '1' (ADC runs on ADCRC), there may be unexpected delays in operation when setting the ADC control bits. Figure 31-2. Analog-to-Digital Conversion Cycles #### Notes: - 1. Refer to the ADC Conversion Timing Specifications table in the "Electrical Specifications" chapter of the device data sheet for more details. - 2. Refer to the ADPRE register for more details. - 3. Refer to the ADACQ register for more details. ### 31.1.5 Interrupts The ADC module allows for the ability to generate an interrupt upon completion of an Analog-to-Digital Conversion. The ADC interrupt flag is the ADIF bit in the PIRx register. The ADC interrupt enable is the ADIE bit in the PIEx register. The ADIF bit must be cleared by software. #### Important: - The ADIF bit is set at the completion of every conversion, regardless of whether or not the ADC interrupt is enabled. - The ADC operates during Sleep only when the ADCRC oscillator is selected. The ADC Interrupt can be generated while the device is operating or while in Sleep. While the device is operating in Sleep mode: - If ADIE = 1, PEIE = 1, and GIE = 0: An interrupt will wake the device from Sleep. Upon waking from Sleep, the instructions following the SLEEP instruction are executed. The Interrupt Service Routine is not executed. - If ADIE = 1, PEIE = 1, and GIE = 1: An interrupt will wake the device from Sleep. Upon waking from Sleep, the instruction following the SLEEP instruction is always executed. Then the execution will switch to the Interrupt Service Routine. #### 31.1.6 Result Formatting The ADC conversion result can be supplied in two formats: Left justified or right justified. The FM bit controls the output format as shown in the figure below. Figure 31-3. 10-Bit ADC Conversion Result Format **Important:** Writes to the ADRES register pair are always right justified, regardless of the selected format mode. Therefore, a data read after writing to ADRES when FM = 0 will be shifted left five places. ### 31.2 ADC Operation #### 31.2.1 Starting a Conversion To enable the ADC module, the ON bit must be set to '1'. A conversion may be started by any of the following: - · Software setting the GO bit to '1' - An external trigger (source selected by ADACT) - A Continuous-mode retrigger (see the Continuous Sampling Mode section for more details) **Important:** The GO bit must not be set in the same instruction that turns on the ADC. Refer to the ADC Conversion Procedure (Basic Mode) section for more details. ### 31.2.2 Completion of a Conversion When any individual conversion is complete, the existing value in ADRES is written into ADPREV (if PSIS = 0) and the new conversion results appear in ADRES. When the conversion completes, the ADC module will: - · Clear the GO bit (unless the CONT bit is set) - · Set the ADIF Interrupt Flag bit - · Set the MATH bit - Update ADACC After every conversion when DSEN = 0, or after every other conversion when DSEN = 1, the following events occur: - · ADERR is calculated - ADC Channel Threshold Interrupt (ADCHxIF) is set if ADERR calculation meets threshold comparison ### 31.2.3 ADC Operation During Sleep The ADC module can operate during Sleep. This requires the ADC clock source to be set to the ADCRC option. When the ADCRC oscillator source is selected, the ADC waits one additional instruction before starting the ## ADC - Analog-to-Digital Converter with ... conversion. This allows the SLEEP instruction to be executed, which can reduce system noise during the conversion. If the ADC interrupt is enabled, the device will wake up from Sleep when the conversion completes. If the ADC interrupt is disabled, the device remains in Sleep and the ADC module is turned off after the conversion completes, although the ON bit remains set. #### 31.2.4 **External Trigger During Sleep** If the external trigger is received during Sleep while the ADC clock source is set to the ADCRC, the ADC module will perform the conversion and set the ADIF bit upon completion. If an external trigger is received when the ADC clock source is something other than ADCRC, the trigger will be recorded, but the conversion will not begin until the device exits Sleep. #### 31.2.5 **Auto-Conversion Trigger** The auto-conversion trigger allows periodic ADC measurements without software intervention. When a rising edge of the selected source occurs, the GO bit is set by hardware. The auto-conversion trigger source is selected with the ACT bits. Using the auto-conversion trigger does not ensure proper ADC timing. It is the user's responsibility to ensure that the ADC timing requirements are met. #### 31,2,6 **ADC Conversion Procedure (Basic Mode)** This is an example procedure for using the ADC to perform an Analog-to-Digital Conversion: - Configure Port: - Disable pin output driver (refer to the TRISx register) - Configure pin as analog (refer to the ANSELx register) - Configure the ADC module: - a. Select ADC conversion clock - b. Configure voltage reference - Select ADC input channel C. - d. Configure precharge (ADPRE) and acquisition (ADACQ) time period - Turn on ADC module - Configure ADC interrupt (optional): - a. Clear ADC interrupt flag - b. Enable ADC interrupt - Enable global interrupt (GIE bit)(1) - If ADACQ != 0, software must wait the required acquisition time<sup>(2)</sup>. - Start conversion by setting the GO bit. - Wait for ADC conversion to complete by one of the following: - Polling the GO bit - Waiting for the ADC interrupt (if interrupt is enabled) - Read ADC Result. - Clear the ADC interrupt flag (if interrupt is enabled). 8. ### Notes: - With global interrupts disabled (GIE = 0), the device will wake from Sleep, but will not enter an Interrupt Service Routine. - Refer to the ADC Acquisition Requirements section for more details. ``` Example 31-2. ADC Conversion (Single-Ended Input) /*This code block configures the ADC for polling, V_{DD} and V_{SS} references, ADCRC oscillator Conversion start & polling for completion are included. ``` ``` void main() initializeSystem(); //System Initialize //Setup ADC ADCONObits.FM = 1; //Right justify ADCONObits.CS = 1; //ADCRC Clock ADPCH = 0x00; //RAO is positive input TRISAbits.TRISA0 = 1; //Set RAO to input ANSELAbits.ANSELA0 = 1; //Set RA0 to analog ADACQ = 32; //Set acquitisition time ADCONObits.ON = 1; //Turn ADC On while (1) ADCONObits.GO = 1; //Start conversion while (ADCONObits.GO); //Wait for conversion done resultHigh = ADRESH; //Read result resultLow = ADRESL; //Read result ``` ## 31.3 ADC Acquisition Requirements For the ADC to meet its specified accuracy, the charge holding capacitor ( $C_{HOLD}$ ) must be allowed to fully charge to the input channel voltage level. The analog input model is shown in Figure 31-4. The source impedance ( $R_S$ ) and the internal sampling switch ( $R_{SS}$ ) impedance directly affect the time required to charge the capacitor $C_{HOLD}$ . The sampling switch ( $R_{SS}$ ) impedance varies over the device voltage ( $V_{DD}$ ). The maximum recommended impedance for analog sources is 10 k $\Omega$ . As the source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an ADC acquisition time must be completed before the conversion can be started. To calculate the minimum acquisition time, Equation 31-1 may be used. This equation assumes an error of 1/2 LSb. The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution. #### **Equation 31-1. Acquisition Time Example** Assumptions: Temperature = $50^{\circ}$ C; External impedance = $10 \text{ k}\Omega$ ; $V_{DD}$ = 5.0V T<sub>ACQ</sub> = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient $$T_{ACO} = T_{AMP} + T_C + T_{COFF}$$ $$T_{ACQ} = 2 \mu s + T_C + \left[ \left( Temperature - 25^{\circ}C \right) \left( 0.05 \mu s / ^{\circ}C \right) \right]$$ The value for T<sub>C</sub> can be approximated with the following equations: $$V_{APPLIED} \left( 1 - \frac{1}{\left(2^{n+1}\right) - 1} \right) = V_{CHOLD}$$ ; [1] $V_{CHOLD}$ charged to within ½ LSb $$V_{APPLIED} \left(1 - e^{\frac{-T_C}{RC}}\right) = V_{CHOLD}$$ ; [2] $V_{CHOLD}$ charge response to $V_{APPLIED}$ $$V_{APPLIED} \left(1 - e^{\frac{-T_C}{RC}}\right) = V_{APPLIED} \left(1 - \frac{1}{\left(2^{n+1}\right) - 1}\right)$$ ; Combining [1] and [2] Note: Where n = ADC resolution in bits Solving for T<sub>C</sub>: $$T_C = -C_{HOLD}(R_{IC} + R_{SS} + R_S) \ln (1/2047)$$ $$T_C = -10 \, pF(1 \, k\Omega + 7 \, k\Omega + 10 \, k\Omega) \, ln \, (0.0004885)$$ $$T_C = 1.37 \, \mu s$$ Therefore: $$T_{ACQ} = 2 \mu s + 1.37 \mu s + [(50^{\circ}C - 25^{\circ}C) (0.05 \mu s/^{\circ}C)]$$ $T_{ACQ} = 4.62 \mu s$ #### Important: - The reference voltage ( $V_{\text{REF}}$ ) has no effect on the equation, since it cancels itself out - The charge holding capacitor (C<sub>HOLD</sub>) is not discharged after each conversion - The maximum recommended impedance for analog sources is 10 k $\Omega$ . This is required to meet the pin leakage specification. Figure 31-4. Analog Input Model Note: Legend: CPIN = Input Capacitance ILEAKAGE = Leakage Current at the pin due to various junctions = Interconnect Resistance Rs = Source Impedance VA Vт SS Rss CHOLD Sampling Switch Rss = Analog Voltage $(K\Omega)$ = Diode Forward Voltage = Sampling Switch = Resistance of the Sampling Switch = Sample/Hold Capacitance 3 4 5 6 VDD (V) 1. Refer to the "Electrical Specifications" chapter of the device data sheet for more details. Figure 31-5. ADC Transfer Function # 31.4 Computation Operation The ADC module hardware is equipped with post-conversion computation features. These features provide post-processing functions such as digital filtering/averaging and threshold comparison. Based on computation results, the module can be configured to take additional samples or stop conversions and an interrupt may be asserted. Figure 31-6. Computational Features Simplified Block Diagram The operation of the ADC computational features is controlled by the MD bits. The module can be operated in one of five modes: - **Basic:** This is a Legacy mode. In this mode, ADC conversion occurs on single (DSEN = 0) or double (DSEN = 1) samples. ADIF is set after each conversion is complete. ADCHxIF is set according to the Calculation mode. - Accumulate: With each trigger, the ADC conversion result is added to the accumulator and ADCNT increments. ADIF is set after each conversion. ADCHxIF is set according to the Calculation mode. # PIC16F18015/25/44/45 ## ADC - Analog-to-Digital Converter with ... - Average: With each trigger, the ADC conversion result is added to the accumulator. When the RPT number of samples have been accumulated, a threshold test is performed. Upon the next trigger, the accumulator is cleared. For the subsequent tests, additional RPT samples are required to be accumulated. - Burst Average: At the trigger, the accumulator is cleared. The ADC conversion results are then collected repetitively until RPT samples are accumulated and finally the threshold is tested. - Low-Pass Filter (LPF): With each trigger, the ADC conversion result is sent through a filter. When RPT samples have occurred, a threshold test is performed. Every trigger after that, the ADC conversion result is sent through the filter and another threshold test is performed. The five modes are summarized in the following table. Table 31-2. Computation Modes | | : | Register Clear<br>Event | Value after Cycle <sup>(1)</sup> | e <sup>(1)</sup> Completion | T. | Threshold Operations | Su | Value at | Value at ADCHmIF Interrupt | rupt | |-----------------|---|--------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------|----------------------|-------------------|-------------------|--------------------------------------------|-------| | Miode | 2 | ADACC and CNT | ADACC | ADCNT | Retrigger | Threshold Test | Interrupt | AOV | ADFLTR | ADCNT | | Basic | 0 | ACLR = 1 | Unchanged | Unchanged | N <sub>O</sub> | Every Sample | If threshold=true | N/A | N/A | count | | Accumulate | - | <b>ACLR</b> = 1 | S1 + ADACC<br>or (S2-S1) <sup>(2)</sup> +<br>ADACC | If (ADCNT = 0xFF): ADCNT, otherwise: ADCNT+1 | o<br>Z | Every Sample | If threshold=true | ADACC | ADACC/2 <sup>CRS</sup> | count | | Average | 2 | ACLR = 1 or ADCNT ≥ ADRPT at GO set or retrigger | S1 + ADACC or<br>(S2-S1) + ADACC | If (ADCNT = 0×FF): ADCNT, otherwise: ADCNT+1 | o<br>Z | If ADCNT ≥<br>ADRPT | If threshold=true | ADACC<br>Overflow | ADACC/2 <sup>CRS</sup> | count | | Burst Average | က | ACLR = 1 or at<br>GO set or<br>retrigger | Each repetition:<br>same as Average<br>End with sum of all<br>samples | Each repetition:<br>same as Average<br>End with ADCNT<br>= ADRPT | Repeat while<br>ADCNT <<br>ADRPT | If ADCNT ≥<br>ADRPT | If threshold=true | ADACC<br>Overflow | ADACC/2 <sup>CRS</sup> ADRPT | ADRPT | | Low-pass Filter | 4 | ACLR = 1 | S1 + ADACC-<br>ADACC/<br>2 <sup>CRS</sup> or (S2-S1)<br>+ ADACC-ADACC/<br>2 <sup>CRS</sup> | If (ADCNT = 0xFF): ADCNT, otherwise: ADCNT+1 | o<br>Z | If ADCNT ≥<br>ADRPT | If threshold=true | ADACC | ADACC/2 <sup>CRS</sup><br>(Filtered Value) | count | | Notes: | | | | | | | | | | | When DSEN = 0, Cycle means one conversion. When DSEN = 1, Cycle means two conversions. -: 2 S1 and S2 are abbreviations for Sample 1 and Sample 2, respectively. When DSEN = 0, S1 = ADRES; when DSEN = 1, S1 = ADPREV and S2 = ADRES. ### 31.4.1 Digital Filter/Average The digital filter/average module consists of an accumulator with data feedback options, and control logic to determine when threshold tests need to be applied. The accumulator can be accessed through the ADACC register. Upon each trigger event (the GO bit set or external event trigger), the ADC conversion result is added to or subtracted from the accumulator. If the accumulated value exceeds 2<sup>(accumulator\_width)</sup> - 1 = 2<sup>18</sup> - 1 = 262143, the AOV overflow bit is set. The number of samples to be accumulated is determined by the ADRPT (ADC Repeat Setting) register. Each time a sample is added to the accumulator, the ADCNT register is incremented. Once the ADRPT samples are accumulated (ADCNT = ADRPT), the accumulator may be cleared automatically depending on ADC Operation mode. An accumulator clear command can be issued in software by setting the ACLR bit. Setting the ACLR bit will also clear the AOV (Accumulator Overflow) bit, as well as the ADCNT register. The ACLR bit is cleared by the hardware when accumulator clearing action is complete. **Important:** When ADC is operating from ADCRC, up to five ADCRC clock cycles are required to execute the ADACC clearing operation. The CRS bits control the data shift on the accumulator result, which effectively divides the value in the accumulator registers. For the Accumulate mode of the digital filter, the shift provides a simple scaling operation. For the Average/Burst Average mode, the calculated average is only accurate when the number of samples agrees with the number of bits shifted. For the Low-Pass Filter mode, the shift is an integral part of the filter, and determines the cutoff frequency of the filter. Table 31-3 shows the -3 dB cutoff frequency in $\omega T$ (radians) and the highest signal attenuation obtained by this filter at Nyquist frequency ( $\omega T = \pi$ ). Table 31-3. Low-Pass Filter -3 dB Cutoff Frequency | CRS | ωT (radians) @ -3 dB Frequency | dB @ F <sub>Nyquist</sub> = 1/(2T) | |-----|--------------------------------|------------------------------------| | 1 | 0.72 | -9.5 | | 2 | 0.284 | -16.9 | | 3 | 0.134 | -23.5 | | 4 | 0.065 | -29.8 | | 5 | 0.032 | -36.0 | | 6 | 0.016 | -42.0 | #### 31.4.2 Basic Mode Basic mode (MD = 'b000) disables all additional computation features. In this mode, no accumulation occurs but threshold error comparison is performed. Double sampling, Continuous mode, and all CVD features are still available, but no digital filter/average calculations are performed. #### 31.4.3 Accumulate Mode In Accumulate mode (MD = `b001), after every conversion, the ADC result is added to the ADACC register. The ADACC register is right-shifted by the value of the CRS bits. This right-shifted value is copied into the ADFLTR register. The Formatting mode does not affect the right-justification of the ADACC or ADFLTR values. Upon each sample, ADCNT is incremented, counting the number of samples accumulated. After each sample and accumulation, the ADFLTR value has a threshold comparison performed on it (see the Threshold Comparison section) and the ADCHxIF interrupt may trigger. #### 31.4.4 Average Mode In Average mode (MD = `b010), the ADACC registers accumulate with each ADC sample, much as in Accumulate mode, and the ADCNT register increments with each sample. The ADFLTR register is also updated with the right-shifted value of the ADACC register. The value of the CRS bits governs the number of right shifts. However, in Average mode, the threshold comparison is performed upon ADCNT being greater than or equal to a user-defined ## ADC - Analog-to-Digital Converter with ... ADRPT value. In this mode, when ADRPT = $2^{CRS}$ , the final accumulated value will be divided by the number of samples, allowing for a threshold comparison operation on the average of all gathered samples. #### 31.4.5 Burst Average Mode The Burst Average mode (MD = `b011) acts the same as the Average mode in most respects. The one way it differs is that it continuously retriggers ADC sampling until the CNT value is equal to RPT, even if Continuous Sampling mode (see Continuous Sampling Mode) is not enabled. This provides a threshold comparison on the average of a short burst of ADC samples. #### 31.4.6 Low-Pass Filter Mode The Low-Pass Filter mode (MD = 'b100) acts similarly to the Average mode in how it handles samples; it accumulates samples until the CNT value is greater than or equal to RPT, then triggers a threshold comparison. But, instead of a simple average, it performs a low-pass filter operation on all of the samples, reducing the effect of high-frequency noise on the total, then performs a threshold comparison on the results. In this mode, the CRS bits determine the cutoff frequency of the low-pass filter (as demonstrated by Digital Filter/Average). Refer to the Computation Operation section for a more detailed description of the mathematical operation. For more information about Low-Pass Filter mode, refer to the following Microchip application note, available in the corporate website (www.microchip.com): • AN2749, "PIC18 12-bit ADCC in Low-Pass Filter Mode" #### 31.4.7 Threshold Comparison At the end of each computation: - The conversion results are captured at the end-of-conversion. - The error (ADERR) is calculated based on a difference calculation which is selected by the CALC bits. The value can be one of the following calculations: - The first derivative of single measurements - The CVD result when double sampling is enabled - The current result vs. setpoint value in the ADSTPT register - The current result vs. the filtered/average result - The first derivative of the filtered/average value - Filtered/average value vs. setpoint value in the ADSTPT register - The result of the calculation (ADERR) is compared to the upper and lower thresholds, ADUTH and ADLTH registers, to set the UTHR and LTHR Status bits. The threshold logic is selected by the TMD bits. The threshold trigger option can be one of the following: - Never interrupt - Error is less than lower threshold - Error is greater than or equal to lower threshold - Error is between thresholds (inclusive) - Error is outside of thresholds - Error is less than or equal to upper threshold - Error is greater than upper threshold - Always interrupt regardless of threshold test results - If the Threshold condition is met, the channel threshold interrupt flag ADCHxIF is set. #### Important: - · The threshold tests are signed operations. - If the AOV bit is set, a threshold interrupt is signaled. It is good practice for threshold interrupt handlers to verify the validity of the threshold by checking the AOV bit. ### 31.4.8 Repetition and Sampling Options #### 31.4.8.1 Continuous Sampling Mode Setting the CONT bit automatically retriggers a new conversion cycle after updating the ADACC register. That means the GO bit remains set to generate automatic retriggering. If SOI = 1, a Threshold Interrupt condition will clear the GO bit and the conversion will stop. #### 31.4.8.2 Double Sample Conversion Double sampling is enabled by setting the DSEN bit. When this bit is set, two conversions are required before the module calculates the threshold error. Each conversion must be triggered separately when CONT = 0, but will repeat automatically form a single trigger when CONT = 1. The first conversion will set the MATH bit and update the ADACC register, but will not calculate ADERR or trigger ADCHnIF. When the second conversion completes, the first value is transferred to ADPREV (depending on the setting of PSIS) and the value of the second conversion is placed into ADRES. Only upon the completion of the second conversion is ADERR calculated and ADCHnIF triggered (depending on the value of CALC). #### 31.4.9 Capacitive Voltage Divider (CVD) Features The ADC module contains several features that allow the user to perform a relative capacitance measurement on any ADC channel using the internal ADC Sample-and-Hold capacitance as a reference. This relative capacitance measurement can be used to implement capacitive touch or proximity sensing applications. The following figure shows the basic block diagram of the CVD portion of the ADC module. Figure 31-7. Hardware Capacitive Voltage Divider Block Diagram This is an example to configure ADC for CVD operation: - 1. Configure Port: - a. Disable pin output driver (refer to the TRISx register) - b. Configure pin as analog (refer to the ANSELx register) - 2. Configure the ADC module: - a. Select ADC conversion clock - b. Configure voltage reference - c. Select ADC input channel - d. Configure precharge (ADPRE) and acquisition (ADACQ) time period - e. Select precharge polarity (PPOL) - f. Enable Double Sampling (DSEN) # PIC16F18015/25/44/45 ## ADC - Analog-to-Digital Converter with ... - g. Turn on ADC module - Configure ADC interrupt (optional): - a. Clear ADC interrupt flag - b. Enable ADC interrupt - c. Enable global interrupt (GIE bit)<sup>(1)</sup> - 4. Start double sample conversion by setting the GO bit. - 5. Wait for ADC conversion to complete by one of the following: - Polling the GO bit - Waiting for the ADC interrupt (if interrupt is enabled) - 6. Second ADC conversion depends on the state of CONT: - a. If CONT = 1, both conversion will repeat automatically form a single trigger. - If CONT = 0, each conversion must be triggered separately. - The ADERR register contains the CVD result. - Clear the ADC interrupt flag (if interrupt is enabled). #### Note: 1. With global interrupts disabled (GIE = 0), the device will wake from Sleep, but will not enter an Interrupt Service Routine. #### 31.4.9.1 CVD Operation A CVD operation begins with the ADC's internal Sample-and-Hold capacitor ( $C_{HOLD}$ ) being disconnected from the path, which connects it to the external capacitive sensor node. While disconnected, $C_{HOLD}$ is precharged to $V_{DD}$ or discharged to $V_{SS}$ . If the PCSC bit is clear, the sensor node is either discharged or charged to $V_{SS}$ or $V_{DD}$ , respectively to the opposite level of $C_{HOLD}$ . If PCSC is set, the external capacitive sensor node receives no precharge. When the precharge phase is complete, the $V_{DD}/V_{SS}$ bias paths for the two nodes are disconnected and the paths between $C_{HOLD}$ and the external sensor node is reconnected, at which time the acquisition phase of the CVD operation begins. During acquisition, a capacitive voltage divider is formed between the precharged $C_{HOLD}$ and sensor nodes, which results in a final voltage level setting on $C_{HOLD}$ , which is determined by the capacitances and precharge levels of the two nodes. After acquisition, the ADC converts the voltage level on $C_{HOLD}$ . This process is then repeated with the selected precharge levels inverted for both the $C_{HOLD}$ and the sensor nodes. The waveform for two CVD measurements, which is known as differential CVD measurement, is shown in the following figure. Figure 31-8. Differential CVD Measurement Waveform **Note 1:** External Capacitive Sensor voltage during the conversion phase may vary as per the configuration of the corresponding pin. #### 31.4.9.2 Precharge Control The precharge stage is the period of time that brings the external channel and internal Sample-and-Hold capacitor to known voltage levels. Precharge is enabled by writing a nonzero value to the ADPRE register. This stage is initiated when an ADC conversion begins, either from setting the GO bit, a Special Event Trigger, or a conversion restart from the computation functionality. If the ADPRE register is cleared when an ADC conversion begins, this stage is skipped. The Precharge Sample Capacitor Only (PCSC) bit can be used to disable the precharge stage to the external channel. During the precharge time, $C_{HOLD}$ is disconnected from the outer portion of the sample path that leads to the external capacitive sensor and is connected to either $V_{DD}$ or $V_{SS}$ , depending on the value of the PPOL bit. At the same time, when PCSC is clear (PCSC = 0), the port pin logic of the selected analog channel is overridden to drive a digital high or low out, to precharge the outer portion of the ADC's sample path, which includes the external sensor. The output polarity of this override is determined by the PPOL bit such that the external sensor cap is charged opposite that of the internal $C_{HOLD}$ cap. If PCSC is set (PCSC = 1), the outer portion of the ADC's sample path is disconnected, preventing the precharge from occurring on the external channel. The amount of time for precharge is controlled by the ADPRE register. **Important:** The external charging overrides the TRIS/LAT/Guard outputs setting of the respective I/O pin. If there is a device attached to this pin, the PCSC bit will be set, or precharge will not be used. #### 31.4.9.3 Acquisition Control for CVD (ADPRE > 0) The acquisition stage allows time for the voltage on the internal Sample-and-Hold capacitor to charge or discharge from the selected analog channel. This acquisition time is controlled by the ADACQ register. The acquisition stage begins when precharge stage ends. At the start of the acquisition stage, the port pin logic of the selected analog channel is overridden to turn off the digital high/low output drivers so they do not affect the final result of the charge averaging. Also, the selected ADC channel is connected to $C_{HOLD}$ . This allows charge averaging to proceed between the precharged channel and the $C_{HOLD}$ capacitor. **Important:** When ADPRE > 0, setting ADACQ to '0' will set a maximum acquisition time. When precharge is disabled, setting ADACQ to '0' will disable hardware acquisition time control. #### 31.4.9.4 Guard Ring Outputs Figure 31-9 shows a typical guard ring circuit. $C_{GUARD}$ represents the capacitance of the guard ring trace placed on the PCB. The user selects values for $R_A$ and $R_B$ that will create a voltage profile on $C_{GUARD}$ , which will match the selected acquisition channel. The purpose of the guard ring is to generate a signal in phase with the CVD sensing signal to minimize the effects of the parasitic capacitance on sensing electrodes. It also can be used as a mutual drive for mutual capacitive sensing. For more information about active guard and mutual drive, refer to the following Microchip application note, available on the corporate website (www.microchip.com): • AN1478, "mTouch<sup>TM</sup> Sensing Solution Acquisition Methods Capacitive Voltage Divider" The ADC has two guard ring drive outputs, ADGRDA and ADGRDB. These outputs are routed through PPS controls to I/O pins. Refer to the "Peripheral Pin Select (PPS) Module" chapter for more details. The polarity of these outputs is controlled by the GPOL and IPEN bits. At the start of the first precharge stage, both outputs are set to match the GPOL bit. Once the acquisition stage begins, ADGRDA changes polarity, while ADGRDB remains unchanged. When performing a double sample conversion, setting the IPEN bit causes both guard ring outputs to transition to the opposite polarity of GPOL at the start of the second precharge stage, and ADGRDA toggles again for the second acquisition. For more information on the timing of the guard ring output, refer to Figure 31-10. Figure 31-9. Guard Ring Circuit Figure 31-10. Differential CVD with Guard Ring Output Waveform Note 1: External Capacitive Sensor voltage during the conversion phase may vary as per the configuration of the corresponding pin. #### 31.4.9.5 Additional Sample-and-Hold Capacitance Additional capacitance can be added in parallel with the internal Sample-and-Hold capacitor (C<sub>HOLD</sub>) by using the ADCAP register. This register selects a digitally programmable capacitance that is added to the ADC conversion bus, increasing the effective internal capacitance of the Sample-and-Hold capacitor in the ADC module. This is used to improve the match between internal and external capacitance for a better sensing performance. The additional capacitance does not affect analog performance of the ADC because it is not connected during conversion. # 31.5 Register Definitions: ADC Control Long bit name prefixes for the ADC peripherals are shown in the following table. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 31-4. ADC Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | ADC | AD | #### 31.5.1 ADCON0 Name: ADCON0 Offset: 0x1D26 ### ADC Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|------|---|-----|---|-----|---|-----------| | | ON | CONT | | cs | | FM | | GO | | Access | R/W | R/W | • | R/W | • | R/W | | R/W/HC/HS | | Reset | 0 | 0 | | 0 | | 0 | | 0 | ### Bit 7 - ON ADC Enable | Value | Description | |-------|-----------------| | 1 | ADC is enabled | | 0 | ADC is disabled | #### Bit 6 - CONT ADC Continuous Operation Enable | Value | Description | |-------|----------------------------------------------------------------------------------------------------------| | 1 | GO is retriggered upon completion of each conversion trigger until ADTIF is set (if SOI is set) or until | | | GO is cleared (regardless of the value of SOI) | | 0 | ADC is cleared upon completion of each conversion trigger | #### Bit 4 - CS ADC Clock Selection | 1 | /alue | Description | |----|-------|------------------------------------------------------------------------------| | [1 | | Clock supplied from ADCRC dedicated oscillator | | ( | ) | Clock supplied by F <sub>OSC</sub> , divided according to the ADCLK register | ### Bit 2 - FM ADC Results Format/Alignment Selection | Value | Description | |-------|-------------------------------------------| | 1 | ADRES and ADPREV data are right justified | | 0 | ADRES and ADPREV data are left justified | #### Bit 0 - GO ADC Conversion Status<sup>(1,2)</sup> | | 7.2.5.5.11.11.11.11.11.11.11.11.11.11.11.11 | |-------|----------------------------------------------------------------------------------------------------------| | Value | Description | | 1 | ADC conversion cycle in progress. Setting this bit starts an ADC conversion cycle. The bit is cleared by | | | hardware as determined by the CONT bit. | | 0 | ADC conversion completed/not in progress | #### Notes: - 1. This bit requires the ON bit to be set. - If cleared by software while a conversion is in progress, the results of the conversion up to this point will be transferred to ADRES and the state machine will be reset, but the ADIF Interrupt Flag bit will not be set; filter and threshold operations will not be performed. ### 31.5.2 ADCON1 Name: ADCON1 Offset: 0x1D27 ADC Control Register 1 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|------|------|---|---|---|------|------| | | PPOL | IPEN | GPOL | | | | PCSC | DSEN | | Access | R/W | R/W | R/W | | | | R/W | R/W | | Reset | 0 | 0 | 0 | | | | 0 | 0 | ### Bit 7 - PPOL Precharge Polarity Action During 1st Precharge Stage | Value | Condition | Description | |-------|-----------|-------------------------------------------------------------------------------------------------------------------------| | Х | ADPRE = 0 | Bit has no effect | | 1 | ADPRE > 0 | External analog I/O pin is connected to $V_{DD}$ Internal AD sampling capacitor ( $C_{HOLD}$ ) is connected to $V_{SS}$ | | 0 | ADPRE > 0 | External analog I/O pin is connected to $V_{SS}$ Internal AD sampling capacitor ( $C_{HOLD}$ ) is connected to $V_{DD}$ | ### Bit 6 - IPEN A/D Inverted Precharge Enable | Va | lue | Condition | Description | |----|-----|-----------|-------------------------------------------------------------------------------------------------------------| | X | | DSEN = 0 | Bit has no effect | | 1 | | DSEN = 1 | The precharge and guard signals in the second conversion cycle are the opposite polarity of the first cycle | | 0 | | DSEN = 1 | Both Conversion cycles use the precharge and guards specified by PPOL and GPOL | ### Bit 5 - GPOL Guard Ring Polarity Selection | Value | Description | |-------|---------------------------------------------------------------------| | 1 | ADC guard Ring outputs start as digital high during Precharge stage | | 0 | ADC guard Ring outputs start as digital low during Precharge stage | #### Bit 1 - PCSC Precharge Sample Capacitor Only | | Bit 1 1 900 Fredharge dampie dapacitor only | | | | | |-------|------------------------------------------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | Precharge only applies to the internal sampling capacitor | | | | | | 0 | Precharge applies to both the internal sampling capacitor and the external I/O pin | | | | | ### Bit 0 - DSEN Double-Sample Enable | Value | Description | | |-------|---------------------------------------------------------------------------------------------------|--| | 1 | Two conversions are processed as a pair. The selected computation is performed after every second | | | | conversion. | | | 0 | Selected computation is performed after every conversion | | #### 31.5.3 ADCON2 Name: ADCON2 Offset: 0x1D28 ADC Control Register 2 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|-----|----------|-----|--------|-----|---------|-----| | | PSIS | | CRS[2:0] | | ACLR | | MD[2:0] | | | Access | R/W | R/W | R/W | R/W | R/W/HC | R/W | R/W | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - PSIS ADC Previous Sample Input Select | Value | Description | |-------|------------------------------------------------------------| | 1 | ADFLTR is transferred to ADPREV at the start of conversion | | 0 | ADRES is transferred to ADPREV at the start of conversion | #### Bits 6:4 - CRS[2:0] ADC Accumulated Calculation Right Shift Select | Value | Condition | Description | |--------|----------------------|-----------------------------------------------------------------------------------------------| | 1 to 6 | MD = 'b100 | Low-pass filter time constant is 2 <sup>CRS</sup> , filter gain is 1:1 <sup>(2)</sup> | | 1 to 6 | MD = 'b011 to 'b001 | The accumulated value is right-shifted by CRS (divided by 2 <sup>CRS</sup> ) <sup>(1,2)</sup> | | X | MD = 'b0000 or 'b111 | These bits are ignored | ### Bit 3 - ACLR A/D Accumulator Clear Command<sup>(3)</sup> | Value | Description | |-------|-------------------------------------------------------| | 1 | Registers ADACC and ADCNT and the AOV bit are cleared | | 0 | Clearing action is complete (or not started) | ### Bits 2:0 - MD[2:0] ADC Operating Mode Selection<sup>(4)</sup> | Value | Description | |---------|----------------------| | 111-101 | Reserved | | 100 | Low-Pass Filter mode | | 011 | Burst Average mode | | 010 | Average mode | | 001 | Accumulate mode | | 000 | Basic (Legacy) mode | ### Notes: - To correctly calculate an average, the number of samples (set in ADRPT) must be 2<sup>CRS</sup>. - 2. CRS = 'b111 and 'b000 are reserved. - 3. This bit is cleared by hardware when the accumulator operation is complete; depending on oscillator selections, the delay may be many instructions. - 4. See the "Computation Operation" section for full mode descriptions. ### 31.5.4 ADCON3 Name: ADCON3 Offset: 0x1D29 ADC Control Register 3 Bits 6:4 - CALC[2:0] ADC Error Calculation Mode Select ### Table 31-5. ADC Error Calculation Mode | | | ADERR | | | |------|--------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------|--| | CALC | DSEN = 0<br>Single-Sample Mode | DSEN = 1<br>CVD Double-Sample Mode <sup>(1)</sup> | Application | | | 111 | Reserved | Reserved | Reserved | | | 110 | Reserved | Reserved | Reserved | | | 101 | ADFLTR-ADSTPT | ADFLTR-ADSTPT | Average/filtered value vs. setpoint | | | 100 | ADPREV-ADFLTR | ADPREV-ADFLTR | First derivative of filtered value <sup>(3)</sup> (negative) | | | 011 | Reserved | Reserved | Reserved | | | 010 | ADRES-ADFLTR | (ADRES-ADPREV)-ADFLTR | Actual result vs. averaged/filtered value | | | 001 | ADRES-ADSTPT | (ADRES-ADPREV)-ADSTPT | Actual result vs. setpoint | | | 000 | ADRES-ADPREV | ADRES-ADPREV | First derivative of single measurement <sup>(2)</sup> Actual CVD result <sup>(2)</sup> | | ## Notes: - 1. When DSEN = 1 and PSIS = 0, ADERR is computed only after every second sample. - 2. When PSIS = 0. - 3. When PSIS = 1. ### Bit 3 - SOI ADC Stop-on-Interrupt | Value | Condition | Description | |-------|-----------|----------------------------------------------------------------------------------| | value | | | | X | CONT = 0 | This bit is not used | | 1 | CONT = 1 | GO is cleared when the Threshold conditions are met, otherwise the conversion is | | | | retriggered | | 0 | CONT = 1 | GO is not cleared by hardware, must be cleared by software to stop retriggers | ### Bits 2:0 - TMD[2:0] Threshold Interrupt Mode Select | Value | Description | |-------|------------------------------------------------| | 111 | Interrupt regardless of threshold test results | | 110 | Interrupt if ADERR > ADUTH | | 101 | Interrupt if ADERR ≤ ADUTH | | 100 | Interrupt if ADERR < ADLTH or ADERR > ADUTH | | 011 | Interrupt if ADERR > ADLTH and ADERR < ADUTH | | 010 | Interrupt if ADERR ≥ ADLTH | | 001 | Interrupt if ADERR < ADLTH | | 000 | Never interrupt | ### 31.5.5 ADSTAT Name: ADSTAT Offset: 0x1D2A **ADC Status Register** | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----------|------|------|--------|---|---|-----------|---| | [ | AOV | UTHR | LTHR | MATH | | | STAT[2:0] | | | Access | R/C/HS/HC | R | R | R/W/HS | | R | R | R | | Reset | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | ### Bit 7 - AOV ADC Accumulator Overflow | | Value | Description | |---|-------|-------------------------------------------------------| | ſ | 1 | ADACC or ADFLTR or ADERR registers have overflowed | | | 0 | ADACC, ADFLTR and ADERR registers have not overflowed | #### Bit 6 - UTHR ADC Module Greater-than Upper Threshold Flag | Value | Description | |-------|---------------| | 1 | ADERR > ADUTH | | 0 | ADERR ≤ ADUTH | #### Bit 5 - LTHR ADC Module Less-than Lower Threshold Flag | | <b>U</b> | |-------|---------------| | Value | Description | | 1 | ADERR < ADLTH | | 0 | ADERR ≥ ADLTH | #### Bit 4 - MATH ADC Module Computation Status ADC Module Computation Status(1) | Value | e Description | |-------|--------------------------------------------------------------------------------------------| | 1 | Registers ADACC, ADFLTR, ADUTH, ADLTH and the AOV bit are updating or have already updated | | 0 | Associated registers/bits have not changed since this bit was last cleared | ### Bits 2:0 - STAT[2:0] ADC Module Cycle Multi-Stage Status | Value | Description | |-------|-------------------------------------------------------------------------------------------------| | 111 | ADC module is in 2 <sup>nd</sup> conversion stage | | 110 | ADC module is in 2 <sup>nd</sup> acquisition stage | | 101 | ADC module is in 2 <sup>nd</sup> precharge stage | | 100 | ADC computation is suspended between 1st and 2nd sample; the computation results are incomplete | | | and awaiting data from the 2nd sample <sup>(2,3)</sup> | | 011 | ADC module is in 1 <sup>st</sup> conversion stage | | 010 | ADC module is in 1 <sup>st</sup> acquisition stage | | 001 | ADC module is in 1st precharge stage | | 000 | ADC module is not converting | #### Notes: - 1. MATH bit cannot be cleared by software while STAT = 'b100. - If ADC clock source is ADCRC, and F<sub>OSC</sub> < ADCRC, the indicated status may not be valid.</li> - 3. STAT = b100 appears between the two triggers when DSEN = 1 and CONT = 0. ### 31.5.6 ADCLK Name: ADCLK Offset: 0x1D2D ADC Clock divider Register Bits 5:0 - CS[5:0] ADC Clock divider Select | | object in the object and object | |-------|-------------------------------------------| | Value | Description | | n | ADC Clock frequency = $F_{OSC}/(2*(n+1))$ | **Note:** ADC Clock divider is only available if $F_{OSC}$ is selected as the ADC clock source (CS = 0). ### 31.5.7 ADREF Name: ADREF Offset: 0x1D2B ADC Reference Selection Register Bits 1:0 - PREF[1:0] ADC Positive Voltage Reference Selection | Value | Description | |-------|----------------------------------------------------------------------------------| | 11 | V <sub>REF</sub> + is connected to internal Fixed Voltage Reference (FVR) module | | 10 | V <sub>REF</sub> + is connected to external V <sub>REF</sub> + | | 01 | Reserved | | 00 | V <sub>REF</sub> + is connected to V <sub>DD</sub> | ### 31.5.8 ADPCH Name: ADPCH Offset: 0x1D1F ADC Positive Channel Selection Register Bits 5:0 - PCH[5:0] ADC Positive Input Channel Selection ### Table 31-6. ADC Positive Input Channel Selections | PCH | ADC Positive Channel Input | |---------------|-------------------------------------------------------| | 111111 | Fixed Voltage Reference (FVR) Buffer 2 <sup>(1)</sup> | | 111110 | Fixed Voltage Reference (FVR) Buffer 1 <sup>(1)</sup> | | 111101-111100 | Reserved | | 111011 | Temperature Indicator <sup>(2)</sup> | | 111010 | V <sub>SS</sub> (Analog Ground) | | 111001-011000 | Reserved | | 010111 | RC7/ANC7 <sup>(3)</sup> | | 010110 | RC6/ANC6 <sup>(3)</sup> | | 010101 | RC5/ANC5 <sup>(4)</sup> | | 010100 | RC4/ANC4 <sup>(4)</sup> | | 010011 | RC3/ANC3 <sup>(4)</sup> | | 010010 | RC2/ANC2 <sup>(4)</sup> | | 010001 | RC1/ANC1 <sup>(4)</sup> | | 010000 | RC0/ANC0 <sup>(4)</sup> | | 001111 | RB7/ANB7 <sup>(3)</sup> | | 001110 | RB6/ANB6 <sup>(3)</sup> | | 001101 | RB5/ANB5 <sup>(3)</sup> | | 001100 | RB4/ANB4 <sup>(3)</sup> | | 001011-000110 | Reserved | | 000101 | RA5/ANA5 | | 000100 | RA4/ANA4 | | 000011 | ADCG1 | | 000010 | RA2/ANA2 | | 000001 | RA1/ANA1 | | 000000 | RA0/ANA0 | #### Notes: - 1. Refer to the "Fixed Voltage Reference Module" chapter for more details. - 2. Refer to the "Temperature Indicator Module" chapter for more details. - 3. 20-pin devices only. - 4. 14/20-pin devices only. ### 31.5.9 ADPRE Name: ADPRE Offset: 0x1D24 ADC Precharge Time Control Register Bits 12:0 - PRE[12:0] Precharge Time Select Table 31-7. Precharge Time | ADPRE | Precharge Time | | | |------------------|---------------------------------|-------------------------|--| | ADFRE | CS != ADCRC | CS = ADCRC | | | 1 1111 1111 1111 | 8191 clocks of F <sub>OSC</sub> | 8191 clocks of ADCRC | | | 1 1111 1111 1110 | 8190 clocks of F <sub>OSC</sub> | 8190 clocks of ADCRC | | | 1 1111 1111 1101 | 8189 clocks of F <sub>OSC</sub> | 8189 clocks of ADCRC | | | | | | | | 0 0000 0000 0010 | 2 clocks of F <sub>OSC</sub> | 2 clocks of ADCRC | | | 0 0000 0000 0001 | 1 clocks of F <sub>OSC</sub> | 1 clocks of ADCRC | | | 0 0000 0000 0000 | Not included in the | e data conversion cycle | | **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - ADPREH: Accesses the high byte ADPRE[12:8] - ADPREL: Accesses the low byte ADPRE[7:0] ### 31.5.10 ADACQ Name: ADACQ Offset: 0x1D21 ADC Acquisition Time Control Register Bits 12:0 - ACQ[12:0] Acquisition (charge share time) Select Table 31-8. Acquisition Time | ADACQ | Acquisition Time | | | |--------------------------------------|-------------------------------------|-------------------------------------------|--| | ADACQ | CS != ADCRC | CS = ADCRC | | | 1 1111 1111 1111 | 8191 clocks of F <sub>OSC</sub> | 8191 clocks of ADCRC | | | 1 1111 1111 1110 | 8190 clocks of F <sub>OSC</sub> | 8190 clocks of ADCRC | | | 1 1111 1111 1101 | 8189 clocks of F <sub>OSC</sub> | 8189 clocks of ADCRC | | | | | | | | 0 0000 0000 0010 | 2 clocks of F <sub>OSC</sub> | 2 clocks of ADCRC | | | 0 0000 0000 0001 | 1 clocks of F <sub>OSC</sub> | 1 clocks of ADCRC | | | 0 0000 0000 0000 | Not included in the | data conversion cycle <sup>(1)</sup> | | | Note: | | | | | 1. If ADPRE is not equal to '0', the | n ACQ = 0 means Acquisition Time is | 8192 clocks of F <sub>OSC</sub> or ADCRC. | | Notes: The individual bytes in this multibyte register can be accessed with the following register names: - ADACQH: Accesses the high byte ADACQ[12:8] - ADACQL: Accesses the low byte ADACQ[7:0] # ADC - Analog-to-Digital Converter with ... ### 31.5.11 ADCAP Name: ADCAP Offset: 0x1D23 ADC Additional Sample Capacitor Selection Register Bits 4:0 - CAP[4:0] ADC Additional Sample Capacitor Selection | Value | Description | | |---------|--------------------------------------------|--| | 1 to 31 | Number of pF in the additional capacitance | | | 0 | No additional capacitance | | # PIC16F18015/25/44/45 # ADC - Analog-to-Digital Converter with ... ### 31.5.12 ADRPT Name: ADRPT Offset: 0x1D1A **ADC Repeat Setting Register** ### Bits 7:0 - RPT[7:0] ADC Repeat Threshold Determines the number of times that the ADC is triggered for a threshold check. When CNT reaches this value, the error threshold is checked. Used when the computation mode is Low-Pass Filter, Burst Average, or Average. See the "Computation Operation" section for more details. # PIC16F18015/25/44/45 # ADC - Analog-to-Digital Converter with ... ### 31.5.13 ADCNT Name: ADCNT Offset: 0x1D19 **ADC Repeat Counter Register** ### Bits 7:0 - CNT[7:0] ADC Repeat Count Counts the number of times that the ADC is triggered before the threshold is checked. When this value reaches RPT, the threshold is checked. Used when the computation mode is Low-Pass Filter, Burst Average, or Average. See the "Computation Operation" section for more details. ### 31.5.14 ADFLTR Name: ADFLTR Offset: 0x1D14 ADC Filter Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |--------|------------|----|----|----|----|----|---|---|--| | | FLTR[15:8] | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | Reset | x | X | x | x | X | x | x | X | | | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | FLTR[7:0] | | | | | | | | | | Access | R | R | R | R | R | R | R | R | | | Reset | x | X | x | x | X | x | x | x | | Bits 15:0 - FLTR[15:0] ADC Filter Output - Signed two's complement In Accumulate, Average, and Burst Average mode, this is equal to ACC right shifted by the CRS bits. In LPF mode, this is the output of the Low-Pass Filter. Notes: The individual bytes in this multibyte register can be accessed with the following register names: - ADFLTRH: Accesses the high byte ADFLTR[15:8] - ADFLTRL: Accesses the low byte ADFLTR[7:0] ### 31,5,15 ADRES Name: ADRES Offset: 0x1D1D **ADC Result Register** Bits 15:0 - RES[15:0] ADC Sample Result Notes: The individual bytes in this multibyte register can be accessed with the following register names: - ADRESH: Accesses the high byte ADRES[15:18] - ADRESL: Accesses the low byte ADRES[7:0] ### 31.5.16 ADPREV Name: ADPREV Offset: 0x1D1B ### ADC Previous Result Register | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|----|----|----|----|----|---|---| | | PREV[15:8] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PREV[7:0] | | | | | | | | | Access | R | R | R | R | R | R | R | R | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | #### Bits 15:0 - PREV[15:0] Previous ADC Result | Value | Condition | Description | |-------|-----------|-----------------------------------------------------------------| | n | PSIS = 1 | n = ADFLTR value at the start of current ADC conversion | | n | PSIS = 0 | n = ADRES at the start of current ADC conversion <sup>(1)</sup> | #### Notes: - 1. If PSIS = 0, ADPREV is formatted the same way as ADRES is, depending on the FM bits. - 2. The individual bytes in this multibyte register can be accessed with the following register names: - ADPREVH: Accesses ADPREV[15:8] - ADPREVL: Accesses ADPREV[7:0]. ### 31,5,17 ADACC Name: ADACC Offset: 0x1D16 ADC Accumulator Register(1) See the "Computation Operation" section for more details. **Important:** This register contains signed two's complement accumulator value and the upper unused bits contain copies of the sign bit. Bits 17:0 - ACC[17:0] ADC Accumulator - Signed two's complement #### Notes: - 1. This register can only be written when GO = 0. - 2. The individual bytes in this multibyte register can be accessed with the following register names: - ADACCU: Accesses the upper byte ADACC[17:16] - ADACCH: Accesses the high byte ADACC[15:8] - ADACCL: Accesses the low byte ADACC[7:0]. ### 31.5.18 ADSTPT Name: ADSTPT Offset: 0x1D12 ADC Threshold Setpoint Register Depending on CALC, it may be used to determine ADERR. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|------------|-----|-----|-----|-----|-----|-----|-----| | | STPT[15:8] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | STPT[7:0] | | | | | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - STPT[15:0] ADC Threshold Setpoint - Signed two's complement **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - ADSTPTH: Accesses the high byte ADSTPT[15:8] - ADSTPTH: Accesses the low byte ADSTPT[7:0] ### 31,5,19 ADERR Name: ADERR Offset: 0x1D10 ADC Setpoint Error Register ADC Setpoint Error calculation is determined by the CALC bits. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|----|----|----|-----|--------|----|---|---| | | | | | ERR | [15:8] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | X | x | X | x | x | X | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | ERR | [7:0] | | | | | Access | R | R | R | R | R | R | R | R | | Reset | X | X | x | x | X | x | x | x | Bits 15:0 - ERR[15:0] ADC Setpoint Error - Signed two's complement **Notes:** The individual bytes in this multibyte register can be accessed with the following register names: - ADERRH: Accesses the high byte ADERR[15:8] - ADERRL: Accesses the low byte ADERR[7:0] ### 31,5,20 ADLTH Name: ADLTH Offset: 0x1D0C ADC Lower Threshold Register ADLTH and ADUTH are compared with ADERR to set the UTHR and LTHR bits. Depending on the setting of the TMD bits, an interrupt may be triggered by the results of this comparison. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|------|-------|-----|-----|-----| | | | | | LTH[ | 15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | LTH | [7:0] | , | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - LTH[15:0] ADC Lower Threshold - Signed two's complement Notes: The individual bytes in this multibyte register can be accessed with the following register names: - ADLTHH: Accesses the high byte ADLTH[15:8] - ADLTHL: Accesses the low byte ADLTH[7:0] ### 31,5,21 ADUTH Name: ADUTH Offset: 0x1D0E ## ADC Upper Threshold Register ADLTH and ADUTH are compared with ADERR to set the UTHR and LTHR bits. Depending on the setting of the TMD bits, an interrupt may be triggered by the results of this comparison. | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |--------|-----|-----|-----|-----|--------|-----|-----|-----| | | | | | UTH | [15:8] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | | | | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | UTH | [7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 15:0 - UTH[15:0] ADC Upper Threshold - Signed two's complement Notes: The individual bytes in this multibyte register can be accessed with the following register names: - ADUTHH: Accesses the high byte ADUTH[15:8] - ADUTHL: Accesses the low byte ADUTH[7:0] ### 31,5,22 ADACT Name: ADACT Offset: 0x1D2C ADC Auto-Conversion Trigger Source Selection Register Bits 5:0 – ACT[5:0] Auto-Conversion Trigger Select Table 31-9. ADC Auto-Conversion Trigger Sources | ACT | Auto-Conversion Trigger Source | |-------------|------------------------------------| | 11111-10111 | Reserved | | 10110 | Software write to ADPCH | | 10101 | Software read of ADRESH | | 10100 | Software read of ADERRH | | 10011 | CLC4_OUT | | 10010 | CLC3_OUT | | 10001 | CLC2_OUT | | 10000 | CLC1_OUT | | 01111 | Interrupt-on-change Interrupt Flag | | 01110 | C1_OUT | | 01101 | NCO1_OUT | | 01100 | PWM5_OUT | | 01011 | PWM4_OUT | | 01010 | PWM3_OUT | | 01001 | CCP2_OUT | | 01000 | CCP1_OUT | | 00111 | TMR6_postscaled_OUT | | 00110 | TMR4_postscaled_OUT | | 00101 | TMR3_overflow | | 00100 | TMR2_postscaled_OUT | | 00011 | TMR1_overflow | | 00010 | TMR0_overflow | | 00001 | Pin selected by ADACTPPS | | 00000 | External Trigger Disabled | ### 31.5.23 ADCGxA Name: ADCGxA Offset: 0x1D2E ADC Channel Group Selection Port A Bits 4, 5 - CGAn Channel Group Selection Enable on RA Pins Bits 0, 1, 2 - CGAn Channel Group Selection Enable on RA Pins Note: Refer to the "Pin Allocation Table" for details about available pins per port. ### 31.5.24 ADCGxB Name: ADCGxB Offset: 0x1D2F ADC Channel Group Selection Port B Bits 4, 5, 6, 7 - CGBn Channel Group Selection Enable on RB Pins Note: Refer to the "Pin Allocation Table" for details about available pins per port. ### 31.5.25 ADCGxC Name: ADCGxC Offset: 0x1D30 ADC Channel Group Selection Port C | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|------|------|------|------|------|------|------|------| | | CGC7 | CGC6 | CGC5 | CGC4 | CGC3 | CGC2 | CGC1 | CGC0 | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 0, 1, 2, 3, 4, 5 - CGCn Channel Group Selection Enable on RC Pins Bits 0, 1, 2, 3, 4, 5, 6, 7 - CGCn Channel Group Selection Enable on RC Pins Note: Refer to the "Pin Allocation Table" for details about available pins per port. # 31.6 Register Summary - ADC | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|-------------|------|------|-----------|------|------------------|-----------|-----------|---------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1D0B | | 7.0 | | | | LTU | 17.01 | | | | | 0x1D0C | ADLTH | 7:0<br>15:8 | | | | | [7:0] | | | | | | | 7:0 | | | | | [15:8]<br>I[7:0] | | | | | 0x1D0E | ADUTH | 15:8 | | | | | [15:8] | | | | | | | 7:0 | | | | | R[7:0] | | | | | 0x1D10 | ADERR | 15:8 | | | | | [15:8] | | | | | | | 7:0 | | | | | T[7:0] | | | | | 0x1D12 | ADSTPT | 15:8 | | | | | [15:8] | | | | | | | 7:0 | | | | | R[7:0] | | | | | 0x1D14 | ADFLTR | 15:8 | | | | | 1[15:8] | | | | | | | 7:0 | | | | | [7:0] | | | | | 0x1D16 | ADACC | 15:8 | | | | | [15:8] | | | | | 0.0.0 | 7127100 | 23:16 | | | | 7.00 | [] | | ACC | [17:16] | | 0x1D19 | ADCNT | 7:0 | | | | CNT | [7:0] | | | | | 0x1D1A | ADRPT | 7:0 | | | | | [7:0] | | | | | | | 7:0 | | | | PRE | | | | | | 0x1D1B | ADPREV | 15:8 | | | | | /[15:8] | | | | | | | 7:0 | | | | | [7:0] | | | | | 0x1D1D | ADRES | 15:8 | | | | | [15:8] | | | | | 0x1D1F | ADPCH | 7:0 | | | | | | H[5:0] | | | | 0x1D20 | Reserved | | | | | | | | | | | 0.4004 | ADACQ | 7:0 | | • | | ACC | Q[7:0] | | | | | 0x1D21 | ADACQ | 15:8 | | | | | | ACQ[12:8] | | | | 0x1D23 | ADCAP | 7:0 | | | | | | CAP[4:0] | | | | 0x1D24 | ADPRE | 7:0 | | • | | PRE | [7:0] | | | | | 0.0024 | ADPRE | 15:8 | | | | | | PRE[12:8] | | | | 0x1D26 | ADCON0 | 7:0 | ON | CONT | | CS | | FM | | GO | | 0x1D27 | ADCON1 | 7:0 | PPOL | IPEN | GPOL | | | | PCSC | DSEN | | 0x1D28 | ADCON2 | 7:0 | PSIS | | CRS[2:0] | | ACLR | | MD[2:0] | | | 0x1D29 | ADCON3 | 7:0 | | | CALC[2:0] | | SOI | | TMD[2:0] | | | 0x1D2A | ADSTAT | 7:0 | AOV | UTHR | LTHR | MATH | | | STAT[2:0] | | | 0x1D2B | ADREF | 7:0 | | | | | | | PRE | F[1:0] | | 0x1D2C | ADACT | 7:0 | | | | | | Γ[5:0] | | | | 0x1D2D | ADCLK | 7:0 | | | | | CS | [5:0] | | | | 0x1D2E | ADCG1A | 7:0 | | | CGA5 | CGA4 | | CGA2 | CGA1 | CGA0 | | 0x1D2F | ADCG1B | 7:0 | CGB7 | CGB6 | CGB5 | CGB4 | | | | | | 0x1D30 | ADCG1C | 7:0 | CGC7 | CGC6 | CGC5 | CGC4 | CGC3 | CGC2 | CGC1 | CGC0 | # 32. DAC - Digital-to-Analog Converter Module The Digital-to-Analog Converter (DAC) supplies a variable voltage reference, ratiometric with the input source, with programmable selectable output levels. The positive and negative input references (DACxREF+ and DACxREF-) can each be selected from several sources. The output of the DAC (DAC10UT1) can be selected as a reference voltage to several other peripherals or routed to output pins. The Digital-to-Analog Converter (DAC) is enabled by setting the EN bit. **Important:** This family of devices has one DAC module. The DAC1 module has a buffered output that can be connected to any of the designated DAC output pins. DAC1 is also connected internally to the ADC and CMP modules. Figure 32-1. Digital-to-Analog Converter Block Diagram Note 1: The output enable bits are configured so that they act as a 'one-hot' system, meaning only one DAC output can be enabled at a time. ## 32.1 Output Voltage Selection The DAC has 2<sup>n</sup> voltage level ranges, where n is the number of bits in DACR. Each level is determined by the DACxR bits. The DAC output voltage can be determined by using Equation 32-1. #### **Equation 32-1. DAC Output Equation** $$DACx\_output = \left( \left( V_{REF+} - V_{REF-} \right) \times \frac{DACR}{2^n} \right) + V_{REF-}$$ ## 32.2 Ratiometric Output Level The DAC output value is derived using a resistor ladder with each end of the ladder tied to a positive and negative voltage reference input source. If the voltage of either input source fluctuates, a similar fluctuation will result in the DAC output value. The value of the individual resistors within the ladder can be found in the "Electrical Specifications" chapter for each respective device. # 32.3 Buffered DAC Output Range Selection The DAC offers selectable output ranges that improve the output performance of the buffered DAC output (DAC1OUT1). Range selection allows module hardware to optimize the DAC buffer output by biasing the reference voltages towards either DACxREF+ (high range) or DACxREF- (low range). Range selection can be done automatically or through software control. The DAC Buffer Automatic Range Select Enable (DACAUTOEN) bit of the Configuration Words is used to select either user software-controlled ranging or automatic ranging via hardware control. When $\overline{DACAUTOEN}$ is set ( $\overline{DACAUTOEN}$ = 1), the range is determined by the Buffer Reference Range Selection (REFRNG) bit in user software. When REFRNG is set (REFRNG = 1), the high range (( $V_{SS}$ + 1.0V) through $V_{DD}$ ) is selected as the voltage reference range. When REFRNG is clear (REFRNG = 0), the low range ( $V_{SS}$ through ( $V_{DD}$ - 1.0V) is selected as the reference range. When DACAUTOEN is clear (DACAUTOEN = 0), module hardware monitors the DACxDATL register and automatically selects the appropriate range based on the DACxDAT value. **Important:** To ensure the most accurate results, it is highly recommended to do the following: - Enable the DAC Auto-Ranging feature in the Configuration Words (DACAUTOEN = 0) - Set the Charge Pump to Auto mode (CPCONbits.CPON = \b10) - Wait the required settling time when changing the DACxDATL values (see the "Electrical Specifications" section) This allows module hardware to continuously monitor the DAC output and $V_{DD}$ levels to ensure a stable, accurate result with little software overhead. # 32.4 Operation During Sleep When the device wakes from Sleep through an interrupt or a WWDT Time-out Reset, the contents of the DACxCON and DACxDATL registers are not affected. To minimize current consumption in Sleep mode, the voltage reference will be disabled. ## 32.5 Effects of a Reset A device Reset affects the following: # **DAC - Digital-to-Analog Converter Module** - · The DAC module is disabled - The DAC output voltage is removed from the DACxOUTn pin(s) - · The DACxR bits are cleared # 32.6 Register Definitions: DAC Control Long bit name prefixes for the DAC are shown in the table below. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 32-1. DAC Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | DAC1 | DAC1 | ### 32.6.1 DACxCON Name: DACxCON Offset: 0x110C Digital-to-Analog Converter Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|--------|-----|------|-----|-------|---|-----| | | EN | REFRNG | OE[ | 1:0] | PSS | [1:0] | | NSS | | Access | R/W | R/W | R/W | R/W | R/W | R/W | | R/W | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | ### Bit 7 - EN DAC Enable | V | alue | Description | |---|------|-----------------| | 1 | | DAC is enabled | | 0 | | DAC is disabled | # Bit 6 – REFRNG Buffer Reference Range Selection<sup>(1)</sup> | Value | Condition | Description | |-------|---------------|------------------------------------------------------------------------------------| | Х | DACAUTOEN = 0 | Automatic ranging enabled; the REFRNG bit is ignored | | 1 | DACAUTOEN = 1 | Range optimized for voltages from (V <sub>SS</sub> + 1.0V) through V <sub>DD</sub> | | 0 | DACAUTOEN = 1 | Range optimized for voltages from V <sub>SS</sub> through (V <sub>DD</sub> - 1.0V) | ## Bits 5:4 - OE[1:0] DAC Output Enable | OE | DAC1 | |----|-------------------------------------| | 11 | DAC1OUT1 is disabled | | 10 | DAC1OUT1 is disabled | | 01 | DAC1OUT1 is enabled on pin RA0 only | | 00 | DAC1OUT1 is disabled | ## Bits 3:2 - PSS[1:0] DAC Positive Reference Selection | PSS | DAC Positive Reference | |-----|------------------------| | 11 | Reserved, do not use | | 10 | FVR Buffer 2 | | 01 | V <sub>REF</sub> + | | 00 | $V_{DD}$ | ## Bit 0 - NSS DAC Negative Reference Selection | NSS | DAC Negative Reference | |-----|------------------------| | 1 | V <sub>REF</sub> - | | 0 | $V_{SS}$ | #### Note: 1. The REFRNG bit only applies to DAC1OUT1. ## 32.6.2 DACxDATL Name: DACxDATL Offset: 0x110D Digital-to-Analog Converter Data Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|-----|------|--------|-----|-----|-----| | [ | | | | DACx | R[7:0] | | | | | Access | R/W | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Bits 7:0 - DACxR[7:0] Data Input Bits for DAC Value # 32.7 Register Summary - DAC | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|------------|--------|----|-------|-----|-------|---|-----| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x110B | | | | | | | | | | | | 0x110C | DAC1CON | 7:0 | EN | REFRNG | OE | [1:0] | PSS | [1:0] | | NSS | | 0x110D | DAC1DATL | 7:0 | DAC1R[7:0] | | | | | | | | # 33. CMP - Comparator Module Comparators are used to interface analog circuits to a digital circuit by comparing two analog voltages and providing a digital indication of their relative magnitudes. Comparators are very useful mixed signal building blocks because they provide analog functionality independent of program execution. The analog comparator module includes the following features: - · Programmable input selection - · Programmable output polarity - · Rising/falling output edge interrupts - · Wake-up from Sleep - · Selectable voltage reference - · ADC auto-trigger - Inter-connections with other available modules (e.g., timer clocks) # 33.1 Comparator Overview A single comparator is shown in Figure 33-1 along with the relationship between the analog input levels and the digital output. When the analog voltage at $V_{IN}$ + is less than the analog voltage at $V_{IN}$ -, the output of the comparator is a digital low level. When the analog voltage at $V_{IN}$ + is greater than the analog voltage at $V_{IN}$ -, the output of the comparator is a digital high level. Figure 33-1. Single Comparator #### Note: 1. The black areas of the output of the comparator represent the uncertainty due to input offsets and response time. Figure 33-2. Comparator Module Simplified Block Diagram Note 1: When EN = 0, all multiplexer inputs are disconnected and the Comparator will produce a '0' at the output. # 33.2 Comparator Control Each comparator has two control registers: CMxCON0 and CMxCON1. The CMxCON0 register contains Control and Status bits for the following: - Enable - Output - Output Polarity - · Hysteresis Enable - · Timer1 Output Synchronization The CMxCON1 register contains Control bits for the following: Interrupt on Positive/Negative Edge Enables The CMxPCH and CMxNCH registers are used to select the positive and negative input channels, respectively. ## 33.2.1 Comparator Enable Setting the EN bit enables the comparator for operation. Clearing the EN bit disables the comparator, resulting in minimum current consumption. #### 33.2.2 Comparator Output The output of the comparator can be monitored in two different registers. Each output can be read individually by reading the OUT bit. Outputs of all the comparators can be collectively accessed by reading the CMOUT register. ## **CMP - Comparator Module** The comparator output can also be routed to an external pin through the RxyPPS register. Refer to the "PPS - Peripheral Pin Select Module" chapter for more details. The corresponding TRIS bit must be clear to enable the pin as an output. **Important:** The internal output of the comparator is latched with each instruction cycle. Unless otherwise specified, external outputs are not latched. #### 33.2.3 Comparator Output Polarity Inverting the output of the comparator is functionally equivalent to swapping the comparator inputs. The polarity of the comparator output can be inverted by setting the POL bit. Clearing the POL bit results in a noninverted output. Table 33-1 shows the Output state versus Input conditions, including polarity control. Table 33-1. Comparator Output State vs. Input Conditions | Input Condition | POL | OUT | |-----------------|-----|-----| | CxVn > CxVp | 0 | 0 | | CxVn < CxVp | 0 | 1 | | CxVn > CxVp | 1 | 1 | | CxVn < CxVp | 1 | 0 | ## 33.3 Comparator Output Synchronization The output from a comparator can be synchronized with Timer1 by setting the SYNC bit. Once enabled, the comparator output is latched on the falling edge of the Timer1 source clock. If a prescaler is used with Timer1, the comparator output is latched after the prescaling function. To prevent a Race condition, the comparator output is latched on the falling edge of the Timer1 clock source and Timer1 increments on the rising edge of its clock source. A simplified block diagram of the comparator module is shown in Figure 33-2. Refer to the "TMR1 - Timer1 Module with Gate Control" chapter for more details. # 33.4 Comparator Hysteresis A selectable amount of separation voltage can be added to the input pins of each comparator to provide a hysteresis function to the overall operation. Hysteresis is enabled by setting the HYS bit. See the "Comparator Specifications" section for more information. ## 33.5 Comparator Interrupt An interrupt can be generated for every rising or falling edge of the comparator output. When either edge detector is triggered and its associated enable bit is set (INTP and/or INTN bits), the Corresponding Interrupt Flag bit (CxIF bit of the respective PIR register) will be set. To enable the interrupt, the following bits must be set: - EN bit - INTP bit (for a rising edge detection) - INTN bit (for a falling edge detection) - CxIE bit of the respective PIE register - GIE bit of the INTCON0 register **CMP - Comparator Module** The associated interrupt flag bit, CxIF bit of the respective PIR register, must be cleared in software to successfully detect another edge. **Important:** Although a comparator is disabled, an interrupt will be generated by changing the output polarity with the POL bit. ## 33.6 Comparator Positive Input Selection Configuring the PCH bits direct an internal voltage reference or an analog pin to the noninverting input of the comparator. Any time the comparator is disabled (EN = 0), all comparator inputs are disabled. ## 33.7 Comparator Negative Input Selection The NCH bits direct an analog input pin, internal reference voltage or analog ground to the inverting input of the comparator. **Important:** To use CxINy+ and CxINy- pins as analog input, the appropriate bits must be set in the ANSEL register and the corresponding TRIS bits must also be set to disable the output drivers. # 33.8 Comparator Response Time The comparator output is indeterminate for a period of time after the change of an input source or the selection of a new reference voltage. This period is referred to as the response time. The response time of the comparator differs from the settling time of the voltage reference. Therefore, both of these times must be considered when determining the total response time to a comparator input change. See the Comparator and Voltage Reference Specifications in the "Comparator Specifications" and "Fixed Voltage Reference (FVR) Specifications" sections for more details. ## 33.9 Analog Input Connection Considerations A simplified circuit for an analog input is shown in Figure 33-3. Since the analog input pins share their connection with a digital input, they have reverse biased ESD protection diodes to $V_{DD}$ and $V_{SS}$ . The analog input, therefore, must be between $V_{SS}$ and $V_{DD}$ . If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and abnormal behavior may occur. A maximum source impedance of 10 k $\Omega$ is recommended for the analog sources. Also, any external component connected to an analog input pin, such as a capacitor or a Zener diode, will have very little leakage current to minimize corrupting the result. #### Notes: - 1. When reading a PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert as an analog input, according to the input specification. - 2. Analog levels on any pin defined as a digital input may cause the input buffer to consume more current than specified. Figure 33-3. Analog Input Model Legend: CPIN = Input Capacitance ILEAKAGE = Leakage Current at the pin due to various junctions Ric = Interconnect Resistance Rs = Source Impedance VA = Analog Voltage VT = Diode Forward Voltage #### Note: 1. See the "Electrical Specifications" chapter. # 33.10 Operation in Sleep Mode The comparator module can operate during Sleep. A comparator interrupt will wake the device from Sleep. The CxIE bits of the respective PIE register must be set to enable comparator interrupts. The comparator clock source is based on the Timer1 clock source. If the Timer1 clock source is either the system clock ( $F_{OSC}$ ) or the instruction clock ( $F_{OSC}$ /4), Timer1 will not operate during Sleep, and synchronized comparator outputs will not operate. # 33.11 ADC Auto-Trigger Source The output of the comparator module can be used to trigger an ADC conversion. When the ADACT register is set to trigger on a comparator output, an ADC conversion will trigger when the comparator output goes high. # 33.12 Register Definitions: Comparator Control Long bit name prefixes for the Comparator peripherals are shown in the table below. Refer to the "Long Bit Names" section in the "Register and Bit Naming Conventions" chapter for more information. Table 33-2. Comparator Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | C1 | C1 | ### 33.12.1 CMxCON0 Name: CMxCON0 Offset: 0x108C Comparator Control Register 0 | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|---|-----|---|---|-----|------| | | EN | OUT | | POL | | | HYS | SYNC | | Access | R/W | R | | R/W | | | R/W | R/W | | Reset | 0 | 0 | | 0 | | | 0 | 0 | ### Bit 7 - EN Comparator Enable | Value | Description | |-------|-----------------------------------------------------| | 1 | Comparator is enabled | | 0 | Comparator is disabled and consumes no active power | #### Bit 6 - OUT Comparator Output | Value | Condition | Description | |-------|------------------------------------|-------------| | 1 | If POL = 0 (noninverted polarity): | CxVP > CxVN | | 0 | If POL = 0 (noninverted polarity): | CxVP < CxVN | | 1 | If POL = 1 (inverted polarity): | CxVP < CxVN | | 0 | If POL = 1 (inverted polarity): | CxVP > CxVN | ## Bit 4 – POL Comparator Output Polarity Select | Value Description | | Description | |-------------------|---|-----------------------------------| | | 1 | Comparator output is inverted | | | 0 | Comparator output is not inverted | #### Bit 1 - HYS Comparator Hysteresis Enable | Value | Description | |-------|--------------------------------| | 1 | Comparator hysteresis enabled | | 0 | Comparator hysteresis disabled | # Bit 0 - SYNC Comparator Output Synchronous Mode | Value | Description | |-------|--------------------------------------------------------------------------------------------------| | 1 | Comparator output to Timer1 and I/O pin is synchronous to changes on Timer1 clock source. Output | | | updated on the falling edge of Timer1 clock source. | | 0 | Comparator output to Timer1 and I/O pin is asynchronous | ### 33.12.2 CMxCON1 Name: CMxCON1 Offset: 0x108D Comparator Control Register 1 Bit 1 - INTP Comparator Interrupt on Positive-Going Edge Enable | Value | Description | |-------|---------------------------------------------------------------------------------| | 1 | The CxIF interrupt flag will be set upon a positive-going edge of the CxOUT bit | | 0 | No interrupt flag will be set on a positive-going edge of the CxOUT bit | ### Bit 0 - INTN Comparator Interrupt on Negative-Going Edge Enable | | √alue | Description | |---|-------|---------------------------------------------------------------------------------| | | 1 | The CxIF interrupt flag will be set upon a negative-going edge of the CxOUT bit | | ( | ) | No interrupt flag will be set on a negative-going edge of the CxOUT bit | ### 33.12.3 CMxNCH Name: **CMxNCH** Offset: 0x108E Comparator Inverting Channel Select Register Bits 2:0 - NCH[2:0] Comparator Inverting Input Channel Select | V <sub>SS</sub> FVR_Buffer2 NCH not connected NCH not connected CxIN3- <sup>(1)</sup> | |---------------------------------------------------------------------------------------| | NCH not connected NCH not connected | | NCH not connected | | | | CVINI3_(1) | | ONINO- , | | CxIN2- <sup>(1)</sup> | | CxIN1- | | CxIN0- | | | | | # 33.12.4 CMxPCH Name: CMxPCH Offset: 0x108F Comparator Noninverting Channel Select Register Bits 2:0 - PCH[2:0] Comparator Noninverting Input Channel Select | PCH | Positive Input Sources | |-----|------------------------| | 111 | $V_{SS}$ | | 110 | FVR_Buffer2 | | 101 | PCH not connected | | 100 | DAC1_OUT | | 011 | PCH not connected | | 010 | PCH not connected | | 001 | PCH not connected | | 000 | CxIN0+ | # 33.12.5 CMOUT Name: CMOUT Offset: 0x109F Comparator Output Register Bit 0 - CxOUT Mirror copy of the CMxCON0.OUT # 33.13 Register Summary - Comparator | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|----|-----|---|-----|---|---|----------|-------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x108B | | | | | | | | | | | | 0x108C | CM1CON0 | 7:0 | EN | OUT | | POL | | | HYS | SYNC | | 0x108D | CM1CON1 | 7:0 | | | | | | | INTP | INTN | | 0x108E | CM1NCH | 7:0 | | | | | | | NCH[2:0] | | | 0x108F | CM1PCH | 7:0 | | | | | | | PCH[2:0] | | | 0x1090 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x109E | | | | | | | | | | | | 0x109F | CMOUT | 7:0 | | | | | | | | C1OUT | # 34. FVR - Fixed Voltage Reference The Fixed Voltage Reference (FVR) is a stable voltage reference, independent of V<sub>DD</sub>, with 1.024V, 2.048V or 4.096V selectable output levels. The output of the FVR can be configured to supply a reference voltage to analog peripherals such as those listed below. - · ADC input channel - · ADC positive reference - · Comparator input - Digital-to-Analog Converter (DAC) The FVR can be enabled by setting the EN bit to '1'. **Note:** Fixed Voltage Reference output cannot exceed V<sub>DD</sub>. ## 34.1 Independent Gain Amplifiers The output of the FVR is routed through two independent programmable gain amplifiers. Each amplifier can be programmed for a gain of 1x, 2x or 4x, to produce the three possible voltage levels. The ADFVR bits are used to enable and configure the gain amplifier settings for the reference supplied to the ADC module. Refer to the "ADCC - Analog-to-Digital Converter with Computation Module" chapter for additional information. The CDAFVR bits are used to enable and configure the gain amplifier settings for the reference supplied to the DAC and comparator modules. Refer to the "DAC - Digital-to-Analog Converter Module" and "CMP - Comparator Module" chapters for additional information. Refer to the figure below for the block diagram of the FVR module. Figure 34-1. Fixed Voltage Reference Block Diagram #### 34.2 FVR Stabilization Period When the Fixed Voltage Reference module is enabled, it requires time for the reference and amplifier circuits to stabilize. Once the circuits stabilize and are ready for use, the RDY bit will be set. ## 34.3 Register Definitions: FVR Long bit name prefixes for the FVR peripherals are shown in the following table. Refer to the "Long Bit Names" section in the "Register and Bits Naming Conventions" chapter for more information. # PIC16F18015/25/44/45 **FVR - Fixed Voltage Reference** # Table 34-1. FVR Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | FVR | FVR | #### 34,3,1 FVRCON Name: FVRCON Offset: 0x100C **FVR Control Register** **Important:** This register is shared between the Fixed Voltage Reference (FVR) module and the temperature indicator module. | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|-----|------|-------|-------|---------|------|--------| | | EN | RDY | TSEN | TSRNG | CDAF\ | /R[1:0] | ADFV | R[1:0] | | Access | R/W | R | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | q | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - EN Fixed Voltage Reference Enable | Value | Description | |-------|-----------------| | 1 | Enables module | | 0 | Disables module | #### Bit 6 - RDY Fixed Voltage Reference Ready Flag | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Fixed Voltage Reference output is ready for use | | 0 | Fixed Voltage Reference output is not ready for use or not enabled | #### Bit 5 - TSEN Temperature Indicator Enable | Value | Description | |-------|-----------------------------------| | 1 | Temperature Indicator is enabled | | 0 | Temperature Indicator is disabled | ## Bit 4 - TSRNG Temperature Indicator Range Selection | DIC + 101 | Dit 4 TOTATO Temperature indicator range defection | | | | | |-----------|----------------------------------------------------|--|--|--|--| | Value | Description | | | | | | 1 | $V_{OUT} = 3V_{T}$ (High Range) | | | | | | 0 | $V_{OUT} = 2V_T$ (Low Range) | | | | | ### Bits 3:2 - CDAFVR[1:0] FVR Buffer 2 Gain Selection<sup>(1)</sup> | Value | Description | |-------|--------------------------------------------------| | 11 | FVR Buffer 2 Gain is 4x, (4.096V) <sup>(3)</sup> | | 10 | FVR Buffer 2 Gain is 2x, (2.048V) <sup>(3)</sup> | | 01 | FVR Buffer 2 Gain is 1x, (1.024V) | | 00 | FVR Buffer 2 is OFF | #### Bits 1:0 - ADFVR[1:0] FVR Buffer 1 Gain Selection<sup>(2)</sup> | | · · · · · · · · · · · · · · · · · · · | |-------|--------------------------------------------------| | Value | Description | | 11 | FVR Buffer 1 Gain is 4x, (4.096V) <sup>(3)</sup> | | 10 | FVR Buffer 1 Gain is 2x, (2.048V) <sup>(3)</sup> | | 01 | FVR Buffer 1 Gain is 1x, (1.024V) | | 00 | FVR Buffer 1 is OFF | ## Notes: - 1. This output goes to the DAC and comparator modules, and to the ADC module as an input channel only. - 2. This output goes to the ADC module as a reference and an input channel. - 3. Fixed Voltage Reference output cannot exceed V<sub>DD</sub>. # 34.4 Register Summary - FVR | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|----|-----|------|-------|------|---------|------|---------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x100B | | | | | | | | | | | | 0x100C | FVRCON | 7:0 | EN | RDY | TSEN | TSRNG | CDAF | VR[1:0] | ADFV | 'R[1:0] | # 35. Temperature Indicator Module This family of devices is equipped with a temperature circuit designed to measure the operating temperature of the silicon die. The temperature indicator module provides a temperature-dependent voltage that can be measured by the internal Analog-to-Digital Converter. The circuit's range of operating temperature falls between -40°C and +125°C. The circuit may be used as a temperature threshold detector or a more accurate temperature indicator, depending on the level of calibration performed. A one-point calibration allows the circuit to indicate a temperature closely surrounding that point. A two-point calibration allows the circuit to sense the entire range of temperature more accurately. Microchip tests each device during manufacturing and provides the gain, offset, and Temperature Indicator ADC values at 90°C, for both High and Low Range operation. ## 35.1 Module Operation The temperature indicator module consists of a temperature-sensing circuit that provides a voltage to the device ADC. The analog voltage output varies inversely to the device temperature. The output of the temperature indicator is referred to as $V_{\text{MEAS}}$ . The following figure shows a simplified block diagram of the temperature indicator module. Figure 35-1. Temperature Indicator Module Block Diagram The output of the circuit is measured using the internal Analog-to-Digital Converter. A channel is reserved for the temperature circuit output. Refer to the "ADCC - Analog-to-Digital Converter with Computation Module" chapter for more details. The ON/OFF bit for the module is located in the FVRCON register. The circuit is enabled by setting the TSEN bit. When the module is disabled, the circuit draws no current. Refer to the "FVR - Fixed Reference Voltage" chapter for more details. #### 35.1.1 Temperature Indicator Range The temperature indicator circuit operates in either high or low range. The high range, selected by setting the TSRNG bit, provides a wider output voltage. This provides more resolution over the temperature range. High range requires a higher bias voltage to operate and thus, a higher $V_{DD}$ is needed. The low range is selected by clearing the TSRNG bit. The low range generates a lower sensor voltage and thus, a lower $V_{DD}$ voltage is needed to operate the circuit. The output voltage of the sensor is the highest value at -40°C and the lowest value at +125°C. - High Range: The high range is used in applications with the reference for the ADC, V<sub>REF</sub> = 2.048V. This range may not be suitable for battery-powered applications. - Low Range: This mode is useful in applications in which the V<sub>DD</sub> is too low for high-range operation. The V<sub>DD</sub> in this mode can be as low as 1.8V. However, V<sub>DD</sub> must be at least 0.5V higher than the maximum sensor voltage depending on the expected low operating temperature. **Important:** The standard parameters for the Temperature Indicator for both high range and low range are stored in the DIA table. Refer to the DIA table in the "**Memory Organization**" chapter for more details. Additionally, the Temperature Indicator sensitivity parameter ( $M_V$ ) for both high range and low range is located in the "**Electrical Specifications**" section. ## 35.1.2 Minimum Operating V<sub>DD</sub> When the temperature circuit is operated in low range, the device may be operated at any operating voltage that is within the device specifications. When the temperature circuit is operated in high range, the device operating voltage, $V_{DD}$ , must be high enough to ensure that the temperature circuit is correctly biased. The following table shows the recommended minimum V<sub>DD</sub> vs. Range setting. Table 35-1. Recommended V<sub>DD</sub> vs. Range | Min. V <sub>DD</sub> , TSRNG = 1 (High Range) | Min. V <sub>DD</sub> , TSRNG = 0 (Low Range) | | | | | |-----------------------------------------------|----------------------------------------------|--|--|--|--| | ≥ 2.5 | ≥ 1.8 | | | | | # 35.2 Temperature Calculation This section describes the steps involved in calculating the die temperature, T<sub>MEAS</sub>: - Obtain the ADC count value of the measured analog voltage: The analog output voltage, V<sub>MEAS</sub>, is converted to a digital count value by the Analog-to-Digital Converter (ADC) and is referred to as ADC<sub>MEAS</sub>. - Obtain the Gain value from the DIA table. This parameter is TSLR1 for the low range setting or TSHR1 for the high range setting of the temperature indicator module. Refer to the DIA table in the "Memory Organization" chapter for more details. - 3. Obtain the Offset value from the DIA table. This parameter is TSLR3 for the low range setting or TSHR3 for the high range setting of the temperature indicator module. Refer to the DIA table in the "Memory Organization" chapter for more details. The following equation provides an estimate for the die temperature based on the above parameters: #### Equation 35-1. Sensor Temperature (in °C) $$T_{MEAS} = \frac{\frac{\left(ADC_{MEAS} \times Gain\right)}{256} + Offset}{10}$$ Where: ADC<sub>MEAS</sub> = ADC reading at temperature being estimated Gain = Gain value stored in the DIA table Offset = Offset value stored in the DIA table **Note:** It is recommended to take the average of ten measurements of $ADC_{MEAS}$ to reduce noise and improve accuracy. ``` Example 35-1. Temperature Calculation (C) // offset is int16_t data type // gain is int16_t data type // ADC_MEAS is uint16_t data type // Temp_in_C is int24_t data type ADC_MEAS = ((ADRESH << 8) + ADRESL); Temp_in_C = (int24_t) (ADC_MEAS) * gain; // Store the ADC Result // Gain and store the result in a // signed variable Temp_in_C = Temp_in_C / 256; Temp_in_C = Temp_in_C + offset; // Add (Offset) to the result</pre> ``` # PIC16F18015/25/44/45 # **Temperature Indicator Module** **Important:** If the application requires more precise temperature measurement, additional calibrations steps will be necessary. For these applications, two-point or three-point calibration is recommended. For additional information on two-point calibration method, refer to the following Microchip application note, available at the corporate website (www.microchip.com): • AN2798, "Using the PIC16F/PIC18F Ground Referenced Temperature Indicator Module" # 35.3 ADC Acquisition Time To ensure accurate temperature measurements, the user must wait a certain minimum acquisition time (parameter TS01) after the temperature indicator output is selected as ADC input. This is required for the ADC sampling circuit to settle before the conversion is performed. **Note**: Parameter TS01 can be found in the Temperature Indicator Requirements table of the "**Electrical Specifications**" chapter. # 35.4 Register Definitions: Temperature Indicator #### 35.4.1 FVRCON Name: FVRCON Offset: 0x100C **FVR Control Register** **Important:** This register is shared between the Fixed Voltage Reference (FVR) module and the temperature indicator module. | Bit | 7 | 7 6 5 | | 4 3 | | 2 | 1 | 0 | |--------|-----|-------|------|-------|-------------|-----|------------|-----| | | EN | RDY | TSEN | TSRNG | CDAFVR[1:0] | | ADFVR[1:0] | | | Access | R/W | R | R/W | R/W | R/W | R/W | R/W | R/W | | Reset | 0 | q | 0 | 0 | 0 | 0 | 0 | 0 | #### Bit 7 - EN Fixed Voltage Reference Enable | Value | Description | |-------|-----------------| | 1 | Enables module | | 0 | Disables module | ### Bit 6 - RDY Fixed Voltage Reference Ready Flag | Value | Description | |-------|--------------------------------------------------------------------| | 1 | Fixed Voltage Reference output is ready for use | | 0 | Fixed Voltage Reference output is not ready for use or not enabled | #### Bit 5 - TSEN Temperature Indicator Enable | Value | Description | |-------|-----------------------------------| | 1 | Temperature Indicator is enabled | | 0 | Temperature Indicator is disabled | #### Bit 4 - TSRNG Temperature Indicator Range Selection | D.C - 1011 | NO Temperature indicator runge colocion | |------------|------------------------------------------------| | Value | Description | | 1 | $V_{OUT} = 3V_T$ (High Range) | | 0 | V <sub>OUT</sub> = 2V <sub>T</sub> (Low Range) | #### Bits 3:2 - CDAFVR[1:0] FVR Buffer 2 Gain Selection(1) | Value | Description | |-------|--------------------------------------------------| | 11 | FVR Buffer 2 Gain is 4x, (4.096V) <sup>(3)</sup> | | 10 | FVR Buffer 2 Gain is 2x, (2.048V) <sup>(3)</sup> | | 01 | FVR Buffer 2 Gain is 1x, (1.024V) | | 00 | FVR Buffer 2 is OFF | #### Bits 1:0 - ADFVR[1:0] FVR Buffer 1 Gain Selection<sup>(2)</sup> | | · · · · · · · · · · · · · · · · · · · | |-------|--------------------------------------------------| | Value | Description | | 11 | FVR Buffer 1 Gain is 4x, (4.096V) <sup>(3)</sup> | | 10 | FVR Buffer 1 Gain is 2x, (2.048V) <sup>(3)</sup> | | 01 | FVR Buffer 1 Gain is 1x, (1.024V) | | 00 | FVR Buffer 1 is OFF | ## Notes: - 1. This output goes to the DAC and comparator modules, and to the ADC module as an input channel only. - 2. This output goes to the ADC module as a reference and an input channel. - 3. Fixed Voltage Reference output cannot exceed V<sub>DD</sub>. # 35.5 Register Summary - Temperature Indicator | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|----|-----|------|-------|------|---------|------|---------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x100B | | | | | | | | | | | | 0x100C | FVRCON | 7:0 | EN | RDY | TSEN | TSRNG | CDAF | VR[1:0] | ADFV | 'R[1:0] | ## 36. ZCD - Zero-Cross Detection Module The ZCD module detects when an A/C signal crosses through the ground potential. The actual zero-crossing threshold is the zero-crossing reference voltage, $Z_{CPINV}$ , which is typically 0.75V above ground. The connection to the signal to be detected is through a series current-limiting resistor. The module applies a current source or sink to the ZCD pin to maintain a constant voltage on the pin, thereby preventing the pin voltage from forward biasing the ESD protection diodes. When the applied voltage is greater than the reference voltage, the module sinks current. When the applied voltage is less than the reference voltage, the module sources current. The current source and sink action keeps the pin voltage constant over the full range of the applied voltage. The ZCD module is shown in the following simplified block diagram. Figure 36-1. Simplified ZCD Block Diagram The ZCD module is useful when monitoring an A/C waveform for, but not limited to, the following purposes: - · A/C period measurement - Accurate long term time measurement - · Dimmer phase delayed drive - · Low EMI cycle switching #### 36.1 External Resistor Selection The ZCD module requires a current-limiting resistor in series with the external voltage source. The impedance and rating of this resistor depends on the external source peak voltage. Select a resistor value that will drop all of the peak voltage when the current through the resistor is less than the maximum input current (ZC02). Refer to the "Electrical Specifications" chapter for more details. Make sure that the ZCD I/O pin internal weak pull-up is disabled so it does not interfere with the current source and sink. #### Equation 36-1. External Resistor $$R_{SERIES} = \frac{V_{PEAK}}{I_{ZCD}}$$ Figure 36-2. External Voltage Source # 36.2 ZCD Logic Output The ZCD module includes a Status bit, which can be read to determine whether the current source or sink is active. The OUT bit is set when the current sink is active, and cleared when the current source is active. The OUT bit is affected by the polarity bit. The OUT signal can also be used as input to other modules. This is controlled by the registers of the corresponding module. ## 36.3 ZCD Logic Polarity The POL bit inverts the OUT bit relative to the current source and sink output. When the POL bit is set, a OUT high indicates that the current source is active, and a low output indicates that the current sink is active. The POL bit affects the ZCD interrupts. ### 36.4 ZCD Interrupts An interrupt will be generated upon a change in the ZCD logic output when the appropriate interrupt enables are set. The ZCD module has a rising edge detector and a falling edge detector. The ZCDIF bit of the PIRx register will be set when either edge detector is triggered and its associated enable bit is set. The INTP enables rising edge interrupts and the INTN bit enables falling edge interrupts. To fully enable the interrupt, the following bits must be set: - · ZCDIE bit of the PIEx register - · INTP bit for rising edge detection - · INTN bit for falling edge detection - · GIEL and GIE bits of the INTCON0 register Changing the POL bit will cause an interrupt, regardless of the level of the SEN bit. The ZCDIF bit of the PIRx register must be cleared in software as part of the interrupt service. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence. ## 36.5 Correction for Z<sub>CPINV</sub> Offset The actual voltage at which the ZCD switches is the reference voltage at the noninverting input of the ZCD op amp. For external voltage source waveforms other than square waves, this voltage offset from zero causes the zero-cross event to occur either too early or too late. #### 36.5.1 Correction by AC Coupling When the external voltage source is sinusoidal, the effects of the $Z_{CPINV}$ offset can be eliminated by isolating the external voltage source from the ZCD pin with a capacitor, in addition to the voltage reducing resistor. The capacitor will cause a phase shift resulting in the ZCD output switch in advance of the actual zero-crossing event. The phase shift will be the same for both rising and falling zero-crossings, which can be compensated for by either delaying the CPU response to the ZCD switch by a timer or other means, or selecting a capacitor value large enough that the phase shift is negligible. To determine the series resistor and capacitor values for this configuration, start by computing the impedance, Z, to obtain a peak current less than the maximum input current (ZC02). Refer to the "Electrical Specifications" chapter for more details. Next, arbitrarily select a suitably large nonpolar capacitor and compute its reactance, Xc, at the external voltage source frequency. Finally, compute the series resistor, capacitor peak voltage, and phase shift using the formulas shown below. When this technique is used and the input signal is not present, the ZCD will tend to oscillate. To avoid this oscillation, connect the ZCD pin to $V_{DD}$ or GND with a high-impedance resistor. Note: In this example, the impedance value is calculated for a peak current of 300 µA. #### Equation 36-2. R-C Equations V<sub>PEAK</sub> = external voltage source peak voltage f = external voltage source frequency C = series capacitor R = series resistor V<sub>C</sub> = peak capacitor voltage $\Phi$ = capacitor induced zero-crossing phase advance in radians $T_{\Phi}$ = time ZC event occurs before actual zero-crossing $$Z = \frac{V_{PEAK}}{3 \times 10^{-4}}$$ $$X_C = \frac{1}{2\pi f C}$$ $$R = \sqrt{Z^2 - X_C^2}$$ $$V_C = X_C \left(3 \times 10^{-4}\right)$$ $$\Phi = \tan^{-1} \left( \frac{X_C}{R} \right)$$ $$T_{\Phi} = \frac{\Phi}{2\pi f}$$ ### Equation 36-3. R-C Calculation Example $$V_{rms}=120\,$$ $$V_{PEAK} = V_{rms} \times \sqrt{2} = 169.7$$ $$f = 60 Hz$$ $$C = 0.1 \,\mu F$$ $$Z = \frac{V_{PEAK}}{3 \times 10^{-4}} = \frac{169.7}{3 \times 10^{-4}} = 565.7 \,k\Omega$$ $$X_C = \frac{1}{2\pi f C} = \frac{1}{2\pi \times 60 \times 10^{-7}} = 26.53 \,k\Omega$$ $$R = \sqrt{Z^2 - X_C^2} = 565.1 \,k\Omega \,(computed)$$ $$R_a = 560 \,k\Omega \,(used)$$ $$Z_R = \sqrt{R_a^2 + X_C^2} = 560.6 \,k\Omega$$ $$I_{PEAK} = \frac{V_{PEAK}}{Z_R} = 302.7 \times 10^{-6} A$$ $$V_C = X_C \times I_{PEAK} = 8.0 \,V$$ $$\Phi = \tan^{-1}\left(\frac{X_C}{R}\right) = 0.047 \, radians$$ $$T_{\Phi} = \frac{\Phi}{2\pi f} = 125.6 \,\mu s$$ ## 36.5.2 Correction by Offset Current When the waveform is varying relative to $V_{SS}$ , the zero-cross is detected too early as the waveform falls and too late as the waveform rises. When the waveform is varying relative to $V_{DD}$ , the zero-cross is detected too late as the waveform rises and too early as the waveform falls. The actual offset time can be determined for sinusoidal waveforms with the corresponding equations shown below. ## Equation 36-4. ZCD Event Offset When External Voltage source is relative to VSS: $$T_{offset} = \frac{\sin^{-1}\left(\frac{Z_{CPINV}}{V_{PEAK}}\right)}{2\pi f}$$ When External Voltage source is relative to $V_{\text{DD}}$ : $$T_{offset} = \frac{\sin^{-1}\left(\frac{V_{DD} - Z_{CPINV}}{V_{PEAK}}\right)}{2\pi f}$$ This offset time can be compensated for by adding a pull-up or pull-down biasing resistor to the ZCD pin. A pull-up resistor is used when the external voltage source is varying relative to $V_{SS}$ . A pull-down resistor is used when the voltage is varying relative to $V_{DD}$ . The resistor adds a bias to the ZCD pin so that the target external voltage source must go to zero to pull the pin voltage to the $Z_{CPINV}$ switching voltage. The pull-up or pull-down value can be determined with the equations shown below. #### Equation 36-5. ZCD Pull-up/Pull-down Resistor When External Voltage source is relative to V<sub>SS</sub>: $$R_{pullup} = \frac{R_{SERIES} \left( V_{pullup} - Z_{CPINV} \right)}{Z_{CPINV}}$$ When External Voltage source is relative to V<sub>DD</sub>: $$R_{pulldown} = \frac{R_{SERIES}(Z_{CPINV})}{(V_{DD} - Z_{CPINV})}$$ ## 36.6 Handling V<sub>PEAK</sub> Variations If the peak amplitude of the external voltage is expected to vary, the series resistor must be selected to keep the ZCD current source, and sink below the design maximum range specified by ZC02 and above a reasonable minimum range depending on the application. The compensating pull-up for this series resistance can be determined with the equations shown in Equation 36-5 because the pull-up value is independent from the peak voltage. **Tip:** It is recommended that the maximum peak voltage be no more than six times the minimum peak voltage. ## 36.7 Operation During Sleep The ZCD current sources and interrupts are unaffected by Sleep. #### 36.8 Effects of a Reset The ZCD circuit can be configured to default to the Active or Inactive state on Power-on Reset (POR). When the $\overline{\text{ZCD}}$ Configuration bit is cleared, the ZCD circuit will be active at POR. When the $\overline{\text{ZCD}}$ Configuration bit is set, the SEN bit must be set to enable the ZCD module. ## 36.9 Disabling the ZCD Module The ZCD module can be disabled in two ways: - The ZCD Configuration bit disables the ZCD module when set. When this is the case, then the ZCD module will be enabled by setting the SEN bit. When the ZCD bit is clear, the ZCD is always enabled and the SEN bit has no effect. - 2. The ZCD can also be disabled using the ZCDMD bit of the PMDx register. This is subject to the status of the ZCD bit. ## 36.10 Register Definitions: ZCD Control Long bit name prefixes for the ZCD peripherals are shown in the table below. Refer to the "Long Bit Names" section of the "Register and Bit Naming Conventions" chapter for more information. Table 36-1. ZCD Long Bit Name Prefixes | Peripheral | Bit Name Prefix | |------------|-----------------| | ZCD | ZCD | #### 36.10.1 ZCDCON Name: ZCDCON Offset: 0x101F Zero-Cross Detect Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|---|-----|-----|---|---|------|------| | | SEN | | OUT | POL | | | INTP | INTN | | Access | R/W | | R | R/W | | • | R/W | R/W | | Reset | 0 | | x | 0 | | | 0 | 0 | #### Bit 7 - SEN Zero-Cross Detect Software Enable This bit is ignored when the ZCD fuse is cleared. | Value | Condition | Description | |-------|---------------------|---------------------------------------------------------------------------------------| | X | ZCD Config fuse = 0 | Zero-cross detect is always enabled. This bit is ignored. | | 1 | ZCD Config fuse = 1 | Zero-cross detect is enabled. ZCD pin is forced to output to source and sink current. | | 0 | ZCD Config fuse = 1 | Zero-cross detect is disabled. ZCD pin operates according to PPS and TRIS controls. | #### Bit 5 - OUT Zero-Cross Detect Data Output | Value | Condition | Description | |-------|-----------|-----------------------------| | 1 | POL = 0 | ZCD pin is sinking current | | 0 | POL = 0 | ZCD pin is sourcing current | | 1 | POL = 1 | ZCD pin is sourcing current | | 0 | POL = 1 | ZCD pin is sinking current | #### Bit 4 - POL Zero-Cross Detect Polarity | Value | Description | |-------|----------------------------------| | 1 | ZCD logic output is inverted | | 0 | ZCD logic output is not inverted | ## Bit 1 – INTP Zero-Cross Detect Positive-Going Edge Interrupt Enable | V | /alue | Description | |---|-------|------------------------------------------------------------------| | 1 | • | The ZCDIF bit is set on low-to-high ZCD_output transition | | C | ) | The ZCDIF bit is unaffected by low-to-high ZCD_output transition | #### Bit 0 - INTN Zero-Cross Detect Negative-Going Edge Interrupt Enable | Value | escription | |-------|-----------------------------------------------------------------| | 1 | he ZCDIF bit is set on high-to-low ZCD_output transition | | 0 | he ZCDIF bit is unaffected by high-to-low ZCD_output transition | # 36.11 Register Summary - ZCD | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-----|---|-----|-----|---|---|------|------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x101E | | | | | | | | | | | | 0x101F | ZCDCON | 7:0 | SEN | | OUT | POL | | | INTP | INTN | # 37. Charge Pump This family of devices offers a dedicated charge pump, which is controlled through the Charge Pump Control (CPCON) register. The primary purpose of the charge pump is to supply a constant voltage to the gates of transistor devices contained in analog peripherals, signal and reference input pass-gates, and to prevent degradation of transistor performance at low operating voltages. The charge pump offers the following modes: - Manually Enabled - · Automatically Enabled - Disabled ## 37.1 Manually Enabled The charge pump can be manually enabled via the Charge Pump Enable (CPON) bits. When the CPON bits are configured as '11', the charge pump is enabled. In this case, the charge pump provides additional voltage to all analog systems, regardless of $V_{DD}$ levels, but also consumes additional current. ## 37.2 Automatically Enabled The charge pump can also be enabled automatically. This allows the application to determine when to enable the charge pump. If the charge pump is enabled while $V_{DD}$ levels are above a sufficient threshold, the charge pump does not improve analog performance, but also consumes additional current. Allowing hardware to monitor $V_{DD}$ and determine when to enable the charge pump prevents unnecessary current consumption. When the CPON bits are configured as '10', charge pump hardware monitors $V_{DD}$ and compares the $V_{DD}$ levels to a reference voltage threshold ( $V_{AUTO}$ ), which is set to 4.096V. When hardware detects a $V_{DD}$ level lower than the threshold, the charge pump is automatically enabled. If $V_{DD}$ returns to a level above the threshold, hardware automatically disables the charge pump. When the CPON bits are configured as '01', charge pump hardware waits for an analog peripheral, such as the ADC, to be enabled before monitoring $V_{DD}$ . In this case, charge pump hardware monitors all analog peripherals, and once an analog peripheral is enabled, hardware begins to compare $V_{DD}$ to $V_{AUTO}$ . When hardware detects a $V_{DD}$ level lower than the threshold, hardware enables the charge pump. If $V_{DD}$ returns to a level above the threshold, or if the analog peripheral is disabled, the charge pump is automatically disabled. ### 37.3 Disabled The charge pump is disabled by default (CPON = 00). Clearing the CPON bits will disable the charge pump. ### 37.4 Charge Pump Oscillator The Charge Pump Oscillator Selection (CPOS) bit selects the charge pump oscillator source. The CPOS bit allows the user to select between the charge pump's internal oscillator or the oscillator driving the ADC. When CPOS is set (CPOS = 1), the charge pump utilizes its internal oscillator. The charge pump's internal oscillator provides a very steady output voltage, but at the expense of higher operating current. When CPOS is clear (CPOS = 0), and the ADGO bit is clear (GO = 0), the charge pump is clock by the ADCRC. When ADGO is set (GO = 1), the charge pump is clocked by a derivative of the F<sub>OSC</sub> (as determined by the ADCLK register). This allows the charge pump to operate at a lower current when the ADC is not converting, while offering higher performance when the ADC is converting. ## 37.5 Charge Pump Threshold The Charge Pump Threshold (CPT) bit indicates whether or not $V_{DD}$ is at an acceptable operating level. Charge pump hardware compares $V_{DD}$ to the threshold voltage ( $V_{AUTO}$ ), which is set at 4.096V. If $V_{DD}$ is above $V_{AUTO}$ , the CPT bit is set (CPT = 1). If $V_{DD}$ is below $V_{AUTO}$ , CPT is clear (CPT = 0). ## 37.6 Charge Pump Ready The Charge Pump Ready Status (CPRDY) bit indicates whether or not the charge pump is ready for use. When CPRDY is set (CPRDY = 1), the charge pump has reached a steady-state operation and is ready for use. When CPRDY is clear (CPRDY = 0), the charge pump is either in the OFF state or has not reached a steady-state operation. ## 37.7 Register Definitions: Charge Pump #### 37.7.1 CPCON Name: CPCON Offset: 0x100D Charge Pump Control Register | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|-----|--------|------|---|---|-------|-----|-------| | | CPO | N[1:0] | CPOS | | | CPREQ | CPT | CPRDY | | Access | R/W | R/W | R/W | • | • | R | R | R | | Reset | 0 | 0 | 0 | | | 0 | 0 | 0 | ## Bits 7:6 - CPON[1:0] Charge Pump Enable | s enabled | |-----------------------------------------------------------------------------------------------| | s automatically enabled when V <sub>DD</sub> < V <sub>AUTO</sub> (V <sub>AUTO</sub> = 4.096V) | | s automatically enabled when an analog peripheral is enabled (ADCON0.ON = 1) and | | | | s disabled | | | #### Bit 5 - CPOS Charge Pump Oscillator Selection | Value | Condition | Description | |-------|---------------------|----------------------------------------------------------------------| | 1 | | Charge pump clock is the internal charge pump oscillator | | 0 | When ADC GO bit = 1 | Charge pump clock is FOSC (oscillator frequency determined by ADCLK) | | 0 | When ADC GO bit = 0 | Charge pump clock is the ADCRC | #### Bit 2 - CPREQ Charge Pump Request Status | Value | Description | |-------|------------------------------------------------------------| | 1 | Charge pump has been requested by an analog peripheral | | 0 | Charge pump has not been requested by an analog peripheral | ## Bit 1 - CPT Charge Pump Threshold | Sharge Famp Threehold | | | | |-----------------------|-------------------------------------------------------------------------------------|--|--| | Value | Description | | | | 1 | V <sub>DD</sub> is above the charge pump auto-enable threshold (V <sub>AUTO</sub> ) | | | | 0 | V <sub>DD</sub> is below the charge pump auto-enable threshold (V <sub>AUTO</sub> ) | | | ### Bit 0 - CPRDY Charge Pump Ready Status | 1 | /alue | Description | | |---|-------|----------------------------------------------------------------|--| | 1 | L | Charge pump has reached a steady-state operation | | | ( | ) | Charge pump is off or has not reached a steady-state operation | | # 37.8 Register Summary - Charge Pump | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|----------|----------|-----|--------|------|---|---|-------|-----|-------| | 0x00 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x100C | | | | | | | | | | | | 0x100D | CPCON | 7:0 | CPO | N[1:0] | CPOS | | | CPREQ | CPT | CPRDY | # 38. Instruction Set Summary The PIC16F180 devices incorporate the standard set of 50 PIC16 core instructions. Each instruction is a 14-bit word containing the operation code (opcode) and all required operands. The opcodes are broken into three broad categories: - · Byte-Oriented - · Bit-Oriented - · Literal and Control The literal and control category contains the most varied instruction word format. Table 38-3 lists the instructions recognized by the XC8 assembler. All instructions are executed within a single instruction cycle, with the following exceptions, which may take two or three cycles: - Subroutine entry takes two cycles (CALL, CALLW) - Returns from interrupts or subroutines take two cycles (RETURN, RETLW, RETFIE) - Program branching takes two cycles (GOTO, BRA, BRW, BTFSS, BTFSC, DECFSZ, INCSFZ) - One additional instruction cycle will be used when any instruction references an indirect file register, and the file select register is pointing to program memory One instruction cycle consists of four oscillator cycles; for an oscillator frequency of 4 MHz, this gives a nominal instruction execution rate of 1 MHz. All instruction examples use the format '0xhh' to represent a hexadecimal number, where 'h' signifies a hexadecimal digit. ## 38.1 Read-Modify-Write Operations Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (RMW) operation. The register is read, the data is modified, and the result is stored according to either the Working (W) register, or the originating file register, depending on the state of the destination designator 'd' (see Table 38-1 for more information). A read operation is performed on a register even if the instruction writes to that register. Table 38-1. Opcode Field Descriptions | Field | Description | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | f | Register file address (0x00 to 0x7F) | | W | Working register (accumulator) | | b | Bit address within an 8-bit file register | | k | Literal field, constant data or label | | x | "Don't care" location (= $0$ or $1$ ). The assembler will generate code with $x = 0$ . It is the recommended form of use for compatibility with all Microchip software tools. | | d | Destination select; d = 0: store result in W, d = 1: store result in file register f. | | n | FSR or INDF number. (0-1) | | mm | Pre/post increment/decrement mode selection | Table 38-2. Abbreviation Descriptions | Field | Description | |-------|-----------------| | PC | Program Counter | | continued | | | | | | | | |-----------|-----------------|--|--|--|--|--|--| | Field | Description | | | | | | | | TO | Time-Out bit | | | | | | | | С | Carry bit | | | | | | | | DC | Digit Carry bit | | | | | | | | Z | Zero bit | | | | | | | | PD | Power-Down bit | | | | | | | # 38.2 Standard Instruction Set Table 38-3. Instruction Set | Mnemo | | Description | Cycles | | 14-Bit ( | Opcode | | Status | Notes | |--------|------|------------------------------|--------|-----|----------|--------|------|----------|-------| | Operar | nds | Description | Cycles | MSb | | | LSb | Affected | notes | | | | BYTE-ORIENTED OPER | ATIONS | | | | | | | | ADDWF | f, d | Add WREG and f | 1 | 00 | 0111 | dfff | ffff | C, DC, Z | 2 | | ADDWFC | f, d | Add WREG and Carry bit to f | 1 | 11 | 1101 | dfff | ffff | C, DC, Z | 2 | | ANDWF | f, d | AND WREG with f | 1 | 00 | 0101 | dfff | ffff | Z | 2 | | ASRF | f, d | Arithmetic Right Shift | 1 | 11 | 0111 | dfff | ffff | C, Z | 2 | | LSLF | f, d | Logical Left Shift | 1 | 11 | 0101 | dfff | ffff | C, Z | 2 | | LSRF | f, d | Logical Right Shift | 1 | 11 | 0110 | dfff | ffff | C, Z | 2 | | CLRF | f | Clear f | 1 | 00 | 0001 | lfff | ffff | Z | 2 | | CLRW | _ | Clear WREG | 1 | 00 | 0001 | 0000 | 00xx | Z | | | COMF | f, d | Complement f | 1 | 00 | 1001 | dfff | ffff | Z | 2 | | DECF | f, d | Decrement f | 1 | 00 | 0011 | dfff | ffff | Z | 2 | | INCF | f, d | Increment f | 1 | 00 | 1010 | dfff | ffff | Z | 2 | | IORWF | f, d | Inclusive OR WREG with f | 1 | 00 | 0100 | dfff | ffff | Z | 2 | | MOVF | f, d | Move f | 1 | 00 | 1000 | dfff | ffff | Z | 2 | | MOVWF | f | Move WREG to f | 1 | 00 | 0000 | 1fff | ffff | None | 2 | | RLF | f, d | Rotate Left f through Carry | 1 | 00 | 1101 | dfff | ffff | С | 2 | | RRF | f, d | Rotate Right f through Carry | 1 | 00 | 1100 | dfff | ffff | С | 2 | | con | | | | | | | | | | |------------------------|------|-------------------------------------|---------|-------|----------|--------|------|--------------------|-------| | <b>Mnemo</b><br>Operar | | Description | Cycles | MSb | 14-Bit ( | Opcode | LSb | Status<br>Affected | Notes | | SUBWF | f, d | Subtract WREG from f | 1 | 00 | 0010 | dfff | ffff | C, DC, Z | 2 | | SUBWFB | f, d | Subtract WREG from f with<br>Borrow | 1 | 11 | 1011 | dfff | ffff | C, DC, Z | 2 | | SWAPF | f, d | Swap nibbles in f | 1 | 00 | 1110 | dfff | ffff | None | 2 | | XORWF | f, d | Exclusive OR WREG with f | 1 | 00 | 0110 | dfff | ffff | Z | 2 | | | , | BYTE-ORIENTED SKIP OP | ERATION | NS | | | | | | | DECFSZ | f, d | Decrement f, Skip if 0 | 1(2) | 00 | 1011 | dfff | ffff | None | 1, 2 | | INCFSZ | f, d | Increment f, Skip if 0 | 1(2) | 00 | 1111 | dfff | ffff | None | 1, 2 | | | | BIT-ORIENTED FILE REGISTER | OPERA | TIONS | | | | | | | BCF | f, b | Bit Clear f | 1 | 01 | 00bb | bfff | ffff | None | 2 | | BSF | f, b | Bit Set f | 1 | 01 | 01bb | bfff | ffff | None | 2 | | | ' | BIT-ORIENTED SKIP OPE | RATION | S | | | | | | | BTFSC | f, b | Bit Test f, Skip if Clear | 1(2) | 01 | 10bb | bfff | ffff | None | 1, 2 | | BTFSS | f, b | Bit Test f, Skip if Set | 1(2) | 1010 | 11bb | bfff | ffff | None | 1, 2 | | · | ' | LITERAL OPERATION | NS | | | | | | | | ADDLW | k | Add literal and WREG | 1 | 11 | 1110 | kkkk | kkkk | C, DC, Z | | | ANDLW | k | AND literal with WREG | 1 | 11 | 1001 | kkkk | kkkk | Z | | | IORLW | k | Inclusive OR literal with WREG | 1 | 11 | 1000 | kkkk | kkkk | Z | | | MOVLB | k | Move literal to BSR | 1 | 00 | 000 | 0 k | kkkk | None | | | MOVLP | k | Move literal to PCLATH | 1 | 11 | 0001 | 1kkk | kkkk | None | | | MOVLW | k | Move literal to W | 1 | 11 | 0000 | kkkk | kkkk | None | | | SUBLW | k | Subtract W from literal | 1 | 11 | 1100 | kkkk | kkkk | C, DC, Z | | | XORLW | k | Exclusive OR literal with W | 1 | 11 | 1010 | kkkk | kkkk | Z | | | | | CONTROL OPERATION | ONS | | | | | | | | cor | | | | | | | | | | |------------------------|-------|---------------------------------------------------------------|----------|-----|--------|--------|------|--------------------|------| | <b>Mnemo</b><br>Operar | | Description | Cycles | | 14-Bit | Opcode | | Status<br>Affected | Note | | | | | <u> </u> | MSb | | | LSb | | | | BRA | k | Relative Branch | 2 | 11 | 001k | kkkk | kkkk | None | | | BRW | _ | Relative Branch with WREG | 2 | 00 | 0000 | 0000 | 1011 | None | - | | CALL | k | Call Subroutine | 2 | 10 | 0kkk | kkkk | kkkk | None | - | | CALLW | _ | Call Subroutine with WREG | 2 | 00 | 0000 | 0000 | 1010 | None | | | GOTO | k | Go to address | 2 | 10 | 1kkk | kkkk | kkkk | None | - | | RETFIE | k | Return from interrupt | 2 | 00 | 0000 | 0000 | 1001 | None | - | | RETLW | k | Return with literal in WREG | 2 | 11 | 0100 | kkkk | kkkk | None | | | RETURN | _ | Return from Subroutine | 2 | 00 | 0000 | 0000 | 1000 | None | - | | | | INHERENT OPERATION | S | | | | | | 1 | | CLRWDT | _ | Clear Watchdog Timer | 1 | 00 | 0000 | 0110 | 0100 | TO, PD | | | NOP | _ | No Operation | 1 | 00 | 0000 | 0000 | 0000 | None | | | RESET | _ | Software device Reset | 1 | 00 | 0000 | 0000 | 0001 | None | | | SLEEP | _ | Go into Standby mode | 1 | 00 | 0000 | 0110 | 0011 | TO, PD | | | TRIS | f | Load TRIS register with WREG | 1 | 00 | 0000 | 0110 | Offf | None | | | | | C-COMPILER OPTIM | IZED | | | - | | | - | | ADDFSR | n, k | Add Literal k to FSRn | 1 | 11 | 0001 | 0nkk | kkkk | None | | | | n, mm | Move Indirect FSRn to WREG with pre/post inc/dec modifier, mm | 1 | 00 | 0000 | 0001 | Onmm | Z | 2, 3 | | MOVIW | k[n] | Move INDFn to WREG, Indexed Indirect. | 1 | 11 | 1111 | 0nkk | kkkk | Z | 2 | | | n, mm | Move WREG to Indirect FSRn with pre/post inc/dec modifier, mm | 1 | 00 | 0000 | 0001 | 1nmm | None | 2, 3 | | MOVWI | k[n] | Move WREG to INDFn, Indexed Indirect. | 1 | 11 | 1111 | 1nkk | kkkk | None | 2 | #### Notes: - 1. If the Program Counter (PC) is modified, or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP. - 2. If this instruction addresses an INDF register and the MSb of the corresponding FSR is set, this instruction will require one additional instruction cycle. - 3. Details on MOVIW and MOVWI instruction descriptions are available in the next section. ## 38.2.1 Standard Instruction Set | ADDFSR | Add Literal to FSRn | |---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] ADDFSR FSRn, k | | Operands: | $-32 \le k \le 31;$<br>$n \in [0, 1]$ | | Operation: | $FSR(n) + k \rightarrow FSR(n)$ | | Status<br>Affected: | None | | Description: | The signed 6-bit literal 'k' is added to the contents of the FSRnH:FSRnL register pair. FSRn is limited to the range 0000h-FFFFh. Moving beyond these bounds will cause the FSR to wrap-around. | | ADDLW | Add Literal to W | |------------------|-------------------------------------------------------------------------------------| | Syntax: | [ label ] ADDLW k | | Operands: | 0 ≤ k ≤ 255 | | Operation: | (W) + k → (W) | | Status Affected: | C, DC, Z | | Description: | The contents of W are added to the 8-bit literal 'k' and the result is placed in W. | | ADDWF | Add W to f | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] ADDWF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(W) + (f) \rightarrow dest$ | | Status Affected: | C, DC, Z | | Description: | Add the contents of the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. | | ADDWFC | Add W and Carry Bit to f | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] ADDWFC f {,d} | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(W) + (f) + (C) \rightarrow dest$ | | Status Affected: | C, DC, Z | | Description: | Add W, the Carry flag and data memory location 'f'. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is placed in data memory location 'f'. | | ANDLW | AND Literal with W | |------------|-------------------------------| | Syntax: | [ label ] ANDLW k | | Operands: | 0 ≤ k ≤ 255 | | Operation: | (W) .AND. $k \rightarrow (W)$ | | continued | | |------------------|-------------------------------------------------------------------------------------| | ANDLW | AND Literal with W | | Status Affected: | Z | | Description: | The contents of W are AND'ed with the 8-bit literal 'k'. The result is placed in W. | | ANDWF | AND W with f | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] ANDWF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | (W) .AND. (f) $\rightarrow$ dest | | Status Affected: | Z | | Description: | AND the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. | | ASRF | Arithmetic Right Shift | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] ASRF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | $(f[7]) \rightarrow dest[7]$ | | Operation: | $(f[7:1]) \rightarrow dest[6:0]$ | | | $(f[0]) \rightarrow C$ | | Status Affected: | C, Z | | Description: | The contents of register 'f' are shifted one bit to the right through the Carry flag. The MSb remains unchanged. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'. Register $f \rightarrow C$ | | BCF | Bit Clear f | |------------------|-------------------------------------| | Syntax: | [ label ] BCF f, b | | Operands: | $0 \le f \le 127$ $0 \le b \le 7$ | | Operation: | $0 \rightarrow f[b]$ | | Status Affected: | None | | Description: | Bit 'b' in register 'f' is cleared. | | BRA | Relative Branch | |-----------|---------------------------------------------| | Syntax: | [ label ] BRA label<br>[ label ] BRA \$+k | | Operands: | -256 ≤ label - PC + ≤ 255<br>-256 ≤ k ≤ 255 | | continued | | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BRA | Relative Branch | | Operation: | (PC) + 1 + k → PC | | Status<br>Affected: | None | | Description: | Add the signed 9-bit literal 'k' to the PC. Since the PC will have incremented to fetch the next instruction, the new address will be PC + 1 + k. This instruction is a two-cycle instruction. This branch has a limited range. | | BRW | Relative Branch with W | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] BRW | | Operands: | None | | Operation: | (PC) + (W) → PC | | Status Affected: | None | | Description: | Add the contents of W (unsigned) to the PC. Since the PC will have incremented to fetch the next instruction, the new address will be PC + 1 + (W). This instruction is a two-cycle instruction. | | BSF | Bit Set f | |------------------|-----------------------------------| | Syntax: | [ label ] BSF f, b | | Operands: | $0 \le f \le 127$ $0 \le b \le 7$ | | Operation: | $1 \to (f[b])$ | | Status Affected: | None | | Description: | Bit 'b' in register 'f' is set. | | BTFSC | Bit Test File, Skip If Clear | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] BTFSC f, b | | Operands: | 0 ≤ f ≤ 127<br>0 ≤ b ≤ 7 | | Operation: | skip if (f[b]) = 0 | | Status Affected: | None | | Description: | If bit 'b' in register 'f' is '1', the next instruction is executed. If bit 'b', in register 'f', is '0', the next instruction is discarded, and a NOP is executed instead, making this a two-cycle instruction. | | BTFSS | Bit Test File, Skip If Set | |------------|----------------------------| | Syntax: | [ label ] BTFSS f, b | | Operands: | 0 ≤ f ≤ 127<br>0 ≤ b < 7 | | Operation: | skip if (f[b]) = 1 | | continued | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BTFSS | Bit Test File, Skip If Set | | Status Affected: | None | | Description: | If bit 'b' in register 'f' is '0', the next instruction is executed. If bit 'b' is '1', then the next instruction is discarded, and a NOP is executed instead, making this a two-cycle instruction. | | CALL | Subroutine Call | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] CALL k | | Operands: | 0 ≤ k ≤ 2047 | | Operation: | $(PC) + 1 \rightarrow TOS,$ $k \rightarrow PC[10:0],$ $(PCLATH[6:3]) \rightarrow PC[14:11]$ | | Status Affected: | None | | Description: | Call Subroutine. First, return address (PC + 1) is pushed onto the stack. The 11-bit immediate address is loaded into PC bits [10:0]. The upper bits of the PC are loaded from PCLATH. CALL is a two-cycle instruction. | | CALLW | Subroutine Call with W | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Syntax: | [ label ] CALLW | | | Operands: | None | | | Operation: | $(PC) + 1 \rightarrow TOS,$ $(W) \rightarrow PC[7:0],$ $(PCLATH[6:0]) \rightarrow PC[14:8]$ | | | Status Affected: | None | | | Description: | Subroutine call with W. First, the return address (PC + 1) is pushed onto the return stack. Then, the contents of W is loaded into PC[7:0], and the contents of PCLATH into PC[14:8]. CALLW is a two-cycle instruction. | | | CLRF | Clear f | |------------------|----------------------------------------------------------------------| | Syntax: | [ label ] CLRF f | | Operands: | 0 ≤ f ≤ 127 | | Operation: | $\begin{array}{c} 000h \rightarrow f \\ 1 \rightarrow Z \end{array}$ | | Status Affected: | Z | | Description: | The contents of register 'f' are cleared and the Z bit is set. | | CLRW | Clear W | |-----------|----------------| | Syntax: | [ label ] CLRW | | Operands: | None | | continued | | |------------------|---------------------------------------------| | CLRW | Clear W | | Operation: | $00h \rightarrow (W)$ $1 \rightarrow Z$ | | Status Affected: | Z | | Description: | W register is cleared. Zero (Z) bit is set. | | CLRWDT | Clear Watchdog Timer | |------------------|-----------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] CLRWDT | | Operands: | None | | Operation: | 00h → WDT,<br>00h → WDT prescaler,<br>1 → $\overline{\text{TO}}$ ,<br>1 → $\overline{\text{PD}}$ | | Status Affected: | TO, PD | | Description: | The CLRWDT instruction resets the Watchdog Timer. It also resets the prescaler of the WDT. Status bits, TO and PD, are set. | | COMF | Complement f | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] COMF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(\overline{\mathfrak{f}}) o dest$ | | Status Affected: | Z | | Description: | The contents of register 'f' are complemented. If 'd' is '0', the result is stored in W. If 'd' is '1', the result is stored back in register 'f'. | | DECF | Decrement f | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] DECF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | (f) – 1 → dest | | Status Affected: | Z | | Description: | Decrement register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. | | DECFSZ | Decrement f, Skip If 0 | |---------|------------------------| | Syntax: | [ label ] DECFSZ f, d | | continued | | |--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DECFSZ | Decrement f, Skip If 0 | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | (f) − 1 → dest,<br>skip if result = 0 | | Description: | The contents of register 'f' are decremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. If the result is '1', the next instruction is executed. If the result is '0', then a NOP is executed instead, making it a two-cycle instruction. | | GOTO | Unconditional Branch | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] GOTO k | | Operands: | 0 ≤ k ≤ 2047 | | Operation: | k → PC[10:0]<br>PCLATH[6:3] → PC[14:11] | | Status Affected: | None | | Description: | GOTO is an unconditional branch. The 11-bit immediate value is loaded into PC bits [10:0]. The upper bits of PC are loaded from PCLATH[4:3]. GOTO is a two-cycle instruction. | | INCF | Increment f | | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Syntax: | [ label ] INCF f, d | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | Operation: | (f) + 1 → dest | | | Status Affected: | Z | | | Description: | The contents of register 'f' are incremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. | | | INCFSZ | Increment f, Skip If 0 | |------------------|---------------------------------------| | Syntax: | [ label ] INCFSZ f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | (f) + 1 → dest,<br>skip if result = 0 | | Status Affected: | None | | continued | | | | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | INCFSZ | Increment f, Skip If 0 | | | | | Description: | The contents of register 'f' are incremented. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. If the result is '1', the next instruction is executed. If the result is '0', a NOP is executed instead, making it a two-cycle instruction. | | | | | IORLW | Inclusive OR Literal with W | | | |------------------|-----------------------------------------------------------------------------------|--|--| | Syntax: | [ label ] IORLW k | | | | Operands: | 0 ≤ k ≤ 255 | | | | Operation: | (W) .OR. $k \rightarrow (W)$ | | | | Status Affected: | Z | | | | Description: | The contents of W are ORed with the 8-bit literal 'k'. The result is placed in W. | | | | IORWF | Inclusive OR W with f | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Syntax: | IORWF f, d | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | Operation: | (W) .OR. (f) $\rightarrow$ dest | | | Status Affected: | Z | | | Description: | Inclusive OR the W register with register 'f'. If 'd' is '0', the result is placed in the W register. If 'd' is '1', the result is placed back in register 'f'. | | | LSLF | Logical Left Shift | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] LSLF f {,d} | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $ \begin{array}{l} (f[7]) \rightarrow C \\ (f[6:0]) \rightarrow dest[7:1] \\ 0 \rightarrow dest[0] \end{array} $ | | Status Affected: | C, Z | | Description: | The contents of register 'f' are shifted one bit to the left through the Carry flag. A '0' is shifted into the LSb. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'. $C \leftarrow Register\ f \leftarrow 0$ | | LSRF | Logical Right Shift | |---------|-----------------------| | Syntax: | [ label ] LSRF f {,d} | | continued | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | LSRF | Logical Right Shift | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | Operation: | $0 \rightarrow \text{dest}[7]$ $(f[7:1]) \rightarrow \text{dest}[6:0],$ $(f[0]) \rightarrow C$ | | | Status Affected: | C, Z | | | Description: | The contents of register 'f' are shifted one bit to the right through the Carry flag. A '0' is shifted into the MSb. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is stored back in register 'f'. $0 \to \mathbf{Register} \ \mathbf{f} \to \mathbf{C}$ | | | MOVF | Move f | | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|--| | Syntax: | [ label ] MOVF f, d | [ label ] MOVF f, d | | | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | | | | Operation: | $f \rightarrow dest$ | | | | | Status Affected: | Z | | | | | Description: | The contents of register f is moved to a destination dependent upon the status of d. If $d = 0$ , destination is W register. If $d = 1$ , the destination is file register f itself. $d = 1$ is useful to test a file register since status flag Z is affected. | | | | | Words: | 1 | | | | | Cycles: | 1 | | | | | Example: | MOVF F | SR, 0 | |---------------------------------------------------|--------|-------| | After Instruction W = value in FSR register Z = 1 | | | | MOVIW | Move INDFn to W | |-----------|---------------------------------------------------------------| | Syntax: | [ label ] MOVIW ++FSRn<br>[ label ] MOVIWFSRn | | | [ label ] MOVIW FSRn++ | | | [ label ] MOVIW FSRn | | | [ label ] MOVIW k[FSRn] | | Operands: | $n \in [0,1]$<br>$mm \in [00,01,10,11]$<br>$-32 \le k \le 31$ | | continued | | | | | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|--| | MOVIW | Move INDFn to W | | | | | Operation: | INDFn → (W) Effective address is determined by • FSR + 1 (preincrement) • FSR - 1 (predecrement) • FSR + k (relative offset) After the Move, the FSR value will be either: • FSR + 1 (all increments) • FSR - 1 (all decrements) • Unchanged | | | | | | Z | | | | | | MODE | SYNTAX | mm | | | Status | Preincrement | ++FSRn | 00 | | | Affected: | Predecrement | FSRn | 01 | | | | Postincrement | FSRn++ | 10 | | | | Postdecrement | FSRn | 11 | | | Description: | This instruction is used to move data between W and one of the indirect registers (INDFn). Before/after this move, the pointer (FSRn) is updated by pre/post incrementing/decrementing it. The INDFn registers are not physical registers. Any instruction that accesses an INDFn register actually accesses the register at the address specified by the FSRn. FSRn is limited to the range 0000h - FFFFh. Incrementing/decrementing it beyond these bounds will cause it to wrap-around. | | | | | MOVLB | Move Literal to BSR | |------------------|----------------------------------------------------------------------| | Syntax: | [ label ] MOVLB k | | Operands: | 0 ≤ k ≤ 127 | | Operation: | $k \rightarrow BSR$ | | Status Affected: | None | | Description: | The 6-bit literal 'k' is loaded into the Bank Select Register (BSR). | | MOVLP | Move Literal to PCLATH | |------------------|-----------------------------------------------------------| | Syntax: | [ label ] MOVLP k | | Operands: | 0 ≤ k ≤ 127 | | Operation: | $k \rightarrow PCLATH$ | | Status Affected: | None | | Description: | The 7-bit literal 'k' is loaded into the PCLATH register. | | MOVLW | Move Literal to W | |-----------|-------------------| | Syntax: | [ label ] MOVLW k | | Operands: | 0 ≤ k ≤ 255 | | continued | | | | | |------------------|-------------------------------------------------------------------------------------------|----------|--|--| | MOVLW | Move Literal to W | <i>I</i> | | | | Operation: | $k \rightarrow (VV)$ | | | | | Status Affected: | None | | | | | Description: | The 8-bit literal 'k' is loaded into W register. The "don't cares" will assemble as '0's. | | | | | Words: | 1 | | | | | Cycles: | 1 | | | | | Example: | MOVLW | 5Ah | |------------------------------|-------|-----| | After Instruction<br>W = 5Ah | | | | MOVWF | Move W to f | | | | |------------------|-----------------------------------|--|--|--| | Syntax: | [ label ] MOVWF f | | | | | Operands: | 0 ≤ f ≤ 127 | | | | | Operation: | $(VV) \rightarrow f$ | | | | | Status Affected: | None | | | | | Description: | Move data from W to register 'f'. | | | | | Words: | 1 | | | | | Cycles: | 1 | | | | | Example: | MOVWF | LATA | |----------------------------------|-------|------| | Before Instruction<br>LATA = FFh | | | | <b>W</b> = 4 Fh | | | | After Instruction | | | | LATA = 4Fh | | | | <b>W</b> = 4 Fh | | | | MOVWI | Move W to INDFn | |-----------|---------------------------------------------------------------| | Syntax: | [ label ] MOVWI ++FSRn<br>[ label ] MOVWIFSRn | | | [ label ] MOVWI FSRn++ | | | [ label ] MOVWI FSRn | | | [ label ] MOVWI k[FSRn] | | Operands: | $n \in [0,1]$<br>$mm \in [00,01,10,11]$<br>$-32 \le k \le 31$ | | continued | | | | | |--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----|--| | MOVWI | Move W to INDFn | | | | | Operation: | <ul> <li>(W) → INDFn</li> <li>Effective address is determined by</li> <li>FSR + 1 (preincrement)</li> <li>FSR - 1 (predecrement)</li> <li>FSR + k (relative offset)</li> </ul> After the Move, the FSR value will be either: <ul> <li>FSR + 1 (all increments)</li> <li>FSR - 1 (all decrements)</li> <li>Unchanged</li> </ul> | | | | | | None | | | | | | MODE | SYNTAX | mm | | | Status | Preincrement | ++FSRn | 00 | | | Affected: | Predecrement | FSRn | 01 | | | | Postincrement | FSRn++ | 10 | | | | Postdecrement | FSRn | 11 | | | Description: | This instruction is used to move data between W and one of the indirect registers (INDFn). Before/after this move, the pointer (FSRn) is updated by pre/post incrementing/decrementing it. The INDFn registers are not physical registers. Any instruction that accesses an INDFn register actually accesses the register at the address specified by the FSRn. FSRn is limited to the range 0000h-FFFFh. Incrementing/decrementing it beyond these bounds will cause it to wrap-around. The increment/decrement operation on FSRn will not affect any Status bits. | | | | | NOP | No Operation | |------------------|---------------| | Syntax: | [ label ] NOP | | Operands: | None | | Operation: | No operation | | Status Affected: | None | | Description: | No operation. | | Words: | 1 | | Cycles: | 1 | | Example: | NOP | |----------|-----| | None. | | | RESET | Software Reset | |------------|------------------------------------------------------------------| | Syntax: | [ label ] RESET | | Operands: | None | | Operation: | Execute a device Reset. Resets the RI flag of the PCON register. | | continued | | |------------------|--------------------------------------------------------------------------| | RESET | Software Reset | | Status Affected: | None | | Description: | This instruction provides a way to execute a hardware Reset by software. | | RETFIE | Return from Interrupt | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Syntax: | [ label ] RETFIE k | | | | Operands: | None | | | | Operation: | (TOS) → PC,<br>1 → GIE | | | | Status Affected: | None | | | | Description: | Return from Interrupt. Stack is POPed and Top-of-Stack (TOS) is loaded in the PC. Interrupts are enabled by setting the Global Interrupt Enable bit, GIE (INTCON[7]). This is a two-cycle instruction. | | | | Words: | 1 | | | | Cycles: | 2 | | | | Example: | RETFIE | |-----------------------------|--------| | After Interrupt<br>PC = TOS | | | GIE = 1 | | | RETLW | Return Literal to W | | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Syntax: | [ label ] RETLW k | | | Operands: | 0 ≤ k ≤ 255 | | | Operation: | $k \rightarrow (W),$<br>(TOS) $\rightarrow$ PC, | | | Status Affected: | None | | | Description: | The W register is loaded with the 8-bit literal 'k'. The program counter is loaded from the top of the stack (the return address). This is a two-cycle instruction. | | | Words: | 1 | | | Cycles: | 2 | | ``` Example: CALL TABLE ; W contains table ; offset value ; W now has ; table value : TABLE ADDWF PC ; W = offset RETLW k1 ; Begin table RETLW k2 ; : RETLW kn ; End of table Before Instruction W = 07h After Instruction W = value of k8 ``` | RETURN | Return from Subroutine | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--|--| | Syntax: | [ label ] RETURN | [ label ] RETURN | | | | Operands: | None | None | | | | Operation: | $(TOS) \rightarrow PC$ , | | | | | Status Affected: | None | | | | | Encoding: | 0000 | 0000 0000 0001 001s | | | | Description: | Return from subroutine. The stack is POPped and the top of the stack (TOS) is loaded into the Program Counter. This is a two-cycle instruction. | | | | | RLF | Rotate Left f through Carry | | | | |------------------|-------------------------------------------------------------------------------------------|-------------------------------|------|-------| | Syntax: | [ label ] RLF f, d | | | | | Operands: | 0 ≤ f ≤ 127<br>d ∈ [0,1] | - ' '=' | | | | Operation: | $(f[n]) \rightarrow dest[n + 1],$<br>$(f[7]) \rightarrow C,$<br>$(C) \rightarrow dest[0]$ | | | | | Status Affected: | С | | | | | Encoding: | 0011 | 01da | ffff | ffff | | Description: | If 'd' is '0', the result is pl | ored back in register 'f' (de | | flag. | | Words: | 1 | | | | | Cycles: | 1 | | | | | Example: | RLF | REG1, 0 | |----------------------------------------|-----|---------| | Before Instruction<br>REG1 = 1110 0110 | | | | C = 0 | | | | After Instruction | | | | REG = 1110 0110 | | | | W = 1100 1100 | | | | C = 1 | | | | RRF | Rotate Right f through Carry | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [label] RRF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(f[n]) \rightarrow dest[n-1],$<br>$(f[0]) \rightarrow C,$<br>$(C) \rightarrow dest[7]$ | | Status Affected: | С | | Description: | The contents of register 'f' are rotated one bit to the right through the Carry flag. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is placed back in register 'f' (default). C register f | | SLEEP | Enter Sleep Mode | |------------------|-------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] SLEEP | | Operands: | None | | Operation: | 00h → WDT,<br>0 → WDT prescaler,<br>1 → $\overline{TO}$ ,<br>0 → $\overline{PD}$ | | Status Affected: | TO, PD | | Description: | The Power-Down (PD) Status bit is cleared. The Time-Out (TO) Status bit is set. Watchdog Timer and its prescaler are cleared. | | SUBLW | Subtract W from Literal | |------------------|---------------------------| | Syntax: | [ label ] SUBLW k | | Operands: | 0 ≤ k ≤ 255 | | Operation: | $k - (W) \rightarrow (W)$ | | Status Affected: | C, DC, Z | | continued | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------| | SUBLW | Subtract W from Literal | | | The W register is subtracted (two's complement method) from the 8-bit literal 'k'. The result is placed in the W register. $C = 0$ , W > k | | Description | $C = 1, W \le k$ | | | DC = 0, $W[3:0] > k[3:0]$ | | | $DC = 1, W[3:0] \le k[3:0]$ | | SUBWF | Subtract W from f | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] SUBWF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(f) - (W) \rightarrow (dest)$ | | Status Affected: | C, DC, Z | | Description | Subtract (two's complement method) W register from register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f. $C = 0$ , $W > f$ $C = 1$ , $W \le f$ $DC = 0$ , $W[3:0] > f[3:0]$ $DC = 1$ , $W[3:0] \le f[3:0]$ | | SUBWFB | Subtract W from f with Borrow | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] SUBFWB f {,d} | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(W) - (f) - (\overline{B}) \rightarrow dest$ | | Status Affected: | C, DC, Z | | Description: | Subtract W and the Borrow flag (Carry) from register 'f' (two's complement method). If 'd' is '0', the result is stored in W. If 'd' is '1', the result is stored back in register 'f'. | | SWAPF | Swap Nibbles in f | |------------------|-----------------------------------------------------------------------| | Syntax: | [ label ] SWAPF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | $(f[3:0]) \rightarrow dest[7:4],$<br>$(f[7:4]) \rightarrow dest[3:0]$ | | Status Affected: | None | | continued | | | | | | | | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | SWAPF | Swap Nibbles in f | | | | | | | | Description: | The upper and lower nibbles of register 'f' are exchanged. If 'd' is '0', the result is placed in W. If 'd' is '1', the result is placed in register 'f' (default). | | | | | | | | TRIS | Load TRIS Register with W | |------------------|------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] TRIS f | | Operands: | 5 ≤ f ≤ 7 | | Operation: | (W) → TRIS register 'f' | | Status Affected: | None | | Description: | Move data from W register to TRIS register. When 'f' = 5, TRISA is loaded. When 'f' = 6, TRISB is loaded. When 'f' = 7, TRISC is loaded. | | XORLW | Exclusive OR Literal with W | |------------------|------------------------------------------------------------------------------------| | Syntax: | [ label ] XORLW k | | Operands: | 0 ≤ k ≤ 255 | | Operation: | (W) .XOR. $k \rightarrow (W)$ | | Status Affected: | Z | | Description: | The contents of W are XORed with the 8-bit literal 'k'. The result is placed in W. | | XORWF | Exclusive OR W with f | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Syntax: | [ label ] XORWF f, d | | Operands: | $0 \le f \le 127$<br>$d \in [0,1]$ | | Operation: | (W) .XOR. (f) $\rightarrow$ dest | | Status Affected: | Z | | Description: | Exclusive OR the contents of the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. | # 39. ICSP<sup>™</sup> - In-Circuit Serial Programming<sup>™</sup> ICSP programming allows customers to manufacture circuit boards with unprogrammed devices. Programming can be done after the assembly process, allowing the device to be programmed with the most recent firmware or a custom firmware. Five pins are needed for ICSP programming: - ICSPCLK - ICSPDAT - MCLR/V<sub>PP</sub> - V<sub>DD</sub> - V<sub>SS</sub> In Program/Verify mode, the program memory, User IDs and the Configuration bits are programmed through serial communications. The ICSPDAT pin is a bidirectional I/O used for transferring the serial data and the ICSPCLK pin is the clock input. For more information on ICSP, refer to the "Family Programming Specification". ## 39.1 High-Voltage Programming Entry Mode The device is placed into High-Voltage Programming Entry mode by holding the ICSPCLK and ICSPDAT pins low, then raising the voltage on $\overline{MCLR}/V_{PP}$ to $V_{IH}$ . ## 39.2 Low-Voltage Programming Entry Mode The Low-Voltage Programming Entry mode allows the $PIC^{\otimes}$ Flash MCUs to be programmed using $V_{DD}$ only, without high voltage. When the LVP Configuration bit is set to '1', the low-voltage ICSP programming entry is enabled. To disable the Low-Voltage ICSP mode, the LVP bit must be programmed to '0'. Entry into the Low-Voltage Programming Entry mode requires the following steps: - 1. $\overline{\mathsf{MCLR}}$ is brought to $\mathsf{V}_\mathsf{H}$ . - 2. A 32-bit key sequence is presented on ICSPDAT, while clocking ICSPCLK. Once the key sequence is complete, $\overline{MCLR}$ must be held at $V_{IL}$ for as long as Program/Verify mode is to be maintained. If low-voltage programming is enabled (LVP = 1), the $\overline{MCLR}$ Reset function is automatically enabled and cannot be disabled. See the $\overline{MCLR}$ section for more information. The LVP bit can only be reprogrammed to '0' by using the High-Voltage Programming mode. ## 39.3 Common Programming Interfaces Connection to a target device is typically done through an ICSP header. A commonly found connector on development tools is the RJ-11 in the 6P6C (6-pin, 6-connector) configuration. See Figure 39-1. Figure 39-1. ICD RJ-11 Style Connector Interface Pin Description - $1 = V_{PP} / \overline{MCLR}$ - 2 = V<sub>DD</sub> Target - $3 = V_{SS}$ (ground) - 4 = ICSPDAT - 5 = ICSPCLK - 6 = No Connect Another connector often found in use with the PICkit<sup>™</sup> programmers is a standard 6-pin header with 0.1 inch spacing. Refer to Figure 39-2. For additional interface recommendations, refer to the specific device programmer manual prior to PCB design. It is recommended that isolation devices be used to separate the programming pins from other circuitry. The type of isolation is highly dependent on the specific application and may include devices such as resistors, diodes, or even jumpers. See Figure 39-3 for more information. Figure 39-2. PICkit™ Programmer Style Connector Interface Pin Description<sup>(1)</sup>: $1 = V_{PP} / \overline{MCLR}$ $2 = V_{DD}$ Target $3 = V_{SS}$ (ground) 4 = ICSPDAT 5 = ICSPCLK 6 = No Connect #### Note: 1. The 6-pin header (0.100" spacing) accepts 0.025" square pins. Figure 39-3. Typical Connection for ICSP™ Programming \* Isolation devices (as required). # 40. Register Summary | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |--------------|--------------|------------|-----------------|-------------------|-----------------|------------------|---------------|-----------------|------------------|------------------|--| | 0x00 | INDF0 | 7:0 | | | l . | INDF | 0[7:0] | | | | | | 0x01 | INDF1 | 7:0 | | | | INDF | | | | | | | 0x02 | PCL | 7:0 | | | | | [7:0] | | | | | | 0x03 | STATUS | 7:0 | | | | TO | PD | Z | DC | С | | | | | 7:0 | | ! | ! | FSR | | | Į. | | | | 0x04 | FSR0 | 15:8 | | FSR0[15:8] | | | | | | | | | 0.00 | E0D4 | 7:0 | | | | FSR <sup>-</sup> | | | | | | | 0x06 | FSR1 | 15:8 | | | | FSR1 | | | | | | | 0x08 | BSR | 7:0 | | | | | BSR | [5:0] | | | | | 0x09 | WREG | 7:0 | | | | WRE | G[7:0] | | | | | | 0x0A | PCLATH | 7:0 | | | | | PCLATH[6:0] | | | | | | 0x0B | INTCON | 7:0 | GIE | PEIE | | | | | | INTEDG | | | 0x0C | PORTA | 7:0 | | | RA5 | RA4 | RA3 | RA2 | RA1 | RA0 | | | 0x0D | PORTB | 7:0 | RB7 | RB6 | RB5 | RB4 | | | | | | | 0x0E | PORTC | 7:0 | RC7 | RC6 | RC5 | RC4 | RC3 | RC2 | RC1 | RC0 | | | 0x0F | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x11 | | | | | | | | | | | | | 0x12 | TRISA | 7:0 | | | TRISA5 | TRISA4 | Reserved | TRISA2 | TRISA1 | TRISA0 | | | 0x13 | TRISB | 7:0 | TRISB7 | TRISB6 | TRISB5 | TRISB4 | | | | | | | 0x14 | TRISC | 7:0 | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | | | 0x15 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x17 | | | | | | | | | | | | | 0x18 | LATA | 7:0 | | | LATA5 | LATA4 | | LATA2 | LATA1 | LATA0 | | | 0x19 | LATB | 7:0 | LATB7 | LATB6 | LATB5 | LATB4 | | | | | | | 0x1A | LATC | 7:0 | LATC7 | LATC6 | LATC5 | LATC4 | LATC3 | LATC2 | LATC1 | LATC0 | | | 0x1B | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x8B | | | | | | | | | | | | | 0x8C | PIR0 | 7:0 | | | TMR0IF | IOCIF | | | | INTF | | | 0x8D | PIR1 | 7:0 | TMR2IF | TMR3GIF | TMR3IF | TMR1GIF | TMR1IF | ACTIF | | NVMIF | | | 0x8E | PIR2 | 7:0 | CLC2IF | CLC1IF | CWG1IF | NCO1IF | CCP2IF | CCP1 <b>I</b> F | TMR6IF | TMR4IF | | | 0x8F | PIR3 | 7:0 | BCL1 <b>I</b> F | SSP1IF | RC2IF | TX2IF | RC1IF | TX1IF | CLC4IF | CLC3IF | | | 0x90 | PIR4 | 7:0 | | | ZCDIF | ADTIF | ADIF | CM1 <b>I</b> F | BCL2IF | SSP2IF | | | 0x91 | | | | | | | | | | | | | | Reserved | | | | | | | | | | | | 0x95 | DIEO | 7.0 | | | TMDOLE | IOOIE | | | | INITE | | | 0x96 | PIE0<br>PIE1 | 7:0<br>7:0 | TMDOLE | TMD2CIE | TMR0IE | IOCIE | TMD4IF | ACTIC | | INTE | | | 0x97 | | | TMR2IE | TMR3GIE<br>CLC1IE | TMR3IE | TMR1GIE | TMR1IE | ACTIE | TMDelF | NVMIE | | | 0x98 | PIE2 | 7:0 | CLC2IE | | CWG1IE<br>RC2IE | NCO1IE | CCP2IE | CCP1IE | TMR6IE | TMR4IE | | | 0x99<br>0x9A | PIE3<br>PIE4 | 7:0<br>7:0 | BCL1IE | SSP1IE | ZCDIE | TX2IE<br>ADTIE | RC1IE<br>ADIE | TX1IE<br>CM1IE | CLC4IE<br>BCL2IE | CLC3IE<br>SSP2IE | | | 0x9A<br>0x9B | FIE4 | 7.0 | | | ZODIE | ADITE | ADIC | CIVITIE | BULZIE | JOFZIE | | | | Reserved | | | | | | | | | | | | <br>0x018B | r coei veu | | | | | | | | | | | | 0x018C | WDTCON | 7:0 | CS | | | | PS[4:0] | | | SEN | | | 0x018D | BORCON | 7:0 | SBOREN | | | | 1 0[4.0] | | | BORRDY | | | 0x018E | PCON0 | 7:0 | STKOVF | STKUNF | | RWDT | RMCLR | RI | POR | BOR | | | 0x018F | PCON1 | 7:0 | 511.0 VI | 311(0)(1) | | 111101 | TUNGER | - 11 | MEMV | 2310 | | | 0x0190 | 1 33111 | 7.0 | | | | | | | 171.E1VI V | | | | | Reserved | | | | | | | | | | | | 0x019B | 500, 700 | | | | | | | | | | | | 0x019C | TMR0L | 7:0 | | | | TMRC | L[7:0] | | | | | | 0x019D | TMR0H | 7:0 | | | | | H[7:0] | | | | | | 0x019E | TOCONO | 7:0 | EN | | OUT | MD16 | [ ] | OUT | PS[3:0] | | | | OVOIRE | 1000110 | 7.0 | L14 | | | INIDIO | | 0011 | <u> </u> | | | | conti | inued | | | | | | | | | | |------------------|-------------------|------------|-------------|---------|-----------|-------|-------------------|-----------|-----------------|-----| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x019F | T0CON1 | 7:0 | | CS[2:0] | | ASYNC | | CKP | S[3:0] | | | 0x01A0 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x020D | | | | | | | | | | | | 0x020E | OSCCON2 | 7:0 | | | COSC[2:0] | | | | | | | 0x020F | OSCCON3 | 7:0 | | SOSCPWR | | | | | | | | 0x0210 | OSCSTAT | 7:0 | | HFOR | MFOR | LFOR | SOR | ADOR | SFOR | | | 0x0211 | OSCEN | 7:0 | | HFOEN | MFOEN | LFOEN | SOSCEN | ADOEN | | | | 0x0212 | OSCTUNE | 7:0 | | | | | TUN | [5:0] | | | | 0x0213 | OSCFRQ | 7:0 | | | | | | | FRQ[2:0] | | | 0x0214 | ACTCON | 7:0 | ACTEN | ACTUD | | | ACTLOCK | | ACTORS | | | 0x0215 | Danamand | | | | | | | | | | | <br>0x028B | Reserved | | | | | | | | | | | 0X020B | | 7:0 | | | | TMD | 1[7:0] | | | | | 0x028C | TMR1 | 15:8 | | | | | 1[7:0]<br>1[15:8] | | | | | 0x028E | T1CON | 7:0 | | | CKPS | | . [ . 0.0] | SYNC | RD16 | ON | | 0x028F | T1GCON | 7:0 | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | 1.510 | 514 | | 0x0290 | T1GATE | 7:0 | J | 5. 52 | 57101 | | 300.00112 | GSS[4:0] | | | | 0x0291 | T1CLK | 7:0 | | | | | | CS[4:0] | | | | | | 7:0 | | | | TMR | 3[7:0] | | | | | 0x0292 | TMR3 | 15:8 | | | | | B[15:8] | | | | | 0x0294 | T3CON | 7:0 | | | CKPS | | | SYNC | RD16 | ON | | 0x0295 | T3GCON | 7:0 | GE | GPOL | GTM | GSPM | GGO/DONE | GVAL | | | | 0x0296 | T3GATE | 7:0 | | | | | | GSS[4:0] | | | | 0x0297 | T3CLK | 7:0 | | | | | | CS[4:0] | | | | 0x0298 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x030B | | | | | | | | | | | | 0x030C | T2TMR | 7:0 | | | | | IR[7:0] | | | | | 0x030D | T2PR | 7:0 | | | | T2PI | R[7:0] | | | | | 0x030E | T2CON | 7:0 | ON | | CKPS[2:0] | | | | PS[3:0] | | | 0x030F | T2HLT | 7:0 | PSYNC | CPOL | CSYNC | | | MODE[4:0] | - | | | 0x0310 | T2CLKCON | 7:0 | | | | | | | [3:0] | | | 0x0311 | T2RST | 7:0 | | | | | | RSE | L[3:0] | | | 0x0312 | T4TMR | 7:0 | | | | | IR[7:0] | | | | | 0x0313<br>0x0314 | T4PR<br>T4CON | 7:0 | ON | I | CKDCI2-01 | 1491 | R[7:0] | OUTE | 10.01 | | | 0x0314<br>0x0315 | T4CON T4HLT | 7:0<br>7:0 | ON<br>PSYNC | CPOL | CKPS[2:0] | | | MODE[4:0] | PS[3:0] | | | | | | POTING | CFOL | CSTNC | | | | .3·U] | | | 0x0316<br>0x0317 | T4CLKCON<br>T4RST | 7:0<br>7:0 | | | | | | | [3:0]<br>L[3:0] | | | 0x0317<br>0x0318 | T6TMR | 7:0 | | | | TATM | <br> R[7:0] | INGE | _[0.0] | | | 0x0310 | T6PR | 7:0 | | | | | R[7:0] | | | | | 0x0313 | T6CON | 7:0 | ON | | CKPS[2:0] | 1011 | | OUTE | PS[3:0] | | | 0x031A | T6HLT | 7:0 | PSYNC | CPOL | CSYNC | | | MODE[4:0] | <u> </u> | | | 0x031C | T6CLKCON | 7:0 | | 5. 52 | 200 | | | | [3:0] | | | 0x031D | T6RST | 7:0 | | | | | | | L[3:0] | | | 0x031E | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x038B | | | | | | | | | | | | | CCDD4 | 7:0 | | | | CCP | R[7:0] | | | | | 0x038C | CCPR1 | 15:8 | | | | | R[15:8] | | | | | 0x038E | CCP1CON | 7:0 | EN | | OUT | FMT | | MOD | E[3:0] | | | 0x038F | CCP1CAP | 7:0 | | | | | | | [3:0] | | | 0x0390 | CCPR2 | 7:0 | | | | ССР | R[7:0] | | | | | UXU39U | COPKZ | 15:8 | | | | CCPF | R[15:8] | | | | | | | | | | | | | | | | | 0x0392 | CCP2CON | 7:0 | EN | | OUT | FMT | | MOD | E[3:0] | | | conti | nued | | | | | | | | | | |------------------|-----------------------|-------------|-----------|----------|-------|------------|---------------|----------|----------------------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0394 | | | | | | | | | | | | <br>0x039E | Reserved | | | | | | | | | | | 0x039F | CCPTMRS0 | 7:0 | | | | | C2TSE | =I [1·0] | C1TSI | =I [1·0] | | 0x03A0 | 001 11111100 | 7.0 | | | | | 02101 | [,,0] | 0110. | [,,,,] | | <br>0x040B | Reserved | | | | | | | | | | | | | 7:0 | DCL | [1:0] | | | | | | | | 0x040C | PWM3DC | 15:8 | | | | | I[7:0] | | | | | 0x040E | PWM3CON | 7:0 | EN | | OUT | POL | | | | | | 0x040F | PWM4DC | 7:0<br>15:8 | DCL | [1:0] | | DCH | l[7:0] | | | | | 0x0411 | PWM4CON | 7:0 | EN | | OUT | POL | | | | | | 0x0412 | PWM5DC | 7:0 | DCL | [1:0] | | | | | | | | 030412 | FVIVISDC | 15:8 | | | | DCF | H[7:0] | | | | | 0x0414 | PWM5CON | 7:0 | EN | | OUT | POL | | | | | | 0x0415<br> | Reserved | | | | | | | | | | | 0x041E | | | | | | | | | | | | 0x041F | PWMTMRS0 | 7:0 | | | P5TS | EL[1:0] | P4TSE | EL[1:0] | P3TSE | EL[1:0] | | 0x0420 | | | | | | | | | | | | <br>0x048B | Reserved | | | | | | | | | | | | | 7:0 | | | | ACC | [7:0] | | | | | 0x048C | NCO1ACC | 15:8 | | | | ACC | [15:8] | | | | | | | 23:16 | | | | | | ACC[ | 19:16] | | | | | 7:0 | | | | INC | [7:0] | | | | | 0x048F | NCO1INC | 15:8 | | | | INC[ | [15:8] | | | | | | | 23:16 | | | | | | INC[1 | 19:16] | | | 0x0492 | NCO1CON | 7:0 | EN | | OUT | POL | | | | PFM | | 0x0493 | NCO1CLK | 7:0 | | PWS[2:0] | 1 | | | CKS | S[3:0] | | | 0x0494<br> | Reserved | | | | | | | | | | | 0x050B | | | | | | | | | | | | 0x050C | CWG1CLK | 7:0 | | | | | | | | CS | | 0x050D | CWG1ISM | 7:0 | | | | | | | [3:0] | | | 0x050E | CWG1DBR | 7:0 | | | | | DBR | | | | | 0x050F | CWG1DBF | 7:0 | - FN | 1.0 | | | DBF | [5:0] | MODEIO | | | 0x0510<br>0x0511 | CWG1CON0<br>CWG1CON1 | 7:0<br>7:0 | EN | LD | IN | | POLD | POLC | MODE[2:0]<br>POLB | POLA | | 0x0511 | CWG1AS0 | 7:0 | SHUTDOWN | REN | | <br>D[1:0] | LSAC | | I OLD | I OLA | | 0x0512 | CWG1AS1 | 7:0 | AS7E | AS6E | AS5E | AS4E | AS3E | AS2E | AS1E | AS0E | | 0x0514 | CWG1STR | 7:0 | OVRD | OVRC | OVRB | OVRA | STRD | STRC | STRB | STRA | | 0x0515 | | 111 | 2.1.1.2 | | | | 2.1.1.2 | | | | | <br>0v0E0D | Reserved | | | | | | | | | | | 0x058B | 01.00011 | 7.0 | EN. | | OUT | INITO | INITAL | | MODER | | | 0x058C<br>0x058D | CLCnCON | 7:0 | EN<br>POL | | OUT | INTP | INTN<br>G4POL | Caboi | MODE[2:0] | CAROL | | 0x058D<br>0x058E | CLCnSEL0 | 7:0<br>7:0 | PUL | | | | G4POL<br>D1S | G3POL | G2POL | G1POL | | 0x058E | CLCnSEL1 | 7:0 | | | | | D1S | | | | | 0x0590 | CLCnSEL2 | 7:0 | | | | | D23 | | | | | 0x0590 | CLCnSEL3 | 7:0 | | | | | D3S | | | | | 0x0591 | CLCnGLS0 | 7:0 | G1D4T | G1D4N | G1D3T | G1D3N | G1D2T | G1D2N | G1D1T | G1D1N | | 0x0593 | CLCnGLS1 | 7:0 | G2D4T | G2D4N | G2D3T | G2D3N | G2D2T | G2D2N | G2D1T | G2D1N | | 0x0594 | CLCnGLS2 | 7:0 | G3D4T | G3D4N | G3D3T | G3D3N | G3D2T | G3D2N | G3D1T | G3D1N | | | | - | G4D4T | G4D4N | G4D3T | G4D3N | G4D2T | G4D2N | G4D1T | G4D1N | | | CLCnGLS3 | 7:0 | G4D41 | CTDTI | | | | | | | | 0x0595<br>0x0596 | CLCnGLS3<br>CLCSELECT | 7:0 | G4D41 | OTDTI | 0.001 | - 1 - 1 1 | ¥ = . | | | | | 0x0595 | | | G4D41 | OFBFIN | 0.20. | | CLC4OUT | CLC3OUT | SLCT[2:0]<br>CLC2OUT | CLC1OUT | | conti | inuad | | | | | | | | | | |------------------|--------------------|------------|----------|---------|-------|--------------|----------|---------|----------|----------| | | | | | | | | | | | | | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x0598 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x060B | DOADEO | 7.0 | | | | DODE | 0.7.01 | | | | | 0x060C | RC1REG | 7:0<br>7:0 | | | | RCRE | | | | | | 0x060D | TX1REG | 7:0 | | | | TXRE | | | | | | 0x060E | SP1BRG | 15:8 | | | | SPBR<br>SPBR | | | | | | 0x0610 | RC1STA | 7:0 | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | 0x0611 | TX1STA | 7:0 | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | | 0x0612 | BAUD1CON | 7:0 | ABDOVF | RCIDL | TALI | SCKP | BRG16 | BIXOIT | WUE | ABDEN | | 0x0613 | 2710210011 | 7.0 | 7,850 11 | TOBE | | 00111 | Britaria | | 1102 | , abben | | | Reserved | | | | | | | | | | | 0x0615 | | | | | | | | | | | | 0x0616 | RC2REG | 7:0 | | | | RCRE | G[7:0] | | ļ. | | | 0x0617 | TX2REG | 7:0 | | | | TXRE | G[7:0] | | | | | 0x0618 | SP2BRG | 7:0 | | | | SPBR | | | | | | UXU010 | 3FZBRG | 15:8 | | | | SPBR | G[15:8] | | | | | 0x061A | RC2STA | 7:0 | SPEN | RX9 | SREN | CREN | ADDEN | FERR | OERR | RX9D | | 0x061B | TX2STA | 7:0 | CSRC | TX9 | TXEN | SYNC | SENDB | BRGH | TRMT | TX9D | | 0x061C | BAUD2CON | 7:0 | ABDOVF | RCIDL | | SCKP | BRG16 | | WUE | ABDEN | | 0x061D | | | | | | | | | | | | <u>.</u> | Reserved | | | | | | | | | | | 0x068B | 00040115 | 7.0 | | | | DUE | 17.01 | | | | | 0x068C | SSP1BUF | 7:0 | | | | | [7:0] | | | | | 0x068D | SSP1ADD | 7:0 | | | | ADD | 0[7:0] | | | 1401/0 | | 0x068E | SSP1MSK | 7:0 | CMD | OKE | D/Ā | MSK[6:0] | | R/W | 110 | MSK0 | | 0x068F | SSP1STAT | 7:0 | SMP | CKE | | | S | | UA | BF | | 0x0690 | SSP1CON1 | 7:0 | WCOL | SSPOV | SSPEN | CKP | DOEN | | M[3:0] | CEN | | 0x0691 | SSP1CON2 | 7:0 | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x0692<br>0x0693 | SSP1CON3 | 7:0 | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | | Reserved | | | | | | | | | | | 0x0695 | reserved | | | | | | | | | | | 0x0696 | SSP2BUF | 7:0 | | | | BUF | :[7·0] | | | | | 0x0697 | SSP2ADD | 7:0 | | | | ADD | | | | | | 0x0698 | SSP2MSK | 7:0 | | | | MSK[6:0] | | | | MSK0 | | 0x0699 | SSP2STAT | 7:0 | SMP | CKE | D/Ā | P | s | R/W | UA | BF | | 0x069A | SSP2CON1 | 7:0 | WCOL | SSPOV | SSPEN | CKP | | SSPI | M[3:0] | | | 0x069B | SSP2CON2 | 7:0 | GCEN | ACKSTAT | ACKDT | ACKEN | RCEN | PEN | RSEN | SEN | | 0x069C | SSP2CON3 | 7:0 | ACKTIM | PCIE | SCIE | BOEN | SDAHT | SBCDE | AHEN | DHEN | | 0x069D | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x100B | | | | | | | | | | | | 0x100C | FVRCON | 7:0 | EN | RDY | TSEN | TSRNG | CDAF | VR[1:0] | | 'R[1:0] | | 0x100D | CPCON | 7:0 | СРО | N[1:0] | CPOS | | | CPREQ | CPT | CPRDY | | 0x100E | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x101E | 7000011 | 7.0 | 051 | | OUT | DOL | | | INITE | IA ITA I | | 0x101F | ZCDCON | 7:0 | SEN | | OUT | POL | | | INTP | INTN | | 0x1020 | Doggrand | | | | | | | | | | | <br>0x108B | Reserved | | | | | | | | | | | | CM1CON0 | 7:0 | ENI | OUT | | POL | | | HYS | SYNC | | 0x108C<br>0x108D | CM1CON0<br>CM1CON1 | 7:0<br>7:0 | EN | 001 | | FUL | | | INTP | INTN | | 0x108D<br>0x108E | CM1NCH | 7:0 | | | | | | | NCH[2:0] | INTIN | | 0x108E<br>0x108F | CM1PCH | 7:0 | | | | | | | PCH[2:0] | | | 0x108F<br>0x1090 | CWITCH | 7.0 | | | | | | | гоп[2:0] | | | | Reserved | | | | | | | | | | | <br>0x109E | r Coci veu | | | | | | | | | | | CATOOL | | | | | | | | | | | | contii | nued | | | | | | | | | | |--------|-----------------------------------------|-------------|------|----------|-----------|-------|-------------------|-----------|-----------|----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x109F | CMOUT | 7:0 | | <u> </u> | | | | | <u> </u> | C1OUT | | 0x1091 | CIVIOUT | 7.0 | | | | | | | | 01001 | | | Reserved | | | | | | | | | | | 0x110B | 110001100 | | | | | | | | | | | 0x110C | DAC1CON | 7:0 | EN | REFRNG | OE | [1:0] | PSS | [1:0] | | NSS | | 0x110D | DAC1DATL | 7:0 | | | | | IR[7:0] | | | | | 0x110E | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1C8B | | | | | | | | | | | | 04000 | NI MAADD | 7:0 | | | | NVMA | DR[7:0] | | | ! | | 0x1C8C | NVMADR | 15:8 | | | | | NVMADR[14:8 | ] | | | | 0v1C9E | NVMDAT | 7:0 | | - | | NVMD | AT[7:0] | | | | | 0x1C8E | NVMDAT | 15:8 | | | | | NVMD | AT[13:8] | | | | 0x1C90 | NVMCON1 | 7:0 | | NVMREGS | LWLO | FREE | WRERR | WREN | WR | RD | | 0x1C91 | NVMCON2 | 7:0 | | | | NVMC | ON2[7:0] | | | | | 0x1C92 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1D0B | | | | | | | | | | | | 0x1D0C | ADLTH | 7:0 | | | | | I[7:0] | | | | | 5X1200 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 15:8 | | | | | [15:8] | | | | | 0x1D0E | ADUTH | 7:0 | | | | | 1[7:0] | | | | | | | 15:8 | | | | | [15:8] | | | | | 0x1D10 | ADERR | 7:0 | | | | | R[7:0] | | | | | | | 15:8 | | | | | [15:8] | | | | | 0x1D12 | ADSTPT | 7:0 | | | | | T[7:0] | | | | | | | 15:8 | | | | | Γ[15:8] | | | | | 0x1D14 | ADFLTR | 7:0 | | | | | R[7:0] | | | | | | | 15:8 | | | | | R[15:8] | | | | | | | 7:0 | | | | | C[7:0] | | | | | 0x1D16 | ADACC | 15:8 | | | | ACC | [15:8] | | | | | 0.4040 | ADONT | 23:16 | | | | 011 | F17.01 | | ACC | 17:16] | | 0x1D19 | ADDRT | 7:0 | | | | | Γ[7:0] | | | | | 0x1D1A | ADRPT | 7:0 | | | | | Γ[7:0]<br>\(17:0) | | | | | 0x1D1B | ADPREV | 7:0<br>15:8 | | | | | V[7:0] | | | | | | | 7:0 | | | | | /[15:8]<br>S[7:0] | | | | | 0x1D1D | ADRES | 15:8 | | | | | [15:8] | | | | | 0x1D1F | ADPCH | 7:0 | | | | INLO | | H[5:0] | | | | 0x1D11 | Reserved | 7.0 | | | | | FOI | 1[3.0] | | | | | | 7:0 | | | | ACC | Q[7:0] | | | <u> </u> | | 0x1D21 | ADACQ | 15:8 | | | | /.00 | ~[∨] | ACQ[12:8] | | | | 0x1D23 | ADCAP | 7:0 | | | | | | CAP[4:0] | | | | | | 7:0 | | | | PRE | E[7:0] | S [1.0] | | | | 0x1D24 | ADPRE | 15:8 | | | | | | PRE[12:8] | | | | 0x1D26 | ADCON0 | 7:0 | ON | CONT | | CS | | FM | | GO | | 0x1D27 | ADCON1 | 7:0 | PPOL | IPEN | GPOL | | | | PCSC | DSEN | | 0x1D28 | ADCON2 | 7:0 | PSIS | 1 = 1 | CRS[2:0] | | ACLR | | MD[2:0] | | | 0x1D29 | ADCON3 | 7:0 | | | CALC[2:0] | | SOI | | TMD[2:0] | | | 0x1D2A | ADSTAT | 7:0 | AOV | UTHR | LTHR | MATH | | | STAT[2:0] | | | 0x1D2B | ADREF | 7:0 | | | | | | | | F[1:0] | | 0x1D2C | ADACT | 7:0 | | | | | ACT | [5:0] | | | | 0x1D2D | ADCLK | 7:0 | | | | | | [5:0] | | | | 0x1D2E | ADCG1A | 7:0 | | | CGA5 | CGA4 | | CGA2 | CGA1 | CGA0 | | 0x1D2F | ADCG1B | 7:0 | CGB7 | CGB6 | CGB5 | CGB4 | | | | | | 0x1D30 | ADCG1C | 7:0 | CGC7 | CGC6 | CGC5 | CGC4 | CGC3 | CGC2 | CGC1 | CGC0 | | 0x1D31 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1D8B | | | | | | | | | | | | 0x1D8C | RA0PPS | 7:0 | | | | | RA0P | PS[5:0] | | | | contin | ued | | | | | | | | | | |------------------|------------|----------|---|---|---|-------------|-------|---------|------------|-----------| | Offect | | | | | | | | | | | | Oliser | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x1D8D | RA1PPS | 7:0 | | | | | RA1PI | PS[5:0] | | | | 0x1D8E | RA2PPS | 7:0 | | | | | RA2PI | PS[5:0] | | | | 0x1D8F | Reserved | | | | | | | | | | | 0x1D90 | RA4PPS | 7:0 | | | | | RA4PI | PS[5:0] | | | | 0x1D91 | RA5PPS | 7:0 | | | | | RA5PI | PS[5:0] | | | | 0x1D92 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1D97 | | | | | | | | | | | | 0x1D98 | RB4PPS | 7:0 | | | | | RB4PI | PS[5:0] | | | | 0x1D99 | RB5PPS | 7:0 | | | | | | PS[5:0] | | | | 0x1D9A | RB6PPS | 7:0 | | | | | RB6PI | PS[5:0] | | | | 0x1D9B | RB7PPS | 7:0 | | | | | RB7PI | PS[5:0] | | | | 0x1D9C | RC0PPS | 7:0 | | | | | RC0P | PS[5:0] | | | | 0x1D9D | RC1PPS | 7:0 | | | | | | PS[5:0] | | | | 0x1D9E | RC2PPS | 7:0 | | | | | RC2P | PS[5:0] | | | | 0x1D9F | RC3PPS | 7:0 | | | | | RC3P | PS[5:0] | | | | 0x1DA0 | RC4PPS | 7:0 | | | | | | PS[5:0] | | | | 0x1DA1 | RC5PPS | 7:0 | | | | | | PS[5:0] | | | | 0x1DA2 | RC6PPS | 7:0 | | | | | | PS[5:0] | | | | 0x1DA3 | RC7PPS | 7:0 | | | | | RC7P | PS[5:0] | | | | 0x1DA4 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E0B | | | | | | | | | | | | 0x1E0C | PPSLOCK | 7:0 | | | | | | | | PPSLOCKED | | 0x1E0D | INTPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E0E | T0CKIPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E0F | T1CKIPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E10 | T1GPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E11 | T3CKIPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E12 | T3GPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E13 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E18 | | | | | | | | | | | | 0x1E19 | T2INPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E1A | T4INPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E1B | T6INPPS | 7:0 | | | | PORT[2:0] | ı | | PIN[2:0] | | | 0x1E1C | December | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E1D | 0004000 | 7.0 | | | | DODTIO 01 | | | DINIO | | | 0x1E1E | CCP1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E1F | CCP2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E20 | Reserved | | | | | | | | | | | <br>0x1E38 | Reserveu | | | | | | | | | | | 0x1E36 | CWG1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E39 | CVVGTFF3 | 7.0 | | | | PORT[2.0] | | | FIN[Z.U] | | | | Reserved | | | | | | | | | | | <br>0x1E3C | r coci veu | | | | | | | | | | | 0x1E3D | CLCIN0PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E3E | CLCIN1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E3E | CLCIN2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E31 | CLCIN3PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E40 | RX1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E41 | CK1PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E42<br>0x1E43 | RX2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E43 | CK2PPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E44 | UNZFFO | 7.0 | | | | 1 (111[2.0] | | | 1 114[2.0] | | | | Reserved | | | | | | | | | | | <br>0x1E46 | 1 COOL VEG | | | | | | | | | | | | | | | | | | | | | | | conti | inued | | | | | | | | | | |------------|------------|----------|-----------|----------|-----------|-----------|-----------|---------|----------|---------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | ļ | , | | | | | 2 | | | | 0x1E47 | SSP1CLKPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E48 | SSP1DATPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E49 | SSP1SSPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4A | SSP2CLKPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4B | SSP2DATPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4C | SSP2SSPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E4D | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E4F | ADAOTEDO | 7.0 | | | | DODTIO O | | | DINIO 01 | | | 0x1E50 | ADACTPPS | 7:0 | | | | PORT[2:0] | | | PIN[2:0] | | | 0x1E51 | Decembed | | | | | | | | | | | <br>0v4F0D | Reserved | | | | | | | | | | | 0x1E8B | ANCELA | 7:0 | | | ANCELAE | ANCELAA | ANCELAS | ANCELAS | ANCELAA | ANCELAG | | 0x1E8C | ANSELA | 7:0 | | | ANSELA5 | ANSELA4 | ANSELA3 | ANSELA2 | ANSELA1 | ANSELA0 | | 0x1E8D | WPUA | 7:0 | | | WPUA5 | WPUA4 | WPUA3 | WPUA2 | WPUA1 | WPUA0 | | 0x1E8E | ODCONA | 7:0 | | | ODCA5 | ODCA4 | | ODCA2 | ODCA1 | ODCA0 | | 0x1E8F | SLRCONA | 7:0 | | | SLRA5 | SLRA4 | INITYTEAC | SLRA2 | SLRA1 | SLRA0 | | 0x1E90 | INLVLA | 7:0 | | | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2 | INLVLA1 | INLVLA0 | | 0x1E91 | IOCAP | 7:0 | | | IOCAP5 | IOCAP4 | IOCAP3 | IOCAP2 | IOCAP1 | IOCAP0 | | 0x1E92 | IOCAN | 7:0 | | | IOCAN5 | IOCAN4 | IOCAN3 | IOCAN2 | IOCAN1 | IOCAN0 | | 0x1E93 | IOCAF | 7:0 | | | IOCAF5 | IOCAF4 | IOCAF3 | IOCAF2 | IOCAF1 | IOCAF0 | | 0x1E94 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E95 | 441051.5 | | ANIOE! DE | 11105150 | 411051.05 | 41105157 | | | | | | 0x1E96 | ANSELB | 7:0 | ANSELB7 | ANSELB6 | ANSELB5 | ANSELB4 | | | | | | 0x1E97 | WPUB | 7:0 | WPUB7 | WPUB6 | WPUB5 | WPUB4 | | | | | | 0x1E98 | ODCONB | 7:0 | ODCB7 | ODCB6 | ODCB5 | ODCB4 | | | | | | 0x1E99 | SLRCONB | 7:0 | SLRB7 | SLRB6 | SLRB5 | SLRB4 | | | | | | 0x1E9A | INLVLB | 7:0 | INLVLB7 | INLVLB6 | INLVLB5 | INLVLB4 | | | | | | 0x1E9B | IOCBP | 7:0 | IOCBP7 | IOCBP6 | IOCBP5 | IOCBP4 | | | | | | 0x1E9C | IOCBN | 7:0 | IOCBN7 | IOCBN6 | IOCBN5 | IOCBN4 | | | | | | 0x1E9D | IOCBF | 7:0 | IOCBF7 | IOCBF6 | IOCBF5 | IOCBF4 | | | | | | 0x1E9E | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1E9F | | | | | | | | | | | | 0x1EA0 | ANSELC | 7:0 | ANSELC7 | ANSELC6 | ANSELC5 | ANSELC4 | ANSELC3 | ANSELC2 | ANSELC1 | ANSELC0 | | 0x1EA1 | WPUC | 7:0 | WPUC7 | WPUC6 | WPUC5 | WPUC4 | WPUC3 | WPUC2 | WPUC1 | WPUC0 | | 0x1EA2 | ODCONC | 7:0 | ODCC7 | ODCC6 | ODCC5 | ODCC4 | ODCC3 | ODCC2 | ODCC1 | ODCC0 | | 0x1EA3 | SLRCONC | 7:0 | SLRC7 | SLRC6 | SLRC5 | SLRC4 | SLRC3 | SLRC2 | SLRC1 | SLRC0 | | 0x1EA4 | INLVLC | 7:0 | INLVLC7 | INLVLC6 | INLVLC5 | INLVLC4 | INLVLC3 | INLVLC2 | INLVLC1 | INLVLC0 | | 0x1EA5 | IOCCP | 7:0 | IOCCP7 | IOCCP6 | IOCCP5 | IOCCP4 | IOCCP3 | IOCCP2 | IOCCP1 | IOCCP0 | | 0x1EA6 | IOCCN | 7:0 | IOCCN7 | IOCCN6 | IOCCN5 | IOCCN4 | IOCCN3 | IOCCN2 | IOCCN1 | IOCCN0 | | 0x1EA7 | IOCCF | 7:0 | IOCCF7 | IOCCF6 | IOCCF5 | IOCCF4 | IOCCF3 | IOCCF2 | IOCCF1 | IOCCF0 | | 0x1EA8 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1EE0 | | | | | | | | | | | | 0x1EE1 | RA1I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE2 | RA2I2C | 7:0 | | SLEW | PU[ | 1:0] | | | THI | 1:0] | | 0x1EE3 | | | | | | | | | | | | | Reserved | | | | | | | | | | | 0x1EE4 | | | | | | | | | | | | 0x1EE5 | RB4I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE6 | RB5I2C | 7:0 | | SLEW | PU[ | | | | | 1:0] | | 0x1EE7 | RB6I2C | 7:0 | | SLEW | PU[ | 1:0] | | | | 1:0] | | 0x1EE7 | RB7I2C | 7:0 | | SLEW | PU[ | 1:0] | | | THI | 1:0] | | 0x1EE8 | Reserved | | | | | | | | | | | 0x1EE9 | RC0I2C | 7:0 | | SLEW | PU[ | 1:0] | | | THI | 1:0] | | 0x1EEA | RC1I2C | 7:0 | | SLEW | PU[ | 1:0] | | | THI | 1:0] | | 0x1EEB | Reserved | | | | | | | | | | | J.A | | | | | | | | | | | # PIC16F18015/25/44/45 # **Register Summary** | conti | nued | | | | | | | | | | |----------------------|------------|----------|--------|---------|-------------|----------|---------|---------|-------------|-----------| | Offset | Name | Bit Pos. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0x1EEC | RC4I2C | 7:0 | | SLEW | PU | 1:0] | | | TH | [1:0] | | 0x1EED | RC5I2C | 7:0 | | SLEW | PU | PU[1:0] | | | TH | [1:0] | | 0x1EEE<br><br>0x8004 | Reserved | | | | | | | | | | | 0,,000 | REVISIONID | 7:0 | MJRRI | EV[1:0] | | | MNRR | EV[5:0] | | | | 0x8005 | KENISIONID | 15:8 | | | Reserved | Reserved | | MJRR | EV[5:2] | | | 0x8006 | DEVICEID | 7:0 | | | | DEV | /[7:0] | | | | | 000000 | DEVICEID | 15:8 | | | Reserved | Reserved | | DEV | [11:8] | | | 0x8007 | CONFIG1 | 7:0 | | | RSTOSC[2:0] | | | | FEXTO | OSC[1:0] | | 0.0007 | CONFIG | 15:8 | | | | VDDAR | | | | CLKOUTEN | | 0x8008 | CONFIG2 | 7:0 | BORE | N[1:0] | | WDT | E[1:0] | PWR | ΓS[1:0] | MCLRE | | 000000 | CONFIG2 | 15:8 | | | DEBUG | STVREN | PPS1WAY | ZCD | BORV | DACAUTOEN | | 0x8009 | CONFIG3 | 7:0 | | | | | | | | | | 0x6009 | CONFIGS | 15:8 | | | | | | | | | | 0x800A | CONFIG4 | 7:0 | WRTAPP | | | SAFEN | BBEN | | BBSIZE[2:0] | | | OXOUUA | CONFIG4 | 15:8 | | | LVP | | WRTSAF | WRTD | WRTC | WRTB | | 0x800B | CONFIG5 | 7:0 | | | | | | | CPD | CP | | OXOUUD | CONFIGS | 15:8 | | | | | | | | | ## 41. Electrical Specifications ## 41.1 Absolute Maximum Ratings(†) | Parameter | | Rating | |---------------------------------------------------------------------------------------------|--------------------------------------------------------------|------------------------------| | Ambient temperature under bias | | -40°C to +125°C | | Storage temperature | | -65°C to +150°C | | Volta | ge on pins with respect to V <sub>SS</sub> | | | • on V <sub>DD</sub> pin: | | -0.3V to +6.5V | | • on MCLR pin: | | -0.3V to +9.0V | | • on all other pins: | | $-0.3V$ to $(V_{DD} + 0.3V)$ | | | Maximum current <sup>(1)</sup> | | | • on V <sub>SS</sub> pin | -40°C ≤ T <sub>A</sub> ≤ $+85$ °C | 300 mA | | | $85^{\circ}\text{C} < \text{T}_{A} \le +125^{\circ}\text{C}$ | 120 mA | | • on V <sub>DD</sub> pin | $-40$ °C $\leq$ T <sub>A</sub> $\leq$ $+85$ °C | 250 mA | | | $85^{\circ}\text{C} < \text{T}_{A} \le +125^{\circ}\text{C}$ | 85 mA | | on any standard I/O pin | | ±25 mA | | Clamp current, I <sub>K</sub> (V <sub>PIN</sub> < 0 or V <sub>PIN</sub> > V <sub>DD</sub> ) | | ±20 mA | | Total power dissipation <sup>(2)</sup> | | 800 mW | #### Notes: - Maximum current rating requires even load distribution across I/O pins. Maximum current rating may be limited by the device package power dissipation characterizations, see the "Thermal Characteristics" section to calculate device specifications. - 2. Power dissipation is calculated as follows: $P_{DIS} = V_{DD} x \{I_{DD} \Sigma I_{OH}\} + \Sigma \{(V_{DD} V_{OH}) \times I_{OH}\} + \Sigma (V_{OI} \times I_{OL})$ - Internal Power Dissipation is calculated as follows: $P_{INTERNAL} = I_{DD} \times V_{DD}$ where I<sub>DD</sub> is current to run the chip alone without driving any load on the output pins. 4. I/O Power Dissipation is calculated as follows: $$P_{I/O} = \Sigma(I_{OL}*V_{OL}) + \Sigma(I_{OH}*(V_{DD}-V_{OH}))$$ 5. Derated Power is calculated as follows: $$P_{DER} = PD_{MAX}(T_J-T_A)/\theta_{JA}$$ where $T_A$ = Ambient Temperature, $T_J$ = Junction Temperature. **Notice:** Stresses above those listed under the "**Absolute Maximum Ratings**" section may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure above maximum rating conditions for extended periods may affect device reliability. ## 41.2 Standard Operating Conditions The standard operating conditions for any device are defined as: | Parameter | Condition | |------------------------|--------------------------------------| | Operating Voltage: | $V_{DDMIN} \le V_{DD} \le V_{DDMAX}$ | | Operating Temperature: | $T_{AMIN} \le T_A \le T_{AMAX}$ | | Parameter | | Ratings | |-----------------------------------------------------------|------------------------------------------------|---------------| | V <sub>DD</sub> — Operating Supply Voltage <sup>(1)</sup> | | | | | V <sub>DDMIN</sub> (F <sub>OSC</sub> ≤ 16 MHz) | +1.8V | | | V <sub>DDMIN</sub> (F <sub>OSC</sub> ≤ 32 MHz) | +2.5V | | | $V_{DDMAX}$ | +5.5V | | T <sub>A</sub> — Operating Ambient Temperature Ra | nge | | | Industrial Temperature | T <sub>A_MIN</sub> | <b>-4</b> 0°C | | industrial remperature | T <sub>A_MAX</sub> | +85°C | | Extended Temperature | T <sub>A_MIN</sub> | <b>-4</b> 0°C | | Extended remperature | T <sub>A_MAX</sub> | +125°C | | Note: | | | | 1. See Parameter <b>D002</b> , DC Characteris | tics: Supply Voltage. | | Figure 41-1. Voltage Frequency Graph, -40°C $\leq T_A \leq +125$ °C - 1. The shaded region indicates the permissible combinations of voltage and frequency. - 2. Refer to the "External Clock/Oscillator Timing Requirements" section for each Oscillator mode's supported frequencies. ## 41.3 DC Characteristics ## 41.3.1 Supply Voltage Table 41-1. | Standard Op | perating Cond | ditions (unless other | wise stated | d) | | | | |-------------------------|-------------------------|------------------------|-------------|-------|------|-------|-----------------------------| | Param. No. | Sym. | Characteristic | Min. | Typ.† | Max. | Units | Conditions | | Supply Volta | ige | | | | | | | | D002 | V | | 1.8 | _ | 5.5 | V | F <sub>OSC</sub> ≤ 16 MHz | | D002 | V <sub>DD</sub> | | 2.5 | _ | 5.5 | V | F <sub>OSC</sub> > 16 MHz | | RAM Data R | etention <sup>(1)</sup> | | | | | | | | D003 | V <sub>DR</sub> | | 1.7 | _ | _ | V | Device in Sleep mode | | Power-on Re | eset Release | Voltage <sup>(2)</sup> | | | | | | | D004 | V <sub>POR</sub> | | _ | 1.6 | _ | V | BOR disabled <sup>(3)</sup> | | Power-on Re | eset Rearm V | oltage <sup>(2)</sup> | : | | | • | | | D005 | V <sub>PORR</sub> | | _ | 1 | _ | V | BOR disabled <sup>(3)</sup> | | V <sub>DD</sub> Rise Ra | te to ensure i | internal Power-on Re | eset signal | (2) | | • | - | | D006 | S <sub>VDD</sub> | | 0.05 | _ | _ | V/ms | BOR disabled <sup>(3)</sup> | $<sup>\</sup>dagger$ Data in "Typ." column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - 1. This is the limit to which $V_{DD}$ can be lowered in Sleep mode without losing RAM data. - 2. See the POR and POR Rearm with Slow Rising $V_{DD}$ figure below. - 3. See the Reset, WDT, Power-up Timer, and Brown-Out Reset Specifications section for BOR trip point information. Figure 41-2. POR and POR Rearm with Slow Rising V<sub>DD</sub> #### Note: 1. When N<sub>POR</sub> is low, the device is held in Reset. ## 41.3.2 Supply Current $(I_{DD})^{(1,2)}$ Table 41-2. | Standard O | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | | |------------|---------------------------------------------------------|----------------------|------|-------|------|-------|-----------------|------|--|--|--|--| | Param. No. | Sym. | Device | Min. | Тур.† | Max. | Units | Conditions | | | | | | | | | Characteristics | | | | | V <sub>DD</sub> | Note | | | | | | D101 | I <sub>DDHFO16</sub> | HFINTOSC = 16<br>MHz | _ | 2.4 | 2.6 | mA | 3.0V | | | | | | | D102 | I <sub>DDHFOPLL</sub> | HFINTOSC = 32<br>MHz | _ | 4.5 | 5 | mA | 3.0V | | | | | | † Data in "Typ." column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - 1. The test conditions for all $I_{DD}$ measurements in Active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins are outputs driven low; $\overline{MCLR} = V_{DD}$ ; WDT disabled. - The supply current is mainly a function of the operating voltage and frequency. Other factors, such as I/O pin loading and switching rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption. ## 41.3.3 Power-Down Current (I<sub>PD</sub>)<sup>(1,2,3)</sup> #### Table 41-3. | Standard | Operating Cor | nditions (unless oth | erwise s | stated) | | | | | | |----------|--------------------------|---------------------------------------------|----------|---------|-------|--------|-------|-----------------|--------------------------------| | Param. | Sym. | Device | Min. | Typ.† | Max. | Max. | Units | Co | onditions | | No. | | Characteristics | | | +85°C | +125°C | | V <sub>DD</sub> | Note | | D200 | I <sub>PD</sub> | I <sub>PD</sub> Base | _ | 0.4 | 4 | 7 | μA | 3.0V | | | D201 | I <sub>PD_WDT</sub> | Low-Frequency<br>Internal<br>Oscillator/WDT | _ | 0.5 | 5 | 13 | μΑ | 3.0V | | | D202 | I <sub>PD_SOSC</sub> | Secondary<br>Oscillator (S <sub>OSC</sub> ) | _ | _ | 8.5 | 20 | μА | 3.0V | | | D204 | I <sub>PD_FVR_BUF1</sub> | FVR Buffer 1<br>(ADC) | _ | 40 | 64 | 76 | μΑ | 3.0V | | | D204A | I <sub>PD_FVR_BUF2</sub> | FVR Buffer 2<br>(DAC/CMP) | _ | 40 | 64 | 76 | μΑ | 3.0V | | | D205 | I <sub>PD_BOR</sub> | Brown-out Reset<br>(BOR) | _ | 27 | 38 | 50 | μΑ | 3.0V | | | D207 | I <sub>PD_ADCA</sub> | ADC - Active | _ | _ | 5 | 13 | μΑ | 3.0V | ADC is not converting (Note 4) | | D208 | I <sub>PD_CMP</sub> | Comparator | _ | 27 | 45 | 70 | μA | 3.0V | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ." column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### Notes: - 1. The peripheral current is the sum of the base $I_{DD}$ and the additional current consumed when this peripheral is enabled. The peripheral $\Delta$ current can be determined by subtracting the base $I_{DD}$ or $I_{PD}$ current from this limit. Max. values will be used when calculating total current consumption. - 2. The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode with all I/O pins in High-Impedance state and tied to V<sub>SS</sub>. - All peripheral currents listed are on a per-peripheral basis if more than one instance of a peripheral is available. - 4. ADC clock source is ADCRC. #### 41.3.4 I/O Ports #### Table 41-4. | Standard Op | erating Co | onditions (unless other | wise stated | d) | | | | |--------------|------------|---------------------------|-------------|-------|------|-------|------------| | Param. No. | Sym. | Device<br>Characteristics | Min. | Typ.† | Max. | Units | Conditions | | Input Low Vo | oltage | | | | | | | | cont | | | | | | | | |--------------|------------------|---------------------------------|-------------------------------|-------|----------------------|-------|--------------------------------------------------------------------------------------------| | Standard C | Operating C | onditions (unless othe | rwise stated | ) | | | | | Param. No | Sym. | Device<br>Characteristics | Min. | Typ.† | Max. | Units | Conditions | | | $V_{IL}$ | I/O PORT: | | | | | _ | | D300 | | with TTL buffer | _ | _ | 0.8 | V | $4.5V \le V_{DD} \le 5.5V$ | | D301 | | | _ | _ | 0.15 V <sub>DD</sub> | V | 1.8V ≤ V <sub>DD</sub> < 4.5V | | D302 | | with Schmitt Trigger buffer | _ | _ | 0.2 V <sub>DD</sub> | V | 2.0V ≤ V <sub>DD</sub> ≤ 5.5V | | D303 | | with I <sup>2</sup> C levels | _ | _ | 0.3 V <sub>DD</sub> | V | 2.0V ≤ V <sub>DD</sub> ≤ 5.5V | | D304 | | with SMBus 2.0 | _ | _ | 0.8 | V | $2.7V \le V_{DD} \le 5.5V$ | | D305 | | with SMBus 3.0 | _ | _ | 0.8 | V | | | D306 | | MCLR | _ | | 0.2 V <sub>DD</sub> | V | | | High Low \ | | | | | | | | | | V <sub>IH</sub> | I/O PORT: | | | | | | | D320 | | with TTL buffer | 2.0 | | _ | V | $4.5V \le V_{DD} \le 5.5V$ | | D321 | | | 0.25 V <sub>DD</sub><br>+ 0.8 | _ | _ | V | 1.8V ≤ V <sub>DD</sub> < 4.5V | | D322 | | with Schmitt Trigger buffer | 0.8 V <sub>DD</sub> | _ | _ | V | 2.0V ≤ V <sub>DD</sub> ≤ 5.5V | | D323 | | with I <sup>2</sup> C levels | 0.7 V <sub>DD</sub> | _ | _ | V | | | D324 | | with SMBus 2.0 | 2.1 | | _ | V | $2.7V \le V_{DD} \le 5.5V$ | | D325 | | • with SMBus 3.0 | 1.35 | _ | _ | V | | | D326 | | MCLR | 0.7 V <sub>DD</sub> | _ | _ | V | | | | age Curren | | | | | | | | D340 | I <sub>IL</sub> | I/O PORTS | _ | ±5 | _ | nA | V <sub>SS</sub> ≤ V <sub>PIN</sub> ≤ V <sub>DD</sub> ,<br>Pin at high-<br>impedance, 85°C | | D341 | | | _ | ±5 | _ | nA | V <sub>SS</sub> ≤ V <sub>PIN</sub> ≤ V <sub>DD</sub> ,<br>Pin at high-<br>impedance, 125°C | | D342 | | MCLR <sup>(2)</sup> | _ | ±50 | _ | nA | V <sub>SS</sub> ≤ V <sub>PIN</sub> ≤ V <sub>DD</sub> ,<br>Pin at high-<br>impedance, 85°C | | Weak Pull- | up Current | | | | | | | | D350 | I <sub>PUR</sub> | | _ | _ | _ | μΑ | $V_{DD} = 3.0V,$<br>$V_{PIN} = V_{SS}$ | | Output Lov | w Voltage | | | | | | | | D360 | V <sub>OL</sub> | I/O PORTS | _ | _ | 0.6 | V | I <sub>OL</sub> = 10.0 mA,<br>V <sub>PIN</sub> = 3.0V | | Output Hig | h Voltage | | | | | | | | D370 | V <sub>OH</sub> | I/O PORTS | V <sub>DD</sub> - 0.7 | _ | _ | V | I <sub>OH</sub> = 6.0 mA,<br>V <sub>PIN</sub> = 3.0V | | All I/O Pins | 3 | | | | | | | | D380 | C <sub>IO</sub> | | | 5 | 50 | pF | | | continued | | | | | | | | | | |---------------------------------------------------------|------|---------------------------|------|-------|------|-------|------------|--|--| | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | Param. No. | Sym. | Device<br>Characteristics | Min. | Typ.† | Max. | Units | Conditions | | | † Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### Notes: - 1. Negative current is defined as current sourced by the pin. - 2. The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. ## 41.3.5 Memory Programming Specifications #### Table 41-5. | Standard O | perating | Conditions (unless otherwise s | tated) | | | | | |---------------|--------------------|---------------------------------------------------|--------------------|--------|--------------------|-------|-----------------------------------------------| | Param. No. | Sym. | Device Characteristics | Min. | Typ. † | Max. | Units | Conditions | | Data EEPRO | OM Memo | ory Specifications | | | | | | | MEM20 | E <sub>D</sub> | DataEE Byte Endurance | 100k | _ | _ | E/W | -40°C ≤ T <sub>A</sub> ≤ +85°C | | MEM21 | T <sub>D_RET</sub> | Characteristic Retention | _ | 40 | _ | Year | Provided no other specifications are violated | | MEM23 | V <sub>D_RW</sub> | V <sub>DD</sub> for Read or Erase/Write operation | V <sub>DDMIN</sub> | _ | V <sub>DDMAX</sub> | ٧ | | | MEM24 | T <sub>D_BEW</sub> | Byte Erase and Write Cycle<br>Time | _ | _ | 11 | ms | | | Program Fla | ash Mem | ory Specifications | | | | | | | МЕМ30 | E <sub>P</sub> | Flash Memory Cell Endurance | 10k | _ | _ | E/W | -40°C ≤ T <sub>A</sub> ≤ +85°C (Note 1) | | MEM32 | T <sub>P_RET</sub> | Characteristic Retention | _ | 40 | _ | Year | Provided no other specifications are violated | | MEM33 | V <sub>P_RD</sub> | V <sub>DD</sub> for Read operation | V <sub>DDMIN</sub> | _ | V <sub>DDMAX</sub> | V | | | MEM34 | V <sub>P_REW</sub> | V <sub>DD</sub> for Row Erase or Write operation | V <sub>DDMIN</sub> | _ | $V_{\text{DDMAX}}$ | V | | | MEM35 | T <sub>P_REW</sub> | Self-Timed Page Write | _ | _ | _ | ms | | | МЕМ36 | T <sub>SE</sub> | Self-Timed Page Erase | _ | _ | _ | ms | | | MEM37 | T <sub>P_WRD</sub> | Self-Timed Word Write | _ | _ | _ | μs | | | + D-4- :- "T- | ,, | | 4-41 | | | - | | <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### Note: Flash Memory Cell Endurance for the Flash memory is defined as: One Row Erase operation and one Self-Timed Write. ## 41.3.6 Thermal Characteristics ## Table 41-6. | Standard O | perating Co | onditions (unless otherwise stated) | | | | |------------|-----------------------|-------------------------------------|------|-------|-----------------------------------------------------------------------| | Param. No. | Sym. | Characteristic | Тур. | Units | Conditions | | TH01 | $\theta_{JA}$ | Thermal Resistance Junction to | _ | °C/W | 8-pin PDIP package | | | | Ambient | _ | °C/W | 8-pin SOIC package | | | | | _ | °C/W | 8-pin DFN package | | | | | | °C/W | 14-pin PDIP package | | | | | _ | °C/W | 14-pin SOIC package | | | | | _ | °C/W | 14-pin TSSOP package | | | | | _ | °C/W | 16-pin VQFN package | | | | | _ | °C/W | 20-pin PDIP package | | | | | _ | °C/W | 20-pin SOIC package | | | | | _ | °C/W | 20-pin SSOP package | | | | | _ | °C/W | 20-pin QFN package | | TH02 | T <sub>JMAX</sub> | Maximum Junction Temperature | 150 | °C | | | TH03 | PD | Power Dissipation | _ | W | PD = P <sub>INTERNAL</sub> +P <sub>I/O</sub> | | TH04 | P <sub>INTERNAL</sub> | Internal Power Dissipation | _ | W | $P_{INTERNAL} = I_{DD} \times V_{DD}^{(1)}$ | | TH05 | P <sub>I/O</sub> | I/O Power Dissipation | | W | $P_{I/O} = \Sigma(I_{OL}^*V_{OL}) + \Sigma(I_{OH}^*(V_{DD}^-V_{OH}))$ | | TH06 | P <sub>DER</sub> | Derated Power | _ | W | $P_{DER} = PD_{MAX} (T_J - T_A) / \theta_{JA}^{(2)}$ | - 1. I<sub>DD</sub> is current to run the chip alone without driving any load on the output pins. - 2. $T_A$ = Ambient Temperature, $T_J$ = Junction Temperature. ## 41.4 AC Characteristics Figure 41-3. Load Conditions ## 41.4.1 External Clock/Oscillator Timing Requirements Figure 41-4. Clock Timing Table 41-7. | Standard Op | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | |----------------|---------------------------------------------------------|------------------|------|--------|-------|------------|------------------------|--|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Тур. † | Units | Conditions | | | | | | | ECL Oscillator | | | | | | | | | | | | | OS1 | F <sub>ECL</sub> | Clock Frequency | _ | _ | 1 | MHz | | | | | | | OS2 | T <sub>ECL_DC</sub> | Clock Duty Cycle | 40 | _ | 60 | % | | | | | | | ECH Oscilla | tor | | | | | | | | | | | | OS5 | F <sub>ECH</sub> | Clock Frequency | _ | _ | 32 | MHz | V <sub>DD</sub> ≥ 2.7V | | | | | | | | | _ | _ | 16 | MHz | V <sub>DD</sub> < 2.7V | | | | | | contin | ued | | | | | | | | | | |---------------------------------------------------------|---------------------|---------------------------|------|---------------------|------|-------|------------------|--|--|--| | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | | | | OS6 | T <sub>ECH_DC</sub> | Clock Duty Cycle | 40 | _ | 60 | % | | | | | | Secondary ( | Oscillator | | ' | - | | | | | | | | OS10 | F <sub>SEC</sub> | Clock Frequency | _ | 32.768 | _ | kHz | (Note 4) | | | | | System Osc | illator | | ' | - | | | | | | | | OS20 | Fosc | System Clock<br>Frequency | _ | _ | 32 | MHz | (Note 2, Note 3) | | | | | OS21 | F <sub>CY</sub> | Instruction<br>Frequency | _ | F <sub>OSC</sub> /4 | _ | MHz | | | | | | OS22 | T <sub>CY</sub> | Instruction Period | 125 | 1/F <sub>CY</sub> | _ | ns | | | | | #### Notes: - Instruction cycle period (T<sub>CY</sub>) equals four times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min" values with an external clock applied to OSC1 pin. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices. - 2. The system clock frequency (F<sub>OSC</sub>) is selected by the "main clock switch controls" as described in the "Power Saving Operation Modes" section. - 3. The system clock frequency (F<sub>OSC</sub>) must meet the voltage requirements defined in the "Standard Operating Conditions" section. #### 41.4.2 Internal Oscillator Parameters<sup>(1)</sup> #### Table 41-8. | Standard Op | perating Condi | tions (unless otherwis | se stated) | | | | | |-------------|----------------------|-------------------------------------------------|------------------|--------------------|-----------------------|--------------------------|----------------------------------------------------------------------| | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | OS50 | F <sub>HFOSC</sub> | Precision Calibrated<br>HFINTOSC<br>Frequency | _ | 4<br>8<br>16<br>32 | _ | MHz | (Note 2) | | OS51 | F <sub>HFOSCLP</sub> | Low-Power<br>Optimized<br>HFINTOSC<br>Frequency | _<br>_<br>_<br>_ | 1<br>2<br>1<br>2 | _<br>_<br>_<br>_<br>_ | MHz<br>MHz<br>MHz<br>MHz | -40°C to 85°C<br>-40°C to 85°C<br>-40°C to 125 °C<br>-40°C to 125 °C | | OS52 | F <sub>MFOSC</sub> | Internal Calibrated<br>MFINTOSC<br>Frequency | _ | 500 | _ | kHz | | | OS53* | F <sub>LFOSC</sub> | Internal LFINTOSC<br>Frequency | _ | 31 | _ | kHz | | | | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | |------------|---------------------------------------------------------|-------------------------------------------------|------|--------|------|-------|------------|--|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Тур. † | Max. | Units | Conditions | | | | | | OS54* | T <sub>HFOSCST</sub> | HFINTOSC Wake-up from Sleep Start-up Time | _ | _ | _ | μs | | | | | | | OS56 | T <sub>LFOSCST</sub> | LFINTOSC Wake-up<br>from Sleep Start-up<br>Time | _ | _ | _ | ms | | | | | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - 1. To ensure these oscillator frequency tolerances, $V_{DD}$ and $V_{SS}$ must be capacitively decoupled as close to the device as possible. 0.1 $\mu F$ and 0.01 $\mu F$ values in parallel are recommended. - 2. See the figure below. Figure 41-5. Precision Calibrated HFINTOSC Frequency Accuracy Over Device V<sub>DD</sub> and Temperature ## 41.4.3 I/O and CLKOUT Timing Specifications Figure 41-6. CLKOUT and I/O Timing Table 41-9. I/O and CLKOUT Timing Specifications | Param. No. | Sym. | Characteristic | Min. | Тур. † | Max. | Units | Conditions | |------------|-------------------------|------------------------------------------------------------------------------------------|------|--------|------|-------|------------------------| | IO1* | T <sub>CLKOUTH</sub> | CLKOUT rising edge delay (rising edge F <sub>OSC</sub> (Q1 cycle) to falling edge CLKOUT | _ | _ | _ | ns | | | IO2* | T <sub>CLKOUTL</sub> | CLKOUT falling edge delay (rising edge F <sub>OSC</sub> (Q3 cycle) to rising edge CLKOUT | _ | _ | _ | ns | | | IO3* | T <sub>IO_VALID</sub> | Port output valid time (rising edge F <sub>OSC</sub> (Q1 cycle) to port valid) | _ | _ | _ | ns | | | IO4* | T <sub>IO_SETUP</sub> | Port input setup time (Setup time before rising edge F <sub>OSC</sub> – Q2 cycle) | _ | _ | _ | ns | | | IO5* | T <sub>IO_HOLD</sub> | Port input hold time (Hold time after rising edge F <sub>OSC</sub> – Q2 cycle) | _ | _ | _ | ns | | | IO6* | T <sub>IOR_SLREN</sub> | Port I/O rise time, slew rate enabled | _ | _ | _ | ns | V <sub>DD</sub> = 3.0V | | IO7* | T <sub>IOR_SLRDIS</sub> | Port I/O rise time, slew rate disabled | _ | _ | _ | ns | V <sub>DD</sub> = 3.0V | | IO8* | T <sub>IOF_SLREN</sub> | Port I/O fall time, slew rate enabled | _ | _ | _ | ns | V <sub>DD</sub> = 3.0V | | IO9* | T <sub>IOF_SLRDIS</sub> | Port I/O fall time, slew rate disabled | _ | _ | _ | ns | V <sub>DD</sub> = 3.0V | | IO10* | T <sub>INT</sub> | INT pin high or low time to trigger an interrupt | _ | _ | _ | ns | | | IO11* | T <sub>IOC</sub> | Interrupt-on-Change minimum high or low time to trigger interrupt | _ | _ | _ | ns | | # 41.4.4 Timer0 and Timer1 External Clock Requirements Table 41-10. Standard Operating Conditions (unless otherwise stated) Operating Temperature: $-40^{\circ}C \le T_A \le +125^{\circ}C$ | Param. | Sym. | Cha | racteristic | Min. | Тур. † | Max. | Units | Conditions | |--------|------------------------|-------------------------------|--------------------------------|-------------------------------------------|--------|--------------------|-------|-----------------------| | No. | | | | | | | | | | 40* | T <sub>T</sub> 0H | T0CKI High | No Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | Pulse<br>Width | With Prescaler | 10 | _ | _ | ns | | | 41* | T <sub>T</sub> 0L | T0CKI Low | No Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | Pulse<br>Width | With Prescaler | 10 | _ | _ | ns | | | 42* | T <sub>T</sub> 0P | T0CKI Perio | d | Greater of: 20 or (T <sub>CY</sub> +40)/N | _ | _ | ns | N = Prescale<br>value | | 45* | T <sub>T</sub> 1H | T1CKI High<br>Time | Synchronous, No<br>Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | | Synchronous, with<br>Prescaler | 15 | _ | _ | ns | | | | | | Asynchronous | 30 | _ | _ | ns | | | 46* | T <sub>T</sub> 1L | T1CKI Low<br>Time | Synchronous, No<br>Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | | Synchronous, with<br>Prescaler | 15 | _ | _ | ns | | | | | | Asynchronous | 30 | _ | _ | ns | | | 47* | T <sub>T</sub> 1P | T1CKI<br>Input | Synchronous | Greater of: 30 or (T <sub>CY</sub> +40)/N | _ | _ | ns | N = Prescale value | | | | Period | Asynchronous | 60 | _ | _ | ns | | | 49* | TCKEZ <sub>TMR</sub> 1 | Delay from E<br>to Timer Incr | External Clock Edge<br>ement | 2 T <sub>OSC</sub> | _ | 7 T <sub>OSC</sub> | _ | Timers in Sync | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Figure 41-7. Timer0 and Timing1 External Clock Timings ## 41.4.5 Reset, WDT, Power-up Timer, and Brown-Out Reset Specifications Figure 41-8. Reset, Watchdog Timer, and Power-up Timer Timing #### Note: 1. Asserted low. Figure 41-9. Brown-out Reset Timing and Characteristics #### Note: 1. Delay period is determined by the PWRTS bits in the Configuration Word register. Table 41-11 | Standard Op | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | |-------------|---------------------------------------------------------|------------------------------------------------------|------|--------|------|-------|-----------------------|--|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Тур. † | Max. | Units | Conditions | | | | | | RST01* | T <sub>MCLR</sub> | MCLR Pulse Width Low to ensure Reset | _ | _ | _ | μs | | | | | | | RST02* | T <sub>IOZ</sub> | I/O high-impedance from Reset detection | _ | _ | _ | μs | | | | | | | RST03 | T <sub>WDT</sub> | Watchdog Timer Time-<br>out Period | _ | _ | _ | ms | <b>WDTCPS =</b> 00100 | | | | | | RST04* | T <sub>PWRT</sub> | Power-up Timer<br>Period | _ | _ | 64 | ms | | | | | | | RST05 | T <sub>OST</sub> | Oscillator Start-up<br>Timer Period <sup>(1,2)</sup> | _ | 1024 | _ | Tosc | | | | | | | RST06 | $V_{BOR}$ | Brown-out Reset | _ | 2.65 | _ | V | BORV = 0 | | | | | | | | Voltage | _ | 1.9 | _ | V | BORV = 1 | | | | | | RST07 | V <sub>BORHYS</sub> | Brown-out Reset<br>Hysteresis | _ | _ | _ | mV | BORV = 00 | | | | | | RST08 | T <sub>BORDC</sub> | Brown-out Reset<br>Response Time | _ | _ | _ | μs | | | | | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. - 1. By design, the Oscillator Start-up Timer (OST) counts the first 1024 cycles, independent of frequency. - 2. To ensure these voltage tolerances, $V_{DD}$ and $V_{SS}$ must be capacitively decoupled as close to the device as possible. 0.1 $\mu F$ and 0.01 $\mu F$ values in parallel are recommended. # 41.4.6 Analog-to-Digital Converter (ADC) Accuracy Specifications<sup>(1,2)</sup> Table 41-12. | Standard Op | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | |-------------------|---------------------------------------------------------|-------------------------------------------------------------------|---------------------|--------|---------------------|-------|---------------------------------------------|--|--|--| | $V_{DD} = 3.0 V,$ | Γ <sub>A</sub> = 25°C | c, T <sub>AD</sub> = 500 ns | | | | | | | | | | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | | | | AD01 | N <sub>R</sub> | Resolution | _ | _ | 10 | bit | | | | | | AD02 | E <sub>IL</sub> | Integral Nonlinearity Error | _ | _ | ±2 | LSb | $ADC_{REF}$ + = 3.0V,<br>$ADC_{REF}$ - = 0V | | | | | AD03 | E <sub>DL</sub> | Differential Nonlinearity Error | _ | _ | ±1 | LSb | $ADC_{REF}$ + = 3.0V,<br>$ADC_{REF}$ - = 0V | | | | | AD04 | E <sub>OFF</sub> | Offset Error | _ | _ | ±2 | LSb | $ADC_{REF}$ + = 3.0V,<br>$ADC_{REF}$ - = 0V | | | | | AD05 | E <sub>GN</sub> | Gain Error | _ | _ | ±2.5 | LSb | $ADC_{REF}$ + = 3.0V,<br>$ADC_{REF}$ - = 0V | | | | | AD06 | V <sub>ADREF</sub> | ADC Reference Voltage (AD <sub>REF</sub> + - AD <sub>REF</sub> -) | _ | _ | V <sub>DD</sub> | ٧ | | | | | | AD07 | V <sub>AIN</sub> | Full-Scale Range | AD <sub>REF</sub> - | _ | AD <sub>REF</sub> + | V | | | | | | AD08 | Z <sub>AIN</sub> | Recommended Impedance of Analog<br>Voltage Source | _ | 1 | _ | kΩ | | | | | | AD09 | R <sub>VREF</sub> | ADC Voltage Reference Ladder Impedance | _ | 50 | _ | kΩ | (Note 3) | | | | <sup>\*</sup> These parameters are characterized but not tested. #### Notes: - 1. Total Absolute Error is the sum of the offset, gain and integral nonlinearity (INL) errors. - 2. The ADC conversion result never decreases with an increase in the input and has no missing codes. - 3. This is the impedance seen by the $V_{\mathsf{REF}}$ pads when the external reference pads are selected. # 41.4.7 Analog-to-Digital Converter (ADC) Conversion Timing Specifications Table 41-13. | Standard O | peratin | g Conditions (unless other | wise s | stated) | | | | |------------|------------------|----------------------------|--------|--------------------------------------|------|-------|----------------------------------------------------------| | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | AD20 | T <sub>AD</sub> | ADC Clock Period | _ | _ | _ | μs | Using F <sub>OSC</sub> as the ADC clock source ADOCS = 0 | | | | | _ | 2 | _ | μs | Using ADCRC as the ADC clock source ADOCS = 1 | | AD21 | T <sub>CNV</sub> | Conversion Time | _ | 14 T <sub>AD</sub> +2T <sub>CY</sub> | _ | _ | Using F <sub>OSC</sub> as the ADC clock source ADOCS = 0 | | | | | _ | 16 T <sub>AD</sub> +2T <sub>CY</sub> | _ | _ | Using ADCRC as the ADC clock source ADOCS = 1 | <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | |---------------------------------------------------------|------------------|----------------------------------------------|------|-------------------------------------|------|-------|----------------------------------------------------------|--|--| | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | | | AD22 | T <sub>HCD</sub> | Sample-and-Hold<br>Capacitor Disconnect Time | _ | 2 T <sub>AD</sub> +1T <sub>CY</sub> | _ | _ | Using F <sub>OSC</sub> as the ADC clock source ADOCS = 0 | | | | | | | _ | 3 T <sub>AD</sub> +2T <sub>CY</sub> | _ | _ | Using ADCRC as the ADC clock source ADOCS = 1 | | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Figure 41-10. ADC Conversion Timing (ADC Clock F<sub>OSC</sub>-Based) Figure 41-11. ADC Conversion Timing (ADC Clock from ADCRC) #### Note: 1. If the ADC clock source is selected as ADCRC, a time of $T_{CY}$ is added before the ADC clock starts. This allows the SLEEP instruction to be executed. #### 41.4.8 8-Bit DAC Specifications #### Table 41-14. | Standard Ope | rating Cond | ditions (unless otherwise | e stated) | | | | | |----------------------|---------------------|------------------------------|-----------|-------------------------------------------------------|------|-------|------------| | $V_{DD} = 3.0V, T_A$ | <sub>λ</sub> = 25°C | | | | | | | | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | DAC01* | C <sub>LSB</sub> | Step Size | _ | (V <sub>DACREF</sub> +-<br>V <sub>DACREF</sub> -)/256 | _ | V | | | DAC02 | C <sub>INL</sub> | Integral Error | _ | _ | ±1 | LSb | | | DAC03 | C <sub>DNL</sub> | Differential Error | _ | _ | ±1 | LSb | | | DAC04 | C <sub>OFF</sub> | Offset Error | _ | _ | ±1 | LSb | | | DAC05 | C <sub>GN</sub> | Gain Error | _ | _ | ±2 | LSb | | | DAC06* | C <sub>R</sub> | Unit Resistor Value | _ | _ | _ | Ω | | | DAC07* | C <sub>ST</sub> | Settling Time <sup>(1)</sup> | _ | _ | 10 | μs | | | DAC08* | C <sub>ACC</sub> | Absolute Accuracy | _ | _ | ±1 | LSb | | <sup>\*</sup> These parameters are characterized but not tested. #### Note: 1. Settling time measured while DACR[7:0] transitions from 'b000000000 to 'b111111111. <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. ## 41.4.9 Comparator Specifications #### Table 41-15. | Standard Opera | ating Conditi | ons (unless otherwise stated | d) | | | | | |------------------------|-----------------------|--------------------------------------|------|--------|-----------------|-------|----------------------| | $V_{DD}$ = 3.0V, $T_A$ | = 25°C | | | | | | | | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | CM01 | V <sub>IOFF</sub> | Input Offset Voltage | _ | _ | ±50 | mV | $V_{ICM} = V_{DD}/2$ | | CM02 | V <sub>ICM</sub> | Input Common Mode<br>Range | GND | _ | V <sub>DD</sub> | V | | | CM03 | CMRR | Common Mode Input<br>Rejection Ratio | _ | _ | 35 | dB | | | CM04 | V <sub>HYST</sub> | Comparator Hysteresis | 10 | _ | 35 | mV | | | CM05 | T <sub>RESP</sub> (1) | Response Time, Rising<br>Edge | _ | _ | _ | ns | | | | | Response Time, Falling | _ | _ | _ | ns | | <sup>\*</sup> These parameters are characterized but not tested. #### Note: 1. Response time measured with one comparator input at $V_{DD}/2$ , while the other input transitions from $V_{SS}$ to $V_{DD}$ . ## 41.4.10 Zero-Cross Detect (ZCD) Specifications #### Table 41-16. | $V_{DD} = 3.0V, T_A = 25^{\circ}C$ | | | | | | | | | | | |------------------------------------|----------------------|--------------------------------|------|--------|------|-------|------------|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | | | | ZC01 | V <sub>PINZC</sub> | Voltage on Zero-Cross<br>Pin | _ | 0.9 | _ | V | | | | | | ZC02 | I <sub>ZCD_MAX</sub> | Maximum source or sink current | _ | _ | 600 | μA | | | | | | ZC03 | T <sub>RESPH</sub> | Response Time,<br>Rising Edge | _ | 1 | _ | μs | | | | | | | T <sub>RESPL</sub> | Response Time,<br>Falling Edge | _ | 1 | _ | μs | | | | | <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. ## 41.4.11 Fixed Voltage Reference (FVR) Specifications Table 41-17. | Standard Ope | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | |--------------|---------------------------------------------------------|-------------------|------------|--------|------|-------|----------------------------------------|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Тур. † | Max. | Units | Conditions | | | | | FVR01 | V <sub>FVR</sub> 1 | 1x Gain (1.024V) | -4 | _ | +4 | % | V <sub>DD</sub> ≥ 2.5V, -40°C to 85°C | | | | | FVR02 | V <sub>FVR</sub> 2 | 2x Gain (2.048V) | -4 | _ | +4 | % | V <sub>DD</sub> ≥ 2.5V, -40°C to 85°C | | | | | FVR03 | V <sub>FVR</sub> 4 | 4x Gain (4.096V) | <b>-</b> 6 | _ | +6 | % | V <sub>DD</sub> ≥ 4.75V, -40°C to 85°C | | | | | FVR04 | T <sub>FVRST</sub> | FVR Start-up Time | _ | 25 | _ | μs | | | | | #### 41.4.12 Temperature Indicator Requirements Table 41-18. | Standard Ope | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | |--------------|---------------------------------------------------------|-----------------------------|----------------|---|-------|------|-------|------------|--| | Param. No. | Sym. | Characte | Characteristic | | | Max. | Units | Conditions | | | TS01* | T <sub>ACQMIN</sub> | Minimum ADC A<br>Time Delay | cquisition | _ | 25 | _ | μs | | | | TS02* | M <sub>V</sub> | Voltage | High Range | _ | -3.75 | _ | mV/°C | TSRNG = 1 | | | | | Sensitivity | Low Range | _ | -2.75 | _ | mV/°C | TSRNG = 0 | | <sup>\*</sup> These parameters are characterized but not tested. ## 41.4.13 Capture/Compare/PWM Requirements (CCP) Table 41-19. Standard Operating Conditions (unless otherwise stated) Operating Temperature: -40°C $\leq T_A \leq +125$ °C | Param. No. | Sym. | Chara | cteristic | Min. | Тур. † | Max. | Units | Conditions | |------------|-------------------|----------------------|----------------|--------------------------|--------|------|-------|-----------------------| | CC01* | T <sub>CC</sub> L | CCPx Input | No Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | Low Time | With Prescaler | 20 | _ | _ | ns | | | CC02* | T <sub>CC</sub> H | CCPx Input | No Prescaler | 0.5T <sub>CY</sub> +20 | _ | _ | ns | | | | | High Time | With Prescaler | 20 | _ | _ | ns | | | CC03* | T <sub>CC</sub> P | CCPx Input<br>Period | | (3T <sub>CY</sub> +40)/N | _ | _ | ns | N = Prescale<br>value | <sup>\*</sup> These parameters are characterized but not tested. <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Figure 41-12. Capture/Compare/PWM Timings (CCP) Note: Refer to the "Load Conditions" figure for load conditions. ## 41.4.14 EUSART Synchronous Transmission Requirements Table 41-20. | Standard Ope | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | |--------------|---------------------------------------------------------|-----------------------------------|------|------|-------|-------------------------------|--|--|--| | Param. No. | Sym. | Characteristic | Min. | Max. | Units | Conditions | | | | | US120 | T <sub>CK</sub> H2 <sub>DT</sub> V | SYNC XMIT (Host and Client) | _ | _ | ns | 3.0V ≤ V <sub>DD</sub> ≤ 5.5V | | | | | | | Clock high to data-out valid | _ | _ | ns | 1.8V ≤ V <sub>DD</sub> ≤ 5.5V | | | | | US121 | T <sub>CKRF</sub> | Clock out rise time and fall time | _ | _ | ns | 3.0V ≤ V <sub>DD</sub> ≤ 5.5V | | | | | | | (Host mode) | _ | _ | ns | $1.8V \le V_{DD} \le 5.5V$ | | | | | US122 | T <sub>DTRF</sub> | Data-out rise time and fall time | _ | _ | ns | $3.0V \le V_{DD} \le 5.5V$ | | | | | | | | _ | _ | ns | 1.8V ≤ V <sub>DD</sub> ≤ 5.5V | | | | Figure 41-13. EUSART Synchronous Transmission (Host/Client) Timing Note: Refer to the "Load Conditions" figure for load conditions. ## 41.4.15 EUSART Synchronous Receive Requirements Table 41-21. | Standard Ope | Standard Operating Conditions (unless otherwise stated) | | | | | | | | |--------------|---------------------------------------------------------|-------------------------------------------------------------------|------|------|-------|------------|--|--| | Param. No. | Sym. | Characteristic | Min. | Max. | Units | Conditions | | | | US125 | T <sub>DT</sub> V2 <sub>CKL</sub> | SYNC RCV (Host and Client) Data-setup before CK ↓ (DT hold time) | _ | _ | ns | | | | | US126 | T <sub>CK</sub> L2 <sub>DTL</sub> | Data-hold after CK ↓ (DT hold time) | | _ | ns | | | | Figure 41-14. EUSART Synchronous Receive (Host/Client) Timing Note: Refer to the "Load Conditions" figure for load conditions. ## 41.4.16 SPI Mode Requirements Table 41-22. SPI Mode | Standard ( | Operating Cond | litions (unless otherwis | e stated) | | | | | |---------------|---------------------------------------------------------------------------|------------------------------------------------|--------------------------|--------|------------------------------|-------|-----------------------------------| | Param.<br>No. | Sym. | Characteristic | Min. | Тур. † | Max. | Units | Conditions | | SP70* | T <sub>SS</sub> L2 <sub>SC</sub> H,<br>T <sub>SS</sub> L2 <sub>SC</sub> L | SDO to SCK↓ or<br>SCK↑ input | 2.25*T <sub>CY</sub> | _ | _ | ns | | | SP71* | T <sub>SC</sub> H | SCK output high time | T <sub>CY</sub> + 20 | _ | 0.5 T <sub>SCK</sub><br>+ 12 | ns | | | SP72* | T <sub>SC</sub> L | SCK output low time | T <sub>CY</sub> + 20 | _ | 0.5 T <sub>SCK</sub><br>+ 12 | ns | | | SP73* | T <sub>DI</sub> V2 <sub>SC</sub> H,<br>T <sub>DI</sub> V2 <sub>SC</sub> L | Setup time of SDI<br>data input to SCK<br>edge | 85 | _ | _ | ns | | | SP74* | T <sub>SC</sub> H2 <sub>DI</sub> L,<br>T <sub>SC</sub> L2 <sub>DI</sub> L | Hold time of SDI<br>data input to SCK<br>edge | 0 | _ | _ | ns | | | | | Hold time of SDI<br>data input to final<br>SCK | 0.5 T <sub>SCK</sub> | | | ns | CKE = 0,<br>SMP = 1 | | SP75* | T <sub>DO</sub> R | SDO data output rise time | _ | 10 | 25 | ns | C <sub>L</sub> = 50 pF | | SP76* | T <sub>DO</sub> F | SDO data output fall time | _ | 10 | 25 | ns | C <sub>L</sub> = 50 pF | | SP78* | T <sub>SC</sub> R | SCK output rise time | _ | 10 | 25 | ns | C <sub>L</sub> = 50 pF | | SP79* | T <sub>SC</sub> F | SCK output fall time | _ | 10 | 25 | ns | C <sub>L</sub> = 50 pF | | SP80* | $T_{SC}H2_{DO}V$ , $T_{SC}L2_{DO}V$ | SDO data output valid after SCK edge | _ | _ | _ | ns | C <sub>L</sub> = 50 pF | | SP81* | T <sub>DO</sub> V2 <sub>SC</sub> H,<br>T <sub>DO</sub> V2 <sub>SC</sub> L | SDO data output<br>valid to first SCK<br>edge | 1 T <sub>CY</sub> | _ | _ | ns | C <sub>L</sub> = 50 pF<br>CKE = 1 | | SP82* | T <sub>SS</sub> L2 <sub>DO</sub> V | SDO data output valid after SS↓ edge | _ | _ | 50 | ns | C <sub>L</sub> = 20 pF | | SP83* | T <sub>SC</sub> H2 <sub>SS</sub> H,<br>T <sub>SC</sub> L2 <sub>SS</sub> H | SS ↑ after last SCK<br>edge | 1.5 T <sub>CY</sub> + 40 | _ | _ | ns | | | conti | continued | | | | | | | | | |---------------|-----------------|-----------------------|-----------|--------|------|-------|------------|--|--| | Standard O | perating Condit | ions (unless otherwis | e stated) | | | | | | | | Param.<br>No. | Sym. | Characteristic | Min. | Typ. † | Max. | Units | Conditions | | | <sup>\*</sup> These parameters are characterized but not tested. † Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. #### Note: 1. SMP bit in the SSPxSTAT register must be set and the slew rate control must be disabled on the clock and data pins (clear the corresponding bits in SLRCONx register) for SPI to operate over 4 MHz. Figure 41-15. SPI Host Mode Timing (CKE = 0, SMP = 0) Note: Refer to the "Load Conditions" figure for load conditions. Rev. 30-0000844 4/6/2017 Figure 41-16. SPI Host Mode Timing (CKE = 1, SMP = 1) SS ; SP81; Note: Refer to the "Load Conditions" figure for load conditions. Figure 41-17. SPI Client Mode Timing (CKE = 0) Note: Refer to the "Load Conditions" figure for load conditions. Rev. 30-000086A 4/6/2017 - SP82 SS SP70 SP83 SCK (CKP = 0) SP72 SCK (CKP = 1) -¦SP80 LSb SDO MSb bit 6 →; ;<del>←</del> SP75, SP76 SP77 SDI MSb In LSb In SP74 Figure 41-18. SPI Client Mode Timing (CKE = 1) Note: Refer to the "Load Conditions" figure for load conditions. ## 41.4.17 I<sup>2</sup>C Bus Start/Stop Bits Requirements Table 41-23. | Standard O | perating | Conditions (un | less otherwise | stated | ) | | | | | |--------------|------------------------------------------------------|-----------------|----------------|--------|--------|------|-------|------------------------------------|--| | Param. No. | Sym. | Characteristic | | Min. | Тур. † | Max. | Units | Conditions | | | SP90* | T <sub>SU:STA</sub> | Start condition | 100 kHz mode | 4700 | _ | _ | ns | Only relevant for Repeated | | | | | Setup time | 400 kHz mode | 600 | _ | _ | | Start condition | | | SP91* | T <sub>HD:STA</sub> | Start condition | 100 kHz mode | 4000 | _ | _ | ns | After this period, the first clock | | | | | Hold time | 400 kHz mode | 600 | _ | _ | | pulse is generated | | | SP92* | T <sub>SU:STO</sub> | Stop condition | 100 kHz mode | 4000 | _ | _ | ns | | | | | | Setup time | 400 kHz mode | 600 | _ | _ | | | | | SP93* | T <sub>HD:STO</sub> | Stop condition | 100 kHz mode | 4700 | _ | _ | ns | | | | | | Hold time | 400 kHz mode | 1300 | _ | _ | | | | | * These para | * These parameters are characterized but not tested. | | | | | | | | | Figure 41-19. I<sup>2</sup>C Bus Start/Stop Bits Timing Note: Refer to the "Load Conditions" figure for load conditions. ## 41.4.18 I<sup>2</sup>C Bus Data Requirements Table 41-24. | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | |---------------------------------------------------------|---------------------|-----------------------|-----------------|----------------------------------|--------------|-------|------------------------------------------------------|--|--| | Param. No. | Sym. | Characteristic | | Min. | Max. | Units | Conditions | | | | SP100* | T <sub>HIGH</sub> | Clock high time | 100 kHz<br>mode | 4000 | _ | ns | Device must<br>operate at a<br>minimum of 1.5<br>MHz | | | | | | | 400 kHz<br>mode | 600 | <u> </u> | ns | Device must<br>operate at a<br>minimum of 10<br>MHz | | | | SP101* | T <sub>LOW</sub> | Clock low time | 100 kHz<br>mode | 4700 | <del>_</del> | ns | Device must<br>operate at a<br>minimum of 1.5<br>MHz | | | | | | | 400 kHz<br>mode | 1300 | <del>_</del> | ns | Device must<br>operate at a<br>minimum of 10<br>MHz | | | | SP102* | T <sub>R</sub> | SDA and SCL rise time | 100 kHz<br>mode | _ | 1000 | ns | | | | | | | | 400 kHz<br>mode | 20 | 300 | ns | C <sub>B</sub> is specified to be from 10-400 pF | | | | SP103* | T <sub>F</sub> | SDA and SCL fall time | 100 kHz<br>mode | _ | 250 | ns | | | | | | | | 400 kHz<br>mode | 20 × (V <sub>DD</sub> /<br>5.5V) | 250 | ns | C <sub>B</sub> is specified to be from 10-400 pF | | | | SP106* | T <sub>HD:DAT</sub> | Data input hold time | 100 kHz<br>mode | 0 | _ | ns | | | | | | | | 400 kHz<br>mode | 0 | <del>_</del> | ns | | | | | continued Standard Operating Conditions (unless otherwise stated) | | | | | | | | | |-------------------------------------------------------------------|---------------------|-------------------------|-----------------|------|------|-------|------------------------------------|--| | Param. No. | Sym. | Characteristic | | Min. | Max. | Units | Conditions | | | SP107* | T <sub>SU:DAT</sub> | Data input setup time | 100 kHz<br>mode | 250 | _ | ns | (Note 2) | | | | | | 400 kHz<br>mode | 100 | _ | ns | | | | SP109* | T <sub>AA</sub> | Output valid from clock | 100 kHz<br>mode | _ | 3450 | ns | (Note 1) | | | | | | 400 kHz<br>mode | _ | 900 | ns | | | | SP110* | T <sub>BUF</sub> | Bus free time | 100 kHz<br>mode | 4700 | _ | ns | Time the bus must be free before a | | | | | | 400 kHz<br>mode | 1300 | _ | ns | new transmission can start | | | SP111 | Св | Bus capacitive loading | 100 kHz<br>mode | _ | 400 | pF | | | | | | | 400 kHz<br>mode | _ | 400 | pF | | | <sup>\*</sup> These parameters are characterized but not tested. #### Notes: - 1. As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions. - 2. A Fast mode (400 kHz) I<sup>2</sup>C bus device can be used in a Standard mode (100 kHz) I<sup>2</sup>C bus system, but the requirement T<sub>SU:DAT</sub> ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the low period of the SCL signal. If such a device does stretch the low period of the SCL signal, it must output the next data bit to the SDA line TR max. + T<sub>SU:DAT</sub> = 1000 + 250 = 1250 ns (according to the Standard mode I<sup>2</sup>C bus specification), before the SCL line is released. - 3. Using internal I<sup>2</sup>C pull-ups. For greater bus capacitance use external pull-ups. Figure 41-20. I<sup>2</sup>C Bus Data Timing Note: Refer to the "Load Conditions" figure for load conditions. # 41.4.19 Configurable Logic Cell (CLC) Characteristics Table 41-25. | Standard Operating Conditions (unless otherwise stated) | | | | | | | | | | | |---------------------------------------------------------|---------------------|---------------------------------|-----------|------|--------|------|-------|------------------------|--|--| | Operating Temperature: -40°C≤T <sub>A</sub> ≤+125°C | | | | | | | | | | | | Param. No. | Sym. | Characteristic | | Min. | Тур. † | Max. | Units | Conditions | | | | CLC01* | T <sub>CLCIN</sub> | CLC input time | | _ | 7 | IO5 | ns | (Note 1) | | | | CLC02* | T <sub>CLC</sub> | CLC module input to output | | _ | 24 | _ | ns | V <sub>DD</sub> = 1.8V | | | | | | propagation time | | _ | 12 | | | V <sub>DD</sub> > 3.6V | | | | CLC03* | T <sub>CLCOUT</sub> | CLC output time | Rise Time | _ | 106 | _ | _ | (Note 1) | | | | | | | Fall Time | _ | IO8 | _ | _ | (Note 1) | | | | CLC04* | F <sub>CLCMAX</sub> | CLC maximum switching frequency | | _ | _ | OS20 | _ | | | | <sup>\*</sup> These parameters are characterized but not tested. #### Note: 1. See the "I/O and CLKOUT Timing Specifications" section for IO5, IO6 and IO8 rise and fall times. Figure 41-21. CLC Propagation Timing <sup>†</sup> Data in "Typ" column is at 3.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. Graphs and tables are not available at this time. ## 43. Packaging Information Package Marking Information Legend: XX...X Customer-specific information or Microchip part number Y Year code (last digit of calendar year) YY Year code (last 2 digits of calendar year) WW Week code (week of January 1 is week '01') NNN Alphanumeric traceability code e3 Pb-free JEDEC® designator for Matte Tin (Sn) Note: In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information. 8-Lead Plastic Dual In-Line - 300 mil Body [PDIP] 8-Lead PDIP (300 mil) Example 8-Lead SOIC (3.90 mm) Example # PIC16F18015/25/44/45 ## **Packaging Information** 14-Lead TSSOP (4.4 mm) 14-Lead SOIC (3.90 mm) 14-Lead Plastic Dual In-Line – 300 mil Body [PDIP] 14-Lead PDIP (300 mil) Example Rev. 30-009020A 09/21/2017 20-Lead PDIP (300 mil) Example 20-Lead SSOP (5.30 mm) 20-Lead QFN (4x4x1 mm) ## 43.1 Package Details The following sections give the technical details of the packages. ## 8-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing No. C04-018-P Rev E Sheet 1 of 2 ## 8-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | INCHES | | | |----------------------------|----|--------|----------|------| | Dimension Limits | | MIN | NOM | MAX | | Number of Pins | N | | 8 | | | Pitch | е | | .100 BSC | | | Top to Seating Plane | Α | 1 | - | .210 | | Molded Package Thickness | A2 | .115 | .130 | .195 | | Base to Seating Plane | A1 | .015 | ı | - | | Shoulder to Shoulder Width | Е | .290 | .310 | .325 | | Molded Package Width | E1 | .240 | .250 | .280 | | Overall Length | D | .348 | .365 | .400 | | Tip to Seating Plane | L | .115 | .130 | .150 | | Lead Thickness | С | .008 | .010 | .015 | | Upper Lead Width | b1 | .040 | .060 | .070 | | Lower Lead Width | b | .014 | .018 | .022 | | Overall Row Spacing § | eВ | - | - | .430 | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M - BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 5. Lead design above seating plane may vary, based on assembly vendor. Microchip Technology Drawing No. C04-018-P Rev E Sheet 2 of 2 ## 8-Lead Plastic Small Outline (SN) - Narrow, 3.90 mm (.150 ln.) Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing No. C04-057-SN Rev G Sheet 1 of 2 ## 8-Lead Plastic Small Outline (SN) - Narrow, 3.90 mm (.150 ln.) Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | MILLIMETERS | | | | |--------------------------|--------|-------------|----------|------|--| | Dimension | Limits | MIN | NOM | MAX | | | Number of Pins | N | | 8 | | | | Pitch | е | | 1.27 BSC | | | | Overall Height | Α | - | 1 | 1.75 | | | Molded Package Thickness | A2 | 1.25 | 1 | - | | | Standoff § | A1 | 0.10 | 1 | 0.25 | | | Overall Width | Е | | 6.00 BSC | | | | Molded Package Width | E1 | 3.90 BSC | | | | | Overall Length | D | 4.90 BSC | | | | | Chamfer (Optional) | h | 0.25 – 0.50 | | | | | Foot Length | L | 0.40 | ı | 1.27 | | | Footprint | L1 | | 1.04 REF | | | | Lead Thickness | С | 0.17 | - | 0.25 | | | Lead Width | b | 0.31 | 1 | 0.51 | | | Lead Bend Radius | R | 0.07 – – | | | | | Lead Bend Radius | R1 | 0.07 – – | | | | | Foot Angle | θ | 0° | _ | 8° | | | Mold Draft Angle | θ1 | 5° | _ | 15° | | | Lead Angle | θ2 | 0° | _ | 8° | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M - BSC: Basic Dimension. Theoretically exact value shown without tolerances. - REF: Reference Dimension, usually without tolerance, for information purposes only. - 5. Datums A & B to be determined at Datum H. Microchip Technology Drawing No. C04-057-SN Rev G Sheet 2 of 2 $\,$ ## 8-Lead Plastic Small Outline (SN) - Narrow, 3.90 mm (.150 ln.) Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### RECOMMENDED LAND PATTERN | | Units | MILLIMETERS | | | | |-------------------------|------------------|-------------|-----|------|--| | Dimension | Dimension Limits | | NOM | MAX | | | Contact Pitch | Е | 1.27 BSC | | | | | Contact Pad Spacing | С | 5.40 | | | | | Contact Pad Width (X8) | X1 | | | 0.60 | | | Contact Pad Length (X8) | Y1 | | | 1.55 | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-2057-SN Rev G ## 14-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | INCHES | | | |----------------------------|------------------|------|----------|------|--| | | Dimension Limits | | NOM | MAX | | | Number of Pins | N | | 14 | | | | Pitch | е | | .100 BSC | | | | Top to Seating Plane | A | - | _ | .210 | | | Molded Package Thickness | A2 | .115 | .130 | .195 | | | Base to Seating Plane | A1 | .015 | _ | - | | | Shoulder to Shoulder Width | E | .290 | .310 | .325 | | | Molded Package Width | E1 | .240 | .250 | .280 | | | Overall Length | D | .735 | .750 | .775 | | | Tip to Seating Plane | L | .115 | .130 | .150 | | | Lead Thickness | С | .008 | .010 | .015 | | | Upper Lead Width | b1 | .045 | .060 | .070 | | | Lower Lead Width | b | .014 | .018 | .022 | | | Overall Row Spacing § | eB | - | _ | .430 | | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located with the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-005B ## 14-Lead Plastic Small Outline (SL) - Narrow, 3.90 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging ## 14-Lead Plastic Small Outline (SL) - Narrow, 3.90 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | MILLIMETERS | | | | |--------------------------|-------------|-------------|----------|------| | Dimension | Limits | MIN | NOM | MAX | | Number of Pins | N | | 14 | | | Pitch | е | | 1.27 BSC | | | Overall Height | Α | 1 | - | 1.75 | | Molded Package Thickness | A2 | 1.25 | - | - | | Standoff § | A1 | 0.10 | - | 0.25 | | Overall Width | Е | | 6.00 BSC | | | Molded Package Width | E1 | | 3.90 BSC | | | Overall Length | D | | 8.65 BSC | | | Chamfer (Optional) | h | 0.25 | - | 0.50 | | Foot Length | L | 0.40 | - | 1.27 | | Footprint | L1 | | 1.04 REF | | | Lead Angle | Θ | 0° | - | - | | Foot Angle | $\varphi$ | 0° | - | 8° | | Lead Thickness | С | 0.10 - 0.25 | | | | Lead Width | b | 0.31 - 0.51 | | | | Mold Draft Angle Top | α | 5° - 15° | | | | Mold Draft Angle Bottom | β | 5° | - | 15° | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic - Dimension D does not include mold flash, protrusions or gate burrs, which shall not exceed 0.15 mm per end. Dimension E1 does not include interlead flash or protrusion, which shall not exceed 0.25 mm per side. - 4. Dimensioning and tolerancing per ASME Y14.5M - BSC: Basic Dimension. Theoretically exact value shown without tolerances. - REF: Reference Dimension, usually without tolerance, for information purposes only. - 5. Datums A & B to be determined at Datum H. Microchip Technology Drawing No. C04-065-SL Rev D Sheet 2 of 2 ## 14-Lead Plastic Small Outline (SL) - Narrow, 3.90 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging ### RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | |--------------------------|---|-------------|----------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | Е | | 1.27 BSC | | | Contact Pad Spacing | С | | 5.40 | | | Contact Pad Width (X14) | Х | | | 0.60 | | Contact Pad Length (X14) | Υ | | | 1.55 | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2065-SL Rev D ## 14-Lead Thin Shrink Small Outline Package [ST] - 4.4 mm Body [TSSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-087 Rev E Sheet 1 of 2 ## 14-Lead Thin Shrink Small Outline Package [ST] - 4.4 mm Body [TSSOP] For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | MILLIMETERS | | | |--------------------------|---------------|-------------|----------|------| | Dime | ension Limits | MIN | NOM | MAX | | Number of Terminals | N | | 14 | | | Pitch | е | | 0.65 BSC | | | Overall Height | А | - | _ | 1.20 | | Standoff | A1 | 0.05 | _ | 0.15 | | Molded Package Thickness | A2 | 0.80 | 1.00 | 1.05 | | Overall Length | D | 4.90 | 5.00 | 5.10 | | Overall Width | E | | 6.40 BSC | | | Molded Package Width | E1 | 4.30 | 4.40 | 4.50 | | Terminal Width | b | 0.19 | _ | 0.30 | | Terminal Thickness | С | 0.09 | - | 0.20 | | Terminal Length | L | 0.45 | 0.60 | 0.75 | | Footprint | L1 | | 1.00 REF | | | Lead Bend Radius | R1 | 0.09 | _ | _ | | Lead Bend Radius | R2 | 0.09 | _ | _ | | Foot Angle | θ1 | 0° | _ | 8° | | Mold Draft Angle | θ2 | - | 12° REF | _ | | Mold Draft Angle | θ3 | _ | 12° REF | _ | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-087 Rev E Sheet 2 of 2 ## 14-Lead Thin Shrink Small Outline Package [ST] - 4.4 mm Body [TSSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging ### RECOMMENDED LAND PATTERN | | MILLIMETERS | | | | |----------------------------------|-------------|----------|------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | Е | 0.65 BSC | | | | Contact Pad Spacing | С | | 5.90 | | | Contact Pad Width (Xnn) | Χ | | | 0.45 | | Contact Pad Length (Xnn) | Υ | | | 1.45 | | Contact Pad to Contact Pad (Xnn) | G | 0.20 | | | #### Notes: Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-2087 Rev E # 16-Lead Plastic Quad Flat, No Lead Package (7N) - 4x4x1.0 mm Body [VQFN] Wettable Flanks (Stepped), 0.40 mm Terminal Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-403C Sheet 1 of 2 # 16-Lead Plastic Quad Flat, No Lead Package (7N) - 4x4x1.0 mm Body [VQFN] Wettable Flanks (Stepped), 0.40 mm Terminal Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | MILLIMETERS | | | |-------------------------|------------------|-------------|----------|-------| | Dimension | Dimension Limits | | NOM | MAX | | Number of Terminals | N | | 16 | | | Pitch | е | | 0.65 BSC | | | Overall Height | Α | 0.80 | 0.90 | 1.00 | | Standoff | A1 | 0.00 | 0.02 | 0.05 | | Terminal Thickness | A3 | | 0.20 REF | | | Step Height | A4 | 0.05 | 0.12 | 0.19 | | Overall Width | Е | | 4.00 BSC | | | Exposed Pad Width | E2 | 2.50 | 2.60 | 2.70 | | Overall Length | D | | 4.00 BSC | | | Exposed Pad Length | D2 | 2.50 | 2.60 | 2.70 | | Terminal Width | b | 0.25 | 0.30 | 0.35 | | Terminal Length | Ĺ | 0.30 | 0.40 | 0.50 | | Step Length | L1 | 0.035 | 0.060 | 0.085 | | Terminal-to-Exposed Pad | K | 0.30 | - | - | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-403C Sheet 2 of 2 # 16-Lead Plastic Quad Flat, No Lead Package (7N) - 4x4x1.0 mm Body [VQFN] Wettable Flanks (Stepped), 0.40 mm Terminal Length **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### RECOMMENDED LAND PATTERN | | MILLIMETERS | | | | |----------------------------------|-------------|------|----------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | E | | 0.65 BSC | | | Optional Center Pad Width | X2 | | | 2.70 | | Optional Center Pad Length | Y2 | | | 2.70 | | Contact Pad Spacing | C1 | | 4.00 | | | Contact Pad Spacing | C2 | | 4.00 | | | Contact Pad Width (X16) | X1 | | | 0.30 | | Contact Pad Length (X16) | Y1 | | | 0.80 | | Contact Pad to Center Pad (X16) | G1 | 0.20 | | | | Contact Pad to Contact Pad (X12) | G2 | 0.35 | | | | Thermal Via Diameter | V | | 0.30 | | | Thermal Via Pitch | EV | | 1.00 | | #### Notes: - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Drawing C04-2403B ## 20-Lead Plastic Dual In-Line (P) - 300 mil Body [PDIP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | | INCHES | | |----------------------------|-----------|------|----------|-------| | Dimensi | on Limits | MIN | NOM | MAX | | Number of Pins | N | | 20 | | | Pitch | е | | .100 BSC | | | Top to Seating Plane | Α | - | _ | .210 | | Molded Package Thickness | A2 | .115 | .130 | .195 | | Base to Seating Plane | A1 | .015 | _ | _ | | Shoulder to Shoulder Width | E | .300 | .310 | .325 | | Molded Package Width | E1 | .240 | .250 | .280 | | Overall Length | D | .980 | 1.030 | 1.060 | | Tip to Seating Plane | L | .115 | .130 | .150 | | Lead Thickness | С | .008 | .010 | .015 | | Upper Lead Width | b1 | .045 | .060 | .070 | | Lower Lead Width | b | .014 | .018 | .022 | | Overall Row Spacing § | eB | _ | _ | .430 | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. § Significant Characteristic. - 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" per side. - 4. Dimensioning and tolerancing per ASME Y14.5M. BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing C04-019B ## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Erawing C04-094 Rev E Sheet 1 of 2 ## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | | Units | MILLIMETERS | | | |--------------------------|------------------|-------------|-----------|------| | | Dimension Limits | MIN | NOM | MAX | | Number of Terminals | N | | 20 | | | Pitch | е | | 1.27 BSC | | | Overall Height | А | - | - | 2.65 | | Standoff § | A1 | 0.10 | - | 0.30 | | Molded Package Thickness | A2 | 2.05 | - | - | | Overall Length | D | | 12.80 BSC | | | Overall Width | Е | | 10.30 BSC | | | Molded Package Width | E1 | | 7.50 BSC | | | Terminal Width | b | 0.31 | - | 0.51 | | Terminal Thickness | С | 0.25 | - | 0.75 | | Corner Chamfer | h | 0.25 | - | 0.75 | | Terminal Length | L | 0.40 | 0.65 | 1.27 | | Footprint | L1 | | 1.40 REF | | | Lead Bend Radius | R1 | 0.07 | - | - | | Lead Bend Radius | R2 | 0.07 | - | - | | Foot Angle | θ | 0° | - | 8° | | Lead Angle | θ1 | 0° | - | - | | Mold Draft Angle | θ2 | 5° | - | 15° | | Mold Draft Angle | θ3 | 5° | - | 15° | ### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Dimensioning and tolerancing per ASME Y14.5M - BSC: Basic Dimension. Theoretically exact value shown without tolerances. - REF: Reference Dimension, usually without tolerance, for information purposes only. 3. Dimension D does not include mold flash, protrusions or gate burrs, which shall - not exceed 0.15 mm per end. Dimension E1 does not include interlead flash or protrusion, which shall not exceed 0.25 mm per side. - 4. § Significant Characteristic Microchip Technology Erawing C04-094 Rev E $\,$ Sheet 2 of 2 $\,$ ## 20-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | | MILLIMETERS | | | | |----------------------------|-------------|----------|------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch E | | 1.27 BSC | | | | Contact Pad Spacing | С | | 9.40 | | | Contact Pad Width (X20) | Х | | | 0.60 | | Contact Pad Length (X20) | | | | 1.95 | | Contact Pad to Contact Pad | G | 0.67 | | | | Contact Pad to Contact Pad | G1 | 7.45 | | | #### Notes - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Erawing C04-2094 Rev E ## 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-072 Rev C Sheet 1 of 2 ### 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | MILLIMETERS | | | |--------------------------|----|-------------|----------|------| | Dimension Limits | | MIN | NOM | MAX | | Number of Pins | N | 20 | | | | Pitch | е | | 0.65 BSC | | | Overall Height | Α | A 2.00 | | 2.00 | | Molded Package Thickness | A2 | 1.65 | 1.75 | 1.85 | | Standoff | A1 | 0.05 | - | - | | Overall Width | Е | 7.40 | 7.80 | 8.20 | | Molded Package Width | E1 | 5.00 | 5.30 | 5.60 | | Overall Length | D | 6.90 | 7.20 | 7.50 | | Foot Length L | | 0.55 | 0.75 | 0.95 | | Footprint L1 | | 1.25 REF | | | | Lead Thickness | С | 0.09 | - | 0.25 | | Foot Angle 9 | | 0° | 4° | 8° | | Lead Width b | | 0.22 | - | 0.38 | #### Notes: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.20mm per side. - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-072 Rev C Sheet 2 of 2 ## 20-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging #### RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | |---------------------------------|----|-------------|------|------| | Dimension Limits | | MIN | NOM | MAX | | Contact Pitch | Е | 0.65 BSC | | · | | Contact Pad Spacing | С | | 7.00 | | | Contact Pad Width (X20) | X1 | | | 0.45 | | Contact Pad Length (X20) | Y1 | | | 1.85 | | Contact Pad to Center Pad (X18) | G1 | 0.20 | | | #### Notes: - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Drawing C04-2072 Rev C # 20-Lead Plastic Quad Flat, No Lead Package (ML) - 4x4 mm Body [QFN] Also called VQFN **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging Microchip Technology Drawing C04-126-ML Rev D Sheet 1 of 2 # 20-Lead Plastic Quad Flat, No Lead Package (ML) - 4x4 mm Body [QFN] Also called VQFN For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging | Units | | MILLIMETERS | | | |---------------------------|------------------|----------------|----------|------| | Dimension | Dimension Limits | | NOM | MAX | | Number of Terminals | N | | 20 | | | Pitch | е | | 0.50 BSC | | | Overall Height | Α | 0.80 0.90 1.00 | | | | Standoff | A1 | 0.00 0.02 0.05 | | 0.05 | | Terminal Thickness | A3 | 0.20 REF | | | | Overall Length | D | 4.00 BSC | | | | Exposed Pad Length | D2 | 2.60 2.70 2.80 | | 2.80 | | Overall Width | Е | 4.00 BSC | | | | Exposed Pad Width | E2 | 2.60 2.70 2.80 | | 2.80 | | Terminal Width | b | 0.18 | 0.25 | 0.30 | | Terminal Length | L | 0.30 | 0.40 | 0.50 | | Terminal-to-Exposed-Pad K | | 0.20 | - | - | #### Notes: Note: - 1. Pin 1 visual index feature may vary, but must be located within the hatched area. - 2. Package is saw singulated - 3. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only. Microchip Technology Drawing C04-126-ML Rev D Sheet 2 of 2 # 20-Lead Plastic Quad Flat, No Lead Package (ML) - 4x4 mm Body [QFN] Also called VQFN **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging ### RECOMMENDED LAND PATTERN | Units | | MILLIMETERS | | | |---------------------------------|--------|-------------|------|------| | Dimension | Limits | MIN | NOM | MAX | | Contact Pitch | E | 0.50 BSC | | | | Optional Center Pad Width | X2 | | | 2.80 | | Optional Center Pad Length | Y2 | | | 2.80 | | Contact Pad Spacing | C1 | | 4.00 | | | Contact Pad Spacing | C2 | | 4.00 | | | Contact Pad Width (X20) | X1 | | | 0.30 | | Contact Pad Length (X20) | Y1 | | | 0.80 | | Contact Pad to Center Pad (X16) | G1 | 0.20 | | | | Thermal Via Diameter | V | | 0.30 | | | Thermal Via Pitch | EV | | 1.00 | | ### Notes: - Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. - 2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process Microchip Technology Drawing C04-2126-ML Rev D **Appendix A: Revision History** # 44. Appendix A: Revision History | Doc Rev. | Date | Comments | |----------|--------|------------------------------| | В | 4/2022 | Preliminary document release | | A | 8/2021 | Initial document release | ## The Microchip Website Microchip provides online support via our website at www.microchip.com/. This website is used to make files and information easily available to customers. Some of the content available includes: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's quides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip design partner 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 ## **Product Change Notification Service** Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, go to www.microchip.com/pcn and follow the registration instructions. ## **Customer Support** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Embedded Solutions Engineer (ESE) - · Technical Support Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document. Technical support is available through the website at: www.microchip.com/support ## **Product Identification System** To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office. | Device: | PIC16F18015, PIC16F18025, PIC16F18044, PIC16F18045 | | | |---------------------|----------------------------------------------------|-------------------------------|--| | Tape & Reel Option: | Blank | = Tube | | | | Т | = Tape & Reel | | | Temperature Range: | I | = -40°C to +85°C (Industrial) | | | | E | = -40°C to +125°C (Extended) | | | Package: | P | = 8-lead PDIP | | | | SN | = 8-lead SOIC | | | | P | = 14-lead PDIP | | | | SL | = 14-lead SOIC | | | | ST | = 14-lead TSSOP | | | | 7N | = 16-lead VQFN | | | | P | = 20-lead PDIP | | | | SO | = 20-lead SOIC | | | | SS | = 20-lead SSOP | | | | ML | = 20-lead QFN | | #### Examples: - PIC16F18015 T-E/P: Tape and Reel, Extended temperature, 8-lead PDIP - PIC16F18045 T-I/P: Tape and Reel, Industrial temperature, 20-lead PDIP #### Notes: - Tape and Reel identifier only appears in the catalog part number description. This identifier is used for ordering purposes and is not printed on the device package. Check with your Microchip Sales Office for package availability with the Tape and Reel option. - 2. Small form-factor packaging options may be available. Please check www.microchip.com/packaging for small-form factor package availability, or contact your local Sales Office. # **Microchip Devices Code Protection Feature** Note the following details of the code protection feature on Microchip products: - Microchip products meet the specifications contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is secure when used in the intended manner, within operating specifications, and under normal conditions. - Microchip values and aggressively protects its intellectual property rights. Attempts to breach the code protection features of Microchip product is strictly prohibited and may violate the Digital Millennium Copyright Act. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable". Code protection is constantly evolving. Microchip is committed to continuously improving the code protection features of our products. ## **Legal Notice** This publication and the information herein may be used only with Microchip products, including to design, test, and integrate Microchip products with your application. Use of this information in any other manner violates these terms. Information regarding device applications 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. Contact your local Microchip sales office for additional support or, obtain additional support at www.microchip.com/en-us/support/design-help/client-support-services. THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE, OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE. IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL, OR CONSEQUENTIAL LOSS, DAMAGE, COST, OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION. 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 unless otherwise stated. ### **Trademarks** The Microchip name and logo, the Microchip logo, Adaptec, AnyRate, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, CryptoMemory, CryptoRF, dsPIC, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. AgileSwitch, APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, Flashtec, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet- Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, TrueTime, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A. Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, Anyln, AnyOut, Augmented Switching, BlueSky, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, GridTime, IdealBridge, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, Inter-Chip Connectivity, JitterBlocker, Knob-on-Display, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, NVM Express, NVMe, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O, simpleMAP, SimpliPHY, SmartBuffer, SmartHLS, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, TSHARC, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. SQTP is a service mark of Microchip Technology Incorporated in the U.S.A. The Adaptec logo, Frequency on Demand, Silicon Storage Technology, Symmcom, and Trusted Time are registered trademarks of Microchip Technology Inc. in other countries. GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries. All other trademarks mentioned herein are property of their respective companies. © 2021-2022, Microchip Technology Incorporated and its subsidiaries. All Rights Reserved. ISBN: 978-1-6683-0201-9 # **Quality Management System** For information regarding Microchip's Quality Management Systems, please visit www.microchip.com/quality. # **Worldwide Sales and Service** | AMERICAS | ASIA/PACIFIC | ASIA/PACIFIC | EUROPE | |---------------------------|-----------------------|-------------------------|-----------------------| | Corporate Office | Australia - Sydney | India - Bangalore | Austria - Wels | | 2355 West Chandler Blvd. | Tel: 61-2-9868-6733 | Tel: 91-80-3090-4444 | Tel: 43-7242-2244-39 | | Chandler, AZ 85224-6199 | China - Beijing | India - New Delhi | Fax: 43-7242-2244-393 | | Tel: 480-792-7200 | Tel: 86-10-8569-7000 | Tel: 91-11-4160-8631 | Denmark - Copenhagen | | Fax: 480-792-7277 | China - Chengdu | India - Pune | Tel: 45-4485-5910 | | Technical Support: | Tel: 86-28-8665-5511 | Tel: 91-20-4121-0141 | Fax: 45-4485-2829 | | www.microchip.com/support | China - Chongging | Japan - Osaka | Finland - Espoo | | Web Address: | Tel: 86-23-8980-9588 | Tel: 81-6-6152-7160 | Tel: 358-9-4520-820 | | www.microchip.com | China - Dongguan | Japan - Tokyo | France - Paris | | Atlanta | Tel: 86-769-8702-9880 | Tel: 81-3-6880- 3770 | Tel: 33-1-69-53-63-20 | | Duluth, GA | China - Guangzhou | Korea - Daegu | Fax: 33-1-69-30-90-79 | | Tel: 678-957-9614 | Tel: 86-20-8755-8029 | Tel: 82-53-744-4301 | Germany - Garching | | Fax: 678-957-1455 | China - Hangzhou | Korea - Seoul | Tel: 49-8931-9700 | | Austin, TX | Tel: 86-571-8792-8115 | Tel: 82-2-554-7200 | Germany - Haan | | Tel: 512-257-3370 | China - Hong Kong SAR | Malaysia - Kuala Lumpur | Tel: 49-2129-3766400 | | Boston | Tel: 852-2943-5100 | Tel: 60-3-7651-7906 | Germany - Heilbronn | | Westborough, MA | China - Nanjing | Malaysia - Penang | Tel: 49-7131-72400 | | Tel: 774-760-0087 | Tel: 86-25-8473-2460 | Tel: 60-4-227-8870 | Germany - Karlsruhe | | Fax: 774-760-0088 | China - Qingdao | Philippines - Manila | Tel: 49-721-625370 | | Chicago | Tel: 86-532-8502-7355 | Tel: 63-2-634-9065 | Germany - Munich | | Itasca, IL | China - Shanghai | Singapore | Tel: 49-89-627-144-0 | | Tel: 630-285-0071 | Tel: 86-21-3326-8000 | Tel: 65-6334-8870 | Fax: 49-89-627-144-44 | | Fax: 630-285-0075 | China - Shenyang | Taiwan - Hsin Chu | Germany - Rosenheim | | Dallas | Tel: 86-24-2334-2829 | Tel: 886-3-577-8366 | Tel: 49-8031-354-560 | | Addison, TX | China - Shenzhen | Taiwan - Kaohsiung | Israel - Ra'anana | | Tel: 972-818-7423 | Tel: 86-755-8864-2200 | Tel: 886-7-213-7830 | Tel: 972-9-744-7705 | | Fax: 972-818-2924 | China - Suzhou | Taiwan - Taipei | Italy - Milan | | Detroit | Tel: 86-186-6233-1526 | Tel: 886-2-2508-8600 | Tel: 39-0331-742611 | | Novi, MI | China - Wuhan | Thailand - Bangkok | Fax: 39-0331-466781 | | Tel: 248-848-4000 | Tel: 86-27-5980-5300 | Tel: 66-2-694-1351 | Italy - Padova | | Houston, TX | China - Xian | Vietnam - Ho Chi Minh | Tel: 39-049-7625286 | | Tel: 281-894-5983 | Tel: 86-29-8833-7252 | Tel: 84-28-5448-2100 | Netherlands - Drunen | | Indianapolis | China - Xiamen | | Tel: 31-416-690399 | | Noblesville, IN | Tel: 86-592-2388138 | | Fax: 31-416-690340 | | Tel: 317-773-8323 | China - Zhuhai | | Norway - Trondheim | | Fax: 317-773-5453 | Tel: 86-756-3210040 | | Tel: 47-72884388 | | Tel: 317-536-2380 | | | Poland - Warsaw | | Los Angeles | | | Tel: 48-22-3325737 | | Mission Viejo, CA | | | Romania - Bucharest | | Tel: 949-462-9523 | | | Tel: 40-21-407-87-50 | | Fax: 949-462-9608 | | | Spain - Madrid | | Tel: 951-273-7800 | | | Tel: 34-91-708-08-90 | | Raleigh, NC | | | Fax: 34-91-708-08-91 | | Tel: 919-844-7510 | | | Sweden - Gothenberg | | New York, NY | | | Tel: 46-31-704-60-40 | | Tel: 631-435-6000 | | | Sweden - Stockholm | | San Jose, CA | | | Tel: 46-8-5090-4654 | | Tel: 408-735-9110 | | | UK - Wokingham | | Tel: 408-436-4270 | | | Tel: 44-118-921-5800 | | Canada - Toronto | | | Fax: 44-118-921-5820 | | Tel: 905-695-1980 | | | | | Fax: 905-695-2078 | | | |