



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        | 896B (512 x 14)                                                             |
| Program Memory Type        | ОТР                                                                         |
| 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/pic16c620at-04-ss |

Email: info@E-XFL.COM

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

# 3.0 ARCHITECTURAL OVERVIEW

The high performance of the PIC16C62X family can be attributed to a number of architectural features commonly found in RISC microprocessors. To begin with, the PIC16C62X uses a Harvard architecture, in which, program and data are accessed from separate memories using separate busses. This improves bandwidth over traditional von Neumann architecture, where program and data are fetched from the same memory. Separating program and data memory further allows instructions to be sized differently than 8-bit wide data word. Instruction opcodes are 14-bits wide making it possible to have all single word instructions. A 14-bit wide program memory access bus fetches a 14-bit instruction in a single cycle. A two-stage pipeline overlaps fetch and execution of instructions. Consequently, all instructions (35) execute in a single cycle (200 ns @ 20 MHz) except for program branches.

The PIC16C620(A) and PIC16CR620A address 512 x 14 on-chip program memory. The PIC16C621(A) addresses  $1K \times 14$  program memory. The PIC16C622(A) addresses  $2K \times 14$  program memory. All program memory is internal.

The PIC16C62X can directly or indirectly address its register files or data memory. All special function registers including the program counter are mapped in the data memory. The PIC16C62X has an orthogonal (symmetrical) instruction set that makes it possible to carry out any operation on any register using any Addressing mode. This symmetrical nature and lack of 'special optimal situations' make programming with the PIC16C62X simple yet efficient. In addition, the learning curve is reduced significantly.

The PIC16C62X devices contain an 8-bit ALU and working register. The ALU is a general purpose arithmetic unit. It performs arithmetic and Boolean functions between data in the working register and any register file.

The ALU is 8-bits wide and capable of addition, subtraction, shift and logical operations. Unless otherwise mentioned, arithmetic operations are two's complement in nature. In two-operand instructions, typically one operand is the working register (W register). The other operand is a file register or an immediate constant. In single operand instructions, the operand is either the W register or a file register.

The W register is an 8-bit working register used for ALU operations. It is not an addressable register.

Depending on the instruction executed, the ALU may affect the values of the Carry (C), Digit Carry (DC), and Zero (Z) bits in the STATUS register. The C and DC bits operate as a Borrow and Digit Borrow out bit, respectively, bit in subtraction. See the SUBLW and SUBWF instructions for examples.

A simplified block diagram is shown in Figure 3-1, with a description of the device pins in Table 3-1.

#### **OPTION Register** 4.2.2.2

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

| Note: | To achieve a 1:1 prescaler assignment for |
|-------|-------------------------------------------|
|       | TMR0, assign the prescaler to the WDT     |
|       | (PSA = 1).                                |

| REGISTER 4-2: | OPTION REGISTER (ADDRESS 81H) |
|---------------|-------------------------------|
|---------------|-------------------------------|

| RBPU       INTEDG       TOCS       TOSE         bit 7         bit 7         RBPU: PORTB Pull-up Enable bit         1 = PORTB pull-ups are disabled         0 = PORTB pull-ups are enabled by individual por         bit 6         INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         bit 5         TOCS: TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4         TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit | PSA<br>t latch va<br>DCKI pin<br>DCKI pin | PS2   | PS1 | PS0<br>bit 0 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-------|-----|--------------|
| bit 7         RBPU: PORTB Pull-up Enable bit         1 = PORTB pull-ups are disabled         0 = PORTB pull-ups are enabled by individual por         bit 6         INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         0 = Interrupt on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4         TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3                                                                                                                                                             | t latch va<br>DCKI pin<br>DCKI pin        | alues |     | bit 0        |
| bit 7       RBPU: PORTB Pull-up Enable bit         1 = PORTB pull-ups are disabled       0 = PORTB pull-ups are enabled by individual por         bit 6       INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin       0 = Interrupt on falling edge of RB0/INT pin         bit 5       TOCS: TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin       0 = Internal instruction cycle clock (CLKOUT)         bit 4       TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit                                                                                                                                  | t latch va<br>DCKI pin<br>DCKI pin        | alues |     |              |
| bit 7       RBPU: PORTB Pull-up Enable bit         1 = PORTB pull-ups are disabled       0 = PORTB pull-ups are enabled by individual por         bit 6       INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin       0 = Interrupt on falling edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin       0 = Interrupt on falling edge of RB0/INT pin         bit 5       T0CS: TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin       0 = Internal instruction cycle clock (CLKOUT)         bit 4       T0SE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0       0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit                            | rt latch va<br>DCKI pin<br>DCKI pin       | alues |     |              |
| 1 = PORTB pull-ups are disabled         0 = PORTB pull-ups are enabled by individual por         bit 6       INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         bit 5       TOCS: TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4       TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit                                                                                                                                                                               | t latch va<br>DCKI pin<br>DCKI pin        | alues |     |              |
| <ul> <li>bit 6</li> <li>INTEDG: Interrupt Edge Select bit         <ol> <li>Interrupt on rising edge of RB0/INT pin</li> <li>Interrupt on falling edge of RB0/INT pin</li> <li>Interrupt on falling edge of RB0/INT pin</li> </ol> </li> <li>bit 5</li> <li>TOCS: TMR0 Clock Source Select bit         <ol> <li>Transition on RA4/T0CKI pin</li> <li>Internal instruction cycle clock (CLKOUT)</li> </ol> </li> <li>bit 4</li> <li>TOSE: TMR0 Source Edge Select bit         <ol> <li>Increment on high-to-low transition on RA4/T0</li> <li>Increment on low-to-high transition on RA4/T0</li> </ol> </li> <li>bit 3</li> </ul>                                                                                                                                                                                        | )CKI pin<br>)CKI pin                      | alues |     |              |
| bit 6       INTEDG: Interrupt Edge Select bit         1 = Interrupt on rising edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         bit 5       TOCS: TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4       TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit                                                                                                                                                                                                                                                                                | DCKI pin<br>DCKI pin                      |       |     |              |
| 1 = Interrupt on rising edge of RB0/INT pin         0 = Interrupt on falling edge of RB0/INT pin         bit 5 <b>T0CS</b> : TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4 <b>T0SE</b> : TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                | )CKI pin<br>)CKI pin                      |       |     |              |
| <ul> <li>bit 5</li> <li><b>TOCS</b>: TMR0 Clock Source Select bit         <ol> <li>Transition on RA4/T0CKI pin</li> <li>Transition on RA4/T0CKI pin</li> <li>Internal instruction cycle clock (CLKOUT)</li> </ol> </li> <li>bit 4</li> <li><b>TOSE</b>: TMR0 Source Edge Select bit         <ol> <li>Increment on high-to-low transition on RA4/T0</li> <li>Increment on low-to-high transition on RA4/T0</li> </ol> </li> <li>bit 3</li> </ul>                                                                                                                                                                                                                                                                                                                                                                        | )CKI pin<br>)CKI pin                      |       |     |              |
| bit 5 <b>TOCS</b> : TMR0 Clock Source Select bit         1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4 <b>TOSE</b> : TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                         | )CKI pin<br>)CKI pin                      |       |     |              |
| 1 = Transition on RA4/T0CKI pin         0 = Internal instruction cycle clock (CLKOUT)         bit 4 <b>T0SE</b> : TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | )CKI pin<br>)CKI pin                      |       |     |              |
| <ul> <li>0 = Internal instruction cycle clock (CLKOUT)</li> <li>bit 4 T0SE: TMR0 Source Edge Select bit         <ol> <li>1 = Increment on high-to-low transition on RA4/T0</li> <li>0 = Increment on low-to-high transition on RA4/T0</li> </ol> </li> <li>bit 3 PSA: Prescaler Assignment bit</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | )CKI pin<br>)CKI pin                      |       |     |              |
| bit 4       TOSE: TMR0 Source Edge Select bit         1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3       PSA: Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | )CKI pin<br>)CKI pin                      |       |     |              |
| 1 = Increment on high-to-low transition on RA4/T0         0 = Increment on low-to-high transition on RA4/T0         bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | CKI pin<br>CKI pin                        |       |     |              |
| 0 = Increment on low-to-high transition on RA4/T0         bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | OCKI pin                                  |       |     |              |
| bit 3 <b>PSA</b> : Prescaler Assignment bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                           |       |     |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |       |     |              |
| 1 = Prescaler is assigned to the WDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                           |       |     |              |
| 0 = Prescaler is assigned to the Timer0 module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                           |       |     |              |
| bit 2-0 <b>PS&lt;2:0&gt;</b> : Prescaler Rate Select bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           |       |     |              |
| Bit Value TMR0 Rate WDT Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                           |       |     |              |
| 000 1:2 1:1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                           |       |     |              |
| 001 1:4 1:2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                           |       |     |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |       |     |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |       |     |              |
| 101 1:64 1:32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                           |       |     |              |
| 110 1:128 1:64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                           |       |     |              |
| 111 1:256 1:128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                           |       |     |              |

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

### 4.4 Indirect Addressing, INDF and FSR Registers

The INDF register is not a physical register. Addressing the INDF register will cause indirect addressing.

Indirect addressing is possible by using the INDF register. Any instruction using the INDF register actually accesses data pointed to by the File Select Register (FSR). Reading INDF itself indirectly will produce 00h. Writing to the INDF register indirectly results in a no-operation (although STATUS bits may be affected). An effective 9-bit address is obtained by concatenating the 8-bit FSR register and the IRP bit (STATUS<7>), as shown in Figure 4-9. However, IRP is not used in the PIC16C62X.

A simple program to clear RAM location 20h-7Fh using indirect addressing is shown in Example 4-1.

| EXAN  | IPLE 4- | 1: INI | DIRECT ADDRESSING    |
|-------|---------|--------|----------------------|
|       | movlw   | 0x20   | ;initialize pointer  |
|       | movwf   | FSR    | ;to RAM              |
| NEXT  | clrf    | INDF   | clear INDF register; |
|       | incf    | FSR    | ;inc pointer         |
|       | btfss   | FSR,7  | ;all done?           |
|       | goto    | NEXT   | ;no clear next       |
|       |         |        | ;yes continue        |
| CONTI | NUE:    |        |                      |
|       |         |        |                      |

## FIGURE 4-9: DIRECT/INDIRECT ADDRESSING PIC16C62X



#### TABLE 5-1:PORTA FUNCTIONS

| Name         | Bit # | Buffer<br>Type | Function                                                                                          |  |  |  |
|--------------|-------|----------------|---------------------------------------------------------------------------------------------------|--|--|--|
| RA0/AN0      | bit0  | ST             | Input/output or comparator input                                                                  |  |  |  |
| RA1/AN1      | bit1  | ST             | Input/output or comparator input                                                                  |  |  |  |
| RA2/AN2/VREF | bit2  | ST             | Input/output or comparator input or VREF output                                                   |  |  |  |
| RA3/AN3      | bit3  | ST             | Input/output or comparator input/output                                                           |  |  |  |
| RA4/T0CKI    | bit4  | ST             | Input/output or external clock input for TMR0 or comparator output.<br>Output is open drain type. |  |  |  |

Legend: ST = Schmitt Trigger input

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

| Address | Name  | Bit 7 | Bit 6 | Bit 5 | Bit 4      | Bit 3      | Bit 2      | Bit 1      | Bit 0      | Value on<br>POR | Value on<br>All Other<br>RESETS |
|---------|-------|-------|-------|-------|------------|------------|------------|------------|------------|-----------------|---------------------------------|
| 05h     | PORTA |       | _     |       | RA4        | RA3        | RA2        | RA1        | RA0        | x 0000          | u 0000                          |
| 85h     | TRISA | _     | _     | _     | TRISA<br>4 | TRISA<br>3 | TRISA<br>2 | TRISA<br>1 | TRISA<br>0 | 1 1111          | 1 1111                          |
| 1Fh     | CMCON | C2OUT | C1OUT | _     | _          | CIS        | CM2        | CM1        | CM0        | 00 0000         | 00 0000                         |
| 9Fh     | VRCON | VREN  | VROE  | VRR   | _          | VR3        | VR2        | VR1        | VR0        | 000- 0000       | 000- 0000                       |

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

Note: Shaded bits are not used by PORTA.

# 5.3 I/O Programming Considerations

#### 5.3.1 BI-DIRECTIONAL I/O PORTS

Any instruction which writes, operates internally as a read followed by a write operation. The BCF and BSF instructions, for example, read the register into the CPU, execute the bit operation and write the result back to the register. Caution must be used when these instructions are applied to a port with both inputs and outputs defined. For example, a BSF operation on bit5 of PORTB will cause all eight bits of PORTB to be read into the CPU. Then the BSF operation takes place on bit5 and PORTB is written to the output latches. If another bit of PORTB is used as a bi-directional I/O pin (e.g., bit0) and it is defined as an input at this time, the input signal present on the pin itself would be read into the CPU and re-written to the data latch of this particular pin, overwriting the previous content. As long as the pin stays in the Input mode, no problem occurs. However, if bit0 is switched into Output mode later on, the content of the data latch may now be unknown.

Reading the port register reads the values of the port pins. Writing to the port register writes the value to the port latch. When using read-modify-write instructions (ex. BCF, BSF, etc.) on a port, the value of the port pins is read, the desired operation is done to this value, and this value is then written to the port latch.

Example 5-2 shows the effect of two sequential read-modify-write instructions (ex.,  ${\tt BCF}\,,\;\;{\tt BSF},\; etc.)$  on an I/O port

A pin actively outputting a Low or High should not be driven from external devices at the same time in order to change the level on this pin ("wired-or", "wired-and"). The resulting high output currents may damage the chip.

#### EXAMPLE 5-2: READ-MODIFY-WRITE INSTRUCTIONS ON AN I/O PORT

| ; Initial PORT settings:                                                         | PORTB<7:4> Inpu                                | ıts      |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------|------------------------------------------------|----------|--|--|--|--|--|--|--|--|
| ; PORTE<3:0> Outputs                                                             |                                                |          |  |  |  |  |  |  |  |  |
| ; PORTB<7:6> have external pull-up and are not<br>; connected to other circuitry |                                                |          |  |  |  |  |  |  |  |  |
| ;                                                                                |                                                |          |  |  |  |  |  |  |  |  |
| ;                                                                                | PORT latch PO                                  | ORT pins |  |  |  |  |  |  |  |  |
| ;                                                                                |                                                |          |  |  |  |  |  |  |  |  |
|                                                                                  | -                                              |          |  |  |  |  |  |  |  |  |
|                                                                                  |                                                |          |  |  |  |  |  |  |  |  |
| BCF PORTB, 7                                                                     | ;01pp pppp 11                                  | ipp pppp |  |  |  |  |  |  |  |  |
| BCF PORTB, 6                                                                     | ;10pp pppp 11                                  | lpp pppp |  |  |  |  |  |  |  |  |
| BSF STATUS, RPO                                                                  | ;                                              |          |  |  |  |  |  |  |  |  |
| BCF TRISB, 7                                                                     | ;10pp pppp 11                                  | lpp pppp |  |  |  |  |  |  |  |  |
| BCF TRISB, 6                                                                     | ;10pp pppp 10                                  | )pp pppp |  |  |  |  |  |  |  |  |
| ;                                                                                |                                                |          |  |  |  |  |  |  |  |  |
| ; Note that the user may h                                                       | ; Note that the user may have expected the pin |          |  |  |  |  |  |  |  |  |
| ; values to be 00pp pppp.                                                        | The 2nd BCF cause                              | ed       |  |  |  |  |  |  |  |  |
| ; RB7 to be latched as the                                                       | e pin value (High)                             | ).       |  |  |  |  |  |  |  |  |
|                                                                                  |                                                |          |  |  |  |  |  |  |  |  |

# 5.3.2 SUCCESSIVE OPERATIONS ON I/O PORTS

The actual write to an I/O port happens at the end of an instruction cycle, whereas for reading, the data must be valid at the beginning of the instruction cycle (Figure 5-7). Therefore, care must be exercised if a write followed by a read operation is carried out on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. When in doubt, it is better to separate these instructions with a NOP or another instruction not accessing this I/O port.



#### FIGURE 5-7: SUCCESSIVE I/O OPERATION

# 6.0 TIMER0 MODULE

The Timer0 module timer/counter has the following features:

- 8-bit timer/counter
- · Readable and writable
- 8-bit software programmable prescaler
- · Internal or external clock select
- · Interrupt on overflow from FFh to 00h
- · Edge select for external clock

Figure 6-1 is a simplified block diagram of the Timer0 module.

Timer mode is selected by clearing the T0CS bit (OPTION<5>). In Timer mode, the TMR0 will increment every instruction cycle (without prescaler). If Timer0 is written, the increment is inhibited for the following two cycles (Figure 6-2 and Figure 6-3). The user can work around this by writing an adjusted value to TMR0.

Counter mode is selected by setting the T0CS bit. In this mode, Timer0 will increment either on every rising or falling edge of pin RA4/T0CKI. The incrementing edge is determined by the source edge (T0SE) control bit (OPTION<4>). Clearing the T0SE bit selects the rising edge. Restrictions on the external clock input are discussed in detail in Section 6.2.

The prescaler is shared between the Timer0 module and the Watchdog Timer. The prescaler assignment is controlled in software by the control bit PSA (OPTION<3>). Clearing the PSA bit will assign the prescaler to Timer0. The prescaler is not readable or writable. When the prescaler is assigned to the Timer0 module, prescale value of 1:2, 1:4, ..., 1:256 are selectable. Section 6.3 details the operation of the prescaler.

# 6.1 TIMER0 Interrupt

Timer0 interrupt is generated when the TMR0 register timer/counter overflows from FFh to 00h. This overflow sets the T0IF bit. The interrupt can be masked by clearing the T0IE bit (INTCON<5>). The T0IF bit (INTCON<2>) must be cleared in software by the Timer0 module interrupt service routine before reenabling this interrupt. The Timer0 interrupt cannot wake the processor from SLEEP, since the timer is shut off during SLEEP. See Figure 6-4 for Timer0 interrupt timing.



### FIGURE 6-2: TIMER0 (TMR0) TIMING: INTERNAL CLOCK/NO PRESCALER

| Counter)             | ( PC-1      | X PC        | ( PC+1 )     | PC+2        | PC+3        | PC+4        | <u>PC+5</u> χ | PC+6      |
|----------------------|-------------|-------------|--------------|-------------|-------------|-------------|---------------|-----------|
| Instruction<br>Fetch | 1<br>1<br>1 | MOVWF TMR   | 0MOVF TMR0,V | MOVF TMR0,V | MOVF TMR0,W | MOVF TMR0,V | MOVF TMR0,W   | I         |
|                      |             |             |              |             |             |             |               |           |
| TMR0                 | T0 X        | T0+1 )      | T0+2         | I           | NT0         |             | NT0+1 \       | NT0+2 \   |
| Instruction          | 1<br>1<br>1 | 1<br>1<br>1 | <b>≜</b>     | <b>≜</b>    | 1           | <b>≜</b>    | <b>↑</b>      | <b>≜</b>  |
| Executed             | 1           | 1           | Write TMR0   | Read TMR0   | Read TMR0   | Read TMR0   | Read TMR0     | Read TMR0 |

# 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  $\overline{\text{MCLR}}$  Reset path has a noise filter to detect and ignore small pulses. See Table 12-5 for pulse width specification.





# PIC16C62X



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.5.1 RB0/INT INTERRUPT

External interrupt on RB0/INT pin is edge triggered, either rising if INTEDG bit (OPTION<6>) is set, or falling, if INTEDG bit is clear. When a valid edge appears on the RB0/INT pin, the INTF bit (INTCON<1>) is set. This interrupt can be disabled by clearing the INTE control bit (INTCON<4>). The INTF bit must be cleared in software in the interrupt service routine before reenabling this interrupt. The RB0/INT interrupt can wake-up the processor from SLEEP, if the INTE bit was set prior to going into SLEEP. The status of the GIE bit decides whether or not the processor branches to the interrupt vector following wake-up. See Section 9.8 for details on SLEEP and Figure 9-18 for timing of wakeup from SLEEP through RB0/INT interrupt.

#### 9.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set the T0IF (INTCON<2>) bit. The interrupt can be enabled/disabled by setting/clearing T0IE (INTCON<5>) bit. For operation of the Timer0 module, see Section 6.0.

#### 9.5.3 PORTB INTERRUPT

An input change on PORTB <7:4> sets the RBIF (INTCON<0>) bit. The interrupt can be enabled/disabled by setting/clearing the RBIE (INTCON<4>) bit. For operation of PORTB (Section 5.2).

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

#### 9.5.4 COMPARATOR INTERRUPT

See Section 7.6 for complete description of comparator interrupts.



#### FIGURE 9-16: INT PIN INTERRUPT TIMING

## 9.9 Code Protection

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

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

### 9.10 ID Locations

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

# 9.11 In-Circuit Serial Programming™

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

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

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

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

# FIGURE 9-19:

#### TYPICAL IN-CIRCUIT SERIAL PROGRAMMING CONNECTION



| SUBLW               | Subtract W from Literal                                                                                                      | SUBWF                     | Subtract W from f                                                                                                                                                        |  |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:             | [ <i>label</i> ] SUBLW k                                                                                                     | Syntax:                   | [ <i>label</i> ] SUBWF f,d                                                                                                                                               |  |  |  |  |
| Operands:           | $0 \le k \le 255$                                                                                                            | Operands:                 | $0 \le f \le 127$                                                                                                                                                        |  |  |  |  |
| Operation:          | $k - (W) \rightarrow (W)$                                                                                                    |                           | d ∈ [0,1]                                                                                                                                                                |  |  |  |  |
| Status<br>Affected: | C, DC, Z                                                                                                                     | Operation:<br>Status      | (f) - (W) $\rightarrow$ (dest)<br>C, DC, Z                                                                                                                               |  |  |  |  |
| Encoding:           | 11 110x kkkk kkkk                                                                                                            | Affected:                 |                                                                                                                                                                          |  |  |  |  |
| Description:        | The W register is subtracted (2's complement method) from the eight bit literal 'k'. The result is placed in the W register. | Encoding:<br>Description: | 000010dfffffffSubtract (2's complement method)W register from register 'f'. If 'd' is 0,the result is stored in the W register.If 'd' is 1, the result is stored head in |  |  |  |  |
| Words:              | 1                                                                                                                            |                           | register 'f'.                                                                                                                                                            |  |  |  |  |
| Cycles:             | 1                                                                                                                            | Words:                    | 1                                                                                                                                                                        |  |  |  |  |
| Example 1:          | SUBLW 0x02                                                                                                                   | Cycles:                   | 1                                                                                                                                                                        |  |  |  |  |
|                     | Before Instruction                                                                                                           | Example 1:                | SUBWF REG1,1                                                                                                                                                             |  |  |  |  |
|                     | W = 1 $C = ?$                                                                                                                |                           | Before Instruction                                                                                                                                                       |  |  |  |  |
|                     | After Instruction                                                                                                            |                           | REG1= 3                                                                                                                                                                  |  |  |  |  |
|                     | W = 1                                                                                                                        |                           | W = 2<br>C = ?                                                                                                                                                           |  |  |  |  |
| Example 2:          | Before Instruction                                                                                                           |                           | After Instruction                                                                                                                                                        |  |  |  |  |
| Example 2.          | W = 2 $C = ?$                                                                                                                |                           | REG1= 1<br>W = 2<br>C = 1; result is positive                                                                                                                            |  |  |  |  |
|                     | After Instruction                                                                                                            | Example 2:                | Before Instruction                                                                                                                                                       |  |  |  |  |
|                     | W = 0<br>C = 1; result is zero                                                                                               |                           | REG1= 2<br>W = 2                                                                                                                                                         |  |  |  |  |
| Example 3:          | Before Instruction                                                                                                           |                           | C = ?                                                                                                                                                                    |  |  |  |  |
|                     | W = 3<br>C = ?                                                                                                               |                           | After Instruction<br>REG1= 0                                                                                                                                             |  |  |  |  |
|                     | After Instruction                                                                                                            |                           | W = 2                                                                                                                                                                    |  |  |  |  |
|                     | W = 0xFF                                                                                                                     | Example 3                 | C = 1; result is zero<br>Before Instruction                                                                                                                              |  |  |  |  |
|                     | C – 0, result is negative                                                                                                    |                           | REG1= 1<br>W = 2<br>C = ?                                                                                                                                                |  |  |  |  |
|                     |                                                                                                                              |                           | After Instruction                                                                                                                                                        |  |  |  |  |
|                     |                                                                                                                              |                           | REG1= 0xFF<br>W = 2<br>C = 0; result is negative                                                                                                                         |  |  |  |  |

# 12.0 ELECTRICAL SPECIFICATIONS

### Absolute Maximum Ratings †

| Ambient Temperature under bias                                                                      | 40° to +125°C                                       |
|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| Storage Temperature                                                                                 | 65° to +150°C                                       |
| Voltage on any pin with respect to Vss (except VDD and MCLR)                                        | -0.6V to VDD +0.6V                                  |
| Voltage on VDD with respect to VSS                                                                  | 0 to +7.5V                                          |
| Voltage on MCLR with respect to Vss (Note 2)                                                        | 0 to +14V                                           |
| Voltage on RA4 with respect to Vss                                                                  | 8.5V                                                |
| Total power Dissipation (Note 1)                                                                    | 1.0W                                                |
| Maximum Current out of Vss pin                                                                      |                                                     |
| Maximum Current into VDD pin                                                                        |                                                     |
| Input Clamp Current, Iк (Vi <0 or Vi> VDD)                                                          | ±20 mA                                              |
| Output Clamp Current, IOK (Vo <0 or Vo>VoD)                                                         | ±20 mA                                              |
| Maximum Output Current sunk by any I/O pin                                                          | 25 mA                                               |
| Maximum Output Current sourced by any I/O pin                                                       | 25 mA                                               |
| Maximum Current sunk by PORTA and PORTB                                                             |                                                     |
| Maximum Current sourced by PORTA and PORTB                                                          |                                                     |
| <b>Note 1:</b> Power dissipation is calculated as follows: PDIS = VDD x {IDD - $\sum$ IOH} + $\sum$ | $\{(VDD-VOH) \times IOH\} + \sum (VOI \times IOL).$ |

2: Voltage spikes below Vss at the MCLR pin, inducing currents greater than 80 mA, may cause latchup. Thus, a series resistor of 50-100Ω should be used when applying a "low" level to the MCLR pin rather than pulling this pin directly to Vss.

**† NOTICE**: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

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

| PIC16C        | 62X  |                                               | $ \begin{array}{ c c c c c } \hline \textbf{Standard Operating Conditions (unless otherwise stated)} \\ \hline \textbf{Operating temperature } -40^{\circ}\text{C} &\leq T\text{A} \leq +85^{\circ}\text{C} \text{ for industrial and} \\ \hline 0^{\circ}\text{C} &\leq T\text{A} \leq +70^{\circ}\text{C} \text{ for commercial and} \\ \hline -40^{\circ}\text{C} &\leq T\text{A} \leq +125^{\circ}\text{C} \text{ for extended} \\ \hline \end{array} $ |                                                                                                                                                                                                                                                                                                        |           |          |                                                                        |  |  |  |
|---------------|------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------|------------------------------------------------------------------------|--|--|--|
| PIC16LC62X    |      |                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 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 extendedOperating voltage VDD range is the PIC16C62X range. |           |          |                                                                        |  |  |  |
| Param.<br>No. | Sym  | Characteristic                                | Min                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Тур†                                                                                                                                                                                                                                                                                                   | Max       | Units    | Conditions                                                             |  |  |  |
| D001          | Vdd  | Supply Voltage                                | 3.0                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                        | 6.0       | V        | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5                           |  |  |  |
| D001          | Vdd  | Supply Voltage                                | 2.5                                                                                                                                                                                                                                                                                                                                                                                                                                                         | —                                                                                                                                                                                                                                                                                                      | 6.0       | V        | See Figures 12-1, 12-2, 12-3, 12-4, and 12-5                           |  |  |  |
| D002          | Vdr  | RAM Data Retention Voltage <sup>(1)</sup>     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.5*                                                                                                                                                                                                                                                                                                   | —         | V        | Device in SLEEP mode                                                   |  |  |  |
| D002          | Vdr  | RAM Data Retention Voltage <sup>(1)</sup>     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.5*                                                                                                                                                                                                                                                                                                   | —         | V        | Device in SLEEP mode                                                   |  |  |  |
| D003          | VPOR | VDD start voltage to ensure<br>Power-on Reset | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Vss                                                                                                                                                                                                                                                                                                    | —         | V        | See section on Power-on Reset for details                              |  |  |  |
| D003          | VPOR | VDD start voltage to<br>ensure Power-on Reset | _                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Vss                                                                                                                                                                                                                                                                                                    | —         | V        | See section on Power-on Reset for details                              |  |  |  |
| D004          | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                                                                                                                                                                                                                                                                                                      | —         | V/ms     | See section on Power-on Reset for details                              |  |  |  |
| D004          | SVDD | VDD rise rate to ensure<br>Power-on Reset     | 0.05*                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                                                                                                                                                                                                                                                                                                      | —         | V/ms     | See section on Power-on Reset for details                              |  |  |  |
| D005          | VBOR | Brown-out Detect Voltage                      | 3.7                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4.0                                                                                                                                                                                                                                                                                                    | 4.3       | V        | BOREN configuration bit is cleared                                     |  |  |  |
| D005          | VBOR | Brown-out Detect Voltage                      | 3.7                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4.0                                                                                                                                                                                                                                                                                                    | 4.3       | V        | BOREN configuration bit is cleared                                     |  |  |  |
| D010          | Idd  | Supply Current <sup>(2)</sup>                 | _                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.8                                                                                                                                                                                                                                                                                                    | 3.3       | mA       | Fosc = 4 MHz, Vdd = 5.5V, WDT disabled, XT<br>mode, ( <b>Note 4</b> )* |  |  |  |
|               |      |                                               | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 35                                                                                                                                                                                                                                                                                                     | 70        | μA       | Fosc = 32 kHz, VDD = 4.0V, WDT disabled, LP                            |  |  |  |
|               |      |                                               | _                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9.0                                                                                                                                                                                                                                                                                                    | 20        | mA       | Fosc = 20 MHz, VDD = 5.5V, WDT disabled, HS mode                       |  |  |  |
| D010          | Idd  | Supply Current <sup>(2)</sup>                 | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.4                                                                                                                                                                                                                                                                                                    | 2.5       | mA       | Fosc = 2.0 MHz, VDD = 3.0V, WDT disabled, XT mode, ( <b>Note 4</b> )   |  |  |  |
|               |      |                                               | -                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 26                                                                                                                                                                                                                                                                                                     | 53        | μA       | Fosc = 32 kHz, VDD = 3.0V, WDT disabled, LP mode                       |  |  |  |
| D020          | IPD  | Power-down Current <sup>(3)</sup>             | —                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1.0                                                                                                                                                                                                                                                                                                    | 2.5<br>15 | μΑ<br>μΑ | VDD=4.0V, WDT disabled<br>(125°C)                                      |  |  |  |
| D020          | IPD  | Power-down Current <sup>(3)</sup>             | _                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0.7                                                                                                                                                                                                                                                                                                    | 2         | μA       | VDD=3.0V, WDT disabled                                                 |  |  |  |

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

# PIC16C62X

# 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 state<br>Operating temperature         -40°C       ≤ TA ≤ +85°C for industrial<br>0°C         0°C       ≤ TA ≤ +70°C for commerci<br>-40°C         -40°C       ≤ TA ≤ +125°C for extende |                |                                                          |                                                                                                                                                                                                                                                           |      |          |                      | 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 |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| PIC16L                                                                                                                                                                                                                                                    | C62XA          | Stand<br>Opera                                           | Standard Operating Conditions (unless otherwise stateOperating temperature $-40^{\circ}$ C $\leq TA \leq +85^{\circ}$ C for industrial $0^{\circ}$ C $\leq TA \leq +70^{\circ}$ C for commercia $-40^{\circ}$ C $\leq TA \leq +125^{\circ}$ C for extende |      |          |                      |                                                                                                                                                                                                                       |  |  |
| Param.<br>No.                                                                                                                                                                                                                                             | Sym            | Characteristic                                           | Min                                                                                                                                                                                                                                                       | Тур† | Max      | 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                        | U                                                                                                                                                                                                                                                         | —    | 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.)

| PIC16C                    | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ |                                                                     |                               |                                                      |            |    |                                                                                                 |  |  |  |
|---------------------------|-------------------------------------------------------|---------------------------------------------------------------------|-------------------------------|------------------------------------------------------|------------|----|-------------------------------------------------------------------------------------------------|--|--|--|
| PIC16LC62X/LC62XA/LCR62XA |                                                       |                                                                     | <b>Standaı</b><br>Operatir    | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |            |    |                                                                                                 |  |  |  |
| Param.<br>No.             | Sym                                                   | Characteristic                                                      | Min Typ† Max 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.

# 12.5 DC CHARACTERISTICS: PIC16C620A/C621A/C622A-40<sup>(7)</sup> (Commercial) PIC16CR620A-40<sup>(7)</sup> (Commercial)

| DC CH        | IARAC <sup>.</sup> | TERISTICS                                 | Standard Operating Conditions (unless otherwise stated)Operating temperature $0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial |      |                 |      |                                                                  |  |
|--------------|--------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------|-----------------|------|------------------------------------------------------------------|--|
| Param<br>No. | Sym                | Characteristic                            | Min                                                                                                                                | Тур† | Мах             | Unit | Conditions                                                       |  |
|              | VIL                | Input Low Voltage                         |                                                                                                                                    |      |                 |      |                                                                  |  |
|              |                    | I/O ports                                 |                                                                                                                                    |      |                 |      |                                                                  |  |
| D030         |                    | with TTL buffer                           | Vss                                                                                                                                | —    | 0.8V<br>0.15Vdd | V    | VDD = 4.5V to 5.5V, otherwise                                    |  |
| D031         |                    | with Schmitt Trigger input                | Vss                                                                                                                                |      | 0.2VDD          | V    |                                                                  |  |
| D032         |                    | MCLR, RA4/T0CKI, OSC1<br>(in RC mode)     | Vss                                                                                                                                | —    | 0.2Vdd          | V    | (Note 1)                                                         |  |
| D033         |                    | OSC1 (in XT and HS)                       | Vss                                                                                                                                | —    | 0.3VDD          | V    |                                                                  |  |
|              |                    | OSC1 (in LP)                              | Vss                                                                                                                                | _    | 0.6Vdd - 1.0    | V    |                                                                  |  |
|              | Viн                | Input High Voltage                        |                                                                                                                                    |      |                 |      |                                                                  |  |
|              |                    | I/O ports                                 |                                                                                                                                    |      |                 |      |                                                                  |  |
| D040         |                    | with TTL buffer                           | 2.0V                                                                                                                               | —    | VDD             | V    | VDD = 4.5V to 5.5V, otherwise                                    |  |
| D044         |                    | with Ochavitt Triansations t              | 0.25 VDD + 0.8                                                                                                                     |      | VDD             |      |                                                                  |  |
| D041         |                    |                                           |                                                                                                                                    |      | VDD             |      |                                                                  |  |
| D042         |                    | MCLR RA4/TUCKI                            |                                                                                                                                    | _    | VDD             | V    |                                                                  |  |
| D043         |                    | OSC1 (A1, HS and LP)<br>OSC1 (in RC mode) |                                                                                                                                    | _    | VDD             | v    | (Note 1)                                                         |  |
| D070         | IPURB              | PORTB Weak Pull-up Current                | 50                                                                                                                                 | 200  | 400             | μА   | $V_{DD} = 5.0V$ . VPIN = Vss                                     |  |
|              | lil                | Input Leakage Current <sup>(2, 3)</sup>   |                                                                                                                                    |      |                 |      |                                                                  |  |
|              |                    | 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 \le VPIN \le VDD$                                           |  |
| 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 mA, VDD = 4.5V, -40° to +85°C                          |  |
|              |                    |                                           | —                                                                                                                                  | —    | 0.6             | V    | IOL = 7.0 mA, VDD = 4.5V, +125°C                                 |  |
| D083         |                    | OSC2/CLKOUT (RC only)                     | —                                                                                                                                  | —    | 0.6             | V    | IOL = 1.6 mA, VDD = 4.5V, -40° to +85°C                          |  |
|              |                    | (2)                                       | _                                                                                                                                  | —    | 0.6             | V    | IOL = 1.2 mA, VDD = 4.5V, +125°C                                 |  |
|              | Vон                | Output High Voltage <sup>(3)</sup>        |                                                                                                                                    |      |                 |      |                                                                  |  |
| D090         |                    | I/O ports (except RA4)                    | VDD-0.7                                                                                                                            | —    | —               | V    | IOH = -3.0 mA, VDD = 4.5V, -40° to +85°C                         |  |
|              |                    |                                           | VDD-0.7                                                                                                                            | —    | —               | V    | IOH = -2.5 mA, VDD = 4.5V, +125°C                                |  |
| D092         |                    | OSC2/CLKOUT (RC only)                     | VDD-0.7                                                                                                                            | —    | —               | V    | IOH = -1.3 mA, VDD = 4.5V, -40° to +85°C                         |  |
| *0450        | 1/25               | On an Duain Ulink Matterna                | VDD-0.7                                                                                                                            | _    |                 | V    | IOH = -1.0 mA, VDD = 4.5V, +125°C                                |  |
| "D150        | VOD                | Open Drain High Voltage                   |                                                                                                                                    |      | 8.5             | V    | RA4 pin                                                          |  |
|              |                    | Output Pins                               |                                                                                                                                    |      |                 |      |                                                                  |  |
| D100         | Cosc2              | OSC2 pin                                  |                                                                                                                                    |      | 15              | pF   | In XT, HS and LP modes when external<br>clock used to drive OSC1 |  |
| D101         | Сю                 | All I/O pins/OSC2 (in RC mode)            |                                                                                                                                    |      | 50              | pF   |                                                                  |  |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 5.0V, 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 in SLEEP mode 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.
 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 bi-impedance state and tied to VDD or VSS.

 mode, with all I/O pins in hi-impedance state and tied to VDD or VSs.
 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.

7: See Section 12.1 and Section 12.3 for 16C62X and 16CR62X devices for operation between 20 MHz and 40 MHz for valid modified characteristics.

| Parameter<br>No. | Sym          | Characteristic                                               | Min                                | Тур†    | Max        | Units    | Conditions                                                   |
|------------------|--------------|--------------------------------------------------------------|------------------------------------|---------|------------|----------|--------------------------------------------------------------|
| 10*              | TosH2ckL     | OSC1↑ to CLKOUT↓ <sup>(1)</sup>                              |                                    | 75<br>— | 200<br>400 | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 11*              | TosH2ck<br>H | OSC1↑ to CLKOUT↑ <sup>(1)</sup>                              | _                                  | 75<br>— | 200<br>400 | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 12*              | TckR         | CLKOUT rise time <sup>(1)</sup>                              |                                    | 35<br>— | 100<br>200 | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 13*              | TckF         | CLKOUT fall time <sup>(1)</sup>                              |                                    | 35<br>— | 100<br>200 | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 14*              | TckL2ioV     | CLKOUT $\downarrow$ to Port out valid <sup>(1)</sup>         | _                                  | —       | 20         | ns       |                                                              |
| 15*              | TioV2ckH     | Port in valid before CLKOUT ↑ <sup>(1)</sup>                 | Tosc +200<br>ns<br>Tosc +400<br>ns | _       | _          | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 16*              | TckH2iol     | Port in hold after CLKOUT $\uparrow^{(1)}$                   | 0                                  | —       |            | ns       |                                                              |
| 17*              | TosH2ioV     | OSC1↑ (Q1 cycle) to Port out valid                           | _                                  | 50      | 150<br>300 | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 18*              | TosH2iol     | OSC1↑ (Q2 cycle) to Port input<br>invalid (I/O in hold time) | 100<br>200                         | _       | _          | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 19*              | TioV2osH     | Port input valid to OSC1 <sup>↑</sup> (I/O in setup time)    | 0                                  | —       | —          | ns       |                                                              |
| 20*              | TioR         | Port output rise time                                        | _                                  | 10<br>— | 40<br>80   | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 21*              | TioF         | Port output fall time                                        | _                                  | 10<br>— | 40<br>80   | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 22*              | Tinp         | RB0/INT pin high or low time                                 | 25<br>40                           | _       | _          | ns<br>ns | PIC16C62X(A)<br>PIC16LC62X(A)<br>PIC16CR62XA<br>PIC16LCR62XA |
| 23               | Trbp         | RB<7:4> change interrupt high or low time                    | Тсү                                | —       | —          | ns       |                                                              |

# TABLE 12-4: CLKOUT AND I/O TIMING REQUIREMENTS

\* These parameters are characterized but not tested.

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

Note 1: Measurements are taken in RC Mode where CLKOUT output is 4 x Tosc.

# 14.0 PACKAGING INFORMATION

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



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

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

# 14.1 Package Marking Information



| Legenc | I: XXX<br>Y<br>YY<br>WW<br>NNN          | Customer specific information*<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code |
|--------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:  | In the even<br>be carried<br>for custom | nt the full Microchip part number cannot be marked on one line, it will<br>over to the next line thus limiting the number of available characters<br>her specific information.                          |

\* Standard PICmicro device marking consists of Microchip part number, year code, week code, and traceability code. For PICmicro device marking beyond this, certain price adders apply. Please check with your Microchip Sales Office. For QTP devices, any special marking adders are included in QTP price.

# PIC16C62X

NOTES: