



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

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

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

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

# **PIC16C62X**

TABLE 1-1: PIC16C62X FAMILY OF DEVICES

|             |                                        | PIC16C620 <sup>(3)</sup>            | PIC16C620A <sup>(1)(4)</sup>        | PIC16CR620A <sup>(2)</sup>          | PIC16C621 <sup>(3)</sup>            | PIC16C621A <sup>(1)(4)</sup>        | PIC16C622 <sup>(3)</sup>            | PIC16C622A <sup>(1)(4)</sup>        |
|-------------|----------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| Clock       | Maximum Frequency of Operation (MHz)   | 20                                  | 40                                  | 20                                  | 20                                  | 40                                  | 20                                  | 40                                  |
| Memory      | EPROM Program<br>Memory<br>(x14 words) | 512                                 | 512                                 | 512                                 | 1K                                  | 1K                                  | 2K                                  | 2K                                  |
|             | Data Memory (bytes)                    | 80                                  | 96                                  | 96                                  | 80                                  | 96                                  | 128                                 | 128                                 |
| Peripherals | Timer Module(s)                        | TMR0                                | TMR0                                | TMRO                                | TMR0                                | TMR0                                | TMR0                                | TMR0                                |
|             | Comparators(s)                         | 2                                   | 2                                   | 2                                   | 2                                   | 2                                   | 2                                   | 2                                   |
|             | Internal Reference<br>Voltage          | Yes                                 |
| Features    | Interrupt Sources                      | 4                                   | 4                                   | 4                                   | 4                                   | 4                                   | 4                                   | 4                                   |
|             | I/O Pins                               | 13                                  | 13                                  | 13                                  | 13                                  | 13                                  | 13                                  | 13                                  |
|             | Voltage Range (Volts)                  | 2.5-6.0                             | 2.7-5.5                             | 2.5-5.5                             | 2.5-6.0                             | 2.7-5.5                             | 2.5-6.0                             | 2.7-5.5                             |
|             | Brown-out Reset                        | Yes                                 |
|             | Packages                               | 18-pin DIP,<br>SOIC;<br>20-pin SSOP |

All PICmicro® Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C62X Family devices use serial programming with clock pin RB6 and data pin RB7.

Note 1: If you change from this device to another device, please verify oscillator characteristics in your application.

- 2: For ROM parts, operation from 2.0V 2.5V will require the PIC16LCR62XA parts.
- **3:** For OTP parts, operation from 2.5V 3.0V will require the PIC16LC62X part.
- 4: For OTP parts, operation from 2.7V 3.0V will require the PIC16LC62XA part.

# 4.2 Data Memory Organization

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

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

# 4.2.1 GENERAL PURPOSE REGISTER

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

# 4.2.2.1 STATUS Register

The STATUS register, shown in Register 4-1, contains the arithmetic status of the ALU, the RESET status and the bank select bits for data memory.

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

For example, CLRF STATUS will clear the upper-three bits and set the Z bit. This leaves the STATUS register as 000uu1uu (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any STATUS bit. For other instructions not affecting any STATUS bits, see the "Instruction Set Summary".

- Note 1: The IRP and RP1 bits (STATUS<7:6>) are not used by the PIC16C62X and should be programmed as '0'. Use of these bits as general purpose R/W bits is NOT recommended, since this may affect upward compatibility with future products.
  - 2: The <u>C and DC bits</u> operate as a Borrow and Digit Borrow out bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

# REGISTER 4-1: STATUS REGISTER (ADDRESS 03H OR 83H)

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

- bit 7 IRP: Register Bank Select bit (used for indirect addressing)
  - 1 = Bank 2, 3 (100h 1FFh)
  - 0 = Bank 0, 1 (00h FFh)

The IRP bit is reserved on the PIC16C62X; always maintain this bit clear.

- bit 6-5 RP<1:0>: Register Bank Select bits (used for direct addressing)
  - 01 = Bank 1 (80h FFh)
  - 00 = Bank 0 (00h 7Fh)

Each bank is 128 bytes. The RP1 bit is reserved on the PIC16C62X; always maintain this bit clear.

- bit 4  $\overline{\mathbf{TO}}$ : Time-out bit
  - 1 = After power-up, CLRWDT instruction, or SLEEP instruction
  - 0 = A WDT time-out occurred
- bit 3 **PD**: Power-down bit
  - 1 = After power-up or by the CLRWDT instruction
  - 0 = By execution of the SLEEP instruction
- bit 2 **Z**: Zero bit
  - 1 = The result of an arithmetic or logic operation is zero
  - 0 = The result of an arithmetic or logic operation is not zero
- bit 1 **DC**: Digit carry/borrow bit (ADDWF, ADDLW, SUBLW, SUBWF instructions)(for borrow the polarity is reversed)
  - 1 = A carry-out from the 4th low order bit of the result occurred
  - 0 = No carry-out from the 4th low order bit of the result
- - 1 = A carry-out from the Most Significant bit of the result occurred
  - 0 = No carry-out from the Most Significant bit of the result occurred

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

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

# 6.3 Prescaler

An 8-bit counter is available as a prescaler for the Timer0 module, or as a postscaler for the Watchdog Timer, respectively (Figure 6-6). For simplicity, this counter is being referred to as "prescaler" throughout this data sheet. Note that there is only one prescaler available which is mutually exclusive between the Timer0 module and the Watchdog Timer. Thus, a prescaler assignment for the Timer0 module means that there is no prescaler for the Watchdog Timer and vice-versa.

The PSA and PS<2:0> bits (OPTION<3:0>) determine the prescaler assignment and prescale ratio.

When assigned to the Timer0 module, all instructions writing to the TMR0 register (e.g., CLRF 1, MOVWF 1, BSF 1, x....etc.) will clear the prescaler. When assigned to WDT, a CLRWDT instruction will clear the prescaler along with the Watchdog Timer. The prescaler is not readable or writable.

FIGURE 6-6: BLOCK DIAGRAM OF THE TIMERO/WDT PRESCALER



# 7.1 Comparator Configuration

There are eight modes of operation for the comparators. The CMCON register is used to select the mode. Figure 7-1 shows the eight possible modes. The TRISA register controls the data direction of the comparator pins for each mode. If the Comparator

mode is changed, the comparator output level may not be valid for the specified mode change delay shown in Table 12-2.

**Note:** Comparator interrupts should be disabled during a Comparator mode change otherwise a false interrupt may occur.

# FIGURE 7-1: COMPARATOR I/O OPERATING MODES



# 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



# 7.6 Comparator Interrupts

The comparator interrupt flag is set whenever there is a change in the output value of either comparator. Software will need to maintain information about the status of the output bits, as read from CMCON<7:6>, to determine the actual change that has occurred. The CMIF bit, PIR1<6>, is the comparator interrupt flag. The CMIF bit must be RESET by clearing '0'. Since it is also possible to write a '1' to this register, a simulated interrupt may be initiated.

The CMIE bit (PIE1<6>) and the PEIE bit (INTCON<6>) must be set to enable the interrupt. In addition, the GIE bit must also be set. If any of these bits are clear, the interrupt is not enabled, though the CMIF bit will still be set if an interrupt condition occurs.

Note: If a change in the CMCON register (C1OUT or C2OUT) should occur when a read operation is being executed (start of the Q2 cycle), then the CMIF (PIR1<6>) interrupt flag may not get set.

The user, in the interrupt service routine, can clear the interrupt in the following manner:

- Any read or write of CMCON. This will end the mismatch condition.
- b) Clear flag bit CMIF.

A mismatch condition will continue to set flag bit CMIF. Reading CMCON will end the mismatch condition and allow flag bit CMIF to be cleared.

# 7.7 Comparator Operation During SLEEP

When a comparator is active and the device is placed in SLEEP mode, the comparator remains active and the interrupt is functional if enabled. This interrupt will wake up the device from SLEEP mode when enabled. While the comparator is powered-up, higher SLEEP currents than shown in the power-down current specification will occur. Each comparator that is operational will consume additional current as shown in the comparator specifications. To minimize power consumption while in SLEEP mode, turn off the comparators, CM<2:0> = 111, before entering SLEEP. If the device wakes up from SLEEP, the contents of the CMCON register are not affected.

# 7.8 Effects of a RESET

A device RESET forces the CMCON register to its RESET state. This forces the comparator module to be in the comparator RESET mode, CM<2:0> = 000. This ensures that all potential inputs are analog inputs. Device current is minimized when analog inputs are present at RESET time. The comparators will be powered-down during the RESET interval.

# 7.9 Analog Input Connection Considerations

A simplified circuit for an analog input is shown in Figure 7-4. Since the analog pins are connected to a digital output, they have reverse biased diodes to VDD and Vss. The analog input therefore, must be between Vss and VDD. If the input voltage deviates from this range by more than 0.6V in either direction, one of the diodes is forward biased and a latchup may occur. A impedance maximum source οf 10 k $\Omega$ recommended for the analog sources. Any external component connected to an analog input pin, such as a capacitor or a Zener diode, should have very little leakage current.

FIGURE 7-4: ANALOG INPUT MODEL



# 9.3 RESET

The PIC16C62X differentiates between various kinds of RESET:

- a) Power-on Reset (POR)
- b) MCLR Reset during normal operation
- c) MCLR Reset during SLEEP
- d) WDT Reset (normal operation)
- e) WDT wake-up (SLEEP)
- f) Brown-out Reset (BOR)

Some registers are not affected in any RESET condition Their status is unknown on POR and unchanged in any other RESET. Most other registers are reset to a "RESET state" on Power-on Reset,

MCLR Reset, WDT Reset and MCLR Reset during SLEEP. They are not affected by a WDT wake-up, since this is viewed as the resumption of normal operation. TO and PD bits are set or cleared differently in different RESET situations as indicated in Table 9-2. These bits are used in software to determine the nature of the RESET. See Table 9-5 for a full description of RESET states of all registers.

A simplified block diagram of the on-chip RESET circuit is shown in Figure 9-6.

The MCLR Reset path has a noise filter to detect and ignore small pulses. See Table 12-5 for pulse width specification.

# FIGURE 9-6: SIMPLIFIED BLOCK DIAGRAM OF ON-CHIP RESET CIRCUIT



TABLE 9-4: INITIALIZATION CONDITION FOR SPECIAL REGISTERS

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

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

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

TABLE 9-5: INITIALIZATION CONDITION FOR REGISTERS

| Register | Address | Power-on Reset | MCLR Reset during normal operation     MCLR Reset during SLEEP     WDT Reset     Brown-out Reset (1) | Wake-up from SLEEP<br>through interrupt     Wake-up from SLEEP<br>through WDT time-out |
|----------|---------|----------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| W        | _       | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| INDF     | 00h     | _              | _                                                                                                    | _                                                                                      |
| TMR0     | 01h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| PCL      | 02h     | 0000 0000      | 0000 0000                                                                                            | PC + 1 <sup>(3)</sup>                                                                  |
| STATUS   | 03h     | 0001 1xxx      | 000q quuu <sup>(4)</sup>                                                                             | uuuq quuu <sup>(4)</sup>                                                               |
| FSR      | 04h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| PORTA    | 05h     | x xxxx         | u uuuu                                                                                               | u uuuu                                                                                 |
| PORTB    | 06h     | xxxx xxxx      | uuuu uuuu                                                                                            | uuuu uuuu                                                                              |
| CMCON    | 1Fh     | 00 0000        | 00 0000                                                                                              | uu uuuu                                                                                |
| PCLATH   | 0Ah     | 0 0000         | 0 0000                                                                                               | u uuuu                                                                                 |
| INTCON   | 0Bh     | 0000 000x      | 0000 000u                                                                                            | uuuu uqqq <sup>(2)</sup>                                                               |
| PIR1     | 0Ch     | -0             | -0                                                                                                   | -q <sup>(2,5)</sup>                                                                    |
| OPTION   | 81h     | 1111 1111      | 1111 1111                                                                                            | uuuu uuuu                                                                              |
| TRISA    | 85h     | 1 1111         | 1 1111                                                                                               | u uuuu                                                                                 |
| TRISB    | 86h     | 1111 1111      | 1111 1111                                                                                            | uuuu uuuu                                                                              |
| PIE1     | 8Ch     | -0             | -0                                                                                                   | -u                                                                                     |
| PCON     | 8Eh     | 0x             | uq <sup>(1,6)</sup>                                                                                  | uu                                                                                     |
| VRCON    | 9Fh     | 000- 0000      | 000- 0000                                                                                            | uuu- uuuu                                                                              |

 $\label{eq:local_local_local_local_local} \text{Legend:} \quad \text{$u$ = unchanged, $x$ = unknown, $-$ = unimplemented bit, reads as `0', $q$ = value depends on condition.}$ 

Note 1: If VDD goes too low, Power-on Reset will be activated and registers will be affected differently.

- 2: One or more bits in INTCON, PIR1 and/or PIR2 will be affected (to cause wake-up).
- 3: When the wake-up is due to an interrupt and the GIE bit is set, the PC is loaded with the interrupt vector (0004h).
- **4:** See Table 9-4 for RESET value for specific condition.
- 5: If wake-up was due to comparator input changing, then bit 6 = 1. All other interrupts generating a wake-up will cause bit 6 = u.
- **6:** If RESET was due to brown-out, then bit 0 = 0. All other RESETS will cause bit 0 = u.

# PIC16C62X

TABLE 10-2: PIC16C62X INSTRUCTION SET

| Mnemonic,  |                                        | Description                  | Cycles |     | 14-Bit | Opcode | )    | Status   | Notes |
|------------|----------------------------------------|------------------------------|--------|-----|--------|--------|------|----------|-------|
| Operands   |                                        |                              |        | MSb |        |        | LSb  | Affected |       |
| BYTE-ORIE  | BYTE-ORIENTED FILE REGISTER OPERATIONS |                              |        |     |        |        |      |          |       |
| ADDWF      | f, d                                   | Add W and f                  | 1      | 00  | 0111   | dfff   | ffff | C,DC,Z   | 1,2   |
| ANDWF      | f, d                                   | AND W with f                 | 1      | 00  | 0101   | dfff   | ffff | Z        | 1,2   |
| CLRF       | f                                      | Clear f                      | 1      | 00  | 0001   | lfff   | ffff | Z        | 2     |
| CLRW       | -                                      | Clear W                      | 1      | 00  | 0001   | 0000   | 0011 | Z        |       |
| COMF       | f, d                                   | Complement f                 | 1      | 00  | 1001   | dfff   | ffff | Z        | 1,2   |
| DECF       | f, d                                   | Decrement f                  | 1      | 00  | 0011   | dfff   | ffff | Z        | 1,2   |
| DECFSZ     | f, d                                   | Decrement f, Skip if 0       | 1(2)   | 00  | 1011   | dfff   | ffff |          | 1,2,3 |
| INCF       | f, d                                   | Increment f                  | 1      | 00  | 1010   | dfff   | ffff | Z        | 1,2   |
| INCFSZ     | f, d                                   | Increment f, Skip if 0       | 1(2)   | 00  | 1111   | dfff   | ffff |          | 1,2,3 |
| IORWF      | f, d                                   | Inclusive OR W with f        | 1      | 00  | 0100   | dfff   | ffff | Z        | 1,2   |
| MOVF       | f, d                                   | Move f                       | 1      | 00  | 1000   | dfff   | ffff | Z        | 1,2   |
| MOVWF      | f                                      | Move W to f                  | 1      | 00  | 0000   | lfff   | ffff |          |       |
| NOP        | -                                      | No Operation                 | 1      | 00  | 0000   | 0xx0   | 0000 |          |       |
| RLF        | f, d                                   | Rotate Left f through Carry  | 1      | 00  | 1101   | dfff   | ffff | С        | 1,2   |
| RRF        | f, d                                   | Rotate Right f through Carry | 1      | 00  | 1100   | dfff   | ffff | С        | 1,2   |
| SUBWF      | f, d                                   | Subtract W from f            | 1      | 00  | 0010   | dfff   | ffff | C,DC,Z   | 1,2   |
| SWAPF      | f, d                                   | Swap nibbles in f            | 1      | 00  | 1110   | dfff   | ffff |          | 1,2   |
| XORWF      | f, d                                   | Exclusive OR W with f        | 1      | 00  | 0110   | dfff   | ffff | Z        | 1,2   |
| BIT-ORIENT | ED FIL                                 | E REGISTER OPERATIONS        |        |     |        |        |      |          |       |
| BCF        | f, b                                   | Bit Clear f                  | 1      | 01  | 00bb   | bfff   | ffff |          | 1,2   |
| BSF        | f, b                                   | Bit Set f                    | 1      | 01  | 01bb   | bfff   | ffff |          | 1,2   |
| BTFSC      | f, b                                   | Bit Test f, Skip if Clear    | 1 (2)  | 01  | 10bb   | bfff   | ffff |          | 3     |
| BTFSS      | f, b                                   | Bit Test f, Skip if Set      | 1 (2)  | 01  | 11bb   | bfff   | ffff |          | 3     |
| LITERAL AN | ID CO                                  | NTROL OPERATIONS             |        |     |        |        |      |          |       |
| ADDLW      | k                                      | Add literal and W            | 1      | 11  | 111x   | kkkk   | kkkk | C,DC,Z   |       |
| ANDLW      | k                                      | AND literal with W           | 1      | 11  | 1001   | kkkk   | kkkk | Z        |       |
| CALL       | k                                      | Call subroutine              | 2      | 10  | 0kkk   | kkkk   | kkkk |          |       |
| CLRWDT     | -                                      | Clear Watchdog Timer         | 1      | 00  | 0000   | 0110   | 0100 | TO,PD    |       |
| GOTO       | k                                      | Go to address                | 2      | 10  | 1kkk   | kkkk   | kkkk |          |       |
| IORLW      | k                                      | Inclusive OR literal with W  | 1      | 11  | 1000   | kkkk   | kkkk | Z        |       |
| MOVLW      | k                                      | Move literal to W            | 1      | 11  | 00xx   | kkkk   | kkkk |          |       |
| RETFIE     | -                                      | Return from interrupt        | 2      | 00  | 0000   | 0000   | 1001 |          |       |
| RETLW      | k                                      | Return with literal in W     | 2      | 11  | 01xx   | kkkk   | kkkk |          |       |
| RETURN     | -                                      | Return from Subroutine       | 2      | 00  | 0000   | 0000   | 1000 |          |       |
| SLEEP      | -                                      | Go into Standby mode         | 1      | 00  | 0000   | 0110   | 0011 | TO,PD    |       |
| SUBLW      | k                                      | Subtract W from literal      | 1      | 11  | 110x   | kkkk   | kkkk | C,DC,Z   |       |
| XORLW      | k                                      | Exclusive OR literal with W  | 1      | 11  | 1010   | kkkk   | kkkk | Z        |       |

Note 1: When an I/O register is modified as a function of itself (e.g., MOVF PORTB, 1), the value used will be that value present on the pins themselves. For example, if the data latch is '1' for a pin configured as input and is driven low by an external device, the data will be written back with a '0'.

<sup>2:</sup> If this instruction is executed on the TMR0 register (and, where applicable, d = 1), the prescaler will be cleared if assigned to the Timer0 Module.

<sup>3:</sup> If Program Counter (PC) is modified or a conditional test is true, the instruction requires two cycles. The second cycle is executed as a NOP.

| SWAPF            | Swap Nibbles in f                                      |                                           |                             |                   |  |  |
|------------------|--------------------------------------------------------|-------------------------------------------|-----------------------------|-------------------|--|--|
| Syntax:          | [label] SWAPF f,d                                      |                                           |                             |                   |  |  |
| Operands:        | $0 \le f \le 12$ $d \in [0,1]$                         | .7                                        |                             |                   |  |  |
| Operation:       | (f<3:0>) -<br>(f<7:4>) -                               | •                                         | , ,                         |                   |  |  |
| Status Affected: | None                                                   |                                           |                             |                   |  |  |
| Encoding:        | 00                                                     | 1110                                      | dfff                        | ffff              |  |  |
| Description:     | The upper register 'f 0, the res register. I placed in | " are excl<br>sult is plad<br>f 'd' is 1, | hanged<br>ced in<br>the res | d. If 'd' is<br>W |  |  |
| Words:           | 1                                                      |                                           |                             |                   |  |  |
| Cycles:          | 1                                                      |                                           |                             |                   |  |  |
| Example          | SWAPF                                                  | REG,                                      | 0                           |                   |  |  |
|                  | Before In                                              | struction                                 |                             |                   |  |  |
|                  |                                                        | REG1                                      | = (                         | 0xA5              |  |  |
|                  | After Inst                                             | ruction                                   |                             |                   |  |  |
|                  |                                                        | REG1<br>W                                 |                             | 0xA5<br>0x5A      |  |  |

| TRIS             | Load TR                                                                                                   | IS Regis                                        | ter                 |      |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------|------|--|--|--|--|
| Syntax:          | [ label ]                                                                                                 | [label] TRIS f                                  |                     |      |  |  |  |  |
| Operands:        | $5 \le f \le 7$                                                                                           |                                                 |                     |      |  |  |  |  |
| Operation:       | $(W) \rightarrow TRIS register f;$                                                                        |                                                 |                     |      |  |  |  |  |
| Status Affected: | None                                                                                                      |                                                 |                     |      |  |  |  |  |
| Encoding:        | 00                                                                                                        | 0000                                            | 0110                | Offf |  |  |  |  |
| Description:     | The instruction code complete PIC16C5 registers writable, address to                                      | npatibility<br>X produc<br>are read<br>the user | with the cts. Since | TRIS |  |  |  |  |
| Words:           | 1                                                                                                         |                                                 |                     |      |  |  |  |  |
| Cycles:          | 1                                                                                                         |                                                 |                     |      |  |  |  |  |
| Example          |                                                                                                           |                                                 |                     |      |  |  |  |  |
|                  | To maintain upward compatibility with future PICmicro <sup>®</sup> products, do not use this instruction. |                                                 |                     |      |  |  |  |  |

| XORLW               | Exclusive OR Literal with W                                                                                       |  |  |  |  |  |
|---------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:             | [ label XORLW k<br>]                                                                                              |  |  |  |  |  |
| Operands:           | $0 \leq k \leq 255$                                                                                               |  |  |  |  |  |
| Operation:          | (W) .XOR. $k \rightarrow (W)$                                                                                     |  |  |  |  |  |
| Status Affected:    | Z                                                                                                                 |  |  |  |  |  |
| Encoding:           | 11 1010 kkkk kkkk                                                                                                 |  |  |  |  |  |
| Description: Words: | The contents of the W register are XOR'ed with the eight bit literal 'k'. The result is placed in the W register. |  |  |  |  |  |
| Cycles:             | 1                                                                                                                 |  |  |  |  |  |
| Example:            | XORLW 0xAF                                                                                                        |  |  |  |  |  |
|                     | Before Instruction                                                                                                |  |  |  |  |  |
|                     | W = 0xB5                                                                                                          |  |  |  |  |  |
|                     | After Instruction                                                                                                 |  |  |  |  |  |
|                     | W = 0x1A                                                                                                          |  |  |  |  |  |
| XORWE               | Exclusive OR W with f                                                                                             |  |  |  |  |  |

| XORWF            | Exclusive OR W with f                                                                                                                                                       |                         |       |            |      |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-------|------------|------|--|--|--|
| Syntax:          | [ label ] XORWF f,d                                                                                                                                                         |                         |       |            |      |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                          |                         |       |            |      |  |  |  |
| Operation:       | (W) .XOF                                                                                                                                                                    | $R. (f) \rightarrow (e$ | dest) |            |      |  |  |  |
| Status Affected: | Z                                                                                                                                                                           |                         |       |            |      |  |  |  |
| Encoding:        | 00                                                                                                                                                                          | 0110                    | dff   | f          | ffff |  |  |  |
| Description:     | Exclusive OR the contents of the W register with register 'f'. If 'd' is 0, the result is stored in the W register. If 'd' is 1, the result is stored back in register 'f'. |                         |       |            |      |  |  |  |
| Words:           | 1                                                                                                                                                                           |                         |       |            |      |  |  |  |
| Cycles:          | 1                                                                                                                                                                           |                         |       |            |      |  |  |  |
| Example          | XORWF                                                                                                                                                                       | REG                     | 1     |            |      |  |  |  |
|                  | Before In                                                                                                                                                                   | struction               |       |            |      |  |  |  |
|                  | REG = 0xAF  W = 0xB5                                                                                                                                                        |                         |       |            |      |  |  |  |
|                  | After Inst                                                                                                                                                                  | ruction                 |       |            |      |  |  |  |
|                  |                                                                                                                                                                             | REG<br>W                | =     | 0x1<br>0xE |      |  |  |  |

# 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™ 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® Plus Development Programmer
- · Low Cost Demonstration Boards
  - PICDEM™ 1 Demonstration Board
  - PICDEM.net™ 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® 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® 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

# 11.3 MPLAB C17 and MPLAB C18 C Compilers

The MPLAB C17 and MPLAB C18 Code Development Systems are complete ANSI C compilers for Microchip's PIC17CXXX and PIC18CXXX family of microcontrollers. These compilers provide powerful integration capabilities, superior code optimization and ease of use not found with other compilers.

For easy source level debugging, the compilers provide symbol information that is optimized to the MPLAB IDE debugger.

# 11.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK object linker combines relocatable objects created by the MPASM assembler and the MPLAB C17 and MPLAB C18 C compilers. It can link relocatable objects from pre-compiled libraries, using directives from a linker script.

The MPLIB object librarian manages the creation and modification of library files of pre-compiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

# 11.5 MPLAB C30 C Compiler

The MPLAB C30 C compiler is a full-featured, ANSI compliant, optimizing compiler that translates standard ANSI C programs into dsPIC30F assembly language source. The compiler also supports many command-line options and language extensions to take full advantage of the dsPIC30F device hardware capabilities, and afford fine control of the compiler code generator.

MPLAB C30 is distributed with a complete ANSI C standard library. All library functions have been validated and conform to the ANSI C library standard. The library includes functions for string manipulation, dynamic memory allocation, data conversion, time-keeping, and math functions (trigonometric, exponential and hyperbolic). The compiler provides symbolic information for high level source debugging with the MPLAB IDE.

# 11.6 MPLAB ASM30 Assembler, Linker, and Librarian

MPLAB ASM30 assembler produces relocatable machine code from symbolic assembly language for dsPIC30F devices. MPLAB C30 compiler uses the assembler to produce it's object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- · Support for the entire dsPIC30F instruction set
- · Support for fixed-point and floating-point data
- · Command line interface
- · Rich directive set
- · Flexible macro language
- · MPLAB IDE compatibility

# 11.7 MPLAB SIM Software Simulator

The MPLAB SIM software simulator allows code development in a PC hosted environment by simulating the PICmicro series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file, or user defined key press, to any pin. The execution can be performed in Single-Step, Execute Until Break, or Trace mode.

The MPLAB SIM simulator fully supports symbolic debugging using the MPLAB C17 and MPLAB C18 C Compilers, as well as the MPASM assembler. The software simulator offers the flexibility to develop and debug code outside of the laboratory environment, making it an excellent, economical software development tool.

# 11.8 MPLAB SIM30 Software Simulator

The MPLAB SIM30 software simulator allows code development in a PC hosted environment by simulating the dsPIC30F series microcontrollers on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a file, or user defined key press, to any of the pins.

The MPLAB SIM30 simulator fully supports symbolic debugging using the MPLAB C30 C Compiler and MPLAB ASM30 assembler. The simulator runs in either a Command Line mode for automated tasks, or from MPLAB IDE. This high speed simulator is designed to debug, analyze and optimize time intensive DSP routines.

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

| PIC16C62XA    |     |                                   |                  | Standard Operating Conditions (unless otherwise stated)  Operating temperature $-40^{\circ}\text{C} \leq \text{TA} \leq +85^{\circ}\text{C}$ for industrial and $0^{\circ}\text{C} \leq \text{TA} \leq +70^{\circ}\text{C}$ for commercial and |                         |                      |                                                                                                                                                                                                                               |  |  |
|---------------|-----|-----------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PIC16LC62XA   |     |                                   |                  |                                                                                                                                                                                                                                                |                         | ng Con<br>ature -4   | $10^{\circ}$ C ≤ TA ≤ +125°C for extended<br>ditions (unless otherwise stated)<br>$10^{\circ}$ C ≤ TA ≤ +85°C for industrial and<br>$0^{\circ}$ C ≤ TA ≤ +70°C for commercial and<br>$0^{\circ}$ C ≤ TA ≤ +125°C for extended |  |  |
| Param.<br>No. | Sym | Characteristic                    | Min              | Тур†                                                                                                                                                                                                                                           | Max                     | Units                | Conditions                                                                                                                                                                                                                    |  |  |
| D010          | IDD | Supply Current <sup>(2, 4)</sup>  |                  | 1.2<br>0.4                                                                                                                                                                                                                                     | 2.0                     | mA<br>mA             | Fosc = 4 MHz, VDD = 5.5V, WDT disabled,<br>XT mode, (Note 4)*<br>Fosc = 4 MHz, VDD = 3.0V, WDT disabled,<br>XT mode, (Note 4)*                                                                                                |  |  |
|               |     |                                   | —<br> -          | 1.0                                                                                                                                                                                                                                            | 2.0<br>6.0              | mA<br>mA             | Fosc = 10 MHz, VDD = 3.0V, WDT disabled, HS mode, (Note 6) Fosc = 20 MHz, VDD = 4.5V, WDT disabled, HS mode                                                                                                                   |  |  |
|               |     |                                   | _<br>_           | 4.0<br>35                                                                                                                                                                                                                                      | 7.0<br>70               | mA<br>μA             | Fosc = 20 MHz, VDD = 5.5V, WDT disabled*, HS mode Fosc = 32 kHz, VDD = 3.0V, WDT disabled, LP mode                                                                                                                            |  |  |
| D010          | IDD | Supply Current <sup>(2)</sup>     | _<br>_           | 1.2                                                                                                                                                                                                                                            | 2.0                     | mA<br>mA             | Fosc = 4 MHz, VDD = 5.5V, WDT disabled,<br>XT mode, (Note 4)*<br>Fosc = 4 MHz, VDD = 2.5V, WDT disabled,<br>XT mode, (Note 4)                                                                                                 |  |  |
|               |     |                                   | _                | 35                                                                                                                                                                                                                                             | 70                      | μА                   | Fosc = 32 kHz, VDD = 2.5V, WDT disabled, LP mode                                                                                                                                                                              |  |  |
| D020          | IPD | Power-down Current <sup>(3)</sup> |                  | _<br>_<br>_<br>_                                                                                                                                                                                                                               | 2.2<br>5.0<br>9.0<br>15 | μΑ<br>μΑ<br>μΑ<br>μΑ | VDD = 3.0V<br>VDD = 4.5V*<br>VDD = 5.5V<br>VDD = 5.5V Extended Temp.                                                                                                                                                          |  |  |
| D020          | IPD | Power-down Current <sup>(3)</sup> | _<br>_<br>_<br>_ | _<br>_<br>_<br>_                                                                                                                                                                                                                               | 2.0<br>2.2<br>9.0<br>15 | μΑ<br>μΑ<br>μΑ<br>μΑ | VDD = 2.5V<br>VDD = 3.0V*<br>VDD = 5.5V<br>VDD = 5.5V Extended Temp.                                                                                                                                                          |  |  |

- \* 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.
  - 6: Commercial temperature range only.

# 12.2 DC Characteristics: PIC16C62XA-04 (Commercial, Industrial, Extended)

PIC16C62XA-20 (Commercial, Industrial, Extended)

PIC16LC62XA-04 (Commercial, Industrial, Extended (CONT.)

| PIC16C62XA    |                 |                                                                                                                                                  |                  | Standard Operating Conditions (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for industrial and $0^{\circ}\text{C} \le \text{TA} \le +70^{\circ}\text{C}$ for commercial and $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended |                     |                          |                                                                                      |  |  |  |
|---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------------|--------------------------------------------------------------------------------------|--|--|--|
| PIC16LC62XA   |                 |                                                                                                                                                  |                  |                                                                                                                                                                                                                                                                                                                     |                     |                          |                                                                                      |  |  |  |
| Param.<br>No. | Sym             | Characteristic                                                                                                                                   | Min              | Тур†                                                                                                                                                                                                                                                                                                                | Max                 | Units                    | Conditions                                                                           |  |  |  |
| D022          | Δlwdt           | WDT Current <sup>(5)</sup>                                                                                                                       | _                | 6.0                                                                                                                                                                                                                                                                                                                 | 10<br>12            | μ <b>Α</b><br>μ <b>Α</b> | VDD = 4.0V<br>(125°C)                                                                |  |  |  |
| D022A<br>D023 | ΔIBOR<br>ΔICOMP | Brown-out Reset Current <sup>(5)</sup> Comparator Current for each Comparator <sup>(5)</sup>                                                     | _<br>_           | 75<br>30                                                                                                                                                                                                                                                                                                            | 125<br>60           | μ <b>Α</b><br>μ <b>Α</b> | BOD enabled, VDD = 5.0V<br>VDD = 4.0V                                                |  |  |  |
| D023A         | $\Delta$ IVREF  | VREF Current <sup>(5)</sup>                                                                                                                      | _                | 80                                                                                                                                                                                                                                                                                                                  | 135                 | μА                       | VDD = 4.0V                                                                           |  |  |  |
| D022          | ΔĺWDT           | WDT Current <sup>(5)</sup>                                                                                                                       | _                | 6.0                                                                                                                                                                                                                                                                                                                 | 10<br>12            | μ <b>Α</b><br>μ <b>Α</b> | VDD=4.0V<br>(125°C)                                                                  |  |  |  |
| D022A<br>D023 | ΔIBOR<br>ΔICOMP | Brown-out Reset Current <sup>(5)</sup> Comparator Current for each Comparator <sup>(5)</sup>                                                     | _<br>_           | 75<br>30                                                                                                                                                                                                                                                                                                            | 125<br>60           | μA<br>μA                 | BOD enabled, VDD = 5.0V<br>VDD = 4.0V                                                |  |  |  |
| D023A         | ΔIVREF          | VREF Current <sup>(5)</sup>                                                                                                                      | _                | 80                                                                                                                                                                                                                                                                                                                  | 135                 | μА                       | VDD = 4.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 | _<br>_<br>_<br>_                                                                                                                                                                                                                                                                                                    | 200<br>4<br>4<br>20 | kHz<br>MHz<br>MHz<br>MHz | All temperatures All temperatures All temperatures All temperatures 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 | _<br>_<br>_<br>_                                                                                                                                                                                                                                                                                                    | 200<br>4<br>4<br>20 | kHz<br>MHz<br>MHz<br>MHz | All temperatures All temperatures All temperatures All temperatures 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 Δ 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.3 DC CHARACTERISTICS: PIC16CR62XA-04 (Commercial, Industrial, Extended) PIC16CR62XA-20 (Commercial, Industrial, Extended) PIC16LCR62XA-04 (Commercial, Industrial, Extended) (CONT.)

| PIC16CR62XA-04<br>PIC16CR62XA-20 |                             |                                                                                                                                                     | Standard Operating Conditions (unless otherwise stated)  Operating temperature -40°C ≤ Ta ≤ +85°C for industrial and  0°C ≤ Ta ≤ +70°C for commercial and  -40°C ≤ Ta ≤ +125°C for extended                                                                                                                          |                              |                          |                          |                                                                                         |  |  |
|----------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------------|--------------------------|-----------------------------------------------------------------------------------------|--|--|
| PIC16LCR62XA-04                  |                             |                                                                                                                                                     | Standard Operating Conditions (unless otherwise stated)  Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for industrial and $0^{\circ}\text{C} \le \text{TA} \le +70^{\circ}\text{C}$ for commercial and $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for extended |                              |                          |                          |                                                                                         |  |  |
| Param.<br>No.                    | Sym                         | Characteristic                                                                                                                                      | Min                                                                                                                                                                                                                                                                                                                  | Тур†                         | Max                      | Units                    | Conditions                                                                              |  |  |
| D020                             | IPD                         | Power-down Current <sup>(3)</sup>                                                                                                                   | _<br>_<br>_<br>_                                                                                                                                                                                                                                                                                                     | 200<br>0.400<br>0.600<br>5.0 | 950<br>1.8<br>2.2<br>9.0 | nA<br>μA<br>μA<br>μA     | VDD = 3.0V<br>VDD = 4.5V*<br>VDD = 5.5V<br>VDD = 5.5V Extended Temp.                    |  |  |
| D020                             | IPD                         | Power-down Current <sup>(3)</sup>                                                                                                                   |                                                                                                                                                                                                                                                                                                                      | 200<br>200<br>0.600<br>5.0   | 850<br>950<br>2.2<br>9.0 | nA<br>nA<br>μA<br>μA     | VDD = 2.5V<br>VDD = 3.0V*<br>VDD = 5.5V<br>VDD = 5.5V Extended                          |  |  |
| D022<br>D022A<br>D023<br>D023A   | ΔIWDT  ΔIBOR ΔICOMP  ΔIVREF | WDT Current <sup>(5)</sup> Brown-out Reset Current <sup>(5)</sup> Comparator Current for each Comparator <sup>(5)</sup> VREF Current <sup>(5)</sup> | _<br>_<br>_<br>_                                                                                                                                                                                                                                                                                                     | 6.0<br>75<br>30<br>80        | 10<br>12<br>125<br>60    | μΑ<br>μΑ<br>μΑ<br>μΑ     | VDD=4.0V<br>(125°C)<br>BOD enabled, VDD = 5.0V<br>VDD = 4.0V<br>VDD = 4.0V              |  |  |
| D022<br>D022A<br>D023            | ΔIWDT  ΔIBOR ΔICOMP  ΔIVREF | WDT Current <sup>(5)</sup> Brown-out Reset Current <sup>(5)</sup> Comparator Current for each Comparator <sup>(5)</sup> VREF Current <sup>(5)</sup> | _<br>_<br>_                                                                                                                                                                                                                                                                                                          | 6.0<br>75<br>30<br>80        | 10<br>12<br>125<br>60    | μΑ<br>μΑ<br>μΑ<br>μΑ     | $V_{DD}=4.0V$ $(125^{\circ}C)$ $BOD$ enabled, $V_{DD}=5.0V$ $V_{DD}=4.0V$ $V_{DD}=4.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                                                                                                                                                                                                                                                                                                     | _<br>_<br>_                  | 200<br>4<br>4<br>20      | kHz<br>MHz<br>MHz<br>MHz | All temperatures All temperatures All temperatures 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                                                                                                                                                                                                                                                                                                     | _<br>_<br>_<br>_             | 200<br>4<br>4<br>20      | kHz<br>MHz<br>MHz<br>MHz | All temperatures All temperatures All temperatures 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\Omega$ .
- 5: The Δ 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.6 DC Characteristics: PIC16C620A/C621A/C622A-40<sup>(3)</sup> (Commercial) PIC16CR620A-40<sup>(3)</sup> (Commercial)

| DC CHARACTERISTICS Power Supply Pins |      |        |                    | Standard Operating Conditions (unless otherwise stated)<br>Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial |          |                                                                          |  |  |
|--------------------------------------|------|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------------------------|--|--|
| Characteristic                       | Sym  | Min    | Typ <sup>(1)</sup> | Max                                                                                                                                  | Units    | Conditions                                                               |  |  |
| Supply Voltage                       | VDD  | 4.5    | _                  | 5.5                                                                                                                                  | V        | HS Option from 20 - 40 MHz                                               |  |  |
| Supply Current <sup>(2)</sup>        | IDD  | _      | 5.5<br>7.7         | 11.5<br>16                                                                                                                           | mA<br>mA | Fosc = 40 MHz, VDD = 4.5V, HS mode<br>Fosc = 40 MHz, VDD = 5.5V, HS mode |  |  |
| HS Oscillator Operating Frequency    | Fosc | 20     | _                  | 40                                                                                                                                   | MHz      | OSC1 pin is externally driven,<br>OSC2 pin not connected                 |  |  |
| Input Low Voltage OSC1               | VIL  | Vss    | _                  | 0.2VDD                                                                                                                               | V        | HS mode, OSC1 externally driven                                          |  |  |
| Input High Voltage OSC1              | VIH  | 0.8VDD | —                  | Vdd                                                                                                                                  | V        | HS mode, OSC1 externally driven                                          |  |  |

- \* These parameters are characterized but not tested.
- Note 1: Data in the Typical ("Typ") column is based on characterization results at 25°C. This data is for design guidance only and is not tested.
  - 2: The supply current is mainly a function of the operating voltage and frequency. Other factors such as bus loading, oscillator type, bus rate, internal code execution pattern, and temperature also have an impact on the current consumption.
    - a) 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 Vss, T0CKI = VDD, MCLR = VDD; WDT disabled, HS mode with OSC2 not connected.
  - 3: For device operation between DC and 20 MHz. See Table 12-1 and Table 12-2.

# 12.7 AC Characteristics: PIC16C620A/C621A/C622A-40<sup>(2)</sup> (Commercial) PIC16CR620A-40<sup>(2)</sup> (Commercial)

| AC CHARACTERISTICS All Pins Except Power Supply Pin       |            | Standard Operating Conditions (unless otherwise stated) Operating temperature $0^{\circ}C \le TA \le +70^{\circ}C$ for commercial |                    |     |       |                                      |
|-----------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|--------------------------------------|
| Characteristic                                            | Sym        | Min                                                                                                                               | Typ <sup>(1)</sup> | Max | Units | Conditions                           |
| External CLKIN Frequency                                  | Fosc       | 20                                                                                                                                | _                  | 40  | MHz   | HS mode, OSC1 externally driven      |
| External CLKIN Period                                     | Tosc       | 25                                                                                                                                | _                  | 50  | ns    | HS mode (40), OSC1 externally driven |
| Clock in (OSC1) Low or High Time                          | TosL, TosH | 6                                                                                                                                 | _                  | _   | ns    | HS mode, OSC1 externally driven      |
| Clock in (OSC1) Rise or Fall Time                         | TosR, TosF | _                                                                                                                                 | _                  | 6.5 | ns    | HS mode, OSC1 externally driven      |
| OSC1↑ (Q1 cycle) to Port out valid                        | TosH2ioV   | _                                                                                                                                 | _                  | 100 | ns    | _                                    |
| OSC1↑ (Q2 cycle) to Port input invalid (I/O in hold time) | TosH2iol   | 50                                                                                                                                | _                  | _   | ns    | _                                    |

- Note 1: Data in the Typical ("Typ") column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested.
  - 2: For device operation between DC and 20 MHz. See Table 12-1 and Table 12-2.

FIGURE 12-13: CLKOUT AND I/O TIMING



# **APPENDIX A: ENHANCEMENTS**

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

- Instruction word length is increased to 14 bits.
   This allows larger page sizes both in program memory (4K now as opposed to 512 before) and register file (up to 128 bytes now versus 32 bytes before).
- A PC high latch register (PCLATH) is added to handle program memory paging. PA2, PA1, PA0 bits are removed from STATUS register.
- Data memory paging is slightly redefined. STATUS register is modified.
- 4. Four new instructions have been added: RETURN, RETFIE, ADDLW, and SUBLW.

  Two instructions TRIS and OPTION are being phased out, although they are kept for compatibility with PIC16C5X.
- OPTION and TRIS registers are made addressable.
- Interrupt capability is added. Interrupt vector is at 0004h.
- 7. Stack size is increased to 8 deep.
- 8. RESET vector is changed to 0000h.
- RESET of all registers is revisited. Five different RESET (and wake-up) types are recognized. Registers are reset differently.
- Wake-up from SLEEP through interrupt is added.
- 11. Two separate timers, Oscillator Start-up Timer (OST) and Power-up Timer (PWRT) are included for more reliable power-up. These timers are invoked selectively to avoid unnecessary delays on power-up and wake-up.
- 12. PORTB has weak pull-ups and interrupt-onchange feature.
- 13. Timer0 clock input, T0CKI pin is also a port pin (RA4/T0CKI) and has a TRIS bit.
- 14. FSR is made a full 8-bit register.
- "In-circuit programming" is made possible. The user can program PIC16CXX devices using only five pins: VDD, Vss, VPP, RB6 (clock) and RB7 (data in/out).
- PCON STATUS register is added with a Poweron-Reset (POR) STATUS bit and a Brown-out Reset STATUS bit (BOD).
- 17. Code protection scheme is enhanced such that portions of the program memory can be protected, while the remainder is unprotected.
- 18. PORTA inputs are now Schmitt Trigger inputs.
- 19. Brown-out Reset reset has been added.
- Common RAM registers F0h-FFh implemented in bank1.

# APPENDIX B: COMPATIBILITY

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

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



# WORLDWIDE SALES AND SERVICE

# **AMERICAS**

# **Corporate Office**

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

### Atlanta

3780 Mansell Road, Suite 130 Alpharetta, GA 30022 Tel: 770-640-0034 Fax: 770-640-0307

## **Boston**

2 Lan Drive, Suite 120 Westford, MA 01886

Tel: 978-692-3848 Fax: 978-692-3821

# Chicago

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

### **Dallas**

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

Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260

2767 S. Albright Road Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387

# Los Angeles

18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 949-263-1888 Fax: 949-263-1338

# Phoenix

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

# San Jose

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

# **Toronto**

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

# ASIA/PACIFIC

## Australia

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

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

## China - Beijing

Microchip Technology Consulting (Shanghai)
Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg.

No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104

## China - Chengdu

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

## China - Fuzhou

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

# China - Hong Kong SAR

Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431

# China - Shanghai

Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza

No. 317 Xian Xia Road Shanghai, 200051

Tel: 86-21-6275-5700 Fax: 86-21-6275-5060

# China - Shenzhen

Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1812, 18/F, Building A, United Plaza No. 5022 Binhe Road, Futian District Shenzhen 518033, China Tel: 86-755-82901380 Fax: 86-755-82966626

# China - Qingdao

Rm. B505A, Fullhope Plaza, No. 12 Hong Kong Central Rd. Qingdao 266071, China Tel: 86-532-5027355 Fax: 86-532-5027205

# India

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

## Japan

Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122

## Korea

Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934

# Singapore

Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-6334-8870 Fax: 65-6334-8850

# Taiwan

Microchip Technology (Barbados) Inc., Taiwan Branch 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

## **EUROPE**

# Austria

Microchip Technology Austria GmbH Durisolstrasse 2 A-4600 Wels Austria Tel: 43-7242-2244-399 Fax: 43-7242-2244-393

# Denmark

Microchip Technology Nordic ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910

# France

Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

# Germany

Microchip Technology GmbH Steinheilstrasse 10 D-85737 Ismaning, Germany Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

# Italy

Microchip Technology SRL Via Quasimodo, 12 20025 Legnano (MI)

Milan, Italy
Tel: 39-0331-742611 Fax: 39-0331-466781

# **United Kingdom**

Microchip Ltd 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU

Tel: 44 118 921 5869 Fax: 44-118 921-5820

03/25/03