# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





# PIC12F683 Data Sheet

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

© 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 contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

### 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 a service 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 water 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® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.



# **PIC12F683**

### 8-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
- Power-Saving Sleep mode
- Wide operating voltage range (2.0V-5.5V)
- · Industrial and Extended temperature range
- Power-on Reset (POR)
- 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
- 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:
  - 50 nA @ 2.0V, typical
- Operating Current:
  - 11 μA @ 32 kHz, 2.0V, typical
  - 220 μA @ 4 MHz, 2.0V, typical
- Watchdog Timer Current:
  - 1 μA @ 2.0V, typical

#### **Peripheral Features:**

- 6 I/O pins with individual direction control:
  - High current source/sink for direct LED drive
  - Interrupt-on-pin change
  - Individually programmable weak pull-ups
  - Ultra Low-Power Wake-up on GP0
- · Analog Comparator module with:
  - One analog comparator
  - Programmable on-chip voltage reference (CVREF) module (% of VDD)
  - Comparator inputs and output externally accessible
- A/D Converter:
  - 10-bit resolution and 4 channels
- 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
- Timer2: 8-bit timer/counter with 8-bit period register, prescaler and postscaler
- Capture, Compare, PWM module:
  - 16-bit Capture, max resolution 12.5 ns
  - Compare, max resolution 200 ns
  - 10-bit PWM, max frequency 20 kHz
- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) via two pins

| Device    | Program Memory | Data         | lemory         | I/O | 10-bit A/D (ob) | Comparators | Timers   |
|-----------|----------------|--------------|----------------|-----|-----------------|-------------|----------|
| Device    | Flash (words)  | SRAM (bytes) | EEPROM (bytes) | 1/0 | 10-bit A/D (ch) | Comparators | 8/16-bit |
| PIC12F683 | 2048           | 128          | 256            | 6   | 4               | 1           | 2/1      |

#### 8-Pin Diagram (PDIP, SOIC)



#### 8-Pin Diagram (DFN)



#### 8-Pin Diagram (DFN-S)



#### TABLE 1: 8-PIN SUMMARY

| I/O                | Pin | Analog   | Comparators | Timer | ССР  | Interrupts | Pull-ups         | Basic         |
|--------------------|-----|----------|-------------|-------|------|------------|------------------|---------------|
| GP0                | 7   | AN0      | CIN+        | _     | —    | IOC        | Y                | ICSPDAT/ULPWU |
| GP1                | 6   | AN1/VREF | CIN-        | —     |      | IOC        | Y                | ICSPCLK       |
| GP2                | 5   | AN2      | COUT        | T0CKI | CCP1 | INT/IOC    | Y                | —             |
| GP3 <sup>(1)</sup> | 4   |          | —           | _     |      | IOC        | Y <sup>(2)</sup> | MCLR/Vpp      |
| GP4                | 3   | AN3      | —           | 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  $\overline{MCLR}$ .

#### **Table of Contents**

| 1.0   | Device Overview                                  |      |
|-------|--------------------------------------------------|------|
| 2.0   | Memory Organization                              |      |
| 3.0   | Oscillator Module (With Fail-Safe Clock Monitor) | . 19 |
| 4.0   | GPIO Port                                        | . 31 |
| 5.0   | Timer0 Module                                    | . 41 |
| 6.0   | Timer1 Module with Gate Control                  | . 44 |
| 7.0   | Timer2 Module                                    | . 49 |
| 8.0   | Comparator Module                                |      |
| 9.0   | Analog-to-Digital Converter (ADC) Module         | . 61 |
| 10.0  | Data EEPROM Memory                               | . 71 |
| 11.0  | Capture/Compare/PWM (CCP) Module                 |      |
| 12.0  | Special Features of the CPU                      |      |
| 13.0  | Instruction Set Summary                          | 101  |
| 14.0  | Development Support                              | 111  |
| 15.0  | Electrical Specifications                        | 115  |
| 16.0  | DC and AC Characteristics Graphs and Tables      | 137  |
| 17.0  | Packaging Information                            | 159  |
|       | ndix A: Data Sheet Revision History              |      |
| Appe  | ndix B: Migrating From Other PIC® Devices        | 165  |
| The N | /icrochip Web Site                               | 171  |
| Custo | mer Change Notification Service                  | 171  |
| Custo | mer Support                                      | 171  |
| Read  | er Response                                      | 172  |
| Produ | ict Identification System                        | 173  |
|       |                                                  |      |

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

The PIC12F683 is covered by this data sheet. It is available in 8-pin PDIP, SOIC and DFN-S packages. Figure 1-1 shows a block diagram of the PIC12F683 device. Table 1-1 shows the pinout description.



© 2007 Microchip Technology Inc.

#### **PIC12F683 PINOUT DESCRIPTION TABLE 1-1:**

| Name                        | Function | Input<br>Type | Output<br>Type | Description                                         |
|-----------------------------|----------|---------------|----------------|-----------------------------------------------------|
| Vdd                         | Vdd      | Power         |                | Positive supply                                     |
| GP5/T1CKI/OSC1/CLKIN        | GP5      | TTL           | CMOS           | GPIO I/O with prog. pull-up and interrupt-on-change |
|                             | T1CKI    | ST            | _              | Timer1 clock                                        |
|                             | OSC1     | XTAL          | _              | Crystal/Resonator                                   |
|                             | CLKIN    | ST            |                | External clock input/RC oscillator connection       |
| GP4/AN3/T1G/OSC2/CLKOUT     | GP4      | TTL           | CMOS           | GPIO I/O with prog. pull-up and interrupt-on-change |
|                             | AN3      | AN            | _              | A/D Channel 3 input                                 |
|                             | T1G      | ST            | _              | Timer1 gate                                         |
|                             | OSC2     | _             | XTAL           | Crystal/Resonator                                   |
|                             | CLKOUT   | —             | CMOS           | Fosc/4 output                                       |
| GP3/MCLR/Vpp                | GP3      | TTL           | _              | GPIO input with interrupt-on-change                 |
|                             | MCLR     | ST            | _              | Master Clear with internal pull-up                  |
|                             | VPP      | HV            | _              | Programming voltage                                 |
| GP2/AN2/T0CKI/INT/COUT/CCP1 | GP2      | ST            | CMOS           | GPIO I/O with prog. pull-up and interrupt-on-change |
|                             | AN2      | AN            | _              | A/D Channel 2 input                                 |
|                             | TOCKI    | ST            |                | Timer0 clock input                                  |
|                             | INT      | ST            |                | External Interrupt                                  |
|                             | COUT     |               | CMOS           | Comparator 1 output                                 |
|                             | CCP1     | ST            | CMOS           | Capture input/Compare output/PWM output             |
| GP1/AN1/CIN-/VREF/ICSPCLK   | GP1      | TTL           | CMOS           | GPIO I/O with prog. pull-up and interrupt-on-change |
|                             | AN1      | AN            | _              | A/D Channel 1 input                                 |
|                             | CIN-     | AN            |                | Comparator 1 input                                  |
|                             | VREF     | AN            | _              | External Voltage Reference for A/D                  |
|                             | ICSPCLK  | ST            |                | Serial Programming Clock                            |
| GP0/AN0/CIN+/ICSPDAT/ULPWU  | GP0      | TTL           | CMOS           | GPIO I/O with prog. pull-up and interrupt-on-change |
|                             | AN0      | AN            | _              | A/D Channel 0 input                                 |
|                             | CIN+     | AN            | _              | Comparator 1 input                                  |
|                             | ICSPDAT  | ST            | CMOS           | Serial Programming Data I/O                         |
|                             | ULPWU    | AN            | _              | Ultra Low-Power Wake-up input                       |
| Vss                         | Vss      | Power         | —              | Ground reference                                    |

TTL = TTL compatible input HV = High Voltage

ST = Schmitt Trigger input with CMOS levels XTAL = Crystal

#### 2.0 MEMORY ORGANIZATION

#### 2.1 Program Memory Organization

The PIC12F683 has a 13-bit program counter capable of addressing an  $8k \times 14$  program memory space. Only the first  $2k \times 14$  (0000h-07FFh) for the PIC12F683 is physically implemented. Accessing a location above these boundaries will cause a wraparound within the first  $2K \times 14$  space. The Reset vector is at 0000h and the interrupt vector is at 0004h (see Figure 2-1).

#### FIGURE 2-1: PROGRAM MEMORY MAP AND STACK FOR THE PIC12F683



#### 2.2 Data Memory Organization

The data memory (see Figure 2-2) is partitioned into two banks, which contain 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 General Purpose Registers, implemented as static RAM. Register locations F0h-FFh in Bank 1 point to addresses 70h-7Fh in Bank 0. All other RAM is unimplemented and returns '0' when read. RP0 of the STATUS register is the bank select bit.

#### <u>RP0</u>

- $0 \rightarrow Bank 0 is selected$
- $1 \rightarrow Bank 1$  is selected

**Note:** The IRP and RP1 bits of the STATUS register are reserved and should always be maintained as '0's.

#### 2.2.1 GENERAL PURPOSE REGISTER FILE

The register file is organized as 128 x 8 in the PIC12F683. Each register is accessed, 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 Registers are registers used by the CPU and peripheral functions for controlling the desired operation of the device (see Table 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.

#### FIGURE 2-2: DATA MEMORY MAP OF THE PIC12E683

|                               | File    |                               | File     |
|-------------------------------|---------|-------------------------------|----------|
|                               | Address |                               | Addre    |
| Indirect addr. <sup>(1)</sup> | 00h     | Indirect addr. <sup>(1)</sup> | 80       |
| TMR0                          | 01h     | OPTION_REG                    | 81       |
| PCL                           | 02h     | PCL                           | 82       |
| STATUS                        | 03h     | STATUS                        | 83       |
| FSR                           | 04h     | FSR                           | 84       |
| GPIO                          | 05h     | TRISIO                        | 85       |
|                               | 06h     |                               | 86       |
|                               | 07h     |                               | 87       |
|                               | 08h     |                               | 88       |
|                               | 09h     |                               | 89       |
| PCLATH                        | 0Ah     | PCLATH                        | 84       |
| INTCON                        | 0Bh     | INTCON                        | 8E       |
| PIR1                          | 0Ch     | PIE1                          | 80       |
|                               | 0Dh     |                               | 80       |
| TMR1L                         | 0Eh     | PCON                          | 8E       |
| TMR1H                         | 0Fh     | OSCCON                        | 8F       |
| T1CON                         | 10h     | OSCTUNE                       | 90       |
| TMR2                          | 11h     |                               | 91       |
| T2CON                         | 12h     | PR2                           | 92       |
| CCPR1L                        | 13h     |                               | 93       |
| CCPR1H                        | 14h     |                               | 94       |
| CCP1CON                       | 15h     | WPU                           | 95       |
|                               | 16h     | IOC                           | 96       |
|                               | 17h     |                               | 97       |
| WDTCON                        | 18h     |                               | 98       |
| CMCON0                        | 19h     | VRCON                         | 99       |
| CMCON1                        | 1Ah     | EEDAT                         | 9A       |
|                               | 1Bh     | EEADR                         | 9E       |
|                               | 1Ch     | EECON1                        | 90       |
|                               | 1Dh     | EECON2 <sup>(1)</sup>         | 90       |
| ADRESH                        | 1Eh     | ADRESL                        | 9E       |
| ADCON0                        | 1Fh     | ANSEL                         | 9F       |
|                               | 20h     | General                       | AC       |
|                               |         | Purpose<br>Registers          |          |
| Canaral                       |         | 32 Bytes                      | BF       |
| General<br>Purpose            |         |                               | C        |
| Registers                     |         |                               |          |
| 96 Bytes                      |         |                               |          |
| SO DYIES                      |         |                               |          |
|                               |         |                               | 1        |
|                               |         |                               | 1        |
|                               |         |                               |          |
|                               |         |                               | -        |
|                               |         |                               | EF<br>F0 |
|                               | 7Eb     | Accesses 70h-7Fh              | F        |
|                               | 7Fh     | BANK 1                        | _ · r    |

| IADL   | E 2-1:  | FIC12F             | -003 3FE                                                          |               | GISTER        | SUMMA         |                | ΝU             | 1             | r            |      |        |
|--------|---------|--------------------|-------------------------------------------------------------------|---------------|---------------|---------------|----------------|----------------|---------------|--------------|------|--------|
| Addr   | Name    | Bit 7              | Bit 6                                                             | Bit 5         | Bit 4         | Bit 3         | Bit 2          | Bit 1          | Bit 0         | Valu<br>POR, |      | Page   |
| Bank ( | )       |                    |                                                                   |               |               |               |                |                |               |              |      |        |
| 00h    | INDF    | Addressin          | g this locatio                                                    | on uses conte | ents of FSR   | to address d  | ata memory     | v (not a physi | cal register) | xxxx         | xxxx | 17, 90 |
| 01h    | TMR0    | Timer0 M           | odule Regis                                                       | ter           |               |               |                |                |               | xxxx         | xxxx | 41, 90 |
| 02h    | PCL     | Program (          | Counter's (F                                                      | PC) Least S   | ignificant By | rte           |                |                |               | 0000         | 0000 | 17, 90 |
| 03h    | STATUS  | IRP <sup>(1)</sup> | RP1 <sup>(1)</sup>                                                | RP0           | TO            | PD            | Z              | DC             | С             | 0001         | 1xxx | 11, 90 |
| 04h    | FSR     | Indirect D         | ata Memory                                                        | Address P     | ointer        |               |                |                | •             | xxxx         | xxxx | 17, 90 |
| 05h    | GPIO    | _                  | _                                                                 | GP5           | GP4           | GP3           | GP2            | GP1            | GP0           | xx           | xxxx | 31, 90 |
| 06h    | _       | Unimplem           | nplemented —                                                      |               |               |               |                |                | _             |              |      |        |
| 07h    |         | Unimplem           | implemented -                                                     |               |               |               |                | - 1            | _             | _            |      |        |
| 08h    |         | Unimplem           | nented                                                            |               |               |               |                |                |               | - 1          | _    | _      |
| 09h    | _       | Unimplem           | nented                                                            |               |               |               |                |                |               | _            | _    |        |
| 0Ah    | PCLATH  | _                  | _                                                                 | —             | Write Buffe   | r for upper 5 | 5 bits of Pro  | gram Count     | er            | 0            | 0000 | 17, 90 |
| 0Bh    | INTCON  | GIE                | PEIE                                                              | T0IE          | INTE          | GPIE          | T0IF           | INTF           | GPIF          | 0000         | 0000 | 13, 90 |
| 0Ch    | PIR1    | EEIF               | ADIF                                                              | CCP1IF        | _             | CMIF          | OSFIF          | TMR2IF         | TMR1IF        | 000-         | 0000 | 15, 90 |
| 0Dh    |         | Unimplem           | nimplemented —                                                    |               |               |               |                |                | _             |              |      |        |
| 0Eh    | TMR1L   | Holding R          | olding Register for the Least Significant Byte of the 16-bit TMR1 |               |               |               |                |                | 44, 90        |              |      |        |
| 0Fh    | TMR1H   | Holding R          | egister for t                                                     | he Most Sig   | nificant Byt  | e of the 16-b | bit TMR1       |                |               | xxxx         | xxxx | 44, 90 |
| 10h    | T1CON   | T1GINV             | TMR1GE                                                            | T1CKPS1       | T1CKPS0       | T1OSCEN       | T1SYNC         | TMR1CS         | TMR10N        | 0000         | 0000 | 47, 90 |
| 11h    | TMR2    | Timer2 M           | odule Regis                                                       | ter           |               |               |                |                |               | 0000         | 0000 | 49, 90 |
| 12h    | T2CON   | —                  | TOUTPS3                                                           | TOUTPS2       | TOUTPS1       | TOUTPS0       | TMR2ON         | T2CKPS1        | T2CKPS0       | -000         | 0000 | 50, 90 |
| 13h    | CCPR1L  | Capture/C          | Compare/PV                                                        | VM Register   | 1 Low Byte    | 9             |                |                |               | xxxx         | xxxx | 76, 90 |
| 14h    | CCPR1H  | Capture/C          | Compare/PV                                                        | VM Register   | r 1 High Byt  | e             |                |                |               | xxxx         | xxxx | 76, 90 |
| 15h    | CCP1CON | _                  | —                                                                 | DC1B1         | DC1B0         | CCP1M3        | CCP1M2         | CCP1M1         | CCP1M0        | 00           | 0000 | 75, 90 |
| 16h    |         | Unimplem           | nented                                                            | •             |               | •             |                |                | •             | -            | -    | _      |
| 17h    | _       | Unimplem           | nented                                                            |               |               |               |                |                |               | _            | _    |        |
| 18h    | WDTCON  | _                  | _                                                                 | _             | WDTPS3        | WDTPS2        | WDTPS1         | WDTPS0         | SWDTEN        | 0            | 1000 | 97, 90 |
| 19h    | CMCON0  | _                  | COUT                                                              | —             | CINV          | CIS           | CM2            | CM1            | CM0           | - 0 - 0      | 0000 | 56, 90 |
| 1Ah    | CMCON1  | _                  | -                                                                 | —             | —             | —             | —              | T1GSS          | CMSYNC        |              | 10   | 57, 90 |
| 1Bh    | —       | Unimplem           | nented                                                            |               |               |               |                |                |               | -            | -    | —      |
| 1Ch    | _       | Unimplem           | nented                                                            |               |               |               |                |                |               | _            | _    | _      |
| 1Dh    | _       | Unimplem           | nented                                                            |               |               |               |                |                |               | _            | _    | _      |
| 1Eh    | ADRESH  | Most Sign          | ificant 8 bits                                                    | s of the left | shifted A/D   | result or 2 b | its of right s | hifted result  |               | xxxx         | xxxx | 61,90  |
| 1Fh    | ADCON0  | ADFM               | VCFG                                                              | _             |               | CHS1          | CHS0           | GO/DONE        | ADON          | 00           | 0000 | 65,90  |
| 0000   |         |                    | tod logotion                                                      |               |               |               |                |                |               |              |      |        |

**Note 1:** IRP and RP1 bits are reserved, always maintain these bits clear.

| Addr | Name               | Bit 7              | Bit 6                                        | Bit 5         | Bit 4        | Bit 3               | Bit 2          | Bit 1        | Bit 0         | Value on<br>POR, BOR | Page   |
|------|--------------------|--------------------|----------------------------------------------|---------------|--------------|---------------------|----------------|--------------|---------------|----------------------|--------|
| Bank | 1                  |                    |                                              |               |              |                     |                |              |               |                      |        |
| 80h  | INDF               | Addressing         | this location                                | i uses conte  | nts of FSR t | o address d         | ata memory     | (not a physi | cal register) | xxxx xxxx            | 17, 90 |
| 81h  | OPTION_REG         | GPPU               | INTEDG                                       | TOCS          | T0SE         | PSA                 | PS2            | PS1          | PS0           | 1111 1111            | 12, 90 |
| 82h  | PCL                | Program C          | rogram Counter's (PC) Least Significant Byte |               |              |                     |                |              |               | 0000 0000            | 17, 90 |
| 83h  | STATUS             | IRP <sup>(1)</sup> | RP1 <sup>(1)</sup>                           | RP0           | TO           | PD                  | Z              | DC           | С             | 0001 1xxx            | 11, 90 |
| 84h  | FSR                | Indirect Da        | ta Memory                                    | Address Po    | pinter       |                     |                |              |               | xxxx xxxx            | 17, 90 |
| 85h  | TRISIO             | _                  | _                                            | TRISIO5       | TRISIO4      | TRISIO3             | TRISIO2        | TRISIO1      | TRISIO0       | 11 1111              | 32, 90 |
| 86h  | _                  | Unimpleme          | implemented                                  |               |              |                     |                |              |               | _                    | _      |
| 87h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | _      |
| 88h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 89h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 8Ah  | PCLATH             | _                  | _                                            | _             | Write Buffe  | er for upper        | 5 bits of Pro  | ogram Cou    | nter          | 0 0000               | 17, 90 |
| 8Bh  | INTCON             | GIE                | PEIE                                         | TOIE          | INTE         | GPIE                | T0IF           | INTF         | GPIF          | 0000 0000            | 13, 90 |
| 8Ch  | PIE1               | EEIE               | ADIE                                         | CCP1IE        | —            | CMIE                | OSFIE          | TMR2IE       | TMR1IE        | 000- 0000            | 14, 90 |
| 8Dh  |                    | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    |        |
| 8Eh  | PCON               | —                  | —                                            | ULPWUE        | SBOREN       | —                   | —              | POR          | BOR           | 01qq                 | 16, 90 |
| 8Fh  | OSCCON             | _                  | IRCF2                                        | IRCF1         | IRCF0        | OSTS <sup>(2)</sup> | HTS            | LTS          | SCS           | -110 x000            | 20, 90 |
| 90h  | OSCTUNE            | —                  | —                                            | _             | TUN4         | TUN3                | TUN2           | TUN1         | TUN0          | 0 0000               | 24, 90 |
| 91h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 92h  | PR2                | Timer2 Mo          | dule Period                                  | Register      |              |                     |                |              |               | 1111 1111            | 49, 90 |
| 93h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 94h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 95h  | WPU <sup>(3)</sup> | —                  | _                                            | WPU5          | WPU4         | _                   | WPU2           | WPU1         | WPU0          | 11 -111              | 34, 90 |
| 96h  | IOC                | _                  | —                                            | IOC5          | IOC4         | IOC3                | IOC2           | IOC1         | IOC0          | 00 0000              | 34, 90 |
| 97h  | _                  | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    | —      |
| 98h  |                    | Unimpleme          | ented                                        |               |              |                     |                |              |               | —                    |        |
| 99h  | VRCON              | VREN               | —                                            | VRR           | —            | VR3                 | VR2            | VR1          | VR0           | 0-0- 0000            | 58, 90 |
| 9Ah  | EEDAT              | EEDAT7             | EEDAT6                                       | EEDAT5        | EEDAT4       | EEDAT3              | EEDAT2         | EEDAT1       | EEDAT0        | 0000 0000            | 71, 90 |
| 9Bh  | EEADR              | EEADR7             | EEADR6                                       | EEADR5        | EEADR4       | EEADR3              | EEADR2         | EEADR1       | EEADR0        | 0000 0000            | 71, 90 |
| 9Ch  | EECON1             | —                  | —                                            | —             | —            | WRERR               | WREN           | WR           | RD            | x000                 | 72, 91 |
| 9Dh  | EECON2             | EEPROM             | Control Reg                                  | jister 2 (not | a physical   | register)           |                |              |               |                      | 72, 91 |
| 9Eh  | ADRESL             | Least Sign         | ificant 2 bits                               | s of the left | shifted resu | It or 8 bits of     | of the right s | shifted resu | lt            | xxxx xxxx            | 66, 91 |
| 9Fh  | ANSEL              | —                  | ADCS2                                        | ADCS1         | ADCS0        | ANS3                | ANS2           | ANS1         | ANS0          | -000 1111            | 33, 91 |

#### TABLE 2-2: PIC12F683 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: IRP and RP1 bits are reserved, always maintain these bits clear.

2: OSTS bit of the OSCCON register reset to '0' with Dual Speed Start-up and LP, HS or XT selected as the oscillator.

3: GP3 pull-up is enabled when MCLRE is '1' in the Configuration Word register.

#### 2.2.2.1 STATUS Register

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

- Arithmetic status of the ALU
- Reset status
- Bank select bits for data memory (SRAM)

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then 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 instructions are used to alter the STATUS register, because these instructions do not affect any Status bits. For other instructions not affecting any Status bits, see the "Instruction Set Summary".

- Note 1: Bits IRP and RP1 of the STATUS register are not used by the PIC12F683 and should be maintained as clear. Use of these bits is not recommended, since this may affect upward compatibility with future products.
  - 2: The <u>C and DC bits</u> operate as a Borrow and Digit Borrow out bit, respectively, in subtraction.

| Reserved | Reserved | R/W-0 | R-1 | R-1 | R/W-x | R/W-x | R/W-x |
|----------|----------|-------|-----|-----|-------|-------|-------|
| IRP      | RP1      | RP0   | TO  | PD  | Z     | DC    | С     |
| bit 7    |          |       |     |     |       |       | bit 0 |

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

| Legend:           |                                                                                                                                |                                                                                                                    |                                                                      |                    |  |  |  |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--------------------|--|--|--|--|--|--|
| R = Reada         | ble 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             | IRP: This                                                                                                                      | bit is reserved and should                                                                                         | pe maintained as '0'                                                 |                    |  |  |  |  |  |  |
| bit 6             | RP1: Thi                                                                                                                       | s bit is reserved and should                                                                                       | be maintained as '0'                                                 |                    |  |  |  |  |  |  |
| bit 5             | <b>RP0:</b> Re                                                                                                                 | <b>RP0:</b> Register Bank Select bit (used for direct addressing)                                                  |                                                                      |                    |  |  |  |  |  |  |
|                   |                                                                                                                                | 1 = Bank 1 (80h - FFh)<br>0 = Bank 0 (00h - 7Fh)                                                                   |                                                                      |                    |  |  |  |  |  |  |
| bit 4             | TO: Time-out bit                                                                                                               |                                                                                                                    |                                                                      |                    |  |  |  |  |  |  |
|                   | <ul> <li>1 = After power-up, CLRWDT instruction or SLEEP instruction</li> <li>0 = A WDT time-out occurred</li> </ul>           |                                                                                                                    |                                                                      |                    |  |  |  |  |  |  |
| oit 3             | PD: Power-down bit                                                                                                             |                                                                                                                    |                                                                      |                    |  |  |  |  |  |  |
|                   |                                                                                                                                | power-up or by the CLRWDT<br>kecution of the SLEEP instru                                                          |                                                                      |                    |  |  |  |  |  |  |
| bit 2             | Z: Zero b                                                                                                                      | Z: Zero bit                                                                                                        |                                                                      |                    |  |  |  |  |  |  |
|                   |                                                                                                                                | result of an arithmetic or logi<br>result of an arithmetic or logi                                                 |                                                                      |                    |  |  |  |  |  |  |
| bit 1             |                                                                                                                                | <b>DC:</b> Digit Carry/Borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions), For Borrow, the polarity is reversed. |                                                                      |                    |  |  |  |  |  |  |
|                   | 1 = A carry-out from the 4th low-order bit of the result occurred<br>0 = No carry-out from the 4th low-order bit of the result |                                                                                                                    |                                                                      |                    |  |  |  |  |  |  |
| bit 0             | C: Carry                                                                                                                       | C: Carry/Borrow bit <sup>(1)</sup> (ADDWF, ADDLW, SUBLW, SUBWF instructions)                                       |                                                                      |                    |  |  |  |  |  |  |
|                   |                                                                                                                                |                                                                                                                    | cant bit of the result occurred<br>ficant bit of the result occurred |                    |  |  |  |  |  |  |

**Note 1:** For Borrow, the polarity is reversed. A subtraction is executed by adding the two's complement of the second operand. For rotate (RRF, RLF) instructions, this bit is loaded with either the high-order or low-order bit of the source register.

#### 2.2.2.2 OPTION Register

The OPTION register is a readable and writable register, which contains various control bits to configure:

- TMR0/WDT prescaler
- External GP2/INT interrupt
- TMR0
- · Weak pull-ups on GPIO

#### Note: To achieve a 1:1 prescaler assignment for Timer0, assign the prescaler to the WDT by setting PSA bit of the OPTION register to '1' See Section 5.1.3 "Software Programmable Prescaler".

| REGISTER 2-2: | OPTIC  | ON_REG: OP1 | TION REGIS | TER   |        |
|---------------|--------|-------------|------------|-------|--------|
| R/M/_1        | B/M/_1 | R/M_1       | B/M_1      | B/M_1 | R/M/_1 |

| R/W-1        | R/W-1                                                | R/W-1                                                                         | R/W-1         | R/W-1            | R/W-1           | R/W-1          | R/W-1 |  |  |  |  |  |
|--------------|------------------------------------------------------|-------------------------------------------------------------------------------|---------------|------------------|-----------------|----------------|-------|--|--|--|--|--|
| GPPU         | INTEDG                                               | TOCS                                                                          | T0SE          | PSA              | PS2             | PS1            | PS0   |  |  |  |  |  |
| bit 7        |                                                      |                                                                               |               |                  |                 | ÷              | bit ( |  |  |  |  |  |
|              |                                                      |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
| Legend:      |                                                      |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
| R = Readab   | ole bit                                              | W = Writable                                                                  | e bit         | U = Unimplei     | mented bit, rea | d as '0'       |       |  |  |  |  |  |
| -n = Value a | at POR                                               | '1' = Bit is se                                                               | et            | '0' = Bit is cle | ared            | x = Bit is unk | nown  |  |  |  |  |  |
|              |                                                      |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
| bit 7        | GPPU: GPIC                                           | ) Pull-up Enab                                                                | le bit        |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 1 = GPIO pull-ups are disabled                                                |               |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 0 = GPIO pull-ups are enabled by individual PORT latch values in WPU register |               |                  |                 |                |       |  |  |  |  |  |
| bit 6        |                                                      | errupt Edge Se                                                                |               |                  |                 |                |       |  |  |  |  |  |
|              | 1 = Interrupt on rising edge of INT pin              |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
|              | •                                                    | 0 = Interrupt on falling edge of INT pin                                      |               |                  |                 |                |       |  |  |  |  |  |
| bit 5        | TOCS: Timer                                          | TOCS: Timer0 Clock Source Select bit                                          |               |                  |                 |                |       |  |  |  |  |  |
|              | 1 = Transition on TOCKI pin                          |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 0 = Internal instruction cycle clock (FOSC/4)                                 |               |                  |                 |                |       |  |  |  |  |  |
| bit 4        |                                                      | TOSE: Timer0 Source Edge Select bit                                           |               |                  |                 |                |       |  |  |  |  |  |
|              | 1 = Increment on high-to-low transition on TOCKI pin |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
|              | 0 = Increment on low-to-high transition on TOCKI pin |                                                                               |               |                  |                 |                |       |  |  |  |  |  |
| bit 3        | PSA: Presca                                          | aler Assignmer                                                                | it bit        |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | r is assigned to                                                              |               |                  |                 |                |       |  |  |  |  |  |
|              | 0 = Prescale                                         | 0 = Prescaler is assigned to the Timer0 module                                |               |                  |                 |                |       |  |  |  |  |  |
| bit 2-0      | <b>PS&lt;2:0&gt;:</b> Pr                             | escaler Rate S                                                                | elect bits    |                  |                 |                |       |  |  |  |  |  |
|              | BIT                                                  | VALUE TIMER                                                                   | 0 RATE WDT RA | TE               |                 |                |       |  |  |  |  |  |
|              |                                                      | 000 1:2                                                                       | 2 1:1         |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 001 1:4                                                                       |               |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 010 1:8                                                                       |               |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 011 1:1                                                                       | -             |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 100 1:3<br>101 1:6                                                            | -             |                  |                 |                |       |  |  |  |  |  |
|              |                                                      | 110 1:1                                                                       |               |                  |                 |                |       |  |  |  |  |  |
|              |                                                      |                                                                               |               |                  |                 |                |       |  |  |  |  |  |

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

1:128

1:256

111

#### 2.2.2.3 INTCON Register

The INTCON register is a readable and writable register, which contains the various enable and flag bits for TMR0 register overflow, GPIO change and external GP2/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 enable bit, GIE of the INTCON register. User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt.

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

| R/W-0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| GIE   | PEIE  | T0IE  | INTE  | GPIE  | T0IF  | INTF  | GPIF  |
| 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 | <b>GIE:</b> 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>TolE:</b> Timer0 Overflow Interrupt Enable bit<br>1 = Enables the Timer0 interrupt<br>0 = Disables the Timer0 interrupt                                                                    |
| bit 4 | INTE: GP2/INT External Interrupt Enable bit<br>1 = Enables the GP2/INT external interrupt<br>0 = Disables the GP2/INT external interrupt                                                      |
| bit 3 | <b>GPIE:</b> GPIO Change Interrupt Enable bit <sup>(1)</sup><br>1 = Enables the GPIO change interrupt<br>0 = Disables the GPIO change interrupt                                               |
| bit 2 | <b>TOIF:</b> Timer0 Overflow Interrupt Flag bit <sup>(2)</sup><br>1 = Timer0 register has overflowed (must be cleared in software)<br>0 = Timer0 register did not overflow                    |
| bit 1 | INTF: GP2/INT External Interrupt Flag bit<br>1 = The GP2/INT external interrupt occurred (must be cleared in software)<br>0 = The GP2/INT external interrupt did not occur                    |
| bit 0 | <b>GPIF:</b> GPIO Change Interrupt Flag bit<br>1 = When at least one of the GPIO <5:0> pins changed state (must be cleared in software)<br>0 = None of the GPIO <5:0> pins have changed state |

- Note 1: IOC register must also be enabled.
  - 2: T0IF bit is set when TMR0 rolls over. TMR0 is unchanged on Reset and should be initialized before clearing T0IF bit.

## PIC12F683

#### 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  | U-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  |
|-------|-------|--------|-----|-------|-------|--------|--------|
| EEIE  | ADIE  | CCP1IE | —   | CMIE  | OSFIE | TMR2IE | TMR1IE |
| bit 7 |       |        |     |       |       |        | bit 0  |

| Legend:      |                                                                                                                                                                                                         |                                                                                                  |                             |                    |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------------|--------------------|--|--|
| R = Readab   | ole bit                                                                                                                                                                                                 | W = Writable bit                                                                                 | U = Unimplemented bit       | , read as '0'      |  |  |
| -n = Value a | at POR                                                                                                                                                                                                  | '1' = Bit is set                                                                                 | '0' = Bit is cleared        | x = Bit is unknown |  |  |
| bit 7        | 1 = Enat                                                                                                                                                                                                | E Write Complete Interrupt Er<br>bles the EE write complete int                                  | terrupt                     |                    |  |  |
| bit 6        | <ul> <li>0 = Disables the EE write complete interrupt</li> <li>ADIE: A/D Converter (ADC) Interrupt Enable bit</li> <li>1 = Enables the ADC interrupt</li> <li>0 = Disables the ADC interrupt</li> </ul> |                                                                                                  |                             |                    |  |  |
| bit 5        | <b>CCP1IE:</b> CCP1 Interrupt Enable bit<br>1 = Enables the CCP1 interrupt<br>0 = Disables the CCP1 interrupt                                                                                           |                                                                                                  |                             |                    |  |  |
| bit 4        | Unimple                                                                                                                                                                                                 | Unimplemented: Read as '0'                                                                       |                             |                    |  |  |
| bit 3        | <b>CMIE:</b> Comparator Interrupt Enable bit<br>1 = Enables the Comparator 1 interrupt<br>0 = Disables the Comparator 1 interrupt                                                                       |                                                                                                  |                             |                    |  |  |
| bit 2        | <b>OSFIE:</b> Oscillator Fail Interrupt Enable bit<br>1 = Enables the oscillator fail interrupt<br>0 = Disables the oscillator fail interrupt                                                           |                                                                                                  |                             |                    |  |  |
| bit 1        | <b>TMR2IE</b> :<br>1 = Enat                                                                                                                                                                             | : Timer2 to PR2 Match Interru<br>bles the Timer2 to PR2 match<br>bles the Timer2 to PR2 match    | upt Enable bit<br>interrupt |                    |  |  |
| bit 0        | 1 = Enat                                                                                                                                                                                                | Timer1 Overflow Interrupt En<br>bles the Timer1 overflow inter<br>bles the Timer1 overflow inter | rupt                        |                    |  |  |

#### 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    |
|       | enable bit, GIE of the INTCON register.       |
|       | User software should ensure the appropri-     |
|       | ate interrupt flag bits are clear prior to    |
|       | enabling an interrupt.                        |

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

| R/W-0 | R/W-0 | R/W-0  | U-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0  |
|-------|-------|--------|-----|-------|-------|--------|--------|
| EEIF  | ADIF  | CCP1IF |     | CMIF  | OSFIF | TMR2IF | 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: EEPROM Write Operation Interrupt Flag bit                                               |
|-------|-----------------------------------------------------------------------------------------------|
|       | 1 = The write operation completed (must be cleared in software)                               |
|       | 0 = The write operation has not completed or has not been started                             |
| bit 6 | ADIF: A/D Interrupt Flag bit                                                                  |
|       | 1 = A/D conversion complete                                                                   |
|       | 0 = A/D conversion has not completed or has not been started                                  |
| bit 5 | CCP1IF: CCP1 Interrupt Flag bit                                                               |
|       | Capture mode:                                                                                 |
|       | 1 = A TMR1 register capture occurred (must be cleared in software)                            |
|       | <ul> <li>0 = No TMR1 register capture occurred</li> <li>Compare mode:</li> </ul>              |
|       | 1 = A TMR1 register compare match occurred (must be cleared in software)                      |
|       | 0 = No TMR1 register compare match occurred                                                   |
|       | <u>PWM mode</u> :                                                                             |
|       | Unused in this mode                                                                           |
| bit 4 | Unimplemented: Read as '0'                                                                    |
| bit 3 | CMIF: Comparator Interrupt Flag bit                                                           |
|       | 1 = Comparator 1 output has changed (must be cleared in software)                             |
|       | 0 = Comparator 1 output has not changed                                                       |
| bit 2 | OSFIF: Oscillator Fail Interrupt Flag bit                                                     |
|       | 1 = System oscillator failed, clock input has changed to INTOSC (must be cleared in software) |
|       | 0 = System clock operating                                                                    |
| bit 1 | TMR2IF: Timer2 to PR2 Match Interrupt Flag bit                                                |
|       | 1 = Timer2 to PR2 match occurred (must be cleared in software)                                |
|       | 0 = Timer2 to PR2 match has not occurred                                                      |
| bit 0 | TMR1IF: Timer1 Overflow Interrupt Flag bit                                                    |
|       | 1 = Timer1 register overflowed (must be cleared in software)                                  |
|       | 0 = Timer1 has not overflowed                                                                 |

#### 2.2.2.6 PCON Register

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

- Power-on Reset (POR)
- 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  | U-0 | U-0 | R/W-0 | R/W-x |
|-------|-----|--------|--------|-----|-----|-------|-------|
| —     | —   | ULPWUE | SBOREN | —   | —   | POR   | BOR   |
| bit 7 |     |        |        |     |     |       | bit 0 |

| Legend:                                                                  |                                                |                           |                                    |                                |  |  |
|--------------------------------------------------------------------------|------------------------------------------------|---------------------------|------------------------------------|--------------------------------|--|--|
| R = Readable bit $W = Writable bit$ $-n = Value at POR$ '1' = Bit is set |                                                | W = Writable bit          | U = Unimplemented bit, read as '0' |                                |  |  |
|                                                                          |                                                | '1' = Bit is set          | '0' = Bit is cleared               | x = Bit is unknown             |  |  |
|                                                                          |                                                |                           |                                    |                                |  |  |
| bit 7-6                                                                  | Unimple                                        | mented: 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-2                                                                  | Unimple                                        | mented: Read as '0'       |                                    |                                |  |  |
| bit 1                                                                    | POR: Po                                        | wer-on Reset Status bit   |                                    |                                |  |  |
|                                                                          | 1 = No P                                       | ower-on Reset occurred    |                                    |                                |  |  |
|                                                                          | 0 = A Po                                       | wer-on Reset occurred (mu | st be set in software after a Po   | wer-on Reset occurs)           |  |  |
| bit 0                                                                    | BOR: Bro                                       | own-out Reset Status bit  |                                    |                                |  |  |
|                                                                          | 1 = No B                                       | rown-out Reset occurred   |                                    |                                |  |  |
|                                                                          | 0 = A Bro<br>occu                              |                           | ist be set in software after a Po  | wer-on Reset or Brown-out Rese |  |  |

**Note 1:** Set BOREN<1:0> = 01 in the Configuration Word register for this bit to control the  $\overline{\text{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 high byte (PC<12:8>) is not directly readable or writable and comes from PCLATH. On any Reset, the PC is cleared. Figure 2-3 shows the two situations for the loading of the PC. The upper example in Figure 2-3 shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in Figure 2-3 shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

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



#### 2.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When performing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256-byte block). Refer to the Application Note *AN556, "Implementing a Table Read"* (DS00556).

#### 2.3.2 STACK

The PIC12F683 family has an 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 onto the stack when 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 instruction execution. PCLATH is not affected by a PUSH or POP operation. The stack operates as a circular 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 instructions/mnemonics called PUSH or POP. 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 possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the File Select Register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a no operation (although Status bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit of the STATUS register, as shown in Figure 2-4.

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

| EXAMPLE 2-1: | INDIRECT ADDRESSING |
|--------------|---------------------|
|--------------|---------------------|

|          | MOVLW | 0x20  | ;initialize pointer  |  |
|----------|-------|-------|----------------------|--|
|          | MOVWF | FSR   | ;to RAM              |  |
| NEXT     | CLRF  | INDF  | clear INDF register; |  |
|          | INCF  | FSR   | ;inc pointer         |  |
|          | BTFSS | FSR,4 | ;all done?           |  |
|          | GOTO  | NEXT  | ;no clear next       |  |
| CONTINUE |       |       | ;yes continue        |  |
|          |       |       |                      |  |





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

#### 3.1 Overview

The Oscillator module has a wide variety of clock 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 configured from external oscillators, quartz crystal resonators, ceramic resonators and Resistor-Capacitor (RC) circuits. In addition, 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 Medium Gain Crystal or Ceramic Resonator Oscillator mode.
- 4. HS High Gain Crystal or Ceramic Resonator mode.
- 5. RC External Resistor-Capacitor (RC) with FOSC/4 output on OSC2/CLKOUT.
- 6. RCIO External Resistor-Capacitor (RC) with I/O on OSC2/CLKOUT.
- 7. INTOSC Internal oscillator with Fosc/4 output on OSC2 and I/O on OSC1/CLKIN.
- 8. INTOSCIO Internal 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 clock can be generated from two internal oscillators. The HFINTOSC is a calibrated high-frequency oscillator. The LFINTOSC 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 clock and frequency selection options. The OSCCON register contains the following 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, read | 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 = 8 MHz                                                                                                                                                                                                        |
|         | 110 = 4 MHz (default)                                                                                                                                                                                              |
|         | 101 = 2  MHz                                                                                                                                                                                                       |
|         | 100 = 1  MHz                                                                                                                                                                                                       |
|         | 011 = 500 kHz                                                                                                                                                                                                      |
|         | 010 = 250  kHz                                                                                                                                                                                                     |
|         | 001 = 125  kHz                                                                                                                                                                                                     |
|         | 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 register</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 register                                                                                                                                           |
| Note 1. | Bit resets to '0' with Two-Speed Start-up and LP XT or HS selected as the Oscillator mode or Fail-Safe                                                                                                             |

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 Select (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 Oscillator Start-up Timer (OST) counts 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 switching between clock sources, a delay is required to allow the new clock to stabilize. These oscillator delays are shown in Table 3-1.

In order to minimize latency between external oscillator start-up and code execution, the Two-Speed Clock Start-up mode can be selected (see **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 External Clock (EC) mode allows an externally generated logic level as the system clock source. When operating in this mode, an external clock source is connected to the OSC1 input and the OSC2 is available for general purpose I/O. Figure 3-2 shows the pin 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 Power-on Reset (POR) or wake-up from Sleep. Because the PIC<sup>®</sup> MCU design is fully static, stopping the external clock input will have the effect of halting the device while leaving all data intact. Upon restarting the external clock, the device will resume operation as if no time had elapsed.

#### 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 or high gain setting of the internal inverter-amplifier to support various resonator types 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 kHz tuning-fork type crystals (watch crystals).

**XT** Oscillator mode selects the intermediate gain setting of the internal inverter-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 highest of the three modes. This mode is best suited for resonators that require a high drive setting.

Figure 3-3 and Figure 3-4 show typical circuits 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 type, package and manufacturer. The user should consult the manufacturer data sheets for specifications and recommended application.
  - 2: Always verify oscillator performance over the VDD and temperature range 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 rfPIC<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)





operation.

#### 3.4.4 EXTERNAL RC MODES

The external Resistor-Capacitor (RC) modes support the use of an external RC circuit. This allows the 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 mode, the RC circuit connects to OSC1. OSC2/CLKOUT outputs the RC oscillator frequency divided by 4. This signal may be used to provide a clock for external circuitry, synchronization, calibration, test or other application requirements. Figure 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 Oscillator module has two independent, internal oscillators that can be configured or selected as the system clock source.

- 1. The **HFINTOSC** (High-Frequency Internal 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 uncalibrated and operates at 31 kHz.

The system clock speed can be selected via software using the Internal Oscillator Frequency Select bits 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 OSCCON register. See **Section 3.6** "**Clock Switching**" for more information.

#### 3.5.1 INTOSC AND INTOSCIO MODES

The INTOSC and INTOSCIO modes configure the internal oscillators as the system clock source when the device is programmed using the oscillator selection or the FOSC<2:0> bits in the Configuration Word register (CONFIG). See Section 12.0 "Special Features of the CPU" for more information.

In **INTOSC** mode, OSC1/CLKIN is available for general purpose I/O. OSC2/CLKOUT outputs the selected internal oscillator frequency divided by 4. The CLKOUT signal may be used to provide a clock for external circuitry, synchronization, calibration, test or other 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 HFINTOSC can be altered 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 seven frequencies can be selected via software using the IRCF<2:0> bits of the OSCCON register. See **Section 3.5.4 "Frequency Select Bits (IRCF)**" 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 the OSCCON register  $\neq$  000. Then, set the System Clock Source (SCS) bit of the OSCCON register to '1' or enable Two-Speed Start-up by setting the IESO bit in the Configuration Word register (CONFIG) to '1'.

The HF Internal Oscillator (HTS) bit of the OSCCON register indicates whether the HFINTOSC is stable or not.