



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded - Microcontrollers</u>"

| Details                    |                                                                           |
|----------------------------|---------------------------------------------------------------------------|
| Product Status             | Active                                                                    |
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 20MHz                                                                     |
| Connectivity               | -                                                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 13                                                                        |
| Program Memory Size        | 1.75KB (1K x 14)                                                          |
| Program Memory Type        | OTP                                                                       |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                 |
| Data Converters            | A/D 4x8b                                                                  |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                            |
| Supplier Device Package    | 20-SSOP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c712-20-ss |

#### **Table of Contents**

| 1.0   | Device Overview                                 | 5    |
|-------|-------------------------------------------------|------|
| 2.0   | Memory Organization                             | 9    |
| 3.0   | I/O Ports                                       | . 21 |
| 4.0   | I/O Ports Timer0 Module                         | . 29 |
| 5.0   | Timer1 Module                                   | . 31 |
| 6.0   | Timer2 Module                                   | . 36 |
| 7.0   | Capture/Compare/PWM (CCP) Module(s)             | . 39 |
| 8.0   | Analog-to-Digital Converter (A/D) Module        |      |
| 9.0   | Special Features of the CPU                     |      |
| 10.0  | Instruction Set Summary                         | . 67 |
| 11.0  | Development Support  Electrical Characteristics | . 69 |
| 12.0  | Electrical Characteristics                      | . 73 |
| 13.0  | Packaging Information                           | . 89 |
| Revis | ion History                                     | . 95 |
| Conv  | ersion Considerations                           | . 95 |
|       | tion from Base-line to Mid-Range Devices        |      |
| Index |                                                 | . 97 |
| On-Li | ne Support                                      | 101  |
| Read  | er Response                                     | 102  |
| PIC1  | 6C712/716 Product Identification System         | 103  |
|       |                                                 |      |

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

## PIC16C712/716

TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

| Addr    | Name                    | Bit 7              | Bit 6                               | Bit 5        | Bit 4                             | Bit 3         | Bit 2           | Bit 1         | Bit 0     | Value on:<br>POR,<br>BOR | Value on<br>all other<br>Resets (4) |
|---------|-------------------------|--------------------|-------------------------------------|--------------|-----------------------------------|---------------|-----------------|---------------|-----------|--------------------------|-------------------------------------|
| Bank 1  |                         |                    |                                     |              |                                   |               |                 |               |           |                          |                                     |
| 80h     | INDF <sup>(1)</sup>     | Addressing         | this location                       | uses conten  | ts of FSR to ac                   | ldress data r | nemory (not     | a physical re | gister)   | 0000 0000                | 0000 0000                           |
| 81h     | OPTION_<br>REG          | RBPU               | INTEDG                              | T0CS         | T0SE                              | PSA           | PS2             | PS1           | PS0       | 1111 1111                | 1111 1111                           |
| 82h     | PCL <sup>(1)</sup>      | Program Co         | ounter's (PC)                       | Least Signif | ficant Byte                       |               |                 |               | 0000 0000 | 0000 0000                |                                     |
| 83h     | STATUS <sup>(1)</sup>   | IRP <sup>(4)</sup> | RP1 <sup>(4)</sup>                  | RP0          | TO                                | PD            | Z               | DC            | С         | rr01 1xxx                | rr0q quuu                           |
| 84h     | FSR <sup>(1)</sup>      | Indirect Data      | ndirect Data Memory Address Pointer |              |                                   |               |                 |               | xxxx xxxx | uuuu uuuu                |                                     |
| 85h     | TRISA                   | ı                  | ı                                   | _(7)         | (7) PORTA Data Direction Register |               |                 |               |           | x1 1111                  | x1 1111                             |
| 86h     | TRISB                   | PORTB Dat          | a Direction F                       | Register     |                                   |               |                 |               |           | 1111 1111                | 1111 1111                           |
| 87h     | TRISCCP                 | (7)                | (7)                                 | (7)          | (7)                               | (7)           | TCCP            | (7)           | TT1CK     | xxxx x1x1                | xxxx x1x1                           |
| 88h-89h | -                       | Unimpleme          | nted                                |              |                                   |               |                 |               |           | -                        | -                                   |
| 8Ah     | PCLATH <sup>(1,2)</sup> | _                  | _                                   | _            | Write Buffer fo                   | or the upper  | 5 bits of the F | Program Cou   | nter      | 0 0000                   | 0 0000                              |
| 8Bh     | INTCON <sup>(1)</sup>   | GIE                | PEIE                                | TOIE         | INTE                              | RBIE          | TOIF            | INTF          | RBIF      | 0000 000x                | 0000 000u                           |
| 8Ch     | PIE1                    | _                  | ADIE                                | _            | _                                 | _             | CCP1IE          | TMR2IE        | TMR1IE    | -0000                    | -0000                               |
| 8Dh     | -                       | Unimpleme          | nted                                |              |                                   |               |                 |               |           | -                        | -                                   |
| 8Eh     | PCON                    | _                  | _                                   | _            | _                                 | _             | _               | POR           | BOR       | qq                       | uu                                  |
| 8Fh-91h | _                       | Unimpleme          | nted                                |              |                                   |               |                 |               |           | -                        | -                                   |
| 92h     | PR2                     | Timer2 Peri        | od Register                         |              |                                   |               |                 |               |           | 1111 1111                | 1111 1111                           |
| 93h-9Eh |                         | Unimpleme          | nted                                |              |                                   |               |                 |               |           | _                        | -                                   |
| 9Fh     | ADCON1                  | _                  | _                                   | _            | _                                 | _             | PCFG2           | PCFG1         | PCFG0     | 000                      | 000                                 |

**Legend:** x = unknown, u = unchanged, q = value depends on condition, — = unimplemented, read as '0', Shaded locations are unimplemented, read as '0'.

- Note 1: These registers can be addressed from either bank.
  - 2: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for PC<12:8> whose contents are transferred to the upper byte of the program counter.
  - 3: Other (non Power-up) Resets include: external Reset through  $\overline{\text{MCLR}}$  and the Watchdog Timer Reset.
  - 4: The IRP and RP1 bits are reserved. Always maintain these bits clear.
  - 5: On any device Reset, these pins are configured as inputs.
  - 6: This is the value that will be in the port output latch.
  - 7: Reserved bits; Do Not Use.

## 2.2.2.2 OPTION\_REG Register

The OPTION\_REG register is a readable and writable register, which contains various control bits to configure the TMR0 prescaler/WDT postscaler (single assignable register known also as the prescaler), the External INT Interrupt, TMR0 and the weak pull-ups on PORTB.

**Note:** To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer.

## FIGURE 2-5: OPTION\_REG REGISTER (ADDRESS 81h)

|          |                              |                    |            |            | `                           | ,           |       |                                       |
|----------|------------------------------|--------------------|------------|------------|-----------------------------|-------------|-------|---------------------------------------|
| R/W-1    | R/W-1                        | R/W-1              | R/W-1      | R/W-1      | R/W-1                       | R/W-1       | R/W-1 |                                       |
| RBPU     | INTEDG                       | T0CS               | T0SE       | PSA        | PS2                         | PS1         | PS0   | R = Readable bit                      |
| bit7     |                              |                    |            |            |                             |             | bit0  | W = Writable bit                      |
|          |                              |                    |            |            |                             |             |       | U = Unimplemented bit,<br>read as '0' |
|          |                              |                    |            |            |                             |             |       | - n = Value at POR Reset              |
| bit 7:   | RBPU: PO                     |                    |            |            |                             |             |       |                                       |
|          | 1 = PORTI                    |                    |            |            | C. Calcondina and           | L. Cala l   |       |                                       |
|          |                              |                    |            | -          | lividual port               | latch value | es    |                                       |
| bit 6:   | INTEDG: Interru              |                    |            |            | nin                         |             |       |                                       |
|          | 0 = Interru                  |                    |            |            |                             |             |       |                                       |
| bit 5:   | TOCS: TMI                    | =                  |            |            | •                           |             |       |                                       |
|          | 1 = Transit                  |                    |            | •          |                             |             |       |                                       |
|          | 0 = Interna                  | l instruction      | on cycle o | clock (CLK | (OUT)                       |             |       |                                       |
| bit 4:   | TOSE: TM                     |                    |            |            |                             |             |       |                                       |
|          |                              |                    |            |            | on RA4/T00<br>on RA4/T00    |             |       |                                       |
| hit 2:   |                              |                    | •          |            | UII IXA <del>4</del> / I UX | oki bili    |       |                                       |
| bit 3:   | <b>PSA</b> : Pres 1 = Presca |                    |            |            |                             |             |       |                                       |
|          | 0 = Presca                   |                    | •          |            | module                      |             |       |                                       |
| bit 2-0: | PS2:PS0:                     | Prescaler          | Rate Sel   | ect bits   |                             |             |       |                                       |
|          | Bit Value                    | TMR0 Ra            | ate WD     | Γ Rate     |                             |             |       |                                       |
|          | 000                          | 1:2                | 1:         |            |                             |             |       |                                       |
|          | 001<br>010                   | 1:4<br>1:8         | 1:         |            |                             |             |       |                                       |
|          | 010                          | 1:8                | 1:         |            |                             |             |       |                                       |
|          | 100                          | 1:32               |            | 16         |                             |             |       |                                       |
|          | 101                          | 1:64               |            | 32         |                             |             |       |                                       |
|          | 110<br>111                   | 1 : 128<br>1 : 256 | · .        | 64<br>128  |                             |             |       |                                       |
|          | 111                          | 1 : 250            | )   '.     | 120        |                             |             |       |                                       |

#### 3.0 I/O PORTS

Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Additional information on I/O ports may be found in the PIC<sup>®</sup> Mid-Range Reference Manual, (DS33023).

### 3.1 PORTA and the TRISA Register

PORTA is a 5-bit wide bidirectional port. The corresponding data direction register is TRISA. Setting a TRISA bit (=1) will make the corresponding PORTA pin an input, (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISA bit (=0) will make the corresponding PORTA pin an output, (i.e., put the contents of the output latch on the selected pin).

Reading the PORTA register reads the status of the pins whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, the value is modified, and then written to the port data latch.

Pin RA4 is multiplexed with the Timer0 module clock input to become the RA4/T0CKI pin. The RA4/T0CKI pin is a Schmitt Trigger input and an open drain output. All other RA port pins have TTL input levels and full CMOS output drivers.

PORTA pins, RA3:0, are multiplexed with analog inputs and analog VREF input. The operation of each pin is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register1).

**Note:** On a Power-on Reset, these pins are configured as analog inputs and read as '0'.

The TRISA register controls the direction of the RA pins, even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs.

#### **EXAMPLE 3-1: INITIALIZING PORTA**

| DOE   | CHIAMIIC DDO |                         |
|-------|--------------|-------------------------|
| BCF   | STATUS, RP0  | ;                       |
| CLRF  | PORTA        | ; Initialize PORTA by   |
|       |              | ; clearing output       |
|       |              | ; data latches          |
| BSF   | STATUS, RPO  | ; Select Bank 1         |
| MOVLW | 0xEF         | ; Value used to         |
|       |              | ; initialize data       |
|       |              | ; direction             |
| MOVWF | TRISA        | ; Set RA<3:0> as inputs |
|       |              | ; RA<4> as outputs      |
| BCF   | STATUS, RPO  | ; Return to Bank 0      |

FIGURE 3-5: BLOCK DIAGRAM OF RB2/T10SI PIN



#### FIGURE 3-6: BLOCK DIAGRAM OF RB3/CCP1 PIN



FIGURE 3-7: BLOCK DIAGRAM OF RB7:RB4 PINS



TABLE 3-3: PORTB FUNCTIONS

| Name                | Bit#  | Buffer                | Function                                                                                                                                                        |
|---------------------|-------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RB0/INT             | bit 0 | TTL/ST <sup>(1)</sup> | Input/output pin or external interrupt input. Internal software programmable weak pull-up.                                                                      |
| RB1/T1OS0/<br>T1CKI | bit 1 | TTL/ST <sup>(1)</sup> | Input/output pin or Timer1 oscillator output, or Timer1 clock input. Internal software programmable weak pull-up. See Timer1 section for detailed operation.    |
| RB2/T1OSI           | bit 2 | TTL/ST <sup>(1)</sup> | Input/output pin or Timer1 oscillator input. Internal software programmable weak pull-up. See Timer1 section for detailed operation.                            |
| RB3/CCP1            | bit 3 | TTL/ST <sup>(1)</sup> | Input/output pin or Capture 1 input, or Compare 1 output, or PWM1 output. Internal software programmable weak pull-up. See CCP1 section for detailed operation. |
| RB4                 | bit 4 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                                       |
| RB5                 | bit 5 | TTL                   | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up.                                                                       |
| RB6                 | bit 6 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up. Serial programming clock.                                             |
| RB7                 | bit 7 | TTL/ST <sup>(2)</sup> | Input/output pin (with interrupt-on-change). Internal software programmable weak pull-up. Serial programming data.                                              |

**Legend:** TTL = TTL input, ST = Schmitt Trigger input

Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt or peripheral input.

2: This buffer is a Schmitt Trigger input when used in Serial Programming mode.

## 4.2.1 SWITCHING PRESCALER ASSIGNMENT

The prescaler assignment is fully under software control (i.e., it can be changed "on the fly" during program execution).

Note: To avoid an unintended device Reset, a specific instruction sequence (shown in the PIC® Mid-Range Reference Manual, DS33023) must be executed when changing the prescaler assignment from Timer0 to the WDT. This sequence must be followed even if the WDT is disabled.

## 4.3 Timer0 Interrupt

The TMR0 interrupt is generated when the TMR0 register overflows from FFh to 00h. This overflow sets bit T0IF (INTCON<2>). The interrupt can be masked by clearing bit T0IE (INTCON<5>). Bit T0IF must be cleared in software by the Timer0 module Interrupt Service Routine before re-enabling this interrupt. The TMR0 interrupt cannot awaken the processor from Sleep since the timer is shut off during Sleep.

#### FIGURE 4-2: BLOCK DIAGRAM OF THE TIMERO/WDT PRESCALER



TABLE 4-1: REGISTERS ASSOCIATED WITH TIMER0

| IABLE   | ADEL 4 1. REGIOTERO AGGOGIATED WITH HIMERO |        |                         |       |       |       |          |           |        |                          |                           |
|---------|--------------------------------------------|--------|-------------------------|-------|-------|-------|----------|-----------|--------|--------------------------|---------------------------|
| Address | Name                                       | Bit 7  | Bit 6                   | Bit 5 | Bit 4 | Bit 3 | Bit 2    | Bit 1     | Bit 0  | Value on:<br>POR,<br>BOR | Value on all other Resets |
| 01h     | TMR0                                       | Timer0 | imer0 Module's Register |       |       |       |          |           |        | xxxx xxxx                | uuuu uuuu                 |
| 0Bh,8Bh | INTCON                                     | GIE    | PEIE                    | TOIE  | INTE  | RBIE  | TOIF     | INTF      | RBIF   | 0000 000x                | 0000 000u                 |
| 81h     | OPTION_REG                                 | RBPU   | INTEDG                  | T0CS  | T0SE  | PSA   | PS2      | PS1       | PS0    | 1111 1111                | 1111 1111                 |
| 85h     | TRISA                                      | _      | _                       | (1)   | Bit 4 | PORTA | Data Dir | ection Re | gister | 11 1111                  | 11 1111                   |

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

Note 1: Reserved bit; Do Not Use.

#### FIGURE 5-2: TIMER1 BLOCK DIAGRAM



Note 1: When the T1OSCEN bit is cleared, the inverter and feedback resistor are turned off. This eliminates power drain.

# 5.2 Timer1 Module and PORTB Operation

When Timer1 is configured as timer running from the main oscillator, PORTB<2:1> operate as normal I/O lines. When Timer1 is configured to function as a counter however, the clock source selection may affect the operation of PORTB<2:1>. Multiplexing details of the Timer1 clock selection on PORTB are shown in Figure 3-4 and Figure 3-5.

The clock source for Timer1 in the Counter mode can be from one of the following:

- External circuit connected to the RB1/T1OSO/ T1CKI pin
- 2. Firmware controlled DATACCP<0> bit, DT1CKI
- 3. Timer1 oscillator

Table 5-1 shows the details of Timer1 mode selections, control bit settings, TMR1 and PORTB operations.

### 6.1 Timer2 Operation

Timer2 can be used as the PWM time base for PWM mode of the CCP module.

The TMR2 register is readable and writable, and is cleared on any device Reset.

The input clock (Fosc/4) has a prescale option of 1:1, 1:4 or 1:16, selected by control bits T2CKPS1:T2CKPS0 (T2CON<1:0>).

The match output of TMR2 goes through a 4-bit postscaler (which gives a 1:1 to 1:16 scaling inclusive) to generate a TMR2 interrupt (latched in flag bit TMR2IF, (PIR1<1>)).

The prescaler and postscaler counters are cleared when any of the following occurs:

- · a write to the TMR2 register
- a write to the T2CON register
- any device Reset (Power-on Reset, MCLR Reset, Watchdog Timer Reset, or Brown-out Reset)

TMR2 is not cleared when T2CON is written.

#### 6.2 Timer2 Interrupt

The Timer2 module has an 8-bit period register PR2. Timer2 increments from 00h until it matches PR2 and then resets to 00h on the next increment cycle. PR2 is a readable and writable register. The PR2 register is initialized to FFh upon Reset.

#### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER2 AS A TIMER/COUNTER

| Address | Name                           | Bit 7      | Bit 6          | Bit 5   | Bit 4   | Bit 3   | Bit 2  | Bit 1     | Bit 0     | Value on<br>POR,<br>BOR | Value on<br>all other<br>Resets |
|---------|--------------------------------|------------|----------------|---------|---------|---------|--------|-----------|-----------|-------------------------|---------------------------------|
| 0Bh,8Bh | INTCON                         | GIE        | PEIE           | TOIE    | INTE    | RBIE    | TOIF   | INTF      | RBIF      | 0000 000x               | 0000 000u                       |
| 0Ch     | PIR1                           | 1          | ADIF           | -       | -       | -       | CCP1IF | TMR2IF    | TMR1IF    | -00000                  | 0000 -000                       |
| 8Ch     | PIE1                           | -          | ADIE           | _       | _       | _       | CCP1IE | TMR2IE    | TMR1IE    | -0000                   | 0000 -000                       |
| 11h     | TMR2                           | Timer2 Mod | lule's Registe | er      |         |         |        |           |           | 0000 0000               | 0000 0000                       |
| 12h     | T2CON                          | _          | TOUTPS3        | TOUTPS2 | TOUTPS1 | TOUTPS0 | TMR2ON | T2CKPS1   | T2CKPS0   | -000 0000               | -000 0000                       |
| 92h     | 92h PR2 Timer2 Period Register |            |                |         |         |         |        | 1111 1111 | 1111 1111 |                         |                                 |

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

# 7.4 CCP1 Module and PORTB Operation

When the CCP module is disabled, PORTB<3> operates as a normal I/O pin. When the CCP module is enabled, PORTB<3> operation is affected. Multiplexing details of the CCP1 module are shown on PORTB<3>, refer to Figure 3.6.

Table 7-5 below shows the effects of the CCP module operation on PORTB<3>

TABLE 7-5: CCP1 MODULE AND PORTB OPERATION

| CCP1<br>Module<br>Mode | Control Bits                     | CCP1 Module Operation                                                                                                                                   | PORTB<3> Operation                                                                                                                  |
|------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Off                    | CCP1CON =xx 0000                 | Off                                                                                                                                                     | PORTB<3> functions as normal I/O.                                                                                                   |
| Capture                | CCP1CON =xx 01xx<br>TRISCCP =1-x | The CCP1 module will capture an event on the RB3/CCP1 pin which is driven by an external circuit. The DCCP bit can read the signal on the RB3/CCP1 pin. | PORTB<3> always reads '0' when configured as input. If PORTB<3> is configured as output, reading PORTB<3> will read the data latch. |
|                        | CCP1CON =xx 01xx<br>TRISCCP =0-x | The CCP1 module will capture an event on the RB3/CCP1 pin which is driven by the DCCP bit. The DCCP bit can read the signal on the RB3/CCP1 pin.        | Writing to PORTB<3> will always store the result in the data latch, but it does not drive the RB3/CCP1 pin.                         |
| Compare                | CCP1CON =xx 10xx<br>TRISCCP =0-x | The CCP1 module produces an output on the RB3/CCP1 pin when a compare event occurs. The DCCP bit can read the signal on the RB3/CCP1 pin.               |                                                                                                                                     |
| PWM                    | CCP1CON =xx 11xx<br>TRISCCP =0-x | The CCP1 module produces the PWM signal on the RB3/CCP1 pin. The DCCP bit can read the signal on the RB3/CCP1 pin.                                      |                                                                                                                                     |

## FIGURE 8-2: ADCON1 REGISTER (ADDRESS 9Fh)

|     |     |     |     |     | PCFG2 | DCEC1 | DCEC0 |
|-----|-----|-----|-----|-----|-------|-------|-------|
| U-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 |

bit7

R = Readable bit

W = Writable bit

bit0

U = Unimplemented bit, read as '0'

-n = Value at POR Reset

bit 7-3: Unimplemented: Read as '0'

bit 2-0: PCFG2:PCFG0: A/D Port Configuration Control bits

| PCFG2:PCFG0 | RA0 | RA1 | RA2 | RA3  | VREF |
|-------------|-----|-----|-----|------|------|
| 0x0         | Α   | Α   | Α   | Α    | Vdd  |
| 0x1         | Α   | Α   | Α   | VREF | RA3  |
| 100         | Α   | Α   | D   | Α    | VDD  |
| 101         | Α   | Α   | D   | VREF | RA3  |
| 11x         | D   | D   | D   | D    | Vdd  |

A = Analog input

D = Digital I/O

## 9.9 Power Control/Status Register (PCON)

The Power Control/Status Register, PCON has two bits.

Bit 0 is Brown-out Reset Status bit, BOR. If the BODEN Configuration bit is set, BOR is '1' on Power-on Reset. If the BODEN Configuration bit is clear, BOR is unknown on Power-on Reset.

The BOR Status bit is a "don't care" and is not necessarily predictable if the brown-out circuit is disabled (the BODEN Configuration bit is clear). BOR must then be set by the user and checked on subsequent Resets to see if it is clear, indicating a brown-out has occurred.

Bit 1 is POR (Power-on Reset Status bit). It is cleared on a Power-on Reset and unaffected otherwise. The user must set this bit following a Power-on Reset.

TABLE 9-3: TIME-OUT IN VARIOUS SITUATIONS

| Oscillator Configuration | Power            | -up       | Brown-out        | Wake-up from |  |
|--------------------------|------------------|-----------|------------------|--------------|--|
| Oscillator Configuration | PWRTE = 0        | PWRTE = 1 | Brown-out        | Sleep        |  |
| XT, HS, LP               | 72 ms + 1024Tosc | 1024Tosc  | 72 ms + 1024Tosc | 1024Tosc     |  |
| RC                       | 72 ms            |           | 72 ms            | _            |  |

TABLE 9-4: STATUS BITS AND THEIR SIGNIFICANCE

| POR | BOR | TO | PD |                                                         |
|-----|-----|----|----|---------------------------------------------------------|
| 0   | х   | 1  | 1  | Power-on Reset                                          |
| 0   | х   | 0  | х  | Illegal, TO is set on POR                               |
| 0   | х   | х  | 0  | Illegal, PD is set on POR                               |
| 1   | 0   | 1  | 1  | Brown-out Reset                                         |
| 1   | 1   | 0  | 1  | WDT Reset                                               |
| 1   | 1   | 0  | 0  | WDT Wake-up                                             |
| 1   | 1   | u  | u  | MCLR Reset during normal operation                      |
| 1   | 1   | 1  | 0  | MCLR Reset during Sleep or interrupt wake-up from Sleep |

TABLE 9-5: RESET CONDITION FOR SPECIAL REGISTERS

| Condition                          | Program<br>Counter    | STATUS<br>Register | PCON<br>Register |
|------------------------------------|-----------------------|--------------------|------------------|
| Power-on Reset                     | 000h                  | 0001 1xxx          | 0x               |
| MCLR Reset during normal operation | 000h                  | 000u uuuu          | uu               |
| MCLR Reset during Sleep            | 000h                  | 0001 0uuu          | uu               |
| WDT Reset                          | 000h                  | 0000 1uuu          | uu               |
| WDT Wake-up                        | PC + 1                | uuu0 0uuu          | uu               |
| Brown-out Reset                    | 000h                  | 0001 1uuu          | u0               |
| Interrupt wake-up from Sleep       | PC + 1 <sup>(1)</sup> | uuu1 0uuu          | uu               |

**Legend:** u = unchanged, x = unknown, - = unimplemented bit read as '0'.

**Note 1:** When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).

## PIC16C712/716

### 9.16 In-Circuit Serial Programming™

PIC16CXXX microcontrollers can be serially programmed while in the end application circuit. This is simply done with two lines for clock and data, and three other lines for power, ground and the programming voltage. This allows customers to manufacture boards with unprogrammed devices, and then program the microcontroller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

For complete details on serial programming, please refer to the In-Circuit Serial Programming<sup>TM</sup> (ICSP<sup>TM</sup>) Guide, (DS30277).

#### 11.0 DEVELOPMENT SUPPORT

The PIC<sup>®</sup> microcontrollers are supported with a full range of hardware and software development tools:

- · Integrated Development Environment
  - MPLAB® IDE Software
- · Assemblers/Compilers/Linkers
  - MPASM™ Assembler
  - MPLAB C18 and MPLAB C30 C Compilers
  - MPLINK<sup>TM</sup> Object Linker/ MPLIB<sup>TM</sup> Object Librarian
  - MPLAB ASM30 Assembler/Linker/Library
- Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB ICE 4000 In-Circuit Emulator
- · In-Circuit Debugger
  - MPLAB ICD 2
- · Device Programmers
  - PICSTART® Plus Development Programmer
  - MPLAB PM3 Device Programmer
- Low-Cost Demonstration and Development Boards and Evaluation Kits

## 11.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit micro-controller market. The MPLAB IDE is a Windows® operating system-based application that contains:

- A single graphical interface to all debugging tools
  - Simulator
  - Programmer (sold separately)
  - Emulator (sold separately)
  - In-Circuit Debugger (sold separately)
- · A full-featured editor with color-coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- · High-level source code debugging
- Visual device initializer for easy register initialization
- · Mouse over variable inspection
- Drag and drop variables from source to watch windows
- · Extensive on-line help
- Integration of select third party tools, such as HI-TECH Software C Compilers and IAR C Compilers

The MPLAB IDE allows you to:

- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PIC MCU emulator and simulator tools (automatically updates all project information)
- · Debug using:
  - Source files (assembly or C)
  - Mixed assembly and C
  - Machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost-effective simulators, through low-cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increased flexibility and power.

# 11.11 PICSTART Plus Development Programmer

The PICSTART Plus Development Programmer is an easy-to-use, low-cost, prototype programmer. It connects to the PC via a COM (RS-232) port. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. The PICSTART Plus Development Programmer supports most PIC devices in DIP packages up to 40 pins. Larger pin count devices, such as the PIC16C92X and PIC17C76X, may be supported with an adapter socket. The PICSTART Plus Development Programmer is CE compliant.

## 11.12 Demonstration, Development and Evaluation Boards

A wide variety of demonstration, development and evaluation boards for various PIC MCUs and dsPIC DSCs allows quick application development on fully functional systems. Most boards include prototyping areas for adding custom circuitry and provide application firmware and source code for examination and modification.

The boards support a variety of features, including LEDs, temperature sensors, switches, speakers, RS-232 interfaces, LCD displays, potentiometers and additional EEPROM memory.

The demonstration and development boards can be used in teaching environments, for prototyping custom circuits and for learning about various microcontroller applications.

In addition to the PICDEM™ and dsPICDEM™ demonstration/development board series of circuits, Microchip has a line of evaluation kits and demonstration software for analog filter design, KEELOQ® security ICs, CAN, IrDA®, PowerSmart® battery management, SEEVAL® evaluation system, Sigma-Delta ADC, flow rate sensing, plus many more.

Check the Microchip web page (www.microchip.com) and the latest "Product Selector Guide" (DS00148) for the complete list of demonstration, development and evaluation kits.

FIGURE 12-1: PIC16C712/716 VOLTAGE-FREQUENCY GRAPH,  $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ 





### 13.0 PACKAGING INFORMATION

### 13.1 Package Marking Information

18-Lead PDIP



18-Lead CERDIP Windowed



18-Lead SOIC (.300")



20-Lead SSOP



Example



Example



Example



Example



Legend: XX...X Customer-specific information
Year code (last digit of calendar year)
YY Year code (last 2 digits of calendar year)
WW Week code (week of January 1 is week '01')
NNN Alphanumeric traceability code

© Pb-free JEDEC designator for Matte Tin (Sn)
\* This package is Pb-free. The Pb-free JEDEC designator (@3)
can be found on the outer packaging for this package.

In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information.

## 18-Lead Ceramic Dual In-line with Window (JW) - 300 mil (CERDIP)

For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                            |     | INCHES* |      | MILLIMETERS |       |       |       |
|----------------------------|-----|---------|------|-------------|-------|-------|-------|
| Dimensio                   | MIN | NOM     | MAX  | MIN         | NOM   | MAX   |       |
| Number of Pins             | n   |         | 18   |             |       | 18    |       |
| Pitch                      | р   |         | .100 |             |       | 2.54  |       |
| Top to Seating Plane       | Α   | .170    | .183 | .195        | 4.32  | 4.64  | 4.95  |
| Ceramic Package Height     | A2  | .155    | .160 | .165        | 3.94  | 4.06  | 4.19  |
| Standoff                   | A1  | .015    | .023 | .030        | 0.38  | 0.57  | 0.76  |
| Shoulder to Shoulder Width | Е   | .300    | .313 | .325        | 7.62  | 7.94  | 8.26  |
| Ceramic Pkg. Width         | E1  | .285    | .290 | .295        | 7.24  | 7.37  | 7.49  |
| Overall Length             | D   | .880    | .900 | .920        | 22.35 | 22.86 | 23.37 |
| Tip to Seating Plane       | L   | .125    | .138 | .150        | 3.18  | 3.49  | 3.81  |
| Lead Thickness             | С   | .008    | .010 | .012        | 0.20  | 0.25  | 0.30  |
| Upper Lead Width           | B1  | .050    | .055 | .060        | 1.27  | 1.40  | 1.52  |
| Lower Lead Width           | В   | .016    | .019 | .021        | 0.41  | 0.47  | 0.53  |
| Overall Row Spacing §      | eB  | .345    | .385 | .425        | 8.76  | 9.78  | 10.80 |
| Window Width               | W1  | .130    | .140 | .150        | 3.30  | 3.56  | 3.81  |
| Window Length              | W2  | .190    | .200 | .210        | 4.83  | 5.08  | 5.33  |

<sup>\*</sup> Controlling Parameter § Significant Characteristic JEDEC Equivalent: MO-036 Drawing No. C04-010

# PIC16C712/716

| Interrupt Sources                                         | . 51. 61  | XT                                                    | 53. | 58  |
|-----------------------------------------------------------|-----------|-------------------------------------------------------|-----|-----|
| A/D Conversion Complete                                   |           | Oscillator, Timer1                                    | ,   |     |
| Block Diagram                                             |           | Oscillator, WDT                                       |     |     |
| Capture Complete (CCP)                                    |           | Р                                                     |     |     |
| Compare Complete (CCP)                                    | 41        | •                                                     |     |     |
| Interrupt-on-Change (RB7:RB4)                             |           | Packaging                                             |     |     |
| RB0/INT Pin, External                                     |           | Details                                               |     |     |
| TMR0 Overflow                                             |           | Paging, Program Memory                                |     |     |
| TMR1 Overflow                                             |           | PCON Register                                         |     |     |
| TMR2 to PR2 Match                                         |           | BOR BitPOR Bit                                        |     |     |
| TMR2 to PR2 Match (PWM)                                   |           | PICSTART Plus Development Programmer                  |     |     |
| Interrupts, Context Saving During Interrupts, Enable Bits | 62        | PIE1 Register                                         |     |     |
| A/D Converter Enable (ADIE Bit)                           | 16        | ADIE Bit                                              |     |     |
| CCP1 Enable (CCP1IE Bit)                                  |           | CCP1IE Bit                                            |     |     |
| Global Interrupt Enable (GIE Bit)                         |           | TMR1IE Bit                                            |     |     |
| Interrupt-on-Change (RB7:RB4) Enable                      | ,         | TMR2IE Bit                                            |     |     |
| (RBIE Bit)                                                | 15, 62    | Pin Functions                                         |     |     |
| Peripheral Interrupt Enable (PEIE Bit)                    |           | MCLR/VPP                                              |     | . 6 |
| RB0/INT Enable (INTE Bit)                                 | 15        | RA0/AN0                                               |     | . 6 |
| TMR0 Overflow Enable (T0IE Bit)                           | 15        | RA1/AN1                                               |     |     |
| TMR1 Overflow Enable (TMR1IE Bit)                         |           | RA2/AN2                                               |     |     |
| TMR2 to PR2 Match Enable (TMR2IE Bit)                     | 16        | RA3/AN3/VREF                                          |     |     |
| Interrupts, Flag Bits                                     |           | RA4/T0CKI                                             |     |     |
| A/D Converter Flag (ADIF Bit)                             |           | RB0/INT                                               |     |     |
| CCP1 Flag (CCP1IF Bit)                                    | 7, 40, 41 | RB1<br>RB2                                            |     |     |
| Interrupt-on-Change (RB7:RB4) Flag                        | - 04 60   | RB3                                                   |     |     |
| (RBIF Bit)                                                |           | RB4                                                   |     |     |
| TMR0 Overflow Flag (T0IF Bit)                             |           | RB5                                                   |     |     |
| TMR1 Overflow Flag (TMR1IF Bit)                           |           | RB6                                                   |     |     |
| TMR2 to PR2 Match Flag (TMR2IF Bit)                       |           | RB7                                                   |     |     |
|                                                           |           | VDD                                                   |     |     |
| M                                                         |           | Vss                                                   |     | . 7 |
| Master Clear (MCLR)                                       |           | Pinout Descriptions                                   |     |     |
| MCLR Reset, Normal Operation 54                           | 4, 58, 59 | PIC16C712/716 Pinout Description                      |     | 6   |
| MCLR Reset, Sleep                                         |           | PIR1 Register                                         |     |     |
| MCLR Reset, Sleep                                         | 54, 58    | ADIF Bit                                              |     |     |
| Memory Organization                                       | 40        | CCP1IF Bit                                            |     |     |
| Data Memory                                               |           | TMR1IF Bit                                            |     |     |
| Program Memory Microchip Internet Web Site                |           | TMR2IF Bit<br>Pointer, FSR                            |     |     |
| MPLAB ASM30 Assembler, Linker, Librarian                  |           | POR. See Power-on Reset                               |     | 20  |
| MPLAB ICD 2 In-Circuit Debugger                           |           | PORTA                                                 |     |     |
| MPLAB ICE 2000 High-Performance Universal                 |           | Initialization                                        |     | 21  |
| In-Circuit Emulator                                       | 71        | PORTA Register                                        |     |     |
| MPLAB ICE 4000 High-Performance Universal                 |           | RA3:RA0 Port Pins                                     |     |     |
| In-Circuit Emulator                                       | 71        | RA4/T0CKI Pin                                         |     | 22  |
| MPLAB Integrated Development Environment Softwa           | are 69    | TRISA Register                                        | 12, | 21  |
| MPLAB PM3 Device Programmer                               | 71        | PORTB                                                 |     |     |
| MPLINK Object Linker/MPLIB Object Librarian               | 70        | Block Diagram of RB1/T1OSO/T1CKI Pin                  |     |     |
| 0                                                         |           | Block Diagram of RB2/T10SI Pin                        |     | 25  |
|                                                           | 67        | Block Diagram of RB3/CCP1 Pin                         |     |     |
| OPCODE Field Descriptions                                 |           | Initialization                                        |     |     |
| OPTION_REG Register INTEDG Bit                            |           | PORTB Register                                        |     |     |
| PS2:PS0 Bits                                              |           | Pull-up Enable (RBPU Bit)                             |     |     |
| PSA Bit                                                   |           | RB0/INT Edge Select (INTEDG Bit)RB0/INT Pin, External |     |     |
| RBPU Bit                                                  |           | RB3:RB0 Port Pins                                     |     |     |
| TOCS Bit                                                  |           | RB7:RB4 Interrupt-on-Change                           |     |     |
| TOSE Bit                                                  |           | RB7:RB4 Interrupt-on-Change Enable (RBIE Bit)         |     |     |
| Oscillator Configuration                                  |           | RB7:RB4 Interrupt-on-Change Flag                      | ,   |     |
| HS                                                        |           | (RBIF Bit)                                            | 24, | 62  |
| LP                                                        |           | RB7:RB4 Port Pins                                     |     |     |
| RC 53                                                     |           | TRISB Register                                        | 12, | 23  |
| Selection (FOSC1:FOSC0 Bits)                              | 52        |                                                       |     |     |

#### THE MICROCHIP WEB SITE

Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information:

- Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- General Technical Support Frequently Asked Questions (FAQ), technical support requests, online discussion groups, Microchip consultant program member listing
- Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

# CUSTOMER CHANGE NOTIFICATION SERVICE

Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions.

#### **CUSTOMER SUPPORT**

Users of Microchip products can receive assistance through several channels:

- · Distributor or Representative
- · Local Sales Office
- · Field Application Engineer (FAE)
- · Technical Support

Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document.

Technical support is available through the web site at: http://microchip.com/support