



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

| Product Status             | Obsolete                                                                     |
|----------------------------|------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                          |
| Core Size                  | 8-Bit                                                                        |
| Speed                      | 4MHz                                                                         |
| Connectivity               | -                                                                            |
| Peripherals                | Brown-out Detect/Reset, POR, WDT                                             |
| Number of I/O              | 13                                                                           |
| Program Memory Size        | 896B (512 x 14)                                                              |
| Program Memory Type        | ОТР                                                                          |
| EEPROM Size                | -                                                                            |
| RAM Size                   | 80 x 8                                                                       |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V                                                                    |
| Data Converters            | -                                                                            |
| Oscillator Type            | External                                                                     |
| Operating Temperature      | -40°C ~ 85°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/pic16lc620t-04i-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                 | . 5 |
|---------|-------------------------------------|-----|
| 2.0     | PIC16C62X Device Varieties          | . 7 |
| 3.0     | Architectural Overview              | . 9 |
| 4.0     | Memory Organization                 | 13  |
| 5.0     | I/O Ports                           | 25  |
| 6.0     | Timer0 Module                       | 31  |
| 7.0     | Comparator Module                   | 37  |
| 8.0     | Voltage Reference Module            | 43  |
| 9.0     | Special Features of the CPU         | 45  |
| 10.0    | Instruction Set Summary             | 61  |
| 11.0    | Development Support                 | 75  |
| 12.0    | Electrical Specifications           | 81  |
| 13.0    | Device Characterization Information | 09  |
| 14.0    | Packaging Information 1             | 13  |
| Append  | Jix A: Enhancements 1               | 19  |
| Append  | dix B: Compatibility 1              | 19  |
| Index   |                                     | 21  |
| On-Line | e Support 1                         | 23  |
| System  | Information and Upgrade Hot Line    | 23  |
| Reader  | r Response 1                        | 24  |
| Produc  | t Identification System 1           | 25  |

### 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@mail.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)
- The Microchip Corporate Literature Center; U.S. FAX: (480) 792-7277

When contacting a sales office or the literature center, 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/cn to receive the most current information on all of our products.

#### 4.2 Data Memory Organization

The data memory (Figure 4-4, Figure 4-5, Figure 4-6 and Figure 4-7) is partitioned into two banks, which contain the General Purpose Registers and the Special Function Registers. Bank 0 is selected when the RP0 bit is cleared. Bank 1 is selected when the RP0 bit (STATUS <5>) is set. The Special Function Registers are located in the first 32 locations of each bank. Register locations 20-7Fh (Bank0) on the PIC16C620A/CR620A/621A and 20-7Fh (Bank0) and A0-BFh (Bank1) on the PIC16C622 and PIC16C622A are General Purpose Registers implemented as static RAM. Some Special Purpose Registers are mapped in Bank 1.

Addresses F0h-FFh of bank1 are implemented as common ram and mapped back to addresses 70h-7Fh in bank0 on the PIC16C620A/621A/622A/CR620A.

#### 4.2.1 GENERAL PURPOSE REGISTER FILE

The register file is organized as 80 x 8 in the PIC16C620/621, 96 x 8 in the PIC16C620A/621A/CR620A and 128 x 8 in the PIC16C622(A). Each is accessed either directly or indirectly through the File Select Register FSR (Section 4.4).









#### 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). To avoid an unintended device RESET, the following instruction sequence (Example 6-1) must be executed when changing the prescaler assignment from Timer0 to WDT.)

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

|          | -            |                                               |
|----------|--------------|-----------------------------------------------|
| 1.BCF    | STATUS, RPO  | ;Skip if already in<br>;Bank 0                |
| 2.CLRWDT |              | ;Clear WDT                                    |
| 3.CLRF   | TMR0         | ;Clear TMR0 & Prescaler                       |
| 4.BSF    | STATUS, RPO  | ;Bank 1                                       |
| 5.MOVLW  | '00101111'b; | ;These 3 lines (5, 6, 7)                      |
| 6.MOVWF  | OPTION       | ;are required only if<br>;desired PS<2:0> are |
| 7.CLRWDT |              | ;000 or 001                                   |
| 8.MOVLW  | '00101xxx'b  | ;Set Postscaler to                            |
| 9.MOVWF  | OPTION       | ;desired WDT rate                             |
| 10.BCF   | STATUS, RPO  | ;Return to Bank 0                             |
|          |              |                                               |

To change prescaler from the WDT to the TMR0 module, use the sequence shown in Example 6-2. This precaution must be taken even if the WDT is disabled.

### EXAMPLE 6-2:

#### CHANGING PRESCALER (WDT→TIMER0)

|        | •           |                    |
|--------|-------------|--------------------|
| CLRWDT |             | ;Clear WDT and     |
|        |             | ;prescaler         |
| BSF    | STATUS, RPO |                    |
| MOVLW  | b'xxxx0xxx' | ;Select TMR0, new  |
|        |             | prescale value and |
|        |             | , plock gourgo     |
|        |             | ,CIOCK SOULCE      |
| MOVWF  | OPTION REG  |                    |
| BCF    | STATUS, RPO |                    |
|        |             |                    |

#### 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 | Value on<br>All Other<br>RESETS |
|---------|--------|--------|-------------|-------|--------|--------|--------|--------|--------|-----------------|---------------------------------|
| 01h     | TMR0   | Timer0 | module regi | ister |        |        |        |        |        | XXXX XXXX       | uuuu uuuu                       |
| 0Bh/8Bh | INTCON | GIE    | PEIE        | T0IE  | INTE   | RBIE   | TOIF   | INTF   | RBIF   | 0000 000x       | 0000 000u                       |
| 81h     | OPTION | RBPU   | INTEDG      | TOCS  | TOSE   | PSA    | PS2    | PS1    | PS0    | 1111 1111       | 1111 1111                       |
| 85h     | TRISA  | _      | _           |       | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 1 1111          | 1 1111                          |

Legend: — = Unimplemented locations, read as '0', u = unchanged, x = unknown

**Note:** Shaded bits are not used by TMR0 module.

#### 9.1 Configuration Bits

The configuration bits can be programmed (read as '0') or left unprogrammed (read as '1') to select various device configurations. These bits are mapped in program memory location 2007h.

The user will note that address 2007h is beyond the user program memory space. In fact, it belongs to the special test/configuration memory space (2000h - 3FFFh), which can be accessed only during programming.

#### REGISTER 9-1: CONFIGURATION WORD (ADDRESS 2007h)

| CP1                                                                                | CP0 (2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | CP1                                                                                                                                                                                                                                                                                                                                   | CP0 (2)                          | CP1        | CP0 (2)   |        | BODEN | CP1 | CP0 <sup>(2)</sup> | PWRTE | WDTE     | F0SC1 | F0SC0 |
|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|------------|-----------|--------|-------|-----|--------------------|-------|----------|-------|-------|
| bit 13                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        | Į     |     | ļ                  |       | <u> </u> | ļ     | bit 0 |
| bit 13-8<br>5-4:                                                                   | <ul> <li>I3-8, CP&lt;1:0&gt;: Code protection bit pairs <sup>(2)</sup><br/>Code protection for 2K program memory<br/>11 = Program memory code protection off<br/>10 = 0400h-07FFh code protected<br/>01 = 0200h-07FFh code protected<br/>00 = 0000h-07FFh code protected</li> <li>Code protection for 1K program memory<br/>11 = Program memory code protection off<br/>10 = Program memory code protection off<br/>01 = 0200h-03FFh code protected<br/>00 = 0000h-03FFh code protected</li> </ul> |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        |       |     |                    |       |          |       |       |
|                                                                                    | Code protection for 0.5K program memory<br>11 = Program memory code protection off<br>10 = Program memory code protection off<br>01 = Program memory code protection off<br>00 = 0000h-01FFh code protected                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        |       |     |                    |       |          |       |       |
| bit 7                                                                              | Uniı                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | npleme                                                                                                                                                                                                                                                                                                                                | e <b>nted</b> : Re               | ead as 'C  | )'        |        |       |     |                    |       |          |       |       |
| bit 6                                                                              | BOI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DEN: Br                                                                                                                                                                                                                                                                                                                               | own-out                          | Reset E    | nable bit | (1)    |       |     |                    |       |          |       |       |
|                                                                                    | 1 =<br>0 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | BOR en<br>BOR dis                                                                                                                                                                                                                                                                                                                     | abled<br>sabled                  |            |           |        |       |     |                    |       |          |       |       |
| bit 3                                                                              | <b>PWI</b><br>1 =<br>0 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>RTE</b> : Po<br>PWRT c<br>PWRT e                                                                                                                                                                                                                                                                                                   | ower-up T<br>disabled<br>enabled | īmer En    | able bit  | (1, 3) |       |     |                    |       |          |       |       |
| bit 2                                                                              | <b>WD</b><br>1 = '<br>0 = '                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TE: Wat<br>WDT en<br>WDT dis                                                                                                                                                                                                                                                                                                          | chdog Ti<br>nabled<br>sabled     | mer Ena    | ble bit   |        |       |     |                    |       |          |       |       |
| bit 1-0                                                                            | FOS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | C1:FO                                                                                                                                                                                                                                                                                                                                 | SCO: Oso                         | cillator S | election  | bits   |       |     |                    |       |          |       |       |
|                                                                                    | 11 -<br>10 =<br>01 =<br>00 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 11 = RC oscillator<br>10 = HS oscillator<br>01 = XT oscillator<br>00 = LP oscillator                                                                                                                                                                                                                                                  |                                  |            |           |        |       |     |                    |       |          |       |       |
|                                                                                    | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <ul> <li>Note 1: Enabling Brown-out Reset automatically enables Power-up Timer (PWRT) regardless of the value of bit PWRTE. Ensure the Power-up Timer is enabled anytime Brown-out Detect Reset is enabled.</li> <li>All of the CP&lt;10&gt; pairs have to be given the same value to enable the code protection achieves.</li> </ul> |                                  |            |           |        |       |     | the<br>eset is     |       |          |       |       |
|                                                                                    | <ol> <li>All of the CP&lt;1:0&gt; pairs have to be given the same value to enable the code protection scheme listed.</li> <li>Unprogrammed parts default the Power-up Timer disabled.</li> </ol>                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        |       |     |                    |       |          |       |       |
| Logond                                                                             | 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        |       |     |                    |       |          |       |       |
| Legend:<br>R = Readable bit $W = Writable bit$ $U = Unimplemented bit read as '0'$ |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                       |                                  |            |           |        |       |     |                    |       |          |       |       |

#### 9.4.5 TIME-OUT SEQUENCE

On power-up the time-out sequence is as follows: First PWRT time-out is invoked after POR has expired. Then OST is activated. The total time-out will vary based on oscillator configuration and <u>PWRTE</u> bit status. For example, in RC mode with <u>PWRTE</u> bit erased (<u>PWRT</u> disabled), there will be no time-out at all. Figure 9-8, Figure 9-9 and Figure 9-10 depict time-out sequences.

Since the time-outs occur from the POR pulse, if  $\overline{\text{MCLR}}$  is kept low long enough, the time-outs will expire. Then bringing  $\overline{\text{MCLR}}$  high will begin execution immediately (see Figure 9-9). This is useful for testing purposes or to synchronize more than one PIC16C62X device operating in parallel.

Table 9-4 shows the RESET conditions for some special registers, while Table 9-5 shows the RESET conditions for all the registers.

#### 9.4.6 POWER CONTROL (PCON)/ STATUS REGISTER

The power control/STATUS register, PCON (address 8Eh), has two bits.

Bit0 is  $\overline{\text{BOR}}$  (Brown-out).  $\overline{\text{BOR}}$  is unknown on Poweron Reset. It must then be set by the user and checked on subsequent RESETS to see if  $\overline{\text{BOR}} = 0$ , indicating that a brown-out has occurred. The  $\overline{\text{BOR}}$  STATUS bit is a don't care and is not necessarily predictable if the brown-out circuit is disabled (by setting BODEN bit = 0 in the Configuration word).

Bit1 is POR (Power-on Reset). It is a '0' on Power-on Reset and unaffected otherwise. The user must write a '1' to this bit following a Power-on Reset. On a subsequent RESET, if POR is '0', it will indicate that a Power-on Reset must have occurred (VDD may have gone too low).

| Oscillator Configuration | Powe              | er-up     | Brown-out Reset   | Wake-up<br>from SLEEP |  |
|--------------------------|-------------------|-----------|-------------------|-----------------------|--|
|                          | PWRTE = 0         | PWRTE = 1 | Brown out Rooot   |                       |  |
| XT, HS, LP               | 72 ms + 1024 Tosc | 1024 Tosc | 72 ms + 1024 Tosc | 1024 Tosc             |  |
| RC                       | 72 ms             |           | 72 ms             | _                     |  |

#### TABLE 9-1: TIME-OUT IN VARIOUS SITUATIONS

|  | <b>TABLE 9-2</b> : | STATUS/PCON BITS AND THEIR SIGNIFICANCE |
|--|--------------------|-----------------------------------------|
|--|--------------------|-----------------------------------------|

| POR | BOR | то | 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   | Х  | Х  | Brown-out Reset                    |  |
| 1   | 1   | 0  | u  | 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            |  |

Legend: u = unchanged, x = unknown

#### TABLE 9-3: SUMMARY OF REGISTERS ASSOCIATED WITH BROWN-OUT

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on<br>POR Reset | Value on all<br>other<br>RESETS <sup>(1)</sup> |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|------------------------------------------------|
| 83h     | STATUS |       |       |       | TO    | PD    |       |       |       | 0001 1xxx             | 000q quuu                                      |
| 8Eh     | PCON   | _     | _     |       |       |       | _     | POR   | BOR   | 0x                    | uq                                             |

Legend: u = unchanged, x = unknown, - = unimplemented bit, reads as '0', q = value depends on condition.

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



FIGURE 9-9: TIME-OUT SEQUENCE ON POWER-UP (MCLR NOT TIED TO VDD): CASE 2



FIGURE 9-10: TIME-OUT SEQUENCE ON POWER-UP (MCLR TIED TO VDD)



TABLE 9-6: SUMMARY OF INTERRUPT REGISTERS

| Address | Name   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Value on POR<br>Reset | Value on all<br>other<br>RESETS <sup>(1)</sup> |
|---------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------------|------------------------------------------------|
| 0Bh     | INTCON | GIE   | PEIE  | TOIE  | INTE  | RBIE  | TOIF  | INTF  | RBIF  | 0000 000x             | 0000 000u                                      |
| 0Ch     | PIR1   | —     | CMIF  | —     | _     | —     | —     | —     | —     | -0                    | -0                                             |
| 8Ch     | PIE1   | —     | CMIE  | _     | _     | _     | —     | _     | _     | -0                    | -0                                             |

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

#### 9.6 Context Saving During Interrupts

During an interrupt, only the return PC value is saved on the stack. Typically, users may wish to save key registers during an interrupt (e.g., W register and STATUS register). This will have to be implemented in software.

Example 9-3 stores and restores the STATUS and W registers. The user register, W\_TEMP, must be defined in both banks and must be defined at the same offset from the bank base address (i.e., W\_TEMP is defined at 0x20 in Bank 0 and it must also be defined at 0xA0 in Bank 1). The user register, STATUS\_TEMP, must be defined in Bank 0. The Example 9-3:

- · Stores the W register
- Stores the STATUS register in Bank 0
- Executes the ISR code
- Restores the STATUS (and bank select bit register)
- · Restores the W register

#### EXAMPLE 9-3: SAVING THE STATUS AND W REGISTERS IN RAM

| MOVWF | W_TEMP            | ;copy W to temp register,<br>;could be in either bank                       |
|-------|-------------------|-----------------------------------------------------------------------------|
| SWAPF | STATUS,W          | ;swap status to be saved<br>into W                                          |
| BCF   | STATUS, RPO       | ;change to bank 0 regardless<br>;of current bank                            |
| MOVWF | STATUS_TEMP       | ;save status to bank 0<br>;register                                         |
| :     |                   |                                                                             |
| :     | (ISR)             |                                                                             |
| :     |                   |                                                                             |
| SWAPF | STATUS_TEMP,<br>W | ;swap STATUS_TEMP register<br>;into W, sets bank to origi-<br>nal<br>;state |
| MOVWF | STATUS            | ;move W into STATUS register                                                |
| SWAPF | W_TEMP,F          | ;swap W_TEMP                                                                |
| SWAPF | W_TEMP,W          | ;swap W_TEMP into W                                                         |

#### 9.9 Code Protection

If the code protection bit(s) have not been programmed, the on-chip program memory can be read out for verification purposes.

| Note: | Microchip  | does   | not   | recommend | code |
|-------|------------|--------|-------|-----------|------|
|       | protecting | windov | ved d | evices.   |      |

#### 9.10 ID Locations

Four memory locations (2000h-2003h) are designated as ID locations where the user can store checksum or other code identification numbers. These locations are not accessible during normal execution, but are readable and writable during Program/Verify. Only the Least Significant 4 bits of the ID locations are used.

### 9.11 In-Circuit Serial Programming™

The PIC16C62X 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.

The device is placed into a Program/Verify mode by holding the RB6 and RB7 pins low, while raising the MCLR (VPP) pin from VIL to VIHH (see programming specification). RB6 becomes the programming clock and RB7 becomes the programming data. Both RB6 and RB7 are Schmitt Trigger inputs in this mode.

After RESET, to place the device into Programming/ Verify mode, the program counter (PC) is at location 00h. A 6-bit command is then supplied to the device. Depending on the command, 14-bits of program data are then supplied to or from the device, depending if the command was a load or a read. For complete details of serial programming, please refer to the PIC16C6X/7X/9XX Programming Specification (DS30228).

A typical In-Circuit Serial Programming connection is shown in Figure 9-19.

# FIGURE 9-19:

#### TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



## **10.1** Instruction Descriptions

| ADDLW            | Add Literal and W                                                                    |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                             |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                    |  |  |  |  |
| Operation:       | $(W) + k \to (W)$                                                                    |  |  |  |  |
| Status Affected: | C, DC, Z                                                                             |  |  |  |  |
| Encoding:        | 11 111x kkkk kkkk                                                                    |  |  |  |  |
| Description:     | added to the eight bit literal 'k' and<br>the result is placed in the W<br>register. |  |  |  |  |
| Cycles:          | 1                                                                                    |  |  |  |  |
| Example          | ADDLW 0x15                                                                           |  |  |  |  |
|                  | Before Instruction<br>W = 0x10<br>After Instruction<br>W = 0x25                      |  |  |  |  |

| ANDLW            | AND Literal with W                                                                                                     |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                               |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                                                      |  |  |  |  |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                        |  |  |  |  |
| Status Affected: | Z                                                                                                                      |  |  |  |  |
| Encoding:        | 11 1001 kkkk kkkk                                                                                                      |  |  |  |  |
| Description:     | The contents of W register are<br>AND'ed with the eight bit literal 'k'.<br>The result is placed in the W<br>register. |  |  |  |  |
| Words:           | 1                                                                                                                      |  |  |  |  |
| Cycles:          | 1                                                                                                                      |  |  |  |  |
| Example          | ANDLW 0x5F                                                                                                             |  |  |  |  |
|                  | Before Instruction<br>W = 0xA3<br>After Instruction<br>W = 0x03                                                        |  |  |  |  |
| ANDWF            | AND W with f                                                                                                           |  |  |  |  |

| ADDWF            | Add W and f                                                                                                                                                                    |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ADDWF f,d                                                                                                                                                     |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                              |  |  |  |  |
| Operation:       | $(W) + (f) \rightarrow (dest)$                                                                                                                                                 |  |  |  |  |
| Status Affected: | C, DC, Z                                                                                                                                                                       |  |  |  |  |
| Encoding:        | 00 0111 dfff ffff                                                                                                                                                              |  |  |  |  |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is 0, the result<br>is stored in the W register. If 'd' is<br>1, the result is stored back in<br>register 'f'. |  |  |  |  |
| Words:           | 1                                                                                                                                                                              |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                              |  |  |  |  |
| Example          | ADDWF FSR, <b>O</b>                                                                                                                                                            |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0xD9<br>FSR = 0xC2                                                                                    |  |  |  |  |

| ANDWF            | AND W with f                                                                                                                                                |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] ANDWF f,d                                                                                                                                  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                           |  |  |  |  |  |
| Operation:       | (W) .AND. (f) $\rightarrow$ (dest)                                                                                                                          |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                           |  |  |  |  |  |
| Encoding:        | 00 0101 dfff ffff                                                                                                                                           |  |  |  |  |  |
| Description:     | AND the W register with register<br>'f'. If 'd' is 0, the result is stored in<br>the W register. If 'd' is 1, the result<br>is stored back in register 'f'. |  |  |  |  |  |
| Words:           | 1                                                                                                                                                           |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                           |  |  |  |  |  |
| Example          | ANDWF FSR, 1                                                                                                                                                |  |  |  |  |  |
|                  | Before Instruction<br>W = 0x17<br>FSR = 0xC2<br>After Instruction<br>W = 0x17<br>FSR = 0x02                                                                 |  |  |  |  |  |

| CLRW                                                                                                     | Clear W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | COMF                                                                                                                        | Complement f                                                                                                                                                                                                                                                                                                                            |  |  |
|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:                                                                                                  | [label] CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Syntax:                                                                                                                     | [ <i>label</i> ] COMF f,d                                                                                                                                                                                                                                                                                                               |  |  |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Operands:                                                                                                                   | $0 \leq f \leq 127$                                                                                                                                                                                                                                                                                                                     |  |  |
| Operation:                                                                                               | $00h \rightarrow (W)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                             | d ∈ [0,1]                                                                                                                                                                                                                                                                                                                               |  |  |
|                                                                                                          | $1 \rightarrow Z$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Operation:                                                                                                                  | $(f) \rightarrow (dest)$                                                                                                                                                                                                                                                                                                                |  |  |
| Status Affected:                                                                                         | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Status Affected:                                                                                                            | Z                                                                                                                                                                                                                                                                                                                                       |  |  |
| Encoding:                                                                                                | 00 0001 0000 0011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Encoding:                                                                                                                   | 00 1001 dfff ffff                                                                                                                                                                                                                                                                                                                       |  |  |
| Description:                                                                                             | W register is cleared. Zero bit (Z) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Description:                                                                                                                | The contents of register 'f' are complemented. If 'd' is 0, the                                                                                                                                                                                                                                                                         |  |  |
| Words:                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                             | result is stored in W. If 'd' is 1, the                                                                                                                                                                                                                                                                                                 |  |  |
| Cycles:                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Words:                                                                                                                      | 1                                                                                                                                                                                                                                                                                                                                       |  |  |
| Example                                                                                                  | CLRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Cyclos:                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                                                                                          | Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Cycles.                                                                                                                     |                                                                                                                                                                                                                                                                                                                                         |  |  |
|                                                                                                          | W = 0x5A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Example                                                                                                                     | COMF REGI,U                                                                                                                                                                                                                                                                                                                             |  |  |
|                                                                                                          | W = 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                             | Before Instruction<br>REG1 = 0x13                                                                                                                                                                                                                                                                                                       |  |  |
|                                                                                                          | Z = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                             | After Instruction                                                                                                                                                                                                                                                                                                                       |  |  |
|                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                             | REG1 = 0x13                                                                                                                                                                                                                                                                                                                             |  |  |
| CLRWDT                                                                                                   | Clear Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                         |  |  |
| Syntax:                                                                                                  | [ /aba/ ] CLRW/DT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                         |  |  |
| Oymax.                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DECE                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                             |  |  |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DECF                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                             |  |  |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DECF<br>Syntax:                                                                                                             | Decrement f<br>[ <i>label</i> ] DECF f,d                                                                                                                                                                                                                                                                                                |  |  |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DECF<br>Syntax:<br>Operands:                                                                                                | Decrement f [ /abe/ ] DECF f,d 0 ≤ f ≤ 127 d ∈ [0, 1]                                                                                                                                                                                                                                                                                   |  |  |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow \overline{PD}$                                                                                                                                                                                                                                                                                                                                                                                   | DECF<br>Syntax:<br>Operands:                                                                                                | Decrement f<br>[ label ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) = 1 $\Longrightarrow$ (dest)                                                                                                                                                                                                                             |  |  |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO} PD$                                                                                                                                                                                                                                                                                                                                                                        | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                              | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (dest)<br>7                                                                                                                                                                                                                     |  |  |
| Operands:<br>Operation:<br>Status Affected:                                                              | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow TO$<br>$1 \rightarrow PD$<br>TO, PD                                                                                                                                                                                                                                                                                                                                                                                               | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                              | Decrement f<br>[ label ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (dest)<br>Z                                                                                                                                                                                                                            |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                 | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>00  0000  0110  0100<br>GLOUDE instruction model the                                                                                                                                                                                                                                                                                                    | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:                                                 | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffDecrement variator kit if if if 0                                                                                                                                                                                                  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>OUBLIE<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS                                                                                                                                                                                                                                           | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ /abe/ ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result is                                                                                                                           |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>OUDIAL OUTION OUTO<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.                                                                                                                                                                                                    | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ /abe/ ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.                                                                                                  |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                       | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow TO$<br>$1 \rightarrow PD$<br>TO, PD<br>O<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>pres <u>cal</u> er of <u>the</u> WDT. STATUS<br>bits TO and PD are set.<br>1                                                                                                                                                                                                                                   | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                       | Decrement f[ /abel ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.1                                                                                              |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:            | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT prescaler,$ $1 \rightarrow \overline{10}$ $1 \rightarrow PD$ $\overline{10}$ $00  0000  0110  0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1                                                                                                                                                                                                                       | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:            | Decrement f[ /abe/ ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11                                                                                                |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow TO$<br>$1 \rightarrow PD$<br>TO, PD<br>00  0000  0110  0100<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>pres <u>caler</u> of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT                                                                                                                                                                                                         | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ /abe/ ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1                                                                           |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>00  0000  0110  0100<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction                                                                                                                                                        | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[/abel]DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dfffffffDecrement register 'f'. If 'd' is 0,<br>the result is stored in the W<br>register. If 'd' is 1, the result is<br>stored back in register 'f'.11DECFCNT, 1Before Instruction                                                       |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow TO$<br>$1 \rightarrow PD$<br>TO, PD<br>00  0000  0110  0100<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction                                                                                                                                                   | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[/abel]DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z $00$ $0011$ dffffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1Before InstructionCNT=0                                                        |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT prescaler,$<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$<br>$\overline{TO}, \overline{PD}$<br>00  0000  0110  0100<br>CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>pres <u>caler</u> of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction<br>WDT counter = 0x00                                                                                  | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ /abel ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z000011dfffffffDecrement register 'f'. If 'd' is 0,<br>the result is stored in the W<br>register. If 'd' is 1, the result is<br>stored back in register 'f'.11DECFCNT, 1Before Instruction<br>$Z = 0$ CNT= 0x01<br>$Z = 0$ After Instruction |  |  |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{c} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline 00 & 0000 & 0110 & 0100 \\ \hline \end{array}$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. STATUS<br>bits TO and PD are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction<br>WDT counter = 0x00<br>WDT prescaler = 0 \\ \end{array} | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ /abe/ ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z $00$ $0011$ dfffffDecrement register 'f'. If 'd' is 0,the result is stored in the Wregister. If 'd' is 1, the result isstored back in register 'f'.11DECFCNT, 1Before InstructionCNT $Z$ $0$ After InstructionCNT $CNT$ $T$ $0x00$         |  |  |

NOTES:

NOTES:







#### 12.4 DC Characteristics: PIC16C62X/C62XA/CR62XA (Commercial, Industrial, Extended) PIC16LC62X/LC62XA/LCR62XA (Commercial, Industrial, Extended) (CONT.)

| PIC16C62X/C62XA/CR62XA    |           |                                            | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
|---------------------------|-----------|--------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----|------------------------------------------------------------------------------------------------|--|--|
| PIC16LC62X/LC62XA/LCR62XA |           |                                            | <b>Standa</b><br>Operat                               | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}$ C $\leq$ TA $\leq$ +85°C for industrial and $0^{\circ}$ C $\leq$ TA $\leq$ +70°C for commercial and $-40^{\circ}$ C $\leq$ TA $\leq$ +125°C for extended |             |    |                                                                                                |  |  |
| Param.<br>No.             | Sym       | Characteristic                             | Min Typ† Max Units Conditions                         |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
|                           | Vol       | Output Low Voltage                         |                                                       |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
| D080                      |           | I/O ports                                  | _                                                     | _                                                                                                                                                                                                                                                   | 0.6         | V  | IoL = 8.5 mA, VDD = 4.5V, -40° to +85°C                                                        |  |  |
|                           |           |                                            | _                                                     | _                                                                                                                                                                                                                                                   | 0.6         | V  | IOL = 7.0 mA, VDD = 4.5V, +125°C                                                               |  |  |
| D083                      |           | OSC2/CLKOUT (RC only)                      | _                                                     | _                                                                                                                                                                                                                                                   | 0.6         | V  | IOL = 1.6 mA, VDD = 4.5V, -40° to +85°C                                                        |  |  |
|                           |           |                                            | _                                                     | _                                                                                                                                                                                                                                                   | 0.6         | V  | IOL = 1.2 mA, VDD = 4.5V, +125°C                                                               |  |  |
|                           | Vон       | Output High Voltage <sup>(3)</sup>         |                                                       |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
| D090                      |           | I/O ports (Except RA4)                     | VDD-0.7                                               |                                                                                                                                                                                                                                                     | _           | v  | IOH = -3.0 mA, VDD = 4.5V, -40° to +85°С                                                       |  |  |
|                           |           |                                            | VDD-0.7                                               |                                                                                                                                                                                                                                                     | _           | V  | Іон = -2.5 mA, Vdd = 4.5V, +125°С                                                              |  |  |
| D092                      |           | OSC2/CLKOUT (RC only)                      | VDD-0.7                                               | _                                                                                                                                                                                                                                                   | _           | V  | IOH = -1.3 mA, VDD = 4.5V, -40° to +85°С                                                       |  |  |
|                           |           |                                            | VDD-0.7                                               | _                                                                                                                                                                                                                                                   | _           | V  | IOH = -1.0 mA, VDD = 4.5V, +125°С                                                              |  |  |
|                           | Vон       | Output High Voltage <sup>(3)</sup>         |                                                       |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
| D090                      |           | I/O ports (Except RA4)                     | VDD-0.7                                               | _                                                                                                                                                                                                                                                   | _           | V  | IOH = -3.0 mA, VDD = 4.5V, -40° to +85°C                                                       |  |  |
|                           |           |                                            | VDD-0.7                                               | _                                                                                                                                                                                                                                                   | _           | V  | IOH = -2.5 mA, VDD = 4.5V, +125°С                                                              |  |  |
| D092                      |           | OSC2/CLKOUT (RC only)                      | VDD-0.7                                               | —                                                                                                                                                                                                                                                   | -           | V  | IOH = -1.3 mA, VDD = 4.5V, -40° to +85°C                                                       |  |  |
|                           |           |                                            | VDD-0.7                                               |                                                                                                                                                                                                                                                     | —           | V  | IOH = -1.0 mA, VDD = 4.5V, +125°C                                                              |  |  |
| *D150                     | Vod       | Open-Drain High Voltage                    |                                                       |                                                                                                                                                                                                                                                     | 10*<br>8.5* | V  | RA4 pin PIC16C62X, PIC16LC62X<br>RA4 pin PIC16C62XA, PIC16LC62XA,<br>PIC16CR62XA, PIC16LCR62XA |  |  |
| *D150                     | Vod       | Open-Drain High Voltage                    |                                                       |                                                                                                                                                                                                                                                     | 10*<br>8.5* | V  | RA4 pin PIC16C62X, PIC16LC62X<br>RA4 pin PIC16C62XA, PIC16LC62XA,<br>PIC16CR62XA, PIC16LCR62XA |  |  |
|                           |           | Capacitive Loading Specs on<br>Output Pins |                                                       |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
| D100                      | COSC<br>2 | OSC2 pin                                   |                                                       |                                                                                                                                                                                                                                                     | 15          | pF | In XT, HS and LP modes when external<br>clock used to drive OSC1.                              |  |  |
| D101                      | Сю        | All I/O pins/OSC2 (in RC mode)             |                                                       |                                                                                                                                                                                                                                                     | 50          | pF |                                                                                                |  |  |
|                           |           | Capacitive Loading Specs on<br>Output Pins |                                                       |                                                                                                                                                                                                                                                     |             |    |                                                                                                |  |  |
| D100                      | COSC<br>2 | OSC2 pin                                   |                                                       |                                                                                                                                                                                                                                                     | 15          | pF | In XT, HS and LP modes when external<br>clock used to drive OSC1.                              |  |  |
| D101                      | Сю        | All I/O pins/OSC2 (in RC mode)             |                                                       |                                                                                                                                                                                                                                                     | 50          | pF |                                                                                                |  |  |

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:** In RC oscillator configuration, the OSC1 pin is a Schmitt Trigger input. It is not recommended that the PIC16C62X(A) be driven with external clock in RC mode.

2: The leakage current on the MCLR pin is strongly dependent on applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

**3:** Negative current is defined as coming out of the pin.

\*

#### 12.9 Timing Diagrams and Specifications

#### FIGURE 12-12: EXTERNAL CLOCK TIMING



#### TABLE 12-3: EXTERNAL CLOCK TIMING REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                          | Min  | Тур†   | Max    | Units | Conditions                         |
|------------------|-------|-----------------------------------------|------|--------|--------|-------|------------------------------------|
| 1A               | Fosc  | External CLKIN Frequency <sup>(1)</sup> | DC   | —      | 4      | MHz   | XT and RC Osc mode, VDD=5.0V       |
|                  |       |                                         | DC   | —      | 20     | MHz   | HS Osc mode                        |
|                  |       |                                         | DC   | —      | 200    | kHz   | LP Osc mode                        |
|                  |       | Oscillator Frequency <sup>(1)</sup>     | DC   | —      | 4      | MHz   | RC Osc mode, VDD=5.0V              |
|                  |       |                                         | 0.1  | _      | 4      | MHz   | XT Osc mode                        |
|                  |       |                                         | 1    | _      | 20     | MHz   | HS Osc mode                        |
|                  |       |                                         | DC   | _      | 200    | kHz   | LP Osc mode                        |
| 1                | Tosc  | External CLKIN Period <sup>(1)</sup>    | 250  | _      |        | ns    | XT and RC Osc mode                 |
|                  |       |                                         | 50   | _      |        | ns    | HS Osc mode                        |
|                  |       |                                         | 5    | _      | _      | μS    | LP Osc mode                        |
|                  |       | Oscillator Period <sup>(1)</sup>        | 250  | _      |        | ns    | RC Osc mode                        |
|                  |       |                                         | 250  | _      | 10,000 | ns    | XT Osc mode                        |
|                  |       |                                         | 50   | _      | 1,000  | ns    | HS Osc mode                        |
|                  |       |                                         | 5    | _      |        | μS    | LP Osc mode                        |
| 2                | Тсү   | Instruction Cycle Time <sup>(1)</sup>   | 1.0  | Fosc/4 | DC     | μS    | Tcys=Fosc/4                        |
| 3*               | TosL, | External Clock in (OSC1) High or        | 100* | _      |        | ns    | XT oscillator, Tosc L/H duty cycle |
|                  | TosH  | Low Time                                | 2*   | _      |        | μS    | LP oscillator, Tosc L/H duty cycle |
|                  |       |                                         | 20*  | _      |        | ns    | HS oscillator, Tosc L/H duty cycle |
| 4*               | TosR, | External Clock in (OSC1) Rise or        | 25*  | _      |        | ns    | XT oscillator                      |
|                  | TosF  | Fall Time                               | 50*  | —      | —      | ns    | LP oscillator                      |
|                  |       |                                         | 15*  | —      | _      | ns    | HS oscillator                      |

**2:** \* These parameters are characterized but not tested.

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

Note 1: Instruction cycle period (TCY) equals four times the input oscillator time-base period. All specified values are based on characterization data for that particular oscillator type under standard operating conditions with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "min." values with an external clock applied to the OSC1 pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices.

## FIGURE 12-14: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING



#### FIGURE 12-15: BROWN-OUT RESET TIMING



# TABLE 12-5:RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP<br/>TIMER REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                                   | Min  | Тур†      | Max  | Units | Conditions                       |
|------------------|-------|--------------------------------------------------|------|-----------|------|-------|----------------------------------|
| 30               | TmcL  | MCLR Pulse Width (low)                           | 2000 | —         |      | ns    | -40° to +85°C                    |
| 31               | Twdt  | Watchdog Timer Time-out Period<br>(No Prescaler) | 7*   | 18        | 33*  | ms    | VDD = 5.0V, -40° to +85°C        |
| 32               | Tost  | Oscillation Start-up Timer Period                | _    | 1024 Tosc | _    |       | Tosc = OSC1 period               |
| 33               | Tpwrt | Power-up Timer Period                            | 28*  | 72        | 132* | ms    | VDD = 5.0V, -40° to +85°C        |
| 34               | Tioz  | I/O hi-impedance from MCLR low                   |      | —         | 2.0  | μS    |                                  |
| 35               | TBOR  | Brown-out Reset Pulse Width                      | 100* | _         |      | μs    | $3.7V \leq V\text{DD} \leq 4.3V$ |

\* These parameters are characterized but not tested.

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

### **APPENDIX A: ENHANCEMENTS**

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

- Instruction word length is increased to 14 bits. This allows larger page sizes both in program memory (4K now as opposed to 512 before) and register file (up to 128 bytes now versus 32 bytes before).
- 2. A PC high latch register (PCLATH) is added to handle program memory paging. PA2, PA1, PA0 bits are removed from STATUS register.
- 3. Data memory paging is slightly redefined. 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 compatibility 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.
- 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-onchange feature.
- 13. Timer0 clock input, T0CKI pin is also a port pin (RA4/T0CKI) and has a TRIS bit.
- 14. FSR is made a full 8-bit register.
- 15. "In-circuit programming" is made possible. The user can program PIC16CXX devices using only five pins: VDD, VSS, VPP, RB6 (clock) and RB7 (data in/out).
- PCON STATUS register is added with a Poweron-Reset (POR) STATUS bit and a Brown-out Reset STATUS bit (BOD).
- 17. Code protection scheme is enhanced such that portions of the program memory can be protected, while the remainder is unprotected.
- 18. PORTA inputs are now Schmitt Trigger inputs.
- 19. Brown-out Reset reset has been added.
- 20. Common RAM registers F0h-FFh implemented in bank1.

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

### **READER RESPONSE**

It is our intention to provide you with the best documentation possible to ensure successful use of your Microchip product. If you wish to provide your comments on organization, clarity, subject matter, and ways in which our documentation can better serve you, please FAX your comments to the Technical Publications Manager at (480) 792-4150.

Please list the following information, and use this outline to provide us with your comments about this document.

| To:      | Technical Publications Manag        | er Total Pages Sent                                       |
|----------|-------------------------------------|-----------------------------------------------------------|
| RE:      | Reader Response                     |                                                           |
| From     | n: Name                             |                                                           |
|          | Company                             |                                                           |
|          | Address                             |                                                           |
|          | City / State / ZIP / Country        |                                                           |
|          | Telephone: ()                       | FAX: ()                                                   |
| Appl     | ication (optional):                 |                                                           |
| Wou      | ld you like a reply?YN              |                                                           |
| Devi     | ce: PIC16C62X                       | _iterature Number: DS30235J                               |
| Que      | stions:                             |                                                           |
| 1. \     | What are the best features of this  | document?                                                 |
| -        |                                     |                                                           |
| <u>-</u> |                                     |                                                           |
| 2. I     | How does this document meet yo      | ar hardware and software development needs?               |
| -        |                                     |                                                           |
| 3. [     | Do you find the organization of thi | s document easy to follow? If not, why?                   |
| _        |                                     |                                                           |
| _        |                                     |                                                           |
| 4. \     | What additions to the document d    | o you think would enhance the structure and subject?      |
| -        |                                     |                                                           |
| -        |                                     |                                                           |
| 5. \     | What deletions from the documen     | t could be made without affecting the overall usefulness? |
| -        |                                     |                                                           |
| -<br>6 I | s there any incorrect or misleadin  | a information (what and where)?                           |
| 0. 1     |                                     |                                                           |
| -        |                                     |                                                           |
| 7. H     | How would you improve this docu     | ment?                                                     |
| _        |                                     |                                                           |
| -        |                                     |                                                           |
|          |                                     |                                                           |