

# PIC12F635/PIC16F636/639 Data Sheet

8/14-Pin, Flash-Based 8-Bit CMOS Microcontrollers with nanoWatt Technology

\*8-bit, 8-pin Devices Protected by Microchip's Low Pin Count Patent: U. S. Patent No. 5,847,450. Additional U.S. and foreign patents and applications may be issued or pending.

© 2007 Microchip Technology Inc.

#### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information c ontained in t his p ublication regarding d evice applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES N O R EPRESENTATIONS OR WARRANTIES OF AN Y KIN D W HETHER EXPRESS OR IMPLIED, WR ITTEN O R O RAL, ST ATUTORY OR OTHERWISE, RE LATED T O THE I NFORMATION, INCLUDING B UT NOT L IMITED T O ITS C ONDITION, QUALITY, PE RFORMANCE, M ERCHANTABILITY OR FITNESS FOR PU RPOSE. Microchip dis claims al I lia bility arising f rom t his i nformation and its use. U se o f 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, im plicitly or ot herwise, under an y M icrochip intellectual property rights.

### QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002

#### Trademarks

The Microchip name and logo, the Microchip logo, Accuron, dsPIC, KEELOQ, KEELOQ logo, microID, MPLAB, PIC, PICmicro, PICSTART, PRO MATE, PowerSmart, rfPIC, and SmartShunt are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

AmpLab, FilterLab, Linear Active Thermistor, Migratable Memory, MXDEV, MXLAB, PS logo, SEEVAL, SmartSensor and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, ECAN, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, PICkit, PICDEM, PICDEM.net, PICLAB, PICtail, PowerCal, PowerInfo, PowerMate, PowerTool, REAL ICE, rfLAB, rfPICDEM, Select Mode, Smart Serial, SmartTel, Total Endurance, UNI/O, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is aservice mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2007, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.



Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona, Gresham, Oregon and Mountain View, California. The Company's quality system processes and procedures are for its PIC<sup>®</sup> MCUs and dsPIC<sup>®</sup> DSCs, KEELOQ<sup>®</sup> code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

# MICROCHIP PIC12F635/PIC16F636/639

### 8/14-Pin Flash-Based, 8-Bit CMOS Microcontrollers With nanoWatt Technology

#### High-Performance RISC CPU:

- Only 35 instructions to learn:
  - All single-cycle instructions except branches
- Operating speed:
  - DC 20 MHz oscillator/clock input
  - DC 200 ns instruction cycle
- · Interrupt capability
- 8-level deep hardware stack
- Direct, Indirect and Relative Addressing modes

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

- Precision Internal Oscillator:
  - Factory calibrated to ±1%, typical
  - Software selectable frequency range of 8 MHz to 125 kHz
  - Software tunable
  - Two-Speed Start-up mode
  - Crystal fail detect for critical applications
  - Clock mode switching during operation for
  - power savings
- Clock mode switching for low-power operation
- Power-Saving Sleep mode
- Wide operating voltage range (2.0V-5.5V)
- Industrial and Extended Temperature range
- Power-on Reset (POR)
- Wake-up Reset (WUR)
- Independent weak pull-up/pull-down resistors
- Programmable Low-Voltage Detect (PLVD)
- Power-up Timer (PWRT) and Oscillator Start-up Timer (OST)
- Brown-out Reset (BOR) with software control option
- Enhanced Low-Current Watchdog Timer (WDT) with on-chip oscillator (software selectable nominal 268 seconds with full prescaler) with software enable
- Multiplexed Master Clear with pull-up/input pin
- Programmable code protection (program and data independent)
- High-Endurance Flash/EEPROM cell:
  - 100,000 write Flash endurance
  - 1,000,000 write EEPROM endurance
  - Flash/Data EEPROM Retention: > 40 years

#### Low-Power Features:

- Standby Current:
- 1 nA @ 2.0V, typical
- Operating Current:
  - -8 .5 μA @ 32 kHz, 2.0V, typical
  - -1 00  $\mu A$  @ 1 MHz, 2.0V, typical
- Watchdog Timer Current:
  - -1 μA @ 2.0V, typical

#### **Peripheral Features:**

- 6/12 I/O pins with individual direction control:
  - High-current source/sink for direct LED drive
  - Interrupt-on-change pin
  - Individually programmable weak pull-ups/ pull-downs
  - Ultra Low-Power Wake-up
- Analog Comparator module with:
  - Up to two analog comparators
  - Programmable On-chip Voltage Reference (CVREF) module (% of VDD)
  - Comparator inputs and outputs externally accessible
- Timer0: 8-bit timer/counter with 8-bit programmable prescaler
- Enhanced Timer1:
  - 16-bit timer/counter with prescaler
  - External Timer1 Gate (count enable)
  - Option to use OSC1 and OSC2 in LP mode as Timer1 oscillator if INTOSC mode selected
- •K EELOQ<sup>®</sup> compatible hardware Cryptographic module
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) via two pins

#### Low-Frequency Analog Front-End Features (PIC16F69 only):

- Three input pins for 125 kHz LF input signals
- High input detection sensitivity (3 mVPP, typical)
- Demodulated data, Carrier clock or RSSI output selection
- Input carrier frequency: 125 kHz, typical
- Input modulation frequency: 4 kHz, maximum
- 8 internal Configuration registers
- Bidirectional transponder communication (LF talk back)
- Programmable antenna tuning capacitance (up to 63 pF, 1 pF/step)
- Low standby current: 5  $\mu$ A (with 3 channels enabled), typical
- Low operating current: 15 μA (with 3 channels enabled), typical
- Serial Peripheral Interface (SPI) with internal MCU and external devices
- Supports Battery Back-up mode and batteryless
   operation with external circuits

|           | Program Memory | Data N       | lemory         |     | •           | Low Frequency       |  |
|-----------|----------------|--------------|----------------|-----|-------------|---------------------|--|
| Device    | Flash (words)  | SRAM (bytes) | EEPROM (bytes) | I/O | Comparators | Analog<br>Front-End |  |
| PIC12F635 | 1024           | 64           | 128            | 6   | 1           | Ν                   |  |
| PIC16F636 | 2048           | 128          | 256            | 12  | 2           | N                   |  |
| PIC16F639 | 2048           | 128          | 256            | 12  | 2           | Y                   |  |

Note 1: Any references to PORTA, RAn, TRISA and TRISAn refer to GPIO, GPn, TRISIO and TRISIOn, respectively.

2: VDDT is the supply voltage of the Analog Front-End section (PIC16F639 only). VDDT is treated as VDD in this document unless otherwise stated.

**3:** VSST is the ground reference voltage of the Analog Front-End section (PIC16F639 only). VSST is treated as VSS in this document unless otherwise stated.

#### 8-Pin Diagrams (PDIP, SOIC, DFN, DFN-S)



#### TABLE 1: 8-PIN SUMMARY (PDIP, SOIC, DFN, DFN-S)

| I/O                | Pin | Comparators | Timer | Interrupts | Pull-ups | Basic         |
|--------------------|-----|-------------|-------|------------|----------|---------------|
| GP0                | 7   | C1IN+       | _     | IOC        | Y        | ICSPDAT/ULPWU |
| GP1                | 6   | C1IN-       | —     | IOC        | Y        | ICSPCLK       |
| GP2                | 5   | C1OUT       | TOCKI | INT/IOC    | Y        | —             |
| GP3 <sup>(1)</sup> | 4   | _           | _     | IOC        | Y(2)     | MCLR/VPP      |
| GP4                | 3   |             | T1G   | IOC        | Y        | OSC2/CLKOUT   |
| GP5                | 2   |             | T1CKI | IOC        | Y        | OSC1/CLKIN    |
| _                  | 1   | _           | _     | _          | _        | Vdd           |
| —                  | 8   |             |       |            | _        | Vss           |

Note 1: Input only.

2: Only when pin is configured for external MCLR.

#### 14-Pin Diagram (PDIP, SOIC, TSSOP)



#### TABLE 2: 14-PIN SUMMARY (PDIP, SOIC, TSSOP)

| I/O                | Pin | Comparators | Timer | Interrupts | Pull-ups         | Basic         |
|--------------------|-----|-------------|-------|------------|------------------|---------------|
| RA0                | 13  | C1IN+       |       | IOC        | Y                | ICSPDAT/ULPWU |
| RA1                | 12  | C1IN-       | —     | IOC        | Y                | VREF/ICSPCLK  |
| RA2                | 11  | C1OUT       | TOCKI | INT/IOC    | Y                | —             |
| RA3 <sup>(1)</sup> | 4   | —           | _     | IOC        | Y <sup>(2)</sup> | MCLR/Vpp      |
| RA4                | 3   | —           | T1G   | IOC        | Y                | OSC2/CLKOUT   |
| RA5                | 2   | —           | T1CKI | IOC        | Y                | OSC1/CLKIN    |
| RC0                | 10  | C2IN+       | —     | —          | —                | —             |
| RC1                | 9   | C2IN-       | —     | —          | —                | —             |
| RC2                | 8   | —           | —     | —          | —                | —             |
| RC3                | 7   | —           | —     | —          | —                | —             |
| RC4                | 6   | C2OUT       | —     | —          | —                | —             |
| RC5                | 5   | —           | —     | —          | —                | —             |
|                    | 1   | _           | _     | _          | _                | Vdd           |
| _                  | 14  |             |       | _          |                  | Vss           |

Note 1: Input only.

2: Only when pin is configured for external MCLR.

#### **16-Pin Diagram**



#### TABLE 3: 16-PIN SUMMARY

| I/O                | Pin | Comparators | Timer | Interrupts | Pull-ups         | Basic         |
|--------------------|-----|-------------|-------|------------|------------------|---------------|
| RA0                | 12  | C1IN+       |       | IOC        | Y                | ICSPDAT/ULPWU |
| RA1                | 11  | C1IN-       | —     | IOC        | Y                | VREF/ICSPCLK  |
| RA2                | 10  | C1OUT       | TOCKI | INT/IOC    | Y                | —             |
| RA3 <sup>(1)</sup> | 3—  |             |       | IOC        | Y <sup>(2)</sup> | MCLR/VPP      |
| RA4                | 2   | —           | T1G   | IOC        | Y                | OSC2/CLKOUT   |
| RA5                | 1   |             | T1CKI | IOC        | Y                | OSC1/CLKIN    |
| RC0                | 9   | C2IN+       | —     | —          | —                | —             |
| RC1                | 8   | C2IN-       | —     | —          | —                | —             |
| RC2                | 7   |             |       | —          | —                | —             |
| RC3                | 6   | —           | —     | —          | —                | —             |
| RC4                | 5   | C2OUT       |       | —          | —                | —             |
| RC5                | 4   |             |       | —          | —                | —             |
| —                  | 16  |             |       | —          | —                | Vdd           |
|                    | 13  | —           | —     | _          | —                | Vss           |
| _                  | 14  | _           | _     | _          | _                | NC            |
|                    | 15  |             |       |            |                  | NC            |

Note 1: Input only.

2: Only when pin is configured for external MCLR.

#### 20-Pin Diagram



| TABLE 4: 20-PIN SUMMARY |
|-------------------------|
|-------------------------|

| I/O                | Pin | Analog Front-End | Comparators | Timer | Interrupts | Pull-ups | Basic           |
|--------------------|-----|------------------|-------------|-------|------------|----------|-----------------|
| RA0                | 19  |                  | C1IN+       |       | IOC        | Y        | ICSPDAT/ULPWU   |
| RA1                | 18  | —                | C1IN-       | _     | IOC        | Y        | VREF/ICSPCLK    |
| RA2                | 17  | —                | C1OUT       | T0CKI | INT/IOC    | Y        | —               |
| RA3 <sup>(1)</sup> | 4   | _                | _           | _     | IOC        | Y(2)     | MCLR/Vpp        |
| RA4                | 3   | —                | —           | T1G   | IOC        | Y        | OSC2/CLKOUT     |
| RA5                | 2   |                  | —           | T1CKI | IOC        | Y        | OSC1/CLKIN      |
| RC0                | 16  | —                | C2IN+       | —     | _          | -        | —               |
| RC1                | 15  | —                | C2IN-       | —     | —          | —        | CS              |
| RC2                | 14  | ALERT            | —           | _     | —          | _        | SCLK            |
| RC3                | 7   | LFDATA/RSSI      | _           |       | _          |          | CCLK/SDIO       |
| RC4                | 6   |                  | C2OUT       |       |            |          | —               |
| RC5                | 5   |                  | —           |       | —          |          | —               |
|                    | 8   | —                | —           | —     | —          | -        | Vddt(3)         |
| —                  | 13  |                  | —           |       | —          |          | Vsst <b>(4)</b> |
|                    | 11  | LCX              | —           |       | —          |          | —               |
| —                  | 10  | LCY              | _           |       | _          |          | —               |
|                    | 9   | LCZ              | —           | _     | _          | _        | —               |
| —                  | 12  | LCCOM            |             | _     | _          | _        |                 |
|                    | 1   | _                | _           | _     | _          | _        | Vdd             |
|                    | 20  |                  |             | _     | _          | _        | Vss             |

Note 1: Input only.

2: Only when pin is configured for external MCLR.

**3:** VDDT is the supply voltage of the Analog Front-End section (PIC16F639 only). VDDT is treated as VDD in this document unless otherwise stated.

4: VSST is the ground reference voltage of the Analog Front-End section (PIC16F639 only). VSST is treated as VSS in this document unless otherwise stated.

#### **Table of Contents**

| 1.0   | Device Overview                                                | 9    |  |  |  |  |  |
|-------|----------------------------------------------------------------|------|--|--|--|--|--|
| 2.0   | Device Overview                                                | . 17 |  |  |  |  |  |
| 3.0   | Clock Sources                                                  | . 35 |  |  |  |  |  |
| 4.0   | I/O Ports                                                      | . 47 |  |  |  |  |  |
| 5.0   | Timer0 Module                                                  | . 61 |  |  |  |  |  |
| 6.0   | Timer1 Module with Gate Control                                | . 64 |  |  |  |  |  |
| 7.0   | Comparator Module                                              | . 71 |  |  |  |  |  |
| 8.0   | Programmable Low-Voltage Detect (PLVD) Module                  | . 87 |  |  |  |  |  |
| 9.0   | Data EEPROM Memory                                             | . 91 |  |  |  |  |  |
| 10.0  | KEELOQ <sup>®</sup> Compatible Cryptographic Module            | . 95 |  |  |  |  |  |
| 11.0  | Analog Front-End (AFE) Functional Description (PIC16F639 Only) | . 97 |  |  |  |  |  |
| 12.0  | Special Features of the CPU                                    | 129  |  |  |  |  |  |
| 13.0  | Instruction Set Summary                                        | 149  |  |  |  |  |  |
| 14.0  | Development Support                                            |      |  |  |  |  |  |
| 15.0  | Electrical Specifications                                      |      |  |  |  |  |  |
| 16.0  | DC and AC Characteristics Graphs and Tables                    | 191  |  |  |  |  |  |
| 17.0  | Packaging Information                                          | 211  |  |  |  |  |  |
|       |                                                                | 223  |  |  |  |  |  |
| Syste | ms Information and Upgrade Hot Line                            | 223  |  |  |  |  |  |
|       | er Response                                                    |      |  |  |  |  |  |
| Appe  | ndix A: Data Sheet Revision History                            | 225  |  |  |  |  |  |
|       | roduct Identification System 23                                |      |  |  |  |  |  |
| World | lwide Sales and Service                                        | 232  |  |  |  |  |  |

#### TO OUR VALUED CUSTOMERS

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

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

#### Most Current Data Sheet

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

http://www.microchip.com

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

#### Errata

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

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

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

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

#### **Customer Notification System**

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

NOTES:

#### 1.0 DEVICE OVERVIEW

This document contains device specific information for the PIC12F635/PIC16F636/639 devices.

Block Diagrams and pinout descriptions of the devices are as follows:

- PIC12F635 (Figure 1-1, Table 1-1)
- PIC16F636 (Figure 1-2, Table 1-2)
- PIC16F639 (Figure 1-3, Table 1-3)











#### **PIC12F635 PINOUT DESCRIPTIONS TABLE 1-1:**

| Name                    | Function | Input<br>Type | Output<br>Type | Description                                                                                                                                             |
|-------------------------|----------|---------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| GP0/C1IN+/ICSPDAT/ULPWU | GP0      | TTL           |                | General purpose I/O. Individually controlled<br>interrupt-on-change. Individually enabled pull-up/pull-down.<br>Selectable Ultra Low-Power Wake-up pin. |
|                         | C1IN+    | AN            | _              | Comparator 1 input – positive.                                                                                                                          |
|                         | ICSPDAT  | TTL           | CMOS           | Serial programming data I/O.                                                                                                                            |
|                         | ULPWU    | AN            | —              | Ultra Low-Power Wake-up input.                                                                                                                          |
| GP1/C1IN-/ICSPCLK       | GP1      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | C1IN-    | AN            | _              | Comparator 1 input – negative.                                                                                                                          |
|                         | ICSPCLK  | ST            | _              | Serial programming clock.                                                                                                                               |
| GP2/T0CKI/INT/C1OUT     | GP2      | ST            | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | T0CKI    | ST            | _              | External clock for Timer0.                                                                                                                              |
|                         | INT      | ST            | _              | External interrupt.                                                                                                                                     |
|                         | C1OUT    | _             | CMOS           | Comparator 1 output.                                                                                                                                    |
| GP3/MCLR/Vpp            | GP3      | TTL           | _              | General purpose input. Individually controlled interrupt-on-change.                                                                                     |
|                         | MCLR     | ST            | _              | Master Clear Reset. Pull-up enabled when configured as MCLF                                                                                             |
|                         | Vpp      | ΗV            | _              | Programming voltage.                                                                                                                                    |
| GP4/T1G/OSC2/CLKOUT     | GP4      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | T1G      | ST            | _              | Timer1 gate.                                                                                                                                            |
|                         | OSC2     | _             | XTAL           | XTAL connection.                                                                                                                                        |
|                         | CLKOUT   | _             | CMOS           | TOSC/4 reference clock.                                                                                                                                 |
| GP5/T1CKI/OSC1/CLKIN    | GP5      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | T1CKI    | ST            | _              | Timer1 clock.                                                                                                                                           |
|                         | OSC1     | XTAL          | _              | XTAL connection.                                                                                                                                        |
|                         | CLKIN    | ST            | _              | TOSC reference clock.                                                                                                                                   |
| Vdd                     | Vdd      | D             | _              | Power supply for microcontroller.                                                                                                                       |
|                         | Vss      | D             |                | Ground reference for microcontroller.                                                                                                                   |

HV = High Voltage TTL = TTL compatible input

XTAL = Crystal

| Name                    | Function | Input<br>Type | Output<br>Type | Description                                                                                                                                             |
|-------------------------|----------|---------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| RA0/C1IN+/ICSPDAT/ULPWU | RA0      | TTL           | _              | General purpose I/O. Individually controlled<br>interrupt-on-change. Individually enabled pull-up/pull-down.<br>Selectable Ultra Low-Power Wake-up pin. |
|                         | C1IN+    | AN            | —              | Comparator 1 input – positive.                                                                                                                          |
|                         | ICSPDAT  | TTL           | CMOS           | Serial programming data I/O.                                                                                                                            |
|                         | ULPWU    | AN            | —              | Ultra Low-Power Wake-up input.                                                                                                                          |
| RA1/C1IN-/VREF/ICSPCLK  | RA1      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | C1IN-    | AN            | _              | Comparator 1 input – negative.                                                                                                                          |
|                         | VREF     | AN            | —              | External voltage reference                                                                                                                              |
|                         | ICSPCLK  | ST            | _              | Serial programming clock.                                                                                                                               |
| RA2/T0CKI/INT/C1OUT     | RA2      | ST            | CMOS           | General purpose I/O. Individually controlled interrupt-on-change. Individually enabled pull-up/pull-down.                                               |
|                         | T0CKI    | ST            | _              | External clock for Timer0.                                                                                                                              |
|                         | INT      | ST            | _              | External interrupt.                                                                                                                                     |
|                         | C1OUT    | _             | CMOS           | Comparator 1 output.                                                                                                                                    |
| RA3/MCLR/Vpp            | RA3      | TTL           | —              | General purpose input. Individually controlled interrupt-on-change                                                                                      |
|                         | MCLR     | ST            | _              | Master Clear Reset. Pull-up enabled when configured as MCLR.                                                                                            |
|                         | Vpp      | ΗV            | _              | Programming voltage.                                                                                                                                    |
| RA4/T1G/OSC2/CLKOUT     | RA4      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up/pull-down.                                            |
|                         | T1G      | ST            | _              | Timer1 gate.                                                                                                                                            |
|                         | OSC2     | _             | XTAL           | XTAL connection.                                                                                                                                        |
|                         | CLKOUT   |               | CMOS           | TOSC/4 reference clock.                                                                                                                                 |
| RA5/T1CKI/OSC1/CLKIN    | RA5      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up/pull-down.                                            |
|                         | T1CKI    | ST            | —              | Timer1 clock.                                                                                                                                           |
|                         | OSC1     | XTAL          | —              | XTAL connection.                                                                                                                                        |
|                         | CLKIN    | ST            | —              | TOSC reference clock.                                                                                                                                   |
| RC0/C2IN+               | RC0      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
|                         | C2IN+    | AN            | —              | Comparator 1 input – positive.                                                                                                                          |
| RC1/C2IN-               | RC1      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
|                         | C2IN-    | AN            | —              | Comparator 1 input – negative.                                                                                                                          |
| RC2                     | RC2      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
| RC3                     | RC3      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
| RC4/C2OUT               | RC4      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
|                         | C2OUT    |               | CMOS           | Comparator 2 output.                                                                                                                                    |
| RC5                     | RC5      | TTL           | CMOS           | General purpose I/O.                                                                                                                                    |
| Vdd                     | Vdd      | D             |                | Power supply for microcontroller.                                                                                                                       |
| Vss                     | Vss      | D             |                | Ground reference for microcontroller.                                                                                                                   |

#### TABLE 1-2: PIC16F636 PINOUT DESCRIPTIONS

HV = High Voltage TTL = TTL compatible input ST = Schmitt Trigg XTAL = Crystal

#### TABLE 1-3: PIC16F639 PINOUT DESCRIPTIONS

| Name                                                                 | Function | Input<br>Type   | Output<br>Type | Description                                                                                                                                            |
|----------------------------------------------------------------------|----------|-----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| LCCOM                                                                | LCCOM    | AN              | —              | Common reference for analog inputs.                                                                                                                    |
| LCX                                                                  | LCX      | AN              | _              | 125 kHz analog X channel input.                                                                                                                        |
| LCY                                                                  | LCY      | AN              | _              | 125 kHz analog Y channel input.                                                                                                                        |
| LCZ                                                                  | LCZ      | AN              | _              | 125 kHz analog Z channel input.                                                                                                                        |
| RA0/C1IN+/ICSPDAT/ULPWU                                              | RA0      | TTL             | _              | General purpose I/O. Individually controlled interrupt-on-change<br>Individually enabled pull-up/pull-down.<br>Selectable Ultra Low-Power Wake-up pin. |
|                                                                      | C1IN+    | AN              | _              | Comparator1 input – positive.                                                                                                                          |
|                                                                      | ICSPDAT  | TTL             | CMOS           | Serial Programming Data IO.                                                                                                                            |
|                                                                      | ULPWU    | AN              | _              | Ultra Low-Power Wake-up input.                                                                                                                         |
| RA1/C1IN-/VREF/ICSPCLK                                               | RA1      | TTL             | CMOS           | General purpose I/O. Individually controlled interrupt-on-change Individually enabled pull-up/pull-down.                                               |
|                                                                      | C1IN-    | AN              | —              | Comparator1 input – negative.                                                                                                                          |
|                                                                      | VREF     | AN              | _              | External voltage reference                                                                                                                             |
|                                                                      | ICSPCLK  | ST              | _              | Serial Programming Clock.                                                                                                                              |
| RA2/T0CKI/INT/C1OUT                                                  | RA2      | ST              | CMOS           | General purpose I/O. Individually controlled interrupt-on-change<br>Individually enabled pull-up/pull-down.                                            |
|                                                                      | TOCKI    | ST              | —              | External clock for Timer0.                                                                                                                             |
|                                                                      | INT      | ST              | —              | External Interrupt.                                                                                                                                    |
|                                                                      | C1OUT    | _               | CMOS           | Comparator1 output.                                                                                                                                    |
| RA3/MCLR/Vpp                                                         | RA3      | TTL             | _              | General purpose input. Individually controlled interrupt-on-change.                                                                                    |
|                                                                      | MCLR     | ST              | _              | Master Clear Reset. Pull-up enabled when configured as MCLF                                                                                            |
|                                                                      | Vpp      | ΗV              | _              | Programming voltage.                                                                                                                                   |
| RA4/T1G/OSC2/CLKOUT                                                  | RA4      | TTL             | CMOS           | General purpose I/O. Individually controlled interrupt-on-change<br>Individually enabled pull-up/pull-down.                                            |
|                                                                      | T1G      | ST              | -              | Timer1 gate.                                                                                                                                           |
|                                                                      | OSC2     |                 | XTAL           | XTAL connection.                                                                                                                                       |
|                                                                      | CLKOUT   | _               | CMOS           | Tosc reference clock.                                                                                                                                  |
| RA5/T1CKI/OSC1/CLKIN                                                 | RA5      | TTL             | CMOS           | General purpose I/O. Individually controlled interrupt-on-change<br>Individually enabled pull-up/pull-down.                                            |
|                                                                      | T1CKI    | ST              | _              | Timer1 clock.                                                                                                                                          |
|                                                                      | OSC1     | XTAL            | —              | XTAL connection.                                                                                                                                       |
|                                                                      | CLKIN    | ST              | _              | Tosc/4 reference clock.                                                                                                                                |
| RC0/C2IN+                                                            | RC0      | TTL             | CMOS           | General purpose I/O.                                                                                                                                   |
|                                                                      | C2IN+    | AN              | —              | Comparator1 input – positive.                                                                                                                          |
| RC1/C2IN-/CS                                                         | RC1      | TTL             | CMOS           | General purpose I/O.                                                                                                                                   |
|                                                                      | C2IN-    | AN              |                | Comparator1 input – negative.                                                                                                                          |
|                                                                      | CS       | TTL             | —              | Chip select input for SPI communication with internal pull-up resistor.                                                                                |
| RC2/SCLK/ALERT                                                       | RC2      | TTL             | CMOS           | General purpose I/O.                                                                                                                                   |
|                                                                      | SCLK     | TTL             |                | Digital clock input for SPI communication.                                                                                                             |
|                                                                      | ALERT    |                 | OD             | Output with internal pull-up resistor for AFE error signal.                                                                                            |
| Legend: AN = Analog input<br>HV = High Voltage<br>TTL = TTL compatil |          | CM<br>ST<br>XT/ | = Sch          | OS compatible input or output D = Direct<br>mitt Trigger input with CMOS levels OD = Open Drair<br>stal                                                |

| Name                                       | Function | Input<br>Type | Output<br>Type | Description                                                                                                        |
|--------------------------------------------|----------|---------------|----------------|--------------------------------------------------------------------------------------------------------------------|
| RC3/LFDATA/RSSI/CCLK/SDO                   | RC3      | TTL           | CMOS           | General purpose I/O.                                                                                               |
|                                            | LFDATA   |               | CMOS           | Digital output representation of analog input signal to LC pins.                                                   |
|                                            | RSSI     |               | Current        | Received signal strength indicator. Analog current that is<br>proportional to input amplitude.                     |
|                                            | CCLK     | _             | _              | Carrier clock output.                                                                                              |
|                                            | SDIO     | TTL           | CMOS           | Input/Output for SPI communication.                                                                                |
| RC4/C2OUT                                  | RC4      | TTL           | CMOS           | General purpose I/O.                                                                                               |
|                                            | C2OUT    |               | CMOS           | Comparator2 output.                                                                                                |
| RC5                                        | RC5      | TTL           | CMOS           | General purpose I/O.                                                                                               |
| VDDT                                       | Vddt     | D             | —              | Power supply for Analog Front-End. In this document, VDDT is treated the same as VDD, unless otherwise stated.     |
| Vsst                                       | VSST     | D             | —              | Ground reference for Analog Front-End. In this document, VSST is treated the same as VSS, unless otherwise stated. |
| Vdd                                        | Vdd      | D             |                | Power supply for microcontroller.                                                                                  |
| Vss                                        | Vss      | D             | —              | Ground reference for microcontroller.                                                                              |
| Legend: AN = Analog input or output CMOS = |          |               |                | OS compatible input or output D = Direct                                                                           |

#### PIC16F639 PINOUT DESCRIPTIONS (CONTINUED) **TABLE 1-3:**

HV = High Voltage TTL = TTL compatible input

ST = Schmitt Trigger input with CMOS levels

OD = Open Drain

XTAL = Crystal NOTES:

#### 2.0 MEMORY ORGANIZATION

#### 2.1 Program Memory Organization

The PIC12F635/PIC16F636/639 devices have a 13-bit program counter c apable of ad dressing an 8K x 14 program memory s pace. O nly the fi rst 1K x 14 (0000h-03FFh, for th e PIC 12F635) a nd 2K x 14 (0000h-07FFh, for t he PI C16F636/639) is phy sically implemented. Ac cessing a I ocation above t hese boundaries w ill ca use a w raparound w ithin th e first 2K x 14 space. The Reset vector is at 0000h and the interrupt vector is at 0004h (see Figure 2-1).

#### 2.2 Data Memory Organization

The data memory (see Figure 2-2) is partitioned in to two banks, w hich co ntain the General Purpose Registers (GPR) and the Special Function Registers (SFR). The Special Function Registers are located in the first 32 locations of each bank. Register locations 20h-7Fh in Bank 0 and A0h-BFh in Bank 1 are GPRs, implemented as static R AM for the PIC16F636/639. For the PIC12F635, register locations 40h through 7Fh are G PRs implemented as static R AM. R egister locations F 0h-FFh i n B ank 1 p oint t o addresses 70h-7Fh in Bank 0. All other R AM is unimplemented and returns '0' when read. RP0 of the STATUS register is the bank select bit.

| <u>RP1</u> | <u>RP0</u> |
|------------|------------|
|------------|------------|

| 0 | 0 | $\rightarrow$ | Bank 0 is selected |
|---|---|---------------|--------------------|
| 0 | 1 | $\rightarrow$ | Bank 1 is selected |
| 1 | 0 | $\rightarrow$ | Bank 2 is selected |
| 1 | 1 | $\rightarrow$ | Bank 3 is selected |

#### FIGURE 2-1: PROGRAM MEMORY MAP AND STACK OF THE PIC12F635



#### FIGURE 2-2: PROGRAM MEMORY MAP AND STACK OF THE PIC16F636/639



#### 2.2.1 GENERAL PURPOSE REGISTER

The re gister file is org anized as 64 x 8 for the PIC12F635 and 128 x 8 for the PIC16F636/639. Each register is a ccessed, either directly or indirectly, through the File Select Register, FSR (see Section 2.4 "Indirect Addressing, INDF and FSR Registers").

#### 2.2.2 SPECIAL FUNCTION REGISTERS

The Special Function R egisters (SFRs) are r egisters used by the CPU and peripheral functions for controlling the desired operation of the device (see Figure 2-1). These registers are static RAM.

The special registers can be classified into two sets: core and peripheral. The Special Function Registers associated with the "core" are described in this section. Those related to the operation of the peripheral features are described in the section of that peripheral feature.

|                               | File    |                               | File    |                       | File    |          | File   |
|-------------------------------|---------|-------------------------------|---------|-----------------------|---------|----------|--------|
|                               | Address |                               | Address |                       | Address |          | Addres |
| Indirect addr. <sup>(1)</sup> | 00h     | Indirect addr. <sup>(1)</sup> | 80h     | Accesses              | 100h    | Accesses | 180h   |
| TMR0                          | 01h     | OPTION_REG                    | 81h     | 00h-0Bh               | 101h    | 80h-8Bh  | 181h   |
| PCL                           | 02h     | PCL                           | 82h     |                       | 102h    |          | 182h   |
| STATUS                        | 03h     | STATUS                        | 83h     |                       | 103h    |          | 183h   |
| FSR                           | 04h     | FSR                           | 84h     |                       | 104h    |          | 184h   |
| GPIO                          | 05h     | TRISIO                        | 85h     |                       | 105h    |          | 185h   |
|                               | 06h     |                               | 86h     |                       | 106h    |          | 186h   |
|                               | 07h     |                               | 87h     |                       | 107h    |          | 187h   |
|                               | 08h     |                               | 88h     |                       | 108h    |          | 188h   |
|                               | 09h     |                               | 89h     |                       | 109h    |          | 189h   |
| PCLATH                        | 0Ah     | PCLATH                        | 8Ah     |                       | 10Ah    |          | 18Ah   |
| INTCON                        | 0Bh     | INTCON                        | 8Bh     |                       | 10Bh    |          | 18Bh   |
| PIR1                          | 0Ch     | PIE1                          | 8Ch     |                       | 10Ch    |          | 18Ch   |
|                               | 0Dh     |                               | 8Dh     |                       | 10Dh    |          | 18Dh   |
| TMR1L                         | 0Eh     | PCON                          | 8Eh     |                       | 10Eh    |          | 18Eh   |
| TMR1H                         | 0Fh     | OSCCON                        | 8Fh     |                       | 10Fh    |          | 18Fh   |
| T1CON                         | 10h     | OSCTUNE                       | 90h     | CRCON                 | 110h    |          | 190h   |
|                               | 11h     |                               | 91h     | CRDAT0 <sup>(2)</sup> | 111h    |          | 191h   |
|                               | 12h     |                               | 92h     | CRDAT1 <sup>(2)</sup> | 112h    |          | 192h   |
|                               | 13h     |                               | 93h     | CRDAT2 <sup>(2)</sup> | 113h    |          | 193h   |
|                               | 14h     | LVDCON                        | 94h     | CRDAT3 <sup>(2)</sup> | 114h    |          | 194h   |
|                               | 15h     | WPUDA                         | 95h     |                       | 115h    |          | 195h   |
|                               | 16h     | IOCA                          | 96h     |                       | 116h    |          | 196h   |
|                               | 17h     | WDA                           | 97h     |                       | 117h    |          | 197h   |
| WDTCON                        | 18h     |                               | 98h     |                       | 118h    |          | 198h   |
| CMCON0                        | 19h     | VRCON                         | 99h     |                       | 119h    |          | 199h   |
| CMCON1                        | 1Ah     | EEDAT                         | 9Ah     |                       | 11Ah    |          | 19Ah   |
|                               | 1Bh     | EEADR                         | 9Bh     |                       | 11Bh    |          | 19Bh   |
|                               | 1Ch     | EECON1                        | 9Ch     |                       | 11Ch    |          | 19Ch   |
|                               | 1Dh     | EECON2 <sup>(1)</sup>         | 9Dh     |                       | 11Dh    |          | 19Dh   |
|                               | 1Eh     |                               | 9Eh     |                       | 11Eh    |          | 19Eh   |
|                               | 1Fh     |                               | 9Fh     |                       | 11Fh    |          | 19Fh   |
|                               | 20h     |                               | A0h     |                       | 120h    |          | 1A0h   |
|                               | 3Fh     |                               |         |                       |         |          |        |
| General                       | 40h     |                               |         |                       |         |          |        |
| Purpose                       |         |                               |         |                       |         |          |        |
| Register                      |         |                               | EFh     |                       | 16Fh    |          | 1EFh   |
| 64 Bytes                      |         | Accesses                      | F0h     | Accesses              | 170h    | Accesses | 1F0h   |
|                               | 7Fh     | 70h-7Fh                       | FFh     | 70h-7Fh               | 17Fh    | Bank 0   | 1FFh   |
| Bank 0B                       |         | ank 1B                        |         | ank 2B                |         | ank 3    |        |

#### FIGURE 2-3: PIC12F635 SPECIAL FUNCTION REGISTERS

2: CRDAT<3:0> registers are KEELOQ<sup>®</sup> hardware peripheral related registers and require the execution of the "KEELOQ<sup>®</sup> Encoder License Agreement" regarding implementation of the module and access to related registers. The "KEELOQ<sup>®</sup> Encoder License Agreement" may be accessed through the Microchip web site located at <u>www.microchip.com/KEELOQ</u> or by contacting your local Microchip Sales Representative.

#### FIGURE 2-4: PIC16F636/639 SPECIAL FUNCTION REGISTERS

|                               | File    |                       | File    |                       | File    |          | File   |
|-------------------------------|---------|-----------------------|---------|-----------------------|---------|----------|--------|
|                               | Address |                       | Address |                       | Address |          | Addres |
| Indirect addr. <sup>(1)</sup> | 00h     | Indirect addr. (1)    | 80h     | Accesses              | 100h    | Accesses | 180h   |
| TMR0                          | 01h     | OPTION_REG            | 81h     | 00h-0Bh               | 101h    | 80h-8Bh  | 181h   |
| PCL                           | 02h     | PCL                   | 82h     |                       | 102h    |          | 182h   |
| STATUS                        | 03h     | STATUS                | 83h     |                       | 103h    |          | 183h   |
| FSR                           | 04h     | FSR                   | 84h     |                       | 104h    |          | 184h   |
| PORTA                         | 05h     | TRISA                 | 85h     |                       | 105h    |          | 185h   |
|                               | 06h     |                       | 86h     |                       | 106h    |          | 186h   |
| PORTC                         | 07h     | TRISC                 | 87h     |                       | 107h    |          | 187h   |
|                               | 08h     |                       | 88h     |                       | 108h    |          | 188h   |
|                               | 09h     |                       | 89h     |                       | 109h    |          | 189h   |
| PCLATH                        | 0Ah     | PCLATH                | 8Ah     |                       | 10Ah    |          | 18Ah   |
| INTCON                        | 0Bh     | INTCON                | 8Bh     |                       | 10Bh    |          | 18Bh   |
| PIR1                          | 0Ch     | PIE1                  | 8Ch     |                       | 10Ch    |          | 18Ch   |
|                               | 0Dh     |                       | 8Dh     |                       | 10Dh    |          | 18Dh   |
| TMR1L                         | 0Eh     | PCON                  | 8Eh     |                       | 10Eh    |          | 18Eh   |
| TMR1H                         | 0Fh     | OSCCON                | 8Fh     |                       | 10Fh    |          | 18Fh   |
| T1CON                         | 10h     | OSCTUNE               | 90h     | CRCON                 | 110h    |          | 190h   |
|                               | 11h     |                       | 91h     | CRDAT0 <sup>(2)</sup> | 111h    |          | 191h   |
|                               | 12h     |                       | 92h     | CRDAT1 <sup>(2)</sup> | 112h    |          | 192h   |
|                               | 13h     |                       | 93h     | CRDAT2 <sup>(2)</sup> | 113h    |          | 193h   |
|                               | 14h     | LVDCON                | 94h     | CRDAT3 <sup>(2)</sup> | 114h    |          | 194h   |
|                               | 15h     | WPUDA                 | 95h     |                       | 115h    |          | 195h   |
|                               | 16h     | IOCA                  | 96h     |                       | 116h    |          | 196h   |
|                               | 17h     | WDA                   | 97h     |                       | 117h    |          | 197h   |
| WDTCON                        | 18h     |                       | 98h     |                       | 118h    |          | 198h   |
| CMCON0                        | 19h     | VRCON                 | 99h     |                       | 119h    |          | 199h   |
| CMCON1                        | 1Ah     | EEDAT                 | 9Ah     |                       | 11Ah    |          | 19Ah   |
|                               | 1Bh     | EEADR                 | 9Bh     |                       | 11Bh    |          | 19Bh   |
|                               | 1Ch     | EECON1                | 9Ch     |                       | 11Ch    |          | 19Ch   |
|                               | 1Dh     | EECON2 <sup>(1)</sup> | 9Dh     |                       | 11Dh    |          | 19Dh   |
|                               | 1Eh     |                       | 9Eh     |                       | 11Eh    |          | 19Eh   |
|                               | 1Fh     |                       | 9Fh     |                       | 11Fh    |          | 19Fh   |
| General                       | 20h     | General               | A0h     |                       | 120h    |          | 1A0h   |
| Purpose                       |         | Purpose               |         |                       |         |          |        |
| Register                      |         | Register              |         |                       |         |          |        |
| 96 Bytes                      |         | 32 Bytes              | BFh     |                       |         |          |        |
|                               |         |                       | C0h     |                       |         |          |        |
|                               |         |                       | EFh     |                       | 16Fh    |          | 1EFh   |
|                               |         | Accesses              | F0h     | Accesses              | 170h    | Accesses | 1F0h   |
|                               | 7Fh     | 70h-7Fh               | FFh     | 70h-7Fh               | 17Fh    | Bank 0   | 1FFh   |
| Bank 0B                       | ]       | ank 1B                | 1       | ank 2B                |         | ank 3    |        |

Unimplemented data memory locations, read as '0'.

**Note 1:** Not a physical register.

2: CRDAT<3:0> registers are KEELOQ hardware peripheral related registers and require the execution of the "KEELOQ<sup>®</sup> Encoder License Agreement" regarding implementation of the module and access to related registers. The "KEELOQ<sup>®</sup> Encoder License Agreement" may be accessed through the Microchip web site located at <u>www.microchip.com/KEELOQ</u> or by contacting your local Microchip Sales Representative.

| Addr   | Name   | Bit 7       | Bit 6                          | Bit 5         | Bit 4          | Bit 3          | Bit 2         | Bit 1     | Bit 0               | Value on<br>POR/BOR/<br>WUR | Page    |
|--------|--------|-------------|--------------------------------|---------------|----------------|----------------|---------------|-----------|---------------------|-----------------------------|---------|
| Bank ( | )      |             |                                |               |                |                |               |           |                     |                             |         |
| 00h    | INDF   |             | this location<br>ical register |               | XXXX XXXX      | 32,137         |               |           |                     |                             |         |
| 01h    | TMR0   | Timer0 Mo   | dule Registe                   | r             |                |                |               |           |                     | xxxx xxxx                   | 61,137  |
| 02h    | PCL    | Program C   | ounter's (PC                   | c) Least Sigr | nificant Byte  |                |               |           |                     | 0000 0000                   | 32,137  |
| 03h    | STATUS | IRP         | RP1                            | RP0           | TO             | PD             | Z             | DC        | С                   | 0001 1xxx                   | 26,137  |
| 04h    | FSR    | Indirect Da | ta Memory A                    | Address Poir  | nter           |                | •             |           |                     | xxxx xxxx                   | 32,137  |
| 05h    | GPIO   | —           | —                              | GP5           | GP4            | GP3            | GP2           | GP1       | GP0                 | xx xx00                     | 47,137  |
| 06h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | —                           | —       |
| 07h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | —                           | —       |
| 08h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | —                           | —       |
| 09h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | —       |
| 0Ah    | PCLATH | _           | _                              | _             | Write Buffer   | for upper 5 b  | its of Progra | m Counter |                     | 0 0000                      | 32,137  |
| 0Bh    | INTCON | GIE P       | EIE                            | TOIE          | INTE           | RAIE           | T0IF          | INTF      | RAIF <sup>(2)</sup> | 0000 000x                   | 28,137  |
| 0Ch    | PIR1   | EEIF        | LVDIF                          | CRIF          | —              | C1IF           | OSFIF         | —         | TMR1IF              | 000- 00-0                   | 30,137  |
| 0Dh    |        | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 0Eh    | TMR1L  | Holding Re  | gister for the                 | e Least Sign  | ificant Byte o | f the 16-bit T | MR1           |           |                     | xxxx xxxx                   | 64,137  |
| 0Fh    | TMR1H  | Holding Re  | gister for the                 | e Most Signi  | ficant Byte of | the 16-bit TM  | /IR1          |           |                     | xxxx xxxx                   | 64,137  |
| 10h    | T1CON  | T1GINV      | TMR1GE                         | T1CKPS1       | T1CKPS0        | T1OSCEN        | T1SYNC        | TMR1CS    | TMR10N              | 0000 0000                   | 68,137  |
| 11h    | _      | Unimpleme   | ented                          |               | 1              |                |               | 1         |                     | _                           | _       |
| 12h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           |         |
| 13h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 14h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 15h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | —                           | —       |
| 16h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 17h    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | —       |
| 18h    | WDTCON | _           |                                | —             | WDTPS3         | WDTPS2         | WDTPS1        | WDTPS0    | SWDTEN              | 0 1000                      | 144,137 |
| 19h    | CMCON0 | —           | COUT                           | —             | CINV           | CIS            | CM2           | CM1       | CM0                 | -0-0 0000                   | 79,137  |
| 1Ah    | CMCON1 |             | _                              |               |                |                |               | T1GSS     | CMSYNC              | 10                          | 82,137  |
| 1Bh    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 1Ch    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 1Dh    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |
| 1Eh    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           |         |
| 1Fh    | _      | Unimpleme   | ented                          |               |                |                |               |           |                     | _                           | _       |

Legend: Note

1:

 – = Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented
 <u>Other (non Power-up)</u> Resets include MCLR Reset and Watchdog Timer Reset during normal operation.
 MCLR and WDT Reset do not affect the previous value data latch. The RAIF bit will be cleared upon Reset but will set again if the mismatch or units. 2: match exists.

| Addr   | Name                 | Bit 7      | Bit 6                         | Bit 5        | Bit 4       | Bit 3       | Bit 2        | Bit 1     | Bit 0               | Value on<br>POR/BOR/<br>WUR | Page      |
|--------|----------------------|------------|-------------------------------|--------------|-------------|-------------|--------------|-----------|---------------------|-----------------------------|-----------|
| Bank ' | 1                    |            |                               |              |             |             |              |           |                     |                             |           |
| 80h    | INDF                 |            | ig this locat<br>sical regist |              | ontents of  | FSR to ad   | dress data   | memory    |                     | XXXX XXXX                   | 32,137    |
| 81h    | OPTION_REG           | RAPU       | INTEDG                        | TOCS         | T0SE        | PSA         | PS2          | PS1       | PS0                 | 1111 1111                   | 63,137    |
| 82h    | PCL                  | Program    | Counter's (                   | PC) Least    | Significant | Byte        |              |           |                     | 0000 0000                   | 32,137    |
| 83h    | STATUS               | IRP        | RP1                           | RP0          | TO          | PD          | Z            | DC        | С                   | 0001 1xxx                   | 26,137    |
| 84h    | FSR                  | Indirect D | ata Memor                     | y Address    | Pointer     |             | •            |           |                     | xxxx xxxx                   | 32,137    |
| 85h    | TRISIO               | _          |                               | TRISI05      | TRISIO4     | TRISIO3     | TRISIO2      | TRISIO1   | TRISIO0             | 11 1111                     | 11 1111   |
| 86h    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | _                           | _         |
| 87h    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | _                           | _         |
| 88h    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | _                           | _         |
| 89h    |                      | Unimplem   | nented                        |              |             |             |              |           |                     | —                           | —         |
| 8Ah    | PCLATH               | _          | _                             | —            | Write Buff  | er for uppe | er 5 bits of | Program C | ounter              | 0 0000                      | 32,137    |
| 8Bh    | INTCON               | GIE        | PEIE                          | TOIE         | INTE        | RAIE        | T0IF         | INTF      | RAIF <sup>(3)</sup> | 0000 000x                   | 28,137    |
| 8Ch    | PIE1                 | EEIE       | LVDIE                         | CRIE         | _           | C1IE        | OSFIE        | —         | TMR1IE              | 000- 00-0                   | 29,137    |
| 8Dh    |                      | Unimplem   | Unimplemented —               |              |             |             |              |           |                     |                             | —         |
| 8Eh    | PCON                 | _          | _                             | ULPWUE       | SBOREN      | WUR         | —            | POR       | BOR                 | 01 q-qq                     | 31,137    |
| 8Fh    | OSCCON               | _          | IRCF2                         | IRCF1        | IRCF0       | OSTS        | HTS          | LTS       | SCS                 | -110 q000                   | 36,137    |
| 90h    | OSCTUNE              | _          |                               | _            | TUN4        | TUN3        | TUN2         | TUN1      | TUN0                | 0 0000                      | 40,137    |
| 91h    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | _                           | —         |
| 92h    |                      | Unimplem   | nented                        |              |             |             |              |           |                     | —                           | —         |
| 93h    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | —                           | —         |
| 94h    | LVDCON               | _          | —                             | IRVST        | LVDEN       | —           | LVDL2        | LVDL1     | LVDL0               | 00 -000                     | 00 -000   |
| 95h    | WPUDA <sup>(2)</sup> | _          | —                             | WPUDA5       | WPUDA4      | —           | WPUDA2       | WPUDA1    | WPUDA0              | 11 -111                     | 11 -111   |
| 96h    | IOCA                 | _          | _                             | IOCA5        | IOCA4       | IOCA3       | IOCA2        | IOCA1     | IOCA0               | 00 0000                     | 00 0000   |
| 97h    | WDA <sup>(2)</sup>   | —          | —                             | WDA5         | WDA4        | —           | WDA2         | WDA1      | WDA0                | 11 -111                     | 11 -111   |
| 9Bh    | _                    | Unimplem   | nented                        |              |             |             |              |           |                     | —                           | —         |
| 99h    | VRCON                | VREN       | _                             | VRR          | —           | VR3         | VR2          | VR1       | VR0                 | 0-0- 0000                   | 0-0- 0000 |
| 9Ah    | EEDAT                | EEDAT7     | EEDAT6                        | EEDAT5       | EEDAT4      | EEDAT3      | EEDAT2       | EEDAT1    | EEDAT0              | 0000 0000                   | 0000 0000 |
| 9Bh    | EEADR                | EEADR7     | EEADR6                        | EEADR5       | EEADR4      | EEADR3      | EEADR2       | EEADR1    | EEADR0              | 0000 0000                   | 0000 0000 |
| 9Ch    | EECON1               | _          | —                             | —            | —           | WRERR       | WREN         | WR        | RD                  | x000                        | q000      |
| 9Dh    | EECON2               | EEPROM     | Control Re                    | egister 2 (n | ot a physic | al register | ·)           |           |                     |                             |           |
| 9Eh    | _                    | Unimplem   | Unimplemented —               |              |             |             |              |           |                     |                             | —         |
| 9Fh    | _                    | Unimplem   | Jnimplemented —               |              |             |             |              |           |                     |                             | —         |

#### TABLE 2-2: PIC12F635 SPECIAL FUNCTION REGISTERS SUMMARY BANK 1

**Legend:** – = Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented

Note 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2: GP3 pull-up is enabled when pin is configured as MCLR in the Configuration Word register.

3: MCLR and WDT Reset do not affect the previous value data latch. The RAIF bit will be cleared upon Reset, but will set again if the mismatch exists.

| Addr   | Name   | Bit 7      | Bit 6                                                                                          | Bit 5       | Bit 4         | Bit 3         | Bit 2        | Bit 1      | Bit 0               | Value on<br>POR/BOR/<br>WUR | Page    |
|--------|--------|------------|------------------------------------------------------------------------------------------------|-------------|---------------|---------------|--------------|------------|---------------------|-----------------------------|---------|
| Bank ( | C      |            |                                                                                                |             |               |               |              |            |                     |                             |         |
| 00h    | INDF   |            | dressing this location uses contents of FSR to address data memory xxxx t a physical register) |             |               |               |              |            |                     |                             |         |
| 01h    | TMR0   | Timer0 M   | odule Regi                                                                                     | ster        |               |               |              |            |                     | xxxx xxxx                   | 61,137  |
| 02h    | PCL    | Program    | Counter's (                                                                                    | PC) Least   | Significant   | Byte          |              |            |                     | 0000 0000                   | 32,137  |
| 03h    | STATUS | IRP        | RP1                                                                                            | RP0         | TO            | PD            | Z            | DC         | С                   | 0001 1xxx                   | 26,137  |
| 04h    | FSR    | Indirect D | ata Memo                                                                                       | y Address   | Pointer       | •             |              | •          |                     | xxxx xxxx                   | 32,137  |
| 05h    | PORTA  | _          | _                                                                                              | RA5         | RA4           | RA3           | RA2          | RA1        | RA0                 | xx xx00                     | 48,137  |
| 06h    | _      | Unimplem   | nented                                                                                         |             |               |               |              | •          |                     |                             | _       |
| 07h    | PORTC  | _          | _                                                                                              | RC5         | RC4           | RC3           | RC2          | RC1        | RC0                 | xx xx00                     | 57,137  |
| 08h    | _      | Unimplem   | nented                                                                                         |             |               |               |              | •          |                     |                             | _       |
| 09h    | _      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | —                           | _       |
| 0Ah    | PCLATH | _          | _                                                                                              |             | Write Buffe   | er for upper  | 5 bits of Pr | ogram Coui | nter                | 0 0000                      | 32,137  |
| 0Bh    | INTCON | GIE PE     | IE                                                                                             | T0IE        | INTE          | RAIE          | T0IF         | INTF       | RAIF <sup>(2)</sup> | 0000 000x                   | 28,137  |
| 0Ch    | PIR1   | EEIF       | LVDIF                                                                                          | CRIF        | C2IF          | C1IF          | OSFIF        | _          | TMR1IF              | 0000 00-0                   | 30,137  |
| 0Dh    | —      | Unimplem   | Unimplemented —                                                                                |             |               |               |              |            |                     |                             | _       |
| 0Eh    | TMR1L  | Holding R  | egister for                                                                                    | the Least S | Significant E | Byte of the 1 | 16-bit TMR1  | 1          |                     | xxxx xxxx                   | 64,137  |
| 0Fh    | TMR1H  | Holding R  | egister for                                                                                    | the Most S  | ignificant B  | yte of the 1  | 6-bit TMR1   |            |                     | xxxx xxxx                   | 64,137  |
| 10h    | T1CON  | T1GINV     | TMR1GE                                                                                         | T1CKPS1     | T1CKPS0       | T1OSCEN       | T1SYNC       | TMR1CS     | TMR1ON              | 0000 0000                   | 68,137  |
| 11h    | _      | Unimplem   | nented                                                                                         |             |               | •             |              | •          |                     | —                           | _       |
| 12h    |        | Unimplem   | nented                                                                                         |             |               |               |              |            |                     |                             | _       |
| 13h    |        | Unimplem   | nented                                                                                         |             |               |               |              |            |                     |                             | _       |
| 14h    | _      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 15h    | _      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 16h    | _      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 17h    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 18h    | WDTCON | _          | _                                                                                              | _           | WDTPS3        | WDTPS2        | WDTPS1       | WDTPS0     | SWDTEN              | 0 1000                      | 144,137 |
| 19h    | CMCON0 | C2OUT      | C1OUT                                                                                          | C2INV       | C1INV         | CIS           | CM2          | CM1        | CM0                 | 0000 0000                   | 79,137  |
| 1Ah    | CMCON1 | —          | _                                                                                              |             |               | —             |              | T1GSS      | C2SYNC              | 10                          | 82,137  |
| 1Bh    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 1Ch    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | _                           | _       |
| 1Dh    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | —                           | _       |
| 1Eh    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | —                           | _       |
| 1Fh    | —      | Unimplem   | nented                                                                                         |             |               |               |              |            |                     | —                           | _       |

**Legend:** -= Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented

**Note** 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2: MCLR and WDT Reset do not affect the previous value data latch. The RAIF bit will be cleared upon Reset but will set again if the mismatch exists.

| Addr | Name                 | Bit 7      | Bit 6                      | Bit 5        | Bit 4       | Bit 3       | Bit 2        | Bit 1     | Bit 0               | Value on<br>POR/BOR/<br>WUR | Page      |
|------|----------------------|------------|----------------------------|--------------|-------------|-------------|--------------|-----------|---------------------|-----------------------------|-----------|
| Bank | 1                    |            |                            |              |             |             |              |           |                     |                             |           |
| 80h  | INDF                 |            | g this loca<br>sical regis |              | ontents of  | FSR to ad   | dress data   | memory    |                     | xxxx xxxx                   | 32,137    |
| 81h  | OPTION_REG           | RAPU       | INTEDG                     | TOCS         | TOSE        | PSA         | PS2          | PS1       | PS0                 | 1111 1111                   | 63,137    |
| 82h  | PCL                  | Program (  | Counter's (                | PC) Least    | Significant | Byte        |              |           |                     | 0000 0000                   | 32,137    |
| 83h  | STATUS               | IRP        | RP1                        | RP0          | TO          | PD          | Z            | DC        | С                   | 0001 1xxx                   | 26,137    |
| 84h  | FSR                  | Indirect D | ata Memor                  | y Address    | Pointer     |             |              |           |                     | xxxx xxxx                   | 32,137    |
| 85h  | TRISA                | —          | _                          | TRISA5       | TRISA4      | TRISA3      | TRISA2       | TRISA1    | TRISA0              | 11 1111                     | 11 1111   |
| 86h  | _                    | Unimplem   | ented                      |              |             | •           |              |           |                     | _                           |           |
| 87h  | TRISC                | —          | _                          | TRISC5       | TRISC4      | TRISC3      | TRISC2       | TRISC1    | TRISC0              | 11 1111                     | 11 1111   |
| 88h  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | _                           |           |
| 89h  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | _                           | _         |
| 8Ah  | PCLATH               | —          | _                          | _            | Write Buff  | er for uppe | er 5 bits of | Program C | ounter              | 0 0000                      | 32,137    |
| 8Bh  | INTCON               | GIE        | PEIE                       | TOIE         | INTE        | RAIE        | T0IF         | INTF      | RAIF <sup>(3)</sup> | 0000 000x                   | 28,137    |
| 8Ch  | PIE1                 | EEIE       | LVDIE                      | CRIE         | C2IE        | C1IE        | OSFIE        | _         | TMR1IE              | 0000 00-0                   | 29,137    |
| 8Dh  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | _                           | _         |
| 8Eh  | PCON                 | _          | _                          | ULPWUE       | SBOREN      | WUR         | _            | POR       | BOR                 | 01 q-qq                     | Ou u-uu   |
| 8Fh  | OSCCON               | —          | IRCF2                      | IRCF1        | IRCF0       | OSTS        | HTS          | LTS       | SCS                 | -110 q000                   | -110 x000 |
| 90h  | OSCTUNE              | _          | _                          | _            | TUN4        | TUN3        | TUN2         | TUN1      | TUN0                | 0 0000                      | u uuuu    |
| 91h  |                      | Unimplem   | ented                      |              |             |             |              |           |                     | —                           | _         |
| 92h  |                      | Unimplem   | ented                      |              |             |             |              |           |                     | —                           | _         |
| 93h  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | _                           | _         |
| 94h  | LVDCON               | —          |                            | IRVST        | LVDEN       | —           | LVDL2        | LVDL1     | LVDL0               | 00 -000                     | 00-000    |
| 95h  | WPUDA <sup>(2)</sup> | —          |                            | WPUDA5       | WPUDA4      | —           | WPUDA2       | WPUDA1    | WPUDA0              | 11 -111                     | 11 -111   |
| 96h  | IOCA                 | —          | _                          | IOCA5        | IOCA4       | IOCA3       | IOCA2        | IOCA1     | IOCA0               | 00 0000                     | 00 0000   |
| 97h  | WDA <sup>(2)</sup>   | —          | _                          | WDA5         | WDA4        | _           | WDA2         | WDA1      | WDA0                | 11 -111                     | 11 -111   |
| 9Bh  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | —                           | _         |
| 99h  | VRCON                | VREN       | _                          | VRR          |             | VR3         | VR2          | VR1       | VR0                 | 0-0- 0000                   | 0-0- 0000 |
| 9Ah  | EEDAT                | EEDAT7     | EEDAT6                     | EEDAT5       | EEDAT4      | EEDAT3      | EEDAT2       | EEDAT1    | EEDAT0              | 0000 0000                   | 0000 0000 |
| 9Bh  | EEADR                | EEADR7     | EEADR6                     | EEADR5       | EEADR4      | EEADR3      | EEADR2       | EEADR1    | EEADR0              | 0000 0000                   | 0000 0000 |
| 9Ch  | EECON1               |            |                            |              |             | WRERR       | WREN         | WR        | RD                  | x000                        | q000      |
| 9Dh  | EECON2               | EEPROM     | Control Re                 | egister 2 (r | ot a physic | cal registe | r)           |           |                     |                             |           |
| 9Eh  | _                    | Unimplem   | Unimplemented —            |              |             |             |              |           |                     |                             | _         |
| 9Fh  | _                    | Unimplem   | ented                      |              |             |             |              |           |                     | —                           | _         |

#### TABLE 2-4: PIC16F636/639 SPECIAL FUNCTION REGISTERS SUMMARY BANK 1

Legend: -= Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented

Note 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2: RA3 pull-up is enabled when pin is configured as MCLR in the Configuration Word register.

3: MCLR and WDT Reset do not affect the previous value data latch. The RAIF bit will be cleared upon Reset but will set again if the mismatch exists.

| Addr   | Name                  | Bit 7         | Bit 6                                             | Bit 5    | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0  | Value on<br>POR/BOR/<br>WUR | Page      |
|--------|-----------------------|---------------|---------------------------------------------------|----------|-------|-------|-------|--------|--------|-----------------------------|-----------|
| Bank 2 |                       |               |                                                   |          |       |       |       |        |        |                             |           |
| 10Ch   | _                     | Unimpleme     | nted                                              |          |       |       |       |        |        | —                           | —         |
| 10Dh   | _                     | Unimpleme     | nted                                              |          |       |       |       |        |        | _                           | —         |
| 10Eh   | _                     | Unimpleme     | Inimplemented — — —                               |          |       |       |       |        |        |                             |           |
| 10Fh   | _                     | Unimplemented |                                                   |          |       |       |       |        |        | _                           | —         |
| 110h   | CRCON                 | GO/DONE       | ENC/DEC                                           | —        | _     | _     | _     | CRREG1 | CRREG0 | 0000                        | 0000      |
| 111h   | CRDAT0 <sup>(2)</sup> | Cryptograp    | hic Data Re                                       | gister 0 |       |       |       |        |        | 0000 0000                   | 0000 0000 |
| 112h   | CRDAT1 <sup>(2)</sup> | Cryptograp    | Cryptographic Data Register 1 0000 0000 0000 0000 |          |       |       |       |        |        |                             |           |
| 113h   | CRDAT2 <sup>(2)</sup> | Cryptograp    | hic Data Re                                       | gister 2 |       |       |       |        |        | 0000 0000                   | 0000 0000 |
| 114h   | CRDAT3 <sup>(2)</sup> | Cryptograp    | Cryptographic Data Register 3 0000 0000 0000 0000 |          |       |       |       |        |        |                             |           |
| 115h   | —                     | Unimpleme     | Unimplemented — —                                 |          |       |       |       |        |        |                             | —         |
| 116h   | —                     | Unimpleme     | nted                                              |          |       |       |       |        |        | —                           | —         |

Legend: -= Unimplemented locations read as '0', u = unchanged, x = unknown, q = value depends on condition, shaded = unimplemented

Note 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2: CRDAT<3:0> registers are KEELOQ<sup>®</sup> hardware peripheral related registers and require the execution of the "KEELOQ Encoder License Agreement" regarding implementation of the module and access to related registers. The "KEELOQ Encoder License Agreement" may be accessed through the Microchip web site located at <u>www.microchip.com/KEELOQ</u> or by contacting your local Microchip Sales Representative.

#### 2.2.2.1 STATUS Register

The STATUS register, shown in Register 2-1, contains:

- the arithmetic status of the ALU
- the Reset status
- the bank select bits for data memory (GPR and SFR)

The STATUS register can be the de stination for an y instruction, I ike any other register. If t he S TATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and 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 the upper three bits and set the Z bit. This leaves the STATUS register as '000u u1uu' (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF in structions are used to alter the STATUS register, be cause the se instructions do n ot affect any Status bits. For other instructions not affecting any Status bits, see Section 13.0 "Instruction Set Summary"

| Note 1: | The C and DC bits operate as a Borrow      |
|---------|--------------------------------------------|
|         | and Digit Borrow out bit, respectively, in |
|         | subtraction.                               |

#### REGISTER 2-1: STATUS: STATUS REGISTER

| R/W-0      | 0 R/W-0                                                                              | R/W-0                                                               | R-1             | R-1              | R/W-x           | R/W-x             | R/W-x            |
|------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------|-----------------|------------------|-----------------|-------------------|------------------|
| IRP        | RP1                                                                                  | RP0                                                                 | TO              | PD               | Z               | DC <sup>(1)</sup> | C <sup>(1)</sup> |
| oit 7      | ·                                                                                    |                                                                     |                 |                  |                 | ·                 | bit (            |
| Legend:    |                                                                                      |                                                                     |                 |                  |                 |                   |                  |
| R = Read   | able bit                                                                             | W = Writable                                                        | bit             | U = Unimple      | mented bit, rea | id as '0'         |                  |
| -n = Value | e at POR                                                                             | '1' = Bit is set                                                    |                 | '0' = Bit is cle |                 | x = Bit is unkr   | nown             |
| bit 7      | IRP: Registe                                                                         | r Bank Select bi                                                    | it (used for in | direct addressi  | na)             |                   |                  |
|            | •                                                                                    | 3 (100h-1FFh)                                                       |                 |                  | "9)             |                   |                  |
| bit 6-5    | <b>RP&lt;1:0&gt;:</b> Re<br>00 = Bank 0<br>01 = Bank 1<br>10 = Bank 2<br>11 = Bank 3 | (80h-FFh)<br>(100h-17Fh)                                            | ect bits (usec  | d for direct add | ressing)        |                   |                  |
| bit 4      |                                                                                      | t bit<br>/er-up, CLRWDT<br>me-out occurre                           |                 | SLEEP instruc    | ction           |                   |                  |
| bit 3      |                                                                                      | own bit<br>/er-up or by the<br>/tion of the SLEI                    |                 |                  |                 |                   |                  |
| bit 2      | <b>Z:</b> Zero bit<br>1 = The resu                                                   | It of an arithmet<br>It of an arithmet                              | ic or logic op  | eration is zero  | ero             |                   |                  |
| bit 1      | <b>DC:</b> Digit Car<br>1 = A carry-o                                                | rry/Borrow bit (<br>out from the 4th                                | ADDWF, ADDLW    | N, SUBLW, SUB    | WF instructions | )(1)              |                  |
| bit 0      | <b>C:</b> Carry/Born<br>1 = A carry-o                                                | row bit <sup>(1)</sup> (ADDW<br>out from the Mos<br>out from the Mo | F, ADDLW, S     | UBLW,SUBWE       | occurred        | 1)                |                  |
| Note 1:    | For Borrow, the po<br>second operand. F<br>bit of the source re                      | For rotate (RRF,                                                    |                 |                  |                 |                   |                  |

#### 2.2.2.2 OPTION Register

The O PTION regi ster is a readable and w ritable register w hich c ontains va rious control bi ts to configure:

- TMR0/WDT prescaler
- External RA2/INT interrupt
- •T MR0
- Weak pull-up/pull-downs on PORTA

Note: To achieve a 1:1 pr escaler assignment for Timer0, assign the prescaler to the WDT by setting the PSA bit of the OPTION register to '1'. Se e Section 5.1.3 "S oftware Programmable Prescaler".

#### REGISTER 2-2: OPTION\_REG: OPTION REGISTER

| R/W-1 | R/W-1  | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 |
|-------|--------|-------|-------|-------|-------|-------|-------|
| RAPU  | INTEDG | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   |
| bit 7 |        |       |       |       |       |       | bit 0 |

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | t, read as '0'     |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

| bit 7   | RAPU: PORTA Pull-up Enable bit                                           |                |                                                    |  |  |  |  |  |
|---------|--------------------------------------------------------------------------|----------------|----------------------------------------------------|--|--|--|--|--|
|         | 1 = PORTA pull-ups<br>0 = PORTA pull-ups                                 |                | by individual PORT latch value                     |  |  |  |  |  |
| bit 6   | INTEDG: Interrupt E                                                      | dge Select bi  | it                                                 |  |  |  |  |  |
|         | <ul><li>1 = Interrupt on risin</li><li>0 = Interrupt on fallin</li></ul> |                | -                                                  |  |  |  |  |  |
| bit 5   | TOCS: Timer0 Clock                                                       | Source Sele    | ct bit                                             |  |  |  |  |  |
|         | 1 = Transition on RA                                                     | A2/T0CKI pin   |                                                    |  |  |  |  |  |
|         | 0 = Internal instructi                                                   | on cycle clocł | k (Fosc/4)                                         |  |  |  |  |  |
| bit 4   | T0SE: Timer0 Source Edge Select bit                                      |                |                                                    |  |  |  |  |  |
|         |                                                                          |                | sition on RA2/T0CKI pin<br>sition on RA2/T0CKI pin |  |  |  |  |  |
| bit 3   | PSA: Prescaler Ass                                                       | ignment bit    |                                                    |  |  |  |  |  |
|         | 1 = Prescaler is ass<br>0 = Prescaler is ass                             | •              |                                                    |  |  |  |  |  |
| bit 2-0 | PS<2:0>: Prescaler Rate Select bits                                      |                |                                                    |  |  |  |  |  |
|         | Bit Value                                                                | Timer0 Rate    | WDT Rate                                           |  |  |  |  |  |
|         | 000                                                                      | 1:2            | 1:1                                                |  |  |  |  |  |
|         | 001                                                                      | 1:4            | 1:2                                                |  |  |  |  |  |
|         | 010                                                                      | 1:8            | 1:4                                                |  |  |  |  |  |
|         | 011                                                                      | 1:16           | 1:8                                                |  |  |  |  |  |
|         | 100                                                                      | 1:32           | 1:16                                               |  |  |  |  |  |
|         | 101                                                                      | 1:64           | 1:32                                               |  |  |  |  |  |
|         | 110                                                                      | 1:128          | 1:64                                               |  |  |  |  |  |

1:256 1:128

111

#### 2.2.2.3 INTCON Register

The IN TCON reg ister is a rea dable and w ritable register which contains the various enable and flag bits for TM R0 reg ister o verflow, PO RTA ch ange an d external RA2/INT pin interrupts.

Note: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Interrupt Enable bit, GIE of the INTCON register. User software should ensure the appropriate in terrupt fl ag bits a re cl ear prior to enabling an interrupt.

#### REGISTER 2-3: INTCON: INTERRUPT CONTROL REGISTER

| Legend: |       |       |       |                       | control hit road    | aa '0' |       |
|---------|-------|-------|-------|-----------------------|---------------------|--------|-------|
| bit 7   |       |       |       |                       |                     |        | bit 0 |
| GIE     | PEIE  | TOIE  | INTE  | RAIE <sup>(1,3)</sup> | T0IF <sup>(2)</sup> | INTF   | RAIF  |
| R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0                 | R/W-0               | R/W-0  | R/W-x |

| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
|-------------------|------------------|-----------------------------|--------------------|
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7      | GIE: Global Interrupt Enable bit<br>1 = Enables all unmasked interrupts<br>0 = Disables all interrupts                                                                                                                                                 |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6      | <b>PEIE:</b> Peripheral Interrupt Enable bit<br>1 = Enables all unmasked peripheral interrupts<br>0 = Disables all peripheral interrupts                                                                                                               |
| bit 5      | <b>TOIE:</b> Timer0 Overflow Interrupt Enable bit<br>1 = Enables the Timer0 interrupt<br>0 = Disables the Timer0 interrupt                                                                                                                             |
| bit 4      | INTE: RA2/INT External Interrupt Enable bit<br>1 = Enables the RA2/INT external interrupt<br>0 = Disables the RA2/INT external interrupt                                                                                                               |
| bit 3      | <b>RAIE:</b> PORTA Change Interrupt Enable bit <sup>(1,3)</sup><br>1 = Enables the PORTA change interrupt<br>0 = Disables the PORTA change interrupt                                                                                                   |
| bit 2      | <b>T0IF:</b> Timer0 Overflow Interrupt Flag bit <sup>(2)</sup><br>1 = TMR0 register has overflowed (must be cleared in software)<br>0 = TMR0 register did not overflow                                                                                 |
| bit 1      | INTF: RA2/INT External Interrupt Flag bit<br>1 = The RA2/INT external interrupt occurred (must be cleared in software)<br>0 = The RA2/INT external interrupt did not occur                                                                             |
| bit 0      | <ul> <li>RAIF: PORTA Change Interrupt Flag bit</li> <li>1 = W hen at least one of the PORTA general purpose I/O pins changed state (must be cleared in software)</li> <li>0 = None of the PORTA general purpose I/O pins have changed state</li> </ul> |
| Note 1: IO | CA register must also be enabled.                                                                                                                                                                                                                      |

- 2: T0IF bit is set when Timer0 rolls over. Timer0 is unchanged on Reset and should be initialized before clearing T0IF bit.
- 3: Includes ULPWU interrupt.

#### 2.2.2.4 PIE1 Register

The PIE1 register contains the interrupt enable bits, as shown in Register 2-4.

**Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt.

#### REGISTER 2-4: PIE1: PERIPHERAL INTERRUPT ENABLE REGISTER 1

| R/W-0 | R/W-0 | R/W-0 | R/W-0               | R/W-0 | R/W-0 | U-0 | R/W-0  |
|-------|-------|-------|---------------------|-------|-------|-----|--------|
| EEIE  | LVDIE | CRIE  | C2IE <sup>(1)</sup> | C1IE  | OSFIE | —   | TMR1IE |
| bit 7 |       |       |                     |       |       |     | bit 0  |

| Legend:           |                                                                                                                                                                             |                        |                    |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|
| R = Readable bit  | W = Writable bit                                                                                                                                                            | U = Unimplemented bit, | read as '0'        |
| -n = Value at POR | '1' = Bit is set                                                                                                                                                            | '0' = Bit is cleared   | x = Bit is unknown |
| 1 :               | ELE: EE Write Complete Interrupt Ena<br>Enables the EE write complete inter                                                                                                 | errupt                 |                    |
| bit 6 <b>LV</b>   | <ul> <li>Disables the EE write complete into</li> <li>DIE: Low-Voltage Detect Interrupt E</li> <li>Enables the LVD interrupt</li> <li>Disables the LVD interrupt</li> </ul> | •                      |                    |
| bit 5 <b>CF</b>   | <b>SIE</b> : Cryptographic Interrupt Enable I<br>= Enables the cryptographic interrup<br>= Disables the cryptographic interrup                                              | t                      |                    |
| bit 4 C2          | <b>IE</b> : Comparator 2 Interrupt Enable b<br>= Enables the Comparator 2 interrup<br>= Disables the Comparator 2 interrup                                                  | <sub>it</sub> (1)<br>t |                    |
| 1:                | IE: Comparator 1 Interrupt Enable b<br>= Enables the Comparator 1 interrup<br>= Disables the Comparator 1 interrup                                                          | t                      |                    |
| 1 :               | <b>FIE</b> : Oscillator Fail Interrupt Enable<br>= Enables the oscillator fail interrupt<br>= Disables the oscillator fail interrupt                                        |                        |                    |
| bit 1 Ur          | implemented: Read as '0'                                                                                                                                                    |                        |                    |
| 1:                | IR1IE: Timer1 Overflow Interrupt En<br>= Enables the Timer1 overflow interr<br>= Disables the Timer1 overflow interr                                                        | upt                    |                    |

Note 1: PIC16F636/639 only.

#### 2.2.2.5 PIR1 Register

The PIR1 register contains the interrupt flag bits, as shown in Register 2-5.

Note: Interrupt flag bits are set when an interrupt condition occurs, regardless of the state of its corresponding enable bit or the Global Interrupt E nable bit, G IE of the INTCON register. User software should ensure the appropriate i nterrupt flag bits are c lear prior to enabling an interrupt.

#### REGISTER 2-5: PIR1: PERIPHERAL INTERRUPT REQUEST REGISTER 1

| R/W-0 | R/W-0 | R/W-0 | R/W-0               | R/W-0 | R/W-0 | U-0 | R/W-0  |
|-------|-------|-------|---------------------|-------|-------|-----|--------|
| EEIF  | LVDIF | CRIF  | C2IF <sup>(1)</sup> | C1IF  | OSFIF |     | TMR1IF |
| bit 7 |       |       |                     |       |       |     | bit 0  |

| Legend:                           |                  |                                    |                    |  |
|-----------------------------------|------------------|------------------------------------|--------------------|--|
| R = Readable bit W = Writable bit |                  | U = Unimplemented bit, read as '0' |                    |  |
| -n = Value at POR                 | '1' = Bit is set | '0' = Bit is cleared               | x = Bit is unknown |  |

| bit 7 | EEIF: EE Write Complete Interrupt Flag bit                                                                                                                                                |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul> <li>1 = The write operation completed (must be cleared in software)</li> <li>0 = The write operation has not completed or has not been started</li> </ul>                            |
| bit 6 | LVDIF: Low-Voltage Detect Interrupt Flag bit                                                                                                                                              |
|       | <ul> <li>1 = The supply voltage has crossed selected LVD voltage (must be cleared in software)</li> <li>0 = The supply voltage has not crossed selected LVD voltage</li> </ul>            |
| bit 5 | CRIF: Cryptographic Interrupt Flag bit                                                                                                                                                    |
|       | <ul> <li>1 = The Cryptographic module has completed an operation (must be cleared in software)</li> <li>0 = The Cryptographic module has not completed an operation or is Idle</li> </ul> |
| bit 4 | C2IF: Comparator 2 Interrupt Flag bit <sup>(1)</sup>                                                                                                                                      |
|       | <ul> <li>1 = Comparator output (C2OUT bit) has changed (must be cleared in software)</li> <li>0 = Comparator output (C2OUT bit) has not changed</li> </ul>                                |
| bit 3 | C1IF: Comparator 1 Interrupt Flag bit                                                                                                                                                     |
|       | <ul> <li>1 = Comparator output (C1OUT bit) has changed (must be cleared in software)</li> <li>0 = Comparator output (C1OUT bit) has not changed</li> </ul>                                |
| bit 2 | OSFIF: Oscillator Fail Interrupt Flag bit                                                                                                                                                 |
|       | <ul> <li>1 = System oscillator failed, clock input has changed INTOSC (must be cleared in software)</li> <li>0 = System clock operating</li> </ul>                                        |
| bit 1 | Unimplemented: Read as '0'                                                                                                                                                                |
| bit 0 | TMR1IF: Timer1 Overflow Interrupt Flag bit                                                                                                                                                |
|       | <ul><li>1 = Timer1 rolled over (must be cleared in software)</li><li>0 = Timer1 has not rolled over</li></ul>                                                                             |
|       |                                                                                                                                                                                           |

Note 1: PIC16F636/639 only.

#### 2.2.2.6 PCON Register

The Power Control (PCON) register (see Table 12-3) contains flag bits to differentiate between a:

- Power-on Reset (POR)
- Wake-up Reset (WUR)
- Brown-out Reset (BOR)
- Watchdog Timer Reset (WDT)
- External MCLR Reset

The PCON register also controls the Ultra Low-Power Wake-up and software enable of the BOR.

The PCON register bits are shown in Register 2-6.

#### **REGISTER 2-6: PCON: POWER CONTROL REGISTER**

| U-0   | U-0 | R/W-0  | R/W-1                 | R/W-x | U-0 | R/W-0 | R/W-x |
|-------|-----|--------|-----------------------|-------|-----|-------|-------|
| _     | —   | ULPWUE | SBOREN <sup>(1)</sup> | WUR   |     | POR   | BOR   |
| bit 7 |     |        |                       |       |     |       | bit 0 |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7-6 | Unimplemented: Read as '0'                                                              |
|---------|-----------------------------------------------------------------------------------------|
| bit 5   | ULPWUE: Ultra Low-Power Wake-up Enable bit                                              |
|         | 1 = Ultra low-power wake-up enabled                                                     |
|         | 0 = Ultra low-power wake-up disabled                                                    |
| bit 4   | SBOREN: Software BOR Enable bit <sup>(1)</sup>                                          |
|         | 1 = BOR enabled                                                                         |
|         | 0 = BOR disabled                                                                        |
| bit 3   | WUR: Wake-up Reset Status bit                                                           |
|         | 1 = No Wake-up Reset occurred                                                           |
|         | 0 = A Wake-up Reset occurred (must be set in software after a Power-on Reset occurs)    |
| bit 2   | Unimplemented: Read as '0'                                                              |
| bit 1   | POR: Power-on Reset Status bit                                                          |
|         | 1 = No Power-on Reset occurred                                                          |
|         | 0 = A Power-on Reset occurred (must be set in software after a Power-on Reset occurs)   |
| bit 0   | BOR: Brown-out Reset Status bit                                                         |
|         | 1 = No Brown-out Reset occurred                                                         |
|         | 0 = A Brown-out Reset occurred (must be set in software after a Brown-out Reset occurs) |
|         |                                                                                         |

**Note 1:** BOREN<1:0> = 01 in the Configuration Word register for this bit to control the  $\overline{BOR}$ .

#### 2.3 PCL and PCLATH

The Program Counter (PC) is 13 bits wide. The low byte comes from the PCL register, which is a readable and writable register. The hig h byte (PC<12:8>) is not directly readable or writable and comes from PCLATH. On any Reset, the PC is cleared. Figure 2-5 shows the two s ituations for t he loading of the PC. The upper example in Figure 2-5 shows how the PC is loaded on a write to P CL (PCLATH<4:0>  $\rightarrow$  P CH). The lower example in Figure 2-5 shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 2-5: LOADING OF PC IN DIFFERENT SITUATIONS



#### 2.3.1 MODIFYING PCL

Executing any instruction with the PCL register as the destination s imultaneously c auses the Pro gram Counter PC<12:8> bits (PCH) to be replaced by the contents of the PCLATH register. This allows the entire contents of the er ogram c ounter to be c hanged b y writing the desired upper 5 bits to the PCLATH register. When the lower 8 bits are written to the PCL register, all 13 bits of the program counter will change to the values contained in the PCLATH register.

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). Care should be exercised when jum ping into a loo k-up t able or program branch table (computed GOTO) by mo difying the PCL register. Assuming that PCLATH is set to the table start address, if the table length is greater than 255 instructions or if the lower 8 bits of the memory address rolls over from 0xFF to 0x00 in the middle of the table, then PCLATH must be incremented for each address ro llover tha t o ccurs be tween th e t able beginning and the target location within the table.

For more information refer to Application Note AN556, *"Implementing a Table Read"* (DS00556).

#### 2.3.2 STACK

The PI C12F635/PIC16F636/639 fa mily ha s a n 8-level x 13-bit wide hardware stack (see Figure 2-1). The stack space is not part of either program or data space and the Stack Pointer is not readable or writable. The PC is PUSHed on to the st ack w hen a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE in struction ex ecution. P CLATH is no t affected by a PUSH or POP operation.

The stack operates as a drcular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

| Note 1: | There are no Status bits to indicate stack |  |  |  |
|---------|--------------------------------------------|--|--|--|
|         | overflow or stack underflow conditions.    |  |  |  |

2: There are no ins tructions/mnemonics called PUSH or PO P. These are actions that occur from the execution of the CALL, RETURN, RETLW and RETFIE instructions or the vectoring to an interrupt address.

### 2.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is po ssible b y us ing th e IN DF register. Any in struction usi ng th e IN DF reg ister actually accesses data p ointed to by the File Se lect Register (FS R). R eading INDF i tself i ndirectly wi II produce 00h. W riting to the IN DF re gister indirectly results in a no operation (although Status bits may be affected). An e ffective 9-bit add ress is obt ained b y concatenating the 8-bit FSR and the IR P bit of th e STATUS register, as shown in Figure 2-6.

A simple program to clear RAM location 20h-2Fh using indirect addressing is shown in Example 2-1.

| EXAMPLE 2-1: |                                                 | INDIRECT ADDRESSING                         |                                                                                                        |  |
|--------------|-------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------|--|
| NEXT         | MOVLW<br>MOVWF<br>CLRF<br>INCF<br>BTFSS<br>GOTO | 0x20<br>FSR<br>INDF<br>FSR<br>FSR,4<br>NEXT | ;initialize pointer<br>;to RAM<br>;clear INDF register<br>;INC POINTER<br>;all done?<br>;no clear next |  |
| CONTINUE     |                                                 |                                             | ;yes continue                                                                                          |  |



NOTES:

# 3.0 OSCILLATOR MODULE (WITH FAIL-SAFE CLOCK MONITOR)

### 3.1 Overview

The O scillator m odule has a wide va riety of cl ock sources and selection features that allow it to be used in a wide range of applications while maximizing performance and minimizing power consumption. Figure 3-1 illustrates a block diagram of the Oscillator module.

Clock sources can be con figured from external oscillators, quartz crystal resonators, ceramic resonators and R esistor-Capacitor (R C) c ircuits. In a ddition, the system clock source can be configured from one of two internal oscillators, with a choice of speeds selectable via software. Additional clock features include:

- Selectable system clock source between external or internal via software.
- Two-Speed Start-up mode, which minimizes latency between external oscillator start-up and code execution.
- Fail-Safe Clock Monitor (FSCM) designed to detect a failure of the external clock source (LP, XT, HS, EC or RC modes) and switch automatically to the internal oscillator.

The Oscillator module can be configured in one of eight clock modes.

- 1. EC External clock with I/O on OSC2/CLKOUT.
- 2. LP 32 kHz Low-Power Crystal mode.
- 3. XT Med ium Gai n C rystal or Ceramic Resonator Oscillator mode.
- 4. HS High Gain Crystal or Ceramic Resonator mode.
- 5. RC Ex ternal R esistor-Capacitor (R C) with Fosc/4 output on OSC2/CLKOUT.
- 6. RCIO Ext ernal R esistor-Capacitor (R C) with I/O on OSC2/CLKOUT.
- 7. INTOSC Internal oscillator with Fosc/4 output on OSC2 and I/O on OSC1/CLKIN.
- INTOSCIO In ternal oscillator with I/O on OSC1/CLKIN and OSC2/CLKOUT.

Clock Source modes are configured by the FOSC<2:0> bits in the Configuration Word register (CONFIG). The internal c lock c an b e generated f rom t wo internal oscillators. T he H FINTOSC is a ca librated high-frequency os cillator. The LF INTOSC is an uncalibrated low-frequency oscillator.



#### FIGURE 3-1: PIC<sup>®</sup> MCU CLOCK SOURCE BLOCK DIAGRAM

# 3.2 Oscillator Control

The Oscillator Control (OSCCON) register (Figure 3-1) controls the system c lock a nd frequency s election options. The OSCCON register contains the fol lowing bits:

- Frequency selection bits (IRCF)
- Frequency Status bits (HTS, LTS)
- System clock control bits (OSTS, SCS)

#### REGISTER 3-1: OSCCON: OSCILLATOR CONTROL REGISTER

| U-0   | R/W-1 | R/W-1 | R/W-0 | R-1                 | R-0 | R-0 | R/W-0 |
|-------|-------|-------|-------|---------------------|-----|-----|-------|
| —     | IRCF2 | IRCF1 | IRCF0 | OSTS <sup>(1)</sup> | HTS | LTS | SCS   |
| bit 7 |       |       |       |                     |     |     | bit 0 |

| Legend:           |                  |                            |                    |
|-------------------|------------------|----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, rea | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared       | x = Bit is unknown |

| bit 7   | Unimplemented: Read as '0'                                                                                                                                                                                |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6-4 | IRCF<2:0>: Internal Oscillator Frequency Select bits                                                                                                                                                      |
|         | 111 = \$ Hz                                                                                                                                                                                               |
|         | $110 = 4 \text{ MHz (default)}$ $101 = \mathbb{MHz}$                                                                                                                                                      |
|         | $101 = \mathbb{D}Hz$ $100 = \mathbb{M}Hz$                                                                                                                                                                 |
|         | 011 = 050  kHz                                                                                                                                                                                            |
|         | 010 = 520 kHz                                                                                                                                                                                             |
|         | 001 <b>= 2Б kHz</b>                                                                                                                                                                                       |
|         | 000 = 31  kHz (LFINTOSC)                                                                                                                                                                                  |
| bit 3   | <b>OSTS:</b> Oscillator Start-up Time-out Status bit <sup>(1)</sup>                                                                                                                                       |
|         | <ul> <li>1 = Device is running from the external clock defined by FOSC&lt;2:0&gt; of the Configuration Word</li> <li>0 = Device is running from the internal oscillator (HFINTOSC or LFINTOSC)</li> </ul> |
| bit 2   | HTS: HFINTOSC Status bit (High Frequency – 8 MHz to 125 kHz)                                                                                                                                              |
|         | 1 = HFINTOSC is stable                                                                                                                                                                                    |
|         | 0 = HFINTOSC is not stable                                                                                                                                                                                |
| bit 1   | LTS: LFINTOSC Stable bit (Low Frequency – 31 kHz)                                                                                                                                                         |
|         | 1 = LFINTOSC is stable                                                                                                                                                                                    |
|         | 0 = LFINTOSC is not stable                                                                                                                                                                                |
| bit 0   | SCS: System Clock Select bit                                                                                                                                                                              |
|         | 1 = Internal oscillator is used for system clock                                                                                                                                                          |
|         | 0 = Clock source defined by FOSC<2:0> of the Configuration Word                                                                                                                                           |
|         | Dit reacts to foll with Two Opened Chart we and LD VT or LIC calented on the Openillator model or Tail Opfe                                                                                               |

Note 1: Bit resets to '0' with Two-Speed Start-up and LP, XT or HS selected as the Oscillator mode or Fail-Safe mode is enabled.

# 3.3 Clock Source Modes

Clock Source modes can be classified as external or internal.

- External Clock modes rely on external circuitry for the clock source. Examples are: Oscillator modules (EC mode), quartz crystal resonators or ceramic resonators (LP, XT and HS modes) and Resistor-Capacitor (RC) mode circuits.
- Internal clock sources are contained internally within the Oscillator module. The Oscillator module has two internal oscillators: the 8 MHz High-Frequency Internal Oscillator (HFINTOSC) and the 31 kHz Low-Frequency Internal Oscillator (LFINTOSC).

The system clock can be selected between external or internal clock sources via the System Clock S elect (SCS) bit of the OSCCON register. See **Section 3.6** "**Clock Switching**" for additional information.

# 3.4 External Clock Modes

# 3.4.1 OSCILLATOR START-UP TIMER (OST)

If the Oscillator module is configured for LP, XT or HS modes, the O scillator S tart-up T imer (OST) co unts 1024 oscillations from OSC1. This occurs following a Power-on Reset (POR) and when the Power-up Timer (PWRT) has expired (if configured), or a wake-up from Sleep. During this time, the program counter does not increment and program execution is suspended. The OST ensures that the oscillator circuit, using a quartz crystal resonator or ceramic resonator, has started and is providing a stable system clock to the Oscillator module. When s witching b etween c lock so urces, a delay is required to al low the new clock to stabilize. These oscillator delays are shown in Table 3-1.

In order to minimize latency between external oscillator start-up an d cod e ex ecution, th e T wo-Speed Clock Start-up mo de can be selected (se e **Section 3.7 "Two-Speed Clock Start-up Mode"**).

| Switch From       | Switch To            | Frequency                  | Oscillator Delay                 |  |
|-------------------|----------------------|----------------------------|----------------------------------|--|
| Sleep/POR         | LFINTOSC<br>HFINTOSC | 31 kHz<br>125 kHz to 8 MHz | Oscillator Warm-Up Delay (Twarm) |  |
| Sleep/POR         | EC, RC               | DC – 20 MHz                | 2 instruction cycles             |  |
| LFINTOSC (31 kHz) | EC, RC               | DC – 20 MHz                | 1 cycle of each                  |  |
| Sleep/POR         | LP, XT, HS           | 32 kHz to 20 MHz           | 1024 Clock Cycles (OST)          |  |
| LFINTOSC (31 kHz) | HFINTOSC             | 125 kHz to 8 MHz           | 1 μs (approx.)                   |  |

#### TABLE 3-1: OSCILLATOR DELAY EXAMPLES

# 3.4.2 EC MODE

The Ext ernal C lock (EC) mode al lows an ext ernally generated logic level as the system clock source. When operating in this mode, a n ex ternal clock sour ce is connected to the OSC1 input and the OSC2 is available for ge neral p urpose I /O. Fig ure 3-2 s hows th e pi n connections for EC mode.

The Oscillator Start-up Timer (OST) is disabled when EC mode is selected. Therefore, there is no delay in operation after a Pow er-on Reset (POR) or w ake-up from Sleep. B ecause the PIC<sup>®</sup> MCU de sign is fully static, stopping the external clock input will have the effect of halting the device while leaving all data intact. Upon res tarting the external clock, the dev ice w ill resume operation as if no time had elapsed.

#### FIGURE 3-2:

#### EXTERNAL CLOCK (EC) MODE OPERATION



# 3.4.3 LP, XT, HS MODES

The LP, XT and HS modes support the use of quartz crystal resonators or ceramic resonators connected to OSC1 and OSC2 (Figure 3-3). The mode selects a low, medium o r hi gh gain s etting of the internal inverter-amplifier to support v arious re sonator ty pes and speed.

**LP** Oscillator mode selects the lowest gain setting of the internal inverter-amplifier. LP mode current consumption is the least of the three modes. This mode is designed to drive only 32.768 kH z tun ing-fork type crystals (watch crystals).

**XT** Oscillator mode s elects t he intermediate g ain setting of the internal in verter-amplifier. XT mode current consumption is the medium of the three modes. This mode is best suited to drive resonators with a medium drive level specification.

**HS** Oscillator mode selects the highest gain setting of the internal inverter-amplifier. HS mode current consumption is the h ighest of the three modes. This mode is best suited for resonators that require a high drive setting.

Figure 3-3 a nd Figure 3-4 show ty pical c ircuits for quartz crystal and ceramic resonators, respectively.





**2:** The value of RF varies with the Oscillator mode selected (typically between 2 M $\Omega$  to 10 M $\Omega$ ).

- **Note 1:** Quartz crystal characteristics vary according to ty pe, p ackage and manu facturer. Th e user should consult the manufacturer data sheets for specifications and recommended application.
  - Always verify oscillator performance over the V DD and t emperature ran ge that is expected for the application.
  - **3:** For oscillator design assistance, reference the following Microchip Applications Notes:
    - AN826, "Crystal Oscillator Basics and Crystal Selection for nPIC<sup>®</sup> and PIC<sup>®</sup> Devices" (DS00826)
    - AN849, "Basic PIC<sup>®</sup> Oscillator Design" (DS00849)
    - AN943, "Practical PIC<sup>®</sup> Oscillator Analysis and Design" (DS00943)
    - AN949, "Making Your Oscillator Work" (DS00949)





**3:** An addit ional p arallel f eedback resis tor (R P) may be required for proper ceramic resonator operation.

### 3.4.4 EXTERNAL RC MODES

The external Resistor-Capacitor (RC) modes support the u se of an external RC c ircuit. T his al lows th e designer maximum flexibility in frequency choice while keeping costs to a minimum when clock accuracy is not required. There are two modes: RC and RCIO.

In RC mo de, the R C c ircuit c onnects to O SC1. OSC2/CLKOUT out puts the R C osc illator fre quency divided by 4. This signal may be used to provide a clock for external circuitry, synchronization, calibration, test or o ther a pplication r equirements. F igure 3-5 shows the external RC mode connections.



FIGURE 3-5: EXTERNAL RC MODES

In RCIO mode, the RC circuit is connected to OSC1. OSC2 becomes an additional general purpose I/O pin.

The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values and the operating temperature. Other factors affecting the oscillator frequency are:

- threshold voltage variation
- component tolerances
- packaging variations in capacitance

The user also needs to take into account variation due to tolerance of external RC components used.

# 3.5 Internal Clock Modes

The O scillator module has two independent, internal oscillators that can be configured or selected as the system clock source.

- The HFINTOSC (H igh-Frequency Int ernal Oscillator) is factory calibrated and operates at 8 MHz. The frequency of the HFINTOSC can be user-adjusted via software using the OSCTUNE register (Register 3-2).
- 2. The **LFINTOSC** (Low -Frequency Internal Oscillator) is uncalbrated and opeates at 31kHz.

The system clock speed can be selected via software using the Internal Oscillator Fre quency Sel ect bit s IRCF<2:0> of the OSCCON register.

The system clock can be selected between external or internal clock sources via the System Clock Selection (SCS) bit of the O SCCON register. See **Section 3.6 "Clock Switching"** for more information.

#### 3.5.1 INTOSC AND INTOSCIO MODES

The IN TOSC and INTOSCIO m odes configure the internal oscillators as the system clock source when the device is programmed using the oscillator selection or the F OSC<2:0> bits in the C onfiguration W ord register (C ONFIG). See Section 12.0 "Sp ecial Features of the CPU" for more information.

In **INTOSC** mode, OSC1/CLKIN is available for general purpose I/O. O SC2/CLKOUT out puts the s elected internal oscillator frequency divided by 4. The CLKOUT signal may be used to prov ide a c lock for external circuitry, sy nchronization, ca libration, test or oth er application requirements.

In **INTOSCIO** mode, OSC1/CLKIN and OSC2/CLKOUT are available for general purpose I/O.

#### 3.5.2 HFINTOSC

The High-Frequency Internal Oscillator (HFINTOSC) is a factory calibrated 8 MHz internal clock source. The frequency of the H FINTOSC can be all tered via software using the OSCTUNE register (Register 3-2).

The output of the HFINTOSC connects to a postscaler and multiplexer (see Figure 3-1). One of se ven frequencies c an be s elected v ia softw are using the IRCF<2:0> bit s of the O SCCON register . See **Section 3.5.4 "Fr equency Select Bi ts (IR CF)"** for more information.

The HFINTOSC is enabled by selecting any frequency between 8 MHz and 125 kHz by setting the IRCF<2:0> bits of th e O SCCON r egister  $\neq$  000. Then, s et th e System C lock Source (SCS) bit of t he OS CCON register to '1' or enable Two-Speed Start-up by setting the IESO bit t in the C onfiguration W ord reg ister (CONFIG) to '1'.

The H F Internal O scillator (HTS) bit of the O SCCON register indicates whether the HFINTOSC is stable or not

# PIC12F635/PIC16F636/639

#### 3.5.2.1 **OSCTUNE** Register

The H FINTOSC is fac tory ca librated b ut c an b e adjusted in software by writing to the OSCTUNE register (Register 3-2).

The default value of the OSCTUNE register is '0'. The value is a 5-bit two's complement number.

When the OSC TUNE registe r i s mod ified, the HFINTOSC fr equency will begin s hifting to the new frequency. Code execution continues during this shift. There is no indication that the shift hasoccurred.

OSCTUNE does not affect the L FINTOSC frequency. Operation of features that depend on the L FINTOSC clock source frequency, such as the Power-up Timer (PWRT), W atchdog Timer (WD T), Fai I-Safe Clock Monitor (FSCM) and peripherals, are not affected by the change in frequency.

#### **REGISTER 3-2: OSCTUNE: OSCILLATOR TUNING REGISTER**

| U-0   | U-0 | U-0 | R/W-0 R/W | -0   | R/W-0 | R/W-0 | R/W-0 |
|-------|-----|-----|-----------|------|-------|-------|-------|
| —     |     |     | TUN4      | TUN3 | TUN2  | TUN1  | TUN0  |
| bit 7 |     |     |           |      |       |       | bit 0 |

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | read as '0'        |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

| bit 7-5<br>bit 4-0 | Unimplemented: Read as '0'<br>TUN<4:0>: Frequency Tuning bits<br>01111 = Maximum frequency<br>01110 = |
|--------------------|-------------------------------------------------------------------------------------------------------|
|                    | •<br>•                                                                                                |
|                    | 00001 =<br>00000 = Oscillator module is running at the calibrated frequency.<br>11111 =               |
|                    | • • •                                                                                                 |
|                    | 10000 = Minimum frequency                                                                             |

### 3.5.3 LFINTOSC

The Low-Frequency Internal Oscillator (LFINTOSC) is an uncalibrated 31 kHz internal clock source.

The output of the LFINTOSC connects to a postscaler and m ultiplexer (see Fig ure 3-1). Select 31 kHz, v ia software, u sing the IRCF<2:0> b its of the OSCCON register. S ee **Section 3.5.4 "Fr equency S elect Bit s (IRCF)**" for more information. The LFINTOSC is also the frequency for the Power-up Timer (PWRT), Watchdog Timer (WDT) and Fail-Safe Clock Monitor (FSCM).

The L FINTOSC is enabled by selecting 31 kHz (IRCF<2:0> bits of the OSCCON register = 000) as the system clock s ource (SC S bit of the O SCCON register = 1), or when any of the following are enabled:

- Two-Speed Start-up IESO bit of the Configuration Word register = 1 and IRCF<2:0> bits of the OSCCON register = 000
- Power-up Timer (PWRT)
- Watchdog Timer (WDT)
- Fail-Safe Clock Monitor (FSCM)

The LF Internal Oscillator (LTS) bit of the OSCCON register indicates whether the LFINTOSC is stable or not.

#### 3.5.4 FREQUENCY SELECT BITS (IRCF)

The outp ut of the 8 MHz H FINTOSC and 31 kHz LFINTOSC connects to a postscaler and multiplexer (see Figure 3-1). The Int ernal Os cillator Fre quency Select bits IRCF<2:0> of the OSCCON register select the frequency output of the internal oscillators. One of eight frequencies can be selected via software:

•8 MHz

- 4 MHz (Default after Reset)
- •2 MHz
- •1 MHz
- 500 kHz
- 250 kHz
- 125 kHz
- 31 kHz (LFINTOSC)

| Note: | Following any Reset, the IRCF<2:0> bits of |
|-------|--------------------------------------------|
|       | the OSCCON register are set to '110' and   |
|       | the frequency selection is set to 4 MHz.   |
|       | The use r can modify the IRCF bit s to     |
|       | select a different frequency.              |

### 3.5.5 HF AND LF INTOSC CLOCK SWITCH TIMING

When sw itching be tween the LFI NTOSC and the HFINTOSC, the new os cillator may already be shut down to save power (see Figure 3-6). If this is the case, there is a delay aft ert he I RCF<2:0> bits of the OSCCON register are modified before the frequency selection takes place. The LTS and HTS bits of the OSCCON register will reflect the current active status of the LFI NTOSC and H FINTOSC os cillators. The timing of a frequency selection is as follows:

- 1. IRCF<2:0> bit s o f the OSCCON register ar e modified.
- 2. If the new clock is shut down, a clock start-up delay is started.
- 3. Clock switch circuitry waits for a falling edge of the current clock.
- 4. CLKOUT is held I ow a nd t he clock s witch circuitry waits for a rising edge in the new clock.
- CLKOUT is now connected with the new clock. LTS and HTS bits of the OSCCON register are updated as required.
- 6. Clock switch is complete.

See Figure 3-1 for more details.

If the i nternal os cillator s peed s elected is be tween 8 MHz and 125 kHz, there is no start-up delay before the new frequency is selected. This is because the old and new frequencies are derived from the HFINTOSC via the postscaler and multiplexer.

Start-up d elay s pecifications are loc ated in the A/C Specifications (Oscillator Module) in Section 15.0 "Electrical Specifications".

# PIC12F635/PIC16F636/639

| FIGURE 3-6:                          | INTERNAL OSCILLATOR SWITCH TIMING                         |
|--------------------------------------|-----------------------------------------------------------|
| HF → LF <sup>(1)</sup><br>HFINTOSC → | LFINTOSC (FSCM and WDT disabled)                          |
| HFINTOSC                             | Start-up Time 2-cycle Sync Running                        |
| LFINTOSC                             |                                                           |
| IRCF <2:0>                           | $\neq 0$ $\chi = 0$                                       |
| System Clock                         |                                                           |
| Note 1: Whe                          | en going from LF to HF.                                   |
| HFINTOSC $\rightarrow$               | LFINTOSC (Either FSCM or WDT enabled)                     |
| HFINTOSC                             | 2-cycle Sync Running                                      |
| LFINTOSC                             |                                                           |
| IRCF <2:0>                           | $\neq 0$ $X = 0$                                          |
| System Clock                         |                                                           |
| LFINTOSC -                           | HFINTOSC LFINTOSC turns off unless WDT or FSCM is enabled |
| LFINTOSC                             | Start-up Time 2-cycle Sync Running                        |
| HFINTOSC                             |                                                           |
| IRCF <2:0>                           | $= 0 \qquad \neq 0$                                       |
| System Clock                         |                                                           |

# 3.6 Clock Switching

The system clock source c an b e switched b etween external and internal clock sources via software using the System Clock Select (SCS) bit of the O SCCON register.

# 3.6.1 SYSTEM CLOCK SELECT (SCS) BIT

The System Clock Select (SCS) bit of the OSCCON register selects the system clock source that is used for the CPU and peripherals.

- When the SCS bit of the OSCCON register = 0, the system clock source is determined by configuration of the FOSC<2:0> bits in the Configuration Word register (CONFIG).
- When the SCS bit of the OSCCON register = 1, the system clock source is chosen by the internal oscillator frequency selected by the IRCF<2:0> bits of the OSCCON register. After a Reset, the SCS bit of the OSCCON register is always cleared.
  - Note: Any automa tic clock sw itch, which may occur fromTwo-Speed Start-up or Fail-Safe Clock Monitor, does not update the SCS bit of the OSC CON register . The use r can monitor the OSTS bit of the O SCCON register to determine the current sys tem clock source.

# 3.6.2 OSCILLATOR START-UP TIME-OUT STATUS (OSTS) BIT

The Oscillator Start-up Time-out Status (OSTS) bit of the OSCCON register in dicates w hether the system clock is run ning from the ex ternal clock source, a s defined by the FO SC<2:0> bits in the C onfiguration Word register (CONFIG), or f rom t he i nternal c lock source. In particular, OSTS indicates that the Oscillator Start-up Timer (OST) has timed out for LP, XT or H S modes.

# 3.7 Two-Speed Clock Start-up Mode

Two-Speed Start-up mode provides add itional power savings by m inimizing the latency bet ween external oscillator start-up and code execution. In applications that make heavy use of the Sleep mode, Two-Speed Start-up w ill rem ove the external os cillator s tart-up time from the time spent awake and can reduce the overall power consumption of the device.

This mode allows the application to wake-up from Sleep, perform a few instructions using the INTOSC as the clock source and go back to Sleep without waiting for the primary oscillator to become stable.

Note: Executing a SLEEP instruction will abort the oscillator start-up time and will cause the OSTS bit of the OSCCON register to remain clear. When the Oscillator module is configured for LP, XT or HS mode s, th e Oscill ator S tart-up Timer (OS T) is enabled (see **Section 3.4.1 "Oscillator Start-up Timer (OST)**"). The OST will suspend program execution until 1024 o scillations are co unted. T wo-Speed S tart-up mode minimi zes th e dela y in code execu tion by operating fr om the internal oscil lator as t he OST is counting. When the OST count reaches 1024 and the OSTS bit of the OSCCON register is set, pr ogram execution switches to the external oscillator.

# 3.7.1 TWO-SPEED START-UP MODE CONFIGURATION

Two-Speed S tart-up m ode is configured by the following settings:

- IESO (of the Configuration Word register) = 1; Internal/External Switchover bit (Two-Speed Start-up mode enabled).
- SCS (of the OSCCON register) = 0.
- FOSC<2:0> bits in the Configuration Word register (CONFIG) configured for LP, XT or HS mode.

Two-Speed Start-up mode is entered after:

- Power-on Reset (POR) and, if enabled, after Power-up Timer (PWRT) has expired, or
- Wake-up from Sleep.

If the external clock osc illator is configured to be anything other t han LP, X T or H S mode, then Two-Speed Start-up is di sabled. This is because the external clock os cillator does not r equire an y stabilization time after POR or an exit from Sleep.

#### 3.7.2 TWO-SPEED START-UP SEQUENCE

- 1. Wake-up from Power-on Reset or Sleep.
- Instructions b egin e xecution by the int ernal oscillator at the frequency set in the IRCF<2:0> bits of the OSCCON register.
- 3. OST enabled to count 1024 clock cycles.
- 4. OST timed ou t, wait fo r fa lling ed ge of the internal oscillator.
- 5. OSTS is set.
- 6. System clock held low until the next falling edge of new clock (LP, XT or HS mode).
- 7. System cl ock is sw itched to ex ternal cl ock source.

#### 3.7.3 CHECKING TWO-SPEED CLOCK STATUS

Checking the state of the OSTS bit of the OSCCON register will confirm if the microcontroller is running from the external clock source, as defined by the FOSC<2:0> b its in the Configuration W ord register (CONFIG), or the internal oscillator.

| FIGURE 3-7: | <b>TWO-SPEED</b> | START-UP |
|-------------|------------------|----------|
|             |                  |          |

| $\begin{array}{c c} & & & \\ \hline & & \\ \hline & & \\ OSC1 & - & 0 & 1 & \\ \hline & & \\ \hline \\ \hline$ |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Program Counter         PC - N         PC         PC + 1         X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| System Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# 3.8 Fail-Safe Clock Monitor

The Fail-Safe Clock Monitor (FSCM) allows the device to continue operating should the external oscillator fail. The FSCM can detect oscillator failure any time after the Oscillator Start-up Timer (OST) has expired. The FSCM is enabled by setting the F CMEN bit in the Configuration Word register (CONFIG). The FSCM is applicable to all external oscillator modes (LP, XT, HS, EC, RC and RCIO).

FIGURE 3-8: FSCM BLOCK DIAGRAM



# 3.8.1 FAIL-SAFE DETECTION

The FS CM m odule dete cts a fai led os cillator b y comparing the external oscillator to the FSCM sample clock. The sample clock is generated by dividing the LFINTOSC by 64. See Figure 3-8. Ins ide the fai I detector block is a latc h. The external clock sets the latch on each falling edge of the external clock. The sample clock clears the latch on each rising edge of the sample clock. A fail ure is de tected when an entire half-cycle of the sample clock el apses before t he primary clock goes low.

# 3.8.2 FAIL-SAFE OPERATION

When the external clock fails, the FSCM switches the device clock to an internal clock source and sets the bit flag OSFIF of the PIR 1 register. Setting this flag will generate an interrupt if the OSFIE bit of the PIE1 register is also set. The device firmware can then take steps to mi tigate the problems that may arise from a failed cl ock. The system c lock will continue t o be sourced from the internal clock source until the device firmware s uccessfully re starts the external os cillator and switches back to external operation.

The in ternal cl ock so urce ch osen by the FSC M is determined by the IRCF<2:0> bits of th e OSC CON register. This allows the internal os cillator to be configured before a failure occurs.

# 3.8.3 FAIL-SAFE CONDITION CLEARING

The Fa il-Safe c ondition is cl eared af ter a R eset, executing a SLEEP instruction or toggling the SCS bit of the OSCCON register. When the SCS bit is toggled, the OST is restarted. While the O ST is running, th e device continues to operate from the INTOSC selected in OSCCON. When the OST times out, the Fail-Safe condition is cleared and the device will be o perating from the external clock source. The Fail-Safe condition must be cleared before the OSFIF flag can be cleared.

# 3.8.4 RESET OR WAKE-UP FROM SLEEP

The FSC M is designed to detect an os cillator failure after the Oscillator Start-up Timer (OST) has expired. The OST is used after waking up from Sleep and after any type of Reset. The OST is not used with the EC or RC Clock modes so that the FSCM will be active as soon as the Reset or wake-up has completed. When the FSCM is enabled, the Two-Speed Start-up is also enabled. Therefore, the device will always be executing code while the OST is operating.

| Note: | Due to the wide range of oscillator start-up<br>times, the Fail-Safe circuit is not ac tive<br>during oscillator start-up (i.e., after exiting<br>Reset or Slee p). After an appropriate |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | amount of time, the user should check the OSTS bit of the OSCCON register to verify                                                                                                      |
|       | the oscillator start-up and that the sys tem<br>clock sw itchover has succ essfully                                                                                                      |
|       | completed.                                                                                                                                                                               |

# PIC12F635/PIC16F636/639

#### FIGURE 3-9: FSCM TIMING DIAGRAM



| Name                  | Bit 7 | Bit 6 | Bit 5 | Bit 4               | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets <sup>(1)</sup> |
|-----------------------|-------|-------|-------|---------------------|-------|-------|-------|--------|----------------------|------------------------------------------------|
| CONFIG <sup>(2)</sup> | CPD   | CP    | MCLRE | PWRTE               | WDTE  | FOSC2 | FOSC1 | FOSC0  | _                    | _                                              |
| INTCON                | GIE   | PEIE  | TOIE  | INTE                | RAIE  | T0IF  | INTF  | RAIF   | x000 000x            | 0000 000x                                      |
| OSCCON                | —     | IRCF2 | IRCF1 | IRCF0               | OSTS  | HTS   | LTS   | SCS    | -110 x000            | -110 x000                                      |
| OSCTUNE               | —     | —     | —     | TUN4                | TUN3  | TUN2  | TUN1  | TUN0   | 0 0000               | u uuuu                                         |
| PIE1                  | EEIE  | LVDIE | CRIE  | C2IE <sup>(3)</sup> | C1IE  | OSFIE | —     | TMR1IE | 000- 00-0            | 000- 00-0                                      |
| PIR1                  | EEIF  | LVDIF | CRIF  | C2IF <sup>(3)</sup> | C1IF  | OSFIF | —     | TMR1IF | 000- 00-0            | 000- 00-0                                      |

Note 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2: See Configuration Word register (CONFIG) for operation of all register bits.

3: PIC16F636/639 only.

# 4.0 I/O PORTS

There are as many as twelve general purpose I/O pins available. D epending o n which p eripherals a re enabled, some or all of the pins may not be available as general purpose I/O. In general, when a peripheral is enabled, th e associated pin m ay not be used as a general purpose I/O pin.

### 4.1 PORTA and the TRISA Registers

PORTA is a 6-bit w ide, bidi rectional port. The corresponding data directi on register i s TR ISA (Register 4-2). Setting a TR ISA bit (= 1) will make the corresponding PORTA pi n an inp ut (i.e., put the corresponding output driver in a High-Impedance mode). C learing a TR ISA bit (= 0) w ill make the corresponding POR TA pin an output (i.e., put the contents of the output latch on the selected pin). The exception is RA3, which is input only and its TRIS bit will always read as '1'. Example 4-1 shows how to initialize PORTA.

Note: PORTA = GPIO TRISA = TRISIO

Reading the PORTA register (R egister 4-1) 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, this value is modified and then written to the PORT data latch. RA3 reads '0' when MCLRE = 1.

The TR ISA regi ster c ontrols the dire ction of the PORTA pins, even when they are being used as analog inputs. The u ser m ust en sure the bits in the TRISA register are maintained set when using them as analog inputs. I/ O pins c onfigured as a nalog i nputs always read '0'.

Note: The CMCON0 register must be initialized to configure an analog channel as a digital input. Pins configured as analog inputs will read '0'.

#### EXAMPLE 4-1: INITIALIZING PORTA

| BANKSEI | L PORTA     | ;                      |
|---------|-------------|------------------------|
| CLRF    | PORTA       | ;Init PORTA            |
| MOVLW   | 07h         | ;Set RA<2:0> to        |
| MOVWF   | CMCON0      | ;digital I/O           |
| BSF     | STATUS, RPO | ;Bank 1                |
| BCF     | STATUS, RP1 | ;                      |
| MOVLW   | 0Ch         | ;Set RA<3:2> as inputs |
| MOVWF   | TRISA       | ;and set RA<5:4,1:0>   |
|         |             | ;as outputs            |

# 4.2 Additional Pin Functions

Every PORTA pin on the PI C12F635/PIC16F636/639 has a n int errupt-on-change op tion an d a w eak pull-up/pull-down option. RA0 has an Ultra Low-Power Wake-up opt ion. The next thre e sections describe these functions.

#### 4.2.1 WEAK PULL-UP/PULL-DOWN

Each of the PORTA pins, except RA3, has an internal weak pull-up and pull-down. The WDA bits select either a p ull-up or pull-down for an in dividual port bit. Individual control b its can turn on the p ull-up or pull-down. These pull-ups/pull-downs are automatically turned off when the port pin is configured as an output, as an al ternate function or on a Power-on R eset, setting the RAPU bit of the OPTION register. A weak pull-up on RA3 is enabled when configured as MCLR in the Configuration Word register and disabled when high v oltage is d etected, to reduce c urrent consumption through RA3, while in Programming mode.

Note: PORTA = GPIO

TRISA = TRISIO

| U-0                                | U-0 | R/W-x          | R/W-x            | R-x          | R/W-x           | R/W-x    | R/W-x |
|------------------------------------|-----|----------------|------------------|--------------|-----------------|----------|-------|
| —                                  |     | RA5            | RA4              | RA3          | RA2             | RA1      | RA0   |
| bit 7                              |     |                |                  |              | •               | -        | bit 0 |
|                                    |     |                |                  |              |                 |          |       |
| Legend:                            |     |                |                  |              |                 |          |       |
| R = Readable b                     | oit | W = Writable I | bit              | U = Unimpler | mented bit, rea | d as '0' |       |
| -n = Value at POR '1' = Bit is set |     |                | '0' = Bit is cle | ared         | x = Bit is unkr | nown     |       |

### REGISTER 4-1: PORTA: PORTA REGISTER

bit 7-6 Unimplemented: Read as '0' bit 5-0 RA<5:0>: PORTA I/O Pin bit

1 = Port pin is > VIH

0 = Port pin is < VIL

### REGISTER 4-2: TRISA: PORTA TRI-STATE REGISTER

| U-0   | U-0 | R/W-1  | R/W-1  | R-1    | R/W-1  | R/W-1  | R/W-1  |
|-------|-----|--------|--------|--------|--------|--------|--------|
| —     | —   | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 |
| bit 7 |     |        |        |        |        |        | bit 0  |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | l as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-6 Unimplemented: Read as '0'

bit 5-0 **TRISA<5:0>:** PORTA Tri-State Control bits 1 = PORTA pin configured as an input (tri-stated) 0 = PORTA pin configured as an output

Note 1: TRISA<3> always reads '1'.

2: TRISA<5:4> always reads '1' in XT, HS and LP Oscillator modes.

#### REGISTER 4-3: WDA: WEAK PULL-UP/PULL-DOWN DIRECTION REGISTER

| U-0         | U-0 | R/W-1 | R/W-1 | U-0 | R/W-1 | R/W-1 | R/W-1 |
|-------------|-----|-------|-------|-----|-------|-------|-------|
| —           | —   | WDA5  | WDA4  | —   | WDA2  | WDA1  | WDA0  |
| bit 7 bit 0 |     |       |       |     |       |       |       |

| Legend:           |                  |                                |                    |
|-------------------|------------------|--------------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read as | ʻ0'                |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared           | x = Bit is unknown |

| bit 7-6 | Unimplemented: Read as '0'                                                                   |
|---------|----------------------------------------------------------------------------------------------|
| bit 5-4 | WDA<5:4>: Pull-up/Pull-down Selection bits<br>1 = Pull-up selected<br>0 = Pull-down selected |
| bit 3   | Unimplemented: Read as '0'                                                                   |
| bit 2-0 | WDA<2:0>: Pull-up/Pull-down Selection bits<br>1 = Pull-up selected<br>0 = Pull-down selected |

- Note 1: The weak pull-up/pull-down device is enabled only when the global  $\overline{RAPU}$  bit is enabled, the pin is in Input mode (TRIS = 1), the individual WDA bit is enabled (WDA = 1) and the pin is not configured as an analog input or clock function.
  - 2: RA3 pull-up is enabled when the pin is configured as MCLR in the Configuration Word register and the device is not in Programming mode.

#### REGISTER 4-4: WPUDA: WEAK PULL-UP/PULL-DOWN ENABLE REGISTER

| U-0   | U-0 | R/W-1                 | R/W-1                 | U-0 | R/W-1  | R/W-1  | R/W-1  |
|-------|-----|-----------------------|-----------------------|-----|--------|--------|--------|
| —     | —   | WPUDA5 <sup>(3)</sup> | WPUDA4 <sup>(3)</sup> |     | WPUDA2 | WPUDA1 | WPUDA0 |
| bit 7 |     |                       |                       |     |        |        | bit 0  |

| Legend:           |                  |                                |                    |
|-------------------|------------------|--------------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read as | '0'                |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared           | x = Bit is unknown |

| bit 7-6 | Unimplemented: Read as '0'                                                                                                               |
|---------|------------------------------------------------------------------------------------------------------------------------------------------|
| bit 5-4 | WPUDA<5:4>: Pull-up/Pull-down Direction Selection bits <sup>(3)</sup><br>1 = Pull-up/pull-down enabled<br>0 = Pull-up/pull-down disabled |
| bit 3   | Unimplemented: Read as '0'                                                                                                               |
| bit 2-0 | WPUDA<2:0>: Pull-up/Pull-down Direction Selection bits<br>1 = Pull-up/pull-down enabled<br>0 = Pull-up/pull-down disabled                |

- Note 1: The weak pull-up/pull-down direction device is enabled only when the global RAPU bit is enabled, the pin is in Input mode (TRIS = 1), the individual WPUDA bit is enabled (WPUDA = 1) and the pin is not configured as an analog input or clock function.
  - 2: RA3 pull-up is enabled when the pin is configured as MCLR in the Configuration Word register and the device is not in Programming mode.
  - 3: WPUDA5 bit can be written if INTOSC is enabled and T1OSC is disabled; otherwise, the bit can not be written and reads as '1'. WPUDA4 bit can be written if not configured as OSC2; otherwise, the bit can not be written and reads as '1'

# PIC12F635/PIC16F636/639

### 4.2.2 INTERRUPT-ON-CHANGE

Each of the PORTA pins is individually configurable as an interrupt-on-change pin. Control bits, IOCAx, enable or disable the interrupt function for each pin. Refer to Register 4-5. The interrupt-on-change is disabled on a Power-on Reset.

For enabled interrupt-on-change pins, the values are compared with the old value latched on the last read of PORTA. The 'm ismatch' ou tputs of the last read ar e OR'd together to set the PORTA Change Interrupt Flag bit (RAIF) in the INTCON register.

This interrupt can wake the device from SI eep. The user, in the Interrupt Serv ice R outine, c lears the interrupt by:

- a) Any read or write of PO RTA. This will end the mismatch condition, then
- b) Clear the flag bit RAIF.

A mismatch condition will continue to set flag bit RAIF. Reading PORTA will end the mismatch condition and allow flag bit RAIF to be cleared. The <u>latch</u> holding the last read value is not affected by a M CLR nor BOR Reset. After these Resets, the RAIF flag will continue to be set if a mismatch is present.

Note: If a change on the I/O pin should occur when the read operation is being executed (start of the Q 2 cycle), then the RAIF interrupt flag may not get set.

### REGISTER 4-5: IOCA: INTERRUPT-ON-CHANGE PORTA REGISTER

| U-0   | U-0 | R/W-0                | R/W-0                | R/W-0                | R/W-0 | R/W-0 | R/W-0 |
|-------|-----|----------------------|----------------------|----------------------|-------|-------|-------|
|       | —   | IOCA5 <sup>(2)</sup> | IOCA4 <sup>(2)</sup> | IOCA3 <sup>(3)</sup> | IOCA2 | IOCA1 | IOCA0 |
| bit 7 |     |                      |                      |                      |       |       | bit 0 |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | l as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

#### bit 7-6 Unimplemented: Read as '0'

bit 5-0 **IOCA<5:0>:** Interrupt-on-Change PORTA Control bits<sup>(2,3)</sup>

- $1 = Interrupt-on-change enabled^{(1)}$
- 0 = Interrupt-on-change disabled

Note 1: Global Interrupt Enable (GIE) must be enabled for individual interrupts to be recognized.

- 2: IOCA<5:4> always reads '0' in XT, HS and LP Oscillator modes.
- 3: IOCA<3> is ignored when WUR is enabled and the device is in Sleep mode.

#### 4.2.3 ULTRA LOW-POWER WAKE-UP

The Ultra Low-Power Wake-up (ULPWU) on RA0 allows a slow falling voltage to generate an interrupt-on-change on RA0 without excess current consumption. The mode is selected by setting the ULPWUE bit of the P CON register. This enables a small current sink which can be used to discharge a capacitor on RA0.

To use this feature, the RA0 pin is configured to output '1' to charge the capacitor, interrupt-on-change for RA0 is enabled an d R A0 is configured as an input. The ULPWUE bit is set to begin the discharge and a SLEEP instruction is performed. When the votinge on RA0 drops below VIL, an interrupt will be generated which will cause the device to wake-up. Depending on the state of the GIE bit of the INTCON register, the device will either jump to the interrupt vector (0004h) or execute the next instruction w hen the interrupt event occu rs. See Section 4.2.2 "Interr upt-on-Change" and Section 12.9.3 " PORTA Inter rupt" for more information.

This fea ture provides a low-power te chnique for periodically waking up the device from S leep. The time-out is dependent on the discharge time of the RC circuit on RA0. See Example 4-2 for initializing the Ultra Low Power Wake-up module.

The series resistor provides overcurrent protection for the RAO pin and can allow for software calibration of the time-out (see Figure 4-1). Atimer can be used to measter the charge time and discharge time of the capacitor. The charge time can then be adjusted to provide the desired interrupt delay. This technique will compensate for the affects of temperature, voltage and component accuracy. The Ultra Low-Power Wake-up peripheral can also be configured as a simple Programmable Low-Voltage Detect or temperature sensor

| Note: | For m ore i nformation, refer to the |
|-------|--------------------------------------|
|       | Application N ote AN879, "Using the  |
|       | Microchip Ultra Low-Power Wake-up    |
|       | Module" (DS00879).                   |

# EXAMPLE 4-2: ULTRA LOW-POWER

# WAKE-UP INITIALIZATION

| BANKSEI | J PORTA     | ;                   |
|---------|-------------|---------------------|
| BSF     | PORTA,0     | ;Set RA0 data latch |
| MOVLW   | H'7'        | ;Turn off           |
| MOVWF   | CMCON0      | ; comparators       |
| BANKSEI | TRISA       | ;                   |
| BCF     | TRISA,0     | ;Output high to     |
| CALL    | CapDelay    | ; charge capacitor  |
| BSF     | PCON,ULPWUE | ;Enable ULP Wake-up |
| BSF     | IOCA,0      | ;Select RA0 IOC     |
| BSF     | TRISA,0     | ;RA0 to input       |
| MOVLW   | B'10001000' | ;Enable interrupt   |
| MOVWF   | INTCON      | ; and clear flag    |
| SLEEP   |             | ;Wait for IOC       |
| NOP     |             | ;                   |
|         |             |                     |

# 4.2.4 PIN DESCRIPTIONS AND DIAGRAMS

Each PORTA pin is multiplexed with other functions. The pins and their combined functions are briefly described here. For specific information about individual functions, such as the comparator, refer to the appropriate section in this data sheet.

# FIGURE 4-1: BLOCK DIAGRAM OF RA0

#### 4.2.4.1 RA0/C1IN+/ICSPDAT/ULPWU

Figure 4-2 shows the diagram for this pin. The RA0 pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input to the comparator
- In-Circuit Serial Programming<sup>™</sup> data
- an analog input for the Ultra Low-Power Wake-up



### 4.2.4.2 RA1/C1IN-/VREF/ICSPCLK

Figure 4-2 shows the diagram for this pin. The RA1 pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input to the comparator
- In-Circuit Serial Programming<sup>™</sup> clock



# 4.2.4.3 RA2/T0CKI/INT/C1OUT

Figure 4-3 shows the diagram for this pin. The RA2 pin is configurable to function as one of the following:

- a general purpose I/O
- the clock input for Timer0
- an external edge-triggered interrupt
- · a digital output from the comparator



# 4.2.4.4 RA3/MCLR/VPP

Figure 4-4 shows the diagram for this pin. The RA3 pin is configurable to function as one of the following:

- a general purpose input
- as Master Clear Reset with weak pull-up
- a high-voltage detect for Program mode entry

### FIGURE 4-4: BLOCK DIAGRAM OF RA3



# 4.2.4.5 RA4/T1G/OSC2/CLKOUT

Figure 4-5 shows the diagram for this pin. The RA4 pin is configurable to function as one of the following:

- a general purpose I/O
- a Timer1 gate input
- a crystal/resonator connection
- a clock output



# 4.2.4.6 RA5/T1CKI/OSC1/CLKIN

Figure 4-6 shows the diagram for this pin. The RA5 pin is configurable to function as one of the following:

**BLOCK DIAGRAM OF RA5** 

- a general purpose I/O
- a Timer1 clock input
- a crystal/resonator connection
- · a clock input

FIGURE 4-6:



| TABLE 4-1: SUMMARY OF REGISTERS ASSOCIATED WITH PORT |
|------------------------------------------------------|
|------------------------------------------------------|

| Name       | Bit 7                                                                       | Bit 6                                                                      | Bit 5   | Bit 4   | Bit 3   | Bit 2  | Bit 1  | Bit 0     | Value on<br>POR, BOR,<br>WUR | Value on all other Resets |
|------------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------|---------|---------|---------|--------|--------|-----------|------------------------------|---------------------------|
| PORTA      | —                                                                           | —                                                                          | RA5     | RA4     | RA3     | RA2    | RA1    | RA0       | xx xx00                      | uu uu00                   |
| INTCON     | GIE                                                                         | PEIE                                                                       | TOIE    | INTE    | RAIE    | T0IF   | INTF   | RAIF      | 0000 000x                    | 0000 000x                 |
| TMR1L      | Holding Register for the Least Significant Byte of the 16-bit TMR1 Register |                                                                            |         |         |         |        |        |           | XXXX XXXX                    | uuuu uuuu                 |
| TMR1H      | Holding Reg                                                                 | Holding Register for the Most Significant Byte of the 16-bit TMR1 Register |         |         |         |        |        | XXXX XXXX | uuuu uuuu                    |                           |
| T1CON      | T1GINV                                                                      | TMR1GE                                                                     | T1CKPS1 | T1CKPS0 | T1OSCEN | T1SYNC | TMR1CS | TMR10N    | 0000 0000                    | uuuu uuuu                 |
| CMCON1     | —                                                                           | —                                                                          | _       | _       | _       | _      | T1GSS  | CxSYNC    | 10                           | 10                        |
| CMCON0     | C2OUT                                                                       | C1OUT                                                                      | C2INV   | C1INV   | CIS     | CM2    | CM1    | CM0       | 0000 0000                    | 0000 0000                 |
| OPTION_REG | RAPU                                                                        | INTEDG                                                                     | TOCS    | TOSE    | PSA     | PS2    | PS1    | PS0       | 1111 1111                    | 1111 1111                 |
| TRISA      | —                                                                           | —                                                                          | TRISA5  | TRISA4  | TRISA3  | TRISA2 | TRISA1 | TRISA0    | 11 1111                      | 11 1111                   |
| WPUDA      | _                                                                           | —                                                                          | WPUDA5  | WPUDA4  | _       | WPUDA2 | WPUDA1 | WPUDA0    | 11 -111                      | 11 -111                   |
| IOCA       | —                                                                           | _                                                                          | IOCA5   | IOCA4   | IOCA3   | IOCA2  | IOCA1  | IOCA0     | 00 0000                      | 00 0000                   |
| WDA        | _                                                                           | _                                                                          | WDA5    | WDA4    |         | WDA2   | WDA1   | WDA0      | 11 -111                      | 11 -111                   |

Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTA.

# 4.3 PORTC

PORTC is a general purpose I/O port consisting of 6 bidirectional pins. The pins can be configured for either digital I/O or an alog input to comparator. For specific information abo ut in dividual functions, refer to the appropriate section in this data sheet.

| Note: | The CMCON0 register must be initialized      |
|-------|----------------------------------------------|
|       | to configure an analog channel as a digital  |
|       | input. Pins configured as analog inputs will |
|       | read '0'.                                    |

#### EXAMPLE 4-3: INITIALIZING PORTC

| BANKSEL | PORTC  | ;                      |
|---------|--------|------------------------|
| CLRF    | PORTC  | ;Init PORTC            |
| MOVLW   | 07h    | ;Set RC<4,1:0> to      |
| MOVWF   | CMCON0 | ;digital I/O           |
| BANKSEL | TRISC  | ;                      |
| MOVLW   | 0Ch    | ;Set RC<3:2> as inputs |
| MOVWF   | TRISC  | ;and set RC<5:4,1:0>   |
|         |        | ;as outputs            |

# REGISTER 4-6: PORTC: PORTC REGISTER

| U-0   | U-0 | R/W-x | R/W-x | R/W-x | R/W-x | R/W-0 | R/W-0 |
|-------|-----|-------|-------|-------|-------|-------|-------|
| —     | —   | RC5   | RC4   | RC3   | RC2   | RC1   | RC0   |
| bit 7 |     |       |       |       |       |       | bit 0 |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7-6 Unimplemented: Read as 10 | bit 7-6 | Unimplemented: Read as '0' |
|-----------------------------------|---------|----------------------------|
|-----------------------------------|---------|----------------------------|

bit 5-0 **RC<5:0>:** PORTC General Purpose I/O Pin bits 1 = Port pin is > VIH 0 = Port pin is < VIL

#### REGISTER 4-7: TRISC: PORTC TRI-STATE REGISTER

| U-0   | U-0 | R/W-1  | R/W-1  | R-1    | R/W-1  | R/W-1  | R/W-1  |
|-------|-----|--------|--------|--------|--------|--------|--------|
| _     | —   | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 |
| bit 7 |     |        |        |        |        |        | bit 0  |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | as '0'             |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-6 Unimplemented: Read as '0'

bit 5-0

TRISC<5:0>: PORTC Tri-State Control bits

1 = PORTC pin configured as an input (tri-stated)

0 = PORTC pin configured as an output

# PIC12F635/PIC16F636/639

# 4.3.1 RC0/C2IN+

Figure 4-7 shows the diagram for this pin. The RC0 pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input to the comparator

#### 4.3.2 RC1/C2IN-

Figure 4-7 shows the diagram for this pin. The RC1 pin is configurable to function as one of the following:

- a general purpose I/O
- an analog input to the comparator

#### 4.3.3 RC2

Figure 4-8 shows the diagram for this pin. The RC2 pin is configurable to function as a general purpose I/O.

#### 4.3.4 RC3

Figure 4-8 shows the diagram for this pin. The RC3 pin is configurable to function as a general purpose I/O.

#### 4.3.5 RC5

Figure 4-8 shows the diagram for this pin. The RC5 pin is configurable to function as a general purpose I/O.

# FIGURE 4-7:

#### BLOCK DIAGRAM OF RC0 AND RC1



#### FIGURE 4-8:

#### BLOCK DIAGRAM OF RC2, RC3 AND RC5



#### 4.3.6 RC4/C2OUT

Figure 4-9 shows the diagram for this pin. The RC4 pin is configurable to function as one of the following:

- a general purpose I/O
- a digital output from the comparator



| Name   | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR, BOR,<br>WUR | Value on<br>all other<br>Resets |
|--------|-------|-------|--------|--------|--------|--------|--------|--------|------------------------------|---------------------------------|
| PORTC  | _     | _     | RC5    | RC4    | RC3    | RC2    | RC1    | RC0    | xx xx00                      | uu uu00                         |
| CMCON0 | C2OUT | C10UT | C2INV  | C1INV  | CIS    | CM2    | CM1    | CM0    | 0000 0000                    | 0000 0000                       |
| TRISC  | _     | _     | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 11 1111                      | 11 1111                         |

Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTA.

NOTES:

# 5.0 TIMER0 MODULE

The Timer0 module is an 8-bit timer/counter with the following features:

- 8-bit timer/counter register (TMR0)
- 8-bit prescaler (shared with Watchdog Timer)
- · Programmable internal or external clock source
- · Programmable external clock edge selection
- Interrupt on overflow

Figure 5-1 is a block diagram of the Timer0 module.

# 5.1 Timer0 Operation

When used as a timer, the Timer0 module can be used as either an 8-bit timer or an 8-bit counter.

### 5.1.1 8-BIT TIMER MODE

When us ed as a ti mer, t he T imer0 m odule w ill increment every instruction cycle (without p rescaler). Timer mode is selected by clearing the T0CS bit of the OPTION register to '0'.

When TM R0 is written, the increment is inhibited for two instruction cycles immediately following the write.

Note: The value written to the TMR0 register can be adjusted, in order to account for the two instruction cy cle de lay when TM R0 is written.

#### 5.1.2 8-BIT COUNTER MODE

When used a s a c ounter, the T imer0 module w ill increment on every r ising or falling edge of the T 0CKI pin. The incrementing edge is determined by the T0SE bit of the OPTION register. Counter mode is selected by setting the T0CS bit of the OPTION register to '1'.

### FIGURE 5-1: BLOCK DIAGRAM OF THE TIMER0/WDT PRESCALER



# 5.1.3 SOFTWARE PROGRAMMABLE PRESCALER

A single software programmable prescaler is available for u se w ith either Timer0 or the Watchdog Timer (WDT), but not bot h si multaneously. The pr escaler assignment is controlled by the PSA bit of the OPTION register. To assign the prescaler to Timer0, the PSA bit must be cleared to a '0'.

There are 8 prescaler options for the T imer0 module ranging f rom 1:2 to 1:256. The prescale v alues are selectable via the PS<2:0> bits of the OPTION register. In order to have a 1:1 prescaler value for the Timer0 module, the prescaler must be assigned to the WDT module.

The prescaler is not readable or w ritable. When assigned to the Timer0 module, all instructions writing to the TMR0 register will clear the prescaler.

When the pre scaler is assigned to WD T, a CLRWDT instruction will clear the prescaler along with the WDT.

#### 5.1.3.1 Switching Prescaler Between Timer0 and WDT Modules

As a result of having the prescaler assigned to either Timer0 or the W DT, it is possible to generate an unintended dev ice Reset when sw itching pr escaler values. When changing the prescaler assignment from Timer0 to the WDT module, the instruction sequence shown in Example 5-1, must be executed.

# EXAMPLE 5-1: CHANGING PRESCALER (TIMER0 $\rightarrow$ WDT)

| BANKSEL<br>CLRWDT                | TMR0                                                     | ;<br>;Clear WDT                                            |
|----------------------------------|----------------------------------------------------------|------------------------------------------------------------|
| CLRF                             | TMR0                                                     | ;Clear TMR0 and<br>;prescaler                              |
| BANKSEL<br>BSF                   | OPTION_REG<br>OPTION REG,PSA                             | ;                                                          |
| CLRWDT                           | · · _ · , ·                                              | ;                                                          |
| MOVLW<br>ANDWF<br>IORLW<br>MOVWF | b'11111000'<br>OPTION_REG,W<br>b'00000101'<br>OPTION_REG | ;Mask prescaler<br>;bits<br>;Set WDT prescaler<br>;to 1:32 |

When changing the prescaler as signment f rom t he WDT to the T imer0 m odule, the following instruction sequence must be executed (see Example 5-2).

| EXAMPLE 5-2: | CHANGING PRESCALER         |
|--------------|----------------------------|
|              | (WDT $\rightarrow$ TIMER0) |

| CLRWDT   |           | ;Clear WDT and<br>;prescaler                                                |
|----------|-----------|-----------------------------------------------------------------------------|
| ANDWF OF | 11110000' | ;<br>;Mask TMR0 select and<br>;prescaler bits<br>;Set prescale to 1:16<br>; |

#### 5.1.4 TIMER0 INTERRUPT

Timer0 will ge nerate an interrupt when the TM R0 register overflows from FFh to 00h. The T0IF interrupt flag bit of the IN TCON register is set every time the TMR0 register overflows, regardless of whether or not the Timer0 interrupt is enabled. The T0IF bit must be cleared in software. The Timer0 interrupt enable is the T0IE bit of the INTCON register.

| Note: | The T imer0 in terrupt ca nnot wake the |
|-------|-----------------------------------------|
|       | processor from Sleep since the timer is |
|       | frozen during Sleep.                    |

# 5.1.5 USING TIMER0 WITH AN EXTERNAL CLOCK

When Timer0 is in Counter mode, the synchronization of the T0CKI input and the Timer0 register is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks. Therefore, the high and low periods of the external clock source must meet the ti ming req uirements as shown in th e **Section 15.0 "Electrical Specifications"**.

| R/W-1        | R/W-1         | R/W-1                                                | R/W-1           | R/W-1            | R/W-1           | R/W-1           | R/W-1 |  |  |  |
|--------------|---------------|------------------------------------------------------|-----------------|------------------|-----------------|-----------------|-------|--|--|--|
| RAPU         | INTEDG        | TOCS                                                 | TOSE            | PSA              | PS2             | PS1             | PS0   |  |  |  |
| bit 7        |               |                                                      |                 |                  |                 |                 | bit   |  |  |  |
|              |               |                                                      |                 |                  |                 |                 |       |  |  |  |
| Legend:      |               |                                                      |                 |                  |                 |                 |       |  |  |  |
| R = Readab   | le bit        | W = Writable                                         | bit             | U = Unimpler     | nented bit, rea | d as '0'        |       |  |  |  |
| -n = Value a | t POR         | '1' = Bit is se                                      | t               | '0' = Bit is cle | ared            | x = Bit is unkr | nown  |  |  |  |
|              |               |                                                      |                 |                  |                 |                 |       |  |  |  |
| bit 7        | RAPU: POR     | TA Pull-up Ena                                       | ble bit         |                  |                 |                 |       |  |  |  |
|              |               | pull-ups are dis                                     |                 |                  |                 |                 |       |  |  |  |
|              | 0 = PORTA     | pull-ups are ena                                     | abled by indivi | dual PORT late   | h values        |                 |       |  |  |  |
| bit 6        |               | errupt Edge Se                                       |                 |                  |                 |                 |       |  |  |  |
|              |               | on rising edge                                       |                 |                  |                 |                 |       |  |  |  |
|              | 0 = Interrupt | on falling edge                                      | of INT pin      |                  |                 |                 |       |  |  |  |
| bit 5        | TOCS: TMR     | 0 Clock Source                                       | Select bit      |                  |                 |                 |       |  |  |  |
|              |               | 1 = Transition on T0CKI pin                          |                 |                  |                 |                 |       |  |  |  |
|              | 0 = Internal  | instruction cycle                                    | e clock (Fosc/  | 4)               |                 |                 |       |  |  |  |
| bit 4        | TOSE: TMR     | 0 Source Edge                                        | Select bit      |                  |                 |                 |       |  |  |  |
|              |               | L = Increment on high-to-low transition on TOCKI pin |                 |                  |                 |                 |       |  |  |  |
|              | 0 = Increme   | nt on low-to-hig                                     | h transition on | n TOCKI pin      |                 |                 |       |  |  |  |
| bit 3        | PSA: Presca   | aler Assignmen                                       | t bit           |                  |                 |                 |       |  |  |  |
|              |               | er is assigned to                                    |                 |                  |                 |                 |       |  |  |  |
|              | 0 = Prescale  | er is assigned to                                    | the Timer0 m    | nodule           |                 |                 |       |  |  |  |
| bit 2-0      | PS<2:0>: Pi   | escaler Rate S                                       | elect bits      |                  |                 |                 |       |  |  |  |
|              | BI            | F VALUE TMR0 F                                       | RATE WDT RA     | TE               |                 |                 |       |  |  |  |
|              |               | 000 1:2                                              | 1:1             |                  |                 |                 |       |  |  |  |
|              |               | 001 1:4                                              |                 |                  |                 |                 |       |  |  |  |
|              |               | 010 1:8                                              |                 |                  |                 |                 |       |  |  |  |
|              |               | 011 1:1<br>100 1:3                                   |                 |                  |                 |                 |       |  |  |  |
|              |               | 100 1.3                                              |                 |                  |                 |                 |       |  |  |  |
|              |               | 110 1:1                                              | -               |                  |                 |                 |       |  |  |  |
|              |               | 111 1:2                                              |                 | 3                |                 |                 |       |  |  |  |

#### **REGISTER 5-1: OPTION\_REG: OPTION REGISTER**

Note 1: A dedicated 16-bit WDT postscaler is available. See Section 12.11 "Watchdog Timer (WDT)" for more information.

#### TABLE 5-1: SUMMARY OF REGISTERS ASSOCIATED WITH TIMER0

| Name       | Bit 7    | Bit 6      | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on:<br>POR, BOR | Value on<br>all other<br>Resets |
|------------|----------|------------|--------|--------|--------|--------|--------|--------|-----------------------|---------------------------------|
| TMR0       | Timer0 N | /lodule Re | gister |        |        |        |        |        | xxxx xxxx             | uuuu uuuu                       |
| INTCON     | GIE      | PEIE       | TOIE   | INTE   | RAIE   | T0IF   | INTF   | RAIF   | 0000 000x             | 0000 000x                       |
| OPTION_REG | RAPU     | INTEDG     | TOCS   | T0SE   | PSA    | PS2    | PS1    | PS0    | 1111 1111             | 1111 1111                       |
| TRISA      | _        | —          | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 11 1111               | 11 1111                         |

**Legend:** – = Unimplemented locations, read as '0', u = unchanged, x = unknown. Shaded cells are not used by the Timer0 module.

# 6.0 TIMER1 MODULE WITH GATE CONTROL

The Timer1 module is a 16-bit timer/counter with the following features:

- 16-bit timer/counter register pair (TMR1H:TMR1L)
- Programmable internal or external clock source
- 3-bit prescaler
- Optional LP oscillator
- Synchronous or asynchronous operation
- Timer1 gate (count enable) via comparator or  $$\overline{\text{T1G}}$ pin$
- Interrupt on overflow
- Wake-up on overflow (external clock, Asynchronous mode only)
- Comparator output synchronization to Timer1 clock

Figure 6-1 is a block diagram of the Timer1 module.

# 6.1 Timer1 Operation

The Timer1 module is a 16- bit in crementing co unter which is accessed through the TMR1H:TMR1L register pair. Writes to TMR1H or TMR1L directly up date the counter.

When used with an internal clock source, the module is a timer. When used with an external clock source, the module can be used as either a timer or counter.

# 6.2 Clock Source Selection

The TMR1CS bit of the T1CON register is used to select the clock source. When TMR1CS = 0, the clock source is F OSC/4. W hen TMR 1CS = 1, the c lock source is supplied externally.

| Clock<br>Source | T10SCEN | FOSC<br>Mode      | T1CS |
|-----------------|---------|-------------------|------|
| Fosc/4          | х       | xxx               | х    |
| T1CKI pin       | xl      |                   |      |
| T1LPOSC         | 1       | LP or<br>INTOSCIO |      |

# PIC12F635/PIC16F636/639





# 6.2.1 INTERNAL CLOCK SOURCE

When the internal clocks ource is s elected the TMR1H:TMR1L register pair will increment on multiples of TCY as determined by the Timer1 prescaler.

# 6.2.2 EXTERNAL CLOCK SOURCE

When the external clock source is selected, the Timer1 module may work as a timer or a counter.

When counting, Timer1 is incremented on the rising edge of the external clock input T1CKI. In addition, the Counter mod e clock can be s ynchronized to the microcontroller system clock or run asynchronously.

In Counter mode, a falling edge must be registered by the counter prior to the first incrementing rising edge after one or more of the following conditions:

- Timer1 is enabled after POR or BOR Reset
- A write to TMR1H or TMR1L
- T1CKI is high when Timer1 is disabled and when Timer1 is reenabled T1CKI is low. See Figure 6-2.

# 6.3 Timer1 Prescaler

Timer1 has four prescaler options allowing 1, 2, 4 or 8 divisions of the clock input. The T1C KPS bits of the T1CON register control the prescale counter. The prescale counter is not direc tly readable or w ritable; however, the prescaler counter is œared upon a write to TMR1H or TMR1L.

# 6.4 Timer1 Oscillator

A I ow-power 3 2.768 k Hz c rystal os cillator is bui It-in between pins OSC1 (input) and OSC2 (amplifier output). The oscillator is enabled by setting the T1OSCEN control b it of the T 1CON register. The os cillator w ill continue to run during Sleep.

The T imer1 os cillator i s s hared with the s ystem LP oscillator. Thus, Timer1 can use this mode only when the primary system clock is derived from the internal oscillator or when in LP oscillator mode. The user must provide a software time delay to ensure proper oscillator start-up.

TRISA5 and TR ISA4 b its are s et w hen the Timer1 oscillator is enabled. RA5 and RA4 bits read as '0' and TRISA5 and TRISA4 bits read as '1'.

Note: The oscillator requires a start-up and stabilization time before use. Thus, T1OSCEN should be set and a suitable delay observed prior to enabling Timer1.

### 6.5 Timer1 Operation in Asynchronous Counter Mode

If control bit  $\overline{T1SYNC}$  of the T1CON register is set, the external clock input is not synchronized. The timer continues to incre ment asynchronous to the int ernal phase clock s. The timer will continue to run during Sleep and can gener ate an interr upt on overflow , which will wake-up the processor. However, special precautions in s oftware are needed to read/write the timer (s ee Section 6.5.1 "R eading and W riting Timer1 in Asynchronous Counter Mode").

Note: When switching from synchronous to asynchronous operation, it is possible to skip an increment. When s witching from asynchronous to synchronous operation, it is possible to produce a single spurious increment.

#### 6.5.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in h ardware). Ho wever, the us er should keep in mind that reading the 16-bit timer in two 8-bit values itself, p oses c ertain p roblems, s ince the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the tim er 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 TM R1H:TTMR1L register pair.

# 6.6 Timer1 Gate

Timer1 gate source is software configurable to be the T1G pin or the output of Comparator 2. This allows the device to directly time external events using T1G or analog events using Comparator 2. See the C MCON1 register (R egister 7-3) for selec ting the T imer1 gate source. This feature can sim plify the softw are for a Delta-Sigma A/D converter and manyother applications. For more information on D elta-Sigma A/D converters, see the Microchip web site (www.microchip.com).

| Note: | TMR1GE bit of the T1CON register must    |
|-------|------------------------------------------|
|       | be set to use either T1G or C2OUT as the |
|       | Timer1 gate source. See Register 7-3 for |
|       | more information on selecting the Timer1 |
|       | gate source.                             |

Timer1 gate can be inverted using the T1GINV bit of the T1CON register, whether it originates from the T1G pin or Comparator 2 output. This configures Timer1 to measure either the active-high or active-low time between events.

# 6.7 Timer1 Interrupt

The Timer1 register pair (TMR1H:TMR1L) increments to FFFFh and rolls over to 0000h. When Timer1 rolls over, the Timer1 interrupt flag bit of the PIR1 register is set. To enable the interrupt on rollover, you must set these bits:

- Timer1 interrupt enable bit of the PIE1 register
- PEIE bit of the INTCON register
- GIE bit of the INTCON register

The interrupt is cleared by clearing the TMR1IF bit in the Interrupt Service Routine.

Note: The TMR1H:TTMR1L register pair and the TMR1IF bits hould be cleared before enabling interrupts.

# 6.8 Timer1 Operation During Sleep

Timer1 can only operate during Sleep when setup in Asynchronous Counter mode. In this mode, an external crystal or c lock source can be used to in crement the counter. To set up the timer to wake the device:

- TMR1ON bit of the T1CON register must be set
- TMR1IE bit of the PIE1 register must be set
- PEIE bit of the INTCON register must be set

The device will wake-up on an ov erflow and execute the n ext in struction. If the G IE bit of the INT CON register is set, the device will call the Interrupt Service Routine (0004h).

#### FIGURE 6-2: TIMER1 INCREMENTING EDGE



# 6.9 Comparator Synchronization

The same clock used to increment Timer1 can also be used to synchronize th e c omparator o utput. This feature is enabled in the Comparator module.

When us ing the c omparator for T imer1 gate, the comparator output should be synchronized to Timer1. This ensures Timer1 does not miss an increment if the comparator changes.

For more information, see **Section 7.0 "Comparator Module"**.

# 6.10 Timer1 Control Register

The Timer1 Con trol re gister (T 1CON), s hown i n Register 6-1, is used to control Timer1 and select the various features of the Timer1 module.

#### REGISTER 6-1: T1CON: TIMER 1 CONTROL REGISTER

| R/W-0                 | R/W-0                                                                                                                                                                                                                                                                                                               | R/W-0                                                              | R/W-0                  | R/W-0                               | R/W-0            | R/W-0           | R/W-0      |  |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------|-------------------------------------|------------------|-----------------|------------|--|
| T1GINV <sup>(1)</sup> | TMR1GE <sup>(2)</sup>                                                                                                                                                                                                                                                                                               | T1CKPS1                                                            | T1CKPS0                | T1OSCEN                             | T1SYNC           | TMR1CS          | TMR10N     |  |
| bit 7                 |                                                                                                                                                                                                                                                                                                                     | L                                                                  |                        |                                     |                  |                 | bit 0      |  |
|                       |                                                                                                                                                                                                                                                                                                                     |                                                                    |                        |                                     |                  |                 |            |  |
| Legend:               |                                                                                                                                                                                                                                                                                                                     |                                                                    |                        |                                     |                  |                 |            |  |
| R = Readable          | bit                                                                                                                                                                                                                                                                                                                 | W = Writable                                                       | bit                    | U = Unimplem                        | nented bit, read | d as '0'        |            |  |
| -n = Value at F       | POR                                                                                                                                                                                                                                                                                                                 | '1' = Bit is set                                                   |                        | '0' = Bit is clea                   | ared             | x = Bit is unkr | nown       |  |
| bit 7                 | 1 = Timer1 ga                                                                                                                                                                                                                                                                                                       |                                                                    | h (Timer1 cou          | nts when gate i<br>nts when gate is |                  |                 |            |  |
| bit 6                 | TMR1GE: Tin<br>If TMR1ON =<br>This bit is igno<br>If TMR1ON =                                                                                                                                                                                                                                                       | ner1 Gate Ena<br><u>0:</u><br>ored<br><u>1:</u><br>on if Timer1 ga | ble bit <sup>(2)</sup> | J                                   | ,                |                 |            |  |
| bit 5-4               | <b>T1CKPS&lt;1:0&gt;:</b> Timer1 Input Clock Prescale Select bits<br>11 = 1:8 Prescale Value<br>10 = 1:4 Prescale Value<br>01 = 1:2 Prescale Value                                                                                                                                                                  |                                                                    |                        |                                     |                  |                 |            |  |
| bit 3                 | 00 = 1:1 Prescale Value<br><b>T1OSCEN:</b> LP Oscillator Enable Control bit<br><u>If INTOSC without CLKOUT oscillator is active:</u><br>1 = LP oscillator is enabled for Timer1 clock<br>0 = LP oscillator is off<br><u>Else:</u>                                                                                   |                                                                    |                        |                                     |                  |                 |            |  |
| bit 2                 | This bit is ignored. LP oscillator is disabled.<br><b>T1SYNC:</b> Timer1 External Clock Input Synchronization Control bit<br><u>TMR1CS = 1:</u><br>1 = Do not synchronize external clock input<br>0 = Synchronize external clock input<br><u>TMR1CS = 0:</u><br>This bit is ignored. Timer1 uses the internal clock |                                                                    |                        |                                     |                  |                 |            |  |
| bit 1                 | <b>TMR1CS:</b> Timer1 Clock Source Select bit<br>1 = External clock from T1CKI pin (on the rising edge)<br>0 = Internal clock (Fosc/4)                                                                                                                                                                              |                                                                    |                        |                                     |                  |                 |            |  |
| bit 0                 | TMR1ON: Tir<br>1 = Enables T<br>0 = Stops Tim                                                                                                                                                                                                                                                                       | Timer1                                                             |                        |                                     |                  |                 |            |  |
|                       |                                                                                                                                                                                                                                                                                                                     | -                                                                  |                        | dless of source.<br>or C2OUT, as s  |                  | T1GSS bit of    | the CMCON1 |  |

register, as a Timer1 gate source.

| TABLE 6-1: SUMMARY OF REGISTERS ASSOCIATED WITH TIME |
|------------------------------------------------------|
|------------------------------------------------------|

| Name   | Bit 7                                                                       | Bit 6  | Bit 5   | Bit 4               | Bit 3   | Bit 2  | Bit 1  | Bit 0     | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|-----------------------------------------------------------------------------|--------|---------|---------------------|---------|--------|--------|-----------|----------------------|---------------------------------|
| CMCON1 | —                                                                           | —      | —       | —                   | —       |        | T1GSS  | CMSYNC    | 10                   | 0010                            |
| INTCON | GIE                                                                         | PEIE   | T0IE    | INTE                | RAIE    | T0IF   | INTF   | RAIF      | 0000 000x            | 0000 000x                       |
| PIE1   | EEIE                                                                        | LVDIE  | CRIE    | C2IE <sup>(1)</sup> | C1IE    | OSFIE  | _      | TMR1IE    | 000-00-0             | 000-00-0                        |
| PIR1   | EEIF                                                                        | LVDIF  | CRIF    | C2IF <sup>(1)</sup> | C1IF    | OSFIF  | _      | TMR1IF    | 000-00-0             | 000-00-0                        |
| TMR1H  | Holding Register for the Most Significant Byte of the 16-bit TMR1 Register  |        |         |                     |         |        |        |           | xxxx xxxx            | uuuu uuuu                       |
| TMR1L  | Holding Register for the Least Significant Byte of the 16-bit TMR1 Register |        |         |                     |         |        |        | xxxx xxxx | uuuu uuuu            |                                 |
| T1CON  | T1GINV                                                                      | TMR1GE | T1CKPS1 | T1CKPS0             | T1OSCEN | T1SYNC | TMR1CS | TMR10N    | 0000 0000            | uuuu uuuu                       |

Legend: x = unknown, u = unchanged, - = unimplemented, read as '0'. Shaded cells are not used by the Timer1 module.

Note 1: PIC16F636/639 only.

NOTES:

#### 7.0 COMPARATOR MODULE

Comparators are used to inter face analog circuit s to a digital circuit by comp aring two analog v oltages and providing a digital indication of their relative magnitudes. The comparators are very useful mixed signal building blocks because t hey provide analog functionality independent of the program execution. The An alog Comparator module includes the following features:

- Dual comparators (PIC16F636/639 only)
- Multiple comparator configurations
- Comparator(s) output is available internally/externally
- Programmable output polarity
- Interrupt-on-change
- Wake-up from Sleep
- Timer1 gate (count enable)
- Output synchronization to Timer1 clock input
- Programmable voltage reference

#### 7.1 Comparator Overview

A comparator is shown in Figure 7-1 along with the relationship between the analog input levels and the digital output. When the analog voltage at VIN+ is less than the analog voltage at VIN+, 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.

The PIC12F635 contains a s ingle c omparator a s shown in Figure 7-2.

The PIC16F636/639 devices contains two comparators as shown in Figure 7-3 and Figure 7-4. The comparators are not independently configurable.



### FIGURE 7-2: COMPARATOR OUTPUT BLOCK DIAGRAM (PIC12F635)



#### FIGURE 7-3: COMPARATOR C1 OUTPUT BLOCK DIAGRAM (PIC16F636/639)



#### FIGURE 7-4: COMPARATOR C2 OUTPUT BLOCK DIAGRAM (PIC16F636/639)



#### 7.2 Analog Input Connection Considerations

A simplified c ircuit for an a nalog input is shown in Figure 7-5. Since the analog input pins share their connection with a di gital input, they have reverse biased ESD protection diodes to VDD and Vss. The analog input, therefore, must be between Vss and VDD. If the input voltage d eviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latch-up may occur.

A maximum source impedance of  $10 \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, should have very little leakage current to minimize inaccuracies introduced.

- Note 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 le vels on any pind efined as a digital input, may cause the input buffer to consume more current than is specified.



#### 7.3 Comparator Configuration

There are eight modes of operation for the comparator. The CM<2:0> bits of the CMCON0 register are used to select these modes as shown in Figures 7-6 and 7-7. I/O lines change as a function of the mode and a re designed as follows:

- Analog function (A): digital input buffer is disabled
- Digital function (D): comparator digital output, overrides port function
- Normal port function (I/O): independent of comparator

The port pins denoted as "A" will read as a '0' regardless of the state of the I/O pin or the I/O control TRIS bit. Pins used as analog inputs should also have the corresponding TR IS bit set to '1' to disable the digital output driver. Pins denoted as "D" should have the corresponding TRIS bit set to '0' to enable the digital output driver.

**Note:** Comparator interrupts should be disabled during a C omparator mo de c hange to prevent unintended interrupts.

#### FIGURE 7-6: COMPARATOR I/O OPERATING MODES (PIC12F635)





#### FIGURE 7-7: COMPARATOR I/O OPERATING MODES (PIC16F636/639)

#### 7.4 Comparator Control

The CMCON0 register (Register 7-1) provides access to the following comparator features:

- Mode selection
- Output state
- Output polarity
- Input switch

#### 7.4.1 COMPARATOR OUTPUT STATE

Each comparator state can always be read internally via the CxOUT bit of the CMCON0 register. The comparator state may also be directed to the CxOUT pin in the following modes:

#### PIC12F635

- CM<2:0> = 001
- CM<2:0> = 011
- CM<2:0> = 101

#### PIC16F636/639

• CM<2:0> = 110

When one of the ab ove mo des is selected, the associated TRIS bit of the CxOUT pin must be cleared.

#### 7.4.2 COMPARATOR OUTPUT POLARITY

Inverting the ou tput of a comparator is functionally equivalent to s wapping the comparator inputs. The polarity of a comparator output can be inverted by setting the CXINV bit of the CMCON0 register. Clearing CXINV results in a non-inverted ou tput. A complete table showing the output state versus input conditions and the polarity bit is shown in Table 7-1.

### TABLE 7-1: OUTPUT STATE VS. INPUT CONDITIONS

| Input Conditions | CxINV | CxOUT |
|------------------|-------|-------|
| VIN- > VIN+      | 0     | 0     |
| VIN- < VIN+      | 0     | 1     |
| VIN- > VIN+      | 1     | 1     |
| VIN- < VIN+      | 1     | 0     |

**Note:** CxOUT refers to both the register bit and output pin.

#### 7.4.3 COMPARATOR INPUT SWITCH

The inverting input of the comparators may be switched between two analog pins in the following modes:

#### PIC12F635

- CM<2:0> ╡01
- CM<2:0> =110

#### PIC16F636/639

- CM<2:0> =01 (Comparator C1 only)
- CM<2:0> =10 (Comparators C1 and C2)

In the above modes, both pins remain in Analog mode regardless of which pin is selected as the input. The CIS bit of the CMCON0 register controls the comparator input switch.

#### 7.5 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 r esponse time. The re sponse t ime o f th e comparator differs from the settling time of the voltage reference. Th erefore, b oth of th ese tim es mu st b e considered when determining the total response time to a comparator input change. See the Comparator and Voltage Spec ifications in **Section 15.0** " **Electrical Specifications**" for more details.

#### 7.6 Comparator Interrupt Operation

The comparator interrupt flag is set whenever there is a change in the output value of the comparator. Changes are recognized by means of a mismatch circuit which consists of two latches and an exclusive-or gate (see Figures 7-8 and 7-9). On e l atch is up dated with the comparator output level when the CMCON0 register is read. This latch retains the value until the next read of the CMCON0 register or the occurrence of a Reset. The other latch of the mismatch circuit is updated on every Q1 system clock. A mismatch condition will occur when a comparator output change is clocked through the second latch on the Q1 clock cycle. The mismatch condition will persist, holding the CxIF bit of the PIR1 register true, until either the CMCON0 register is read or the comparator output returns to the previous state.

| Note: | A write operation to the CMCON0 register   |
|-------|--------------------------------------------|
|       | will als o cl ear the mi smatch co ndition |
|       | because a II w rites include a read        |
|       | operation at the be ginning of the w rite  |
|       | cycle.                                     |

Software will need to maintain information about the status of the comparator output to determine the actual change that has occurred.

The C xIF bit of the PIR 1 register, is the comparator interrupt flag. T his bit m ust b e re set in software b y clearing it to '0'. Since it is also possible to write a '1' to this register, a simulated interrupt may be initiated.

The CxIE bit of the PIE1 register and the PEIE and GIE bits of the INTCON register must all be set to enable comparator interrupts. If any of these bits are cleared, the interrupt is not enabled, although the CxIF bit of the PIR1 register will still be set if an interrupt condition occurs.

The user, in the Interrupt Service Routine, can clear the interrupt in the following manner:

- a) Any read or write of CMCON0. This will end the mismatch condition. See Figures 7-8 and 7-9.
- b) Clear the CxIF interrupt flag.

A persistent mismatch condition will preclude clearing the CxIF interrupt flag. Reading CMCON0 will end the mismatch c ondition and al low the C xIF b it t o b e cleared.

Note: If a change in the C MCON0 re gister (CxOUT) s hould o ccur when a r ead operation is being executed (start of the Q2 cycle), then the CxIF interrupt flag may not get set.



#### FIGURE 7-9: COMPARATOR INTERRUPT TIMING WITH CMCON0 READ



- Note 1: If a ch ange in the CMCON0 reg ister (CxOUT) should oc cur whe n a rea d operation is being executed (start of the Q2 c ycle), then the C xIF of th e PIR 1 register interrupt flag may not get set.
  - When either comparator is first enable d, bias circuitry in the Comparator module may cause an invalid ou tput from t he comparator until the bias circuity is stable. Allow about 1 μs for bias settling then clear the mismatch condition and interrupt flags before enabling comparator interrupts.

#### 7.7 Operation During Sleep

The comparator, if enabled before entering Sleep mode, remains ac tive d uring Sleep. The addition al current consumed by the comparator is shown separately in the **Section 15.0 "Electr ical Specifications"**. I f the comparator is not used to wake the device, power consumption can be minimized while in Sleep mode by turning off the comparator. The comparator is turned off by selecting mode CM<2:0> = 000 or CM<2:0> = 111 of the CMCON0 register.

A change to the comparator output can wake-up the device from Sleep. To enable the comparator to wake the device from Sleep, the CxIE bit of the PIE1 register and the PEIE bit of the INTCON register must be set. The instruction following the Sleep instruction al ways executes following a wake from Sleep. If the GIE bit of the INTCON register is also set, the device will then execute the Interrupt Service Routine.

#### 7.8 Effects of a Reset

A d evice Re set forces the CMCON0 and CM CON1 registers to their Reset states. This forces the Comparator mo dule to be in th e Comparator R eset mode (CM<2:0> = 000). T hus, a II c omparator in puts a re analog inputs with the comparator disabled to consume the smallest current possible.

#### **REGISTER 7-1:** CMCON0: COMPARATOR CONFIGURATION REGISTER (PIC12F635)

| U-0             | R-0                                                                                                                                                                                                                                      | U-0                                                                                                                                                                                                                                                                                                           | R/W-0                                                                                                                                                                                                         | R/W-0                                                                                                                                                                                                                                                  | R/W-0                                                                                                                                 | R/W-0                                                                                                    | R/W-0            |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------|
| —               | COUT                                                                                                                                                                                                                                     | —                                                                                                                                                                                                                                                                                                             | CINV                                                                                                                                                                                                          | CIS                                                                                                                                                                                                                                                    | CM2                                                                                                                                   | CM1                                                                                                      | CM0              |
| bit 7           |                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          | bit 0            |
|                 |                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| Legend:         | 1.5                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       | (0)                                                                                                      |                  |
| R = Readable    |                                                                                                                                                                                                                                          | W = Writable bit                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                               | •                                                                                                                                                                                                                                                      | ented bit, read as                                                                                                                    |                                                                                                          |                  |
| -n = Value at F | POR                                                                                                                                                                                                                                      | '1' = Bit is set                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                               | '0' = Bit is clear                                                                                                                                                                                                                                     | ed                                                                                                                                    | x = Bit is unknov                                                                                        | wn               |
| bit 7           | Unimplement                                                                                                                                                                                                                              | ed: Read as '0'                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| bit 6           | COUT:         Compa           When CINV =         1           1 = VIN+ > VIN         0           0 = VIN+ < VIN                                                                                                                          | -<br>-<br>1 <u>:</u><br>-                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| bit 5           | Unimplement                                                                                                                                                                                                                              | ed: Read as '0'                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| bit 4           | <b>CINV:</b> Compare<br>1 = Output invo<br>0 = Output not                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                               | on bit                                                                                                                                                                                                        |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| bit 3           | CIS: Comparator Input Switch bit<br>$\frac{When CM<2:0> = 110 \text{ or } 101:}{1 = CIN+ \text{ connects to VIN-}}$ $0 = CIN- \text{ connects to VIN-}$ $\frac{When CM<2:0> = 0xx \text{ or } 100 \text{ or } 111:}{CIS has no effect.}$ |                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                               |                                                                                                                                                                                                                                                        |                                                                                                                                       |                                                                                                          |                  |
| bit 2-0         | 000 = CIN pin:<br>001 = CIN pin:<br>010 = CIN pin:<br>011 = CIN-pin<br>Compa<br>100 = CIN-pin<br>availab<br>101 = CIN pin:<br>Compa<br>110 = CIN pin:<br>Compa                                                                           | nparator Mode bits<br>s are configured as<br>s are configured as<br>a sare configured as<br>a sis configured as a<br>arator output, CVRE<br>n is configured as a<br>ole internally, CVRE<br>s are configured as<br>arator output, CVRE<br>s are configured as<br>arator output availal<br>s are configured as | analog, COUT<br>analog, COUT<br>analog, COUT<br>analog, CIN+ pin<br>F is non-inverting<br>nalog, CIN+ pin<br>is non-inverting<br>analog and mul<br>F is non-inverting<br>analog and mul<br>ble internally, CV | bin configured as <i>l</i> ,<br>bin configured as C<br>bin configured as <i>l</i> /<br>is configured as <i>l</i> /<br>g input<br>is configured as <i>l</i> /<br>g input<br>tiplexed, COUT pir<br>g input<br>tiplexed, COUT pir<br>/REF is non-invertin | Comparator outpu<br>(O, Comparator o<br>D, COUT pin con<br>D, COUT pin is con<br>n is configured as<br>n is configured as<br>ng input | it<br>international and the second second<br>figured as I/O, C<br>figured as I/O, C<br>figured as I/O, C | omparator output |

| R-0           | R-0                            | R/W-0                              | R/W-0           | R/W-0                             | R/W-0           | R/W-0           | R/W-0 |
|---------------|--------------------------------|------------------------------------|-----------------|-----------------------------------|-----------------|-----------------|-------|
| C2OUT         | C1OUT                          | C2INV                              | C1INV           | CIS                               | CM2             | CM1             | CM0   |
| bit 7         | l                              | 1                                  | I               |                                   | L               |                 | bit 0 |
|               |                                |                                    |                 |                                   |                 |                 |       |
| Legend:       |                                |                                    |                 |                                   |                 |                 |       |
| R = Readabl   | le bit                         | W = Writable                       | bit             | U = Unimpler                      | mented bit, rea | d as '0'        |       |
| -n = Value at | t POR                          | '1' = Bit is set                   |                 | '0' = Bit is cle                  | ared            | x = Bit is unkr | nown  |
|               |                                |                                    |                 |                                   |                 |                 |       |
| bit 7         |                                | parator 2 Outp                     | ut bit          |                                   |                 |                 |       |
|               | When C2INV                     |                                    |                 |                                   |                 |                 |       |
|               | 1 = C2 VIN+ :<br>0 = C2 VIN+ · |                                    |                 |                                   |                 |                 |       |
|               | When C2INV                     | -                                  |                 |                                   |                 |                 |       |
|               | 1 = C2 VIN+ ·                  |                                    |                 |                                   |                 |                 |       |
|               | 0 = C2 VIN+                    |                                    |                 |                                   |                 |                 |       |
| bit 6         | C1OUT: Com                     | nparator 1 Outp                    | ut bit          |                                   |                 |                 |       |
|               | When C1INV                     | <u>' = 0:</u>                      |                 |                                   |                 |                 |       |
|               | 1 = C1 VIN+ :                  | > C1 VIN-                          |                 |                                   |                 |                 |       |
|               | 0 = C1 VIN+ ·                  |                                    |                 |                                   |                 |                 |       |
|               | When C1INV                     |                                    |                 |                                   |                 |                 |       |
|               | 1 = C1 VIN+ ·<br>0 = C1 VIN+ : |                                    |                 |                                   |                 |                 |       |
| bit 5         |                                | parator 2 Outpu                    | it Inversion hi | t                                 |                 |                 |       |
| bit 0         | 1 = C2 outpu                   |                                    |                 |                                   |                 |                 |       |
|               | •                              | t not inverted                     |                 |                                   |                 |                 |       |
| bit 4         | C1INV: Com                     | parator 1 Outpu                    | It Inversion bi | t                                 |                 |                 |       |
|               | 1 = C1 Outpu                   | ut inverted                        |                 |                                   |                 |                 |       |
|               | 0 = C1 Outpu                   | ut not inverted                    |                 |                                   |                 |                 |       |
| bit 3         | CIS: Compar                    | ator Input Swite                   | ch bit          |                                   |                 |                 |       |
|               | When CM<2:                     | : <b>0&gt; =</b> 010:              |                 |                                   |                 |                 |       |
|               |                                | onnects to C1 V                    |                 |                                   |                 |                 |       |
|               |                                | onnects to C2 \<br>nnects to C1 Vı |                 |                                   |                 |                 |       |
|               |                                | nnects to C2 V                     |                 |                                   |                 |                 |       |
|               | When CM<2:                     |                                    |                 |                                   |                 |                 |       |
|               |                                | onnects to C1 V                    |                 |                                   |                 |                 |       |
|               |                                | nnects to C1 Vi                    |                 |                                   |                 |                 |       |
| bit 2-0       |                                | omparator Mode                     |                 |                                   |                 |                 |       |
|               | -                              |                                    | -               | nfigured as anal                  | og              |                 |       |
|               |                                | inputs multiplex                   |                 |                                   |                 |                 |       |
|               |                                | ommon referen                      |                 |                                   |                 |                 |       |
|               | 100 <b>= Two in</b>            | dependent com                      | parators        |                                   |                 |                 |       |
|               |                                | dependent con                      |                 |                                   |                 |                 |       |
|               |                                |                                    |                 | common refere<br>figured as digit |                 |                 |       |
|               | 111 - Compo                    |                                    |                 | inguieu as uigit                  |                 |                 |       |
|               |                                |                                    |                 |                                   |                 |                 |       |

#### REGISTER 7-2: CMCON0: COMPARATOR CONFIGURATION REGISTER (PIC16F636/639)

#### 7.9 Comparator Gating Timer1

This feature can be used to time the duration or interval of analog events. Clearing the T1GSS bit of the CMCON1 register will enable T imer1 to increment based on the output of the comparator (or Comparator C2 for PIC16F636/639). This requires that Timer1 is on and gating is enabled. See **Section 6.0 "Timer1 Module with Gate Control"** for details.

It is recommended to synchronize the comparator with Timer1 by setting the CxSYNC bit when the comparator is used as the Timer1 gate source. This ensures Timer1 does not miss an increment if the comparator changes during an increment.

| Note: | References to the co mparator in thi s  | ; |
|-------|-----------------------------------------|---|
|       | section sp ecifically are refer ring to |   |
|       | Comparator C2 on the PIC16F636/639.     |   |

### 7.10 Synchronizing Comparator Output to Timer1

The comparator (or Comparator C2 for PIC16F636/639) output can be synchronized with Timer1 by setting the CxSYNC bit of the C MCON1 register. When enabled, the comparator output is latched on the falling edge of the Timer1 clock so urce. If a presc aler is used with Timer1, the com parator output is latched after the prescaling function. To prevent a r ace condition, the comparator output is latched on the falling edge of the Timer1 clock sourceand Timer1 increments on the ising edge of its clock source. See the C omparator Block Diagram (Figure 7-2) and the Timer1 Block D iagram (Figure 6-1) for more information.

| Note: | References to the co |                | mpa  | arator in thi | s  |
|-------|----------------------|----------------|------|---------------|----|
|       | section              | specifically   | are  | referring     | to |
|       | Compara              | ator C2 on the | PIC1 | 6F636/639.    |    |

| U-0          | U-0 | U-0          | U-0 | U-0          | U-0               | R/W-1    | R/W-0  |
|--------------|-----|--------------|-----|--------------|-------------------|----------|--------|
| —            | —   | —            | —   | —            | —                 | T1GSS    | CMSYNC |
| bit 7        |     |              |     |              |                   |          | bit 0  |
|              |     |              |     |              |                   |          |        |
| Legend:      |     |              |     |              |                   |          |        |
| R = Readable | hit | W = Writable | bit | U = Unimplen | nented hit read   | 1 as '0' |        |
| R = Reauable | bit |              |     | e ep.e       | ionitou bit, rout |          |        |

#### REGISTER 7-3: CMCON1: COMPARATOR CONFIGURATION REGISTER (PIC12F635)

| bit 7-2 | <b>Unimplemented:</b>                   | Read as '0' |
|---------|-----------------------------------------|-------------|
|         | ••••••••••••••••••••••••••••••••••••••• |             |

| bit 1 | T1GSS: Timer1 Gate Source Select bit <sup>(1)</sup>                                        |
|-------|--------------------------------------------------------------------------------------------|
|       | 1 = Timer1 Gate Source is $\overline{T1G}$ pin (pin should be configured as digital input) |
|       | <ul><li>0 = Timer1 Gate Source is comparator output</li></ul>                              |
| bit 0 | CMSYNC: Comparator Output Synchronization bit <sup>(2)</sup>                               |
|       | 1 = Output is synchronized with falling edge of Timer1 clock                               |
|       | 0 = Output is asynchronous                                                                 |

Note 1: Refer to Section 6.6 "Timer1 Gate".

#### REGISTER 7-4: CMCON1: COMPARATOR CONFIGURATION REGISTER (PIC16F636/639)

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-0  |
|-------|-----|-----|-----|-----|-----|-------|--------|
| —     | —   | —   | —   | —   |     | T1GSS | C2SYNC |
| bit 7 |     |     |     |     |     |       | bit 0  |

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | , read as '0'      |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

| bit 7-2 | Unimplemented: Read as '0'                                                                                                                                                                   |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 1   | T1GSS: Timer1 Gate Source Select bit <sup>(1)</sup>                                                                                                                                          |
|         | <ul> <li>1 = Timer1 gate source is T1G pin (pin should be configured as digital input)</li> <li>0 = Timer1 gate source is Comparator C2 output</li> </ul>                                    |
| bit 0   | <ul> <li>C2SYNC: Comparator C2 Output Synchronization bit<sup>(2)</sup></li> <li>1 = Output is synchronized with falling edge of Timer1 clock</li> <li>0 = Output is asynchronous</li> </ul> |

Note 1: Refer to Section 6.6 "Timer1 Gate".

2: Refer to Figure 7-4.

<sup>2:</sup> Refer to Figure 7-2.

#### 7.11 Comparator Voltage Reference

The C omparator V oltage R eference module provides an i nternally ge nerated vol tage re ference for the comparators. The following features are available:

- Independent from Comparator operation
- Two 16-level voltage ranges
- · Output clamped to Vss
- Ratiometric with VDD
- Fixed Voltage Reference

The VRCO N reg ister (Reg ister 7-5) c ontrols the Voltage Reference module shown in Figure 7-10.

#### 7.11.1 INDEPENDENT OPERATION

The comparator voltage reference is independent of the comparator configuration. Setting the VREN bit of the VRCON register will enable the voltage reference.

#### 7.11.2 OUTPUT VOLTAGE SELECTION

The CVREF voltage reference has 2 ran ges with 16 voltage lev els in eac h ra nge. R ange se lection i s controlled by the VRR bit of the VRCON register. The 16 levels are set with the VR<3:0> bits of the VRCON register.

The CVREF output voltage is determined by the following equations:

#### EQUATION 7-1: CVREF OUTPUT VOLTAGE (INTERNAL CVREF)

VRR = 1 (low range):  $CVREF (= VR < 3:0 > /24) \times VDD$  VRR = 0 (high range):  $CVREF = (VDD/4) + (VR < 3:0 > \times VDD/32)$ 

#### EQUATION 7-2: CVREF OUTPUT VOLTAGE (EXTERNAL CVREF)

VRR = 1 (low range):

 $CVREF( = VR < 3:0 > /24) \times VLADDER$ 

VRR = 0 (high range):

 $CVREF = (VLADDER/4) + (VR < 3:0 > \times VLADDER/32)$ 

VLADDER = VDD or ([VREF+] - [VREF-]) or VREF+

The full range of VSS to VDD cannot be realized due to the construction of the module. See Figure 7-10.

#### 7.11.3 OUTPUT CLAMPED TO Vss

The CVREF output voltage can be set to Vs s with no power consumption by configuring VRCON as follows:

- •V REN = 0
- •V RR = 1
- •V R<3:0> = 0000

This allows the comparator to detect a zero-crossing while not consuming additional CVREF module current.

#### 7.11.4 OUTPUT RATIOMETRIC TO VDD

The comparator voltage reference is V DD derived and therefore, the CVREF output changes with fluctuations in VDD. The tested absolute accuracy of the Comparator Voltage Reference can be found in **Section 15.0 "Electrical Specifications"**.

| R/W-0        | U-0                                                                                                                                | R/W-0                            | U-0    | R/W-0            | R/W-0            | R/W-0           | R/W-0 |
|--------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--------|------------------|------------------|-----------------|-------|
| VREN         | —                                                                                                                                  | VRR                              | —      | VR3              | VR2              | VR1             | VR0   |
| bit 7        |                                                                                                                                    |                                  |        |                  |                  |                 | bit 0 |
|              |                                                                                                                                    |                                  |        |                  |                  |                 |       |
| Legend:      |                                                                                                                                    |                                  |        |                  |                  |                 |       |
| R = Readab   | le bit                                                                                                                             | W = Writable I                   | bit    | U = Unimpler     | nented bit, read | d as '0'        |       |
| -n = Value a | t POR                                                                                                                              | '1' = Bit is set                 |        | '0' = Bit is cle | ared             | x = Bit is unkr | nown  |
| bit 7        |                                                                                                                                    | cuit powered o<br>cuit powered d |        | ain and CVREF    | = Vss.           |                 |       |
| bit 6        | Unimplemen                                                                                                                         | ted: Read as '                   | o'     |                  |                  |                 |       |
| bit 5        | VRR: CVREF                                                                                                                         | Range Selectic                   | on bit |                  |                  |                 |       |
|              | 1 = Low range<br>0 = High rang                                                                                                     |                                  |        |                  |                  |                 |       |
| bit 4        | Unimplemen                                                                                                                         | ted: Read as 'o                  | 0'     |                  |                  |                 |       |
| bit 3-0      | <b>VR&lt;3:0&gt;:</b> CVREF Value Selection bits ( $0 \le VR<3$ : $0 \ge 15$ )<br><u>When VRR = 1</u> : CVREF = (VR<3:0>/24) * VDD |                                  |        |                  |                  |                 |       |

#### REGISTER 7-5: VRCON: VOLTAGE REFERENCE CONTROL REGISTER



When VRR = 0: CVREF = VDD/4 + (VR < 3:0 > /32) \* VDD



### TABLE 7-2:SUMMARY OF REGISTERS ASSOCIATED WITH THE COMPARATOR AND VOLTAGE<br/>REFERENCE MODULES

| Name   | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|-------|-------|--------|--------|--------|--------|--------|--------|----------------------|---------------------------------|
| CMCON0 | _     | COUT  | _      | CINV   | CIS    | CM2    | CM1    | CM0    | -0-0 0000            | -0-0 0000                       |
| CMCON1 | _     | —     | _      | _      | _      | _      | T1GSS  | CMSYNC | 10                   | 10                              |
| INTCON | GIE   | PEIE  | TOIE   | INTE   | RAIE   | TOIF   | INTF   | RAIF   | 0000 000x            | 0000 000x                       |
| PIE1   | EEIE  | LVDIE | CRIE   | _      | C1IE   | OSFIE  | _      | TMR1IE | 000- 00-0            | 000- 00-0                       |
| PIR1   | EEIF  | LVDIF | CRIF   | _      | C1IF   | OSFIF  | _      | TMR1IF | 000- 00-0            | 000- 00-0                       |
| PORTA  | _     | —     | RA5    | RA4    | RA3    | RA2    | RA1    | RA0    | xx xxxx              | uu uuuu                         |
| PORTC  | _     | _     | RC5    | RC4    | RC3    | RC2    | RC1    | RC0    | xx xxxx              | uu uuuu                         |
| TRISA  | _     | —     | TRISA5 | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 11 1111              | 11 1111                         |
| TRISC  | —     | _     | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 11 1111              | 11 1111                         |
| VRCON  | VREN  | _     | VRR    | _      | VR3    | VR2    | VR1    | VR0    | 0-0- 0000            | 0-0- 0000                       |

 $\label{eq:logend: Legend: Legend: u = unchanged, - = unimplemented, read as `0'. Shaded cells are not used for comparator.$ 

NOTES:

#### PROGRAMMABLE 8.0 LOW-VOLTAGE DETECT (PLVD) MODULE

The Pro grammable Lo w-Voltage D etect (PL VD) module is a power supply detector which monitors the internal power supply. This module is typically used in key f obs and o ther de vices, w here ce rtain ac tions need to be taken as a result of a falling battery voltage.

· Eight programmable trip points

- Interrupt on falling VDD
- Stable reference indication
- · Operation during Sleep

A Block diagram of the PLVD module is shown in Figure 8-1.

The PLVD module includes the following capabilities:





#### FIGURE 8-1: PLVD BLOCK DIAGRAM

#### 8.1 PLVD Operation

To setup the PL VD for o peration, the following steps must be taken:

- Enable the module by setting the LVDEN bit of the LVDCON register.
- Configure the trip point by setting the LVDL<2:0> bits of the LVDCON register.
- Wait for the reference voltage to become stable. Refer to Section 8.4 "Stable Reference Indication".
- Clear the LVDIF bit of the PIRx register.

The LVDIF bit will be s et when V DD falls be low the PLVD trip point. The LVDIF bit remains set until cleared by software. Refer to Figure 8-2.

#### 8.2 **Programmable Trip Point**

The PLVD trip point is selectable from one of eight voltage levels. The LVDL bits of the LVDCON register select the t rip point. Ref er to Register 8-1 for the available PLVD trip points.

#### 8.3 Interrupt on Falling VDD

When V DD falls below the PLVD trip point, the falling edge detector will set the LVDIF bit. See Figure 8-2. An interrupt will be generated if the following bits are also set:

- GIE and PEIE bits of the INTCON register
- LVDIE bit of the PIEx register

The LVDIF bit must be deared by software. An interrupt can be generated from a simulated PLVD event when the LVDIF bit is set by software.

#### 8.4 Stable Reference Indication

When the PLVD module is enabled, the reference voltage must be allowed to stabilize before the PLVD will provide a valid res ult. R efer t o *Electrical Se ction, PLVD Characteristics* for the stabilization time.

When the HFINTOSC is running, the IRVST bit of the LVDCON register indicates the stability of the voltage reference. The v oltage reference is stable when the IRVST bit is set.

#### 8.5 Operation During Sleep

To wake from Sleep, set the LVDIE bit of the PIE $\underline{x}$  register and the PEIE bit of the INTCON register. When the LVDIE and PEIE bits are set, the device will wake from Sleep and execute the next instruction. If the GIE bit is also set, the program will call the Interrupt Service Routine upon completion of the first instruction after waking from Sleep.

| U-0          | U-0                         | R-0                  | R/W-0          | U-0              | R/W-1            | R/W-0            | R/W-0 |
|--------------|-----------------------------|----------------------|----------------|------------------|------------------|------------------|-------|
| _            | —                           | IRVST <sup>(1)</sup> | LVDEN          | —                | LVDL2            | LVDL1            | LVDL0 |
| bit 7        |                             |                      |                |                  |                  |                  | bit   |
| Legend:      |                             |                      |                |                  |                  |                  |       |
| R = Readab   | ole bit                     | W = Writable         | bit            | U = Unimplen     | nented bit, read | l as '0'         |       |
| -n = Value a | t POR                       | '1' = Bit is set     |                | '0' = Bit is cle | ared             | x = Bit is unkr  | nown  |
| bit 7-6      | Unimpleme                   | nted: Read as '      | 0'             |                  |                  |                  |       |
| bit 5        | -                           | nal Reference V      |                | Status Flag hit  | (1)              |                  |       |
| on o         |                             | s that the PLVD      |                |                  |                  |                  |       |
|              |                             | s that the PLVD      |                | •                |                  | enabled          |       |
| bit 4        | LVDEN: Low                  | v-Voltage Detect     | Module Enal    | ole bit          |                  |                  |       |
|              | 1 = Enables                 | PLVD Module,         | powers up PL   | VD circuit and   | supporting refer | ence circuitry   |       |
|              | 0 = Disables                | PLVD Module,         | powers down    | PLVD circuit a   | nd supporting r  | eference circuit | try   |
| bit 3        | Unimpleme                   | nted: Read as '      | 0'             |                  |                  |                  |       |
| bit 2-0      | LVDL<2:0>:                  | Low-Voltage De       | etection Level | bits (nominal v  | alues)           |                  |       |
|              | 111 <b>= 4.5</b> V          |                      |                |                  |                  |                  |       |
|              | 110 = 4.2V                  |                      |                |                  |                  |                  |       |
|              | 101 = 4.0V                  |                      |                |                  |                  |                  |       |
|              | 100 = 2.3V (                | default)             |                |                  |                  |                  |       |
|              | 011 = 2.2V<br>010 = 2.1V    |                      |                |                  |                  |                  |       |
|              | 010 = 2.1V<br>001 = 2.0V(2) | 2)                   |                |                  |                  |                  |       |
|              | 001 - 2.00                  |                      |                |                  |                  |                  |       |

#### REGISTER 8-1: LVDCON: LOW-VOLTAGE DETECT CONTROL REGISTER

- **Note 1:** The IRVST bit is usable only when the HFINTOSC is running.
  - 2: Not tested and below minimum operating conditions.

#### TABLE 8-1: REGISTERS ASSOCIATED WITH PROGRAMMABLE LOW-VOLTAGE DETECT

| Name   | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|--------|-------|-------|-------|-------|-------|-------|--------|----------------------|---------------------------------|
| INTCON | GIE PE | IE    | T0IE  | INTE  | RAIE  | T0IF  | INTF  | RAIF   | x000 000x            | 0000 000x                       |
| PIE1   | OSFIE  | C2IE  | C1IE  | LCDIE | _     | LVDIE | —     | CCP2IE | 0000 -0-0            | 0000 -0-0                       |
| PIR1   | OSFIF  | C2IF  | C1IF  | LCDIF | —     | LVDIF | —     | CCP2IF | 0000 -0-0            | 0000 -0-0                       |
| LVDCON | —      | _     | IRVST | LVDEN | _     | LVDL2 | LVDL1 | LVDL0  | 00 -100              | 00 -100                         |

Legend: x = unknown, - = unimplemented read as '0'. Shaded cells are not used by the PLVD module.

NOTES:

#### 9.0 DATA EEPROM MEMORY

The EEPROM data memory is readable and writable during normal operation (full VDD range). This memory is no t di rectly ma pped i n t he r egister f ile s pace. Instead, it is indirectly addressed through the Special Function Registers. There are four SFRs used to read and write this memory:

- EECON1
- EECON2 (not a physically implemented register)
- EEDAT
- EEADR

EEDAT holds the 8-bit data for read/write and EEADR holds the a ddress of t he EEPROM location b eing accessed. P IC16F636/639 ha s 256 bytes of d ata EEPROM and the PIC12F635 has 128 bytes.

The EEPROM data memory allows byte read and write. A by te write a utomatically e rases t he l ocation an d writes the new data (erase before write). The EEPROM data memory is rated for high erase/write cycles. The write time is controlled by an on-chip timer. The write time will vary with voltage and temperature as well as from chip-to-chip. Please refer to A/C specifications in **Section 15.0 "El ectrical Spe cifications"** for ex act limits.

When the d ata m emory is code-protected, the C PU may continue to rea d and write the data EEPRO M memory. The device programmer can no longer access the data EEPROM data and will read zeroes.

| R/W-0  |
|--------|--------|--------|--------|--------|--------|--------|--------|
| EEDAT7 | EEDAT6 | EEDAT5 | EEDAT4 | EEDAT3 | EEDAT2 | EEDAT1 | EEDAT0 |
| bit 7  |        |        |        |        |        |        | bit 0  |

### REGISTER 9-1: EEDAT: EEPROM DATA REGISTER

| Legend:           |                  |                       |                    |
|-------------------|------------------|-----------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit | t, read as '0'     |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

bit 7-0 **EEDATn**: Byte Value to Write To or Read From Data EEPROM bits

#### REGISTER 9-2: EEADR: EEPROM ADDRESS REGISTER

| R/W-0                 | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  | R/W-0  |
|-----------------------|--------|--------|--------|--------|--------|--------|--------|
| EEADR7 <sup>(1)</sup> | EEADR6 | EEADR5 | EEADR4 | EEADR3 | EEADR2 | EEADR1 | EEADR0 |
| bit 7                 |        |        |        |        |        |        | bit 0  |

| Legend:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | d as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

bit 7-0 **EEADR**: Specifies One of 256 Locations for EEPROM Read/Write Operation bits

**Note 1:** PIC16F636/639 only. Read as '0' on PIC12F635.

#### 9.1 EECON1 AND EECON2 Registers

EECON1 is the control register with four low-order bits physically im plemented. The upp er f our bits a re non-implemented and read as '0's.

Control bits RD and WR in itiate read an d w rite, respectively. These bits cannot be cleared, only set in software. They are cleared in hardware at completion of the read or write operation. The inability to clear the WR bit in software prevents the accidental, premature termination of a write operation.

The WREN bit, when set, will allow a write operation. On power-up, the WREN bit is clear. The WRERR bit is set when a write operation is interrupted by a MCLR Reset, or a W DT T ime-out R eset during n ormal operation. In these situations, following Reset, the user can c heck the W RERR b it, c lear it an d rew rite th e location. T he data a nd a ddress w ill be cleared. Therefore, the EEDAT and EEADR registers will need to be re-initialized.

Interrupt flag, EEIF bit of the PIR1 register, is set when write is complete. This bit must be cleared in software.

EECON2 is not a physical register. Reading EECON2 will re ad a II ' 0's. T he E ECON2 register i s used exclusively in the data EEPROM write sequence.

Note: The EECON1, EEDAT and EEADR registers should not be modified during a data EEPROM write (WR bit = 1).

#### REGISTER 9-3: EECON1: EEPROM CONTROL REGISTER

| U-0   | U-0 | U-0 | U-0 | R/W-x | R/W-0 | R/S-0 | R/S-0 |
|-------|-----|-----|-----|-------|-------|-------|-------|
| —     | —   | —   | —   | WRERR | WREN  | WR    | RD    |
| bit 7 |     |     |     |       |       |       | bit 0 |

| Legend:                 |                  |                             |                    |
|-------------------------|------------------|-----------------------------|--------------------|
| S = Bit can only be set |                  |                             |                    |
| R = Readable bit        | W = Writable bit | U = Unimplemented bit, read | 1 as '0'           |
| -n = Value at POR       | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 7-4 | Unimplemented: Read as '0'                                                                                                                                                                                             |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 3   | WRERR: EEPROM Error Flag bit                                                                                                                                                                                           |
|         | <ul> <li>1 = A write operation is prematurely terminated (any MCLR Reset, any WDT Reset during normal operation or BOR Reset)</li> <li>0 = The write operation completed</li> </ul>                                    |
| bit 2   | WREN: EEPROM Write Enable bit                                                                                                                                                                                          |
|         | <ul><li>1 = Allows write cycles</li><li>0 = Inhibits write to the data EEPROM</li></ul>                                                                                                                                |
| bit 1   | WR: Write Control bit                                                                                                                                                                                                  |
|         | <ul> <li>1 = Initiates a write cycle (The bit is cleared by hardware once write is complete. The WR bit can only be set, not cleared, in software.)</li> <li>0 = Write cycle to the data EEPROM is complete</li> </ul> |
| bit 0   | RD: Read Control bit                                                                                                                                                                                                   |
|         | 1 = Initiates an EEPROM read (Read takes one cycle. RD is cleared in hardware. The RD bit can only<br>be set, not cleared, in software.)                                                                               |

0 = Does not initiate an EEPROM read

#### 9.2 Reading the EEPROM Data Memory

To read a data memory location, the user must write the address to the EEADR register and then set control bit RD of the EECON1 register, as shown in Example 9-1. The data is a vailable, in the v ery next c ycle, in the EEDAT register. Therefore, it can be read in the next instruction. EEDAT holds this value until another read, or until it is written to by the user (during a write operation).

| BANKSEL | EEADR       | ;                |
|---------|-------------|------------------|
| MOVLW   | CONFIG_ADDR | ;                |
| MOVWF   | EEADR       | ;Address to read |
| BSF     | EECON1,RD   | ;EE Read         |
| MOVF    | EEDAT,W     | ;Move data to W  |

#### 9.3 Writing to the EEPROM Data Memory

To write an EEPROM data location, the user must first write the address to the EEADR register and the data to the EEDAT register. Then the user must follow a specific sequence to initiate the write for each byte, as shown in Example 9-2.

The write will not initiate if the above sequence is not exactly followed (write 55h to EECON2, write AAh to EECON2, then set WR bit) for each byte. We strongly recommend that in terrupts be dis abled du ring thi s code segment. A cycle count is executed during the required sequence. Any number that is not equal to the required cycles to execute the required sequence will prevent the data from being written into the EEPROM.

Additionally, the WREN bit in EECON1 must be set to enable write. This mechanism prevents accidental writes to dat a E EPROM d ue to errant ( unexpected) code execution (i.e., lost program). The user should keep the WREN bit c lear at all time s, except w hen updating EEPROM. The WREN bit is not cleared by hardware.

After a write sequence has been initiated, clearing the WREN bit will not affect this write cycle. The WR bit will be inhibited from being set unless the WREN bit is set.

At the completion of the write cy cle, the WR bit is cleared in ha rdware and the E E Write Complete Interrupt F lag bit (EEIF) is set. The user can either enable this interrupt or poll this bit. The EEIF bit of the PIR1 register must be cleared by software.

|      | BANKSEL | EEADR       | ;                |
|------|---------|-------------|------------------|
|      | BSF     | EECON1,WREN | ;Enable write    |
|      | BCF     | INTCON,GIE  | ;Disable INTs    |
|      | MOVLW   | 55h         | ;Unlock write    |
| ъ ө  | MOVWF   | EECON2      | ;                |
| nire | MOVLW   | AAh         | ;                |
| edu  | MOVWF   | EECON2      | ;                |
| шv   | BSF     | EECON1,WR   | ;Start the write |
|      | BSF     | INTCON,GIE  | ;Enable INTS     |

#### 9.4 Write Verify

Depending o n th e a pplication, good p rogramming practice may dictate that the value written to the data EEPROM should be verified (see Example 9-3) to the desired value to be written.

#### EXAMPLE 9-3: WRITE VERIFY

| BANKSEL | EEDAT     | ;                                          |
|---------|-----------|--------------------------------------------|
| MOVF    | EEDAT,W   | ;EEDAT not changed<br>;from previous write |
| BSF     | EECON1,RD | ;YES, Read the<br>;value written           |
| XORWF   | EEDAT,W   | ;                                          |
| BTFSS   | STATUS, Z | ;Is data the same                          |
| GOTO    | WRITE_ERR | ;No, handle error                          |
| :       |           | ;Yes, continue                             |

#### 9.4.1 USING THE DATA EEPROM

The data EEPROM is a high-endurance, byte addressable array that has been op timized for the storage of f requently changing in formation (e.g., program v ariables or o ther d ata that are upd ated often). Whe n v ariables in n on es ection ch ange frequently, while v ariables in a nother section do n ot change, it is possible to exceed the total number of write cycles to the EEPROM (s pecification D124) without exceeding the total number of write cycles to a single byte (specifications D120 and D120A). If this is the c ase, the n are fresh of the array mu st b e performed. For t his reas on, va riables that ch ange infrequently (such as constants, IDs, calibration, etc.) should be stored in Flash program memory.

#### 9.5 Protection Against Spurious Write

There are conditions when the user may not want to write to the data EEPROM memory. To protect against spurious EEPROM writes, various mechanisms have been built in. On power-up, WREN is cleared. Also, the Power-up T imer (no minal 64 ms duration) p revents EEPROM write.

The write initiate sequence and the WREN bit together help prevent an accidental write during:

- Brown-out
- •P ower Glitch
- Software Malfunction

#### 9.6 Data EEPROM Operation During Code Protection

Data memory can be code-protected by programming the CPD bit in the Configuration Word (Register 12-1) to '0'.

When the data memory is code-protected, the CPU is able to read and write data to the data EEPROM. It is recommended to c ode-protect th e p rogram memory when code-protecting d ata m emory. This p revents anyone fr om programming z eroes ov er th e ex isting code (which will execute as NOPS) to reach an added routine, pro grammed in unused program me mory, which ou tputs t he contents of d ata me mory. Programming unused locations in program memory to '0' will also help prevent data memory code protection from becoming breached.

| Name   | Bit 7                                                    | Bit 6  | Bit 5  | Bit 4               | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|----------------------------------------------------------|--------|--------|---------------------|--------|--------|--------|--------|----------------------|---------------------------------|
| INTCON | GIE                                                      | PEIE   | TOIE   | INTE                | RAIE   | T0IF   | INTF   | RAIF   | 0000 000x            | 0000 000x                       |
| PIR1   | EEIF                                                     | LVDIF  | CRIF   | C2IF <sup>(1)</sup> | C1IF   | OSFIF  | _      | TMR1IF | 0000 00-0            | 0000 00-0                       |
| PIE1   | EEIE                                                     | LVDIE  | CRIE   | C2IE <sup>(1)</sup> | C1IE   | OSFIE  | _      | TMR1IE | 0000 00-0            | 0000 00-0                       |
| EEDAT  | EEDAT7                                                   | EEDAT6 | EEDAT5 | EEDAT4              | EEDAT3 | EEDAT2 | EEDAT1 | EEDAT0 | 0000 0000            | 0000 0000                       |
| EEADR  | EEADR7 <sup>(1)</sup>                                    | EEADR6 | EEADR5 | EEADR4              | EEADR3 | EEADR2 | EEADR1 | EEADR0 | 0000 0000            | 0000 0000                       |
| EECON1 | _                                                        | _      | _      | _                   | WRERR  | WREN   | WR     | RD     | x000                 | q000                            |
| EECON2 | CON2 EEPROM Control Register 2 (not a physical register) |        |        |                     |        |        |        |        |                      |                                 |

#### TABLE 9-1: SUMMARY OF REGISTERS ASSOCIATED WITH DATA EEPROM

**Legend:** x = unknown, u = unchanged, - = unimplemented read as '0', q = value depends upon condition. Shaded cells are not used by the data EEPROM module.

Note 1: PIC16F636/639 only.

### 10.0 KEELOQ<sup>®</sup> COMPATIBLE CRYPTOGRAPHIC MODULE

To obtain information regarding the implementation of the K EELOQ mo dule, Mi crochip T echnology r equires the ex ecution of the "K EELOQ<sup>®</sup> E ncoder L icense Agreement".

The "KEELOQ<sup>®</sup> Encoder License Agreement" may be accessed through the Microchip web site located at <u>www.microchip.com/KEELOQ</u>. Further information may be obtained by contacting your local Microchip Sales Representative.

NOTES:

#### 11.0 ANALOG FRONT-END (AFE) FUNCTIONAL DESCRIPTION (PIC16F639 ONLY)

The PIC 16F639 device consists of the PIC 16F636 device a nd I ow f requency (L F) Analog Front-End (AFE), w ith the AF E s ection containing three analog-input ch annels for signal det ection and LF talk-back. This section describes the Analog Front-End (AFE) in detail.

The PIC 16F639 de vice can de tect a 1 25 kHz input signal as low as 1 m Vpp and transmit data by u sing internal LF t alk-back mo dulation or vi a an external transmitter. The PIC16F639 can al so b e u sed f or various bi directional communication a pplications. Figure 11-3 and Figure 11-4 show application examples of the device.

Each analog i nput cha nnel ha s in ternal tu ning capacitance, sensitivity control circuits, an input signal strength limiter an d an LF t alk-back modulation transistor. An Automatic G ain Contr ol (AG C) loo p is used for al I th ree input channel gains. The output of each channel is OR'd and fed into a demodulator. The digital output is passed to the LFDATA pin. Figure 11-1 shows the block diagram of the AFE and Figure 11-2 shows the LC input path.

There are a total of eight Configuration registers. Six of them are us ed f or AFE ope ration options, o ne for column parity bits and one for status indication of AFE operation. Each register has 9 bits including one row parity bit. These registers are readable and writable by SPI (Serial Protocol Interface) c ommands except for the STATUS register, which is read-only.

#### 11.1 RF Limiter

The RF Limiter limits LC pin input voltage by de-Q'ing the attached LC resonant circuit. The absolute voltage limit is de fined b y th e si licon proc ess's ma ximum allowed i nput voltage (see **Section 15.0 "Electrical Specifications"**). The limiter be gins de -Q'ing the external LC antenna when the input voltage exceeds VDE\_Q, p rogressively d e-Q'ing h arder to re duce th e antenna input voltage.

The signal levels from all 3 c hannels are combined such th at t he l imiter att enuates a ll 3 ch annels uniformly, in respect to the channel with the strongest signal.

#### 11.2 Modulation Circuit

The mo dulation ci rcuit co nsists of a modulation transistor (FET), internal tuning capacitors and external LC an tenna co mponents. The mo dulation transistor and the in ternal tuning c apacitors a re connected between the LC input pin and LCCOM pin. Each LC input has its own modulation transistor.

When the modulation transistor turns on, its low Turn-on Resistance (R M) cla mps the indu ced LC antenna voltage. The co il volt age is m inimized w hen the modulation transistor turns-on and maximized when the modulation transistor turn s-off. The modu lation transistor's low Turn-on R esistance (RM) results in a high modulation depth.

The LF talk-back is achieved by turning on and off the modulation transistor.

The modulation data comes from the microcontroller section v ia the digital SPI interface as "C lamp On", "Clamp Off" commands. O nly t hose i nputs t hat ar e enabled will execute the c lamp c ommand. A ba sic block di agram of the modulation c ircuit is s hown in Figure 11-1 and Figure 11-2.

The modulation FET is also shorted momentarily after Soft Reset and Inactivity timer time-out.

#### 11.3 Tuning Capacitor

Each channel has internal tuning capacitors for external antenna tuning. The capacitor values are programmed by the Configuration registers up to 63pF, 1 pF per step.

**Note:** The user can control the tuning capacitor by prog ramming the AFE Configuration registers.

#### 11.4 Variable Attenuator

The variable attenuator is used to attenuate, via AGC control, the input signal voltage to avoid saturating the amplifiers and demodulators.

**Note:** The v ariable atte nuator function i s accomplished b y th e d evice it self. Th e user cannot control its function.

#### 11.5 Sensitivity Control

The sensitivity of each channel can be reduced by the channel's C onfiguration reg ister s ensitivity setting. This is used to desensitize the channel from optimum.

**Note:** The u ser c an desensitize th e c hannel sensitivity by p rogramming t he AFE Configuration registers.

#### 11.6 AGC Control

The AGC controls the variable attenuator to li mit the internal signal voltage to av oid saturation of int ernal amplifiers and de modulators (R efer to **Section 11.4 "Variable Attenuator"**).

The signal levels from all 3 channels are combined such that AGC attenuates all 3 channels uniformly in respect to the channel with the strongest signal.

| Note: | The AGC control function is accomplished |  |  |  |  |  |
|-------|------------------------------------------|--|--|--|--|--|
|       | by the device it self. The us er c annot |  |  |  |  |  |
|       | control its function.                    |  |  |  |  |  |

#### 11.7 Fixed Gain Amplifiers 1 and 2

FGA1 and FGA2 provides a maximum two-stage gain of 40 dB.

**Note:** The user cannot control the gain of these two amplifiers.

#### 11.8 Auto Channel Selection

The Auto Channel Selection feature is enabled if the Auto Channel Select bit AUTOCHSEL<8> in Configuration Register 5 (Register 11-6) is set, and disabled if the bit is c leared. W hen th is feature is active (i.e., AUTOCHSE <8> = 1), the control c ircuit c hecks the demodulator output of each input channel immediately after the AGC settling time (TSTAB). If the output is high, it all ows this c hannel to p ass da ta, o therwise it is blocked.

The status of this operation is monitored by AFE Status Register 7 bits <8:6> (Register 11-8). These bits indicate the current status of the channel selection activity, and automatically updates for every Soft Reset period. The auto channel selection function resets after ea ch Soft Reset (or after Inactivity timer time-out). Therefore, the blocked channels are reenabled after Soft Reset.

This fea ture c an mak e th e ou tput si gnal c leaner b y blocking any channel that was not high at the en d of TAGC. This function works only for demodulated data output, an d is not a pplied for c arrier cl ock or R SSI output.

#### 11.9 Carrier Clock Detector

The D etector s enses the i nput c arrier c ycles. The output of the Detector switches digitally at the signal carrier fr equency. C arrier cl ock o utput is available when the output is selected by the DATOUT bit in the AFE Configuration Register 1 (Register 11-2).

#### 11.10 Demodulator

The Demodulator consists of a ful I-wave rectifier, low pass filter, peak detector and Data Slicer that detects the envelope of the input signal.

#### 11.11 Data Slicer

The Data Slicer consists of a reference generator and comparator. The Data Slicer compares the input with the reference voltage. The reference voltage comes from the minimum modulation depth requirement setting and input peak voltage. The data from all 3 channels a re O R'd to gether and sent to the output enable filter.

#### 11.12 Output Enable Filter

The Output E nable Filter enables the LFDATA output once the incoming signal meets the wake-up sequence requirements (see Section 11.15 "C onfigurable Output Enable Filter").

# 11.13 RSSI (Received Signal Strength Indicator)

The RSSI provides a current which is proportional to the input signal amplitude (see Section 11.31.3 "Received Signal Strength Indicator (RSSI) Output").

#### 11.14 Analog Front-End Timers

The AFE has an int ernal 32 kHz R C oscillator. The oscillator is used in several timers:

- Inactivity timer
- Alarm timer
- Pulse Width timer
- Period timer
- AGC settling timer

#### 11.14.1 RC OSCILLATOR

The R C oscillator is low power, 32 kHz  $\pm$  10% ov er temperature and voltage variations.

#### 11.14.2 INACTIVITY TIMER

The Inactivity Timer is used to automatically return the AFE to Standby mode, if there is no input signal. The time-out period is approximately 16 ms (TINACT), based on the 32 kHz internal clock.

The purpose of the Inactivity Timer is to minimize AFE current draw by automatically returning the AFE to the lower current Standby mode, if there is no input signal for approximately 16 ms.

The timer is reset when:

- An amplitude change in LF input signal, either high-to-low or low-to-high
- •C S pin is low (any SPI command)
- Timer-related Soft Reset

The timer starts when:

• AFE receives any LF signal

The timer causes an AFE Soft Reset when:

• A previously received LF signal does not change either high-to-low or low-to-high for TINACT

The Soft Reset returns the AFE to Standby mode where most of the an alog circuits, su ch as the AG C, demodulator and RC oscillator, are powered down. This returns the AFE to the lower Standby Current mode.

#### 11.14.3 ALARM TIMER

The Alarm Timer is used to notify the MCU that the AFE is receiving LF signal that does not p ass t he ou tput enable filter r equirement. The time-out period is approximately 32 ms (TALARM) in the p resence of continuing noise.

The Al arm Timer time-out occ urs if there is an input signal for lon ger than 32 ms that does not meet the output en able filter r equirements. The Alarm Timer time-out causes:

- a) The ALERT pin to go low.
- b) The ALARM bit to set in the AFE Status Configuration 7 register (Register 11-8).

The MCU is in formed of the Alarm timer time-out by monitoring the ALERT pin. If the Alarm timer time-out occurs, the MCU can take appropriate actions such as lowering channel s ensitivity or disabling channels. If the noise source is ignored, the AFE can return to a lower standby current draw state. The timer is reset when the:

•C S pin is low (any SPI command).

- Output enable filter is disabled.
- LFDATA pin is enabled (signal passed output enable filter).

The timer starts when:

Receiving a LF signal.

The timer causes a low output on the ALERT pin when:

• Output enable filter is enabled and modulated input signal is present for TALARM, but does not pass the output enable filter requirement.

**Note:** The Alarm timer is disabled if the output enable filter is disabled.

#### 11.14.4 PULSE WIDTH TIMER

The Puls e Wi dth Timer is use d to verify that the received ou tput enable sequence meets both the minimum TOEH and minimum TOEL requirements.

#### 11.14.5 PERIOD TIMER

The Period Timer is used to verify that the received output e nable sequence meets the maximum TOET requirement.

#### 11.14.6 AGC SETTLING TIMER (TAGC)

This timer is used to keep the output enable filter in Reset while the AGC settles on the input signal. The time-out period is approximately 3.5 ms. At end of this time (TAGC), the input sh ould r emain high (TPAGC), otherwise the counting is aborted and a Soft Reset is issued. See Figure 11-6 for details.

- Note 1: The AFE needs continuous and uninterrupted hi gh inp ut signal d uring AGC settling time (TAGC). Any absence of signal during this time may reset the timer and a new input signal is needed for AGC settling tim e, or m ay res ult in improper AGC gain settings w hich w ill prod uce invalid output.
  - 2: The rest of the AFE section wakes up if any of these input channels receive the AGC se ttling ti me co rrectly. AFE Status Register 7 b its <4:2> (Register 11-8) i ndicate w hich in put channels have waken up the AFE first. Valid in put signal on multiple input pins can cause m ore th an one c hannel's indicator bit to be set.



#### FIGURE 11-1: FUNCTIONAL BLOCK DIAGRAM – ANALOG FRONT-END





#### FIGURE 11-3: BIDIRECTIONAL PASSIVE KEYLESS ENTRY (PKE) SYSTEM APPLICATION EXAMPLE





#### 11.15 Configurable Output Enable Filter

The purpose of this filter is to enable the LFDATA output and w ake the microcont roller only aft er re ceiving a specific sequence of pulses on the LC input pins. Therefore, it prevents the AF E from w aking up the microcontroller due to noise or unwanted input signals. The cir cuit comp ares the timing of t he demodulat ed header waveform with a pre-defined value, and enables the demodulated LFDATA output when a match occurs.

The output enable filter consists of a high (TOEH) and low duration (TOEL) of a pullse immediately after the AGC settling gap time. The selection of high and low times further implies a max period time. The output enable high and I ow times a red etermined by SPI interface programming. Figure 11-5 and Figure 11-6 show the output enable filter waveforms.

There should be no m issing c ycles duri ng TOEH. Missing cycles may result in failing the output enable condition.



#### FIGURE 11-5: OUTPUT ENABLE FILTER TIMING





### TABLE 11-1:TYPICAL OUTPUT ENABLEFILTER TIMING

| OEH<br><1:0> | OEL<br><1:0> | Тоен<br>(ms) | TOEL<br>(ms)  | Тоет<br>(ms) |  |  |
|--------------|--------------|--------------|---------------|--------------|--|--|
| 01           | 00           | 11           |               | 3            |  |  |
| 01           | 01           | 11           |               | 3            |  |  |
| 01           | 10           | 12           |               | 4            |  |  |
| 01           | 11           | 14           |               | 6            |  |  |
|              |              |              |               |              |  |  |
| 10           | 00           | 21           |               | 4            |  |  |
| 10           | 01           | 21           |               | 4            |  |  |
| 10           | 10           | 22           |               | 5            |  |  |
| 10           | 11           | 24           |               | 8            |  |  |
|              |              |              |               |              |  |  |
| 11           | 00           | 41           |               | 6            |  |  |
| 11           | 01           | 41           |               | 6            |  |  |
| 11           | 10           | 42           |               | 8            |  |  |
| 11           | 11           | 44           |               | 10           |  |  |
|              |              |              |               |              |  |  |
| 00           | XX           | Fi           | ilter Disable | ed           |  |  |

**Note 1:** Typical at room temperature and VDD = 3.0V, 32 kHz oscillator.

TOEH is measured from the rising edge of the demodulator output to the fir st falling edge. The pulse width must fall within TOEH  $\leq t \leq$  TOET.

TOEL is me asured from the falling edg e of the e demodulator output to the rising edge of the next pulse. The pulse width must fall within TOEL  $\leq t \leq$  TOET.

TOET is measured from rising edge to the next rising edge (i.e., the sum of TOEH and TOEL). The pulse width must be  $t \le T$  OET. If the C onfiguration R egister 0 (Register 11-1), OE L<8:7> is s et t o ' 00', th en TOEH must no t exceed TOET and TOEL must no t exceed TINACT.

The filter will reset, requiring a complete new successive high a nd low per iod t o enable LFD ATA, und er t he following conditions.

- The received high is not greater than the configured minimum TOEH value.
- D uring TOEH, a loss of signal > 56 μs. A loss of signal < 56 μs may or may not cause a filter Reset.
- The received low is not greater than the configured minimum TOEL value.
- The received sequence exceeds the maximum TOET value:
  - -T OEH + TOEL > TOET
  - -o r TOEH > TOET
  - -o r TOEL > TOET
- A Soft Reset SPI command is received.

If the filter resets due to a long high (TOEH > TOET), the high-pulse timer will not begin timing again until after a gap of TE and another low-to-high transition occurs on the demodulator output.

Disabling the output enable filter disables the TOEH and TOEL requirement and the AFE passes all received LF data. See Figure 11-10, Figure 11-11 and Figure 11-12 for examples.

When viewed from an application perspective, from the pin input, the actual output enable filter timing must factor in the a nalog delays in the input p ath (s uch a s demodulator charge and discharge times).

- TOEH TDR + TDF
- TOEL + TDR TDF

The output enable filter starts immediately after TGAP, the gap after AGC stabilization period.

#### 11.16 Input Sensitivity Control

The AFE is designed to have typical input sensitivity of 3m VPP. This means any input signal with amplitude greater than 3 mVPP can be detected. The AFE's internal AGC loop regulates the detecting signal amplitude when the input level is greater than approximately 20 m VPP. This signal amplitude is called "AGC-active level". The AGC loop regulates the input voltage so that the input signal amplitude range will be kept within the linear range of the d etection c ircuits wi thout s aturation. The AGC Active S tatus b it A GCACT<5>, in the AFE S tatus Register 7 (Register 11-8) is s et if th e AG C loop regulates the input voltage.

Table 11-2 shows the input sensitivity comparison when the AGCSIG option is used. When AGCSIG option bit is set, the demodulated output is available only when the AGC loop is active (see Table 11-1). The AFE has also input sensitivity reduction options per each channel. The Configuration Register 3 (Register 11-4), Configuration Register 4 (Register 11-5) and Configuration Register 5 (Register 11-6) have the option to reduce the channel gains from 0 dB to approximately -30 dB.

| AGCSIG<7><br>(Config. Register 5) | Description                                                                                                                                                                  | Input<br>Sensitivity<br>(Typical) |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| 0                                 | Disabled – the AFE passes signal of any amplitude level it is capable of detecting (demodulated data and carrier clock).                                                     | 3.0 mVpp                          |
| 1                                 | <ul> <li>Enabled – No output until AGC Status = 1 (i.e., VPEAK ≈ 20 mVPP) (demodulated data and carrier clock).</li> <li>Provides the best signal to noise ratio.</li> </ul> | 20 mVpp                           |

#### TABLE 11-2: INPUT SENSITIVITY VS. MODULATED SIGNAL STRENGTH SETTING (AGCSIG <7>)

#### 11.17 Input Channels (Enable/Disable)

Each channel can be individually enabled or disabled by programming bits in Configuration Register 0<3:1> (Register 11-1).

The purpose of having an option to disable a particular channel is to minimize current draw by powering down as m uch ci rcuitry as possible, if th e ch annel is n ot needed for operation. The exact circuits disabled when an input is disabled are amplifiers, detector, full-wave rectifier, data slicer, and modulation FET. However, the RF input li miter re mains active to protect the silicon from excessive antenna input voltages.

#### 11.18 AGC Amplifier

The circuit automatically amplifies input signal voltage levels to an acceptable level for the da ta slicer. Fast attack and slow release by nature, the AGC tracks the carrier signal level and not the modulated data bits.

The AGC inherently tracks the strongest of the three antenna in put si gnals. T he AGC requires a n A GC stabilization time (TAGC).

The AG C will a ttempt to re gulate a c hannel's peak signal voltage into the data slicer to a desired regulated AGC voltage – reducing the input path's gain as the signal level attempts to increase above regulated AGC voltage, and allowing full amplification on signal levels below the regulated AGC voltage.

The AGC has two modes of operation:

- 1. During the AGC settling time (TAGC), the AGC time constant is fast, allowing a reasonably short acquisition time of the continuous input signal.
- 2. After TAGC, the AGC switches to a slower time constant for data slicing.

Also, the AGC is frozen when the input signal envelope is low. The AGC tracks only high envelope levels.

#### 11.19 AGC Preserve

The AGC preserve feature allows the AFE to preserve the AGC value during the AGC settling time (TAGC) and apply the value to the data slicing circuit for the following data streams instead of using a newtracking value. This feature is useful to demodulate the input signal correctly when the input has ra ndom amplitude variations at a given time period. This feature is enabled when the AFE receives an AGC Preserve On command and disabled if it receives an AGC Preserve Off command. Once the AGC Preserve O n com mand is received, t he AF E acquires a new AGC value during each AGC settling time and preserves the value until a So ft Reset or an AGC Preserve Off command is issued. Therefore, it does not need to issue another AGC Pr eserve On command. An AGCPreserve Off command isneeded to disable the A GC preser ve feature (see Section 11.32.2.5 " AGC Preserve On Command" Section 11.32.2.6 " AGC Preserve Of f and Command" for AGC Preserve commands).

#### 11.20 Soft Reset

The AFE issues a Soft Reset in the following events:

- a) After Power-on Reset (POR),
- b) After Inactivity timer time-out,
- c) If an "Abort" occurs,
- d) After receiving SPI Soft Reset command.

The "Abo rt" oc curs if there is no positive signal detected at the end of the A GC stabilization period (TAGC). The Soft R eset initializes internal circuits and brings the A FE into a low current S tandby mode operation. The internal circuits that are initialized by the Soft Reset include:

- Output Enable Filter
- AGC inccuits
- Demodulator
- 32 kHz Internal Oscillator

The Soft Reset has no effect on the Configuration register setup, except for some of the AFE Status Register 7 bits. (Register 11-8).

The circuit initialization takes one internal clock cycle (1/32 kHz = 31 .25  $\mu$ s). During the initialization, the modulation t ransistors be tween e ach i nput a nd LCCOM pi ns are tu rned-on to discharge a ny internal/external parasitic charges. The modulation transistors are tu rned-off immediately a fter the initialization time.

The Soft Reset is executed in Active mode only. It is not valid in Standby mode.

#### 11.21 Minimum Modulation Depth Requirement for Input Signal

The AFE demodulates the modulated input signal if the modulation depth of the input signal is greater than the minimum requirement that is programmed in the AFE Configuration R egister 5 (R egister 11-6). Fig ure 11-7 shows the definition of the modulation dep th and examples. MODMIN<6:5> of the Configuration Register 5 offer four options They are 75%, 50%, 25% and 12%, with a default setting of 50%.

The pu rpose of th is f eature i s to enh ance th e demodulation in tegrity of the in put si gnal. The 12% setting is the best choice for the input signal with weak modulation depth, which is typically observed near the high-voltage base station an tenna an d al so at far-distance from the base station antenna. It gives the best demodulation sensitivity, but is very susceptible to noise spikes that can result in a bit detection error. The 75% setting can reduce the bit errors caused by noise, but gi ves th e I east de modulation s ensitivity. Se e Table 11-3 for minimum modulation depth requirement settings.

#### TABLE 11-3: SETTING FOR MINIMUM MODULATION DEPTH REQUIREMENT

|       | IIN Bits<br>Register 5) | Modulation Depth |  |  |  |  |
|-------|-------------------------|------------------|--|--|--|--|
| Bit 6 | Bit 5                   | 1                |  |  |  |  |
| 00    |                         | 50% (default)    |  |  |  |  |
| 01    |                         | 75%              |  |  |  |  |
| 10    |                         | 25%              |  |  |  |  |
| 11    |                         | 12%              |  |  |  |  |



#### 11.22 Low-Current Sleep Mode

The Sleep command from the microcontroller, via an SPI Interface command, places the AFE i nto an ultra Low-current mode. All circuits including the RF Limiter, except the minimum circuitry required to retain register memory and SPI capability, will be p owered down to minimize the AFE current draw. Power-on Reset or any SPI command, other than Sleep command, is required to wake the AFE from Sleep.

#### 11.23 Low-Current Standby Mode

The AFE is in Standby mode when no LF signal is present on the antenna inputs but the AFE is powered and ready to receive any incoming signals.

#### 11.24 Low-Current Operating Mode

The AFE is in Low-current Operating mode when a LF signal is present on a n LF antenna input and internal circuitry is switching with the received data.

#### 11.25 Error Detection of AFE Configuration Register Data

The AFE's Configuration registers are volatile memory. Therefore, the c ontents of t he registers can be corrupted or cleared by any electrical incidence such as battery disconnect. To ensure the data integrity, the AFE has an error detection mechanism using row and column parity bits of the Configuration register memory map. The bit 0 of each register is a row parity bit which is calculated over the eight Configuration bits (from bit 1 to bit 8). The Column Parity Register (Configuration Register 6) hol ds column parity bit s; eac h bi t is calculated over the respective columns (Configuration registers 0 to 5) of the Configuration bits. The STATUS register is not in cluded for the column p arity bit calculation. Parity is to be odd. The parity bit set or cleared makes an o dd n umber of set bits. The us er needs to calculate the row and column parity bits using the contents of the registers and program them. During operation, the AFE continuously calculates the row and column parity bits of the configuration memory map. If a parity error occurs, the AFE lowers the SCLK/ALERT pin (interrupting the microcontroller section) indicating the configuration m emory has b een c orrupted or unloaded and needs to be reprogrammed.

At a n in itial c ondition a fter a Pow er-On-Reset, th e values of the registers are all clear (default condition). Therefore, the AFE w ill is sue t he p arity bit error by lowering the SCLK/ALERT pin. If user reprograms the registers with correct parity bits, the SCLK/ALERT pin will be toggled to logic high level immediately.

The parity bit errors do not change or affect the AFE's functional operation.

Table 11-4 s hows an example of the register values and corresponding parity bits.

| Register Name                                        | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0<br>(Row Parity) |
|------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|
| Configuration Register 0                             | 1     | 0     | 1     | 0     | 1     | 0     | 0     | 0     | 0                     |
| Configuration Register 1                             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     |
| Configuration Register 2                             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     |
| Configuration Register 3                             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     |
| Configuration Register 4                             | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1                     |
| Configuration Register 5                             | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0                     |
| Configuration Register 6<br>(Column Parity Register) | 1     | 1     | 0     | 1     | 0     | 1     | 1     | 1     | 1                     |

#### TABLE 11-4: AFE CONFIGURATION REGISTER PARITY BIT EXAMPLE

#### 11.26 Factory Calibration

Microchip c alibrates th e AF E to red uce th e device-to-device variation in standby current, internal timing a nd s ensitivity, as well as c hannel-to-channel sensitivity variation.

### 11.27 De-Q'ing of Antenna Circuit

When the transponder is close to the base station, the transponder coil may develop coil voltage higher than VDE\_Q. This condition is called "near field". The AFE detects the strong near field signal through the AGC control, and de-Q'ing the antenna circuit to reduce the input signal amplitude.

#### 11.28 Battery Back-up and Batteryless Operation

The d evice s upports bo th battery back-up a nd batteryless o peration by the a ddition of e xternal components, allowing the de vice to be p artially or completely powered from the field.

Figure 11-8 shows an example of the external circuit for the battery back-up.

Note: Voltage on LCCOM combined with coil input voltage must not exceed the maximum LC input voltage.



DLIM = Voltage limiting diode, may be required to limit VDD voltage when in strong fields.

#### FIGURE 11-8: LF FIELD POWERING AND BATTERY BACK-UP EXAMPLE

Schottky for low forward bias drop.

RLIM = Current limiting resistor, required for air coil in strong fields.

DFLAT = Field rectifier diodes.

RCOM =C COM discharge path.

#### 11.29 Demodulator

The demodulator recovers the modulation data from the received signal, containing carrier plus data, by appropriate envelope detection. The demodulator has a fast rise (charge) time (T DR) and a fall time (T DF) appropriate t o an e nvelope of input s ignal (see **Section 15.0 " Electrical Sp ecifications"** for T DR and T DF sp ecifications). The de modulator contains the full-wave r ectifier, lo w-pass filter, pe ak d etector and data slicer.





#### 11.30 Power-On Reset

This circuit remains in a Reset state until a sufficient supply v oltage is ap plied to the AFE. The R eset releases when the supply is sufficient for correct AFE operation, nominally VPOR of AFE.

The C onfiguration reg isters are a II cl eared on a Power-on R eset. As the Configuration registers a re protected by odd row and column parity, the ALERT pin will be pulled down – in dicating to the m icrocontroller section that the AFE c onfiguration memory is cleared and requires loading.

#### 11.31 LFDATA Output Selection

The LFDATA output can be configured to p ass the Demodulator output, Received Signal Strength Indicator (RSSI) o utput, or Carrier C lock. See Configuration Register 1 (Register 11-2) for more details.

#### 11.31.1 DEMODULATOR OUTPUT

The demodulator output is the default configuration of the output selection. This is the output of an envelope detection circuit. See Figure 11-9 for the demodulator output. For a clean data output or to save operating power, the input channels can be indvidually enabled or disabled. If more than one channel is enabled, the output is the sum of each output of all enabled channels. There will be no valid output if all three channels are disabled. When the demodulated output is selected, the output is available in two different conditions depending on how the options of Configuration Register 0 (Register 11-1) are set: Output Enable Filter is disabled or enabled.

#### **Related Configuration register bits:**

- Configuration Register 1 (Register 11-2), DATOUT <8:7>:
  - -b<u>it 8</u>bit 7
    - 0 0: Demodulator Output
    - 0 1: Carrier Clock Output
    - 1 0: RSSI Output
    - 0 1: RSSI Output
- Configuration Register 0 (Register 11-1): all bits

**Case I. When Output Enable Filter is disabled:** Demodulated output is available immediately after the AGC stabilization time (TAGC). Figure 11-10 shows an example of demodulated output when the Output Enable Filter is disabled.





**Case II. When Output Enable Filter is enabled**: Demodulated output is available only if the incoming signal meets the enable filter timing criteria that is defined in the Configuration Register 0 (Register 11-1). If the criteria is met, the output is available after the I ow tim ing (TOEL) of the Ena ble Filter. Figure 11-11 and Fig ure 11-12 shows examples of demodulated output when the Output Enable Filter is enabled.





FIGURE 11-12: NO DEMODULATOR OUTPUT (WHEN OUTPUT ENABLE FILTER IS ENABLED BUT INPUT DOES NOT MEET FILTER TIMING REQUIREMENTS)



#### 11.31.2 CARRIER CLOCK OUTPUT

When the Carrier Clock output is selected, the LFDATA output is a square pulse of the input carrier clock and available as soon as the AGC stabilization time (TAGC) is completed. There are two Configuration register options for the carrier clock output: (a) clock divide-by one or (b) clock divide-by four, depending on bit D ATOUT<7> of Configuration R egister 2 (R egister 11-3). The ca rrier clock output is available im mediately after the AGC settling time. The Output Enable Filter, AGCSIG, and MODMIN options are appl icable for the carrier clo ck output in the same way as the demodulated output. The input channel can be individually enabled or disabled for the output. If more than one channe I is enabled, the output is the sumof each output of all enabled channels. Therefore, the carrier clock output waveform is not as precise as w hen only one cha nnel is en abled. It is recommended to enable one channel only if a precise output waveform is desired.

There will be no valid output if all three channels are disabled. See Figure 11-13 f or carrier clock output examples.

#### **Related Configuration register bits:**

• Configuration Register 1 (Register 11-2), DATOUT <8:7>:

bit 8 bit 7

- 0 0: Demodulator Output
- 0 1: Carrier Clock Output
- 1 0: RSSI Output
- 1 1: RSSI Output
- Configuration Register 2 (Register 11-3), CLKDIV<7>:
  - 0: Carrier Clock/1
  - 1: Carrier Clock/4
- Configuration Register 0 (Register 11-1): all bits are affected
- Configuration Register 5 (Register 11-6)



#### 11.31.3 RECEIVED SIGNAL STRENGTH INDICATOR (RSSI) OUTPUT

An analog current is available at the LFDATA pin when the Received Signal Strength Indicator (RSSI) output is selected for the AFE's Configuration register. The analog current is linearly proportional to the input signal strength (see Figure 11-15).

All timers in the circuit, such as inactivity timer, alarm timer, and AGC settling time, are disabled during the RSSI mode. Therefore, the RSSI output is not affected by the AG C settling time, and available im mediately when the R SSI option is selected. The AFE enters Active m ode immediately when the R SSI out put is selected. The MC U I/O pin (RC3) c onnected t o the LFDATA pi n, m ust be set to h igh-impedance state during the RSSI Output mode.

When the AFE re ceives an SPI command during the RSSI o utput, the R SSI mode is te mporary di sabled until the SPI interface communication is completed. It returns to the RSSI mode again after the SPI interface communication is completed. The AFE holds the RSSI mode until a nother ou tput type is selected ( $\overline{CS}$  low turns off the R SSI signal). To obtain the R SSI output for a p articular input channel, or to s ave o perating power, the input channel can be individually enabled or disabled. If more than one channel is enabled, the RSSI output is from the s trongest si gnal c hannel. There will be no valid output if all three channels are disabled.

#### **Related AFE Configuration register bits:**

- Configuration Register 1 (Register 11-2), DATOUT<8:7>:
  - bit 8 bit 7
    - 0 0: Demodulated Output
    - 0 1: Carrier Clock Output
    - 10 : RSSI Output
    - 11 : RSSI Output
- Configuration Register 2 (Register 11-3), RSSIFET<8>:
  - 0: Pull-Down MOSFET off
  - 1: Pull-Down MOSFET on.

| Note: | The pull-down MOSFET opt ion is v alid  |
|-------|-----------------------------------------|
|       | only when the R SSI output is selected. |
|       | The MOSFET is not controllable by users |
|       | when D emodulated or C arrier Clock     |
|       | output option is selected.              |

• Configuration Register 0 (Register 11-1): all bits are affected.

#### FIGURE 11-14: RSSI OUTPUT PATH





#### 11.31.3.1 ANALOG-TO-DIGITAL DATA CONVERSION OF RSSI SIGNAL

The AFE's RSSI output is an analog current. It needs an external Analog-to-Digital (ADC) data conversion device for digitized output. The ADC data conversion can be accomplished by u sing a s tand-alone external AD C device or by firm ware util izing M CU's internal comparator along with a few external resistors and a capacitor. For slope ADC implementations, the external capacitor at the LFDATA pad needs to be discharged before data s ampling. For this purpose, the internal pull-down MOSFET on the LFDATA pad can be utilized. The M OSFET can be t urned on o r of f w ith b it RSSIFET<8> of the Configuration R egister 2 (Register 11-3). Wh en i t is t urned on, the i nternal MOSFET provides a dis charge p ath for the ex ternal capacitor. This MOSFET option is v alid only if R SSI output is selected and not c ontrollable by use rs for demodulated or carrier clock output options.

See separate application notes for various external ADC implementation methods for this device.

### **11.32** AFE Configuration

#### 11.32.1 SPI COMMUNICATION

The AFE SPI interface communication is used to read or write the AFE's Configuration registers and to send command only messages. For the SPI in terface, the device has t hree pa ds; C S, SCLK/ALERT, an d LFDATA/RSSI/CCLK/SDIO. Fi gure 11-15, Figure 11-14, Fi gure 11-16 and Fig ure 11-17 shows examples of the SPI communication sequences.

When the dev ice p owers u p, t hese p ins w ill b e high-impedance inputs un til fi rmware m odifies them appropriately. The AF E pins connected to the MCU pins will be as follows.

#### CS

• Pin is permanently an input with an internal pull-up.

#### SCLK/ALERT

 Pin is an open collector output when CS is high. An internal pull-up resistor exists internal to the AFE to ensure no spurious SPI communication between powering and the MCU configuring its pins. This pin becomes the SPI clock input when CS is low.

#### LFDATA/RSSI/CCLK/SDIO

 Pin is a digital output (LFDATA) so long as CS is high. During SPI communication, the pin is the SPI data input (SDI) unless performing a register Read, where it will be the SPI data output (SDO).

#### FIGURE 11-16: POWER-UP SEQUENCE









#### 11.32.2 COMMAND DECODER/CONTROLLER

The circuit executes 8 SPI commands from the MCU. The command structure is:

Command (3 bits) + Configuration Address (4 bits) + Data Byte and Row Parity Bit received by the AFE Most Significant bit first. Table 11-5 shows the available SPI commands. The AFE operates in SPI mo de 0,0. In mode 0,0 the clock idles in the low state (Figure 11-19). SDI data is loaded into the AFE on the rising edge of SCLK and SDO data is clocked out on the falling edge of SCLK. There must be multiples of 16 clocks (SCLK) while  $\overline{CS}$  is low or commands will abort.

| TABLE 11-5: | SPI COMMANDS (AFE) |
|-------------|--------------------|
|             |                    |

| Command    | Address      | Data                | Row<br>Parity | Description                                                     |
|------------|--------------|---------------------|---------------|-----------------------------------------------------------------|
| Command o  | nly – Addr   | ess and Data ar     | e "Don't (    | Care", but need to be clocked in regardless.                    |
| 000        | XXXX         | XXXX XXXX           | Х             | Clamp on – enable modulation circuit                            |
| 001        | XXXX         | XXXX XXXX           | Х             | Clamp off – disable modulation circuit                          |
| 010        | XXXX         | XXXX XXXX           | Х             | Enter Sleep mode (any other command wakes the AFE)              |
| 011        | XXXX         | XXXX XXXX           | Х             | AGC Preserve On – to temporarily preserve the current AGC level |
| 100        | XXXX         | XXXX XXXX           | Х             | AGC Preserve Off – AGC again tracks strongest input signal      |
| 101        | XXXX         | XXXX XXXX           | Х             | Soft Reset – resets various circuit blocks                      |
| Read Comm  | and – Data   | a will be read fro  | om the sp     | ecified register address.                                       |
| 110        | 0000         | Config Byte 0       | Р             | General – options that may change during normal operation       |
|            | 0001         | Config Byte 1       | Р             | LCX antenna tuning and LFDATA output format                     |
|            | 0010         | Config Byte 2       | Р             | LCY antenna tuning                                              |
|            | 0011         | Config Byte 3       | Р             | LCZ antenna tuning                                              |
|            | 0100         | Config Byte 4       | Р             | LCX and LCY sensitivity reduction                               |
|            | 0101         | Config Byte 5       | Р             | LCZ sensitivity reduction and modulation depth                  |
|            | 0110         | Column Parity       | Р             | Column parity byte for Config Byte 0 -> Config Byte 5           |
|            | 0111         | AFE Status          | Х             | AFE status – parity error, which input is active, etc.          |
| Write Comm | and – Data   | a will be written   | to the sp     | ecified register address.                                       |
| 111        | 0000         | Config Byte 0       | Р             | General – options that may change during normal operation       |
|            | 0001         | Config Byte 1       | Р             | LCX antenna tuning and LFDATA output format                     |
|            | 0010         | Config Byte 2       | Р             | LCY antenna tuning                                              |
|            | 0011         | Config Byte 3       | Р             | LCZ antenna tuning                                              |
|            | 0100         | Config Byte 4       | Р             | LCX and LCY sensitivity reduction                               |
|            | 0101         | Config Byte 5       | Р             | LCZ sensitivity reduction and modulation depth                  |
|            | 0110         | Column Parity       | Р             | Column parity byte for Config Byte 0 -> Config Byte 5           |
|            | 0111         | Not Used            | Х             | Register is readable, but not writable                          |
| Note: 'P   | ' denotes tl | he row parity bit ( | odd parity    | ) for the respective data byte.                                 |

#### FIGURE 11-19: DETAILED SPI INTERFACE TIMING (AFE)



#### 11.32.2.1 Clamp On Command

This comm and result s in activating (turning on) the modulation transistors of all enabled channels; channels enabled in Configuration Register 0 (Register 11-1).

#### 11.32.2.2 Clamp Off Command

This command results in de-activating (turning off) the modulation transistors of all channels.

#### 11.32.2.3 Sleep Command

This command places the AFE in Sleep mode – minimizing current dr aw by disabling all but the essential circuitry. Any other command wakes the AFE (example: Clamp Off command).

#### 11.32.2.4 Soft Reset Command

The AFE is sues a Soft Reset when it rec eives an external Soft Reset command. The external Soft Reset command is typically used to end a SPI communication sequence or to in itialize the AFE for the next signal detection sequence, etc. See **Section 11.20 " Soft Reset"** for more details on Soft Reset.

If a Soft Reset command is sent during a "Clamp-on" condition, the AFE still keeps the "Clamp-on" condition after the So ft Reset e xecution. The Soft Re set is executed in Active mode on ly, not in Standby mode. The SPI Soft Reset command is ignored if the AFE is not in Active mode.

#### 11.32.2.5 AGC Preserve On Command

This command results in pre serving the AGC le vel during each AGC settling time and apply the value to the data slicing circuit for the following data stream. The preserved AGC value is reset by a S oft Reset, and a new AGC v alue is acq uired and pre served w hen it starts a new AGC settling time. This feature is disabled by an AGC Preserve Off command (see Section 11.19 "AGC Preserve").

#### 11.32.2.6 AGC Preserve Off Command

This command disables the AGC preserve feature and returns the AFE to the normal AGC tracking mode, fast tracking during AGC settling time and s low tracking after that (see **Section 11.19 "AGC Preserve"**).

#### 11.32.3 CONFIGURATION REGISTERS

The AFE includes 8 Configuration registers, including a column p arity register and AFE Status R egister. All registers a re rea dable a nd w ritable vi a SPI, ex cept STATUS register, which is readable only. Bit 0 of each register is a row parity bit (except for the AFE Status Register 7) that makes the register contents an od d number.

| Register Name            | Address | Bit 8                                                             | Bit 7        | Bit 6                      | Bit 5  | Bit 4   | Bit 3       | Bit 2         | Bit 1 | Bit 0 |
|--------------------------|---------|-------------------------------------------------------------------|--------------|----------------------------|--------|---------|-------------|---------------|-------|-------|
| Configuration Register 0 | 0000    | OEH                                                               | OEH OI       |                            | EL     | ALRTIND | LCZEN       | LCYEN         | LCXEN | R0PAR |
| Configuration Register 1 | 0001    | DATO                                                              | UT           | Channel X Tuning Capacitor |        |         |             |               | R1PAR |       |
| Configuration Register 2 | 0010    | RSSIFET                                                           | CLKDIV       | Channel Y Tuning Capacitor |        |         |             |               | R2PAR |       |
| Configuration Register 3 | 0011    | Unimplem                                                          | nented       | Channel Z Tuning Capacitor |        |         |             |               | R3PAR |       |
| Configuration Register 4 | 0100    | Cha                                                               | annel X Sens | itivity Control            |        | Cha     | annel Y Sen | sitivity Cont | rol   | R4PAR |
| Configuration Register 5 | 0101    | AUTOCHSEL                                                         | AGCSIG       | MODMIN                     | MODMIN | Cha     | annel Z Sen | sitivity Cont | rol   | R5PAR |
| Column Parity Register 6 | 0110    | Column Parity Bits                                                |              |                            |        |         | R6PAR       |               |       |       |
| AFE Status Register 7    | 0111    | Active Channel Indicators AGCACT Wake-up Channel Indicators ALARM |              |                            |        | PEI     |             |               |       |       |

#### TABLE 11-6: ANALOG FRONT-END CONFIGURATION REGISTERS SUMMARY

#### REGISTER 11-1: CONFIGURATION REGISTER 0

| R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0   | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|-------|-------|-------|-------|---------|-------|-------|-------|-------|
| OEH1  | OEH0  | OEL1  | OEL0  | ALRTIND | LCZEN | LCYEN | LCXEN | R0PAR |
| bit 8 |       |       |       |         |       |       |       | bit 0 |

| Legend:    |                                                      |                                |                                   |                                           |
|------------|------------------------------------------------------|--------------------------------|-----------------------------------|-------------------------------------------|
| R = Reada  | ble bit                                              | W = Writable bit               | U = Unimplemented bit             | t, read as '0'                            |
| -n = Value | at POR                                               | '1' = Bit is set               | '0' = Bit is cleared              | x = Bit is unknown                        |
| bit 8-7    |                                                      | is<br>Is                       |                                   | d, passes all signal to LFDATA)           |
| bit 6-5    | OEL<1:0><br>00 =1 m<br>01 =1 m<br>10 =2 m<br>11 =4 m | IS<br>IS                       | Time (TOEL) bit                   |                                           |
| bit 4      |                                                      | •                              | 5                                 | ection 11.14.3 "Alarm Timer")             |
| bit 3      | LCZEN: L<br>1 = Disat<br>0 = Enab                    |                                |                                   |                                           |
| bit 2      | LCYEN: L<br>1 = Disat<br>0 = Enab                    |                                |                                   |                                           |
| bit 1      | LCXEN: L<br>1 = Disat<br>0 = Enab                    |                                |                                   |                                           |
| bit 0      | ROPAR: R                                             | egister Parity bit – set/clear | red so the 9-bit register contair | ns odd parity – an odd number of set bits |

#### REGISTER 11-2: CONFIGURATION REGISTER 1

| R/W-0                                                                                               | R/W-0                                                                                                                                       | R/W-0           | R/W-0           | R/W-0           | R/W-0          | R/W-0          | R/W-0           | R/W-0        |  |  |
|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------|-----------------|----------------|----------------|-----------------|--------------|--|--|
| DATOUT1                                                                                             | DATOUT0                                                                                                                                     | LCXTUN5         | LCXTUN4         | LCXTUN3         | LCXTUN2        | LCXTUN1        | LCXTUN0         | R1PAR        |  |  |
| bit 8                                                                                               |                                                                                                                                             |                 |                 |                 |                |                |                 | bit 0        |  |  |
|                                                                                                     |                                                                                                                                             |                 |                 |                 |                |                |                 |              |  |  |
| Legend:                                                                                             |                                                                                                                                             |                 |                 |                 |                |                |                 |              |  |  |
| R = Readab                                                                                          | le bit                                                                                                                                      | W = Writable    | e bit           | U = Unimple     | mented bit, r  | ead as '0'     |                 |              |  |  |
| -n = Value a                                                                                        | t POR                                                                                                                                       | '1' = Bit is se | et              | '0' = Bit is cl | eared          | x = Bit is unl | known           |              |  |  |
| bit 8-7                                                                                             | bit 8-7 DATOUT<1:0>: LFDATA Output type bit<br>00 = Demodulated output<br>01 = Carrier Clock output<br>10 = RSSI output<br>11 = RSSI output |                 |                 |                 |                |                |                 |              |  |  |
| bit 6-1 LCXTUN<5:0>: LCX Tuning Capacitance bit<br>000000 = +0 pF (Default)<br>:<br>111111 = +63 pF |                                                                                                                                             |                 |                 |                 |                |                |                 |              |  |  |
| bit 0                                                                                               | R1PAR: Reg<br>bits                                                                                                                          | gister Parity B | it – set/cleare | ed so the 9-bi  | t register con | tains odd pari | ity – an odd nι | umber of set |  |  |

#### **REGISTER 11-3: CONFIGURATION REGISTER 2**

| R/W-0   | R/W-0  | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0 |
|---------|--------|---------|---------|---------|---------|---------|---------|-------|
| RSSIFET | CLKDIV | LCYTUN5 | LCYTUN4 | LCYTUN3 | LCYTUN2 | LCYTUN1 | LCYTUN0 | R2PAR |
| bit 8   |        |         |         |         |         |         |         | bit 0 |

| Legend:    |                                                                                                |                                                                    |                             |                                        |
|------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------|----------------------------------------|
| R = Read   | lable bit                                                                                      | W = Writable bit                                                   | U = Unimplemented b         | vit, read as '0'                       |
| -n = Value | e at POR                                                                                       | '1' = Bit is set                                                   | '0' = Bit is cleared        | x = Bit is unknown                     |
| bit 8      | 1 = Pull-                                                                                      | Pull-down MOSFET on<br>down RSSI MOSFET on<br>down RSSI MOSFET off | LFDATA pad bit (controllab  | le by user in the RSSI mode only)      |
| bit 7      | bit 7 <b>CLKDIV:</b> Carrier Clock Divide-by bit<br>1 = Carrier Clock/4<br>0 = Carrier Clock/1 |                                                                    | bit                         |                                        |
| bit 6-1    |                                                                                                | <5:0>: LCY Tuning Capa<br>= +0 pF (Default)<br>:<br>= +63 pF       | citance bit                 |                                        |
| bit 0      |                                                                                                | I.                                                                 | eared so the 9-bit register | contains odd parity – an odd number of |

#### **REGISTER 11-4: CONFIGURATION REGISTER 3**

| U-0   | U-0 | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0   | R/W-0 |
|-------|-----|---------|---------|---------|---------|---------|---------|-------|
| —     | —   | LCZTUN5 | LCZTUN4 | LCZTUN3 | LCZTUN2 | LCZTUN1 | LCZTUN0 | R3PAR |
| bit 8 |     |         |         |         |         |         |         | bit 0 |

|                                                                                        | Legend:           |                  |                       |                    |
|----------------------------------------------------------------------------------------|-------------------|------------------|-----------------------|--------------------|
| -n = Value at POR $(1)^{2}$ = Bit is set $(0)^{2}$ = Bit is cleared x = Bit is unknown | R = Readable bit  | W = Writable bit | U = Unimplemented bit | t, read as '0'     |
|                                                                                        | -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared  | x = Bit is unknown |

bit 8-7 Unimplemented: Read as '0'

- bit 6-1 LCZTUN<5:0>: LCZ Tuning Capacitance bit 000000 = +0 pF (Default) : 111111 = +63 pF
- bit 0 **R3PAR**: Register Parity Bit set/cleared so the 9-bit register contains odd parity an odd number of set bits

#### **REGISTER 11-5: CONFIGURATION REGISTER 4**

| R/W-0   | R/W-0 |
|---------|---------|---------|---------|---------|---------|---------|---------|-------|
| LCXSEN3 | LCXSEN2 | LCXSEN1 | LCXSEN0 | LCYSEN3 | LCYSEN2 | LCYSEN1 | LCYSEN0 | R4PAR |
| bit 8   |         |         |         |         |         |         |         | bit 0 |

| Legend:           |                  |                          |                    |
|-------------------|------------------|--------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, r | read as '0'        |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared     | x = Bit is unknown |

bit 8-5 LCXSEN<3:0><sup>(1)</sup>: Typical LCX Sensitivity Reduction bit

|         | 0000 = -0 dB (Default)                                                                                    |
|---------|-----------------------------------------------------------------------------------------------------------|
|         | 0001 = -2  dB                                                                                             |
|         | 0010 = -4  dB                                                                                             |
|         | 0011 = -6  dB                                                                                             |
|         | 0100 = -8  dB                                                                                             |
|         | 0101 = -10  dB                                                                                            |
|         | 0110 = -12 dB                                                                                             |
|         | 0111 = -14 dB                                                                                             |
|         | 1000 = -16 dB                                                                                             |
|         | 1001 = -18 dB                                                                                             |
|         | 1010 = -20 dB                                                                                             |
|         | 1011 = -22 dB                                                                                             |
|         | 1100 = -24 dB                                                                                             |
|         | 1101 = -26 dB                                                                                             |
|         | 1110 = -28 dB                                                                                             |
|         | 1111 = -30 dB                                                                                             |
| bit 4-1 | LCYSEN<3:0> <sup>(1)</sup> : Typical LCY Sensitivity Reduction bit                                        |
|         | 0000 = -0  dB (Default)                                                                                   |
|         | :                                                                                                         |
|         | 1111 = -30 dB                                                                                             |
| bit 0   | R4PAR: Register Parity Bit – set/cleared so the 9-bit register contains odd parity – an odd number of set |
| DIL U   | bits                                                                                                      |
|         | 010                                                                                                       |

Note 1: Assured monotonic increment (or decrement) by design.

#### **REGISTER 11-6: CONFIGURATION REGISTER 5**

| R/W-0                                                                                                                                                                                                                                                                                       | R/W-0                                                                                                            | R/W-0                                                                    | R/W-0             | R/W-0             | R/W-0            | R/W-0           | R/W-0           | R/W-0           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------------|-------------------|------------------|-----------------|-----------------|-----------------|
| AUTOCHSEL                                                                                                                                                                                                                                                                                   | AGCSIG                                                                                                           | MODMIN1                                                                  | MODMIN0           |                   | LCZSEN2          | LCZSEN1         | LCZSEN0         |                 |
|                                                                                                                                                                                                                                                                                             | AGUSIG                                                                                                           | MODIMINT                                                                 | MODIMINU          | LCZSEN3           | LCZSENZ          | LCZSENI         | LCZSENU         | R5PAR           |
| bit 8                                                                                                                                                                                                                                                                                       |                                                                                                                  |                                                                          |                   |                   |                  |                 |                 | bit 0           |
| Legend:                                                                                                                                                                                                                                                                                     |                                                                                                                  |                                                                          |                   |                   |                  |                 |                 |                 |
| R = Readable b                                                                                                                                                                                                                                                                              | i+                                                                                                               | W = Writable I                                                           | ait               |                   | nented bit, read | 1 22 (0)        |                 |                 |
|                                                                                                                                                                                                                                                                                             |                                                                                                                  |                                                                          | JI                | •                 | ,                |                 |                 |                 |
| -n = Value at PC                                                                                                                                                                                                                                                                            | )R                                                                                                               | '1' = Bit is set                                                         |                   | '0' = Bit is clea | ared             | x = Bit is unkr | nown            |                 |
| <ul> <li>bit 8 AUTOCHSEL: Auto Channel Select bit</li> <li>1 = Enabled – AFE selects channel(s) that has demodulator output "high" at the end of TSTAB; or otherwise, blocks t channel(s).</li> <li>0 = Disabled – AFE follows channel enable/disable bits defined in Register 0</li> </ul> |                                                                                                                  |                                                                          |                   |                   |                  |                 | se, blocks the  |                 |
| bit 7                                                                                                                                                                                                                                                                                       | 1 = Enabled<br>when the                                                                                          | modulator Outpu<br>– No output u r<br>e AGC begins re<br>d – the AFE pas | ntil AGC is regue | llating at ar oun | d 20 mVpp at i   |                 | AGC Active St   | atus bit is set |
| bit 6-5                                                                                                                                                                                                                                                                                     | <b>MODMIN&lt;1:0</b><br>00 =5 0%<br>01 =7 5%<br>10 =2 5%<br>11 =1 2%                                             | <b>D&gt;</b> : Minimum Mc                                                | dulation Depth    | bit               |                  | -               |                 |                 |
| bit 4-1                                                                                                                                                                                                                                                                                     | bit 4-1 LCZSEN<3:0> <sup>(1)</sup> : LCZ Sensitivity Reduction bit<br>0000 = -0dB (Default)<br>:<br>1111 = -30dB |                                                                          |                   |                   |                  |                 |                 |                 |
| bit 0                                                                                                                                                                                                                                                                                       | R5PAR: Regi                                                                                                      | ster Parity Bit –                                                        | set/cleared so    | the 9-bit registe | r contains odd   | parity – an odo | d number of set | bits            |
| Note 1: Ass                                                                                                                                                                                                                                                                                 | sured monotoni                                                                                                   | c increment (or                                                          | decrement) by     | design.           |                  |                 |                 |                 |

### REGISTER 11-7: COLUMN PARITY REGISTER 6

| R/W-0   | R/W-0 |
|---------|---------|---------|---------|---------|---------|---------|---------|-------|
| COLPAR7 | COLPAR6 | COLPAR5 | COLPAR4 | COLPAR3 | COLPAR2 | COLPAR1 | COLPAR0 | R6PAR |
| bit 8   |         |         |         |         |         |         |         | bit 0 |

| Legend:    |          |                                                                 |                                      |                                                      |
|------------|----------|-----------------------------------------------------------------|--------------------------------------|------------------------------------------------------|
| R = Read   | able bit | W = Writable bit                                                | U = Unimplemented bit,               | read as '0'                                          |
| -n = Value | e at POR | '1' = Bit is set                                                | '0' = Bit is cleared                 | x = Bit is unknown                                   |
|            |          |                                                                 |                                      |                                                      |
| bit 8      |          | 7: Set/Cleared so that this 8th mber of set bits.               | h parity bit + the sum of the Cor    | figuration register row parity bits contain an odd   |
| bit 7      |          | 6: Set/Cleared such that this odd number of set bits.           | 7th parity bit + the sum of the 7th  | bits in Configuration Registers 0 through 5 contain  |
| bit 6      |          | 5: Set/Cleared such that this odd number of set bits.           | 6th parity bit + the sum of the 6th  | bits in Configuration Registers 0 through 5 contain  |
| bit 5      |          | 4: Set/Cleared such that this<br>odd number of set bits.        | 5th parity bit + the sum of the 5th  | bits in Configuration Registers 0 through 5 contain  |
| bit 4      |          | <b>3</b> : Set/Cleared such that this 4 odd number of set bits. | 4th parity bit + the sum of the 4th  | bits in Configuration Registers 0 through 5 contain  |
| bit 3      |          | 2: Set/Cleared such that this 3 odd number of set bits.         | Brd parity bit + the sum of the 3rd  | bits in Configuration Registers 0 through 5 contain  |
| bit 2      |          | 1: Set/Cleared such that this 2 odd number of set bits.         | and parity bit + the sum of the 2nd  | bits in Configuration Registers 0 through 5 contain  |
| bit 1      |          | <b>0</b> : Set/Cleared such that this 1 d number of set bits.   | st parity bit + the sum of the 1st b | its in Configuration Registers 0 through 5 contain a |
| bit 0      | R6PAR:   | Register Parity bit – set/clear                                 | d co the 0 bit register contains     | odd parity – an odd number of set bits               |

#### REGISTER 11-8: AFE STATUS REGISTER 7

| R-0             | R-0                        | R-0                | R-0                                                    | R-0               | R-0             | R-0               | R-0                                   | R-0   |
|-----------------|----------------------------|--------------------|--------------------------------------------------------|-------------------|-----------------|-------------------|---------------------------------------|-------|
| CHZACT          | CHYACT                     | CHXACT             | AGCACT                                                 | WAKEZ             | WAKEY           | WAKEX             | ALARM                                 | PEI   |
| bit 8           |                            |                    |                                                        |                   |                 |                   |                                       | bit ( |
| Legend:         |                            |                    |                                                        |                   |                 |                   |                                       |       |
| R = Readable    | bit                        | W = Writable b     | pit                                                    | U = Unimplem      | ented bit, read | as '0'            |                                       |       |
| -n = Value at P | OR                         | '1' = Bit is set   |                                                        | '0' = Bit is clea |                 | x = Bit is unkn   | own                                   |       |
| bit 8           | 1 = Channel                | Z is passing dat   | bit (cleared via<br>ta after TAGC<br>g data after TAGC |                   |                 |                   |                                       |       |
| bit 7           | 1 = Channel                | Y is passing da    | bit (cleared via<br>ta after TAGC<br>data after TAGC   |                   |                 |                   |                                       |       |
| bit 6           | 1 = Channel                | X is passing da    | bit (cleared via<br>ta after TAGC<br>data after TAGC   | ,                 |                 |                   |                                       |       |
| bit 5           | 1 = AGC is a               |                    | 0,                                                     |                   | ,               | evel is approxima | ately > 20 mVPP ı                     | ange. |
| bit 4           | 1 = Channel                | Z caused a AFE     | Indicator Status<br>E wake-up (pass<br>a AFE wake-up   | ed ÷64 clock co   | ,               |                   |                                       |       |
| bit 3           | 1 = Channel                | Y caused a AFE     | Indicator Status<br>E wake-up (pass<br>a AFE wake-up   | ed ÷64 clock co   | ,               |                   |                                       |       |
| bit 2           | 1 = Channel                | X caused a AFE     | Indicator Status<br>E wake-up (pass<br>a AFE wake-up   | ed ÷64 clock co   | ,               |                   |                                       |       |
| bit 1           | 1 = The Alarr<br>Configura |                    | t has occurred. I                                      |                   |                 |                   | egister command<br>nding on the state |       |
| bit 0           |                            | or Indicator bit - | - indicates whetl                                      |                   |                 | ity error has occ | urred (real time)                     |       |

See Table 11-7 for the bit conditions of the AFE Status Register af ter various SPI c ommands and the AFE Power-on Reset.

### TABLE 11-7:AFE STATUS REGISTER BIT CONDITION (AFTER POWER-ON RESET AND<br/>VARIOUS SPI COMMANDS)

| Condition                              | Bit 8  | Bit 7  | Bit 6  | Bit 5  | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------------------|--------|--------|--------|--------|-------|-------|-------|-------|-------|
| Condition                              | CHZACT | СНҮАСТ | СНХАСТ | AGCACT | WAKEZ | WAKEY | WAKEX | ALARM | PEI   |
| POR                                    | 0      | 0      | 0      | 0      | 0     | 0     | 0     | 0     | 1     |
| Read Command<br>(STATUS Register only) | u      | u      | u      | u      | u     | u     | u     | 0     | u     |
| Sleep Command                          | u      | u      | u      | u      | u     | u     | u     | u     | u     |
| Soft Reset Executed <sup>(1)</sup>     | 0      | 0      | 0      | 0      | 0     | 0     | 0     | u     | u     |

Legend: u = unchanged

Note 1: See Section 11.20 "Soft Reset" and Section 11.32.2.4 "Soft Reset Command" for the condition of Soft Reset execution.

NOTES:

### 12.0 SPECIAL FEATURES OF THE CPU

The PIC12F635/PIC16F636/639 has a host of features intended to maximize system reliability, minimize cost through el imination of e xternal components, pro vide power saving features and offer code protection.

These features are:

- Reset
  - Power-on Reset (POR)
  - Wake-up Reset (WUR)
  - Power-up Timer (PWRT)
  - Oscillator Start-up Timer (OST)
  - Brown-out Reset (BOR)
- Interrupts
- Watchdog Timer (WDT)
- · Oscillator selection
- Sleep
- Code protection
- ID Locations
- In-Circuit Serial Programming<sup>™</sup>

The PIC 12F635/PIC16F636/639 has two timers that offer nec essary d elays on pow er-up. O ne i s th e Oscillator Start-up Timer (OST), intended to keep the chip in R eset until the crystal oscillator is stable. The other is the Power-up Timer (PWRT), which provides a fixed de lay of 6 4 ms (nominal) o n po wer-up on ly, designed to keep th e p art in R eset w hile th e po wer supply stabilizes. There is a lso c ircuitry to r eset th e device if a b rown-out oc curs, w hich c an us e th e Power-up Timer to provide at least a no minal 64 ms Reset. Wi th these th ree functions o n-chip, m ost applications need no external Reset circuitry.

The Sleep mode is designed to offer a very low-current Power-down mode. The user can wake-up from Sleep through:

- External Reset
- Watchdog Timer Wake-up
- An Interrupt

Several o scillator options are also made available to allow the part to fit the application. The INTOSC option saves system cost while the LP crystal option saves power. A set of Configuration bits are used to select various options (see Register 12-1).

### 12.1 Configuration Bits

The Configuration Word bits can be programmed (read as '0'), or le ft unp rogrammed (read as '1') to se lect various device configurations as shown in Register 12-1. These bits are mapped in program me mory location 2007h.

Note: Address 2007h is beyond the user program memory sp ace. It belong s to the special configuration me mory sp ace (20 00h-3FFFh), which can be accessed only during programming. See "PIC12F6XX/16F6XX *Memory Prog ramming Specification*" (DS41204) for more information.

#### REGISTER 12-1: CONFIG: CONFIGURATION WORD REGISTER

|                   | —       | —                                                                                                         | _                                                                                                                                                                                                          | WURE                                                                                                                       | FCMEN                                                                                            | IESO                                                                                                                            | BOREN1                                                                                   | BOREN0                          |
|-------------------|---------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------|
| bit 15            |         |                                                                                                           |                                                                                                                                                                                                            |                                                                                                                            |                                                                                                  | 1                                                                                                                               | 1                                                                                        | bit 8                           |
|                   |         |                                                                                                           |                                                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         |                                                                                                           | 1                                                                                                                                                                                                          |                                                                                                                            | 1                                                                                                | 1                                                                                                                               | 1                                                                                        | 1                               |
| C                 | CPD     | CP                                                                                                        | MCLRE                                                                                                                                                                                                      | PWRTE                                                                                                                      | WDTE                                                                                             | FOSC2                                                                                                                           | FOSC1                                                                                    | FOSC0                           |
| bit 7             |         |                                                                                                           |                                                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          | bit 0                           |
|                   |         |                                                                                                           |                                                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| Legen             |         | a hit                                                                                                     | W = Writable bit                                                                                                                                                                                           |                                                                                                                            | D Drogromm                                                                                       | abla'                                                                                                                           |                                                                                          | ated bit read as '0'            |
| R = Re<br>-n = Va |         |                                                                                                           | 1' = Bit is set                                                                                                                                                                                            |                                                                                                                            | P = Programm<br>'0' = Bit is clea                                                                |                                                                                                                                 | x = Bit is unknow                                                                        | nted bit, read as '0'           |
| -11 – Va          | iiue ai | FOR                                                                                                       | 1 – Dit 13 Set                                                                                                                                                                                             |                                                                                                                            |                                                                                                  | lieu                                                                                                                            |                                                                                          | VII                             |
| bit 15-           | 13      | Unimplemente                                                                                              | ed: Read as '1'                                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 12            |         | WURE: Wake-                                                                                               | up Reset Enable                                                                                                                                                                                            | bit                                                                                                                        |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         | 1 = Standard w                                                                                            | ake-up and conti                                                                                                                                                                                           | nue enabled                                                                                                                |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         | •                                                                                                         | nd Reset enabled                                                                                                                                                                                           |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 11            |         | 1 = Fail-Safe C                                                                                           | Safe Clock Monito<br>Clock Monitor is en<br>Clock Monitor is di                                                                                                                                            | nabled                                                                                                                     |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 10            |         | 1 = Internal Ex                                                                                           | External Switcho<br>ternal Switchover<br>ternal Switchover                                                                                                                                                 | mode is enable                                                                                                             |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 9-8           |         | 11 = BOR enal<br>10 = BOR enal<br>01 = BOR cont                                                           | Brown-out Reset<br>bled, SBOREN bi<br>bled during opera<br>rolled by SBORE<br>SBOREN bits dis                                                                                                              | t disabled<br>tion and disable<br>N bit of the PC                                                                          | ed in Sleep, SB                                                                                  | OREN bit disable                                                                                                                | əd                                                                                       |                                 |
| bit 7             |         |                                                                                                           | de Protection bit <sup>(2</sup>                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         |                                                                                                           | ory code protectio                                                                                                                                                                                         |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         |                                                                                                           | ory code protectio                                                                                                                                                                                         | on is enabled                                                                                                              |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 6             |         |                                                                                                           | ection bit <sup>(3)</sup><br>emory code prote<br>emory code prote                                                                                                                                          |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 5             |         | -                                                                                                         | R pin function sele                                                                                                                                                                                        |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         |                                                                                                           | function is MCLR                                                                                                                                                                                           |                                                                                                                            | 4 a wa a lla , 4 a a l 4 a . )                                                                   | 122                                                                                                                             |                                                                                          |                                 |
| bit 4             |         |                                                                                                           | function is digital<br>er-up Timer Enabl                                                                                                                                                                   |                                                                                                                            | ternally tied to v                                                                               | 00/                                                                                                                             |                                                                                          |                                 |
| DIL 4             |         | 1 = PWRT disa<br>0 = PWRT ena                                                                             | abled                                                                                                                                                                                                      | e bit                                                                                                                      |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
| bit 3             |         |                                                                                                           | dog Timer Enable                                                                                                                                                                                           | bit                                                                                                                        |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |
|                   |         | 1 = WDT enab                                                                                              | -                                                                                                                                                                                                          |                                                                                                                            | OTEN bit of the                                                                                  | WDTCON registe                                                                                                                  | er                                                                                       |                                 |
| bit 2-0           |         | 111 = EXTRO<br>110 = EXTRO<br>101 = INTOS<br>100 = INTOS<br>011 = EC: I/C<br>010 = HS osc<br>001 = XT osc | Scillator Selection<br>Coscillator: Extern<br>CIO oscillator: Extern<br>CIO oscillator: CLK<br>CIO oscillator: I/CO<br>function on RA4<br>cillator: High-spee<br>illator: Crystal/res<br>illator: Low-powe | nal RC on RA5,<br>ernal RC on RA<br>OUT function o<br>) function on R,<br>/OSC2/CLKOU<br>d crystal/reson<br>sonator on RA4 | 5/OSC1/CLKIN<br>n RA4/OSC2/C<br>A4/OSC2/CLKC<br>IT pin, CLKIN o<br>ator on RA4/OS<br>/OSC2/CLKOU | , I/O function on F<br>LKOUT pin, I/O f<br>DUT pin, I/O funct<br>n RA5/OSC1/CLI<br>GC2/CLKOUT and<br>T and RA5/OSC <sup>2</sup> | RA4/OSC2/CLKO<br>unction on RA5/C<br>tion on RA5/OSC<br>KIN<br>d RA5/OSC1/CLF<br>1/CLKIN | UT pin<br>DSC1/CLKIN<br>1/CLKIN |
| Note              |         | Enabling Brown-out<br>The entire data EEP                                                                 |                                                                                                                                                                                                            |                                                                                                                            |                                                                                                  |                                                                                                                                 |                                                                                          |                                 |

- 3: The entire program memory will be erased when the code protection is turned off.
  4: When MCLR is asserted in INTOSC or RC mode, the internal clock oscillator is disabled.
- DS41232D-page 130

#### 12.2 Reset

The PIC12F635/PIC16F636/639 differentiates between various kinds of Reset:

- a) Power-on Reset (POR)
- b) Wake-up Reset (WUR)
- c) WDT Reset during normal operation
- d) WDT Reset during Sleep
- e) MCLR Reset during normal operation
- f) MCLR Reset during Sleep
- g) Brown-out Reset (BOR)

Some registers are not affected in any Reset condition; their status is unknown on POR and unchanged in any other Reset. Most other registers are reset to a "Reset state" on:

Power-on Reset

#### •M CLR Reset

- MCLR Reset during Sleep
- WDT Reset
- Brown-out Reset

They are not affected by a WDT wake-up since this is viewed as the resumption of normal operation. TO and  $\overline{PD}$  bits are set or cleared differently in different Reset situations, as indicated in Table 12-3. The se bits a re used in software to determine the nature of the Reset. See Table 12-4 for a full description of Reset states of all registers.

A simplified block diagram of the On-Chip Reset Circuit is shown in Figure 12-1.

The MCLR Reset path has a noise filter to detect and ignore small pul ses. See Section 15.0 " Electrical Specifications" for pulse width specifications.

#### FIGURE 12-1: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT



#### 12.3 Power-on Reset

The on-chip POR circuit holdsthe chip in Reset until VDD has reached a high erough level for proper operation. To take advantage of the POR, simply connect the MCLR pin through a resistor to VDD. This will eliminate external RC components usually needed to create P ower-on Reset. A maxi mum rise time for VDD is required. See **Section 15.0 "Electrical Specifications**" for details. If the BOR is enabled, the maximum rise time specification does not apply. The BOR circuitry will keep the device in Reset until V DD reaches VBOD (s ee **Section 12.6 "Brown-out Reset (BOR)**").

| Note: | The POR c ircuit d oes not p roduce a n |
|-------|-----------------------------------------|
|       | internal Reset w hen V DD dec lines. To |
|       | re-enable the POR, VDD must reach VSS   |
|       | for a minimum of 100 μs.                |

When the dev ice s tarts n ormal o peration (e xits th e Reset condition), device ope rating p arameters (i.e., voltage, frequency, temperature, etc.) must be met to ensure operation. If these conditions are not met, the device m ust b e h eld i n R eset un til th e o perating conditions are met.

For additional information, refer to the Application Note *AN607, "Power-up Trouble Shooting"* (DS00607).

#### 12.4 Wake-up Reset (WUR)

The PIC12F635/PIC16F636/639 h as a m odified wake-up from Sleep mechanism. When waking from Sleep, the WUR function resets the device and releases Reset when VDD reaches an acceptable level.

If the WURE bit is enabled (' 0') in the Configuration Word register, the d evice will W ake-up R eset from Sleep through one of the following events:

- 1. On any event that causes a wake-up event. The peripheral must be enabled to generate an interrupt or wake-up, GIE state is ignored.
- 2. When WURE is e nabled, R A3 w ill al ways generate an interrupt-on-change signal d uring Sleep.

The  $\overline{WUR}$ ,  $\overline{POR}$  and  $\overline{BOR}$  bits in the PCON register and the  $\overline{TO}$  and  $\overline{PD}$  bits in the STATUS register can be used to determine the cause of device Reset.

To allow WUR upon RA3 change:

- Enable the WUR function, WURE Configuration Bit = 0.
- 2. Enable RA3 as an input, MCLRE Configuration Bit = 0.
- 3. Read PORTA to establish the current state of RA3.
- 4. Execute **SLEEP** instruction.
- 5. When R A3 c hanges state, t he device will wake-up and then reset. The WUR bit in PCON will be cleared to '0'.

#### 12.4.1 POWER-UP TIMER (PWRT)

The Power-up Timer provides a fixed 64 ms (nominal) time-out on pow er-up on ly, from POR or Brown-out Reset. The Power-up Timer operates from the 31 kHz LFINTOSC o scillator. F or m ore in formation, se e **Section 3.5 "Internal Clock Modes**". The chip is kept in Reset as long as PWRT is active. The PWRT delay allows the VDD to rise to an acceptable level. A Configuration bit, PWRTE, can disable (if set) or enable (if cleared or programmed) the Power-up Timer. The Power-up Timer should be enabled when B rown-out Reset is enabled, although it is not required.

The Power-up Timer delay will vary from chip-to-chip due to:

- VDD variation
- Temperature variation
- Process variation

See D C parameters for det ails ( Section 15.0 "Electrical Specifications").

Note: Voltage spikes be low V ss at the  $\overline{M}$  CLR pin, inducing currents greater than 80 mA, may cause latch-up. Thus, a series resistor of 50 -100  $\Omega$  s hould be us ed w hen applying a "low" level to the  $\overline{M}$  CLR pin, rather than pulling this pin directly to Vss.

### 12.5 MCLR

PIC12F635/PIC16F636/639 has a noise filter in the MCLR Reset path. The filter will ignore small pulses.

It should be noted that a WDT Reset does not drive  $\frac{MCLR}{MCLR}$  pin low. See Figure 12-2 for the recommended MCLR circuit.

An internal  $\overline{\text{MCLR}}$  option is enabled by clearing the MCLRE bit in the Configuration Word register. When cleared,  $\overline{\text{MCLR}}$  is internally tied to VDD and an internal weak pull-up is enabled for the  $\overline{\text{MCLR}}$  pin. In-Circuit Serial Programming is not affected by selecting the internal  $\overline{\text{MCLR}}$  option.





#### 12.6 Brown-out Reset (BOR)

The BOREN0 and BOR EN1 b its in the Configuration Word r egister select one of four B OR modes. Two modes have been added to allow software or hardware control of the BOR enable. When BOR EN<1:0> = 01, the SBOREN bit of the PCON register enables/disables the BOR all owing it to be controlled in software. By selecting BOREN<1:0>, the BOR is a utomatically disabled in Sleep to cons erve power and enabled on wake-up. In this mode, the SEDREN bit is disabled See Register 12-1 for the Configuration Word definition.

If V DD fall s belo w V BOD for greater than parameter (TBOD) (see **Section 15.0** "**Electrical Specifications**"), the Brown-out situation will reset the device. This will occur regardles s of V DD sle w rate. A Reset i s not ensured to occur if V DD falls below VBOD for less than parameter (TBOD).

On any Reset (Power-on, Brown-out Reset, Watchdog Timer, etc.), the chip will remain in Reset until VDD rises above V BOD (s ee Fig ure 12-3). The Po wer-up Timer will now be invoked, if enabled and will keep the chip in Reset an additional nominal 64 ms.

| Note: | The Power-up Timer is en abled by the |
|-------|---------------------------------------|
|       | PWRTE bit in the Configuration Word   |
|       | register.                             |

If VDD drops below VBOD while the Power-up Timer is running, the chip will go back into a Brown-out Reset and the Power-up Timer will be re-initialized. Once VDD rises above VBOD, the Power-up Timer will execute a 64 ms Reset.



#### FIGURE 12-3: BROWN-OUT RESET SITUATIONS

#### 12.7 **Time-out Sequence**

On power-up, the time-out sequence is as follows: first, PWRT time-out is invoked after POR has expired, then OST is activated after the PWRT time-out has expired. The tot al t ime-out w ill vary ba sed on os cillator Configuration and PWRTE bit status. For example, in EC mode with PWRTE bit erase d (PWRT di sabled), there will be no time-out at all. Figure 12-4, Figure 12-5 and Figure 12-6 depict time-out sequences. The device can execute code from the INTOSC, while OST is active, by enabling T wo-Speed S tart-up or Fail-Safe C lock Section 3.7.2 " Two-Speed S tart-up Monitor (See Section 3.8 "Fail- Safe Clock Sequence" and Monitor").

Since the time-outs occur from the POR pulse, if MCLR is kept low long enough, the time-outs will expire. Then bringing MCLR high will begin execution immediately (see Figure 12-5). This is useful for testing purposes or to sync hronize more than one PIC12F635/PIC16F636/639 device operating in parallel.

Table 12-5 shows the R eset c onditions for s ome special registers, while Table 12-4 shows the Reset conditions for all the registers.

TABLE 12-1:

#### 12.8 Power Control (PCON) Register

The Power Control register, PCON (address 8Eh), has two Status bits to indicate what type of Reset that last occurred.

Bit 0 is BOR (Brown-out). BOR is un known on Power-on Reset. It must then be set by the user and checked on subsequent Resets to see if  $\overline{BOR} = 0$ , indicating that a Brown-out has occurred. The BOR Status bit is a "do n't c are" and i s n ot necessarily predictable if the b rown-out circuit is di sabled (BOREN<1:0> = 00 in the C onfiguration W ord register).

Bit 1 is POR (Power-on Reset). It is a '0' on Power-on Reset and unaffected otherwise. The user must write a '1' to the is b it following a Power-on Reset. On a subsequent Reset, if POR is '0', it will indicate that a Power-on Res et h as oc curred (i.e., V DD may h ave gone too low).

For m ore information, s ee Section 4.2.3 " Ultra Low-Power Wake-up" and Section 12.6 "Brown-out Reset (BOR)".

| Oscillator     | Power-              | up          | Brown-out I         | Wake-up          |             |
|----------------|---------------------|-------------|---------------------|------------------|-------------|
| Configuration  | <b>PWRTE =</b> 0    | PWRTE = 1   | <b>PWRTE =</b> 0    | <b>PWRTE =</b> 1 | from Sleep  |
| XT, HS, LP     | TPWRT + 1024 • TOSC | 1024 • Tosc | TPWRT + 1024 • TOSC | 1024 • Tosc      | 1024 • Tosc |
| RC, EC, INTOSC | TPWRT               | —Т          | PWRT                |                  |             |

TIME-OUT IN VARIOUS SITUATIONS

| IADLE I               | TABLE 12-2. SUMMART OF REGISTERS ASSOCIATED WITH BROWN-OUT RESET |        |       |       |        |        |       |       |       |       |                      |                                                |
|-----------------------|------------------------------------------------------------------|--------|-------|-------|--------|--------|-------|-------|-------|-------|----------------------|------------------------------------------------|
| Name                  | Bit 9                                                            | Bit 8  | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR, BOR | Value on<br>all other<br>Resets <sup>(1)</sup> |
| CONFIG <sup>(2)</sup> | BOREN1                                                           | BOREN0 | CPD   | CP    | MCLRE  | PWRTE  | WDTE  | FOSC2 | FOSC1 | FOSC0 |                      |                                                |
| PCON                  |                                                                  |        |       |       | ULPWUE | SBOREN | WUR   | _     | POR   | BOR   | 01qq                 | 0uuu                                           |
| STATUS                |                                                                  |        | IRP   | RP1   | RP0    | TO     | PD    | Z     | DC    | С     | 0001 1xxx            | 000q quuu                                      |

#### SUMMARY OF REGISTERS ASSOCIATED WITH BROWN-OUT RESET TADI E 12 2.

u = unchanged, x = unknown, - = unimplemented bit, reads as '0', q = value depends on condition. Shaded cells are not used by BOR. Legend: Note 1: Other (non Power-up) Resets include MCLR Reset and Watchdog Timer Reset during normal operation.

2. See Configuration Word register (Register 12-1) for operation of all register bits.

#### **TABLE 12-3**: PCON BITS AND THEIR SIGNIFICANCE

| POR   | BOR | WUR | то | PD | Condition                          |  |
|-------|-----|-----|----|----|------------------------------------|--|
| 0     | х   | х   | 1  | 1  | Power-on Reset                     |  |
| u0u11 | -   |     |    |    | Brown-out Reset                    |  |
| սսս0ս | 1   |     |    |    | WDT Reset                          |  |
| uuu00 | )   |     |    |    | WDT Wake-up                        |  |
| սսսսս | 1   |     |    |    | MCLR Reset during normal operation |  |
| u     | u   | u   | 1  | 0  | MCLR Reset during Sleep            |  |
| u     | u   | 0   | 1  | 0  | Wake-up Reset during Sleep         |  |
| u     | 0   | u   | 1  | 1  | Brown-out Reset during Sleep       |  |

**Legend:** u = unchanged, x = unknown



#### FIGURE 12-5: TIME-OUT SEQUENCE ON POWER-UP (DELAYED MCLR)



#### FIGURE 12-6: TIME-OUT SEQUENCE ON POWER-UP (MCLR WITH VDD)



| Register             | Address | Power-on<br>Reset<br>Wake-up Reset | MCLR Reset<br>WDT Reset<br>Brown-out Reset <sup>(1)</sup><br>Wake-up Reset | Wake-up from Sleep<br>through Interrupt<br>Wake-up from Sleep<br>through WDT Time-out |
|----------------------|---------|------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| W                    | _       | xxxx xxxx                          | uuuu uuuu                                                                  | սսսս սսսս                                                                             |
| INDF                 | 00h/80h | xxxx xxxx                          | xxxx xxxx                                                                  | սսսս սսսս                                                                             |
| TMR0                 | 01h     | xxxx xxxx                          | uuuu uuuu                                                                  | սսսս սսսս                                                                             |
| PCL                  | 02h/82h | 0000 0000                          | 0000 0000                                                                  | PC + 1 <sup>(3)</sup>                                                                 |
| STATUS               | 03h/83h | 0001 1xxx                          | 000q quuu <sup>(4)</sup>                                                   | uuuq quuu <sup>(4)</sup>                                                              |
| FSR                  | 04h/84h | xxxx xxxx                          | uuuu uuuu                                                                  | uuuu uuuu                                                                             |
| PORTA                | 05h     | xx xx00                            | 00 0000                                                                    | uu uu00                                                                               |
| PORTC <sup>(6)</sup> | 07h     | xx xx00                            | 00 0000                                                                    | uu uu00                                                                               |
| PCLATH               | 0Ah/8Ah | 0 0000                             | 0 0000                                                                     | u uuuu                                                                                |
| INTCON               | 0Bh/8Bh | 0000 000x                          | 0000 000x                                                                  | uuuu uuuu <sup>(2)</sup>                                                              |
| PIR1                 | 0Ch     | 0000 00-0                          | 0000 00-0                                                                  | uuuu uu-u <sup>(2)</sup>                                                              |
| TMR1L                | 0Eh     | xxxx xxxx                          | <u>uuuu</u> uuuu                                                           | นนนน นนนน                                                                             |
| TMR1H                | 0Fh     | xxxx xxxx                          | uuuu uuuu                                                                  | սսսս սսսս                                                                             |
| T1CON                | 10h     | 0000 0000                          | uuuu uuuu                                                                  | -uuu uuuu                                                                             |
| WDTCON               | 18h     | 0 1000                             | 0 1000                                                                     | u uuuu                                                                                |
| CMCON0               | 19h     | 0000 0000                          | 0000 0000                                                                  | սսսս սսսս                                                                             |
| CMCON1               | 1Ah     | 10                                 | 10                                                                         | uu                                                                                    |
| OPTION_REG           | 81h     | 1111 1111                          | 1111 1111                                                                  | սսսս սսսս                                                                             |
| TRISA                | 85h     | 11 1111                            | 11 1111                                                                    | uu luuu                                                                               |
| TRISC <sup>(6)</sup> | 87h     | 11 1111                            | 11 1111                                                                    | uu luuu                                                                               |
| PIE1                 | 8Ch     | 0000 00-0                          | 0000 00-0                                                                  | uuuu uu-u                                                                             |
| PCON                 | 8Eh     | 01 q-qq                            | 0u u-uu <sup>(1,5)</sup>                                                   | Ou u-uu                                                                               |
| OSCCON               | 8Fh     | -110 q000                          | -110 q000                                                                  | -uuu uuuu                                                                             |
| OSCTUNE              | 90h     | 0 0000                             | u uuuu                                                                     | u uuuu                                                                                |
| WPUDA                | 95h     | 11 -111                            | 11 -111                                                                    | uuuu uuuu                                                                             |
| IOCA                 | 96h     | 00 0000                            | 00 0000                                                                    | uu uuuu                                                                               |
| WDA                  | 97h     | 11 -111                            | 11 -111                                                                    | սսսս սսսս                                                                             |
| VRCON                | 99h     | 0-0- 0000                          | 0-0- 0000                                                                  | u-u- uuuu                                                                             |
| EEDAT                | 9Ah     | 0000 0000                          | 0000 0000                                                                  | սսսս սսսս                                                                             |
| EEADR                | 9Bh     | 0000 0000                          | 0000 0000                                                                  | սսսս սսսս                                                                             |
| EECON1               | 9Ch     | x000                               | d000                                                                       | uuuu                                                                                  |
| EECON2               | 9Dh     |                                    |                                                                            |                                                                                       |
| ADRESL               | 9Eh     | xxxx xxxx                          | <u>uuuu</u> uuuu                                                           | uuuu uuuu                                                                             |
| ADCON1               | 9Fh     | -000                               | -000                                                                       | -uuu                                                                                  |
| LVDCON               | 94h     | 00 -000                            | 00-000                                                                     | uu -uuu                                                                               |
| CRCON                | 110h    | 0000                               | 0000                                                                       | uuuu                                                                                  |

#### TABLE 12-4: INITIALIZATION CONDITION FOR REGISTERS

 $\label{eq:logend: u = unchanged, x = unknown, - = unimplemented bit, reads as `0', q = value depends on condition.$ 

**Note 1:** If VDD goes too low, Power-on Reset will be activated and registers will be affected differently.

2: One or more bits in INTCON and/or PIR1 will be affected (to cause wake-up).

4: See Table 12-5 for Reset value for specific condition.

**5:** If Reset was due to brown-out, then bit 0 = 0. All other Resets will cause bit 0 = u.

6: PIC16F636/639 only.

<sup>3:</sup> When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).

#### TABLE 12-5: INITIALIZATION CONDITION FOR SPECIAL REGISTERS

| Condition                          | Program<br>Counter    | Status<br>Register | PCON<br>Register |
|------------------------------------|-----------------------|--------------------|------------------|
| Power-on Reset                     | 000h                  | 0001 1xxx          | 010x             |
| MCLR Reset during normal operation | 000h                  | 000u uuuu          | 0uuu             |
| MCLR Reset during Sleep            | 000h                  | 0001 0uuu          | 0uuu             |
| WDT Reset                          | 000h                  | 0000 uuuu          | 0uuu             |
| WDT Wake-up                        | PC + 1                | uuu0 0uuu          | uuuu             |
| Brown-out Reset                    | 000h                  | 0001 luuu          | 0110             |
| Interrupt Wake-up from Sleep       | PC + 1 <sup>(1)</sup> | uuul 0uuu          | uuuu             |
| Wake-up Reset                      | 000h                  | 0001 1xxx          | 010x             |

**Legend:** u = unchanged, x = unknown, - = unimplemented bit, reads as '0'.

**Note 1:** When the wake-up is due to an interrupt and the Global Interrupt Enable bit, GIE, is set, the PC is loaded with the interrupt vector (0004h) after execution of PC + 1.

#### 12.9 Interrupts

The PIC12F635/PIC16F636/639 has multiple interrupt sources:

- External Interrupt RA2/INT
- Timer0 Overflow Interrupt
- PORTA Change Interrupts
- 2 Comparator Interrupts
- Timer1 Overflow Interrupt
- EEPROM Data Write Interrupt
- Fail-Safe Clock Monitor Interrupt

The Interrupt Control register (INTCON) and Peripheral Interrupt R equest R egister 1 (PI R1) record individual interrupt requests in f lag bits. The IN TCON register also has individual and global interrupt enable bits.

A Global Interrupt Enable bit GIE of the INTCON register enables (if set) all unmasked interrupts, or disables (if c leared) all interrupts. Individual interrupts can be disabled through their corresponding enable bits in the INTCON register and PIE1 register. GIE is cleared on Reset.

The Return from Interrupt instruction, RETFIE, exits the interrupt routine, as well as sets the GIE bit, which re-enables unmasked interrupts.

The fol lowing in terrupt fl ags are contained in the INTCON register:

- INT Pin Interrupt
- PORTA Change Interrupt
- TMR0 Overflow Interrupt

The per ipheral interrupt flags are c ontained in the special re gister, PIR 1. T he c orresponding in terrupt enable bit is contained in special register, PIE1.

The following interrupt flags are contained in the PIR1 register:

- EEPROM Data Write Interrupt
- 2 Comparator Interrupts
- Timer1 Overflow Interrupt
- Fail-Safe Clock Monitor Interrupt

When an interrupt is serviced:

- The GIE is cleared to disable any further interrupt.
- The return address is pushed onto the stack.
- The PC is loaded with 0004h.

For external interrupt events, such as the INT pin or PORTA change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends upon when the interrupt event occurs (see Figure 12-8). The latency is the same for one or two-cycle instructions. On ce in the Interrupt Service Routine, the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid multiple interrupt requests.

- Note 1: Individual interrupt flag bits are set, regardless of the st atus of the ir corresponding mask bit or the GIE bit.
  - 2: When an instruction that clears the G IE bit is ex ecuted, any interrupts that were pending for ex ecution in the next cy cle are i gnored. The interrupts, which were ignored, are still pending to be serviced when the GIE bit is set again.

For additional information on Timer1, comparators or data EEPROM m odules, r efer to t he re spective peripheral section.

#### 12.9.1 RA2/INT INTERRUPT

External in terrupt on R A2/INT pin is edge-triggered; either rising if the INTEDG bit of the OPTION register is set, or falling if the INTEDG bit is clear. When a valid edge appears on the RA2/INT pin, the INTF bit of the INTCON register is set. This interrupt can be disabled by clearing the INTE control bit of the INTCON register. The INTF bit must be cleared in software in the Interrupt Service R outine before re-enabling this in terrupt. The RA2/INT interrupt can w ake-up the proce ssor from Sleep if the INTE bit was set prior to going into Sleep. The status of the G IE bit decid es whether or not the processor br anches to the interrupt vector follow ing wake-up (0004h). See **Section 12.12 "Power-Down Mode (Sleep)"** for details on Sleep and Figure12-10 for timing of wake-up from Sleep through RA2/INT interrupt.

**Note:** The CM CON0 (1 9h) re gister mu st be initialized to configure an analog channel as a d igital inp ut. Pins configured a s analog inputs will read '0'.

#### 12.9.2 TIMER INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TM R0 register will set the T0IF bit of the INTCON register. The interrupt can be enabled/disabled by s etting/clearing T0IE bit of the INTCON register. See **Section 5.0** "**Timer0 Module**" for operation of the Timer0 module.

#### 12.9.3 PORTA INTERRUPT

An input change on PORTA change sets the RAIF bit of the IN TCON register . The interrupt can be enabled/disabled by setting/clearing the RAIE bit of the INTCON register. Plus, individual pins can be configured through the IOCA register.

Note: If a change on t he I/O pin should occur when the read operation is being executed (start of the Q 2 cycle), then t he RAIF interrupt flag may not get set.



#### FIGURE 12-7: INTERRUPT LOGIC

| FIGURE 12-8:             | INT PIN INT             | ERRUPT TIMINO     | 6                                |                        |                                       |
|--------------------------|-------------------------|-------------------|----------------------------------|------------------------|---------------------------------------|
|                          | Q1   Q2   Q3   Q4       | Q1   Q2   Q3   Q4 | Q1 Q2 Q3 Q4                      | Q1   Q2   Q3   Q4      | Q1   Q2   Q3   Q4                     |
| OSC1                     |                         |                   |                                  |                        |                                       |
| CLKOUT <sup>(3)</sup>    | (4)                     |                   |                                  | \/                     |                                       |
| INT pin                  |                         | (1)               | 1<br>1<br>1                      | i<br>i<br>i            | · · · · · · · · · · · · · · · · · · · |
| INTF Flag<br>(INTCON<1>) | , (1) (5)               | ¥ (')             | Interrupt Latency <sup>(2)</sup> |                        |                                       |
| GIE bit<br>(INTCON<7>)   |                         |                   |                                  | 1<br>1<br><del>.</del> |                                       |
| Instruction Flow<br>PC   |                         |                   | Y PC+1                           |                        | × 0005h                               |
| Instruction<br>Fetched   | Inst (PC)               | Inst (PC + 1)     |                                  | Inst (0004h)           | Inst (0005h)                          |
| Instruction Executed     | Inst (PC – 1)           | Inst (PC)         | Dummy Cycle                      | Dummy Cycle            | Inst (0004h)                          |
|                          | flag is sampled here (e | <b>,</b>          |                                  | where Toy instruct     | an avala tima. Latanav                |

- 2: Asynchronous interrupt latency = 3-4 Tcy. Synchronous latency = 3 Tcy, where Tcy = instruction cycle time. Latency is the same whether Inst (PC) is a single cycle or a 2-cycle instruction.
- 3: CLKOUT is available only in INTOSC and RC Oscillator modes.
- 4: For minimum width of INT pulse, refer to AC specifications in Section 15.0 "Electrical Specifications".
- 5: INTF is enabled to be set any time during the Q4-Q1 cycles.

| Name   | Bit 7  | Bit 6 | Bit 5 | Bit 4               | Bit 3 | Bit 2 | Bit 1 | Bit 0  | Value on:<br>POR, BOR | Value on<br>all other<br>Resets |
|--------|--------|-------|-------|---------------------|-------|-------|-------|--------|-----------------------|---------------------------------|
| INTCON | GIE PI | EIE   | T0IE  | INTE                | RAIE  | T0IF  | INTF  | RAIF   | 0000 000x             | 0000 000x                       |
| IOCA   | —      | _     | IOCA5 | IOCA4               | IOCA3 | IOCA2 | IOCA1 | IOCA0  | 00 0000               | 00 0000                         |
| PIR1   | EEIF   | LVDIF | CRIF  | C2IF <sup>(1)</sup> | C1IF  | OSFIF | _     | TMR1IF | 0000 00-0             | 0000 00-0                       |
| PIE1   | EEIE   | LVDIE | CRIE  | C2IE <sup>(1)</sup> | C1IE  | OSFIE |       | TMR1IE | 0000 00-0             | 0000 00-0                       |

#### TABLE 12-6: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

**Legend:** x = unknown, u = unchanged, - = unimplemented, read as '0', q = value depends upon condition. Shaded cells are not used by the Interrupt module.

Note 1: PIC16F636/639 only.

#### 12.10 Context Saving During Interrupts

During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt (e.g., W and STATUS registers). This must be implemented in software.

Since the lower 16 bytes of all banks are common in the PIC12F635/PIC16F636/639 (see Figure 2-2), temporary holding registers, W\_TEMP and STATUS\_TEMP, should be p laced in h ere. These 16 lo cations do not require banking and therefore, make it easier to context save and restore. The same code shown in Example 12-1 can be used to:

- Store the W register.
- Store the STATUS register.
- Execute the ISR code.
- Restore the Status (and Bank Select Bit register).
- Restore the W register.

| Note: | The PIC12F635/PIC16F636/639 normally    |
|-------|-----------------------------------------|
|       | does no t req uire s aving the PC LATH. |
|       | However, if computed GOTO's are used in |
|       | the ISR and the main code, the PCLATH   |
|       | must be saved and restored in the ISR.  |

#### EXAMPLE 12-1: SAVING STATUS AND W REGISTERS IN RAM

| MOVWF<br>SWAPF | W_TEMP<br>STATUS,W | ;Copy W to TEMP register<br>;Swap status to be saved into W                                   |
|----------------|--------------------|-----------------------------------------------------------------------------------------------|
| SWAFT          | 51A105,W           | ;Swap status to be saved into w<br>;Swaps are used because they do not affect the status bits |
| MOVWF<br>:     | STATUS_TEMP        | ;Save status to bank zero STATUS_TEMP register                                                |
| :(ISR)<br>:    |                    | ;Insert user code here                                                                        |
| SWAPF          | STATUS_TEMP,W      | ;Swap STATUS_TEMP register into W<br>;(sets bank to original state)                           |
| MOVWF          | STATUS             | ;Move W into STATUS register                                                                  |
| SWAPF          | W_TEMP,F           | ;Swap W_TEMP                                                                                  |
| SWAPF          | W_TEMP,W           | ;Swap W_TEMP into W                                                                           |

### 12.11 Watchdog Timer (WDT)

The PIC 12F635/PIC16F636/639 WD T is c ode an d functionally compatible w ith o ther P IC16F W DT modules and adds a 16-bit prescaler to the WDT. This allows the user to have a scaler value for the WDT and TMR0 at the same time. In addition, the WDT time-out value can be extended to 268 seconds. WDT is cleared under certain conditions described in Table 12-7.

#### 12.11.1 WDT OSCILLATOR

The W DT d erives its t ime base f rom t he 31 kHz LFINTOSC. Th e L TS bit do es not refl ect that the LFINTOSC is enabled.

The value of WDTCON is '---0 1000' on all Resets. This giv es a no minal time base of 16 ms, which is compatible with the time base generated with previous PIC12F635/PIC16F636/639 microcontroller versions.



A new prescaler has been added to the path between the INTRC and the multiplexers used to select the path for the WDT. This prescaler is 16 bits and can be programmed to divide the IN TRC by 32 to 65 536, giving the WDT a nominal range of 1 ms to 268s.

#### 12.11.2 WDT CONTROL

The WD TE bit is I ocated in the Configuration W ord register. When set, the WDT runs continuously.

When the WDTE bit in the Configuration Word register is set, the SWDTEN bit of the WDTCON register has no effect. If WDTE is clear, then the SWDTEN bit can be used to enable and disable the WDT. Setting the bit will enable it and clearing the bit will disable it.

The PSA a nd PS<2:0 > b its of t he OP TION register have the same function as in previous versions of the PIC16F fa mily of m icrocontrollers. See **Section 5.0 "Timer0 Module"** for more information.

#### FIGURE 12-9: WATCHDOG TIMER BLOCK DIAGRAM



#### TABLE 12-7: WDT STATUS

| Conditions                                                 | WDT                          |  |
|------------------------------------------------------------|------------------------------|--|
| WDTE = 0                                                   |                              |  |
| CLRWDT Command                                             | Cleared                      |  |
| Oscillator Fail Detected                                   |                              |  |
| Exit Sleep + System Clock = T1OSC, EXTRC, HFINTOSC, EXTCLK |                              |  |
| Exit Sleep + System Clock = XT, HS, LP                     | Cleared until the end of OST |  |

| U-0                                                                                                                                                                                                      | U-0                      | U-0              | R/W-0         | R/W-1            | R/W-0            | R/W-0          | R/W-0                 |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|------------------|---------------|------------------|------------------|----------------|-----------------------|--|--|--|
| —                                                                                                                                                                                                        | —                        | —                | WDTPS3        | WDTPS2           | WDTPS1           | WDTPS0         | SWDTEN <sup>(1)</sup> |  |  |  |
| bit 7                                                                                                                                                                                                    |                          |                  |               |                  |                  | bit C          |                       |  |  |  |
|                                                                                                                                                                                                          |                          |                  |               |                  |                  |                |                       |  |  |  |
| Legend:                                                                                                                                                                                                  |                          |                  |               |                  |                  |                |                       |  |  |  |
| R = Reada                                                                                                                                                                                                | ble bit                  | W = Writable     | bit           | U = Unimpler     | mented bit, read | d as '0'       |                       |  |  |  |
| -n = Value                                                                                                                                                                                               | at POR                   | '1' = Bit is set | :             | '0' = Bit is cle | ared             | x = Bit is unk | nown                  |  |  |  |
|                                                                                                                                                                                                          |                          |                  |               |                  |                  |                |                       |  |  |  |
| bit 7-5                                                                                                                                                                                                  | Unimpleme                | ented: Read as ' | 0'            |                  |                  |                |                       |  |  |  |
| bit 4-1                                                                                                                                                                                                  | WDTPS<3:                 | 0>: Watchdog Ti  | mer Period Se | elect bits       |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          |                          | Prescale Rate    |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0000 = 1:3               | 32               |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0001 = 1:6               | 64               |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0010 = 1:                | 0010 = 1:128     |               |                  |                  |                |                       |  |  |  |
| 0011 <b>= 1:256</b>                                                                                                                                                                                      |                          |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          |                          | 512 (Reset value | )             |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0101 = 1:                | -                |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0110 = 1:2               |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0111 = 1:4<br>1000 = 1:8 |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1000 = 1.0<br>1001 = 1.0 |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1010 = 13                |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1011 = 1:6               | 65536            |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1100 = Re                | eserved          |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1101 = Re                | eserved          |               |                  |                  |                |                       |  |  |  |
| 1110 = Reserved                                                                                                                                                                                          |                          |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1111 = Re                |                  |               |                  |                  |                |                       |  |  |  |
| bit 0 <b>SWDTEN:</b> Software Enable or Disable the Watchdog Timer bit <sup>(1)</sup>                                                                                                                    |                          |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 1 = WDT is               |                  |               |                  |                  |                |                       |  |  |  |
|                                                                                                                                                                                                          | 0 = WDT is               | turned off (Rese | t value)      |                  |                  |                |                       |  |  |  |
| <b>Note 1:</b> If WDTE Configuration bit = 1, then WDT is always enabled, irrespective of this control bit. If WDTE Configuration bit = 0, then it is possible to turn WDT on/off with this control bit. |                          |                  |               |                  |                  |                |                       |  |  |  |

#### REGISTER 12-2: WDTCON: WATCHDOG TIMER CONTROL REGISTER

TABLE 12-8: SUMMARY OF REGISTERS ASSOCIATED WITH WATCHDOG TIMER

| Name       | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR, BOR | Value on<br>all other<br>Resets |
|------------|-------|--------|-------|--------|--------|--------|--------|--------|----------------------|---------------------------------|
| WDTCON     | —     | —      | _     | WDTPS3 | WDTPS2 | WSTPS1 | WDTPS0 | SWDTEN | 0 1000               | 0 1000                          |
| OPTION_REG | RAPU  | INTEDG | TOCS  | T0SE   | PSA    | PS2    | PS1    | PS0    | 1111 1111            | 1111 1111                       |
| CONFIG     | CPD   | CP     | MCLRE | PWRTE  | WDTE   | FOSC2  | FOSC1  | FOSC0  | —                    | —                               |

Legend: Shaded cells are not used by the Watchdog Timer.

Note 1: See Register 12-1 for operation of all Configuration Word register bits.

### 12.12 Power-Down Mode (Sleep)

The Pow er-down mode is ent ered by ex ecuting a SLEEP instruction.

If the Watchdog Timer is enabled:

- WDT will be cleared but keeps running.
- PD bit in the STATUS register is cleared.
- TO bit is set.
- Oscillator driver is turned off.
- I/O ports maintain the status they had before SLEEP was executed (driving high, low or high-impedance).

For lowest current consumption in this mode, all I/O pins should be either at VDD or VSS, with no external circuitry drawing current from the I/O pin and the comparators and C VREF shou Id be disabled. I /O pins that are high-impedance inputs should be pulled high or low externally to avoid switching currents caused by floating inputs. The TOCKI input should also be at VDD or VSS for lowest current cons umption. The contribution from on-chip pull-ups on PORTA should be considered.

The  $\overline{\text{MCLR}}$  pin must be at a logic high level.

- Note 1: It should be noted that a Reset generated by a WDT time-out does not drive MCLR pin low.
  - 2: The An alog Front-End (AFE) section in the PIC16F639 device is independent of the m icrocontroller's p ower-down mode (Sleep). Se e Section 11.32.2.3 "Sleep Command" for AFE's Sleep mode.

#### 12.12.1 WAKE-UP FROM SLEEP

The device can wake-up from Sleep through one of the following events:

- 1. External Reset input on  $\overline{\text{MCLR}}$  pin.
- 2. Watchdog Timer wake-up (if WDT was enabled).
- 3. Interrupt from RA2/INT pin, PORTA change or a peripheral interrupt.

The first event will cause a device R eset. The two latter events are considered a continuation of program execution. The  $\overline{TO}$  and  $\overline{PD}$  bits in the STATUS register can be used to determine the cause of device Reset. The  $\overline{PD}$  bit, which is set on power-up, is cleared when Sleep is invoked.  $\overline{TO}$  bit is cleared if WDT wake-up occurred.

The following peripheral interrupts can wake the device from Sleep:

- 1. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 2. Special event trigger (Timer1 in Asynchronous mode using an external clock).
- 3. EEPROM write operation completion.
- 4. Comparator output changes state.
- 5. Interrupt-on-change.
- 6. External Interrupt from INT pin.

Other pe ripherals c annot g enerate in terrupts, si nce during Sleep, no on-chip clocks are present.

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 set (enabled). Wake-up is regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction, then branches to the interrupt address (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

| Note: | If the g lobal interrupts are disabled (GIE is |
|-------|------------------------------------------------|
|       | cleared), but any interrupt source has both    |
|       | its interrupt enable bit and the corresponding |
|       | interrupt f lag b its set , t he devi ce w ill |
|       | immediately w ake-up f rom Sleep. T he         |
|       | SLEEP instruction is completely executed.      |

The WDT is cleared when the device wakes up from Sleep, regardless of the source of wake-up.

Note: If WUR i s e nabled (WURE = 0 in Configuration W ord), then t he Wake-up Reset module will force a device Reset.

#### 12.12.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 complete as a NOP. Therefore, the WDT and WDT prescaler and postscaler (if enabled) will not be cleared, the TO bit will not be set and the PD bit will not be cleared.
- If the interrupt occurs during or after the execution of a SLEEP instruction, the device will immediately wake-up from Sleep. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT prescaler and postscaler (if enabled) will be cleared, the TO bit will be set and the PD bit will be cleared.

Even if the flag bits were checked before executing a SLEEP instruction, it m ay be possible for fl ag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the PD bit. If the PD bit is set, the SLEEP instruction was executed as a NOP.

To ensure that the WDT is cleared, a CLRWDT instruction should be executed before a SLEEP instruction.

#### Q1 Q2 Q3 Q4 Q1 Q2 Q3 Q4 Q1 Q1 Q2 Q3 Q4, OSC1 MMM \ 7 NΖ TOST(2) CLKOUT<sup>(4)</sup> INT pin INTF Flag (INTCON<1>) Interrupt Latency(3) GIE bit Processor in (INTCON<7>) Sleep INSTRUCTION FLOW PC X PC + 1P PC + PC + 20004h 0005h Instruction Fetched { Inst(PC) = Sleep Inst(0004h) Inst(PC + 1) Inst(PC + 2) Inst(0005h) Instruction { Executed { Inst(PC - 1) Sleep Inst(PC + 1) Dummy Cycle Dummy Cycle Inst(0004h) Note 1: XT, HS or LP Oscillator mode assumed.

#### FIGURE 12-10: WAKE-UP FROM SLEEP THROUGH INTERRUPT

2: TOST = 1024 TOSC (drawing not to scale). This delay does not apply to EC and RC Oscillator modes.

3: GIE = 1 assumed. In this case after wake-up, the processor jumps to 0004h. If GIE = 0, execution will continue in-line.

4: CLKOUT is not available in XT, HS, LP or EC Oscillator modes, but shown here for timing reference.

### 12.13 Code Protection

If the c ode protection b it(s) h ave n ot been programmed, the on -chip p rogram memory c an b e read out using ICSP for verification purposes.

| Note: | The entire data EEPROM and Flash pro-        |
|-------|----------------------------------------------|
|       | gram me mory will be era sed w hen th e      |
|       | code pro tection i s tu rned of f. Se e th e |
|       | "PIC12F6XX/16F6XX Me mory Program-           |
|       | ming Spec ification" (DS41 204) for m ore    |
|       | information.                                 |

## 12.14 ID Locations

Four memory locations (2000h-2003h) are designated as ID locations where the user can store checksum or other code identification numbers. These locations are not a ccessible du ring no rmal e xecution bu t a re readable and w ritable duri ng Progra m/Verify m ode. Only the Least Significant 7 bits of the ID locations are used.

## 12.15 In-Circuit Serial Programming

The PIC 12F635/PIC16F636/639 microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data and three other lines for:

- Power
- Ground
- Programming Voltage

This a llows c ustomers t o m anufacture bo ards w ith unprogrammed d evices and the n pro gram th e microcontroller just before shipping the product. This also al lows the m ost rec ent firm ware or a custom firmware to be programmed.

The device is placed into a Program/Verify mode by holding the RA0 and RA1 pins low, while raising the MCLR (VPP) pin from VIL to VIHH. See the 'PIC12F6XX/16F6XX *Memory P rogramming Specification*" (DS41204) for more information. RA0 becomes the programming data and RA1 be comes the programming clock. Bo th RA0 and RA1 are Schmitt Trigger inputs in this mode.

After Res et, to pl ace the device into Program/Verify mode, the Program Counter (PC) is at location 00h. A 6-bit command is t hen s upplied t o t he device. Depending on the command, 14 bits of program data are then supplied to or from the device, depending on whether t he command w as a load or a r ead. Fo r complete details of serial programming, please refer to the "PIC12F6XX/16F6XX *Me mory P rogramming Specification*" (DS41204).

A typical In-Circuit Serial Programming connection is shown in Figure 12-11.

#### FIGURE 12-11: TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



### 12.16 In-Circuit Debugger

Since in-circuit de bugging requires the loss of clock, data and MCLR pins, MPLAB<sup>®</sup> ICD 2 development with a 14 -pin de vice i s not pr actical. A sp ecial 20 -pin PIC16F636 ICD device is used with MPLAB ICD 2 to provide separate clock, data and MCLR pins and frees all normally available pins to the user.

Use of the IC D device requires the purchase of a special header. On the top of the header is an MPLAB IC D 2 connector. On the bottom of the header is a 14 -pin so cket that plugs into the user's target via the 14-pin stand-off connector.

When the  $\overline{\text{ICD}}$  pin on the PIC16F636 ICD device is held low, the In-Circuit Debugger functionality is enabled. This function allows simple debugging functions when used with MPLAB ICD 2. When the microcontroller has this feat ure enabled, some of the resources a ren ot available for g eneral u se. Table 12-9 s hows which features are consumed by the background debugger:

#### TABLE 12-9:DEBUGGER RESOURCES

| Resource       | Description                         |
|----------------|-------------------------------------|
| I/O pins       | ICDCLK, ICDDATA                     |
| Stack          | 1 level                             |
| Program Memory | Address 0h must be NOP<br>700h-7FFh |

For more information, see the "*MPLAB*<sup>®</sup> *ICD 2 In-Circuit Debugger U ser's Guide*" (DS51331), available o n Microchip's web site (www.microchip.com).

#### FIGURE 12-12: 20-PIN ICD PINOUT



NOTES:

# 13.0 INSTRUCTION SET SUMMARY

The PI C12F635/PIC16F636/639 i nstruction s et i s highly orthogonal and is comprised of three basic categories:

- Byte-oriented operations
- **Bit-oriented** operations
- Literal and control operations

Each PIC16 instruction is a 14-bit word divided into an **opcode**, which specifies the instruction type and one or more **operands**, which further specify the operation of the instruction. The formats for each of the categories is presented in Figure 13-1, while the various opcode fields are summarized in Table 13-1.

Table 13-2 I ists the instructions re cognized by the MPASM<sup>TM</sup> assembler.

For **byte-oriented** instructions, 'f' represents a file register de signator a nd 'd' represents a d estination designator. The file register designator specifies which file register is to be used by the instruction.

The destination designator specifies where the result of the operation is to be placed. If 'd' is zero, the result is placed in the W register. If 'd' is one, the result is placed in the file register specified in the instruction.

For **bit-oriented** instructions, 'b' represents a bit field designator, w hich s elects the bit af fected by the operation, while 'f' represents the address of the file in which the bit is located.

For **literal and control** operations, 'k' represents an 8-bit or 11-bit constant, or literal value.

One instruction cycle consists of four oscillator periods; for a n os cillator f requency of 4 MH z, this gi ves a nominal i nstruction ex ecution time o f 1  $\mu$ s. A II instructions are executed within a single i nstruction cycle, unless a conditional test is true, or the program counter is changed as a result of an instruction. When this occurs, the execution takes two instruction cycles, with the second cycle executed as a NOP.

All i nstruction e xamples us e t he f ormat '0xhh' t o represent a hexadecimal number, where 'h' signifies a hexadecimal digit.

#### 13.1 Read-Modify-Write Operations

Any instruction that specifies a file register as part of the instruction performs a Read-Modify-Write (R-M-W) operation. The register is read, the data is modified, and t he re sult is s tored a ccording to e ither th e instruction, or the de stination des ignator 'd'. A rea d operation is performed on a r egister even if t he instruction writes to that register.

For ex ample, a CLRF PORTA in struction will r ead PORTA, clear all the data bits, then write the result back to PORTA. This example would have the unintended consequence of clearing the condition that set the RAIF flag.

#### TABLE 13-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).<br>The assembler will generate code with x = $0$ .<br>It is the recommended form of use for<br>compatibility with all Microchip software tools. |
| d     | Destination select; $d = 0$ : store result in W,<br>d = 1: store result in file register f.<br>Default is $d = 1$ .                                                               |
| PC    | Program Counter                                                                                                                                                                   |
| TO    | Time-out bit                                                                                                                                                                      |
| С     | Carry bit                                                                                                                                                                         |
| DC    | Digit carry bit                                                                                                                                                                   |
| Z     | Zero bit                                                                                                                                                                          |
| PD    | Power-down bit                                                                                                                                                                    |

# FIGURE 13-1: GENERAL FORMAT FOR INSTRUCTIONS



| Mnemonic, |                                        | Description                  | Cycles       |     | 14-Bit | Opcode | Status |          |         |
|-----------|----------------------------------------|------------------------------|--------------|-----|--------|--------|--------|----------|---------|
| Oper      | ands                                   | Description                  |              | MSb |        |        | LSb    | Affected | Notes   |
|           | BYTE-ORIENTED FILE REGISTER OPERATIONS |                              |              |     |        |        |        |          |         |
| ADDWF     | f, d                                   | Add W and f                  | 1            | 00  | 0111   | dfff   | ffff   | C, DC, Z | 1, 2    |
| ANDWF     | f, d                                   | AND W with f                 | 1            | 00  | 0101   | dfff   | ffff   | Z        | 1, 2    |
| CLRF      | f                                      | Clear f                      | 1            | 00  | 0001   | lfff   | ffff   | Z        | 2       |
| CLRW      | -                                      | Clear W                      | 1            | 00  | 0001   | 0xxx   | xxxx   | Z        |         |
| COMF      | f, d                                   | Complement f                 | 1            | 00  | 1001   | dfff   | ffff   | Z        | 1, 2    |
| DECF      | f, d                                   | Decrement f                  | 1            | 00  | 0011   | dfff   | ffff   | Z        | 1, 2    |
| DECFSZ    | f, d                                   | Decrement f, Skip if 0       | 1 <b>(2)</b> | 00  | 1011   | dfff   | ffff   |          | 1, 2, 3 |
| INCF      | f, d                                   | Increment f                  | 1            | 00  | 1010   | dfff   | ffff   | Z        | 1, 2    |
| INCFSZ    | f, d                                   | Increment f, Skip if 0       | 1 <b>(2)</b> | 00  | 1111   | dfff   | ffff   |          | 1, 2, 3 |
| IORWF     | f, d                                   | Inclusive OR W with f        | 1            | 00  | 0100   | dfff   | ffff   | Z        | 1, 2    |
| MOVF      | f, d                                   | Move f                       | 1            | 00  | 1000   | dfff   | ffff   | Z        | 1, 2    |
| MOVWF     | f                                      | Move W to f                  | 1            | 00  | 0000   | lfff   | ffff   |          |         |
| NOP       | _                                      | No Operation                 | 1            | 00  | 0000   | 0xx0   | 0000   |          |         |
| RLF       | f, d                                   | Rotate Left f through Carry  | 1            | 00  | 1101   | dfff   | ffff   | С        | 1, 2    |
| RRF       | f, d                                   | Rotate Right f through Carry | 1            | 00  | 1100   | dfff   | ffff   | C        | 1, 2    |
| SUBWF     | f, d                                   | Subtract W from f            | 1            | 00  | 0010   |        | ffff   | C, DC, Z | 1, 2    |
| SWAPF     | f, d                                   | Swap nibbles in f            | 1            | 00  | 1110   | dfff   | ffff   | -,, -    | 1, 2    |
| XORWF     | f, d                                   | Exclusive OR W with f        | 1            | 00  | 0110   |        | ffff   | z        | 1, 2    |
|           | ,                                      | BIT-ORIENTED FILE REGIST     |              |     | IS     |        |        |          | ,       |
| BCF       | f, b                                   | Bit Clear f                  | 1            | 01  | 00bb   | bfff   | ffff   |          | 1, 2    |
| BSF       | f, b                                   | Bit Set f                    | 1            | 01  | 01bb   | bfff   |        |          | 1, 2    |
| BTFSC     | f, b                                   | Bit Test f, Skip if Clear    | 1 <b>(2)</b> | 01  | 10bb   | bfff   |        |          | 3       |
| BTFSS     | f, b                                   | Bit Test f, Skip if Set      | 1 (2)        | 01  | 11bb   | bfff   | ffff   |          | 3       |
| 51100     | 1, 0                                   |                              |              |     | 1100   | DIII   |        |          | Ŭ       |
| ADDLW     | k                                      | Add literal and W            | 1            | 11  | 111x   | kkkk   | kkkk   | C, DC, Z |         |
| ANDLW     | k                                      | AND literal with W           | 1            | 11  | 1001   |        | kkkk   | Z        |         |
| CALL      | k                                      | Call Subroutine              | 2            | 10  |        | kkkk   |        | _        |         |
| CLRWDT    | _                                      | Clear Watchdog Timer         | 1            | 00  | 0000   | 0110   | 0100   | TO, PD   |         |
| GOTO      | k                                      | Go to address                | 2            | 10  | 1kkk   | kkkk   |        | 10,10    |         |
| IORLW     | k                                      | Inclusive OR literal with W  | 1            | 11  | 1000   | kkkk   |        | Z        |         |
| MOVLW     | k                                      | Move literal to W            | 1            | 11  | 00xx   |        |        | _        |         |
| RETFIE    | _                                      | Return from interrupt        | 2            | 00  | 0000   | 0000   | 1001   |          |         |
| RETLW     | k                                      | Return with literal in W     | 2            | 11  | 01xx   | kkkk   |        |          |         |
| RETURN    | _                                      | Return from Subroutine       | 2            | 00  | 0000   | 0000   | 1000   |          |         |
| SLEEP     | _                                      | Go into Standby mode         | 1            | 00  | 0000   | 0110   | 0011   | TO, PD   |         |
| SUBLW     | k                                      | Subtract W from literal      | 1            | 11  | 110x   |        | kkkk   | C, DC, Z |         |
| XORLW     | k                                      | Exclusive OR literal with W  | 1            | 11  | 1010   |        | kkkk   | C, DC, Z |         |
| NONEW     | Л                                      |                              | 1            | 11  | TOTO   | VVVV   | KKKK   |          |         |

#### TABLE 13-2: PIC12F635/PIC16F636/639 INSTRUCTION SET

**Note 1:** When an I/O register is modified as a function of itself (e.g., MOVF GPIO, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

2: If this instruction is executed on the TMR0 register (and where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 module.

**3:** 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.

| ADDLW            | Add literal and W                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                                   |
| Operands:        | $0 \le k \le 255$                                                                                                          |
| Operation:       | $(W) + k \to (W)$                                                                                                          |
| Status Affected: | C, DC, Z                                                                                                                   |
| Description:     | The contents of the W register<br>are added to the eight-bit literal 'k'<br>and the result is placed in the<br>W register. |

Instruction Descriptions

13.2

| BCF              | Bit Clear f                                                         |
|------------------|---------------------------------------------------------------------|
| Syntax:          | [label]BCF f,b                                                      |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |
| Operation:       | $0 \rightarrow (f < b >)$                                           |
| Status Affected: | None                                                                |
| Description:     | Bit 'b' in register 'f' is cleared.                                 |

| ADDWF            | Add W and f                                                                                                                                                                        |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] ADDWF f,d                                                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                    |
| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                                              |
| Status Affected: | C, DC, Z                                                                                                                                                                           |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is '0', the<br>result is stored in the W register. If<br>'d' is '1', the result is stored back<br>in register 'f'. |

| BSF              | Bit Set f                                                           |
|------------------|---------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] BSF f,b                                            |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |
| Operation:       | $1 \rightarrow (f < b >)$                                           |
| Status Affected: | None                                                                |
| Description:     | Bit 'b' in register 'f' is set.                                     |

| ANDLW            | AND literal with W                                                                                                     |
|------------------|------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                               |
| Operands:        | $0 \le k \le 255$                                                                                                      |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                        |
| Status Affected: | Z                                                                                                                      |
| Description:     | The contents of W register are<br>AND'ed with the eight-bit literal<br>'k'. The result is placed in the W<br>register. |

| BTFSC            | Bit Test f, Skip if Clear                                                                                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] BTFSC f,b                                                                                                                                                                                                      |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                                                             |
| Operation:       | <b>skip if (f<b>) =</b> 0</b>                                                                                                                                                                                                   |
| Status Affected: | None                                                                                                                                                                                                                            |
| Description:     | If bit 'b' in register 'f' is '1', the next<br>instruction is executed.<br>If bit 'b', in register 'f', is '0', the<br>next instruction is discarded, and<br>a NOP is executed instead, making<br>this a two-cycle instruction. |

| 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$ (destination)                                                                                                                       |
| Status Affected: | Z                                                                                                                                                               |
| Description:     | AND the W register with register<br>'f'. If 'd' is '0', the result is stored in<br>the W register. If 'd' is '1', the<br>result is stored back in register 'f'. |

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                                                               |
| Operands:        | $0 \le f \le 127$<br>$0 \le b < 7$                                                                                                                                                                                |
| Operation:       | skip if (f <b>) = 1</b>                                                                                                                                                                                           |
| Status Affected: | None                                                                                                                                                                                                              |
| Description:     | If bit 'b' in register 'f' is '0', the next<br>instruction is executed.<br>If bit 'b' is '1', then the next<br>instruction is discarded and a NOP<br>is executed instead, making this a<br>two-cycle instruction. |

| CLRWDT           | Clear Watchdog Timer                                                                                                                                     |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] CLRWDT                                                                                                                                           |
| Operands:        | None                                                                                                                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow \overline{PD} \end{array}$ |
| Status Affected: | TO, PD                                                                                                                                                   |
| Description:     | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT.<br>Status bits TO and PD are set.                           |

| CALL             | Call Subroutine                                                                                                                                                                                                                               |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                       |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                                                                            |
| Operation:       | $\begin{array}{l} (PC)+1 \rightarrow TOS, \\ k \rightarrow PC < 10:0>, \\ (PCLATH < 4:3>) \rightarrow PC < 12:11> \end{array}$                                                                                                                |
| Status Affected: | None                                                                                                                                                                                                                                          |
| Description:     | Call Subroutine. First, return<br>address (PC + 1) is pushed onto<br>the stack. The eleven-bit<br>immediate address is loaded into<br>PC bits <10:0>. The upper bits of<br>the PC are loaded from PCLATH.<br>CALL is a two-cycle instruction. |

| COMF             | Complement f                                                                                                                                                   |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] COMF f,d                                                                                                                                      |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                                              |
| Operation:       | $(\overline{f}) \rightarrow$ (destination)                                                                                                                     |
| Status Affected: | Z                                                                                                                                                              |
| Description:     | The contents of register 'f' are<br>complemented. If 'd' is '0', the<br>result is stored in W. If 'd' is '1',<br>the result is stored back in<br>register 'f'. |

| CLRF             | Clear f                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label] CLRF f                                                        |
| Operands:        | $0 \le f \le 127$                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.        |

W register is cleared. Zero bit (Z)

is set.

| L                                                              | Olalas / Incoloa. |
|----------------------------------------------------------------|-------------------|
| The contents of register 'f' are cleared and the Z bit is set. | Description:      |
| Clear W                                                        |                   |
|                                                                |                   |
| [label] CLRW                                                   |                   |
| [ <i>label</i> ] CLRW<br>None                                  |                   |
|                                                                |                   |
| None                                                           |                   |

| DECF             | Decrement f                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] DECF f,d                                                                                                                                |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                   |
| Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                               |
| Status Affected: | Z                                                                                                                                                 |
| Description:     | Decrement register 'f'. If 'd' is '0',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

Status Affected:

Description:

CLRW Syntax: Operands: Operation:

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                                                         |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ensuremath{\left[0,1\right]} \end{array}$                                                                                                                                                                                                                                                    |
| Operation:       | (f) - 1 $\rightarrow$ (destination);<br>skip if result = 0                                                                                                                                                                                                                                                                                 |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                       |
| Description:     | The contents of register 'f' are<br>decremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'.<br>If the result is '1', the next<br>instruction is executed. If the<br>result is '0', then a NOP is<br>executed instead, making it a<br>two-cycle instruction. |

| INCFSZ           | Increment f, Skip if 0                                                                                                                                                                                                                                                                                                                |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] INCFSZ f,d                                                                                                                                                                                                                                                                                                           |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                                                                                                                                                       |
| Operation:       | (f) + 1 $\rightarrow$ (destination),<br>skip if result = 0                                                                                                                                                                                                                                                                            |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                  |
| Description:     | The contents of register 'f' are<br>incremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'.<br>If the result is '1', the next<br>instruction is executed. If the<br>result is '0', a NOP is executed<br>instead, making it a two-cycle<br>instruction. |

| GOTO             | Unconditional Branch                                                                                                                                                                             |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] GOTO k                                                                                                                                                                          |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                               |
| Operation:       | $k \rightarrow PC<10:0>$<br>PCLATH<4:3> $\rightarrow$ PC<12:11>                                                                                                                                  |
| Status Affected: | None                                                                                                                                                                                             |
| Description:     | GOTO is an unconditional branch.<br>The eleven-bit immediate value is<br>loaded into PC bits <10:0>. The<br>upper bits of PC are loaded from<br>PCLATH<4:3>. GOTO is a<br>two-cycle instruction. |

| IORLW            | Inclusive OR literal with W                                                                                               |
|------------------|---------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] IORLW k                                                                                                  |
| Operands:        | $0 \le k \le 255$                                                                                                         |
| Operation:       | (W) .OR. $k \rightarrow$ (W)                                                                                              |
| Status Affected: | Z                                                                                                                         |
| Description:     | The contents of the W register are<br>OR'ed with the eight-bit literal 'k'.<br>The result is placed in the<br>W register. |

| INCF             | Increment f                                                                                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] INCF f,d                                                                                                                                                           |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ensuremath{\left[ 0,1 \right]} \end{array}$                                                                                  |
| Operation:       | (f) + 1 $\rightarrow$ (destination)                                                                                                                                        |
| Status Affected: | Z                                                                                                                                                                          |
| Description:     | The contents of register 'f' are<br>incremented. If 'd' is '0', the result<br>is placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'. |

| IORWF            | Inclusive OR W with f                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] IORWF f,d                                                                                                                                                           |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                             |
| Operation:       | (W) .OR. (f) $\rightarrow$ (destination)                                                                                                                                    |
| Status Affected: | Z                                                                                                                                                                           |
| Description:     | Inclusive OR the W register with<br>register 'f'. If 'd' is '0', the result is<br>placed in the W register. If 'd' is<br>'1', the result is placed back in<br>register 'f'. |

| MOVF             | Move f                                                                                                                                                                                                                                                                               |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] MOVF f,d                                                                                                                                                                                                                                                            |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                                                                                                                                                                    |
| Operation:       | (f) $\rightarrow$ (dest)                                                                                                                                                                                                                                                             |
| Status Affected: | Z                                                                                                                                                                                                                                                                                    |
| Description:     | The contents of register f is<br>moved to a destination dependent<br>upon the status of d. If $d = 0$ ,<br>destination is W register. If $d = 1$ ,<br>the destination is file register f<br>itself. $d = 1$ is useful to test a file<br>register since status flag Z is<br>affected. |
| Words:           | 1                                                                                                                                                                                                                                                                                    |
| Cycles:          | 1                                                                                                                                                                                                                                                                                    |
| Example:         | MOVF FSR, 0                                                                                                                                                                                                                                                                          |
|                  | After Instruction<br>W = alue in SFR<br>register<br>Z = 1                                                                                                                                                                                                                            |

| MOVWF            | Move W to f                                     |
|------------------|-------------------------------------------------|
| Syntax:          | [ label ] MOVWF f                               |
| Operands:        | $0 \le f \le 127$                               |
| Operation:       | $(W) \rightarrow (f)$                           |
| Status Affected: | None                                            |
| Description:     | Move data from W register to register 'f'.      |
| Words:           | 1                                               |
| Cycles:          | 1                                               |
| Example:         | MOVW OPTION<br>F                                |
|                  | Before Instruction<br>OPTION = 0xFF<br>W = 0x4F |
|                  | After Instruction<br>OPTION = 0x4F<br>W = 0x4F  |
|                  |                                                 |

| MOVLW            | Move literal to W                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                            |
| Operands:        | $0 \le k \le 255$                                                                                   |
| Operation:       | $k \rightarrow (W)$                                                                                 |
| Status Affected: | None                                                                                                |
| Description:     | The eight-bit literal 'k' is loaded into<br>W register. The "don't cares" will<br>assemble as '0's. |
| Words:           | 1                                                                                                   |
| Cycles:          | 1                                                                                                   |
| Example:         | MOVLW 0x5A                                                                                          |
|                  | After Instruction<br>W = 0x5A                                                                       |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |
| Words:           | 1             |
| Cycles:          | 1             |
| Example:         | NOP           |

| RETFIE           | Return from Interrupt                                                                                                                                            | RETLW            | Return with literal in W                                                                                                                                                            |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] RETFIE                                                                                                                                                 | Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                            |
| Operands:        | None                                                                                                                                                             | Operands:        | $0 \le k \le 255$                                                                                                                                                                   |
| Operation:       | $\begin{array}{l} TOS \to PC, \\ \mathtt{1} \to GIE \end{array}$                                                                                                 | Operation:       | $k \rightarrow (W);$<br>TOS $\rightarrow PC$                                                                                                                                        |
| Status Affected: | None                                                                                                                                                             | Status Affected: | None                                                                                                                                                                                |
| Description:     | Return from Interrupt. Stack is<br>POPed and Top-of-Stack (TOS) is<br>loaded in the PC. Interrupts are<br>enabled by setting Global<br>Interrupt Enable bit, GIE | Description:     | The W register is loaded with the<br>eight-bit literal 'k'. The program<br>counter is loaded from the top of<br>the stack (the return address).<br>This is a two-cycle instruction. |
|                  | (INTCON<7>). This is a two-cycle<br>instruction.                                                                                                                 | Words:           | 1                                                                                                                                                                                   |
| Words:           | 1                                                                                                                                                                | Cycles:          | 2                                                                                                                                                                                   |
| Cycles:          | 2                                                                                                                                                                | Example:         | CALL TABLE;W contains table                                                                                                                                                         |
| <u>Example:</u>  | RETFIE<br>After Interrupt<br>PC = TOS<br>GIE = 1                                                                                                                 | TABLE            | ;offset value<br>;W now has table value<br>ADDWF PC ;W = offset<br>RETLW k1 ;Begin table<br>RETLW k2 ;                                                                              |

| RETURN           | Return from Subroutine                                                                                                                                     |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [ label ] RETURN                                                                                                                                           |  |
| Operands:        | None                                                                                                                                                       |  |
| Operation:       | $TOS\toPC$                                                                                                                                                 |  |
| Status Affected: | None                                                                                                                                                       |  |
| Description:     | Return from subroutine. The stack<br>is POPed and the top of the stack<br>(TOS) is loaded into the program<br>counter. This is a two-cycle<br>instruction. |  |

•

RETLW kn ; End of table

W = 0x07

W = value of k8

Before Instruction

After Instruction

| RLF              | Rotate Left f through Carry                                                                                                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                             |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                                                                                                    |
| Operation:       | See description below                                                                                                                                                                                                |
| Status Affected: | С                                                                                                                                                                                                                    |
| Description:     | The contents of register 'f' are<br>rotated one bit to the left through<br>the Carry flag. If 'd' is '0', the<br>result is placed in the W register.<br>If 'd' is '1', the result is stored<br>back in register 'f'. |
| Words:           | 1                                                                                                                                                                                                                    |
| Cycles:          | 1                                                                                                                                                                                                                    |
| Example:         | RLF REG1,0                                                                                                                                                                                                           |
|                  | Before Instruction                                                                                                                                                                                                   |
|                  | REG1 = 1110 0110<br>C = 0                                                                                                                                                                                            |
|                  | After Instruction                                                                                                                                                                                                    |
|                  | REG1 = 1110 0110                                                                                                                                                                                                     |
|                  | W = 1100 1100                                                                                                                                                                                                        |

| SLEEP            | Enter Sleep mode                                                                                                                                                                                                                                 |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SLEEP                                                                                                                                                                                                                                    |
| Operands:        | None                                                                                                                                                                                                                                             |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow \underline{W}DT \text{ prescaler}, \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$                                                                           |
| Status Affected: | TO, PD                                                                                                                                                                                                                                           |
| Description:     | The power-down Status bit, $\overline{\text{PD}}$ is<br>cleared. Time-out Status bit, $\overline{\text{TO}}$<br>is set. Watchdog Timer and its<br>prescaler are cleared.<br>The processor is put into Sleep<br>mode with the oscillator stopped. |

| RRF              | Rotate Right f through Carry                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] RRF f,d                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ensuremath{\left[0,1\right]} \end{array}$                                                                                                                               |  |  |  |  |  |  |  |  |
| Operation:       | See description below                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| Status Affected: | С                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description:     | The contents of register 'f' are<br>rotated one bit to the right through<br>the Carry flag. If 'd' is '0', the<br>result is placed in the W register.<br>If 'd' is '1', the result is placed<br>back in register 'f'. |  |  |  |  |  |  |  |  |
|                  | C Register f                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |

| SUBLW            | Subtract W from literal                                                                                                      |                 |  |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--|--|--|
| Syntax:          | [label] SL                                                                                                                   | JBLW k          |  |  |  |  |  |  |
| Operands:        | $0 \leq k \leq 255$                                                                                                          |                 |  |  |  |  |  |  |
| Operation:       | $k \text{ - (W)} \to (W)$                                                                                                    |                 |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                     |                 |  |  |  |  |  |  |
| Description:     | The W register is subtracted (2's complement method) from the eight-bit literal 'k'. The result is placed in the W register. |                 |  |  |  |  |  |  |
|                  | C = 0 W > k                                                                                                                  |                 |  |  |  |  |  |  |
|                  | <b>C</b> = 1                                                                                                                 | $W \leq k$      |  |  |  |  |  |  |
|                  | DC = 0                                                                                                                       | W<3:0> > k<3:0> |  |  |  |  |  |  |

DC = 1

W<3:0> ≤ k<3:0>

| SUBWF            | Subtract W from f                                                                                                                                                                          |  |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] SUBWF f,d                                                                                                                                                                 |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                            |  |  |  |  |  |  |
| Operation:       | (f) - (W) $\rightarrow$ (destination)                                                                                                                                                      |  |  |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                                                   |  |  |  |  |  |  |
| Description:     | Subtract (2's complement method)<br>W register from register 'f'. If 'd' is<br>'0', the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f. |  |  |  |  |  |  |
|                  | C = 0 $W > f$                                                                                                                                                                              |  |  |  |  |  |  |

| <b>C</b> = 0 | W > f                     |
|--------------|---------------------------|
| <b>C</b> = 1 | $W \leq f$                |
| DC = 0       | W<3:0>>f<3:0>             |
| DC = 1       | $W < 3:0 > \le f < 3:0 >$ |

| XORLW            | Exclusive OR literal with W                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] XORLW k                                                                                                   |
| Operands:        | $0 \le k \le 255$                                                                                                          |
| Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                              |
| Status Affected: | Z                                                                                                                          |
| Description:     | The contents of the W register<br>are XOR'ed with the eight-bit<br>literal 'k'. The result is placed in<br>the W register. |

| SWAPF            | Swap Nibbles in f                                                                                                                                                                  | XORWF            | Exclusive OR W with f                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SW APF f,d                                                                                                                                                                 | Syntax:          | [label] XORWF f,d                                                                                                                                       |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                    | Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                      |
| Operation:       | $(f<3:0>) \rightarrow (destination<7:4>),$                                                                                                                                         | Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                               |
|                  | $(f < 7:4 >) \rightarrow (destination < 3:0 >)$                                                                                                                                    | Status Affected: | Z                                                                                                                                                       |
| Status Affected: | None                                                                                                                                                                               | Description:     | Exclusive OR the contents of the                                                                                                                        |
| Description:     | The upper and lower nibbles of<br>register 'f' are exchanged. If 'd' is<br>'0', the result is placed in the W<br>register. If 'd' is '1', the result is<br>placed in register 'f'. | ·                | W register with register 'f'. If 'd' is<br>'0', the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

NOTES:

# 14.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> mi crocontrollers a re s upported w ith a ful I range of hardware and software development tools:

- Integrated Development Environment
  - MPLAB® IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C18 and MPLAB C30 C Compilers
  - MPLINK<sup>™</sup> Object Linker/
  - MPLIB<sup>™</sup> Object Librarian
  - MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB REAL ICE™ In-Circuit Emulator
- In-Circuit Debugger
  - MPLAB ICD 2
- Device Programmers
  - PICSTART<sup>®</sup> Plus Development Programmer
  - MPLAB PM3 Device Programmer
  - PICkit<sup>™</sup> 2 Development Programmer
- Low-Cost Demonstration and Development Boards and Evaluation Kits

### 14.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller m arket. Th e MPL AB IDE is a Wi ndows<sup>®</sup> operating system-based application that contains:

- A single graphical interface to all debugging tools
  - Simulator
  - Programmer (sold separately)
  - Emulator (sold separately)
  - In-Circuit Debugger (sold separately)
- · A full-featured editor with color-coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- High-level source code debugging
- Visual device initializer for easy register initialization
- Mouse over variable inspection
- Drag and drop variables from source to watch windows
- · Extensive on-line help
- Integration of select third party tools, such as HI-TECH Software C Compilers and IAR C Compilers

The MPLAB IDE allows you to:

- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PIC MCU emulator and simulator tools (automatically updates all project information)
- Debug using:
  - Source files (assembly or C)
  - Mixed assembly and C
  - Machine code

MPLAB IDE s upports multiple d ebugging to ols i n a single development p aradigm, from the cost-effective simulators, t hrough low-cost i n-circuit de buggers, to full-featured emu lators. This el iminates the learning curve when upgrading to tools with increased flexibility and power.

# 14.2 MPASM Assembler

The MPASM Assembler is a full -featured, un iversal macro assembler for all PIC MCUs.

The M PASM As sembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, M AP files to det ail memory us age and symbol reference, absolute LST files that contain source lines and g enerated m achine c ode and C OFF fil es for debugging.

The MPASM Assembler features include:

- Integration into MPLAB IDE projects
- User-defined macros to streamline assembly code
- Conditional assembly for multi-purpose source files
- Directives that allow complete control over the assembly process

### 14.3 MPLAB C18 and MPLAB C30 C Compilers

The MPLAB C18 and MPLAB C30 Code Development Systems are c omplete AN SI C compilers for Microchip's PIC18 and PIC24 families of microcontrollers and the dsPIC30 and dsPIC33 family of digital signal c ontrollers. These co mpilers pr ovide powerful integration capabilities, superior code optimization and ease of use not found with other compilers.

For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger.

#### 14.4 MPLINK Object Linker/ MPLIB Object Librarian

The M PLINK O bject L inker c ombines relocatable objects created by the MP ASM Ass embler and the MPLAB C18 C Compiler. It can link relocatable objects from pre compiled lib raries, using di rectives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the ap plication. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

# 14.5 MPLAB ASM30 Assembler, Linker and Librarian

MPLAB ASM 30 Ass embler pro duces relocatable machine c ode f rom s ymbolic a ssembly I anguage f or dsPIC30F devices. MPLAB C30 C Compiler uses the assembler to pro duce its object f ile. The assembler generates rel ocatable object fi les that c an th en b e archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- Support for the entire dsPIC30F instruction set
- Support for fixed-point and floating-point data
- Command line interface
- · Rich directive set
- Flexible macro language
- MPLAB IDE compatibility

### 14.6 MPLAB SIM Software Simulator

The M PLAB SIM So ftware Simulator al lows code development in a P C-hosted environment by simulating the PIC MCUs and dsPIC<sup>®</sup> DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The M PLAB SIM Softwa re Sim ulator full y s upports symbolic de bugging u sing th e M PLAB C 18 an d MPLAB C 30 C Compilers, and the M PASM an d MPLAB ASM 30 As semblers. The software s imulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

#### 14.7 MPLAB ICE 2000 High-Performance In-Circuit Emulator

The MPLAB ICE 2000 In-Circuit Emulator is intended to provide the product development engineer with a complete mi crocontroller design too I set for PIC microcontrollers. Software control of the MPLAB ICE 2000 In-Circuit Emulator is advanced by the MPLAB Integrated D evelopment Environment, which a llows editing, building, downloading and source de bugging from a single environment.

The M PLAB IC E 2 000 is a full-featured emu lator system with enhanced trace, trigger and data monitoring features. Interchangeable processor modules allow the system to be easily reconfigured for emulation of different processors. The architecture of the MP LAB ICE 200 0 In-Circuit Emulator all ows ex pansion to support new PIC microcontrollers.

The MPLAB ICE 2000 In-Circuit Emulator system has been designed as a real-time emulation system with advanced features t hat are ty pically found on more expensive d evelopment tools. The PC p latform an d Microsoft<sup>®</sup> Windows<sup>®</sup> 3 2-bit op erating system w ere chosen to bes t m ake thes e features a vailable in a simple, unified application.

### 14.8 MPLAB REAL ICE In-Circuit Emulator System

MPLAB REAL IC E In-C ircuit Emulator Sy stem is Microchip's next generation high-spee d emulator for Microchip Flash DSC<sup>®</sup> and MCU devices. It debugs and programs PIC<sup>®</sup> and dsPIC<sup>®</sup> Flash microcontrollers with the easy-to-use, powerful graphical user interfaceof the MPLAB Integrated D evelopment Env ironment (ID E), included with each kit.

The MPLAB REAL ICE probe is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connec ted to the t arget with either a c onnector compatible with the popular MPLAB IC D 2 sys tem (RJ11) or with the new high speed, noise tolerant, lowvoltage d ifferential signal (L VDS) interconnection (CAT5).

MPLAB REAL ICE is field upgradeable through future firmware dow nloads in MPLAB IDE. In upcom ing releases of MPLAB IDE, new devices will be supported, and new features will be added, such as software breakpoints and a ssembly c ode trace. M PLAB R EAL IC E offers significant advantages over competitive emulators including low-cost, full -speed e mulation, real-time variable watches, trace analysis, complex breakpoints, a ruggedized probe interface and long (up to threemeters) interconnection cables.

# 14.9 MPLAB ICD 2 In-Circuit Debugger

Microchip's In-C ircuit D ebugger, M PLAB IC D 2, is a powerful, low -cost, run-time dev elopment tool, connecting to the host PC via an RS-232 or high-speed USB interface. This tool is base d on the Flash P IC MCUs and can be used to develop for these and other PIC MCUs and dsPIC DSCs. The MPLAB ICD 2 utilizes the in-circuit debugging capability built into the Flash devices. This feature, along with Microchip's In-Circuit Serial Programming<sup>™</sup> (IC SP<sup>™</sup>) protoc ol, of fers costeffective, in-circuit Flash debugging from the graphical user interface of the MPLAB Integrated Development Environment. This enables a designer to develop and debug source code by setting breakpoints, single stepping and w atching va riables, an d C PU status an d peripheral registers. Running at fulls peed e nables testing hardware and applications in real time. MPLAB ICD 2 also serves as a development programmer for selected PIC devices.

## 14.10 MPLAB PM3 Device Programmer

The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage ve rification at V DDMIN an d V DDMAX fo r maximum reliability. It features a large LC D display (128 x 64) for menus and error messages and a modular, de tachable s ocket assembly to su pport various package types. The ICSP™ cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in thi s mo de. The MPL AB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized al gorithms for quick programming of large memory devices and incorporates an SD/MMC card for file storage and secure data applications.

### 14.11 PICSTART Plus Development Programmer

The PICSTART Plus Development Programmer is an easy-to-use, low -cost, prot otype pro grammer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the prog rammer si mple an d ef ficient. The PICSTART P lus D evelopment P rogrammer su pports most P IC d evices i n D IP pac kages up t o 4 0 pi ns. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus Development Programmer is CE compliant.

### 14.12 PICkit 2 Development Programmer

The PICkit<sup>™</sup> 2 Development Programmer is a low-cost programmer and selected Flash device debugger with an ea sy-to-use int erface f or pro gramming ma ny of Microchip's baseline, mid-range and PIC18F families of Flash memory microcontrollers. The PICkit 2 Starter Kit includes a pro totyping d evelopment boa rd, t welve sequential les sons, so ftware and HI-TECH's PIC C<sup>TM</sup> Lite C compiler, and is designed to help get up to speed quickly u sing PIC<sup>®</sup> microcontrollers. The kit provides everything ne eded to program, evaluate and develop applications us ing M icrochip's po werful, m id-range Flash memory family of microcontrollers.

### 14.13 Demonstration, Development and Evaluation Boards

A w ide v ariety of d emonstration, de velopment and evaluation bo ards f or va rious P IC MC Us a nd dsP IC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature se nsors, sw itches, s peakers, R S-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM<sup>™</sup> and dsPICDEM<sup>™</sup> demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for ana log f ilter de sign, K EELOQ<sup>®</sup> security I Cs, CAN, IrDA<sup>®</sup>, P owerSmart<sup>®</sup> bat tery ma nagement, S EEVAL<sup>®</sup> evaluation system, Sigma-Delta A DC, fl ow ra te sensing, plus many more.

Check the Microchip web page (www.microchip.com) and the latest *"Product Selector Guide"* (DS00148) for the complete list of demonstration, development and evaluation kits.

# 15.0 ELECTRICAL SPECIFICATIONS

# Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                   | 40°C to +125°C       |
|----------------------------------------------------------------------------------|----------------------|
| Storage temperature                                                              |                      |
| Voltage on VDD with respect to Vss                                               |                      |
| Voltage on MCLR with respect to Vss                                              | 0.3V to +13.5V       |
| Voltage on all other pins with respect to Vss                                    | 0.3V to (VDD + 0.3V) |
| Total power dissipation <sup>(1)</sup>                                           | 800 mW               |
| Maximum current out of Vss/Vsst pin                                              | 95 mA                |
| Maximum current into VDD/VDDT pin                                                | 95 mA                |
| Input clamp current, Iк (Vi < 0 or Vi > VDD)                                     | ± 20 mA              |
| Output clamp current, IOK (Vo < 0 or Vo >Voo)                                    | ± 20 mA              |
| Maximum output current sunk by any I/O pin                                       | 25 mA                |
| Maximum output current sourced by any I/O pin                                    | 25 mA                |
| Maximum current sunk by PORTA and PORTC (combined)                               | 95 mA                |
| Maximum current sourced PORTA and PORTC (combined)                               | 95 mA                |
| Maximum LC Input Voltage (LCX, LCY, LCZ) <sup>(2)</sup> loaded, with device      | 10.0 Vpp             |
| Maximum LC Input Voltage (LCX, LCY, LCZ) <sup>(2)</sup> unloaded, without device | 700.0 Vpp            |
| Maximum Input Current (rms) into device per LC Channel <sup>(2)</sup>            | 10 mA                |
| Human Body ESD rating                                                            | 4000 (min.) V        |
| Machine Model ESD rating                                                         | 400 (min.) V         |

- Note 1: Power dissipation for PIC12F635/PIC16F636/639 (AFE section not included) is calculated as follows:  $PDIS = VDD \times \{IDD - \sum IOH\} + \sum \{(VDD-VOH) \times IOH\} + \sum (VOL \times IOL).$ Power dissipation for AFE section is calculated as follows:  $PDIS = VDD \times IACT = 3.6V \times 16 \ \mu A = 57.6 \ \mu W$ 
  - 2: Specification applies to the PIC16F639 only.

**†** NOTICE: Stresses above those listed under "Absolute Maximum Ratings" 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 to maximum rating conditions for extended periods may affect device reliability.

| Note: | Voltage spikes below Vss at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up.                |
|-------|--------------------------------------------------------------------------------------------------------------------|
|       | Thus, a series resistor of 50-100 $\Omega$ should be used when applying a 'low' level to the MCLR pin, rather than |
|       | pulling this pin directly to Vss.                                                                                  |











#### 15.1 DC Characteristics: PIC12F635/PIC16F636-I (Industrial) PIC12F635/PIC16F636-E (Extended)

| DC CHA                          | ARACTE | RISTICS                                                          | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |     |                                 |                  |                                                                                      |  |  |
|---------------------------------|--------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------------|------------------|--------------------------------------------------------------------------------------|--|--|
| Param<br>No.                    | Sym    | Characteristic                                                   | Min Typ† Max Units Conditions                                                                                                                                                           |     |                                 |                  |                                                                                      |  |  |
| D001<br>D001A<br>D001B<br>D001C | Vdd    | Supply Voltage                                                   | 2.0<br>2.0<br>3.0<br>4.5                                                                                                                                                                |     | 5.5<br>5.5<br>5.5<br>5.5<br>5.5 | V<br>V<br>V<br>V | Fosc < = 4 MHz<br>Fosc < = 8 MHz, HFINTOSC, EC<br>Fosc < = 10 MHz<br>Fosc < = 20 MHz |  |  |
| D002                            | Vdr    | RAM Data Retention<br>Voltage <sup>(1)</sup>                     | 1.5*                                                                                                                                                                                    | _   | _                               | V                | Device in Sleep mode                                                                 |  |  |
| D003                            | VPOR   | VDD Start Voltage to<br>ensure internal Power-on<br>Reset signal | V                                                                                                                                                                                       | SS  | —V                              |                  | See Section 12.3 "Power-on Reset" for details.                                       |  |  |
| D004                            | SVDD   | VDD Rise Rate to ensure<br>internal Power-on Reset<br>signal     | 0.05*                                                                                                                                                                                   | —   | _                               | V/ms             | See Section 12.3 "Power-on Reset" for details.                                       |  |  |
| D005                            | VBOD   | Brown-out Reset                                                  | 2.0                                                                                                                                                                                     | 2.1 | 2.2                             | V                |                                                                                      |  |  |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.

| DC CHARACTERISTICS |     |                                 | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |        |      |              |            |                    |
|--------------------|-----|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------|------|--------------|------------|--------------------|
| Param              |     |                                 | Min                                                                                                                                | Turnet |      | Lin ite      | Conditions |                    |
| No.                | Sym | Device Characteristics          | Min                                                                                                                                | Тур†   | Max  | Units        | Vdd        | Note               |
| D010               | Idd | Supply Current <sup>(1,2)</sup> | —1                                                                                                                                 | 1      | 16   | μA2          | .0         | Fosc = 32.768 kHz  |
|                    |     |                                 | —1                                                                                                                                 | 8      | 28   | μ <b>A</b> 3 | .0         | LP Oscillator mode |
|                    |     |                                 | —3                                                                                                                                 | 5      | 54   | μA5          | .0         |                    |
| D011               |     |                                 | _                                                                                                                                  | 140    | 240  | μA2          | .0         | Fosc = 1 MHz       |
|                    |     |                                 | —2                                                                                                                                 | 20     | 380  | μ <b>A</b> 3 | .0         | XT Oscillator mode |
|                    |     |                                 | —3                                                                                                                                 | 80     | 550  | μA5          | .0         |                    |
| D012               |     |                                 | —                                                                                                                                  | 260    | 360  | μA2          | .0         | Fosc = 4 MHz       |
|                    |     |                                 | —4                                                                                                                                 | 20     | 650  | μ <b>A</b> 3 | .0         | XT Oscillator mode |
|                    |     |                                 | _                                                                                                                                  | 0.8    | 1.1  | mA           | 5.0        |                    |
| D013               |     |                                 | _                                                                                                                                  | 130    | 220  | μA2          | .0         | Fosc = 1 MHz       |
|                    |     |                                 | —2                                                                                                                                 | 15     | 360  | μ <b>A</b> 3 | .0         | EC Oscillator mode |
|                    |     |                                 | —3                                                                                                                                 | 60     | 520  | μA5          | .0         |                    |
| D014               |     |                                 | —                                                                                                                                  | 220    | 340  | μA2          | .0         | Fosc = 4 MHz       |
|                    |     |                                 | —3                                                                                                                                 | 75     | 550  | μ <b>A</b> 3 | .0         | EC Oscillator mode |
|                    |     |                                 | —                                                                                                                                  | 0.65   | 1.0  | mA           | 5.0        |                    |
| D015               |     |                                 | —                                                                                                                                  | 8      | 20   | μA2          | .0         | Fosc = 31 kHz      |
|                    |     |                                 | —1                                                                                                                                 | 6      | 40   | μ <b>A</b> 3 | .0         | LFINTOSC mode      |
|                    |     |                                 | —3                                                                                                                                 | 1      | 65   | μA5          | .0         |                    |
| D016               |     |                                 | —                                                                                                                                  | 340    | 450  | μA2          | .0         | Fosc = 4 MHz       |
|                    |     |                                 | —5                                                                                                                                 | 00     | 700  | μ <b>A</b> 3 | .0         | HFINTOSC mode      |
|                    |     |                                 | —                                                                                                                                  | 0.8    | 1.2  | mA           | 5.0        | 1                  |
| D017               |     |                                 |                                                                                                                                    | 410    | 650  | μA2          | .0         | Fosc = 8 MHz       |
|                    |     |                                 | —7                                                                                                                                 | 00     | 950  | μ <b>A</b> 3 | .0         | HFINTOSC mode      |
|                    |     |                                 | —                                                                                                                                  | 1.30   | 1.65 | mA           | 5.0        | 7                  |
| D018               |     |                                 | —                                                                                                                                  | 230    | 400  | μA2          | .0         | Fosc = 4 MHz       |
|                    |     |                                 | —4                                                                                                                                 | 00     | 680  | μ <b>A</b> 3 | .0         | EXTRC mode         |
|                    |     |                                 |                                                                                                                                    | 0.63   | 1.1  | mA           | 5.0        |                    |
| D019               |     |                                 |                                                                                                                                    | 2.6    | 3.25 | mA           | 4.5        | Fosc = 20 MHz      |
|                    |     |                                 | _                                                                                                                                  | 2.6    | 3.25 | mA           | 5.0        | HS Oscillator mode |

## 15.2 DC Characteristics: PIC12F635/PIC16F636-I (Industrial)

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** The test conditions for all IDD measurements in Active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled. MCU only, Analog Front-End not included.

2: 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. MCU only, Analog Front-End not included.

3: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.

| DC CHA | ARACTERI | STICS                  | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |       |     |              |     |                                   |  |
|--------|----------|------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------|-----|--------------|-----|-----------------------------------|--|
| Param  |          |                        |                                                                                                                                    | Truck |     | Unite        |     | Conditions                        |  |
| No.    | Sym      | Device Characteristics | Min                                                                                                                                | Тур†  | Мах | Units        | Vdd | Note                              |  |
| D020   | IPD      | Power-down Base        | —0                                                                                                                                 | .15   | 1.2 | μA           | 2.0 | WDT, BOR,                         |  |
|        |          | Current <sup>(4)</sup> | —0                                                                                                                                 | .20   | 1.5 | μ <b>A</b> 3 | .0  | Comparators, VREF                 |  |
|        |          |                        | —                                                                                                                                  | 0.35  | 1.8 | μA5          | .0  | and T1OSC disabled                |  |
| D021   |          |                        | —                                                                                                                                  | 1.0   | 2.2 | μA           | 2.0 | WDT Current <sup>(1)</sup>        |  |
|        |          |                        | —2                                                                                                                                 | .0    | 4.0 | μ <b>A</b> 3 | .0  |                                   |  |
|        |          |                        | —3                                                                                                                                 | .0    | 7.0 | μA5          | .0  |                                   |  |
| D022A  |          |                        | —                                                                                                                                  | 58    | 60  | μA           | 3.0 | BOR Current <sup>(1)</sup>        |  |
|        |          |                        | —1                                                                                                                                 | 09    | 122 | μA5          | .0  |                                   |  |
| D022B  |          |                        | —                                                                                                                                  | 22    | 28  | μA           | 2.0 | PLVD Current                      |  |
|        |          |                        | —2                                                                                                                                 | 5     | 35  | μ <b>A</b> 3 | .0  |                                   |  |
|        |          |                        | —3                                                                                                                                 | 3     | 45  | μA5          | .0  |                                   |  |
| D023   |          |                        |                                                                                                                                    | 32    | 45  | μΑ           | 2.0 | Comparator Current <sup>(3)</sup> |  |
|        |          |                        | —6                                                                                                                                 | 0     | 78  | μ <b>A</b> 3 | .0  |                                   |  |
|        |          |                        | —1                                                                                                                                 | 20    | 160 | μA5          | .0  |                                   |  |
| D024A  |          |                        | —                                                                                                                                  | 30    | 36  | μA2          | .0  | CVREF Current <sup>(1)</sup>      |  |
|        |          |                        | —4                                                                                                                                 | 5     | 55  | μ <b>A</b> 3 | .0  | (high-range)                      |  |
|        |          |                        | —7                                                                                                                                 | 5     | 95  | μA5          | .0  |                                   |  |
| D024B  |          |                        | _                                                                                                                                  | 39    | 47  | μA2          | .0  | CVREF Current <sup>(1)</sup>      |  |
|        |          |                        | —5                                                                                                                                 | 9     | 72  | μ <b>A</b> 3 | .0  | (low-range)                       |  |
|        |          |                        | —9                                                                                                                                 | 8     | 124 | μA5          | .0  |                                   |  |
| D025   |          |                        | _                                                                                                                                  | 4.5   | 7.0 | μΑ           | 2.0 | T1OSC Current <sup>(3)</sup>      |  |
|        |          |                        | —5                                                                                                                                 | .0    | 8.0 | μ <b>A</b> 3 | .0  |                                   |  |
|        |          |                        | —6                                                                                                                                 | .0    | 12  | μA5          | .0  |                                   |  |

#### 15.2 DC Characteristics: PIC12F635/PIC16F636-I (Industrial) (Continued)

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** The test conditions for all IDD measurements in Active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled. MCU only, Analog Front-End not included.

2: 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. MCU only, Analog Front-End not included.

3: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.

| DC CHARACTERISTICS |     |                                 | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |      |      |              |     |                    |  |
|--------------------|-----|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|-----|--------------------|--|
| Param              |     |                                 |                                                                                                                                   |      |      |              |     | Conditions         |  |
| No.                | Sym | Device Characteristics          | Min                                                                                                                               | Тур† | Мах  | Units        | Vdd | Note               |  |
| D010E              | IDD | Supply Current <sup>(1,2)</sup> | —1                                                                                                                                | 1    | 16   | μA2          | .0  | Fosc = 32.768 kHz  |  |
|                    |     |                                 | —1                                                                                                                                | 8    | 28   | μ <b>A</b> 3 | .0  | LP Oscillator mode |  |
|                    |     |                                 | —3                                                                                                                                | 5    | 54   | μA5          | .0  |                    |  |
| D011E              |     |                                 | —                                                                                                                                 | 140  | 240  | μA2          | .0  | Fosc = 1 MHz       |  |
|                    |     |                                 |                                                                                                                                   | 220  | 380  | μ <b>A</b> 3 | .0  | XT Oscillator mode |  |
|                    |     |                                 | —                                                                                                                                 | 380  | 550  | μA5          | .0  | 1                  |  |
| D012E              |     |                                 | —                                                                                                                                 | 260  | 360  | μA2          | .0  | Fosc = 4 MHz       |  |
|                    |     |                                 | —                                                                                                                                 | 420  | 650  | μАЗ          | .0  | XT Oscillator mode |  |
|                    |     |                                 | —                                                                                                                                 | 0.8  | 1.1  | mA           | 5.0 | 1                  |  |
| D013E              |     |                                 | T —                                                                                                                               | 130  | 220  | μA2          | .0  | Fosc = 1 MHz       |  |
|                    |     |                                 | —                                                                                                                                 | 215  | 360  | μАЗ          | .0  | EC Oscillator mode |  |
|                    |     |                                 | _                                                                                                                                 | 360  | 520  | μA5          | .0  | 7                  |  |
| D014E              |     |                                 | —                                                                                                                                 | 220  | 340  | μA2          | .0  | Fosc = 4 MHz       |  |
|                    |     |                                 | _                                                                                                                                 | 375  | 550  | μ <b>A</b> 3 | .0  | EC Oscillator mode |  |
|                    |     |                                 |                                                                                                                                   | 0.65 | 1.0  | mA           | 5.0 |                    |  |
| D015E              |     |                                 | _                                                                                                                                 | 82   | 0    | μA2          | .0  | Fosc = 31 kHz      |  |
|                    |     |                                 | —                                                                                                                                 | 16   | 40   | μ <b>A</b> 3 | .0  | LFINTOSC mode      |  |
|                    |     |                                 | _                                                                                                                                 | 31   | 65   | μA5          | .0  |                    |  |
| D016E              |     |                                 | <b>—</b>                                                                                                                          | 340  | 450  | μA2          | .0  | Fosc = 4 MHz       |  |
|                    |     |                                 | —                                                                                                                                 | 500  | 700  | μ <b>A</b> 3 | .0  | HFINTOSC mode      |  |
|                    |     |                                 | —                                                                                                                                 | 0.8  | 1.2  | mA           | 5.0 | 1                  |  |
| D017E              |     |                                 | <b>—</b>                                                                                                                          | 410  | 650  | μA2          | .0  | Fosc = 8 MHz       |  |
|                    |     |                                 | —                                                                                                                                 | 700  | 950  | μ <b>A</b> 3 | .0  | HFINTOSC mode      |  |
|                    |     |                                 | —                                                                                                                                 | 1.30 | 1.65 | mA           | 5.0 | 1                  |  |
| D018E              |     |                                 | —                                                                                                                                 | 230  | 100  | μA2          | .0  | Fosc = 4 MHz       |  |
|                    |     |                                 | —                                                                                                                                 | 400  | 680  | μ <b>A</b> 3 | .0  | EXTRC mode         |  |
|                    |     |                                 | <b>—</b>                                                                                                                          | 0.63 | 1.1  | mA           | 5.0 | 1                  |  |
| D019E              |     |                                 | <b>—</b>                                                                                                                          | 2.6  | 3.25 | mA           | 4.5 | Fosc = 20 MHz      |  |
|                    |     |                                 | _                                                                                                                                 | 2.8  | 3.35 | mA           | 5.0 | HS Oscillator mode |  |

### 15.3 DC Characteristics: PIC12F635/PIC16F636-E (Extended)

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: The test conditions for all IDD measurements in Active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled.

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

3: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.

## 15.3 DC Characteristics: PIC12F635/PIC16F636-E (Extended) (Continued)

| DC CHARACTERISTICS |     |                        | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |      |      |              |            |                                   |  |  |
|--------------------|-----|------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------|------|--------------|------------|-----------------------------------|--|--|
| Param              | 0   |                        | Min                                                                                                                               | Turk |      |              | Conditions |                                   |  |  |
| No.                | Sym | Device Characteristics | Min                                                                                                                               | Тур† | Мах  | Units        | Vdd        | Note                              |  |  |
| D020               | IPD | Power-down Base        | -                                                                                                                                 | 0.15 | 1.2  | μA           | 2.0        | WDT, BOR, Comparators,            |  |  |
|                    |     | Current <sup>(4)</sup> | —                                                                                                                                 | 0.20 | 1.5  | μ <b>A</b> 3 | .0         | VREF and T1OSC disabled           |  |  |
|                    |     |                        | _                                                                                                                                 | 0.35 | 1.8  | μA5          | .0         |                                   |  |  |
| D021               |     |                        | —                                                                                                                                 | 1.0  | 17.5 | μΑ           | 2.0        | WDT Current <sup>(1)</sup>        |  |  |
|                    |     |                        | —2                                                                                                                                | .0   | 19   | μ <b>A</b> 3 | .0         |                                   |  |  |
|                    |     |                        | —3                                                                                                                                | .0   | 22   | μA5          | .0         |                                   |  |  |
| D022A              |     |                        | —                                                                                                                                 | 42   | 60   | μA           | 3.0        | BOR Current <sup>(1)</sup>        |  |  |
|                    |     |                        | —8                                                                                                                                | 5    | 122  | μA5          | .0         |                                   |  |  |
| D022B              |     |                        | —                                                                                                                                 | 22   | 48   | μA2          | .0         | PLVD Current                      |  |  |
|                    |     |                        | —2                                                                                                                                | 5    | 55   | μ <b>A</b> 3 | .0         |                                   |  |  |
|                    |     |                        | —3                                                                                                                                | 3    | 65   | μA5          | .0         |                                   |  |  |
| D023               |     |                        | _                                                                                                                                 | 32.3 | 45   | μA           | 2.0        | Comparator Current <sup>(1)</sup> |  |  |
|                    |     |                        | 6                                                                                                                                 | 0    | 78   | μ <b>A</b> 3 | .0         |                                   |  |  |
|                    |     |                        | —                                                                                                                                 | 120  | 160  | μA5          | .0         |                                   |  |  |
| D024A              |     |                        | —                                                                                                                                 | 30   | 36   | μA2          | .0         | CVREF Current <sup>(1)</sup>      |  |  |
|                    |     |                        | —4                                                                                                                                | 5    | 55   | μ <b>A</b> 3 | .0         | (high-range)                      |  |  |
|                    |     |                        | —7                                                                                                                                | 5    | 95   | μA5          | .0         |                                   |  |  |
| D024B              |     |                        | _                                                                                                                                 | 39   | 47   | μA2          | .0         | CVREF Current <sup>(1)</sup>      |  |  |
|                    |     |                        | —5                                                                                                                                | 9    | 72   | μ <b>A</b> 3 | .0         | (low-range)                       |  |  |
|                    |     |                        | —9                                                                                                                                | 8    | 124  | μA5          | .0         |                                   |  |  |
| D025               |     |                        | —                                                                                                                                 | 4.5  | 25   | μA           | 2.0        | T1OSC Current <sup>(3)</sup>      |  |  |
|                    |     |                        | —5                                                                                                                                | .0   | 30   | μ <b>A</b> 3 | .0         |                                   |  |  |
|                    |     |                        | —6                                                                                                                                | .0   | 40   | μ <b>A</b> 5 | .0         |                                   |  |  |

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** The test conditions for all IDD measurements in Active Operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled.

- 2: 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.
- 3: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.
- 4: 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 VDD.

#### 15.4 DC Characteristics: PIC12F635/PIC16F636-I (Industrial) PIC12F635/PIC16F636-E (Extended)

|               |      |                                       | Standard Operating tempo   | -      | o <b>therwise stated)</b><br>-85°C for industrial<br>-125°C for extended |        |                                                                                                                    |
|---------------|------|---------------------------------------|----------------------------|--------|--------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------|
| Param<br>No.  | Sym  | Characteristic                        | Min                        | Тур†   | Max                                                                      | Units  | Conditions                                                                                                         |
|               | VIL  | Input Low Voltage                     |                            |        |                                                                          |        |                                                                                                                    |
|               |      | I/O ports:                            |                            |        |                                                                          |        |                                                                                                                    |
| D030          |      | with TTL buffer                       | Vss                        | -      | 0.8                                                                      | V      | $4.5V \leq V\text{DD} \leq 5.5V$                                                                                   |
| D030A         |      |                                       | Vss                        | —0     | .15 Vdd                                                                  | VO     | therwise                                                                                                           |
| D031          |      | with Schmitt Trigger buffer           | Vss                        | —      | 0.2 Vdd                                                                  | V      | Entire range                                                                                                       |
| D032          |      | MCLR, OSC1 (RC mode)                  | Vss                        | —      | 0.2 Vdd                                                                  | V      |                                                                                                                    |
| D033          |      | OSC1 (XT and LP modes) <sup>(1)</sup> | Vss                        | —0     | .3                                                                       | V      |                                                                                                                    |
| D033A         |      | OSC1 (HS mode) <sup>(1)</sup>         | Vss                        | _      | 0.3 Vdd                                                                  | V      |                                                                                                                    |
|               | Vih  | Input High Voltage                    |                            |        |                                                                          |        |                                                                                                                    |
|               |      | I/O ports:                            |                            |        |                                                                          |        |                                                                                                                    |
| D040<br>D040A |      | with TTL buffer                       | 2.0<br>(0.25 VDD +<br>0.8) | _<br>_ | Vdd<br>Vdd                                                               | V<br>V | $4.5V \le VDD \le 5.5V$<br>Otherwise                                                                               |
| D041          |      | with Schmitt Trigger buffer           | 0.8 VDD                    | —V     | DD                                                                       | V      | Entire range                                                                                                       |
| D042          |      | MCLR                                  | 0.8 Vdd                    | _      | Vdd                                                                      | V      | 5                                                                                                                  |
| D043          |      | OSC1 (XT and LP modes)                | 1.6                        | _      | Vdd                                                                      | V      | (Note 1)                                                                                                           |
| D043A         |      | OSC1 (HS mode)                        | 0.7 Vdd                    | —V     | DD                                                                       | V      | (Note 1)                                                                                                           |
| D043B         |      | OSC1 (RC mode)                        | 0.9 Vdd                    | —V     | DD                                                                       | V      |                                                                                                                    |
|               | lı∟  | Input Leakage Current <sup>(2)</sup>  |                            |        |                                                                          |        |                                                                                                                    |
| D060          |      | I/O ports                             | —                          | ± 0.1  | ± 1                                                                      | μAV    | $\label{eq:ss} \begin{split} &ss \leq V \text{PIN} \leq V \text{DD}, \\ &\text{Pin at high-impedance} \end{split}$ |
| D060A         |      | Analog inputs                         | —                          | ± 0.1  | ± 1                                                                      | μAV    | $SS \leq VPIN \leq VDD$                                                                                            |
| D060B         |      | VREF                                  | —                          | ± 0.1  | ± 1                                                                      | μAV    | $SS \leq VPIN \leq VDD$                                                                                            |
| D061          |      | MCLR <sup>(3)</sup>                   | —                          | ± 0.1  | ± 5                                                                      | μΑ     | $VSS \leq VPIN \leq VDD$                                                                                           |
| D063          |      | OSC1                                  | _                          | ± 0.1  | ±5                                                                       | μAV    | SS $\leq$ VPIN $\leq$ VDD, XT, HS and LP oscillator configuration                                                  |
| D070          | IPUR | PORTA Weak Pull-up<br>Current         | 50                         | 250    | 400                                                                      | μAV    | DD = 5.0V, VPIN = VSS                                                                                              |
| D071          | IPDR | PORTA Weak Pull-down<br>Current       | 50                         | 250    | 400                                                                      | μAV    | DD = 5.0V, VPIN = VDD                                                                                              |
|               | Vol  | Output Low Voltage                    |                            |        |                                                                          |        |                                                                                                                    |
| D080          |      | I/O ports                             | —                          | -      | 0.6                                                                      | V      | IOL = 8.5 mA, VDD = 4.5V (Ind.)                                                                                    |
| D083          |      | OSC2/CLKOUT (RC mode)                 | —                          | -      | 0.6                                                                      | V      | IOL = 1.6 mA, VDD = 4.5V (Ind.)<br>IOL = 1.2 mA, VDD = 4.5V (Ext.)                                                 |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC mode.

2: Negative current is defined as current sourced by the pin.

**3:** 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.

4: See Section 9.4.1 "Using the Data EEPROM" for additional information.

#### 15.4 DC Characteristics: PIC12F635/PIC16F636-I (Industrial) PIC12F635/PIC16F636-E (Extended) (Continued)

| DC CH        | ARACTE |                                                                     |           | onditions (unless otherwise stated)<br>$-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial<br>$-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |     |       |                                                                        |
|--------------|--------|---------------------------------------------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------|------------------------------------------------------------------------|
| Param<br>No. | Sym    | Characteristic                                                      | Min       | Тур†                                                                                                                                                 | Max | Units | Conditions                                                             |
|              | Voн    | Output High Voltage                                                 |           |                                                                                                                                                      |     |       |                                                                        |
| D090         |        | I/O ports                                                           | Vdd - 0.7 | —                                                                                                                                                    | _   | V     | IOH = -3.0  mA,  VDD = 4.5 V (Ind.)                                    |
| D092         |        | OSC2/CLKOUT (RC mode)                                               | Vdd - 0.7 | —                                                                                                                                                    | —   | V     | IOH = -1.3 mA, VDD = 4.5V (Ind.)<br>IOH = -1.0 mA, VDD = 4.5V (Ext.)   |
| D100         | IULP   | Ultra Low-power Wake-up<br>Current                                  | —2        | 00                                                                                                                                                   | _   | nA    |                                                                        |
|              |        | Capacitive Loading Specs<br>on Output Pins                          |           |                                                                                                                                                      |     |       |                                                                        |
| D101         | COSC2  | OSC2 pin                                                            | _         | _                                                                                                                                                    | 15* | pF    | In XT, HS and LP modes when<br>external clock is used to drive<br>OSC1 |
| D101A        | Сю     | All I/O pins                                                        | _         | _                                                                                                                                                    | 50* | pF    |                                                                        |
|              |        | Data EEPROM Memory                                                  |           |                                                                                                                                                      |     |       |                                                                        |
| D120         | ED     | Byte Endurance                                                      | 100K      | 1M                                                                                                                                                   | _   | E/W   | -40°C ≤ TA ≤ +85°C                                                     |
| D120A        | ED     | Byte Endurance                                                      | 10K       | 100K                                                                                                                                                 | _   | E/W   | $+85^{\circ}C \le TA \le +125^{\circ}C$                                |
| D121         | Vdrw   | VDD for Read/Write                                                  | Vmin      | _                                                                                                                                                    | 5.5 | V     | Using EECON1 to read/write<br>VMIN = Minimum operating<br>voltage      |
| D122         | TDEW   | Erase/Write cycle time                                              | —         | 5                                                                                                                                                    | 6   | ms    |                                                                        |
| D123         | TRETD  | Characteristic Retention                                            | 40        | —                                                                                                                                                    | —   | Year  | Provided no other specifications are violated                          |
| D124         | Tref   | Number of Total Erase/Write<br>Cycles before Refresh <sup>(4)</sup> | 1M        | 10M                                                                                                                                                  | —   | E/W   | $-40^{\circ}C \leq TA \leq +85^{\circ}C$                               |
|              |        | Program Flash Memory                                                |           |                                                                                                                                                      |     |       |                                                                        |
| D130         | Eр     | Cell Endurance                                                      | 10K       | 100K                                                                                                                                                 | —   | E/W   | $-40^{\circ}C \le TA \le +85^{\circ}C$                                 |
| D130A        | ED     | Cell Endurance                                                      | 1K        | 10K                                                                                                                                                  | —   | E/W   | $+85^{\circ}C \le TA \le +125^{\circ}C$                                |
| D131         | Vpr    | VDD for Read                                                        | Vmin      | —5                                                                                                                                                   | .5  | V     | VMIN = Minimum operating<br>voltage                                    |
| D132         | VPEW   | VDD for Erase/Write                                                 | 4.5       | —                                                                                                                                                    | 5.5 | V     |                                                                        |
| D133         | TPEW   | Erase/Write cycle time                                              | —         | 2                                                                                                                                                    | 2.5 | ms    |                                                                        |
| D134         | TRETD  | Characteristic Retention                                            | 40        | -                                                                                                                                                    | —   | Year  | Provided no other<br>specifications are violated                       |

These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC mode.

2: Negative current is defined as current sourced by the pin.

**3:** 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.

4: See Section 9.4.1 "Using the Data EEPROM" for additional information.

| DC CHARACTERISTICS |       |                                                                         |       | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial |          |          |                                                                   |  |  |
|--------------------|-------|-------------------------------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------|----------|----------|-------------------------------------------------------------------|--|--|
| Param<br>No.       | Sym   | Characteristic                                                          | Min   | Тур†                                                                                                                               | Max      | Units    | Conditions                                                        |  |  |
| D001               | Vdd   | Supply Voltage                                                          | 2.0   | —                                                                                                                                  | 3.6      | V        | Fosc ≤ 10 MHz                                                     |  |  |
| D001A              | Vddt  | Supply Voltage (AFE)                                                    | 2.0   | _                                                                                                                                  | 3.6      | V        | Analog Front-End VDD voltage. Treated as<br>VDD in this document. |  |  |
| D002               | Vdr   | RAM Data Retention<br>Voltage <sup>(1)</sup>                            | 1.5*  | _                                                                                                                                  | _        | V        | Device in Sleep mode                                              |  |  |
| D003               | VPOR  | VDD Start Voltage to<br>ensure internal Power-on<br>Reset signal        | V     | SS                                                                                                                                 | —V       |          | See Section 12.3 "Power-on Reset" for details.                    |  |  |
| D003A              | VPORT | VDD Start Voltage (AFE)<br>to ensure internal Power-<br>on Reset signal | —     | —                                                                                                                                  | 1.8      | V        | Analog Front-End POR voltage.                                     |  |  |
| D004               | Svdd  | VDD Rise Rate to ensure<br>internal Power-on Reset<br>signal            | 0.05* | —                                                                                                                                  | _        | V/ms     | See Section 12.3 "Power-on Reset" for details.                    |  |  |
| D005               | VBOD  | Brown-out Reset                                                         | 2.0   | 2.1                                                                                                                                | 2.2      | V        |                                                                   |  |  |
| D006               | Rм    | Turn-on Resistance or<br>Modulation Transistor                          | _     | 50                                                                                                                                 | 100      | Ohm      | VDD = 3.0V                                                        |  |  |
| D007               | Rpu   | Digital Input Pull-Up<br>Resistor<br>CS, SCLK                           | 50    | 200                                                                                                                                | 350      | kOhm     | VDD = 3.6V                                                        |  |  |
| D008               | Iail  | Analog Input Leakage<br>Current<br>LCX, LCY, LCZ<br>LCCOM               |       |                                                                                                                                    | ±1<br>±1 | μΑ<br>μΑ | VDD = 3.6V, VSS $\leq$ VIN $\leq$ VDD, tested at Sleep mode       |  |  |

#### DC Characteristics: PIC16F639-I (Industrial) 15.5

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: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.

# 15.6 DC Characteristics: PIC16F639-I (Industrial)

| DC CHAF | RACTERIST      | ICS                                                                                                                                               |     | temperati   |             |                |                   | <b>e stated)</b><br>C for industrial                                                                                                     |  |
|---------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------|-------------|----------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| Param   |                |                                                                                                                                                   |     | <b>.</b>    |             | 11             | Conditions        |                                                                                                                                          |  |
| No.     | Sym            | Device Characteristics                                                                                                                            | Min | Тур†        | Мах         | Units          | Vdd               | Note                                                                                                                                     |  |
| D010    | IDD            | Supply Current <sup>(1,2,3)</sup>                                                                                                                 | —1  | 1           | 16          | μ <b>A</b> 2   | .0                | Fosc = 32.768 kHz                                                                                                                        |  |
|         |                |                                                                                                                                                   | —1  | 8           | 28          | μΑ3            | .0                | LP Oscillator mode                                                                                                                       |  |
| D011    |                |                                                                                                                                                   | _   | 140         | 240         | μA2            | .0                | Fosc = 1 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   | _   | 220         | 380         | μАЗ            | .0                | XT Oscillator mode                                                                                                                       |  |
| D012    |                |                                                                                                                                                   | _   | 260         | 360         | μA2            | .0                | Fosc = 4 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   | _   | 420         | 650         | μ <b>A</b> 3   | .0                | XT Oscillator mode                                                                                                                       |  |
| D013    |                |                                                                                                                                                   | _   | 130         | 220         | μA2            | .0                | Fosc = 1 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   | _   | 215         | 360         | μАЗ            | .0                | EC Oscillator mode                                                                                                                       |  |
| D014    |                |                                                                                                                                                   | -   | 220         | 340         | μA2            | .0                | Fosc = 4 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   | _   | 375         | 550         | μАЗ            | .0                | EC Oscillator mode                                                                                                                       |  |
| D015    |                |                                                                                                                                                   | -   | 8           | 20          | μA2            | .0                | Fosc = 31 kHz                                                                                                                            |  |
|         |                |                                                                                                                                                   | —1  | 6           | 40          | μ <b>A</b> 3   | .0                | LFINTOSC mode                                                                                                                            |  |
| D016    |                |                                                                                                                                                   |     | 340         | 450         | μA2            | .0                | Fosc = 4 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   |     | 500         | 700         | μ <b>A</b> 3   | .0                | HFINTOSC mode                                                                                                                            |  |
| D017    |                |                                                                                                                                                   |     | 230         | 400         | μA2            | .0                | Fosc = 4 MHz                                                                                                                             |  |
|         |                |                                                                                                                                                   |     | 400         | 680         | μ <b>A</b> 3   | .0                | EXTRC mode                                                                                                                               |  |
| D020    | IPD            | Power-down Base Current <sup>(4)</sup>                                                                                                            | _   | 0.15        | 1.2         | μA             | 2.0               | WDT, BOR, Comparators,                                                                                                                   |  |
|         |                |                                                                                                                                                   | -   | 0.20        | 1.5         | μ <b>A</b> 3   | .0                | VREF and T1OSC disabled<br>(excludes AFE)                                                                                                |  |
| D021    | IWDT           |                                                                                                                                                   | _   | 1.2         | 2.2         | μA2            | .0                | WDT Current <sup>(1)</sup>                                                                                                               |  |
|         |                |                                                                                                                                                   | —2  | .0          | 4.0         | μАЗ            | .0                |                                                                                                                                          |  |
| D022A   | IBOR           |                                                                                                                                                   | _   | 42          | 60          | μA             | 3.0               | BOR Current <sup>(1)</sup>                                                                                                               |  |
| D022B   | ILVD           |                                                                                                                                                   | _   | 22          | 28          | μA             | 2.0               | PLVD Current                                                                                                                             |  |
|         |                |                                                                                                                                                   | —2  | 5           | 35          | μ <b>A</b> 3   | .0                |                                                                                                                                          |  |
| D023    | ICMP           |                                                                                                                                                   | _   | 32          | 45          | μA             | 2.0               | Comparator Current <sup>(1)</sup>                                                                                                        |  |
|         |                |                                                                                                                                                   | —6  | 0           | 78          | μ <b>A</b> 3   | .0                |                                                                                                                                          |  |
| D024A   | <b>IVREFHS</b> |                                                                                                                                                   | —3  | 0           | 36          | μA2            | .0                | CVREF Current <sup>(1)</sup>                                                                                                             |  |
|         |                |                                                                                                                                                   | —4  | 5           | 55          | μ <b>A</b> 3   | .0                | (high-range)                                                                                                                             |  |
| D024B   | IVREFLS        |                                                                                                                                                   | —3  | 9           | 47          | μA2            | .0                | CVREF Current <sup>(1)</sup>                                                                                                             |  |
|         |                |                                                                                                                                                   | —5  | 9           | 72          | μ <b>A</b> 3   | .0                | (low-range)                                                                                                                              |  |
| D025    | IT10SC         |                                                                                                                                                   |     | 4.5         | 7.0         | μA             | 2.0               | T1OSC Current <sup>(1)</sup>                                                                                                             |  |
|         |                |                                                                                                                                                   | —5  | .0          | 8.0         | μ <b>A</b> 3   | .0                |                                                                                                                                          |  |
| D026    | IACT           | Active Current of AFE only<br>(receiving signal)<br>1 LC Input Channel Signal<br>3 LC Input Channel Signals                                       |     | 10<br>13    |             | μΑ<br>μΑ       | 3.6<br>3.6        | CS         = VDD; Input = Continuous           Wave (CW);         Amplitude = 300 mVPP.           All channels enabled.         Interval |  |
| D027    | ISTDBY         | Standby Current of AFE only<br>(not receiving signal)<br>1 LC Input Channel Enabled<br>2 LC Input Channels Enabled<br>3 LC Input Channels Enabled |     | 3<br>4<br>5 | 5<br>6<br>7 | μΑ<br>μΑ<br>μΑ | 3.6<br>3.6<br>3.6 | CS = VDD; ALERT = VDD                                                                                                                    |  |
| D028    | ISLEEP         | Sleep Current of AFE only                                                                                                                         | —   | 0.2         | 1           | μ <b>A</b> 3   | .6                | $\overline{CS} = VDD; \overline{ALERT} = VDD$                                                                                            |  |

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: The test conditions for all <u>IDD measurements</u> in active operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled. MCU only, Analog Front-End not included.

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. MCU only, Analog Front-End not included.

3: The peripheral current is the sum of the base IDD or IPD and the additional current consumed when this peripheral is enabled. The peripheral ∆ current can be determined by subtracting the base IDD or IPD current from this limit. Max values should be used when calculating total current consumption.

| DC CHARACTERISTICS |      | Standard Operating Conditions (unless otherwise stated)           Operating temperature $-40^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial           Supply Voltage $2.0V \leq VDD \leq 3.6V$ |                  |       |           |       |                                                                    |  |
|--------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------|-----------|-------|--------------------------------------------------------------------|--|
| Param<br>No.       | Sym  | Characteristic                                                                                                                                                                                     | Min              | Тур†  | Max       | Units | Conditions                                                         |  |
|                    | VIL  | Input Low Voltage                                                                                                                                                                                  |                  |       |           |       |                                                                    |  |
|                    |      | I/O ports:                                                                                                                                                                                         |                  |       |           |       |                                                                    |  |
| D030A              |      | with TTL buffer                                                                                                                                                                                    | Vss              | —     | 0.15 Vdd  | V     |                                                                    |  |
| D031               |      | with Schmitt Trigger buffer                                                                                                                                                                        | Vss              | —0    | .2 Vdd    | V     |                                                                    |  |
| D032               |      | MCLR, OSC1 (RC mode)                                                                                                                                                                               | Vss              | —     | 0.2 DD    | v v   |                                                                    |  |
| D033               |      | OSC1 (XT and LP modes) <sup>(1)</sup>                                                                                                                                                              | Vss              | —0    | .3        | V     |                                                                    |  |
| D033A              |      | OSC1 (HS mode) <sup>(1)</sup>                                                                                                                                                                      | Vss              | —0    | .3 Vdd    | V     |                                                                    |  |
| D034               |      | Digital Input Low Voltage                                                                                                                                                                          | Vss              | —0    | .3 Vdd    | V     | Analog Front-End section                                           |  |
|                    | VIH  | Input High Voltage                                                                                                                                                                                 |                  |       |           |       |                                                                    |  |
|                    |      | I/O ports:                                                                                                                                                                                         |                  |       |           |       |                                                                    |  |
| D040               |      | with TTL buffer                                                                                                                                                                                    |                  |       |           |       |                                                                    |  |
| D040A              |      |                                                                                                                                                                                                    | (0.25 VDD + 0.8) | _     | Vdd       | V     |                                                                    |  |
| D041               |      | with Schmitt Trigger buffer                                                                                                                                                                        | 0.8 Vdd          | V     | DD        | V     |                                                                    |  |
| D042               |      | MCLR                                                                                                                                                                                               | 0.8 Vdd          | _     | Vdd       | V     |                                                                    |  |
| D043               |      | OSC1 (XT and LP modes)                                                                                                                                                                             | 1.6              | _     | Vdd       | V     | (Note 1)                                                           |  |
| D043A              |      | OSC1 (HS mode)                                                                                                                                                                                     | 0.7 Vdd          | V     | DD        | V     | (Note 1)                                                           |  |
| D043B              |      | OSC1 (RC mode)                                                                                                                                                                                     | 0.9 Vdd          | —V    | DD        | V     |                                                                    |  |
|                    |      | Digital Input High Voltage                                                                                                                                                                         |                  |       |           |       | Analog Front-End section                                           |  |
| D044               |      | SCLK, CS, SDIO for Analog<br>Front-End (AFE)                                                                                                                                                       | 0.8 Vdd          | -     | Vdd       | V     |                                                                    |  |
|                    | lı∟  | Input Leakage Current <sup>(2)</sup>                                                                                                                                                               |                  |       |           |       |                                                                    |  |
| D060               |      | I/O ports                                                                                                                                                                                          | -                | ± 0.1 | ± 1       | μAV   | SS ≤ VPIN ≤ VDD,<br>Pin at high-impedance                          |  |
| D060A              |      | Analog inputs                                                                                                                                                                                      | _                | ± 0.1 | ± 1       | μAV   | $SS \leq VPIN \leq VDD$                                            |  |
| D060B              |      | VREF                                                                                                                                                                                               | _                | ± 0.1 | ± 1       | μAV   | $SS \leq VPIN \leq VDD$                                            |  |
| D061               |      | MCLR <sup>(3)</sup>                                                                                                                                                                                | _                | ± 0.1 | ± 5       | μΑ    | $VSS \le VPIN \le VDD$                                             |  |
| D063               |      | OSC1                                                                                                                                                                                               | -                | ± 0.1 | ± 5       | μΑ    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP oscillator configuration |  |
|                    |      | Digital Input Leakage Current <sup>(2)</sup>                                                                                                                                                       |                  |       |           |       | VDD = 3.6V, Analog Front-End section                               |  |
| D064               |      | SDI for Analog Front-End (AFE)                                                                                                                                                                     | _                | _     | ± 1       | μAV   | $SS \leq VPIN \leq VDD$                                            |  |
| D064A              |      | SCLK, CS for Analog Front-End (AFE)                                                                                                                                                                |                  |       | ± 1       | μAV   | $PIN \leq VDD$                                                     |  |
| D070               | IPUR | PORTA Weak Pull-up Current                                                                                                                                                                         | 50*              | 250   | 400       | μAV   | DD = 3.6V, VPIN = VSS                                              |  |
| D071               | IPDR | PORTA Weak Pull-down Current                                                                                                                                                                       | 50               | 250   | 400       | μAV   | DD = 3.6V, VPIN = VDD                                              |  |
|                    | Vol  | Output Low Voltage                                                                                                                                                                                 |                  |       |           |       |                                                                    |  |
| D080               |      | I/O ports                                                                                                                                                                                          | _                | -     | 0.6       | V     | IOL = 8.5 mA, VDD = 3.6V (Ind.)                                    |  |
| D083               |      | OSC2/CLKOUT (RC mode)                                                                                                                                                                              | _                | _     | 0.6       | V     | IOL = 1.6 mA, VDD = 3.6V (Ind.)<br>IOL = 1.2 mA, VDD = 3.6V (Ext.) |  |
|                    |      | Digital Output Low Voltage                                                                                                                                                                         |                  |       |           |       | Analog Front-End section                                           |  |
| D084               |      | ALERT, LFDATA/SDIO for<br>Analog Front-End (AFE)                                                                                                                                                   | —                | _     | VSS + 0.4 | VI    | ol = 1.0 mA, VDD = 2.0V                                            |  |

#### 15.7 DC Characteristics: PIC16F639-I (Industrial)

These parameters are characterized but not tested.

t 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 In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC 1: mode.

2:

Negative current is defined as current sourced by the pin. The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating 3: conditions. Higher leakage current may be measured at different input voltages.

4: See Section 9.4.1 "Using the Data EEPROM" for additional information

#### DC Characteristics: PIC16F639-I (Industrial) (Continued) 15.7

| DC CHARACTERISTICS |       |                                                                     | Standard Operating<br>Operating temperate<br>Supply Voltage | -40°C ≤ | s (unless otherwise stated)<br>-40°C $\leq$ Ta $\leq$ +85°C for industrial<br>2.0V $\leq$ VDD $\leq$ 3.6V |       |                                                                     |
|--------------------|-------|---------------------------------------------------------------------|-------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------|-------|---------------------------------------------------------------------|
| Param<br>No.       | Sym   | Characteristic                                                      | Min                                                         | Тур†    | Max                                                                                                       | Units | Conditions                                                          |
|                    | Voн   | Output High Voltage                                                 |                                                             |         |                                                                                                           |       |                                                                     |
| D090               |       | I/O ports                                                           | Vdd - 0.7                                                   | —       | _                                                                                                         | V     | IOH = -3.0 mA, VDD = 3.6V (Ind.)                                    |
| D092               |       | OSC2/CLKOUT (RC mode)                                               | Vdd - 0.7                                                   | —       | —                                                                                                         | V     | Юн = -1.3 mA, VDD = 3.6V (Ind.)<br>Юн = -1.0 mA, VDD = 3.6V (Ext.)  |
|                    |       | Digital Output High Voltage                                         |                                                             |         |                                                                                                           |       | Analog Front-End (AFE) section                                      |
| D093               |       | LFDATA/SDIO for Analog Front-End (AFE)                              | Vdd - 0.5                                                   | —       | —                                                                                                         | V     | Ioh = -400 $\mu$ A, Vdd = 2.0V                                      |
|                    |       | Capacitive Loading Specs on<br>Output Pins                          |                                                             |         |                                                                                                           |       |                                                                     |
| D100               | COSC2 | OSC2 pin                                                            | _                                                           | —       | 15*                                                                                                       | pF    | In XT, HS and LP modes when<br>external clock is used to drive OSC1 |
| D101               | Сю    | All I/O pins                                                        | _                                                           | _       | 50*                                                                                                       | pF    |                                                                     |
| D102               | IULP  | Ultra Low-power Wake-up Current                                     | —2                                                          | 00      | _                                                                                                         | nA    |                                                                     |
|                    |       | Data EEPROM Memory                                                  |                                                             |         |                                                                                                           |       |                                                                     |
| D120               | ED    | Byte Endurance                                                      | 100K                                                        | 1M      | —                                                                                                         | E/W   | $-40^{\circ}C \le TA \le +85^{\circ}C$                              |
| D120A              | ED    | Byte Endurance                                                      | 10K                                                         | 100K    | —                                                                                                         | E/W   | $+85^{\circ}C \leq TA \leq +125^{\circ}C$                           |
| D121               | Vdrw  | VDD for Read/Write                                                  | Vmin                                                        | —       | 5.5                                                                                                       | V     | Using EECON1 to read/write<br>VMIN = Minimum operating voltage      |
| D122               | TDEW  | Erase/Write cycle time                                              | —                                                           | 5       | 6                                                                                                         | ms    |                                                                     |
| D123               | TRETD | Characteristic Retention                                            | 40                                                          | —       | —                                                                                                         | Year  | Provided no other specifications are violated                       |
| D124               | TREF  | Number of Total Erase/Write Cycles<br>before Refresh <sup>(1)</sup> | 1M                                                          | 10M     | —                                                                                                         | E/W   | $-40^{\circ}C \le TA \le +85^{\circ}C$                              |
|                    |       | Program Flash Memory                                                |                                                             |         |                                                                                                           |       |                                                                     |
| D130               | Eр    | Cell Endurance                                                      | 10K                                                         | 100K    | —                                                                                                         | E/W   | $-40^{\circ}C \le TA \le +85^{\circ}C$                              |
| D130A              | ED    | Cell Endurance                                                      | 1K                                                          | 10K     | —                                                                                                         | E/W   | +85°C ≤ TA ≤ +125°C                                                 |
| D131               | Vpr   | VDD for Read                                                        | VMIN                                                        | —5      | .5                                                                                                        | V     | VMIN = Minimum operating voltage                                    |
| D132               | VPEW  | VDD for Erase/Write                                                 | 4.5                                                         | -       | 5.5                                                                                                       | V     |                                                                     |
| D133               | TPEW  | Erase/Write cycle time                                              | —                                                           | 2       | 2.5                                                                                                       | ms    |                                                                     |
| D134               | TRETD | Characteristic Retention                                            | 40                                                          | —       | —                                                                                                         | Year  | Provided no other specifications are violated                       |

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. In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC t

Note 1: mode.

2:

Negative current is defined as current sourced by the pin. The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating 3: conditions. Higher leakage current may be measured at different input voltages.

See Section 9.4.1 "Using the Data EEPROM" for additional information 4:

### 15.8 Thermal Considerations

| Opera            | ting tempera | ng Conditions (unless of ature $-40^{\circ}C \le TA \le +125^{\circ}$ |           |       | [     | 1                                                        |
|------------------|--------------|-----------------------------------------------------------------------|-----------|-------|-------|----------------------------------------------------------|
| Para<br>m<br>No. | Sym          | Characteristi                                                         | c         | Тур   | Units | Conditions                                               |
| TH01             | θја          | Thermal Resistance                                                    |           | 84.6  | °C/W  | 8-pin PDIP package                                       |
|                  |              | Junction to Ambient                                                   | PIC12F635 | 163.0 | °C/W  | 8-pin SOIC package                                       |
|                  |              |                                                                       | PIC12F035 | 52.4  | °C/W  | 8-pin DFN 4x4x0.9 mm package                             |
|                  |              |                                                                       |           | 52.4  | °C/W  | 8-pin DFN-S 6x5 mm package                               |
|                  |              |                                                                       |           | 69.8  | °C/W  | 14-pin PDIP package                                      |
|                  |              |                                                                       |           | 85.0  | °C/W  | 14-pin SOIC package                                      |
|                  |              |                                                                       | PIC16F636 | 100.4 | °C/W  | 14-pin TSSOP package                                     |
|                  |              |                                                                       |           | 46.3  | °C/W  | 16-pin QFN 4x0.9mm package                               |
|                  |              |                                                                       | PIC16F639 | 108.1 | °C/W  | 20-pin SSOP package                                      |
| TH02             | θJC          | Thermal Resistance<br>Junction to Case                                | PIC12F635 | 41.2  | °C/W  | 8-pin PDIP package                                       |
|                  |              |                                                                       |           | 38.8  | °C/W  | 8-pin SOIC package                                       |
|                  |              |                                                                       |           | 3.0   | °C/W  | 8-pin DFN 4x4x0.9 mm package                             |
|                  |              |                                                                       |           | 3.0   | °C/W  | 8-pin DFN-S 6x5 mm package                               |
|                  |              |                                                                       | PIC16F636 | 32.5  | °C/W  | 14-pin PDIP package                                      |
|                  |              |                                                                       |           | 31.0  | °C/W  | 14-pin SOIC package                                      |
|                  |              |                                                                       |           | 31.7  | °C/W  | 14-pin TSSOP package                                     |
|                  |              |                                                                       |           | 2.6   | °C/W  | 16-pin QFN 4x0.9mm package                               |
|                  |              |                                                                       | PIC16F639 | 32.2  | °C/W  | 20-pin SSOP package                                      |
| TH03             | TJ           | Junction Temperature                                                  |           | 150   | °C    | For derated power calculations                           |
| TH04             | PD           | Power Dissipation                                                     |           | —     | W     | PD = PINTERNAL + PI/O                                    |
| TH05             | PINTERNAL    | Internal Power Dissipation                                            |           | _     | W     | PINTERNAL = IDD x VDD<br>(NOTE 1)                        |
| TH06             | Pi/o         | I/O Power Dissipation                                                 |           | _     | W     | $PI/O = \Sigma (IOL * VOL) + \Sigma (IOH * (VDD - VOH))$ |
| TH07             | Pder         | Derated Power                                                         |           | _     | W     | Pder = (Tj - Ta)/θja<br>(NOTE 2, 3)                      |

Note 1: IDD is current to run the chip alone without driving any load on the output pins.

**2:** TA = Ambient Temperature.

**3:** Maximum allowable power dissipation is the lower value of either the absolute maximum total power dissipation or derated power (PDER).

## 15.9 Timing Parameter Symbology

The timing parameter symbols have been created with one of the following formats:

- 1. TppS2ppS
- 2. TppS

| 2. Tpp3 |                                      |     |                |
|---------|--------------------------------------|-----|----------------|
| т       |                                      |     |                |
| F       | Frequency                            | Т   | Time           |
| Lowerc  | ase letters (pp) and their meanings: |     |                |
| рр      |                                      |     |                |
| СС      | CCP1                                 | OSC | OSC1           |
| ck      | CLKOUT                               | rd  | RD             |
| CS      | CS                                   | rw  | RD or WR       |
| di      | SDI                                  | SC  | SCLK           |
| do      | SDO                                  | SS  | SS             |
| dt      | Data in                              | tO  | TOCKI          |
| io      | I/O port                             | t1  | T1CKI          |
| mc      | MCLR                                 | wr  | WR             |
| Upperc  | ase letters and their meanings:      |     |                |
| S       |                                      |     |                |
| F       | Fall                                 | Р   | Period         |
| н       | High                                 | R   | Rise           |
| 1       | Invalid (High-impedance)             | V   | Valid          |
| L       | Low                                  | Z   | High-impedance |

#### FIGURE 15-4: LOAD CONDITIONS



### 15.10 AC Characteristics: PIC12F635/PIC16F636/639 (Industrial, Extended)



#### TABLE 15-1: CLOCK OSCILLATOR TIMING REQUIREMENTS

| <b>Standar</b><br>Operatin | -     | ting Conditions (unless otherw rature $-40^{\circ}C \le TA \le +125^{\circ}$ |     | ed)    |        |       |                    |
|----------------------------|-------|------------------------------------------------------------------------------|-----|--------|--------|-------|--------------------|
| Param<br>No.               | Sym   | Characteristic                                                               | Min | Тур†   | Max    | Units | Conditions         |
| OS01                       | Fosc  | External CLKIN Frequency <sup>(1)</sup>                                      | DC  | _      | 37     | kHz   | LP Oscillator mode |
|                            |       |                                                                              | DC  | —      | 4      | MHz   | XT Oscillator mode |
|                            |       |                                                                              | DC  | —      | 20     | MHz   | HS Oscillator mode |
|                            |       |                                                                              | DC  | —      | 20     | MHz   | EC Oscillator mode |
|                            |       | Oscillator Frequency <sup>(1)</sup>                                          |     | 32.768 | _      | kHz   | LP Oscillator mode |
|                            |       |                                                                              | 0.1 | _      | 4      | MHz   | XT Oscillator mode |
|                            |       |                                                                              | 1   | _      | 20     | MHz   | HS Oscillator mode |
|                            |       |                                                                              | DC  | —      | 4      | MHz   | RC Oscillator mode |
| OS02                       | Tosc  | External CLKIN Period <sup>(1)</sup>                                         | 27  | —      | ∞µ     | S     | LP Oscillator mode |
|                            |       |                                                                              | 250 | —      | ~      | ns    | XT Oscillator mode |
|                            |       |                                                                              | 50  | —      | ~      | ns    | HS Oscillator mode |
|                            |       |                                                                              | 50  | _      | ~      | ns    | EC Oscillator mode |
|                            |       | Oscillator Period <sup>(1)</sup>                                             | —3  | 0.5    | _      | μs    | LP Oscillator mode |
|                            |       |                                                                              | 250 | —      | 10,000 | ns    | XT Oscillator mode |
|                            |       |                                                                              | 50  | —      | 1,000  | ns    | HS Oscillator mode |
|                            |       |                                                                              | 250 | —      | —      | ns    | RC Oscillator mode |
| OS03                       | Тсү   | Instruction Cycle Time <sup>(1)</sup> 20                                     | 0   | TCY    | DC     | ns    | TCY = 4/FOSC       |
| OS04*                      | TosH, | External CLKIN High,                                                         | 2—  |        | _      | μs    | LP oscillator      |
|                            | TosL  | External CLKIN Low                                                           | 100 | —      | —      | ns    | XT oscillator      |
|                            |       |                                                                              | 20  | —      | —      | ns    | HS oscillator      |
| OS05*                      | TosR, | External CLKIN Rise,                                                         | 0   | —      | 50     | ns    | LP oscillator      |
|                            | TosF  | External CLKIN Fall                                                          | 0   | —      | 25     | ns    | XT oscillator      |
|                            |       |                                                                              | 0   | —      | 15     | ns    | HS oscillator      |

These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

**Note 1:** Instruction cycle period (TCY) 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.

#### TABLE 15-2: OSCILLATOR PARAMETERS

| Param<br>No. | Sym     | Characteristic                                         | Freq<br>Tolerance | Min  | Тур† | Max  | Units | Conditions                                                                                           |
|--------------|---------|--------------------------------------------------------|-------------------|------|------|------|-------|------------------------------------------------------------------------------------------------------|
| OS06         | Twarm   | Internal Oscillator Switch when running <sup>(3)</sup> |                   |      | _    | 2    | Tosc  | Slowest clock                                                                                        |
| OS07         | Tsc     | Fail-Safe Sample Clock<br>Period <sup>(1)</sup>        | —                 | _    | 21   | _    | ms    | LFINTOSC/64                                                                                          |
| OS08         | HFosc   | Internal Calibrated                                    | ±1%               | 7.92 | 8.0  | 8.08 | MHz   | VDD = 3.5V, 25°C                                                                                     |
|              |         | HFINTOSC Frequency <sup>(2)</sup>                      | ±2%               | 7.84 | 8.0  | 8.16 | MHz   | 2.5V ≤ VDD ≤ 5.5V,<br>0°C ≤ Ta ≤ +85°C                                                               |
|              |         |                                                        | ±5%               | 7.60 | 8.0  | 8.40 | MHz   | $2.0V \le VDD \le 5.5V,$<br>-40°C $\le$ TA $\le$ +85°C (Ind.),<br>-40°C $\le$ TA $\le$ +125°C (Ext.) |
| OS09*        | LFosc   | Internal Uncalibrated<br>LFINTOSC Frequency            | —                 | 153  | 14   | 5    | kHz   |                                                                                                      |
| OS10*        | TIOSCST | HFINTOSC Oscillator                                    | _                 | 5.5  | 12   | 24   | μsV   | DD = 2.0V, -40°C to +85°C                                                                            |
|              |         | Wake-up from Sleep                                     | —3                | .5   | 7    | 14   | μsV   | DD = 3.0V, -40°C to +85°C                                                                            |
|              |         | Start-up Time                                          | —3                |      | 6    | 11   | μsV   | DD = 5.0V, -40°C to +85°C                                                                            |

-....

> \* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

- Note 1: Instruction cycle period (TCY) 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 the OSC1 pin. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices.
  - 2: To ensure these oscillator frequency tolerances, VDD and Vss 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.
  - 3: By design.



### TABLE 15-3: CLKOUT AND I/O TIMING PARAMETERS

|              |          | Conditions (unless otherwise stated) re -40°C $\leq$ TA $\leq$ +125°C |               |          |          |       |                          |
|--------------|----------|-----------------------------------------------------------------------|---------------|----------|----------|-------|--------------------------|
| Param<br>No. | Sym      | Characteristic                                                        | Min           | Тур†     | Max      | Units | Conditions               |
| OS11         | TosH2ckL | Fosc↑ to CLKOUT↓ <sup>(1)</sup>                                       | —             | _        | 70       | ns    | VDD = 5.0V               |
| OS12         | TosH2cкH | Fosc↑ to CLKOUT↑ <sup>(1)</sup>                                       |               | _        | 72       | ns    | VDD = 5.0V               |
| OS13         | TckL2I0V | CLKOUT↓ to Port out valid <sup>(1)</sup> —                            |               | _        | 20       | ns    |                          |
| OS14         | ТюV2скН  | Port input valid before CLKOUT↑ <sup>(1)</sup>                        | Tosc + 200 ns | _        |          | ns    |                          |
| OS15*        | TosH2IoV | Fosc↑ (Q1 cycle) to Port out valid                                    |               | 50       | 70       | ns    | VDD = 5.0V               |
| OS16         | TosH2iol | Fosc <sup>↑</sup> (Q2 cycle) to Port input invalid (I/O in hold time) | 50            |          |          | ns    | VDD = 5.0V               |
| OS17         | TioV2osH | Port input valid to Fosc1 (Q2 cycle) (I/O in setup time)              | 20            | _        |          | ns    |                          |
| OS18         | TIOR     | Port output rise time <sup>(2)</sup>                                  |               | 40<br>15 | 72<br>32 | ns    | VDD = 2.0V<br>VDD = 5.0V |
| OS19         | TIOF     | Port output fall time <sup>(2)</sup>                                  |               | 28<br>15 | 55<br>30 | ns    | VDD = 2.0V<br>VDD = 5.0V |
| OS20*        | TINP     | INT pin input high or low time                                        | 25            |          | _        | ns    |                          |
| OS21*        | Trap     | PORTA interrupt-on-change new input level time                        | Тсү           |          |          | ns    |                          |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated.

Note 1: Measurements are taken in RC mode where CLKOUT output is 4 x Tosc.

2: Includes OSC2 in CLKOUT mode.



# FIGURE 15-7: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING





## TABLE 15-4:RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER<br/>AND BROWN-OUT RESET PARAMETERS

|              |       | ting Conditions (unless otherwi<br>erature -40°C ≤ TA ≤ +125°C | se state | ed)      |          |          |                                      |
|--------------|-------|----------------------------------------------------------------|----------|----------|----------|----------|--------------------------------------|
| Param<br>No. | Sym   | Characteristic                                                 | Min      | Тур†     | Max      | Units    | Conditions                           |
| 30           | TMCL  | MCLR Pulse Width (low)                                         | 2<br>5   |          |          | μs<br>μs | VDD = 5V, -40°C to +85°C<br>VDD = 5V |
| 31           | Twdt  | Watchdog Timer Time-out<br>Period (No Prescaler)               | 10<br>10 | 16<br>16 | 29<br>31 | ms<br>ms | VDD = 5V, -40°C to +85°C<br>VDD = 5V |
| 32           | Tost  | Oscillation Start-up Timer<br>Period <sup>(1, 2)</sup>         |          | 1024     | —        | Tosc     | (NOTE 3)                             |
| 33*          | TPWRT | Power-up Timer Period                                          | 40       | 65       | 140      | ms       |                                      |
| 34*          | Tioz  | I/O High-impedance from<br>MCLR Low or Watchdog Timer<br>Reset | _        | _        | 2.0      | μs       |                                      |
| 35           | VBOR  | Brown-out Reset Voltage                                        | 2.0      | _        | 2.2      | V        | (NOTE 4)                             |
| 36*          | VHYST | Brown-out Reset Hysteresis                                     | _        | 50       | —        | mV       |                                      |
| 37*          | TBOR  | Brown-out Reset Minimum<br>Detection Period                    | 100      | —        | —        | μsV      | $DD \leq VBOR$                       |

These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

- 2: By design.
- **3:** Period of the slower clock.
- 4: To ensure these voltage tolerances, VDD and VSS must be capacitively decoupled as dose to the device as possible. 0.1  $\mu$ F and 0.01  $\mu$ F values in parallel are recommended.

**Note 1:** Instruction cycle period (TcY) 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 the OSC1 pin. When an external clock input is used, the "max" cycle time limit is "DC" (no clock) for all devices.

#### **FIGURE 15-9:** TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS



#### TABLE 15-5: TIMER0 AND TIMER1 EXTERNAL CLOCK REQUIREMENTS

| Param<br>No. | Sym       |                           | Characteristic                                              |                | Min          | Тур†   | Max  | Units | Conditions                         |
|--------------|-----------|---------------------------|-------------------------------------------------------------|----------------|--------------|--------|------|-------|------------------------------------|
| 40*          | T⊤0H      | T0CKI High F              | Pulse Width                                                 | No Prescaler   | 0.5 Tcy + 20 | —      | _    | ns    |                                    |
|              |           |                           |                                                             | With Prescaler | 10           | —      | _    | ns    |                                    |
| 41*          | TT0L      | T0CKI Low F               | ulse Width                                                  | No Prescaler   | 0.5 TCY + 20 | —      | _    | ns    |                                    |
|              |           |                           |                                                             | With Prescaler | 10           | —      | _    | ns    |                                    |
| 42*          | Тт0Р      | T0CKI Period              | 1                                                           | I              |              | —      | —    | ns    | N = prescale value<br>(2, 4,, 256) |
| 45*          | TT1H      | T1CKI High                | Synchronous,                                                | No Prescaler   | 0.5 TCY + 20 | —      | _    | ns    |                                    |
|              |           | Time                      | Synchronous, with Prescaler                                 |                | 15           | —      | _    | ns    |                                    |
|              |           |                           | Asynchronous                                                |                | 30           | —      |      | ns    |                                    |
| 46*          | TT1L      | T1CKI Low                 | Synchronous,                                                | No Prescaler   | 0.5 TCY + 20 | —      | _    | ns    |                                    |
|              |           | Time                      | Synchronous,<br>with Prescaler                              |                | 15           | —      | _    | ns    |                                    |
|              |           |                           | Asynchronous                                                |                | 30           | —      | _    | ns    |                                    |
| 47*          | TT1P      | T1CKI Input<br>Period     | Synchronous                                                 | ynchronous     |              | —      | _    | ns    | N = prescale value<br>(1, 2, 4, 8) |
|              |           |                           | Asynchronous                                                |                | 60           | —      | _    | ns    |                                    |
| 48           | FT1       |                           | ator Input Frequency Range<br>abled by setting bit T1OSCEN) |                | _            | 32.768 |      | kHz   |                                    |
| 49*          | TCKEZTMR1 | Delay from E<br>Increment | xternal Clock Edge to Timer                                 |                | 2 Tosc       | —7     | Tosc | —     | Timers in Sync<br>mode             |

Standard Operating Conditions (unless otherwise stated)

These parameters are characterized but not tested.

t Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

#### **COMPARATOR SPECIFICATIONS** TABLE 15-6:

| I |                 |                 |                           |  |
|---|-----------------|-----------------|---------------------------|--|
| I | Ctondord Oneret | in a Conditione | (unless otherwise stated) |  |
| I | Standard Oberat | ina Conditions  | (unless otherwise stated) |  |
|   |                 |                 |                           |  |

|              | Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |                                           |         |     |       |           |       |               |  |  |
|--------------|---------------------------------------------------------------|-------------------------------------------|---------|-----|-------|-----------|-------|---------------|--|--|
| Param<br>No. | Sym                                                           | Characteristics                           |         | Min | Тур†  | Max       | Units | Comments      |  |  |
| CM01         | Vos                                                           | Input Offset Voltage                      |         | —   | ± 5.0 | ± 10      | mV    | (Vdd - 1.5)/2 |  |  |
| CM02         | Vсм                                                           | Input Common Mode Voltage                 |         | 0   |       | Vdd - 1.5 | V     |               |  |  |
| CM03*        | CMRR                                                          | Common Mode Rejection Ratio               |         | +55 |       |           | dB    |               |  |  |
| CM04*        | Trt                                                           | Response Time                             | Falling |     | 150   | 600       | ns    | (NOTE 1)      |  |  |
|              |                                                               |                                           | Rising  | —   | 200   | 1000      | ns    |               |  |  |
| CM05*        | Тмc2coV                                                       | Comparator Mode Change to<br>Output Valid |         |     |       | 10        | μs    |               |  |  |

These parameters are characterized but not tested.

Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and † are not tested.

Note 1: Response time is measured with one comparator input at (VDD - 1.5)/2- 100m V to (VDD - 1.5)/2 + 20 mV.

#### TABLE 15-7: **COMPARATOR VOLTAGE REFERENCE (CVREF) SPECIFICATIONS**

| Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |                              |                                                                                                                                                                                                            |                                                                                                                                                                                                          |                                                                                                                                                                                              |                                                                                                                                                               |                                                                                                                                                                                                      |  |  |  |
|----------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sym                                                                                                                  | Characteristics              | Min                                                                                                                                                                                                        | Тур†                                                                                                                                                                                                     | Мах                                                                                                                                                                                          | Units                                                                                                                                                         | Comments                                                                                                                                                                                             |  |  |  |
| CLSB                                                                                                                 | Step Size <sup>(2)</sup>     | _                                                                                                                                                                                                          | Vdd/24<br>Vdd/32                                                                                                                                                                                         |                                                                                                                                                                                              | V<br>V                                                                                                                                                        | Low Range (VRR = 1)<br>High Range (VRR = 0)                                                                                                                                                          |  |  |  |
| CACC                                                                                                                 | Absolute Accuracy            | _                                                                                                                                                                                                          |                                                                                                                                                                                                          | ± 1/2<br>± 1/2                                                                                                                                                                               | LSb<br>LSb                                                                                                                                                    | Low Range (VRR = 1)<br>High Range (VRR = 0)                                                                                                                                                          |  |  |  |
| CR                                                                                                                   | Unit Resistor Value (R)      | _                                                                                                                                                                                                          | 2k                                                                                                                                                                                                       | _                                                                                                                                                                                            | Ω                                                                                                                                                             |                                                                                                                                                                                                      |  |  |  |
| CST                                                                                                                  | Settling Time <sup>(1)</sup> |                                                                                                                                                                                                            |                                                                                                                                                                                                          | 10                                                                                                                                                                                           | μs                                                                                                                                                            |                                                                                                                                                                                                      |  |  |  |
|                                                                                                                      | Sym<br>CLSB<br>CACC<br>CR    | Sym         Characteristics           CLSB         Step Size <sup>(2)</sup> CACC         Absolute Accuracy           CR         Unit Resistor Value (R)           CST         Settling Time <sup>(1)</sup> | Sym     Characteristics     Min       CLSB     Step Size <sup>(2)</sup> —       CACC     Absolute Accuracy     —       CR     Unit Resistor Value (R)     —       CST     Settling Time <sup>(1)</sup> — | Sym     Characteristics     Min     Typ†       CLSB     Step Size <sup>(2)</sup> —     VDD/24       CACC     Absolute Accuracy     —     —       CR     Unit Resistor Value (R)     —     2k | SymCharacteristicsMinTyp†MaxCLSBStep Size <sup>(2)</sup> —VDD/24—CACCAbsolute Accuracy——± 1/2CRUnit Resistor Value (R)—2k—CSTSettling Time <sup>(1)</sup> —10 | SymCharacteristicsMinTyp†MaxUnitsCLSBStep Size <sup>(2)</sup> —VVDD/24—VCACCAbsolute Accuracy—— $ \frac{1}{2}$ LSbCRUnit Resistor Value (R)—2k— $\Omega$ CSTSettling Time <sup>(1)</sup> —10 $\mu$ s |  |  |  |

These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: Settling time measured while VRR = 1 and VR<3:0> transitions from '0000' to '1111'.

2: See Section 7.11 "Comparator Voltage Reference" for more information.

#### TABLE 15-8: PIC12F635/PIC16F636 PLVD CHARACTERISTICS:

| DC CHARACTERISTICS |               |                 | Operating T | Standard Operating Conditions (unless otherwise stated)Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ Operating VoltageVDD Range 2.0V-5.5V |       |            |                         |  |  |  |
|--------------------|---------------|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------|-------------------------|--|--|--|
| Sym.               | C             | Min             | Тур†        | Max                                                                                                                                                       | Units | Conditions |                         |  |  |  |
| Vplvd              | PLVD          | LVDL<2:0> = 001 | 1.900       | 2.0                                                                                                                                                       | 2.125 | V          |                         |  |  |  |
|                    | Voltage       | LVDL<2:0> = 010 | 2.000       | 2.1                                                                                                                                                       | 2.225 | V          |                         |  |  |  |
|                    |               | LVDL<2:0> = 011 | 2.100       | 2.2                                                                                                                                                       | 2.325 | V          |                         |  |  |  |
|                    |               | LVDL<2:0> = 100 | 2.200       | 2.3                                                                                                                                                       | 2.425 | V          |                         |  |  |  |
|                    |               | LVDL<2:0> = 101 | 3.825       | 4.0                                                                                                                                                       | 4.200 | V          |                         |  |  |  |
|                    |               | LVDL<2:0> = 110 | 4.025       | 4.2                                                                                                                                                       | 4.400 | V          |                         |  |  |  |
|                    |               | LVDL<2:0> = 111 | 4.325       | 4.5                                                                                                                                                       | 4.700 | V          |                         |  |  |  |
| *TPLVDS            | PLVD Settling | g time          | -           | 50<br>25                                                                                                                                                  | —     | μsV        | DD = 5.0V<br>VDD = 3.0V |  |  |  |

These parameters are characterized but not tested

Data in 'Typ' column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

†

#### TABLE 15-9: PIC16F639 PLVD CHARACTERISTICS:

|         |                     |                 | Operating T | Standard Operating Conditions (unless otherwise stated)Operating Temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ Operating VoltageVDD Range 2.0V-5.5V |       |       |            |  |  |  |
|---------|---------------------|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|------------|--|--|--|
| Sym.    | Sym. Characteristic |                 | Min         | Тур†                                                                                                                                                     | Max   | Units | Conditions |  |  |  |
| Vplvd   | PLVD                | LVDL<2:0> = 001 | 1.900       | 2.0                                                                                                                                                      | 2.100 | V     |            |  |  |  |
|         | Voltage             | LVDL<2:0> = 010 | 2.000       | 2.1                                                                                                                                                      | 2.200 | V     |            |  |  |  |
|         |                     | LVDL<2:0> = 011 | 2.100       | 2.2                                                                                                                                                      | 2.300 | V     |            |  |  |  |
|         |                     | LVDL<2:0> = 100 | 2.200       | 2.3                                                                                                                                                      | 2.400 | V     |            |  |  |  |
|         |                     | LVDL<2:0> = 101 | 3.825       | 4.0                                                                                                                                                      | 4.175 | V     |            |  |  |  |
|         |                     | LVDL<2:0> = 110 | 4.025       | 4.2                                                                                                                                                      | 4.375 | V     |            |  |  |  |
|         |                     | LVDL<2:0> = 111 | 4.325       | 4.5                                                                                                                                                      | 4.675 | V     |            |  |  |  |
| *TPLVDS | PLVD Settling       | time            | _           | 50                                                                                                                                                       | _     | μsV   | DD = 5.0V  |  |  |  |
|         |                     |                 |             | 25                                                                                                                                                       |       |       | VDD = 3.0V |  |  |  |

\* These parameters are characterized but not tested

† Data in "Typ" column is at 5.0V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

| AC CHA       | ARACTERIS | STICS                                                                        | Standard C<br>Supply Volt<br>Operating t<br>LC Signal I<br>Carrier Free<br>LCCOM co | age<br>emperatu<br>nput<br>quency | re                   | 2.0V ≤ VD<br>-40°C ≤ TA | t <b>herwise stated)</b><br>D ≤ 3.6V<br>MB ≤ +85°C for industrial<br>I 300 mVPP                                                                                                                                                     |
|--------------|-----------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------|----------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param<br>No. | Sym.      | Characteristic                                                               | Min                                                                                 | Тур†                              | Max                  | Units                   | Conditions                                                                                                                                                                                                                          |
| AF01         | VSENSE    | LC Input Sensitivity                                                         | 13                                                                                  | .0                                | 6                    | тVрр                    | VDD = 3.0V<br>Output enable filter disabled<br>AGCSIG = 0; MODMIN = 00<br>(33% modulation depth setting)<br>Input = Continuous Wave (CW)<br>Output = Logic level transition from low-to-<br>high at sensitivity level for CW input. |
| AF02         | Vde_q     | Coil de-Q'ing Voltage -<br>RF Limiter (RFLM) must be active                  | 3—                                                                                  |                                   | 5                    | V                       | VDD = 3.0V, Force IIN = 5 $\mu$ A                                                                                                                                                                                                   |
| AF03         | Rflm      | RF Limiter Turn-on Resistance<br>(LCX, LCY, LCZ)                             | -                                                                                   | 300                               | 700                  | Ohm                     | VDD = 2.0V, VIN = 8 VDC                                                                                                                                                                                                             |
| AF04         | Sadj      | Sensitivity Reduction                                                        |                                                                                     | 0<br>-30                          |                      | dB<br>dB                | VDD = 3.0V<br>No sensitivity reduction selected<br>Max reduction selected<br>Monotonic increment in attenuation value from<br>setting = 0000 to 1111 by design                                                                      |
| AF05         | VIN_MOD   | Minimum Modulation Depth<br>75% ± 12%<br>50% ± 12%<br>25% ± 12%<br>12% ± 12% | 63<br>38<br>13<br>0                                                                 | 75<br>50<br>25<br>12              | 87<br>62<br>37<br>24 | %<br>%<br>%             | VDD = 3.0V                                                                                                                                                                                                                          |
| AF06         | CTUNX     | LCX Tuning Capacitor                                                         | _                                                                                   | 0                                 | _                    | pF                      | VDD = 3.0V,<br>Config. Reg. 1, bits <6:1> Setting = 000000                                                                                                                                                                          |
|              |           |                                                                              | 44                                                                                  | 63                                | 82                   | pF                      | 63 pF +/- 30%<br>Config. Reg. 1, bits <6:1> Setting = 111111<br>63 steps, 1 pF/step<br>Monotonic increment in capacitor value from<br>setting = 000000 to 111111 by design                                                          |
| AF07         | CTUNY     | LCY Tuning Capacitor                                                         | _                                                                                   | 0                                 | _                    | pF                      | VDD = 3.0V,<br>Config. Reg. 2, bits <6:1> Setting = 000000                                                                                                                                                                          |
|              |           |                                                                              | 44                                                                                  | 63                                | 82                   | pF                      | 63 pF +/- 30%<br>Config. Reg. 2, bits <6:1> Setting = 111111<br>63 steps, 1 pF/step<br>Monctonic increment in capacitor value from<br>setting = 000000 to 111111 by design                                                          |
| AF08         | CTUNZ     | LCZ Tuning Capacitor                                                         | _                                                                                   | 0                                 | _                    | pF                      | VDD = 3.0V,<br>Config. Reg. 3, bits<6:1> Setting = 000000                                                                                                                                                                           |
|              |           |                                                                              | 44                                                                                  | 63                                | 82                   | pF                      | 63 pF +/- 30%<br>Config. Reg. 3, bits<6:1> Setting = 111111<br>63 steps, 1 pF/step<br>Monotonic increment in capacitor value from<br>setting = 000000 to 111111 by design                                                           |
| AF09         | FCARRIER  | Carrier frequency                                                            | _                                                                                   | 125                               | _                    | kHz                     | Characterized at bench.                                                                                                                                                                                                             |
| AF10         | FMOD      | Input modulation frequency                                                   | _                                                                                   | _                                 | 10                   | kHz                     | Input data rate, characterized at bench.                                                                                                                                                                                            |
| AF11         | C_Q       | Q of Trimming Capacitors                                                     | 50*                                                                                 | —                                 | _                    | pF                      | Characterized at bench test                                                                                                                                                                                                         |
| AF12         | Tdr       | Demodulator Charge Time<br>(delay time of demodulated output<br>to rise)     | —5                                                                                  | 0                                 |                      | μsV                     | DD = 3.0V<br>MOD depth setting = 50%<br>Input conditions:<br>Amplitude = 300 mVPP<br>Modulation depth = 80%                                                                                                                         |
| AF13         | Tdf       | Demodulator Discharge Time<br>(delay time of demodulated output<br>to fall)  | —5                                                                                  | 0                                 | _                    | μsV                     | DD = 3.0V<br>MOD depth setting = 50%<br>Input conditions:<br>Amplitude = 300 mVPP<br>Modulation depth = 80%                                                                                                                         |

### 15.11 AC Characteristics: Analog Front-End for PIC16F639 (Industrial)

Parameter is 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. Required output enable filter high time must account for input path analog delays (= **Тоен** - TDR + TDF). Required output enable filter low time must account for input path analog delays (= **ToeL** + TDR - TDF). t

Note 1:

2:

### 15.11 AC Characteristics: Analog Front-End for PIC16F639 (Industrial) (Continued)

| AC CH        | ARACTERIS | STICS                                                                                                                               | Standard O<br>Supply Volta<br>Operating te<br>LC Signal Ir<br>Carrier Freq<br>LCCOM cor | age<br>emperatu<br>put<br>juency | re   | as (unless otherwise stated)<br>2.0V ≤ VDD ≤ 3.6V<br>-40°C ≤ TAMB ≤ +85°C for industrial<br>Sinusoidal 300 mVPP<br>125 kHz |                                                                |  |  |
|--------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|----------------------------------|------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--|--|
| Param<br>No. | Sym.      | Characteristic                                                                                                                      | Min                                                                                     | Тур†                             | Max  | Units                                                                                                                      | Conditions                                                     |  |  |
| AF14         | TlfdataR  | Rise time of LFDATA                                                                                                                 | _                                                                                       | 0.5                              |      | μs                                                                                                                         | VDD = 3.0V<br>Time is measured from 10% to 90% of<br>amplitude |  |  |
| AF15         | TlfdataF  | Fall time of LFDATA                                                                                                                 | -                                                                                       | 0.5                              | _    | μsV                                                                                                                        | DD = 3.0V<br>Time is measured from 10% to 90% of<br>amplitude  |  |  |
| AF16         | TAGC      | AGC initialization time                                                                                                             | _                                                                                       | 3.5*                             | _    | ms                                                                                                                         | Time required for AGC stabilization                            |  |  |
| AF17         | TPAGC     | High time after AGC settling time                                                                                                   | _                                                                                       | 62.5                             | _    | μs                                                                                                                         | Equivalent to two Internal clock cycle (Fosc)                  |  |  |
| AF18         | Тѕтав     | AGC stabilization time plus high<br>time (after AGC settling time)<br>(TAGC +T PAGC)                                                | 4                                                                                       | _                                |      | ms                                                                                                                         | AGC stabilization time                                         |  |  |
| AF19         | TGAP      | Gap time after AGC settling time                                                                                                    | 200                                                                                     | _                                |      | μs                                                                                                                         | Typically 1 Te                                                 |  |  |
| AF20         | Trdy      | Time from exiting Sleep or POR to being ready to receive signal                                                                     |                                                                                         |                                  | 50*  | ms                                                                                                                         |                                                                |  |  |
| AF21         | TPRES     | Minimum time AGC level must be<br>held after receiving AGC Preserve<br>command                                                      | 5*                                                                                      | _                                | —    | ms                                                                                                                         | AGC level must not change more than 10% during TPRES.          |  |  |
| AF22         | Fosc      | Internal RC oscillator frequency (±10%)                                                                                             | 28.8                                                                                    | 32                               | 35.2 | kHz                                                                                                                        | Internal clock trimmed at 32 kHz during test                   |  |  |
| AF23         | TINACT    | Inactivity timer time-out                                                                                                           | 14.4                                                                                    | 16                               | 17.6 | ms                                                                                                                         | 512 cycles of RC oscillator @ Fosc                             |  |  |
| AF24         | TALARM    | Alarm timer time-out                                                                                                                | 28.8                                                                                    | 32                               | 35.2 | ms                                                                                                                         | 1024 cycles of RC oscillator @ Fosc                            |  |  |
| AF25         | RLC       | LC Pin Input Impedance<br>LCX, LCY, LCZ                                                                                             | _                                                                                       | 1*                               | _    | MOhm                                                                                                                       | Device in Standby mode                                         |  |  |
| AF26         | CIN       | LC Pin Input Capacitance<br>LCX, LCY, LCZ                                                                                           | _                                                                                       | 24                               |      | pF                                                                                                                         | LCCOM grounded. Vdd = 3.0V,<br>FCARRIER = 125 kHz              |  |  |
| AF27         | TE        | Time element of pulse                                                                                                               | 100                                                                                     | _                                | -    | μs                                                                                                                         |                                                                |  |  |
| AF28         | Тоен      | Minimum output enable filter high<br>time<br>OEH (Bits Config0<7:6>)<br>01 = 1 ms<br>10 = 2 ms<br>11 = 4 ms<br>00 = Filter Disabled | 32 (~1ms)<br>64 (~2ms)<br>128 (~4ms)<br>—                                               |                                  |      | clock<br>count                                                                                                             | RC oscillator = Fosc<br>Viewed from the pin input:<br>(Note 1) |  |  |
| AF29         | TOEL      | Minimum output enable filter low<br>time<br>OEL (Bits Config0<5:4>)<br>00 = 1 ms<br>01 = 1 ms<br>10 = 2 ms<br>11 = 4 ms             | 32 (~1ms)<br>32 (~1ms)<br>64 (~2ms)<br>128 (~4ms)                                       |                                  |      | clock<br>count                                                                                                             | RC oscillator = Fosc<br>Viewed from the pin input:<br>(Note 2) |  |  |

\* Parameter is 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: Required output enable filter high time must account for input path analog delays (= ТОЕН - TDR + TDF).
 2: Required output enable filter low time must account for input path analog delays (= TOEL + TDR - TDF).

#### AC Characteristics: Analog Front-End for PIC16F639 (hdustrial) (Continued) 15.11

| AC CHARACTERISTICS |         |                                                        | Standard Operating Conditions (unless otherwise stated)Supply Voltage2.0V ≤ VDD ≤ 3.6VOperating temperature-40°C ≤ TAMB ≤ +85°C for industrialLC Signal InputSinusoidal 300 mVPPCarrier Frequency125 kHzLCCOM connected to Vss |                |                                                                                                                                                                     |                | D ≤ 3.6V<br>MB ≤ +85°C for industrial                                                                                                                                                                                                                               |
|--------------------|---------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Param<br>No.       | Sym.    | Characteristic                                         | Min                                                                                                                                                                                                                            | Тур†           | Мах                                                                                                                                                                 | Units          | Conditions                                                                                                                                                                                                                                                          |
| AF30               | ΤΟΕΤ    | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ |                                                                                                                                                                                                                                |                | 96 (-3ms)<br>96 (-3ms)<br>128 (-4ms)<br>192 (-6ms)<br>128 (-4ms)<br>128 (-4ms)<br>160 (-5ms)<br>250 (-8ms)<br>192 (-6ms)<br>192 (-6ms)<br>256 (-8ms)<br>320 (-10ms) | clock<br>count | RC oscillator = Fosc                                                                                                                                                                                                                                                |
|                    |         | 00 XX = Filter Disabled                                | —                                                                                                                                                                                                                              | —              | —                                                                                                                                                                   |                | LFDATA output appears as long as input<br>signal level is greater than VSENSE.                                                                                                                                                                                      |
| AF31               | IRSSI   | RSSI current output                                    | _                                                                                                                                                                                                                              | 100            | _                                                                                                                                                                   | μΑ             | $\label{eq:VDD} \begin{array}{l} V\text{DD}=3.0\text{V},\\ \text{VIN}=0 \text{ to } 4 \text{ VPP}\\ \text{Linearly increases with input signal amplitude}.\\ \hline \text{Tested at VIN}=40 \text{ mVPP}, 400 \text{ mVPP}, \text{ and}\\ 4\text{V PP} \end{array}$ |
|                    |         |                                                        |                                                                                                                                                                                                                                | 1<br>10<br>100 |                                                                                                                                                                     | μΑ<br>μΑ<br>μΑ | VIN = 40 mVPP<br>VIN = 400 mVPP<br>VIN = 4 VPP                                                                                                                                                                                                                      |
| AF32               | IrssiLR | RSSI current linearity                                 | -15                                                                                                                                                                                                                            | —              | 15                                                                                                                                                                  | %              | Tested at room temperature only                                                                                                                                                                                                                                     |

Parameter is 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. Required output enable filter high time must account for input path analog delays (= **Тоен** - TDR + TDF). Required output enable filter low time must account for input path analog delays (= **ToeL** + TDR - TDF). t

Note 1: 2:

### 15.12 SPI Timing: Analog Front-End (AFE) for PIC16F639

| AC CHARACTERISTICS |                          |                                                                                                           | Standard Operating Conditions (unless otherwise stated) |      |                                                                                                          |       |                                                           |  |
|--------------------|--------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------|----------------------------------------------------------------------------------------------------------|-------|-----------------------------------------------------------|--|
|                    |                          | Supply Voltage<br>Operating temperature<br>LC Signal Input<br>Carrier Frequency<br>LCCOM connected to Vss |                                                         |      | $2.0V \le VDD \le 3.6V$<br>-40°C $\le$ TAMB $\le$ +85°C for industrial<br>Sinusoidal 300 mVPP<br>125 kHz |       |                                                           |  |
| Param              | Param Sym Characteristic |                                                                                                           | Min                                                     | Тур† | Max                                                                                                      | Units | Conditions                                                |  |
| AF33               | FSCLK                    | SCLK Frequency                                                                                            | —                                                       | —    | 3                                                                                                        | MHz   |                                                           |  |
| AF34               | Tcssc                    | CS fall to first SCLK edge setup time                                                                     | 100                                                     | _    | _                                                                                                        | ns    |                                                           |  |
| AF35               | Tsu                      | SDI setup time                                                                                            | 30                                                      | _    | —                                                                                                        | ns    |                                                           |  |
| AF36               | THD                      | SDI hold time                                                                                             | 50                                                      | —    | _                                                                                                        | ns    |                                                           |  |
| AF37               | Тні                      | SCLK high time                                                                                            | 150                                                     | —    |                                                                                                          | ns    |                                                           |  |
| AF38               | Tlo                      | SCLK low time                                                                                             | 150                                                     | _    | —                                                                                                        | ns    |                                                           |  |
| AF39               | TDO                      | SDO setup time                                                                                            | —                                                       | —    | 150                                                                                                      | ns    |                                                           |  |
| AF40               | Tsccs                    | SCLK last edge to $\overline{\text{CS}}$ rise setup time                                                  | 100                                                     | —    | —                                                                                                        | ns    |                                                           |  |
| AF41               | Тсѕн                     | CS high time                                                                                              | 500                                                     | —    | _                                                                                                        | ns    |                                                           |  |
| AF42               | Tcs1                     | CS rise to SCLK edge setup time                                                                           | 50                                                      | —    | —                                                                                                        | ns    |                                                           |  |
| AF43               | Tcs0                     | SCLK edge to $\overline{CS}$ fall setup time                                                              | 50                                                      | —    | —                                                                                                        | ns    | SCLK edge when $\overline{CS}$ is high                    |  |
| AF44               | TSPIR                    | Rise time of SPI data<br>(SPI Read command)                                                               | —                                                       | 10   | —                                                                                                        | ns    | VDD = 3.0V. Time is measured from 10% to 90% of amplitude |  |
| AF45               | TSPIF                    | Fall time of SPI data<br>(SPI Read command)                                                               | —1                                                      | 0    | _                                                                                                        | ns    | VDD = 3.0V. Time is measured from 90% to 10% of amplitude |  |

\* Parameter is 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.

## 16.0 DC AND AC CHARACTERISTICS GRAPHS AND TABLES

The graphs and tables provided in this section are for design guidance and are not tested.

In some graphs or t ables, the data presented are **outside specified operating range** (i.e., outside specified VDD range). This is for **information only** and devices are ensured to operate properly only within the specified range.

**Note:** The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the da ta presented may be ou tside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range.

"Typical" r epresents t he me an of t he d istribution at 25°C. "Maximum" or "mi nimum" r epresents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where  $\sigma$  is a standard deviation, over each temperature range.

















FIGURE 16-5: TYPICAL IDD vs. VDD OVER Fosc (XT MODE)









FIGURE 16-7: TYPICAL IDD vs. VDD OVER FOSC (EXTRC MODE)























FIGURE 16-12: MAXIMUM IDD vs. Fosc QVER VDD (HFINTOSC MODE)



#### FIGURE 16-14: MAXIMUM IPD vs. VDD (SLEEP MODE, ALL PERIPHERALS DISABLED)











FIGURE 16-16: BOR IPD vs. VDD OVER TEMPERATURE











Temperature (°C)

85°C

125°C

FIGURE 16-21: CVREF IPD vs. VDD OVER\_TEMPERATURE (HIGH RANGE)

25°C



10

-40°C







FIGURE 16-23: Vol vs. IoL OVER TEMPERATURE (VDD = 3.0V)







FIGURE 16-25: VOH vs. IOH OVER TEMPERATURE (VDD = 3.0V)



FIGURE 16-27: TTL INPUT THRESHOLD VIN vs. VDD OVER TEMPERATURE



FIGURE 16-26: VOH vs. IOH OVER TEMPERATURE (VDD = 5.0V)





















#### FIGURE 16-34: MAXIMUM HFINTOSC START-UP TIMES vs. VDD OVER TEMPERATURE











FIGURE 16-37: TYPICAL HFINTOSC FREQUENCY CHANGE OVER DEVICE VDD (85°C)











## **17.0 PACKAGING INFORMATION**

### 17.1 Package Marking Information

#### 8-Lead PDIP



8-Lead SOIC

|--|

8-Lead DFN (4x4x0.9 mm)



8-Lead DFN-S (6x5 mm)



Example



Example



Example



Example



| Legend | : XXX<br>Y<br>YY<br>WW<br>NNN<br>@3<br>*                                                                                                                                                                          | Customer-specific information<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code<br>Pb-free JEDEC designator for Matte Tin (Sn)<br>This package is Pb-free. The Pb-free JEDEC designator (e3)<br>can be found on the outer packaging for this package. |  |  |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Note:  | In the event the full Microchip part number cannot be marked on one line, it will<br>be carried o ver to t he next line, t hus I imiting the number of available<br>characters for customer-specific information. |                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |

\* Standard PIC device marking consists of Microchip part number, year code, week code and traceability code. For PIC device marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price.

## 17.1 Package Marking Information (Continued)

14-Lead PDIP



14-Lead SOIC



14-Lead TSSOP



16-Lead QFN



### 20-Lead SSOP



Example



Example



Example



Example



### Example



### 17.2 Package Details

The following sections give the technical details of the packages.

#### 8-Lead Plastic Dual In-Line (P or PA) – 300 mil Body [PDIP]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                            | INCHES           |          |      |      |  |  |
|----------------------------|------------------|----------|------|------|--|--|
| Dimer                      | Dimension Limits |          |      | MAX  |  |  |
| Number of Pins             | Ν                |          | 8    |      |  |  |
| 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                | .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 §      | 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-018B

### 8-Lead Plastic Small Outline (SN or OA) – 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



|                          | Units            |          |   | MILLIMETERS |  |  |  |
|--------------------------|------------------|----------|---|-------------|--|--|--|
| Dimen                    | Dimension Limits |          |   | MAX         |  |  |  |
| Number of Pins           | N                | 8        |   |             |  |  |  |
| Pitch                    | е                | 1.27 BSC |   |             |  |  |  |
| Overall Height           | Α                | -        | - | 1.75        |  |  |  |
| Molded Package Thickness | A2               | 1.25     | - | -           |  |  |  |
| Standoff §               | A1               | 0.10     | - | 0.25        |  |  |  |
| Overall Width            | E                | 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 |   |             |  |  |  |
| Foot Angle               | φ                | 0°       | - | 8°          |  |  |  |
| Lead Thickness           | С                | 0.17     | _ | 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.
- 3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 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.

Microchip Technology Drawing C04-057B

### 8-Lead Plastic Dual Flat, No Lead Package (MD) – 4x4x0.9 mm Body [DFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                        | Units            |      | MILLIMETERS | 6    |
|------------------------|------------------|------|-------------|------|
|                        | Dimension Limits | MIN  | NOM         | MAX  |
| Number of Pins         | N                |      | 8           |      |
| Pitch                  | е                |      | 0.80 BSC    |      |
| Overall Height         | A                | 0.80 | 0.90        | 1.00 |
| Standoff A             | 1                | 0.00 | 0.02        | 0.05 |
| Contact Thickness      | A3               |      | 0.20 REF    | •    |
| Overall Length         | D                |      | 4.00 BSC    |      |
| Exposed Pad Width      | E2               | 0.00 | 2.20        | 2.80 |
| Overall Width          | E                |      | 4.00 BSC    | •    |
| Exposed Pad Length     | D2               | 0.00 | 3.00        | 3.60 |
| Contact Width          | b                | 0.25 | 0.30        | 0.35 |
| Contact Length         | L                | 0.30 | 0.55        | 0.65 |
| Contact-to-Exposed Pad | К                | 0.20 | -           | -    |

### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Package may have one or more exposed tie bars at ends.

3. Package is saw singulated.

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

Microchip Technology Drawing C04-131C

## 8-Lead Plastic Dual Flat, No Lead Package (MF) – 6x5 mm Body [DFN-S]

**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                  | e                |          | 1.27 BSC    |      |  |
| Overall Height         | А                | 0.80     | 0.85        | 1.00 |  |
| Standoff A             | 1                | 0.00     | 0.01        | 0.05 |  |
| Contact Thickness      | A3               | 0.20 REF |             |      |  |
| Overall Length         | D                | 5.00 BSC |             |      |  |
| Overall Width          | E                | 6.00 BSC |             |      |  |
| Exposed Pad Length     | D2               | 3.90     | 4.00        | 4.10 |  |
| Exposed Pad Width      | E2               | 2.20     | 2.30        | 2.40 |  |
| Contact Width          | b                | 0.35     | 0.40        | 0.48 |  |
| Contact Length         | L                | 0.50     | 0.60        | 0.75 |  |
| Contact-to-Exposed Pad | К                | 0.20 – – |             |      |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Package may have one or more exposed tie bars at ends.

3. Package is saw singulated.

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

Microchip Technology Drawing C04-122B

## 14-Lead Plastic Dual In-Line (P or PD) – 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   |      |
|----------------------------|----------|------|----------|------|
| Dimensio                   | n Limits | MIN  | NOM      | MAX  |
| Number of Pins             | Ν        |      | 14       |      |
| 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        | .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 or OD) – 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





|                          | Units            |          | MILLIMETERS | 6    |
|--------------------------|------------------|----------|-------------|------|
|                          | Dimension Limits | MIN      | NOM         | MAX  |
| Number of Pins           | N                |          | 14          |      |
| Pitch                    | e                |          | 1.27 BSC    |      |
| Overall Height           | A                | -        | -           | 1.75 |
| Molded Package Thickness | A2               | 1.25     | -           | -    |
| Standoff §               | A1               | 0.10     | -           | 0.25 |
| Overall Width            | E                | 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    |      |
| Foot Angle               | φ                | 0°       | -           | 8°   |
| Lead Thickness           | С                | 0.17     | -           | 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.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 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.

Microchip Technology Drawing C04-065B

### 14-Lead Plastic Thin Shrink Small Outline (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



|                          | Units                   |      | MILLIMETERS | 5    |
|--------------------------|-------------------------|------|-------------|------|
|                          | <b>Dimension Limits</b> | MIN  | NOM         | MAX  |
| Number of Pins           | N                       |      | 14          |      |
| Pitch                    | е                       |      | 0.65 BSC    |      |
| Overall Height           | A                       | -    | -           | 1.20 |
| Molded Package Thickness | A2                      | 0.80 | 1.00        | 1.05 |
| Standoff A               | 1                       | 0.05 | -           | 0.15 |
| Overall Width            | E                       |      | 6.40 BSC    |      |
| Molded Package Width     | E1                      | 4.30 | 4.40        | 4.50 |
| Molded Package Length    | D                       | 4.90 | 5.00        | 5.10 |
| Foot Length              | L                       | 0.45 | 0.60        | 0.75 |
| Footprint                | L1                      |      | 1.00 REF    |      |
| Foot Angle               | φ                       | 0°   | -           | 8°   |
| Lead Thickness           | С                       | 0.09 | -           | 0.20 |
| Lead Width               | b                       | 0.19 | -           | 0.30 |

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.15 mm 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-087B

## 16-Lead Plastic Quad Flat, No Lead Package (ML) – 4x4x0.9 mm Body [QFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                        | Units     |      | MILLIMETERS |      |  |
|------------------------|-----------|------|-------------|------|--|
| Dimensi                | on Limits | MIN  | NOM         | MAX  |  |
| Number of Pins         | Ν         |      | 16          |      |  |
| Pitch                  | е         |      | 0.65 BSC    |      |  |
| Overall Height         | А         | 0.80 | 0.90        | 1.00 |  |
| Standoff A             | 1         | 0.00 | 0.02        | 0.05 |  |
| Contact Thickness      | A3        |      | 0.20 REF    |      |  |
| Overall Width          | E         |      | 4.00 BSC    |      |  |
| Exposed Pad Width      | E2        | 2.50 | 2.65        | 2.80 |  |
| Overall Length         | D         |      | 4.00 BSC    |      |  |
| Exposed Pad Length     | D2        | 2.50 | 2.65        | 2.80 |  |
| Contact Width          | b         | 0.25 | 0.30        | 0.35 |  |
| Contact Length         | L         | 0.30 | 0.40        | 0.50 |  |
| Contact-to-Exposed Pad | К         | 0.20 | -           | -    |  |

### 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-127B

### 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 | 6    |
|--------------------------|---------------|------|-------------|------|
| Dim                      | ension Limits | MIN  | NOM         | MAX  |
| Number of Pins           | N             |      | 20          |      |
| Pitch                    | е             |      | 0.65 BSC    |      |
| Overall Height           | A             | -    | -           | 2.00 |
| Molded Package Thickness | A2            | 1.65 | 1.75        | 1.85 |
| Standoff A               | 1             | 0.05 | -           | -    |
| Overall Width            | E             | 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               | φ             | 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.20 mm 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-072B

NOTES:

# THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to m ake fi les an d i nformation e asily av ailable to customers. Accessible by using your favorite Internet browser, the w eb si te c ontains the following information:

- **Product Support** Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's c ustomer notification s ervice h elps keep customers current on Microchip products. Subscribers will r eceive e-mail notification w henever t here are changes, upd ates, rev isions or errat a related to a specified product family or development tool of interest.

To register, access t he Microchip w eb s ite a t www.microchip.com, c lick o n Customer C hange Notification and follow the registration instructions.

# **CUSTOMER SUPPORT**

Users of Microchip p roducts c an rec eive as sistance through several channels:

- Distributor or Representative
- Local Sales Office
- Field Application Engineer (FAE)
- Technical Support
- Development Systems Information Line

Customers sh ould con tact the ir dis tributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A lis ting of s ales offices and lo cations is included in the back of this document.

Technical support is available through the web site at: http://support.microchip.com

# READER RESPONSE

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150.

Please list the following information, and use this outline to provide us with your comments about this document.

| To:  | Technical Publications Manager          | Total Pages Sent                                       |
|------|-----------------------------------------|--------------------------------------------------------|
| RE:  | Reader Response                         |                                                        |
| Fron | n: Name                                 |                                                        |
|      |                                         |                                                        |
|      | Address                                 |                                                        |
|      | City / State / ZIP / Country            |                                                        |
|      |                                         | FAX: ()                                                |
| Appl | lication (optional):                    |                                                        |
| Wou  | Ild you like a reply?YN                 |                                                        |
| Devi | ice: LPIC12F635/PIC16F636/639           | rature Number: DS41232D                                |
| Que  | stions:                                 |                                                        |
| 1.   | What are the best features of this do   | cument?                                                |
|      |                                         |                                                        |
|      |                                         |                                                        |
| 2.   | How does this document meet your h      | nardware and software development needs?               |
| -    |                                         |                                                        |
|      |                                         |                                                        |
| 3.   | Do you find the organization of this d  | ocument easy to follow? If not, why?                   |
| -    |                                         |                                                        |
| -    |                                         |                                                        |
| 4.   | What additions to the document do y     | ou think would enhance the structure and subject?      |
|      |                                         |                                                        |
|      |                                         |                                                        |
| 5.   | what deletions from the document co     | buld be made without affecting the overall usefulness? |
| •    |                                         |                                                        |
| 6    | le there any incorrect or micloading is | of armation (what and whata)?                          |
| 6.   | Is there any incorrect or misleading in | normation (what and where)?                            |
|      |                                         |                                                        |
| 7.   | How would you improve this docume       | nt?                                                    |
|      |                                         |                                                        |
| -    |                                         |                                                        |
| -    |                                         |                                                        |

## APPENDIX A: DATA SHEET REVISION HISTORY

### **Revision A**

This is a new data sheet.

### **Revision B**

Added PIC16F639 to the data sheet.

### **Revision C (12/2006)**

Added C haracterization d ata; U pdated Package Drawings; Add ed C omparator V oltage R eference section.

### Revision D (03/2007)

Replaced Package D rawings (R ev. AM); R eplaced Development Support Section. Updated Product ID System.

NOTES:

# INDEX

| Α                                                                          |
|----------------------------------------------------------------------------|
| Absolute Maximum Ratings                                                   |
| AC Characteristics                                                         |
| Analog Front-End (AFE) for PIC16F639187                                    |
| Industrial and Extended179                                                 |
| Load Conditions 178                                                        |
| AGC Settling                                                               |
| Analog Front-End                                                           |
| Configuration Registers                                                    |
| Summary Table                                                              |
| Analog Front-End (AFE)                                                     |
| A/D Data Conversion of RSSI Signal118<br>AFE Status Register Bit Condition |
| AGC                                                                        |
| AGC Preserve                                                               |
| Battery Back-up and Batteryless Operation                                  |
| Block Diagrams                                                             |
| Bidirectional PKE System Application Example 102                           |
| Functional100                                                              |
| LC Input Path101                                                           |
| Output Enable Filter Timing                                                |
| Output Enable Filter Timing (Detailed)104                                  |
| Carrier Clock Detector                                                     |
| Carrier Clock Output 114                                                   |
| Examples115                                                                |
| Command Decoder/Controller121                                              |
| Configuration Registers 122                                                |
| Data Slicer                                                                |
| Demodulator                                                                |
| De-Q'ing of Antenna Circuit                                                |
| Error Detection                                                            |
| Factory Calibration                                                        |
| Fixed Gain Amplifiers                                                      |
| LF Field Powering/Battery Back-up                                          |
| Examples                                                                   |
| LFDATA Output Selection                                                    |
| Case I                                                                     |
| Case II                                                                    |
| Low Current Modes                                                          |
| Operating109                                                               |
| Sleep                                                                      |
| Standby109                                                                 |
| Modulation Circuit97                                                       |
| Modulation Depth107                                                        |
| Examples108                                                                |
| Output Enable Filter                                                       |
| Configurable Smart                                                         |
| Output Enable Filter Timing (Table)                                        |
| RF Limiter                                                                 |
| RSSI                                                                       |
| Output Path Diagram                                                        |
| Power-up Sequence Diagram                                                  |
| SPI Read Sequence Diagram                                                  |
| SPI Write Sequence Diagram                                                 |
| RSSI Output Current vs. Input Signal Level                                 |
| Example                                                                    |
| Sensitivity Control                                                        |
| Soft Reset 107                                                             |
| SPI Interface Timing Diagram122                                            |
| Timers                                                                     |
| Alarm                                                                      |

| Auto Channel Selection                 |     |
|----------------------------------------|-----|
| Inactivity                             | 99  |
| Period                                 | 99  |
| Preamble Counters                      |     |
| Pulse Width                            |     |
| RC Oscillator                          |     |
| Tuning Capacitor                       |     |
| Variable Attenuator                    |     |
| Analog Input Connection Considerations | 73  |
| Assembler                              |     |
| MPASM Assembler                        | 160 |
|                                        |     |

### В

| Block Diagrams                               |
|----------------------------------------------|
| Analog Input Model73                         |
| Clock Source                                 |
| Comparator71                                 |
| Comparator C1 72                             |
| Comparator C2                                |
| Comparator Modes                             |
| Crystal Operation                            |
| External RC Mode 39                          |
| Fail-Safe Clock Monitor (FSCM) 45            |
| Functional (AFE) 100                         |
| In-Circuit Serial Programming Connection 147 |
| Interrupt Logic 140                          |
| On-Chip Reset Circuit                        |
| PIC12F635 Device9                            |
| PIC16F636 Device 10                          |
| PIC16F639 Device 11                          |
| RA0 Pin 52                                   |
| RA1 Pin 53                                   |
| RA2 Pin 53                                   |
| RA3 Pin 54                                   |
| RA4 Pin 55                                   |
| RA5 Pin 55                                   |
| RC0 and RC1 Pins 58                          |
| RC2, RC3 and RC5 Pins 58                     |
| RC4 Pin 59                                   |
| Recommended MCLR Circuit                     |
| Resonator Operation 38                       |
| Timer1 65                                    |
| TMR0/WDT Prescaler 61                        |
| Watchdog Timer (WDT) 143                     |
| Brown-out Reset (BOR) 134                    |
| Associated 135                               |
| Specifications 183                           |
| Timing and Characteristics                   |

# С

| C Compilers         |     |
|---------------------|-----|
| MPLAB C18           | 160 |
| MPLAB C30           | 160 |
| Clock Sources       |     |
| External Modes      | 37  |
| EC                  | 37  |
| HS                  | 38  |
| LP                  | 38  |
| OST                 |     |
| RC                  | 39  |
| XT                  | 38  |
| Internal Modes      | 39  |
| Frequency Selection | 41  |
| HFINTOSC            |     |
|                     |     |

# PIC12F635/PIC16F636/639

| NTO00                                    |
|------------------------------------------|
| INTOSC                                   |
| INTOSCIO                                 |
| LFINTOSC                                 |
| Clock Switching                          |
| CMCON0 Register                          |
| CMCON1 Register                          |
| Code Examples                            |
| Assigning Prescaler to Timer0            |
| Assigning Prescaler to WDT62             |
| Data EEPROM Read93                       |
| Data EEPROM Write93                      |
| Indirect Addressing32                    |
| Initializing PORTA 47                    |
| Initializing PORTC57                     |
| Saving Status and W Registers in RAM142  |
| Ultra Low-Power Wake-up Initialization51 |
| Write Verify93                           |
| Code Protection                          |
| Comparator                               |
| Associated registers85                   |
| C2OUT as T1 Gate81                       |
| Configurations74                         |
| I/O Operating Modes74                    |
| Interrupts77                             |
| Operation                                |
| Operation During Sleep                   |
| Response Time                            |
| Synchronizing CxOUT w/Timer181           |
| Comparator Voltage Reference (CVREF)     |
| Response Time                            |
| Specifications                           |
| Comparator Voltage Reference (CVREF)     |
| Effects of a Reset79                     |
| Specifications                           |
| Comparators                              |
| C2OUT as T1 Gate                         |
| Effects of a Reset                       |
| Specifications                           |
| CONFIG Register                          |
| Configuration Bits                       |
| CPU Features                             |
| Customer Change Notification Service     |
| Customer Notification Service            |
| Customer Support                         |
|                                          |

# D

| Data EEPROM Memory                                 |
|----------------------------------------------------|
| Associated Registers                               |
| Code Protection                                    |
| Protection Against Spurious Write                  |
| Using                                              |
| Data Memory17                                      |
| DC and AC Characteristics                          |
| Graphs and Tables191                               |
| DC Characteristics                                 |
| Extended (PIC12F635/PIC16F636)169                  |
| Industrial (PIC12F635/PIC16F636)167                |
| Industrial (PIC16F639)174                          |
| Industrial/Extended (PIC12F635/PIC16F636) 166, 171 |
| Industrial/Extended (PIC16F639) 173, 175           |
| Development Support159                             |
| Device Overview9                                   |
| E                                                  |
|                                                    |

| EEADR Register                     |  |
|------------------------------------|--|
| EECON1 (EEPROM Control 1) Register |  |

| EECON1 Register                    | 92  |
|------------------------------------|-----|
| EECON2 (EEPROM Control 2) Register |     |
| EEDAT Register                     |     |
| EEPROM Data Memory                 |     |
| Reading                            | 93  |
| Write Verify                       | 93  |
| Writing                            | 93  |
| Electrical Specifications          | 163 |
| Errata                             | 7   |

### F

| Fail-Safe Clock Monitor       | 45  |
|-------------------------------|-----|
| Fail-Safe Condition Clearing  |     |
| Fail-Safe Detection           | 45  |
| Fail-Safe Operation           | 45  |
| Reset or Wake-up from Sleep   | 45  |
| Firmware Instructions         | 149 |
| Fuses. See Configuration Bits |     |

### G

| General Purpose Register (GPR) F | File 18 |
|----------------------------------|---------|
|----------------------------------|---------|

### I

| ID Locations                                | 146 |
|---------------------------------------------|-----|
| In-Circuit Debugger                         |     |
| In-Circuit Serial Programming (ICSP)        | 147 |
| Indirect Addressing, INDF and FSR Registers | 32  |
| Instruction Format                          | 149 |
| Instruction Set                             | 149 |
| ADDLW                                       | 151 |
| ADDWF                                       | 151 |
| ANDLW                                       | 151 |
| ANDWF                                       | 151 |
| BCF                                         | 151 |
| BSF                                         | 151 |
| BTFSC                                       | 151 |
| BTFSS                                       | 152 |
| CALL                                        | 152 |
| CLRF                                        | 152 |
| CLRW                                        | 152 |
| CLRWDT                                      | 152 |
| COMF                                        | 152 |
| DECF                                        | 152 |
| DECFSZ                                      | 153 |
| GOTO                                        | 153 |
| INCF                                        | 153 |
| INCFSZ                                      | 153 |
| IORLW                                       |     |
| IORWF                                       | 153 |
| MOVF                                        | 154 |
| MOVLW                                       | 154 |
| MOVWF                                       | 154 |
| NOP                                         | 154 |
| RETFIE                                      | 155 |
| RETLW                                       | 155 |
| RETURN                                      | 155 |
| RLF                                         | 156 |
| RRF                                         | 156 |
| SLEEP                                       | 156 |
| SUBLW                                       | 156 |
| SUBWF                                       | 157 |
| SWAPF                                       | 157 |
| XORLW                                       | 157 |
| XORWF                                       | 157 |
| Summary Table                               |     |
| INTCON Register                             | 28  |

| Internal Oscillator Block |          |
|---------------------------|----------|
| Specifications            | 180, 181 |
| Internet Address          |          |
| Interrupts                |          |
| Associated Registers      |          |
| Comparator                | 77       |
| Context Saving            | 142      |
| Data EEPROM Memory Write  |          |
| Interrupt-on-Change       |          |
| PORTA Interrupt-on-change |          |
| RA2/INT                   |          |
| Timer0                    | 140      |
| TMR1                      | 67       |
| INTOSC Specifications     | 180, 181 |
| IOCA Register             |          |
| -                         |          |

## Κ

| KEELOQ |
|--------|
|--------|

## L

| Load Conditions | 178 |
|-----------------|-----|
|                 |     |

## Μ

| MCLR                                                  |
|-------------------------------------------------------|
| Internal                                              |
| Memory Organization17                                 |
| Data 17                                               |
| Data EEPROM Memory91                                  |
| Program 17                                            |
| Microchip Internet Web Site 223                       |
| MPLAB ASM30 Assembler, Linker, Librarian              |
| MPLAB ICD 2 In-Circuit Debugger161                    |
| MPLAB ICE 2000 High-Performance Universal             |
| In-Circuit Emulator 161                               |
| MPLAB Integrated Development Environment Software 159 |
| MPLAB PM3 Device Programmer161                        |
| MPLAB REAL ICE In-Circuit Emulator System             |
| MPLINK Object Linker/MPLIB Object Librarian           |

## 0

| OPCODE Field Descriptions       | 27 |
|---------------------------------|----|
| OSCCON Register                 | 36 |
| Oscillator                      |    |
| Associated registers            | 69 |
| Oscillator Module               |    |
| EC                              | 35 |
| HFINTOSC                        |    |
| HS                              | 35 |
| INTOSC                          | 35 |
| INTOSCIO                        | 35 |
| LFINTOSC                        | 35 |
| LP                              | 35 |
| RC                              | 35 |
| RCIO                            | 35 |
| XT                              | 35 |
| Oscillator Parameters           | 80 |
| Oscillator Specifications       | 79 |
| Oscillator Start-up Timer (OST) |    |
| Specifications18                | 83 |
| Oscillator Switching            |    |
| Fail-Safe Clock Monitor         | 45 |
| Two-Speed Clock Start-up        | 43 |
| OSCTUNE Register                |    |

## Ρ

| Packaging                                     |
|-----------------------------------------------|
| Details                                       |
| Marking                                       |
| PCL and PCLATH                                |
| Stack                                         |
| PCON Register                                 |
| PICSTART Plus Development Programmer          |
| PIE1 Register                                 |
| Pin Diagrams                                  |
| Pinout Descriptions                           |
| PIC12F635                                     |
| PIC16F636                                     |
| PIC16F639                                     |
| PIR1 Register                                 |
| PLVD                                          |
| Associated Registers                          |
| PORTA                                         |
| Additional Pin Functions                      |
| Interrupt-on-Change                           |
| Ultra Low-Power Wake-up                       |
| Weak Pull-down                                |
| Weak Pull-up                                  |
| Associated Registers                          |
| Pin Descriptions and Diagrams                 |
| RA0/C1IN+/ICSPDAT/ULPWU Pin                   |
| RA1/C1IN-/Vref/ICSPCLK Pin                    |
| RA1/C1112/11001 CERT III                      |
| RA3/MCLR/VPP PIN                              |
| RA4/T1G/OSC2/CLKOUT Pin                       |
| RA5/T1CKI/OSC1/CLKIN Pin                      |
| Specifications                                |
| PORTA Register                                |
| PORTC                                         |
| Associated Registers                          |
| RC0/C2IN+ Pin                                 |
| RC2 Pin                                       |
| RC3 Pin                                       |
| RC4/C2OUT Pin                                 |
| RC5 Pin                                       |
| Specifications                                |
| PORTC Register                                |
| Power Control (PCON) Register                 |
| Power-Down Mode (Sleep)                       |
| Power-on Reset                                |
| Power-up Timer (PWRT)                         |
| Specifications                                |
| Precision Internal Oscillator Parameters      |
| Prescaler                                     |
| Shared WDT/Timer0                             |
| Switching Prescaler Assignment                |
| Product Identification                        |
| Program Memory                                |
| Program Memory Map and Stack                  |
| PIC12F635 17                                  |
| PIC16F636/639                                 |
| Programmable Low-Voltage Detect (PLVD) Module |
| Programming, Device Instructions              |
|                                               |
| R                                             |
| Reader Response                               |
| Read-Modify-Write Operations                  |
| Registers                                     |
| Analog Front-End (AFE)                        |

AFE STATUS Register 7 ...... 127

| Column Parity Register 6                     | . 126 |
|----------------------------------------------|-------|
| Configuration Register 0                     |       |
| Configuration Register 1                     | . 124 |
| Configuration Register 2                     | . 124 |
| Configuration Register 3                     | . 125 |
| Configuration Register 4                     | . 125 |
| Configuration Register 5                     | . 126 |
| CMCON0 (Comparator Control 0)                | 80    |
| CMCON0 (Comparator Control) Register         | 79    |
| CMCON1 (Comparator Control 1)                |       |
| CMCON1 (Comparator Control) Register         | 82    |
| CONFIG (Configuration Word)                  |       |
| EEADR (EEPROM Address)                       | 91    |
| EECON1 (EEPROM Control 1)                    |       |
| EEDAT (EEPROM Data)                          | 91    |
| INTCON (Interrupt Control)                   | 28    |
| IOCA (Interrupt-on-change PORTA)             | 50    |
| LVDCON (Low-Voltage Detect Control)          | 89    |
| OPTION_REG (OPTION)                          | 27    |
| OPTION_REG (Option)                          |       |
| OSCCON (Oscillator Control)                  | 36    |
| OSCTUNE (Oscillator Tuning)                  |       |
| PCON (Power Control Register)                |       |
| PIE1 (Peripheral Interrupt Enable 1)         | 29    |
| PIR1 (Peripheral Interrupt Request 1)        | 30    |
| PORTA                                        | 48    |
| PORTC                                        | 57    |
| Reset Values                                 | . 137 |
| Reset Values (Special Registers)             |       |
| STATUS                                       | 26    |
| T1CON                                        |       |
| TRISA (Tri-State PORTA)                      | 48    |
| TRISC (Tri-State PORTC)                      |       |
| VRCON (Voltage Reference Control)            |       |
| WDA (Weak Pull-up/Pull-down Direction PORTA) |       |
| WDTCON (Watchdog Timer Control)              |       |
| WPUDA (Weak Pull-up/Pull-down Enable PORTA). |       |
| Reset                                        |       |
| Revision History                             | . 225 |

### S

| Software Simulator (MPLAB SIM)       |    |
|--------------------------------------|----|
| Special Function Registers (SFR)     | 18 |
| Maps                                 |    |
| PIC12F635                            | 19 |
| PIC16F636/639                        | 20 |
| Summary                              |    |
| PIC12F635, Bank 0                    | 21 |
| PIC12F635, Bank 1                    | 22 |
| PIC12F635/PIC16F636/639, Bank 2      | 25 |
| PIC16F636/639, Bank 0                | 23 |
| PIC16F636/639, Bank 1                | 24 |
| SPI Timing                           |    |
| Analog Front-End (AFE) for PIC16F639 |    |
| STATUS Register                      |    |
| т                                    |    |
| T1CON Register                       | 68 |

| T1CON Register         | 68     |
|------------------------|--------|
| Thermal Considerations |        |
| Time-out Sequence      | 135    |
| Timer0                 |        |
| Associated Registers   | 63     |
| External Clock         | 62     |
| Interrupt              | 63     |
| Operation              | 61, 64 |
| Specifications         |        |
|                        |        |

| T0CKI 62                                          |
|---------------------------------------------------|
| Timer1                                            |
| Associated registers 69                           |
| Asynchronous Counter Mode                         |
| Reading and Writing 66                            |
| Interrupt                                         |
| Modes of Operation 64                             |
| Operation During Sleep                            |
| Oscillator                                        |
| Prescaler                                         |
| Specifications                                    |
| Timer1 Gate                                       |
| Inverting Gate                                    |
| Selecting Source                                  |
| Synchronizing CxOUT w/Timer1                      |
| TMR1H Register                                    |
| TMR1L Register                                    |
| Timers                                            |
| Timer1                                            |
| T1CON                                             |
| Timing Diagrams                                   |
| Brown-out Reset (BOR)                             |
| Brown-out Reset Situations                        |
| CLKOUT and I/O                                    |
| Clock Timing                                      |
| Comparator Output                                 |
| Fail-Safe Clock Monitor (FSCM)                    |
| INT Pin Interrupt                                 |
| Internal Oscillator Switch Timing                 |
| Reset, WDT, OST and Power-up Timer                |
| Time-out Sequence on Power-up (Delayed MCLR). 136 |
| Time-out Sequence on Power-up (MCLR with VDD) 136 |
| Timer0 and Timer1 External Clock                  |
| Timer1 Incrementing Edge 67                       |
| Two Speed Start-up 44                             |
| Wake-up from Sleep through Interrupt              |
| Timing Parameter Symbology 178                    |
| TRISA                                             |
| TRISA Register                                    |
| TRISC Register                                    |
| Two-Speed Clock Start-up Mode                     |
| U                                                 |

# v

| Voltage Reference. See Comparator Voltage |
|-------------------------------------------|
| Reference (CVREF)                         |
| Voltage References                        |
| Associated registers 85                   |

Ultra Low-Power Wake-up...... 13, 14, 47, 51

### W

| Wake-up from Sleep       | 145 |
|--------------------------|-----|
| Wake-up Reset (WUR)      | 132 |
| Wake-up using Interrupts | 145 |
| Watchdog Timer (WDT)     | 143 |
| Associated Registers     | 144 |
| Control                  | 143 |
| Oscillator               | 143 |
| Specifications           | 183 |
| WDA Register             | 49  |
| WDTCON Register          |     |
| WPUDA Register           | 49  |
| WWW Address              | 223 |
| WWW, On-Line Support     | 7   |
|                          |     |

## **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

| PART NO.<br> <br>Device | X /XX XXX<br>     <br>Temperature Package Pattern<br>Range                                                        | <ul> <li>Examples:</li> <li>a) PIC12F635-E/P 301 = Extended Temp., PDIP package, 20 MHz, QTP pattern #301</li> <li>b) PIC12F635-I/S = Industrial Temp., SOIC package, 20 MHz</li> </ul> |
|-------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device:                 | PIC12F635 <sup>(1, 2)</sup> , PIC16F636 <sup>(1, 2)</sup> , PIC16F639 <sup>(1, 2)</sup><br>VDD range 2.0V to 5.5V |                                                                                                                                                                                         |
| Temperature<br>Range:   |                                                                                                                   |                                                                                                                                                                                         |
| Package:                | $\begin{array}{llllllllllllllllllllllllllllllllllll$                                                              | Note 1: F = Standard Voltage Range<br>2: T = in tape and reel PLCC.                                                                                                                     |
| Pattern:                | 3-Digit Pattern Code for QTP (blank otherwise)                                                                    |                                                                                                                                                                                         |
|                         |                                                                                                                   |                                                                                                                                                                                         |



# WORLDWIDE SALES AND SERVICE

### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://support.microchip.com Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260

**Kokomo** Kokomo, IN Tel: 765-864-8360 Fax: 765-864-8387

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445

Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509

### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Habour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

Australia - Sydney Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8528-2100 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

**China - Fuzhou** Tel: 86-591-8750-3506 Fax: 86-591-8750-3521

**China - Hong Kong SAR** Tel: 852-2401-1200 Fax: 852-2401-3431

China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

**China - Shenyang** Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8203-2660 Fax: 86-755-8203-1760

China - Shunde Tel: 86-757-2839-5507 Fax: 86-757-2839-5571

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7250 Fax: 86-29-8833-7256

### ASIA/PACIFIC

India - Bangalore Tel: 91-80-4182-8400 Fax: 91-80-4182-8422

India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513

**Japan - Yokohama** Tel: 81-45-471- 6166 Fax: 81-45-471-6122

**Korea - Gumi** Tel: 82-54-473-4301 Fax: 82-54-473-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

**Malaysia - Penang** Tel: 60-4-646-8870 Fax: 60-4-646-5086

Philippines - Manila Tel: 63-2-634-9065

Fax: 63-2-634-9069 Singapore Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-572-9526 Fax: 886-3-572-6459

**Taiwan - Kaohsiung** Tel: 886-7-536-4818 Fax: 886-7-536-4803

**Taiwan - Taipei** Tel: 886-2-2500-6610 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen

Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Italy - Milan** Tel: 39-0331-742611 Fax: 39-0331-466781

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820