



#### 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             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| 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        | 3.5KB (2K x 14)                                                           |
| Program Memory Type        | OTP                                                                       |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V                                                                 |
| Data Converters            | -                                                                         |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                           |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                                   |
| Supplier Device Package    | 18-PDIP                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc622-04-p |

Email: info@E-XFL.COM

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

#### 4.2.2 SPECIAL FUNCTION REGISTERS

The Special Function Registers are registers used by the CPU and Peripheral functions for controlling the desired operation of the device (Table 4-1). These registers are static RAM. The Special Function Registers can be classified into two sets (core and peripheral). The Special Function Registers associated with the "core" functions are described in this section. Those related to the operation of the peripheral features are described in the section of that peripheral feature.

| 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> |
|---------|---------------|------------------------|--------------------|-------------|---------------|--------------|--------------|-------------|------------|-----------------------|------------------------------------------------|
| Bank 0  |               |                        |                    |             |               |              |              |             |            |                       |                                                |
| 00h     | INDF          | Addressin<br>register) | ig this locat      | a physical  | XXXX XXXX     | XXXX XXXX    |              |             |            |                       |                                                |
| 01h     | TMR0          | Timer0 Mo              | odule's Reg        | ister       |               |              |              |             |            | xxxx xxxx             | uuuu uuuu                                      |
| 02h     | PCL           | Program (              | Counter's (F       | PC) Least S | Significant B | yte          |              |             |            | 0000 0000             | 0000 0000                                      |
| 03h     | STATUS        | IRP <sup>(2)</sup>     | RP1 <sup>(2)</sup> | RP0         | TO            | PD           | Z            | DC          | С          | 0001 1xxx             | 000q quuu                                      |
| 04h     | FSR           | Indirect da            | ata memory         | address po  | ointer        |              |              |             |            | xxxx xxxx             | uuuu uuuu                                      |
| 05h     | PORTA         | —                      | —                  | —           | RA4           | RA3          | RA2          | RA1         | RA0        | x 0000                | u 0000                                         |
| 06h     | PORTB         | RB7                    | RB6                | RB5         | RB4           | RB3          | RB2          | RB1         | RB0        | xxxx xxxx             | uuuu uuuu                                      |
| 07h-09h | Unimplemented |                        |                    |             |               |              |              |             |            | _                     | _                                              |
| 0Ah     | PCLATH        | —                      | —                  | —           | Write buffe   | er for upper | 5 bits of pr | ogram coui  | nter       | 0 0000                | 0 0000                                         |
| 0Bh     | INTCON        | GIE                    | PEIE               | T0IE        | INTE          | RBIE         | T0IF         | INTF        | RBIF       | 0000 000x             | 0000 000u                                      |
| 0Ch     | PIR1          | —                      | CMIF               | —           | —             | —            | —            | —           | —          | -0                    | -0                                             |
| 0Dh-1Eh | Unimplemented |                        |                    |             |               |              |              |             |            | _                     | _                                              |
| 1Fh     | CMCON         | C2OUT                  | C10UT              | —           | —             | CIS          | CM2          | CM1         | CM0        | 00 0000               | 00 0000                                        |
| Bank 1  |               |                        |                    |             |               |              |              |             |            |                       |                                                |
| 80h     | INDF          | Addressin register)    | g this locat       | ion uses co | ntents of FS  | SR to addre  | ess data me  | mory (not a | a physical | xxxx xxxx             | xxxx xxxx                                      |
| 81h     | OPTION        | RBPU                   | INTEDG             | TOCS        | TOSE          | PSA          | PS2          | PS1         | PS0        | 1111 1111             | 1111 1111                                      |
| 82h     | PCL           | Program (              | Counter's (F       | PC) Least S | ignificant B  | yte          |              |             |            | 0000 0000             | 0000 0000                                      |
| 83h     | STATUS        | IRP <sup>(2)</sup>     | RP1 <sup>(2)</sup> | RP0         | TO            | PD           | Z            | DC          | С          | 0001 1xxx             | 000q quuu                                      |
| 84h     | FSR           | Indirect da            | ata memory         | address po  | ointer        |              |              |             |            | xxxx xxxx             | uuuu uuuu                                      |
| 85h     | TRISA         | -                      | -                  | —           | TRISA4        | TRISA3       | TRISA2       | TRISA1      | TRISA0     | 1 1111                | 1 1111                                         |
| 86h     | TRISB         | TRISB7                 | TRISB6             | TRISB5      | TRISB4        | TRISB3       | TRISB2       | TRISB1      | TRISB0     | 1111 1111             | 1111 1111                                      |
| 87h-89h | Unimplemented |                        |                    |             |               |              |              |             |            | _                     | _                                              |
| 8Ah     | PCLATH        | -                      | -                  | —           | Write buffe   | er for upper | 5 bits of pr | ogram coui  | nter       | 0 0000                | 0 0000                                         |
| 8Bh     | INTCON        | GIE                    | PEIE               | T0IE        | INTE          | RBIE         | T0IF         | INTF        | RBIF       | 0000 000x             | 0000 000u                                      |
| 8Ch     | PIE1          | —                      | CMIE               | —           | —             | —            | —            | —           | —          | -0                    | -0                                             |
| 8Dh     | Unimplemented |                        |                    |             |               |              |              |             |            | _                     | _                                              |
| 8Eh     | PCON          | _                      | _                  | _           | _             | —            | —            | POR         | BOR        | 0x                    | uq                                             |
| 8Fh-9Eh | Unimplemented |                        |                    |             |               |              |              |             | -          | _                     | _                                              |
| 9Fh     | VRCON         | VREN                   | VROE               | VRR         | _             | VR3          | VR2          | VR1         | VR0        | 000- 0000             | 000- 0000                                      |

TABLE 4-1: SPECIAL REGISTERS FOR THE PIC16C62X

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

 ${\rm q}$  = value depends on condition, shaded = unimplemented

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

2: IRP & RP1 bits are reserved; always maintain these bits clear.

The code example in Example 7-1 depicts the steps required to configure the comparator module. RA3 and RA4 are configured as digital output. RA0 and RA1 are configured as the V- inputs and RA2 as the V+ input to both comparators.

#### EXAMPLE 7-1: INITIALIZING COMPARATOR MODULE

| MOVLW | 0x03         | ;Init comparator mode             |
|-------|--------------|-----------------------------------|
| MOVWF | CMCON        | ;CM<2:0> = 011                    |
| CLRF  | PORTA        | ;Init PORTA                       |
| BSF   | STATUS, RPO  | ;Select Bank1                     |
| MOVLW | 0x07         | ;Initialize data direction        |
| MOVWF | TRISA        | ;Set RA<2:0> as inputs            |
|       |              | ;RA<4:3> as outputs               |
|       |              | ;TRISA<7:5> always read `0'       |
| BCF   | STATUS, RPO  | ;Select Bank 0                    |
| CALL  | DELAY 10     | ;10µs delay                       |
| MOVF  | CMCON,F      | ;Read CMCONtoend change condition |
| BCF   | PIR1,CMIF    | ;Clear pending interrupts         |
| BSF   | STATUS, RPO  | ;Select Bank 1                    |
| BSF   | PIE1,CMIE    | ;Enable comparator interrupts     |
| BCF   | STATUS, RPO  | ;Select Bank 0                    |
| BSF   | INTCON, PEIE | ;Enable peripheral interrupts     |
| BSF   | INTCON, GIE  | ;Global interrupt enable          |

### 7.2 Comparator Operation

A single comparator is shown in Figure 7-2 along with the relationship between the analog input levels and the digital output. When the analog input at VIN+ is less than the analog input VIN-, the output of the comparator is a digital low level. When the analog input at VIN+ is greater than the analog input VIN-, the output of the comparator is a digital high level. The shaded areas of the output of the comparator in Figure 7-2 represent the uncertainty due to input offsets and response time.

#### 7.3 Comparator Reference

An external or internal reference signal may be used depending on the comparator Operating mode. The analog signal that is present at VIN- is compared to the signal at VIN+, and the digital output of the comparator is adjusted accordingly (Figure 7-2).





#### 7.3.1 EXTERNAL REFERENCE SIGNAL

When external voltage references are used, the comparator module can be configured to have the comparators operate from the same or different reference sources. However, threshold detector applications may require the same reference. The reference signal must be between VSs and VDD, and can be applied to either pin of the comparator(s).

#### 7.3.2 INTERNAL REFERENCE SIGNAL

The comparator module also allows the selection of an internally generated voltage reference for the comparators. Section 10, Instruction Sets, contains a detailed description of the Voltage Reference Module that provides this signal. The internal reference signal is used when the comparators are in mode CM<2:0>=010 (Figure 7-1). In this mode, the internal voltage reference is applied to the VIN+ pin of both comparators.

#### 7.4 Comparator Response Time

Response time is the minimum time, after selecting a new reference voltage or input source, before the comparator output has a valid level. If the internal reference is changed, the maximum delay of the internal voltage reference must be considered when using the comparator outputs. Otherwise the maximum delay of the comparators should be used (Table 12-2).

#### 7.5 Comparator Outputs

The comparator outputs are read through the CMCON register. These bits are read only. The comparator outputs may also be directly output to the RA3 and RA4 I/O pins. When the CM<2:0> = 110, multiplexors in the output path of the RA3 and RA4 pins will switch and the output of each pin will be the unsynchronized output of the comparator. The uncertainty of each of the comparators is related to the input offset voltage and the response time given in the specifications. Figure 7-3 shows the comparator output block diagram.

The TRISA bits will still function as an output enable/ disable for the RA3 and RA4 pins while in this mode.

- Note 1: When reading the PORT register, all pins configured as analog inputs will read as a '0'. Pins configured as digital inputs will convert an analog input according to the Schmitt Trigger input specification.
  - 2: Analog levels on any pin that is defined as a digital input may cause the input buffer to consume more current than is specified.

#### FIGURE 7-3: COMPARATOR OUTPUT BLOCK DIAGRAM



#### 8.0 **VOLTAGE REFERENCE** MODULE

The Voltage Reference is a 16-tap resistor ladder network that provides a selectable voltage reference. The resistor ladder is segmented to provide two ranges of VREF values and has a power-down function to conserve power when the reference is not being used. The VRCON register controls the operation of the reference as shown in Register 8-1. The block diagram is given in Figure 8-1.

#### 8.1 **Configuring the Voltage Reference**

The Voltage Reference can output 16 distinct voltage levels for each range. The equations used to calculate the output of the Voltage Reference are as follows:

if VRR = 0: VREF = (VDD x 1/4) + (VR<3:0>/32) x VDD

The setting time of the Voltage Reference must be considered when changing the VREF output (Table 12-1). Example 8-1 shows an example of how to configure the Voltage Reference for an output voltage of 1.25V with VDD = 5.0V.

|               | R/W-0                      | R/W-0                         | R/W-0                  | U-0          | R/W-0       | R/W-0      | R/W-0        | R/W-0   |
|---------------|----------------------------|-------------------------------|------------------------|--------------|-------------|------------|--------------|---------|
|               | VREN                       | VROE                          | Vrr                    | _            | VR3         | VR2        | VR1          | Vr0     |
|               | bit 7                      |                               |                        |              |             |            |              | bit 0   |
|               |                            |                               |                        |              |             |            |              |         |
| bit 7         | VREN: VREI<br>1 = VREF C   | F Enable<br>ircuit power      | ed on                  |              |             |            |              |         |
|               | 0 = VREF C                 | ircuit powere                 | ed down, no            | IDD drain    |             |            |              |         |
| bit 6         | VROE: VRE                  | F Output En                   | able                   |              |             |            |              |         |
|               | 1 = VREF IS<br>0 = VREF IS | s output on F<br>s disconnect | cA2 pin<br>ed from RA2 | 2 pin        |             |            |              |         |
| bit 5         | VRR: VREF                  | Range sele                    | ction                  | •            |             |            |              |         |
|               | 1 = Low Ra                 | ange                          |                        |              |             |            |              |         |
| hit 1         |                            | ange                          | d aa '0'               |              |             |            |              |         |
| DIC 4         | Unimplem                   | ented: Rea                    | das U                  |              |             |            |              |         |
| bit 3-0       | VR<3:0>: \                 | /REF value s                  | election $0 \leq$      | VR [3:0] ≤ 1 | 5           |            |              |         |
|               | when VRR                   | = 1: VREF =                   | (VR<3:0>/ 2            | 4) * VDD     | 0) + ) /    |            |              |         |
|               | when VRR                   | = 0: VREF =                   | 1/4 ^ VDD +            | (VR<3:0>/ 3  | 2) ^ VDD    |            |              |         |
|               | Legend:                    |                               |                        |              |             |            |              |         |
|               | R = Reada                  | ıble bit                      | W = W                  | /ritable bit | U = Unin    | nplemented | bit, read as | '0'     |
|               | - n = Value                | at POR                        | '1' = B                | it is set    | '0' = Bit i | s cleared  | x = Bit is u | Inknown |
| 8-1:          | VOLTAGE                    |                               |                        | K DIAGR      | ۸M          |            |              |         |
|               |                            |                               | 16 \$                  | Stages       |             |            |              |         |
| $\sim$        | T                          |                               |                        | ∕            |             | _          |              |         |
| $\rightarrow$ | -여드 <sub>8R</sub>          | R                             | R                      | R            | R           |            |              |         |
|               |                            |                               | ΔΔΔ .                  | ۸ ۸ ۸        | A A A       |            |              |         |

#### **REGISTER 8-1:** VRCON REGISTER(ADDRESS 9Fh)

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

#### **FIGURE 8-**





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)



#### 9.7 Watchdog Timer (WDT)

The Watchdog Timer is a free running on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the RC oscillator of the CLKIN pin. That means that the WDT will run, even if the clock on the OSC1 and OSC2 pins of the device has been stopped, for example, by execution of a SLEEP instruction. During normal operation, a WDT time-out generates a device RESET. If the device is in SLEEP mode, a WDT time-out causes the device to wake-up and continue with normal operation. The WDT can be permanently disabled by programming the configuration bit WDTE as clear (Section 9.1).

#### 9.7.1 WDT PERIOD

The WDT has a nominal time-out period of 18 ms, (with no prescaler). The time-out periods vary with temperature, VDD and process variations from part to part (see

DC specs). If longer time-out periods are desired, a prescaler with a division ratio of up to 1:128 can be assigned to the WDT under software control by writing to the OPTION register. Thus, time-out periods up to 2.3 seconds can be realized.

The CLRWDT and SLEEP instructions clear the WDT and the postscaler, if assigned to the WDT, and prevent it from timing out and generating a device RESET.

The  $\overline{\text{TO}}$  bit in the STATUS register will be cleared upon a Watchdog Timer time-out.

#### 9.7.2 WDT PROGRAMMING CONSIDERATIONS

It should also be taken in account that under worst case conditions (VDD = Min., Temperature = Max., max. WDT prescaler) it may take several seconds before a WDT time-out occurs.



#### FIGURE 9-17: WATCHDOG TIMER BLOCK DIAGRAM

| 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 |
|---------|--------------|-------|--------|-------|-------|-------|-------|-------|-------|-----------------------|---------------------------------|
| 2007h   | Config. bits | —     | BODEN  | CP1   | CP0   | PWRTE | WDTE  | FOSC1 | FOSC0 | —                     | —                               |
| 81h     | OPTION       | RBPU  | INTEDG | TOCS  | TOSE  | PSA   | PS2   | PS1   | PS0   | 1111 1111             | 1111 1111                       |

Legend: Shaded cells are not used by the Watchdog Timer.

**Note:** – = Unimplemented location, read as "0"

+ = Reserved for future use

| BTFSS        | Bit Test f, Skip if Set                                                                                                                                                                                                       | CALL             | Call Subroutine                                                                                                                                                                                                   |  |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Syntax:      | [ <i>label</i> ]BTFSS f,b                                                                                                                                                                                                     | Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                           |  |  |
| Operands:    | $0 \leq f \leq 127$                                                                                                                                                                                                           | Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                              |  |  |
| Operation:   | 0 ≤ b < 7<br>skip if (f <b>) = 1</b>                                                                                                                                                                                          | Operation:       | (PC)+ 1→ TOS,<br>k → PC<10:0>,<br>(PCLATH<4:3>) → PC<12:11>                                                                                                                                                       |  |  |
| Encoding:    |                                                                                                                                                                                                                               | Status Affected: | None                                                                                                                                                                                                              |  |  |
| Encouring.   | If hit 'h' in register 'f' is '1', then the                                                                                                                                                                                   | Encoding:        | 10 Okkk kkkk kkkk                                                                                                                                                                                                 |  |  |
| Description. | next instruction is skipped.<br>If bit 'b' is '1', then the next instruc-<br>tion fetched during the current<br>instruction execution, is discarded<br>and a NOP is executed instead,<br>making this a two-cycle instruction. | Description:     | Call Subroutine. First, return<br>address (PC+1) is pushed onto<br>the stack. The eleven bit immedi-<br>ate address is loaded into PC bits<br><10:0>. The upper bits of the PC<br>are loaded from PCLATH. CALL is |  |  |
| Words:       | 1                                                                                                                                                                                                                             |                  | a two-cycle instruction.                                                                                                                                                                                          |  |  |
| Cycles:      | 1(2)                                                                                                                                                                                                                          | vvords:          | 1                                                                                                                                                                                                                 |  |  |
| Example      | HERE BTFSS FLAG,1                                                                                                                                                                                                             | Cycles:          | 2                                                                                                                                                                                                                 |  |  |
|              | TRUE • DE                                                                                                                                                                                                                     | Example          | HERE CALL<br>THER<br>E                                                                                                                                                                                            |  |  |
|              | Before Instruction<br>PC = address HERE<br>After Instruction<br>if FLAG<1> = 0,<br>PC = address FALSE<br>if FLAG<1> = 1,<br>PC = address TRUE                                                                                 |                  | PC = Address HERE<br>After Instruction<br>PC = Address THERE<br>TOS = Address HERE+1                                                                                                                              |  |  |
|              |                                                                                                                                                                                                                               | CLRF             | Clear f                                                                                                                                                                                                           |  |  |
|              |                                                                                                                                                                                                                               | Syntax:          | [ <i>label</i> ] CLRF f                                                                                                                                                                                           |  |  |
|              |                                                                                                                                                                                                                               | Operands:        | $0 \le f \le 127$                                                                                                                                                                                                 |  |  |
|              |                                                                                                                                                                                                                               | Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$                                                                                                                                             |  |  |
|              |                                                                                                                                                                                                                               | Status Affected: | Z                                                                                                                                                                                                                 |  |  |
|              |                                                                                                                                                                                                                               | Encoding:        | 00 0001 1fff ffff                                                                                                                                                                                                 |  |  |
|              |                                                                                                                                                                                                                               | Description:     | The contents of register 'f' are cleared and the Z bit is set.                                                                                                                                                    |  |  |
|              |                                                                                                                                                                                                                               | Words:           | 1                                                                                                                                                                                                                 |  |  |
|              |                                                                                                                                                                                                                               | Cycles:          | 1                                                                                                                                                                                                                 |  |  |
|              |                                                                                                                                                                                                                               | Example          | CLRF FLAG_REG                                                                                                                                                                                                     |  |  |
|              |                                                                                                                                                                                                                               |                  | Before Instruction<br>FLAG_REG = 0x5A<br>After Instruction<br>FLAG_REG = 0x00<br>Z = 1                                                                                                                            |  |  |

| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Cycles:                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                          | Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Evernle                                                                                                                     | COME DECI 0                                                                                                                                                                                                                                                                                                                                                                              |
|                                                                                                          | W = 0x5A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Example                                                                                                                     | Comp REGI, 0                                                                                                                                                                                                                                                                                                                                                                             |
|                                                                                                          | W = 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                             | REG1 = $0x13$                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                          | Z = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                             | After Instruction                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                             | $\begin{array}{rcl} REG1 &= & 0x13 \\ W &= & 0xEC \end{array}$                                                                                                                                                                                                                                                                                                                           |
| CLRWDT                                                                                                   | Clear Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                          |
| Syntax:                                                                                                  | [label] CLRWDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                          |
| e jineaa                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DECE                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                                                                              |
| Operands:                                                                                                | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DECF                                                                                                                        | Decrement f                                                                                                                                                                                                                                                                                                                                                                              |
| Operands:<br>Operation:                                                                                  | None $00h \rightarrow WDT$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | DECF<br>Syntax:                                                                                                             | Decrement f [/abe/] DECF f,d                                                                                                                                                                                                                                                                                                                                                             |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$                                                                                                                                                                                                                                                                                                                                                                                                                               | DECF<br>Syntax:<br>Operands:                                                                                                | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                           |
| Operands:<br>Operation:                                                                                  | None<br>$00h \rightarrow WDT$<br>$0 \rightarrow WDT$ prescaler,<br>$1 \rightarrow \overline{TO}$<br>$1 \rightarrow PD$                                                                                                                                                                                                                                                                                                                                                                                                         | DECF<br>Syntax:<br>Operands:<br>Operation:                                                                                  | 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)                                                                                                                                                                                                                                                                           |
| Operands:<br>Operation:<br>Status Affected:                                                              | 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>[ label ] 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$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow TO$ $1 \rightarrow PD$ $TO, PD$ $00 \qquad 0000 \qquad 0110 \qquad 0100$                                                                                                                                                                                                                                                                                                                                                                   | 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)Z000011dfffffff                                                                                                                                                                                                                                                                               |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{TO}$ $1 \rightarrow PD$ $\overline{TO}, \overline{PD}$ $00  0000  0110  0100$ CLEWDT instruction resets the                                                                                                                                                                                                                                                                                                                      | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f $[label]$ DECF f,d $0 \le f \le 127$ $d \in [0,1]$ $(f) - 1 \rightarrow (dest)$ Z $00$ $0011$ dffdffDecrement register 'f'If 'd' is 0                                                                                                                                                                                                                                        |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{10}$ $1 \rightarrow PD$ $\overline{10}, PD$ $00  0000  0110  0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the                                                                                                                                                                                                                                                                                           | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ label ] 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 W                                                                                                                                                                                                                   |
| 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 OF CONSTRUCTION OF CONSTRUCTION OF CONSTRUCTION<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[ label ] 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 is                                                                                                                                                                     |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | None<br>$00h \rightarrow WDT$ $0 \rightarrow WDT \text{ prescaler,}$ $1 \rightarrow \overline{10}$ $1 \rightarrow PD$ $\overline{10}, PD$ $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.                                                                                                                                                                                                                                | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                 | Decrement f[ label ] 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>$\begin{array}{c} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \hline 00 & 0000 & 0110 & 0100 \\ \hline \\ CLRWDT \text{ instruction resets the} \\ Watchdog Timer. It also resets the \\ prescaler of the WDT. STATUS \\ bits TO and PD are set. \\ 1 \\ \end{array}$                                                                                                                              | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                       | Decrement f $[label]$ 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'.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 TO$ $1 \rightarrow PD$ $TO, PD$ $00 0000 0110 0100$ CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>pres <u>caler of the</u> 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[ label ] 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'.11                                                                                                                                              |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \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                                                                                                                             | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] 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}, 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 = 2                                                                                                                                                           | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f<br>[ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 → (dest)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f'. If 'd' is 0,<br>the result is stored in the W<br>register. If 'd' is 1, the result is<br>stored back in register 'f'.<br>1<br>1<br>DECF CNT, 1<br>Before Instruction<br>CNT = 0x01                                               |
| Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | None<br>$\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \text{ prescaler,} \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \hline \overline{TO}, \overline{PD} \\ \hline \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                                                               | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] 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'.11DECFCNT, 1Before Instruction $CNT = 0x01$ $Z = 0$                                                                                             |
| 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 \ prescaler, \\ 1 \rightarrow TO \\ 1 \rightarrow PD \\ \hline TO, PD \\ \hline 00 & 0000 & 0110 & 0100 \\ \hline \\ CLRWDT \ instruction \ resets the \\ Watchdog \ Timer. It also resets the \\ prescaler \ of \ the \ WDT. \ STATUS \\ bits \ TO \ and \ PD \ are \ set. \\ 1 \\ 1 \\ \hline \\ CLRWDT \\ \hline \\ Before \ Instruction \\ \ WDT \ counter \ = \ ? \\ After \ Instruction \\ \ WDT \ counter \ = \ 0x00 \\ \hline \end{array}$          | DECF<br>Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example | Decrement f[ label ] 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 InstructionCNTZ0After 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 \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 $\overline{TO}$ and $\overline{PD}$ are set.<br>1<br>1<br>CLRWDT<br>Before Instruction<br>WDT counter = ?<br>After Instruction<br>WDT counter = 0<br>$\overline{TO}$ = 1 | DECF<br>Syntax:<br>Operands:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Example               | Decrement f[ label ] DECF f,d $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (dest)Z000011dffffffDecrement 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$ After Instruction<br>$CNT = 0x01$<br>$Z = 0$ After Instruction<br>$CNT = 0x00$<br>$Z = 1$ |

| DECFSZ           | Decrement f, Skip if 0                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Syntax:          | [label] DECFSZ f,d                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| Operation:       | (f) - 1 $\rightarrow$ (dest); skip if result = 0                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Encoding:        | 00 1011 dfff ffff                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description:     | The contents of register 'f' are<br>decremented. If 'd' is 0, the result<br>is placed in the W register. If 'd' is<br>1, the result is placed back in<br>register 'f'.<br>If the result is 0, the next instruc-<br>tion, which is already fetched, is<br>discarded. A NOP is executed<br>instead making it a two-cycle<br>instruction |  |  |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Cycles:          | 1(2)                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Example          | HERE DECFSZ CNT, 1<br>GOTO LOOP<br>CONTINUE •<br>•<br>•                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                  | After Instruction<br>CNT = CNT - 1<br>if CNT = 0,<br>PC = address CONTINUE<br>if CNT ≠ 0,<br>PC = address HERE+1                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| GOTO             | Unconditional Branch                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Syntax:          | [ <i>label</i> ] GOTO k                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Operands:        | $0 \leq k \leq 2047$                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Operation:       | k → PC<10:0><br>PCLATH<4:3> → PC<12:11>                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
| Encoding:        | 10 1kkk kkkk kkkk                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Description:     | GOTO is an unconditional branch.<br>The eleven bit immediate value is<br>loaded into PC bits <10:0>. The<br>upper bits of PC are loaded from<br>PCLATH<4:3>. GOTO is a two-<br>cycle instruction.                                                                                                                                     |  |  |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Cycles:          | 2                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
| Example          | GOTO THERE                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
|                  | After Instruction<br>PC = Address THERE                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |

| INCF             | Increment f                                                                                                                                                             |  |  |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] INCF f,d                                                                                                                                               |  |  |  |  |  |  |
| Operands:        | $\begin{array}{l} 0\leq f\leq 127\\ d\in [0,1] \end{array}$                                                                                                             |  |  |  |  |  |  |
| Operation:       | (f) + 1 $\rightarrow$ (dest)                                                                                                                                            |  |  |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                       |  |  |  |  |  |  |
| Encoding:        | 00 1010 dfff ffff                                                                                                                                                       |  |  |  |  |  |  |
| Description:     | I he contents of register 'f' are<br>incremented. If 'd' is 0, the result<br>is placed in the W register. If 'd' is<br>1, the result is placed back in<br>register 'f'. |  |  |  |  |  |  |
| Words:           | 1                                                                                                                                                                       |  |  |  |  |  |  |
| Cycles:          | 1                                                                                                                                                                       |  |  |  |  |  |  |
| Example          | INCF CNT, 1                                                                                                                                                             |  |  |  |  |  |  |
|                  | Before Instruction<br>CNT = 0xFF<br>Z = 0<br>After Instruction<br>CNT = 0x00<br>Z = 1                                                                                   |  |  |  |  |  |  |

### 11.0 DEVELOPMENT SUPPORT

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

- Integrated Development Environment
  - MPLAB® IDE Software
- Assemblers/Compilers/Linkers
  - MPASM<sup>™</sup> Assembler
  - MPLAB C17 and MPLAB C18 C Compilers
  - MPLINK<sup>™</sup> Object Linker/ MPLIB<sup>™</sup> Object Librarian
  - MPLAB C30 C Compiler
  - MPLAB ASM30 Assembler/Linker/Library
- · Simulators
  - MPLAB SIM Software Simulator
- MPLAB dsPIC30 Software Simulator
- Emulators
  - MPLAB ICE 2000 In-Circuit Emulator
  - MPLAB ICE 4000 In-Circuit Emulator
- In-Circuit Debugger
- MPLAB ICD 2
- Device Programmers
  - PRO MATE® II Universal Device Programmer
  - PICSTART<sup>®</sup> Plus Development Programmer
- Low Cost Demonstration Boards
  - PICDEM<sup>™</sup> 1 Demonstration Board
  - PICDEM.net<sup>™</sup> Demonstration Board
  - PICDEM 2 Plus Demonstration Board
  - PICDEM 3 Demonstration Board
  - PICDEM 4 Demonstration Board
  - PICDEM 17 Demonstration Board
  - PICDEM 18R Demonstration Board
  - PICDEM LIN Demonstration Board
  - PICDEM USB Demonstration Board
- Evaluation Kits
  - KEELOQ®
  - PICDEM MSC
  - microID®
  - CAN
  - PowerSmart®
  - Analog

#### 11.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16-bit microcontroller market. The MPLAB IDE is a Windows<sup>®</sup> based application that contains:

- · An interface to debugging tools
  - simulator
  - programmer (sold separately)
  - emulator (sold separately)
  - in-circuit debugger (sold separately)
- · A full-featured editor with color coded context
- · A multiple project manager
- Customizable data windows with direct edit of contents
- · High level source code debugging
- Mouse over variable inspection
- Extensive on-line help
- The MPLAB IDE allows you to:
- Edit your source files (either assembly or C)
- One touch assemble (or compile) and download to PICmicro emulator and simulator tools (automatically updates all project information)
- Debug using:
  - source files (assembly or C)
  - absolute listing file (mixed assembly and C)
  - machine code

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

#### 11.2 MPASM Assembler

The MPASM assembler is a full-featured, universal macro assembler for all PICmicro MCUs.

The MPASM assembler generates relocatable object files for the MPLINK object linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code and COFF files for debugging.

The MPASM assembler features include:

- Integration into MPLAB IDE projects
- · User defined macros to streamline assembly code
- Conditional assembly for multi-purpose source files
- Directives that allow complete control over the assembly process



### FIGURE 12-4: PIC16C62XA VOLTAGE-FREQUENCY GRAPH, $-40^{\circ}C \le Ta \le 0^{\circ}C$ , $+70^{\circ}C \le Ta \le +125^{\circ}C$



#### 12.1 DC Characteristics: PIC16C62X-04 (Commercial, Industrial, Extended) PIC16C62X-20 (Commercial, Industrial, Extended) PIC16LC62X-04 (Commercial, Industrial, Extended) (CONT.)

| PIC16C62X<br>PIC16LC62X                                           |                                                                        |                                                                                                                                                                                                                                                                                                     |                  | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}$ C $\leq TA \leq +85^{\circ}$ C for industrial and $0^{\circ}$ C $\leq TA \leq +70^{\circ}$ C for commercial and $-40^{\circ}$ C $\leq TA \leq +125^{\circ}$ C for extendedStandard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}$ C $\leq TA \leq +85^{\circ}$ C for industrial and $0^{\circ}$ C $\leq TA \leq +85^{\circ}$ C for industrial and $0^{\circ}$ C $\leq TA \leq +70^{\circ}$ C for commercial and |                                                   |                                  |                                                                                                                                                     |  |  |
|-------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                   | OULA                                                                   |                                                                                                                                                                                                                                                                                                     | Opera            | $-40^{\circ}$ C $\leq$ TA $\leq$ +70^{\circ}C for commercial a<br>-40°C $\leq$ TA $\leq$ +125°C for extended<br>Operating voltage VDD range is the PIC16C62X range.                                                                                                                                                                                                                                                                                                                                                                           |                                                   |                                  |                                                                                                                                                     |  |  |
| Param<br>. No.                                                    | Sym                                                                    | Characteristic                                                                                                                                                                                                                                                                                      | Min              | Тур†                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Max                                               | Units                            | Conditions                                                                                                                                          |  |  |
| D022<br>D022A<br>D023<br>D023A<br>D022A<br>D022A<br>D022A<br>D023 | ΔIWDT<br>ΔIBOR<br>ΔICOM<br>P<br>ΔIVREF<br>ΔIWDT<br>ΔIBOR<br>ΔICOM<br>P | WDT Current <sup>(5)</sup><br>Brown-out Reset Current <sup>(5)</sup><br>Comparator Current for each<br>Comparator <sup>(5)</sup><br>VREF Current <sup>(5)</sup><br>WDT Current <sup>(5)</sup><br>Brown-out Reset Current <sup>(5)</sup><br>Comparator Current for each<br>Comparator <sup>(5)</sup> | <br><br>         | 6.0<br>350<br>—<br>6.0<br>350<br>—                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 20<br>25<br>425<br>100<br>300<br>15<br>425<br>100 | μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ<br>μΑ | $VDD=4.0V$ $(125^{\circ}C)$ $BOD \text{ enabled, } VDD = 5.0V$ $VDD = 4.0V$ $VDD = 4.0V$ $VDD=3.0V$ $BOD \text{ enabled, } VDD = 5.0V$ $VDD = 3.0V$ |  |  |
| D023A                                                             | $\Delta$ IVREF                                                         | VREF Current <sup>(5)</sup>                                                                                                                                                                                                                                                                         | _                | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 300                                               | μA                               | VDD = 3.0V                                                                                                                                          |  |  |
| 1A                                                                | Fosc                                                                   | LP Oscillator Operating Frequency<br>RC Oscillator Operating Frequency<br>XT Oscillator Operating Frequency<br>HS Oscillator Operating Frequency                                                                                                                                                    | 0<br>0<br>0<br>0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 200<br>4<br>4<br>20                               | kHz<br>MHz<br>MHz<br>MHz         | All temperatures<br>All temperatures<br>All temperatures<br>All temperatures                                                                        |  |  |
| 1A                                                                | Fosc                                                                   | LP Oscillator Operating Frequency<br>RC Oscillator Operating Frequency<br>XT Oscillator Operating Frequency<br>HS Oscillator Operating Frequency                                                                                                                                                    | 0<br>0<br>0<br>0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 200<br>4<br>4<br>20                               | kHz<br>MHz<br>MHz<br>MHz         | All temperatures<br>All temperatures<br>All temperatures<br>All temperatures                                                                        |  |  |

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: This is the limit to which VDD can be lowered without losing RAM data.

2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD,

MCLR = VDD; WDT enabled/disabled as specified.

**3:** The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in kΩ.

5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

#### 12.2 DC Characteristics: PIC16C62XA-04 (Commercial, Industrial, Extended) PIC16C62XA-20 (Commercial, Industrial, Extended) PIC16LC62XA-04 (Commercial, Industrial, Extended (CONT.)

| PIC16C62XA    |                |                                                          |     | dard O<br>ating te                                                                                                                                                                                                           | <b>perati</b><br>empera | n <b>g Con</b><br>iture -4<br>-4 | ditions (unless otherwise stated)<br>$10^{\circ}C \leq TA \leq +85^{\circ}C$ for industrial and<br>$0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial and<br>$10^{\circ}C \leq TA \leq +125^{\circ}C$ for extended |  |  |
|---------------|----------------|----------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PIC16LC62XA   |                |                                                          |     | Standard Operating Conditions (unless otherwise stateOperating temperature $-40^{\circ}$ C $\leq$ TA $\leq$ +85°C for industrial0°C $\leq$ TA $\leq$ +70°C for commercia $-40^{\circ}$ C $\leq$ TA $\leq$ +125°C for extende |                         |                                  |                                                                                                                                                                                                                       |  |  |
| Param.<br>No. | Sym            | Characteristic                                           | Min | Тур†                                                                                                                                                                                                                         | Max                     | Units                            | Conditions                                                                                                                                                                                                            |  |  |
| D022          | ΔİWDT          | WDT Current <sup>(5)</sup>                               | —   | 6.0                                                                                                                                                                                                                          | 10<br>12                | μA<br>μA                         | VDD = 4.0V<br>(125°C)                                                                                                                                                                                                 |  |  |
| D022A         | $\Delta$ IBOR  | Brown-out Reset Current <sup>(5)</sup>                   | —   | 75                                                                                                                                                                                                                           | 125                     | μA                               | BOD enabled, VDD = 5.0V                                                                                                                                                                                               |  |  |
| D023          |                | Comparator Current for each<br>Comparator <sup>(5)</sup> | _   | 30                                                                                                                                                                                                                           | 60                      | μA                               | VDD = 4.0V                                                                                                                                                                                                            |  |  |
| D023A         | ΔIVREF         | VREF Current <sup>(3)</sup>                              | _   | 80                                                                                                                                                                                                                           | 135                     | μA                               | VDD = 4.0V                                                                                                                                                                                                            |  |  |
| D022          | $\Delta I$ WDT | WDT Current <sup>(5)</sup>                               | —   | 6.0                                                                                                                                                                                                                          | 10                      | μΑ                               | VDD=4.0V                                                                                                                                                                                                              |  |  |
| DOODA         | 41             | Descent Descet Operation (5)                             |     | 75                                                                                                                                                                                                                           | 12                      | μA                               | $\frac{(125^{\circ}C)}{200} = 5.017$                                                                                                                                                                                  |  |  |
| D022A         |                | Brown-out Reset Current <sup>(e)</sup>                   |     | 75                                                                                                                                                                                                                           | 125                     | μΑ                               | BOD enabled, $VDD = 5.0V$                                                                                                                                                                                             |  |  |
| D023          | AICOMP         | Comparator Current for each                              |     | 30                                                                                                                                                                                                                           | 60                      | μΑ                               | VDD - 4.0V                                                                                                                                                                                                            |  |  |
| D023A         | $\Delta$ IVREF | VREF Current <sup>(5)</sup>                              | _   | 80                                                                                                                                                                                                                           | 135                     | μA                               | VDD = 4.0V                                                                                                                                                                                                            |  |  |
| 1A            | Fosc           | LP Oscillator Operating Frequency                        | 0   | —                                                                                                                                                                                                                            | 200                     | kHz                              | All temperatures                                                                                                                                                                                                      |  |  |
|               |                | RC Oscillator Operating Frequency                        | 0   | —                                                                                                                                                                                                                            | 4                       | MHz                              | All temperatures                                                                                                                                                                                                      |  |  |
|               |                | XT Oscillator Operating Frequency                        | 0   |                                                                                                                                                                                                                              | 4                       | MHz                              | All temperatures                                                                                                                                                                                                      |  |  |
|               |                | HS Oscillator Operating Frequency                        | 0   | —                                                                                                                                                                                                                            | 20                      | MHZ                              | All temperatures                                                                                                                                                                                                      |  |  |
| 1A            | Fosc           | LP Oscillator Operating Frequency                        | 0   | —                                                                                                                                                                                                                            | 200                     | kHz                              | All temperatures                                                                                                                                                                                                      |  |  |
|               |                | RC Oscillator Operating Frequency                        | 0   | —                                                                                                                                                                                                                            | 4                       | MHz                              | All temperatures                                                                                                                                                                                                      |  |  |
|               |                | HS Oscillator Operating Frequency                        | 0   | _                                                                                                                                                                                                                            | 4<br>20                 | MHZ<br>MHZ                       | All temperatures<br>All temperatures                                                                                                                                                                                  |  |  |

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: This is the limit to which VDD can be lowered without losing RAM data.

2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern, and temperature also have an impact on the current consumption.

The test conditions for all IDD measurements in Active Operation mode are:

OSC1 = external square wave, from rail to rail; all I/O pins tri-stated, pulled to VDD,

 $\overline{\text{MCLR}}$  = VDD; WDT enabled/disabled as specified.

3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD or VSS.

4: For RC osc configuration, current through REXT is not included. The current through the resistor can be estimated by the formula: Ir = VDD/2REXT (mA) with REXT in kΩ.

5: The  $\Delta$  current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.

6: Commercial temperature range only.

#### 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>Operatir                           | 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.             | Min   | Тур†                                                                | Мах                                                  | Units                                                                                                                                                                                                                                               | Conditions |    |                                                                                                 |  |  |  |
| D040                      | Vih   | Input High Voltage<br>I/O ports<br>with TTL buffer                  | 2.0V                                                 | _                                                                                                                                                                                                                                                   | 1/22       | V  | VDD = 4.5V to 5.5V                                                                              |  |  |  |
| D041                      |       | with Schmitt Trigger input                                          | 0.25 VDD<br>+ 0.8V                                   |                                                                                                                                                                                                                                                     | VDD<br>VDD |    | otherwise                                                                                       |  |  |  |
| D041                      |       |                                                                     | 0.8 VDD                                              | _                                                                                                                                                                                                                                                   | VDD        | V  |                                                                                                 |  |  |  |
| D043<br>D043A             |       | OSC1 (XT, HS and LP)<br>OSC1 (in RC mode)                           | 0.7 VDD<br>0.9 VDD                                   | —                                                                                                                                                                                                                                                   | VDD        | V  | (Note 1)                                                                                        |  |  |  |
| D070                      | IPURB | PORTB weak pull-up current                                          | 50                                                   | 200                                                                                                                                                                                                                                                 | 400        | μA | VDD = 5.0V, VPIN = VSS                                                                          |  |  |  |
| D070                      | IPURB | PORTB weak pull-up current                                          | 50                                                   | 200                                                                                                                                                                                                                                                 | 400        | μA | VDD = 5.0V, VPIN = VSS                                                                          |  |  |  |
|                           | lı∟   | Input Leakage Current <sup>(2, 3)</sup><br>I/O ports (Except PORTA) |                                                      |                                                                                                                                                                                                                                                     | ±1.0       | μA | Vss $\leq$ VPIN $\leq$ VDD, pin at hi-impedance                                                 |  |  |  |
| D060                      |       | PORTA                                                               | _                                                    | _                                                                                                                                                                                                                                                   | ±0.5       | μA | Vss $\leq$ VPIN $\leq$ VDD, pin at hi-impedance                                                 |  |  |  |
| D061                      |       | RA4/T0CKI                                                           | _                                                    | _                                                                                                                                                                                                                                                   | ±1.0       | μA | $Vss \leq V \text{PIN} \leq V \text{DD}$                                                        |  |  |  |
| D063                      |       | OSC1, MCLR                                                          |                                                      |                                                                                                                                                                                                                                                     | ±5.0       | μΑ | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration                                     |  |  |  |
|                           | lı∟   | Input Leakage Current <sup>(2, 3)</sup>                             |                                                      |                                                                                                                                                                                                                                                     |            |    |                                                                                                 |  |  |  |
|                           |       |                                                                     |                                                      |                                                                                                                                                                                                                                                     | ±1.0       | μΑ | $Vss \leq V PIN \leq V DD, \ pin \ at \ hi\text{-impedance}$                                    |  |  |  |
| D060                      |       | PORTA                                                               | —                                                    | —                                                                                                                                                                                                                                                   | ±0.5       | μA | $Vss \le VPIN \le VDD$ , pin at hi-impedance                                                    |  |  |  |
| D061                      |       | RA4/T0CKI                                                           | —                                                    | —                                                                                                                                                                                                                                                   | ±1.0       | μA | $Vss \leq V \text{PIN} \leq V \text{DD}$                                                        |  |  |  |
| D063                      |       | OSC1, MCLR                                                          | -                                                    |                                                                                                                                                                                                                                                     | ±5.0       | μA | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration                                     |  |  |  |
|                           | Vol   | Output Low Voltage                                                  |                                                      |                                                                                                                                                                                                                                                     |            |    |                                                                                                 |  |  |  |
| D080                      |       | I/O ports                                                           | —                                                    | —                                                                                                                                                                                                                                                   | 0.6        | V  | $IOL = 8.5 \text{ mA}, \text{ VDD} = 4.5 \text{V}, -40^{\circ} \text{ to } +85^{\circ}\text{C}$ |  |  |  |
|                           |       |                                                                     | —                                                    | —                                                                                                                                                                                                                                                   | 0.6        | V  | IOL = 7.0 mA, VDD = 4.5V, +125°C                                                                |  |  |  |
| D083                      |       | OSC2/CLKOUT (RC only)                                               | —                                                    | —                                                                                                                                                                                                                                                   | 0.6        | V  | $IOL = 1.6 \text{ mA}, \text{ VDD} = 4.5 \text{V}, -40^{\circ} \text{ to } +85^{\circ}\text{C}$ |  |  |  |
|                           |       |                                                                     | _                                                    | —                                                                                                                                                                                                                                                   | 0.6        | V  | Iol = 1.2 mA, VDD = 4.5V, +125°C                                                                |  |  |  |

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

#### TABLE 12-1: COMPARATOR SPECIFICATIONS

Operating Conditions: VDD range as described in Table 12-1, -40°C<TA<+125°C. Current consumption is specified in Table 12-1.

| Characteristics                        | Sym | Min  | Тур   | Мах          | Units    | Comments                   |
|----------------------------------------|-----|------|-------|--------------|----------|----------------------------|
| Input offset voltage                   |     |      | ± 5.0 | ± 10         | mV       |                            |
| Input common mode voltage              |     | 0    |       | Vdd - 1.5    | V        |                            |
| CMRR                                   |     | +55* |       |              | δβ       |                            |
| Response Time <sup>(1)</sup>           |     |      | 150*  | 400*<br>600* | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X |
| Comparator mode change to output valid |     |      |       | 10*          | μS       |                            |

\* These parameters are characterized but not tested.

**Note 1:** Response time measured with one comparator input at (VDD - 1.5)/2, while the other input transitions from Vss to VDD.

#### TABLE 12-2: VOLTAGE REFERENCE SPECIFICATIONS

Operating Conditions:VDD range as described in Table 12-1, -40°C<TA<+125°C. Current consumption is specified in Table 12-1.

| Characteristics                                                                | Sym                       | Min                   | Тур              | Мах                          | Units            | Comments                                |
|--------------------------------------------------------------------------------|---------------------------|-----------------------|------------------|------------------------------|------------------|-----------------------------------------|
| Resolution                                                                     |                           |                       | VDD/24<br>VDD/32 |                              | LSB<br>LSB       | Low Range (VRR=1)<br>High Range (VRR=0) |
| Absolute Accuracy                                                              |                           |                       |                  | <u>+</u> 1/4<br><u>+</u> 1/2 | LSB<br>LSB       | Low Range (VRR=1)<br>High Range (VRR=0) |
| Unit Resistor Value (R)                                                        |                           |                       | 2K*              |                              | Ω                | Figure 8-1                              |
| Settling Time <sup>(1)</sup>                                                   |                           |                       |                  | 10*                          | μs               |                                         |
| * These parameters are characterize<br><b>Note 1:</b> Settling time measured w | zed but not<br>hile VRR = | tested.<br>1 and VR<3 | :0> transitio    | ons from 0000                | ) <b>to</b> 1111 |                                         |

DS30235J-page 102

### 13.0 DEVICE CHARACTERIZATION INFORMATION

The graphs and tables provided in this section are for design guidance and are not tested. In some graphs or tables, the data presented is outside specified operating range (e.g., outside specified VDD range). This is for information only and devices will operate properly only within the specified range.

The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution, while "max" or "min" represents (mean +  $3\sigma$ ) and (mean -  $3\sigma$ ) respectively, where  $\sigma$  is standard deviation.



FIGURE 13-1: IDD VS. FREQUENCY (XT MODE, VDD = 5.5V)

FIGURE 13-2: PIC16C622A IPD VS. VDD (WDT DISABLE)



© 2003 Microchip Technology Inc.









| N                                         |
|-------------------------------------------|
| NOP Instruction                           |
| 0                                         |
| One-Time-Programmable (OTP) Devices7      |
| OPTION Instruction                        |
| OPTION Register                           |
| Oscillator Configurations                 |
| Oscillator Start-up Timer (OST)50         |
| Р                                         |
| Package Marking Information               |
| Packaging Information                     |
| PCL and PCLATH                            |
| PCON Register                             |
| PICkit 1 FLASH Starter Kit79              |
| PICSTART Plus Development Programmer77    |
| PIE1 Register                             |
| PIR1 Register                             |
| Port RB Interrupt                         |
| PORTA                                     |
| PORTB                                     |
| Power Control/Status Register (PCON)      |
| Power-Down Mode (SLEEP)                   |
| Power-On Reset (POR)                      |
| Power-up Timer (PWRT)                     |
| Prescaler                                 |
| PRO MATE II Universal Device Programmer   |
| Program Memory Organization               |
| Q                                         |
| Quick-Turnaround-Production (QTP) Devices |
| R                                         |
| RC Oscillator                             |
| Reset49                                   |
| RETFIE Instruction70                      |
| RETLW Instruction70                       |
| RETURN Instruction70                      |
| RLF Instruction71                         |
| RRF Instruction71                         |
| S                                         |

| 0                                                |         |
|--------------------------------------------------|---------|
| Serialized Quick-Turnaround-Production (SQTP) De | vices 7 |
| SLEEP Instruction                                | 71      |
| Software Simulator (MPLAB SIM)                   | 76      |
| Software Simulator (MPLAB SIM30)                 | 76      |
| Special Features of the CPU                      | 45      |
| Special Function Registers                       | 17      |
| Stack                                            | 23      |
| Status Register                                  | 18      |
| SUBLW Instruction                                | 72      |
| SUBWF Instruction                                | 72      |
| SWAPF Instruction                                | 73      |
|                                                  |         |

#### Т

| Timer0                             |     |
|------------------------------------|-----|
| TIMER0                             |     |
| TIMER0 (TMR0) Interrupt            |     |
| TIMER0 (TMR0) Module               |     |
| TMR0 with External Clock           |     |
| Timer1                             |     |
| Switching Prescaler Assignment     | 35  |
| Timing Diagrams and Specifications | 104 |
| TMR0 Interrupt                     |     |
| TRIS Instruction                   | 73  |
| TRISA                              |     |
| TRISB                              |     |
|                                    |     |

### v

| Voltage Reference Module<br>VRCON Register | 43<br>43 |
|--------------------------------------------|----------|
| W                                          |          |
| Watchdog Timer (WDT)                       | . 58     |
| WWW, On-Line Support                       | 3        |
| X                                          |          |
| XORLW Instruction                          | . 73     |
| XORWF Instruction                          | .73      |

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

Microchip provides on-line support on the Microchip World Wide Web site.

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

### Connecting to the Microchip Internet Web Site

The Microchip web site is available at the following URL:

#### www.microchip.com

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

#### ftp://ftp.microchip.com

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

- Latest Microchip Press Releases
- Technical Support Section with Frequently Asked
   Questions
- Design Tips
- Device Errata
- Job Postings
- Microchip Consultant Program Member Listing
- Links to other useful web sites related to Microchip Products
- Conferences for products, Development Systems, technical information and more
- · Listing of seminars and events

## SYSTEMS INFORMATION AND UPGRADE HOT LINE

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

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

1-480-792-7302 for the rest of the world.

092002

### **PRODUCT IDENTIFICATION SYSTEM**

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

| PART NO.                  | <u>-xx</u>                                                                                                                                                      | ¥                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <u>/xx</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | xxx                                                                                             | E  | xamples:                                                                                                                     |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|----|------------------------------------------------------------------------------------------------------------------------------|
| Device                    | Frequency<br>Range                                                                                                                                              | Temperature<br>Range                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Package                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Pattern                                                                                         | a) | <ul> <li>PIC16C621A - 04/P 301 = Commercial temp<br/>PDIP package, 4 MHz, normal VDD limits, QT<br/>pattern #301.</li> </ul> |
| Device<br>Frequency Range | PIC16C6<br>PIC16C6<br>PIC16C6<br>PIC16LC<br>PIC16LC<br>PIC16LC<br>PIC16LC<br>PIC16LC<br>PIC16CF<br>PIC16CF<br>PIC16CC<br>PIC16LC<br>04 200<br>04 4 M<br>20 20 M | 52X: VDD range 3.0<br>52X: VDD range 3.0<br>52XA: VDD range 3.0<br>52XA: VDD range 2.5<br>562XA: VDD range 2.5<br>572XA: VD range | / to 6.0V<br>DV to 6.0V (Tape<br>DV to 5.5V<br>OV to 5.5V (Taj<br>SV to 6.0V<br>.5V to 6.0V (Taj<br>.5V to 5.5V<br>2.5V to 5.5V<br>2.5V to 5.5V<br>2.5V to 5.5V<br>2.5V to 5.5V<br>2.5V to 5.5V<br>2.0V to 5.5V<br>a 2.0V to 5.5V<br>(Taj<br>.5V to 5.5V<br>(Taj<br>.5V to 5.5V<br>.5V to 5.5V<br>.2V to 5.5V<br>.5V to 5.5V<br>.2V to 5.5V to 5.5V<br>.2V to 5.5V to 5.5V<br>.2V to 5.5V to 5.5V<br>.2V to 5.5V t | e and Reel)<br>be and Reel)<br>be and Reel)<br>ape and Reel)<br>ape and Reel)<br>Tape and Reel) | )  | <ul> <li>PIC16LC622- 04I/SO = Industrial temp., SOI<br/>package, 200 kHz, extended VDD limits.</li> </ul>                    |
| emperature Range          | e - =<br>I =<br>E =                                                                                                                                             | 0°C to +70°C<br>-40°C to +85°C<br>-40°C to +125°C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                 |    |                                                                                                                              |
| Package                   | P =<br>SO =<br>SS =<br>JW* =                                                                                                                                    | PDIP<br>SOIC (Gull Wing,<br>SSOP (209 mil)<br>Windowed CERD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | , 300 mil body)<br>NP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                 |    |                                                                                                                              |
| Pattern                   | 3-Digit Pa                                                                                                                                                      | attern Code for QTF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Optimize (blank otherwise)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | se)                                                                                             |    |                                                                                                                              |

\* JW Devices are UV erasable and can be programmed to any device configuration. JW Devices meet the electrical requirement of each oscillator type.

#### Sales and Support

#### **Data Sheets**

Products supported by a preliminary Data Sheet may have an errata sheet describing minor operational differences and recommended workarounds. To determine if an errata sheet exists for a particular device, please contact one of the following:

- 1. Your local Microchip sales office
- 2. The Microchip Corporate Literature Center U.S. FAX: (480) 792-7277
- 3. The Microchip Worldwide Site (www.microchip.com)

Please specify which device, revision of silicon and Data Sheet (include Literature #) you are using.

#### **New Customer Notification System**

Register on our web site (www.microchip.com/cn) to receive the most current information on our products.