



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 -</u> <u>Microcontrollers</u>"

#### Details

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 4MHz                                                                        |
| Connectivity               | -                                                                           |
| Peripherals                | Brown-out Detect/Reset, PWM, WDT                                            |
| Number of I/O              | 13                                                                          |
| Program Memory Size        | 1.75KB (1K x 14)                                                            |
| Program Memory Type        | ОТР                                                                         |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 68 × 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V                                                                   |
| Data Converters            | A/D 4x8b                                                                    |
| Oscillator Type            | External                                                                    |
| Operating Temperature      | -40°C ~ 125°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/pic16lc711-04e-ss |
|                            |                                                                             |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# **Table of Contents**

| 1.0   | General Description                                                     |      |
|-------|-------------------------------------------------------------------------|------|
| 2.0   | PIC16C71X Device Varieties                                              | 5    |
| 3.0   | Architectural Overview                                                  |      |
| 4.0   | Memory Organization                                                     | . 11 |
| 5.0   | I/O Ports                                                               | . 25 |
| 6.0   | Timer0 Module                                                           | . 31 |
| 7.0   | Analog-to-Digital Converter (A/D) Module                                | . 37 |
| 8.0   | Special Features of the CPU                                             | . 47 |
| 9.0   | Instruction Set Summary                                                 | . 69 |
| 10.0  | Development Support                                                     | . 85 |
| 11.0  | Electrical Characteristics for PIC16C710 and PIC16C711                  |      |
| 12.0  | DC and AC Characteristics Graphs and Tables for PIC16C710 and PIC16C711 | 101  |
| 13.0  | Electrical Characteristics for PIC16C715                                |      |
| 14.0  | DC and AC Characteristics Graphs and Tables for PIC16C715               |      |
| 15.0  | Electrical Characteristics for PIC16C71                                 | 135  |
| 16.0  | DC and AC Characteristics Graphs and Tables for PIC16C71                | 147  |
| 17.0  | Packaging Information                                                   | 155  |
| Appen | dix A:                                                                  | 161  |
|       | dix B: Compatibility                                                    |      |
| Appen | dix C: What's New                                                       | 162  |
|       | dix D: What's Changed                                                   |      |
|       | -                                                                       |      |
| PIC16 | C71X Product Identification System                                      | 173  |
|       | ·                                                                       |      |

# To Our Valued Customers

We constantly strive to improve the quality of all our products and documentation. We have spent an exceptional amount of time to ensure that these documents are correct. However, we realize that we may have missed a few things. If you find any information that is missing or appears in error, please use the reader response form in the back of this data sheet to inform us. We appreciate your assistance in making this a better document.

# 2.0 PIC16C71X DEVICE VARIETIES

A variety of frequency ranges and packaging options are available. Depending on application and production requirements, the proper device option can be selected using the information in the PIC16C71X Product Identification System section at the end of this data sheet. When placing orders, please use that page of the data sheet to specify the correct part number.

For the PIC16C71X family, there are two device "types" as indicated in the device number:

- 1. **C**, as in PIC16**C**71. These devices have EPROM type memory and operate over the standard voltage range.
- 2. LC, as in PIC16LC71. These devices have EPROM type memory and operate over an extended voltage range.

### 2.1 UV Erasable Devices

The UV erasable version, offered in CERDIP package is optimal for prototype development and pilot programs. This version can be erased and reprogrammed to any of the oscillator modes.

Microchip's PICSTART<sup>®</sup> Plus and PRO MATE<sup>®</sup> II programmers both support programming of the PIC16C71X.

### 2.2 <u>One-Time-Programmable (OTP)</u> <u>Devices</u>

The availability of OTP devices is especially useful for customers who need the flexibility for frequent code updates and small volume applications.

The OTP devices, packaged in plastic packages, permit the user to program them once. In addition to the program memory, the configuration bits must also be programmed.

# 2.3 <u>Quick-Turnaround-Production (QTP)</u> <u>Devices</u>

Microchip offers a QTP Programming Service for factory production orders. This service is made available for users who choose not to program a medium to high quantity of units and whose code patterns have stabilized. The devices are identical to the OTP devices but with all EPROM locations and configuration options already programmed by the factory. Certain code and prototype verification procedures apply before production shipments are available. Please contact your local Microchip Technology sales office for more details.

# 2.4 <u>Serialized Quick-Turnaround</u> <u>Production (SQTP<sup>SM</sup>) Devices</u>

Microchip offers a unique programming service where a few user-defined locations in each device are programmed with different serial numbers. The serial numbers may be random, pseudo-random, or sequential.

Serial programming allows each device to have a unique number which can serve as an entry-code, password, or ID number.

#### 4.2.2.2 OPTION REGISTER

# Applicable Devices 710 71 711 715

The OPTION register is a readable and writable register which contains various control bits to configure the TMR0/WDT prescaler, the External INT Interrupt, TMR0, and the weak pull-ups on PORTB.

## FIGURE 4-8: OPTION REGISTER (ADDRESS 81h, 181h)

| 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                                                         | TOCS        | T0SE        | PSA        | PS2        | PS1     | PS0   | R = Readable bit                                          |  |  |  |  |  |  |
| bit7     | · · ·                                                          |             |             |            |            |         | bit0  | W = Writable bit<br>U = Unimplemented bit,<br>read as '0' |  |  |  |  |  |  |
|          | - n = Value at POR reset                                       |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
| bit 7:   | RBPU: PORTB Pull-up Enable bit                                 |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 1 = PORTB pull-ups are disabled                                |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 0 = PORTB pull-ups are enabled by individual port latch values |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
| bit 6:   | INTEDG: Interrupt Edge Select bit                              |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 1 = Interrupt on rising edge of RB0/INT pin                    |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 0 = Interrupt on falling edge of RB0/INT pin                   |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
| bit 5:   | TOCS: TM                                                       | R0 Clock    | Source S    | elect bit  |            |         |       |                                                           |  |  |  |  |  |  |
|          | 1 = Transit                                                    |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 0 = Interna                                                    | al instruct | ion cycle ( | clock (CLk | (OUT)      |         |       |                                                           |  |  |  |  |  |  |
| bit 4:   | TOSE: TM                                                       |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          |                                                                |             |             |            | on RA4/T00 |         |       |                                                           |  |  |  |  |  |  |
|          | 0 = Increm                                                     | ent on lo   | w-to-high   | transition | on RA4/T00 | JKI pin |       |                                                           |  |  |  |  |  |  |
| bit 3:   | PSA: Pres                                                      |             | 0           |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 1 = Presca<br>0 = Presca                                       |             |             |            | modulo     |         |       |                                                           |  |  |  |  |  |  |
|          |                                                                |             | •           |            | module     |         |       |                                                           |  |  |  |  |  |  |
| bit 2-0: | PS2:PS0:                                                       | Prescale    | r Rate Sel  | lect bits  |            |         |       |                                                           |  |  |  |  |  |  |
|          | Bit Value                                                      | TMR0 R      | ate WD      | Γ Rate     |            |         |       |                                                           |  |  |  |  |  |  |
|          | 000                                                            | 1:2         | 1:          |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 001                                                            | 1:4         | 1:          |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 010<br>011                                                     | 1:8         | 1:          |            |            |         |       |                                                           |  |  |  |  |  |  |
|          | 100                                                            | 1:16        |             | 16         |            |         |       |                                                           |  |  |  |  |  |  |
|          | 101                                                            | 1:64        | . 1:        | 32         |            |         |       |                                                           |  |  |  |  |  |  |
|          | 110                                                            | 1 : 12      |             | 64         |            |         |       |                                                           |  |  |  |  |  |  |
|          | 111                                                            | 1:25        | 6   1       | 128        |            |         |       |                                                           |  |  |  |  |  |  |
|          |                                                                |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |
|          |                                                                |             |             |            |            |         |       |                                                           |  |  |  |  |  |  |

Note: To achieve a 1:1 prescaler assignment for the TMR0 register, assign the prescaler to the Watchdog Timer by setting bit PSA (OPTION<3>).

#### 4.2.2.3 INTCON REGISTER

# Applicable Devices 710 71 711 715

The INTCON Register is a readable and writable register which contains various enable and flag bits for the TMR0 register overflow, RB Port change and External RB0/INT pin interrupts.

#### FIGURE 4-9: INTCON REGISTER (ADDRESS 0Bh, 8Bh)

| R/W-0   | R/W-0                                                                                                                                    | R/W-0        | R/W-0        | R/W-0                                      | R/W-0                            | R/W-0       | R/W-x        |                                                                                       |  |  |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------------------------------------|----------------------------------|-------------|--------------|---------------------------------------------------------------------------------------|--|--|--|--|--|
| GIE     | ADIE                                                                                                                                     | TOIE         | INTE         | RBIE                                       | TOIF                             | INTF        | RBIF         | R = Readable bit                                                                      |  |  |  |  |  |
| bit7    |                                                                                                                                          |              |              | -                                          |                                  |             | bitO         | W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>- n = Value at POR reset |  |  |  |  |  |
| bit 7:  | GIE: <sup>(1)</sup> Global Interrupt Enable bit<br>1 = Enables all un-masked interrupts<br>0 = Disables all interrupts                   |              |              |                                            |                                  |             |              |                                                                                       |  |  |  |  |  |
| bit 6:  | ADIE: A/D Converter Interrupt Enable bit<br>1 = Enables A/D interrupt<br>0 = Disables A/D interrupt                                      |              |              |                                            |                                  |             |              |                                                                                       |  |  |  |  |  |
| bit 5:  | <b>T0IE:</b> TMR0 Overflow Interrupt Enable bit<br>1 = Enables the TMR0 interrupt<br>0 = Disables the TMR0 interrupt                     |              |              |                                            |                                  |             |              |                                                                                       |  |  |  |  |  |
| bit 4:  | INTE: RB0/INT External Interrupt Enable bit<br>1 = Enables the RB0/INT external interrupt<br>0 = Disables the RB0/INT external interrupt |              |              |                                            |                                  |             |              |                                                                                       |  |  |  |  |  |
| bit 3:  | 1 = Enabl                                                                                                                                | es the RB    | port char    | upt Enable<br>nge interru<br>nge interru   | pt                               |             |              |                                                                                       |  |  |  |  |  |
| bit 2:  | <b>TOIF:</b> TMF<br>1 = TMR0<br>0 = TMR0                                                                                                 | ) register h | nas overflo  | wed (mus                                   | t be cleare                      | d in softwa | ire)         |                                                                                       |  |  |  |  |  |
| bit 1:  | 1 = The R                                                                                                                                | B0/INT ex    | cternal inte | rupt Flag b<br>errupt occu<br>errupt did i | urred (must                      | be cleare   | d in softwar | e)                                                                                    |  |  |  |  |  |
| bit 0:  | 1 = At lea                                                                                                                               | st one of    | the RB7:R    |                                            | it<br>nanged stat<br>anged state |             | e cleared in | software)                                                                             |  |  |  |  |  |
| Note 1: |                                                                                                                                          | -enabled l   | oy the RET   |                                            |                                  |             |              | ed, the GIE bit may be uninten-<br>ce Routine. Refer to Section 8.5                   |  |  |  |  |  |
| globa   |                                                                                                                                          | GIE (INTC    |              |                                            |                                  |             |              | corresponding enable bit or the rupt flag bits are clear prior to                     |  |  |  |  |  |

# TABLE 5-1: PORTA FUNCTIONS

| Name         | Bit# | Buffer | Function                                        |
|--------------|------|--------|-------------------------------------------------|
| RA0/AN0      | bit0 | TTL    | Input/output or analog input                    |
| RA1/AN1      | bit1 | TTL    | Input/output or analog input                    |
| RA2/AN2      | bit2 | TTL    | Input/output or analog input                    |
| RA3/AN3/VREF | bit3 | TTL    | Input/output or analog input/VREF               |
| RA4/T0CKI    | bit4 | ST     | Input/output or external clock input for Timer0 |
|              |      |        | Output is open drain type                       |

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

# TABLE 5-2: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

| 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 |
|---------|--------|-------|-------|-------|---------|-------------|-------------|--------|--------|--------------------------|---------------------------|
| 05h     | PORTA  | —     | —     | _     | RA4     | RA3         | RA2         | RA1    | RA0    | x 0000                   | u 0000                    |
| 85h     | TRISA  | —     | —     | _     | PORTA D | Data Direct | ion Registe | 1 1111 | 1 1111 |                          |                           |
| 9Fh     | ADCON1 | _     | _     | _     | _       | _           |             | PCFG1  | PCFG0  | 00                       | 00                        |

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

#### 5.2 PORTB and TRISB Registers

PORTB is an 8-bit wide bi-directional port. The corresponding data direction register is TRISB. Setting a bit in the TRISB register puts the corresponding output driver in a hi-impedance input mode. Clearing a bit in the TRISB register puts the contents of the output latch on the selected pin(s).

#### EXAMPLE 5-2: INITIALIZING PORTB

| BCF   | STATUS, RPC | ; |                       |
|-------|-------------|---|-----------------------|
| CLRF  | PORTB       | ; | Initialize PORTB by   |
|       |             | ; | clearing output       |
|       |             | ; | data latches          |
| BSF   | STATUS, RPC | ; | Select Bank 1         |
| MOVLW | 0xCF        | ; | Value used to         |
|       |             | ; | initialize data       |
|       |             | ; | direction             |
| MOVWF | TRISB       | ; | Set RB<3:0> as inputs |
|       |             | ; | RB<5:4> as outputs    |
|       |             | ; | RB<7:6> as inputs     |

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit  $\overline{\text{RBPU}}$  (OPTION<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.

#### FIGURE 5-3: BLOCK DIAGRAM OF RB3:RB0 PINS



Four of PORTB's pins, RB7:RB4, have an interrupt on change feature. Only pins configured as inputs can cause this interrupt to occur (i.e. any RB7:RB4 pin configured as an output is excluded from the interrupt on change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are OR'ed together to generate the RB Port Change Interrupt with flag bit RBIF (INTCON<0>).

This interrupt can wake the device from SLEEP. The user, in the interrupt service routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear flag bit RBIF.

A mismatch condition will continue to set flag bit RBIF. Reading PORTB will end the mismatch condition, and allow flag bit RBIF to be cleared.

This interrupt on mismatch feature, together with software configurable pull-ups on these four pins allow easy interface to a keypad and make it possible for wake-up on key-depression. Refer to the Embedded Control Handbook, *"Implementing Wake-Up on Key Stroke"* (AN552).

| Note: | For the PIC16C71                                 |  |  |  |  |  |  |  |
|-------|--------------------------------------------------|--|--|--|--|--|--|--|
|       | if a change on the I/O pin should occur          |  |  |  |  |  |  |  |
|       | when the read operation is being executed        |  |  |  |  |  |  |  |
|       | (start of the Q2 cycle), then interrupt flag bit |  |  |  |  |  |  |  |
|       | RBIF may not get set.                            |  |  |  |  |  |  |  |

The interrupt on change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt on change feature. Polling of PORTB is not recommended while using the interrupt on change feature.

| 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 |
|-----------|--------|-------|---------------|------------|-------|-----------|-----------|-------|-------|--------------------------|---------------------------|
| 06h, 106h | PORTB  | RB7   | RB6           | RB5        | RB4   | RB3       | RB2       | RB1   | RB0   | xxxx xxxx                | uuuu uuuu                 |
| 86h, 186h | TRISB  | PORTB | Data Directic | on Registe |       | 1111 1111 | 1111 1111 |       |       |                          |                           |
| 81h, 181h | OPTION | RBPU  | INTEDG        | TOCS       | TOSE  | PSA       | PS2       | PS1   | PS0   | 1111 1111                | 1111 1111                 |

Legend: x = unknown, u = unchanged. Shaded cells are not used by PORTB.

#### 6.3.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, the following instruction sequence (shown in Example 6-1) must be executed when changing the prescaler assignment from Timer0 to the WDT. This sequence must be followed even if the WDT is disabled.

### EXAMPLE 6-1: CHANGING PRESCALER (TIMER0→WDT)

BCFSTATUS, RP0;Bank 0CLRFTMR0;Clear TMR0 & PrescalerBSFSTATUS, RP0;Bank 1CLRWDT;Clears WDTMOVLWb'xxxxlxxx';Selects new prescale valueMOVWFOPTION\_REG;and assigns the prescaler to the WDTBCFSTATUS, RP0;Bank 0

To change prescaler from the WDT to the Timer0 module use the sequence shown in Example 6-2.

#### EXAMPLE 6-2: CHANGING PRESCALER (WDT → TIMER0)

| CLRWDT |             | ;Clear WDT and prescaler             |
|--------|-------------|--------------------------------------|
| BSF    | STATUS, RPO | ;Bank 1                              |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new prescale value and |
| MOVWF  | OPTION_REG  | ;clock source                        |
| BCF    | STATUS, RPO | ;Bank 0                              |

#### TABLE 6-1: REGISTERS ASSOCIATED WITH TIMER0

| 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 | module's r | egister |         |            |            |       |        | xxxx xxxx                | uuuu uuuu                 |
| 0Bh,8Bh, | INTCON | GIE    | ADIE       | TOIE    | INTE    | RBIE       | TOIF       | INTF  | RBIF   | 0000 000x                | 0000 000u                 |
| 81h      | OPTION | RBPU   | INTEDG     | T0CS    | TOSE    | PSA        | PS2        | PS1   | PS0    | 1111 1111                | 1111 1111                 |
| 85h      | TRISA  | —      | —          | _       | PORTA D | Data Direc | tion Regis |       | 1 1111 | 1 1111                   |                           |

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

## FIGURE 7-2: ADCON0 REGISTER (ADDRESS 1Fh), PIC16C715

| R/W-0    | R/W-0                                                    | R/W-0                      | R/W-0       | R/W-0       | R/W-0           | U-0        | R/W-0     |                                       |  |
|----------|----------------------------------------------------------|----------------------------|-------------|-------------|-----------------|------------|-----------|---------------------------------------|--|
| ADCS1    | ADCS0                                                    | —                          | CHS1        | CHS0        | GO/DONE         | —          | ADON      | R = Readable bit                      |  |
| bit7     |                                                          |                            |             |             |                 |            | bit0      | W = Writable bit                      |  |
|          |                                                          |                            |             |             |                 |            |           | U = Unimplemented bit,<br>read as '0' |  |
|          |                                                          |                            |             |             |                 |            |           | - n = Value at POR reset              |  |
| bit 7-6: | ADCS1:A                                                  | ADCS0: A                   | D Conver    | sion Clock  | Select bits     |            |           |                                       |  |
|          | 00 = Fos                                                 |                            |             |             |                 |            |           |                                       |  |
|          | 01 = Fos<br>10 = Fos                                     |                            |             |             |                 |            |           |                                       |  |
|          |                                                          |                            | rived from  | an RC oso   | cillation)      |            |           |                                       |  |
| bit 5:   | Unused                                                   | ,                          |             |             | ,               |            |           |                                       |  |
| bit 6-3: |                                                          |                            | og Channe   | l Select bi | its             |            |           |                                       |  |
|          | 000 = channel 0, (RA0/AN0)<br>001 = channel 1, (RA1/AN1) |                            |             |             |                 |            |           |                                       |  |
|          |                                                          | annel 2, (F                |             |             |                 |            |           |                                       |  |
|          |                                                          | annel 3, (F                |             |             |                 |            |           |                                       |  |
|          |                                                          | annel 0, (F                | ,           |             |                 |            |           |                                       |  |
|          |                                                          | annel 1, (F                |             |             |                 |            |           |                                       |  |
|          |                                                          | annel 2, (F<br>annel 3, (F | ,           |             |                 |            |           |                                       |  |
| bit 2:   |                                                          |                            | nversion S  | Statue hit  |                 |            |           |                                       |  |
| 511 2.   | If ADON :                                                |                            |             |             |                 |            |           |                                       |  |
|          |                                                          | -                          | in progres  | s (settina  | this bit starts | the A/D co | nversion) |                                       |  |
|          |                                                          |                            |             |             |                 |            |           | lware when the A/D conver-            |  |
|          | sion is co                                               | mplete)                    |             |             |                 |            |           |                                       |  |
| bit 1:   | Unimple                                                  | mented: F                  | Read as '0' |             |                 |            |           |                                       |  |
| bit 0:   |                                                          | /D On bit                  |             |             |                 |            |           |                                       |  |
|          |                                                          |                            | nodule is o |             |                 | oporation  | ourroat   |                                       |  |
|          | v = A/D C                                                | onverter r                 | noquie is s | inuton and  | d consumes no   | operating  | current   |                                       |  |

# FIGURE 7-3: ADCON1 REGISTER, PIC16C710/71/711 (ADDRESS 88h), PIC16C715 (ADDRESS 9Fh)

| bit, read as '0'                                                                                                                                                                                                                             | ) U-0                                    | U-0 U-0                                       | U-0                       | U-0                   | R/W-0             | R/W-0 |                   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|-----------------------------------------------|---------------------------|-----------------------|-------------------|-------|-------------------|
| <ul> <li>U = Unimplemented:<br/>bit, read as '0'</li> <li>PCFG1:PCFG0: A/D Port Configuration Control bits</li> <li>PCFG1:PCFG0 RA1 &amp; RA0 RA2 RA3 VREF</li> <li>00 A A A A VDD</li> <li>01 A A VREF RA3</li> <li>10 A D D VDD</li> </ul> |                                          |                                               | _                         |                       | PCFG1             | PCFG0 | R = Readable bit  |
| 00AAAVDD01AAVREFRA310ADDVDD                                                                                                                                                                                                                  | 2: Unimplemen                            | ted: Read as '0                               | '                         |                       |                   | bitO  | U = Unimplemented |
| 01AAVREFRA310ADDVDD                                                                                                                                                                                                                          | 0: PCFG1:PCFC                            | GO: A/D Port Co                               | nfiguration C             | control bits          |                   |       |                   |
| 10 A D D VDD                                                                                                                                                                                                                                 |                                          | 1                                             | -                         | 1                     | VREF              |       |                   |
|                                                                                                                                                                                                                                              | PCFG1:PCFG0                              | RA1 & RA0                                     | RA2                       | RA3                   |                   |       |                   |
| 11 D D D VDD                                                                                                                                                                                                                                 | <b>PCFG1:PCFG0</b>                       | <b>RA1 &amp; RA0</b><br>A                     | <b>RA2</b>                | <b>RA3</b>            | Vdd               |       |                   |
|                                                                                                                                                                                                                                              | <b>PCFG1:PCFG0</b> 00 01                 | <b>RA1 &amp; RA0</b><br>A<br>A                | <b>RA2</b><br>A<br>A      | RA3<br>A<br>VREF      | VDD<br>RA3        |       |                   |
| D = Digital I/O                                                                                                                                                                                                                              | PCFG1:PCFG0 00 01 10 11 A = Analog input | RA1 & RA0           A           A           D | <b>RA2</b><br>A<br>A<br>D | RA3<br>A<br>VREF<br>D | VDD<br>RA3<br>VDD |       |                   |

| Register | Power-on Reset,<br>Brown-out Reset<br>Parity Error Reset | MCLR Resets<br>WDT Reset | Wake-up via<br>WDT or<br>Interrupt |
|----------|----------------------------------------------------------|--------------------------|------------------------------------|
| W        | XXXX XXXX                                                | นนนน นนนน                | นนนน นนนน                          |
| INDF     | N/A                                                      | N/A                      | N/A                                |
| TMR0     | xxxx xxxx                                                | uuuu uuuu                | uuuu uuuu                          |
| PCL      | 0000 0000                                                | 0000 0000                | PC + 1(2)                          |
| STATUS   | 0001 1xxx                                                | 000q quuu <sup>(3)</sup> | uuuq quuu <sup>(3)</sup>           |
| FSR      | xxxx xxxx                                                | uuuu uuuu                | uuuu uuuu                          |
| PORTA    | x 0000                                                   | u 0000                   | u uuuu                             |
| PORTB    | xxxx xxxx                                                | uuuu uuuu                | uuuu uuuu                          |
| PCLATH   | 0 0000                                                   | 0 0000                   | u uuuu                             |
| INTCON   | 0000 000x                                                | 0000 000u                | uuuu uuuu <b>(1)</b>               |
| PIR1     | -0                                                       | -0                       | _ <sub>u</sub> _(1)                |
| ADCON0   | 0000 00-0                                                | 0000 00-0                | uuuu uu-u                          |
| OPTION   | 1111 1111                                                | 1111 1111                | นนนน นนนน                          |
| TRISA    | 1 1111                                                   | 1 1111                   | u uuuu                             |
| TRISB    | 1111 1111                                                | 1111 1111                | นนนน นนนน                          |
| PIE1     | -0                                                       | -0                       | -u                                 |
| PCON     | वेर्वेवे                                                 | luu                      | luu                                |
| ADCON1   | 00                                                       | 00                       |                                    |

# TABLE 8-13: INITIALIZATION CONDITIONS FOR ALL REGISTERS, PIC16C715

Legend: u = unchanged, x = unknown, -= unimplemented bit, read as '0', q = value depends on condition Note 1: One or more bits in INTCON and PIR1 will be affected (to cause wake-up).

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

3: See Table 8-11 for reset value for specific condition.

### 8.8 Power-down Mode (SLEEP)

Power-down mode is entered by executing a  $\ensuremath{\mathtt{SLEEP}}$  instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the  $\overline{PD}$  bit (STATUS<3>) is cleared, the  $\overline{TO}$  (STATUS<4>) bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had, before the SLEEP instruction was executed (driving high, low, or hi-impedance).

For lowest current consumption in this mode, place all I/O pins at either VDD, or VSS, ensure no external circuitry is drawing current from the I/O pin, power-down the A/D, disable external clocks. Pull all I/O pins, that are hi-impedance inputs, high or low externally to avoid switching currents caused by floating inputs. The TOCKI input should also be at VDD or VSS for lowest current consumption. The contribution from on-chip pull-ups on PORTB should be considered.

The  $\overline{\text{MCLR}}$  pin must be at a logic high level (VIHMC).

#### 8.8.1 WAKE-UP FROM SLEEP

The device can wake up from SLEEP through one of the following events:

- 1. External reset input on  $\overline{\text{MCLR}}$  pin.
- 2. Watchdog Timer Wake-up (if WDT was enabled).
- 3. Interrupt from INT pin, RB port change, or some Peripheral Interrupts.

External  $\overline{\text{MCLR}}$  Reset will cause a device reset. All other events are considered a continuation of program execution and cause a "wake-up". The  $\overline{\text{TO}}$  and  $\overline{\text{PD}}$  bits in the STATUS register can be used to determine the cause of device reset. The  $\overline{\text{PD}}$  bit, which is set on power-up, is cleared when SLEEP is invoked. The  $\overline{\text{TO}}$  bit is cleared if a WDT time-out occurred (and caused wake-up).

The following peripheral interrupts can wake the device from SLEEP:

- 1. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 2. A/D conversion (when A/D clock source is RC).

Other peripherals cannot generate interrupts since during SLEEP, no on-chip Q clocks are present.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up is regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction after the subset (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

#### 8.8.2 WAKE-UP USING INTERRUPTS

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

- If the interrupt occurs before the the execution of a SLEEP instruction, the SLEEP instruction will complete as a NOP. Therefore, the WDT and WDT postscaler will not be cleared, the TO bit will not be set and PD bits will not be cleared.
- If the interrupt occurs during or after the execution of a SLEEP instruction, the device will immediately wake up from sleep. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT postscaler will be cleared, the TO bit will be set and the PD bit will be cleared.

Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the  $\overline{PD}$  bit. If the  $\overline{PD}$  bit is set, the SLEEP instruction was executed as a NOP.

To ensure that the WDT is cleared, a CLRWDT instruction should be executed before a SLEEP instruction.

| SUBWF             | Subtract W from f                                                                                                                                                                    |              |                            |          |  |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------|----------|--|--|--|--|
| Syntax:           | [ label ]                                                                                                                                                                            | SUBWF        | f,d                        |          |  |  |  |  |
| Operands:         | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                   |              |                            |          |  |  |  |  |
| Operation:        | (f) - (W) $\rightarrow$ (dest)                                                                                                                                                       |              |                            |          |  |  |  |  |
| Status Affected:  | C, DC, Z                                                                                                                                                                             |              |                            |          |  |  |  |  |
| Encoding:         | 00                                                                                                                                                                                   | 0010         | dfff                       | ffff     |  |  |  |  |
| Description:      | Subtract (2's complement method) W reg-<br>ister from register 'f'. If 'd' is 0 the result is<br>stored in the W register. If 'd' is 1 the<br>result is stored back in register 'f'. |              |                            |          |  |  |  |  |
| Words:            | 1                                                                                                                                                                                    |              |                            |          |  |  |  |  |
| Cycles:           | 1                                                                                                                                                                                    |              |                            |          |  |  |  |  |
| Q Cycle Activity: | Q1                                                                                                                                                                                   | Q2           | Q3                         | Q4       |  |  |  |  |
|                   | Decode                                                                                                                                                                               | Read         | Process                    | Write to |  |  |  |  |
|                   |                                                                                                                                                                                      | register 'f' | data                       | dest     |  |  |  |  |
| Example 1:        | SUBWF                                                                                                                                                                                | reg1,1       |                            |          |  |  |  |  |
|                   | Before Ins                                                                                                                                                                           | struction    |                            |          |  |  |  |  |
|                   | REG1                                                                                                                                                                                 | =            | 3                          |          |  |  |  |  |
|                   | W<br>C                                                                                                                                                                               | =            | 2<br>?                     |          |  |  |  |  |
|                   | Z                                                                                                                                                                                    | =            | ?                          |          |  |  |  |  |
|                   | After Instr                                                                                                                                                                          | uction       |                            |          |  |  |  |  |
|                   | REG1 =                                                                                                                                                                               |              | 1                          |          |  |  |  |  |
|                   | W =<br>C =                                                                                                                                                                           |              | 2<br>1; result is positive |          |  |  |  |  |
|                   | Z                                                                                                                                                                                    | =            | 0                          |          |  |  |  |  |
| Example 2:        | Before Ins                                                                                                                                                                           | struction    |                            |          |  |  |  |  |
|                   | REG1                                                                                                                                                                                 | =            | 2                          |          |  |  |  |  |
|                   | W<br>C                                                                                                                                                                               | =            | 2<br>?                     |          |  |  |  |  |
|                   | Z                                                                                                                                                                                    | =            | ?                          |          |  |  |  |  |
|                   | After Instruction                                                                                                                                                                    |              |                            |          |  |  |  |  |
|                   | REG1                                                                                                                                                                                 | =            | 0                          |          |  |  |  |  |
|                   | W                                                                                                                                                                                    | =            | 2                          |          |  |  |  |  |
|                   | C<br>Z                                                                                                                                                                               | =            | 1; result is               | zero     |  |  |  |  |
| Example 3:        | Before Instruction                                                                                                                                                                   |              |                            |          |  |  |  |  |
|                   | REG1                                                                                                                                                                                 |              |                            |          |  |  |  |  |
|                   | W                                                                                                                                                                                    | =            | 1<br>2                     |          |  |  |  |  |
|                   | С                                                                                                                                                                                    | =            | ?                          |          |  |  |  |  |
|                   | Z<br>After Instr                                                                                                                                                                     | =            | ?                          |          |  |  |  |  |
|                   |                                                                                                                                                                                      |              |                            |          |  |  |  |  |
|                   | $\begin{array}{rcl} REG1 &= & 0xFF \\ W &= & 2 \end{array}$                                                                                                                          |              | 0xFF<br>2                  |          |  |  |  |  |
|                   | c                                                                                                                                                                                    | =            | 0; result is               | negative |  |  |  |  |
|                   | Z                                                                                                                                                                                    | =            | 0                          |          |  |  |  |  |

| SWAPF             | Swap Nibbles in f                                                                                                                                                       |                                      |                 |                  |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-----------------|------------------|--|--|--|
| Syntax:           | [label] SWAPF f,d                                                                                                                                                       |                                      |                 |                  |  |  |  |
| Operands:         | $0 \le f \le 12$ $d \in [0,1]$                                                                                                                                          | 27                                   |                 |                  |  |  |  |
| Operation:        |                                                                                                                                                                         | ightarrow (dest<<br>ightarrow (dest< |                 |                  |  |  |  |
| Status Affected:  | None                                                                                                                                                                    |                                      |                 |                  |  |  |  |
| Encoding:         | 00                                                                                                                                                                      | 1110                                 | dfff            | ffff             |  |  |  |
| Description:      | The upper and lower nibbles of regis-<br>ter 'f' are exchanged. If 'd' is 0 the<br>result is placed in W register. If 'd' is 1<br>the result is placed in register 'f'. |                                      |                 |                  |  |  |  |
| Words:            | 1                                                                                                                                                                       |                                      |                 |                  |  |  |  |
| Cycles:           | 1                                                                                                                                                                       |                                      |                 |                  |  |  |  |
| Q Cycle Activity: | Q1                                                                                                                                                                      | Q1 Q2 G                              |                 | Q4               |  |  |  |
|                   | Decode                                                                                                                                                                  | Read<br>register 'f'                 | Process<br>data | Write to<br>dest |  |  |  |
| Example           | SWAPF                                                                                                                                                                   | REG,                                 | 0               |                  |  |  |  |
|                   | Before Instruction                                                                                                                                                      |                                      |                 |                  |  |  |  |
|                   | REG1 = 0xA5                                                                                                                                                             |                                      |                 |                  |  |  |  |
|                   | After Instruction                                                                                                                                                       |                                      |                 |                  |  |  |  |
|                   |                                                                                                                                                                         | REG1<br>W                            | = 0x4<br>= 0x5  |                  |  |  |  |

| TRIS             | Load TRIS Register                                                                                                                                                                  |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] TRIS f                                                                                                                                                             |  |  |  |  |  |  |
| Operands:        | $5 \le f \le 7$                                                                                                                                                                     |  |  |  |  |  |  |
| Operation:       | (W) $\rightarrow$ TRIS register f;                                                                                                                                                  |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                |  |  |  |  |  |  |
| Encoding:        | 00 0000 0110 0fff                                                                                                                                                                   |  |  |  |  |  |  |
| Description:     | The instruction is supported for code<br>compatibility with the PIC16C5X prod-<br>ucts. Since TRIS registers are read-<br>able and writable, the user can directly<br>address them. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                   |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                                   |  |  |  |  |  |  |
| Example          |                                                                                                                                                                                     |  |  |  |  |  |  |
|                  | To maintain upward compatibility<br>with future PIC16CXX products, do<br>not use this instruction.                                                                                  |  |  |  |  |  |  |
|                  |                                                                                                                                                                                     |  |  |  |  |  |  |

MPASM has the following features to assist in developing software for specific use applications.

- Provides translation of Assembler source code to object code for all Microchip microcontrollers.
- Macro assembly capability.
- Produces all the files (Object, Listing, Symbol, and special) required for symbolic debug with Microchip's emulator systems.
- Supports Hex (default), Decimal and Octal source and listing formats.

MPASM provides a rich directive language to support programming of the PIC16/17. Directives are helpful in making the development of your assemble source code shorter and more maintainable.

# 10.11 Software Simulator (MPLAB-SIM)

The MPLAB-SIM Software Simulator allows code development in a PC host environment. It allows the user to simulate the PIC16/17 series microcontrollers on an instruction level. On any given instruction, the user may examine or modify any of the data areas or provide external stimulus to any of the pins. The input/ output radix can be set by the user and the execution can be performed in; single step, execute until break, or in a trace mode.

MPLAB-SIM fully supports symbolic debugging using MPLAB-C and MPASM. The Software Simulator offers the low cost flexibility to develop and debug code outside of the laboratory environment making it an excellent multi-project software development tool.

# 10.12 <u>C Compiler (MPLAB-C)</u>

The MPLAB-C Code Development System is a complete 'C' compiler and integrated development environment for Microchip's PIC16/17 family of micro-controllers. The compiler provides powerful integration capabilities and ease of use not found with other compilers.

For easier source level debugging, the compiler provides symbol information that is compatible with the MPLAB IDE memory display.

# 10.13 <u>Fuzzy Logic Development System</u> (*fuzzy*TECH-MP)

*fuzzy*TECH-MP fuzzy logic development tool is available in two versions - a low cost introductory version, MP Explorer, for designers to gain a comprehensive working knowledge of fuzzy logic system design; and a full-featured version, *fuzzy*TECH-MP, edition for implementing more complex systems.

Both versions include Microchip's *fuzzy*LAB<sup>™</sup> demonstration board for hands-on experience with fuzzy logic systems implementation.

### 10.14 <u>MP-DriveWay™ – Application Code</u> <u>Generator</u>

MP-DriveWay is an easy-to-use Windows-based Application Code Generator. With MP-DriveWay you can visually configure all the peripherals in a PIC16/17 device and, with a click of the mouse, generate all the initialization and many functional code modules in C language. The output is fully compatible with Microchip's MPLAB-C C compiler. The code produced is highly modular and allows easy integration of your own code. MP-DriveWay is intelligent enough to maintain your code through subsequent code generation.

# 10.15 <u>SEEVAL<sup>®</sup> Evaluation and</u> <u>Programming System</u>

The SEEVAL SEEPROM Designer's Kit supports all Microchip 2-wire and 3-wire Serial EEPROMs. The kit includes everything necessary to read, write, erase or program special features of any Microchip SEEPROM product including Smart Serials<sup>™</sup> and secure serials. The Total Endurance<sup>™</sup> Disk is included to aid in tradeoff analysis and reliability calculations. The total kit can significantly reduce time-to-market and result in an optimized system.

# 10.16 <u>KEELOQ<sup>®</sup> Evaluation and</u> <u>Programming Tools</u>

KEELOQ evaluation and programming tools support Microchips HCS Secure Data Products. The HCS evaluation kit includes an LCD display to show changing codes, a decoder to decode transmissions, and a programming interface to program test transmitters.









# FIGURE 12-10: TYPICAL IPD vs. TIMER1 ENABLED (32 kHz, RC0/RC1 = 33 pF/33 pF, RC MODE)

Applicable Devices 710 71 711 715









20 MHz

DS30272A-page 132

± 30 PPM

EPSON CA-301 20.000M-C

6.0

# Applicable Devices 710 71 711 715

| Param<br>No. | Sym      | Characteristic                                 |                    | Min       | Тур†       | Max       | Units    | Conditions                                                                                                                                   |
|--------------|----------|------------------------------------------------|--------------------|-----------|------------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| A01          | NR       | Resolution                                     |                    | _         |            | 8 bits    | bits     | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                                                 |
| A02          | EABS     | Absolute error                                 | PIC16 <b>C</b> 71  |           | _          | < ±1      | LSb      | $\begin{array}{l} VREF=VDD=5.12V,\\ VSS\leqVAIN\leqVREF \end{array}$                                                                         |
|              |          |                                                | PIC16 <b>LC</b> 71 | —         | —          | < ±2      | LSb      | VREF = VDD = 3.0V (Note 3)                                                                                                                   |
| A03          | EIL      | Integral linearity error PIC16 <b>C</b> 71     |                    | _         | _          | < ±1      | LSb      | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                                                 |
|              |          |                                                | PIC16 <b>LC</b> 71 | —         | _          | < ±2      | LSb      | VREF = VDD = 3.0V (Note 3)                                                                                                                   |
| A04          | Edl      | Differential linearity error                   | PIC16 <b>C</b> 71  |           | _          | < ±1      | LSb      | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                                                 |
|              |          |                                                | PIC16 <b>LC</b> 71 | —         | _          | < ±2      | LSb      | VREF = VDD = 3.0V (Note 3)                                                                                                                   |
| A05          | EFS      | Full scale error                               | PIC16 <b>C</b> 71  | —         | _          | < ±1      | LSb      | $\begin{array}{l} VREF=VDD=5.12V,\\ VSS\leqVAIN\leqVREF \end{array}$                                                                         |
|              |          |                                                | PIC16 <b>LC</b> 71 | —         | _          | < ±2      | LSb      | VREF = VDD = 3.0V (Note 3)                                                                                                                   |
| A06          | A06 EOFF | Offset error                                   | PIC16 <b>C</b> 71  | —         | _          | < ±1      | LSb      | $\begin{array}{l} VREF=VDD=5.12V,\\ VSS\leqVAIN\leqVREF \end{array}$                                                                         |
|              |          | PIC16 <b>LC</b> 71                             |                    | —         | _          | < ±2      | LSb      | VREF = VDD = 3.0V (Note 3)                                                                                                                   |
| A10          | —        | Monotonicity                                   |                    | —         | guaranteed | —         | -        | $VSS \leq VAIN \leq VREF$                                                                                                                    |
| A20          | Vref     | Reference voltage                              |                    | 3.0V      | —          | Vdd + 0.3 | V        |                                                                                                                                              |
| A25          | Vain     | Analog input voltage                           |                    | Vss - 0.3 | —          | Vref      | V        |                                                                                                                                              |
| A30          | ZAIN     | Recommended impedance of analog voltage source |                    | _         | _          | 10.0      | kΩ       |                                                                                                                                              |
| A40          | IAD      | A/D conversion current (VDD)                   |                    | _         | 180        | _         | μA       | Average current consump-<br>tion when A/D is on. (Note 1)                                                                                    |
| A50 IREF     |          | VREF input current (Note 2)                    | PIC16 <b>C</b> 71  | 10        | _          | 1000      | μΑ       | During VAIN acquisition.<br>Based on differential of<br>VHOLD to VAIN.<br>To charge CHOLD see<br>Section 7.1.<br>During A/D Conversion cycle |
|              |          |                                                | PIC16 <b>LC</b> 71 | _         | _          | 1         | mA<br>μA | During VAIN acquisition.<br>Based on differential of<br>VHOLD to VAIN.<br>To charge CHOLD see<br>Section 7.1.<br>During A/D Conversion cycle |

# TABLE 15-6: A/D CONVERTER CHARACTERISTICS

These parameters are characterized but not tested.

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.

Note 1: When A/D is off, it will not consume any current other than minor leakage current. The power-down current spec includes any such leakage from the A/D module.

2: VREF current is from RA3 pin or VDD pin, whichever is selected as reference input.

3: These specifications apply if VREF = 3.0V and if VDD  $\ge$  3.0V. VAIN must be between VSS and VREF.

\*

# **APPENDIX A:**

The following are the list of modifications over the PIC16C5X microcontroller family:

- Instruction word length is increased to 14-bits. This allows larger page sizes both in program memory (1K now as opposed to 512 before) and register file (68 bytes now versus 32 bytes before).
- 2. A PC high latch register (PCLATH) is added to handle program memory paging. Bits PA2, PA1, PA0 are removed from STATUS register.
- 3. Data memory paging is redefined slightly. STATUS register is modified.
- Four new instructions have been added: RETURN, RETFIE, ADDLW, and SUBLW.
   Two instructions TRIS and OPTION are being phased out although they are kept for compati-bility with PIC16C5X.
- 5. OPTION and TRIS registers are made addressable.
- 6. Interrupt capability is added. Interrupt vector is at 0004h.
- 7. Stack size is increased to 8 deep.
- 8. Reset vector is changed to 0000h.
- 9. Reset of all registers is revisited. Five different reset (and wake-up) types are recognized. Registers are reset differently.
- 10. Wake up from SLEEP through interrupt is added.
- 11. Two separate timers, Oscillator Start-up Timer (OST) and Power-up Timer (PWRT) are included for more reliable power-up. These timers are invoked selectively to avoid unnecessary delays on power-up and wake-up.
- 12. PORTB has weak pull-ups and interrupt on change feature.
- 13. T0CKI pin is also a port pin (RA4) now.
- 14. FSR is made a full eight bit register.
- "In-circuit serial programming" is made possible. The user can program PIC16CXX devices using only five pins: VDD, Vss, MCLR/VPP, RB6 (clock) and RB7 (data in/out).
- PCON status register is added with a Power-on Reset status bit (POR).
- 17. Code protection scheme is enhanced such that portions of the program memory can be protected, while the remainder is unprotected.
- Brown-out protection circuitry has been added. Controlled by configuration word bit BODEN. Brown-out reset ensures the device is placed in a reset condition if VDD dips below a fixed setpoint.

# APPENDIX B: COMPATIBILITY

To convert code written for PIC16C5X to PIC16CXX, the user should take the following steps:

- 1. Remove any program memory page select operations (PA2, PA1, PA0 bits) for CALL, GOTO.
- 2. Revisit any computed jump operations (write to PC or add to PC, etc.) to make sure page bits are set properly under the new scheme.
- 3. Eliminate any data memory page switching. Redefine data variables to reallocate them.
- 4. Verify all writes to STATUS, OPTION, and FSR registers since these have changed.
- 5. Change reset vector to 0000h.

#### **ON-LINE SUPPORT**

Microchip provides two methods of on-line support. These are the Microchip BBS and the Microchip World Wide Web (WWW) site.

Use Microchip's Bulletin Board Service (BBS) to get current information and help about Microchip products. Microchip provides the BBS communication channel for you to use in extending your technical staff with microcontroller and memory experts.

To provide you with the most responsive service possible, the Microchip systems team monitors the BBS, posts the latest component data and software tool updates, provides technical help and embedded systems insights, and discusses how Microchip products provide project solutions.

The web site, like the BBS, is used by Microchip as a means to make files and information easily available to customers. To view the site, the user must have access to the Internet and a web browser, such as Netscape or Microsoft Explorer. Files are also available for FTP download from our FTP site.

#### Connecting to the Microchip Internet Web Site

The Microchip web site is available by using your favorite Internet browser to attach to:

#### www.microchip.com

The file transfer site is available by using an FTP service to connect to:

#### ftp://ftp.futureone.com/pub/microchip

The web site and file transfer site provide a variety of services. Users may download files for the latest Development Tools, Data Sheets, Application Notes, User's Guides, Articles and Sample Programs. A variety of Microchip specific business information is also available, including listings of Microchip sales offices, distributors and factory representatives. Other data available for consideration is:

- Latest Microchip Press Releases
- Technical Support Section with Frequently Asked
   Questions
- Design Tips
- Device Errata
- Job Postings
- Microchip Consultant Program Member Listing
- Links to other useful web sites related to Microchip Products

#### **Connecting to the Microchip BBS**

Connect worldwide to the Microchip BBS using either the Internet or the CompuServe  $^{\circledast}$  communications network.

#### Internet:

You can telnet or ftp to the Microchip BBS at the address: mchipbbs.microchip.com

#### **CompuServe Communications Network:**

When using the BBS via the Compuserve Network, in most cases, a local call is your only expense. The Microchip BBS connection does not use CompuServe membership services, therefore you do not need CompuServe membership to join Microchip's BBS. There is no charge for connecting to the Microchip BBS. The procedure to connect will vary slightly from country to country. Please check with your local CompuServe agent for details if you have a problem. CompuServe service allow multiple users various baud rates depending on the local point of access.

The following connect procedure applies in most locations.

- 1. Set your modem to 8-bit, No parity, and One stop (8N1). This is not the normal CompuServe setting which is 7E1.
- 2. Dial your local CompuServe access number.
- 3. Depress the **<Enter>** key and a garbage string will appear because CompuServe is expecting a 7E1 setting.
- Type +, depress the <Enter> key and "Host Name:" will appear.
- 5. Type MCHIPBBS, depress the **<Enter>** key and you will be connected to the Microchip BBS.

In the United States, to find the CompuServe phone number closest to you, set your modem to 7E1 and dial (800) 848-4480 for 300-2400 baud or (800) 331-7166 for 9600-14400 baud connection. After the system responds with "Host Name:", type NETWORK, depress the **<Enter>** key and follow CompuServe's directions.

For voice information (or calling from overseas), you may call (614) 723-1550 for your local CompuServe number.

Microchip regularly uses the Microchip BBS to distribute technical information, application notes, source code, errata sheets, bug reports, and interim patches for Microchip systems software products. For each SIG, a moderator monitors, scans, and approves or disapproves files submitted to the SIG. No executable files are accepted from the user community in general to limit the spread of computer viruses.

#### Systems Information and Upgrade Hot Line

The Systems Information and Upgrade Line provides system users a listing of the latest versions of all of Microchip's development systems software products. Plus, this line provides information on how customers can receive any currently available upgrade kits.The Hot Line Numbers are:

1-800-755-2345 for U.S. and most of Canada, and

1-602-786-7302 for the rest of the world.

970301

**Trademarks:** The Microchip name, logo, PIC, PICSTART, PICMASTER and PRO MATE are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. *Flex*ROM, MPLAB and *fuzzy*LAB, are trademarks and SQTP is a service mark of Microchip in the U.S.A.

*fuzzy*TECH is a registered trademark of Inform Software Corporation. IBM, IBM PC-AT are registered trademarks of International Business Machines Corp. Pentium is a trademark of Intel Corporation. Windows is a trademark and MS-DOS, Microsoft Windows are registered trademarks of Microsoft Corporation. CompuServe is a registered trademark of CompuServe Incorporated.

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

NOTES:



# WORLDWIDE SALES AND SERVICE

#### AMERICAS

**Corporate Office** 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com

#### **Rocky Mountain**

2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456

#### Atlanta

500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307

#### Boston

2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821

#### Chicago

333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075

Dallas

4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924

Detroit Tri-Atria Office Building

32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260 Kokomo

# 2767 S. Albright Road

Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387 Los Angeles

18201 Von Karman, Suite 1090 Irvine, CA 92612

Tel: 949-263-1888 Fax: 949-263-1338 New York

150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335 San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

Toronto

6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Australia

Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 China - Beijing

Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104

#### China - Chengdu

Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-6766200 Fax: 86-28-6766599

#### China - Fuzhou

Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521 China - Shanghai

Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060

#### China - Shenzhen

Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1315, 13/F, Shenzhen Kerry Centre, Renminnan Lu Shenzhen 518001, China Tel: 86-755-2350361 Fax: 86-755-2366086 Hong Kong Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza

223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

#### India

Microchip Technology Inc. India Liaison Office **Divvasree Chambers** 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062

#### Japan

Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122 Korea Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934 Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-334-8870 Fax: 65-334-8850 Taiwan Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

#### EUROPE

Denmark

Microchip Technology Nordic ApS **Regus Business Centre** Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 France Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 Germany Microchip Technology GmbH

Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44 Italy

Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883

#### United Kinadom

Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820

01/18/02