



### 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                      | 20MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI                                                      |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 22                                                                         |
| Program Memory Size        | 3.5KB (2K x 14)                                                            |
| Program Memory Type        | ОТР                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 128 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 6V                                                                    |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 28-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c62a-20i-ss |
|                            |                                                                            |

Email: info@E-XFL.COM

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

### **Pin Diagrams**



### FIGURE 4-4: PIC16C66/67 PROGRAM MEMORY MAP AND STACK



### 4.2 Data Memory Organization

# Applicable Devices

61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67 The data memory is partitioned into multiple banks

which contain the General Purpose Registers and the Special Function Registers. Bits RP1 and RP0 are the bank select bits.

RP1:RP0 (STATUS<6:5>)

- = 00  $\rightarrow$  Bank0
- = 01  $\rightarrow$  Bank1
- = 10  $\rightarrow$  Bank2
- = 11  $\rightarrow$  Bank3

Each bank extends up to 7Fh (128 bytes). The lower locations of each bank are reserved for the Special Function Registers. Above the Special Function Registers are General Purpose Registers, implemented as static RAM. All implemented banks contain special function registers. Some "high use" special function registers from one bank may be mirrored in another bank for code reduction and quicker access.

### 4.2.1 GENERAL PURPOSE REGISTERS

These registers are accessed either directly or indirectly through the File Select Register (FSR) (Section 4.5). For the PIC16C61, general purpose register locations 8Ch-AFh of Bank 1 are not physically implemented. These locations are mapped into 0Ch-2Fh of Bank 0.

### FIGURE 4-5: PIC16C61 REGISTER FILE MAP



| Address              | Name    | Bit 7              | Bit 6              | Bit 5          | Bit 4          | Bit 3               | Bit 2       | Bit 1         | Bit 0     | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> |
|----------------------|---------|--------------------|--------------------|----------------|----------------|---------------------|-------------|---------------|-----------|--------------------------|------------------------------------------------|
| Bank 0               | 1       | 1                  | 1                  | I              |                | I                   | 1           | 1             | 1         | 1                        | <u> </u>                                       |
| 00h <sup>(1)</sup>   | INDF    | Addressing         | this location      | uses conter    | its of FSR to  | address data        | a memory (n | ot a physical | register) | 0000 0000                | 0000 0000                                      |
| 01h                  | TMR0    | Timer0 mod         | dule's registe     | r              |                |                     |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 02h <sup>(1)</sup>   | PCL     | Program Co         | ounter's (PC)      | Least Signif   | icant Byte     |                     |             |               |           | 0000 0000                | 0000 0000                                      |
| 03h <sup>(1)</sup>   | STATUS  | IRP <sup>(4)</sup> | RP1 <sup>(4)</sup> | RP0            | TO             | PD                  | Z           | DC            | С         | 0001 1xxx                | 000q quuu                                      |
| 04h <sup>(1)</sup>   | FSR     | Indirect dat       | a memory ac        | Idress pointe  | er             | 1                   |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 05h                  | PORTA   | —                  | —                  | PORTA Dat      | a Latch wher   | written: PO         | RTA pins wh | en read       |           | xx xxxx                  | uu uuuu                                        |
| 06h                  | PORTB   | PORTB Da           | ta Latch whe       | n written: PC  | ORTB pins wh   | nen read            |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 07h                  | PORTC   | PORTC Da           | ta Latch whe       | n written: PC  | ORTC pins wi   | nen read            |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 08h                  | _       | Unimpleme          | nted               |                | —              | _                   |             |               |           |                          |                                                |
| 09h                  | —       | Unimpleme          | nted               |                | —              | _                   |             |               |           |                          |                                                |
| 0Ah <sup>(1,2)</sup> | PCLATH  | —                  | —                  | 0 0000         | 0 0000         |                     |             |               |           |                          |                                                |
| 0Bh <sup>(1)</sup>   | INTCON  | GIE                | PEIE               | TOIE           | INTE           | RBIE TOIF INTE RBIE |             | 0000 000x     | 0000 000u |                          |                                                |
| 0Ch                  | PIR1    | (5)                | (5)                | RCIF           | TXIF           | SSPIF               | CCP1IF      | TMR2IF        | TMR1IF    | 0000 0000                | 0000 0000                                      |
| 0Dh                  | PIR2    | _                  | _                  | CCP2IF         |                |                     |             |               |           |                          | 0                                              |
| 0Eh                  | TMR1L   | Holding reg        | ister for the I    | _east Signific | ant Byte of t  | ne 16-bit TM        | R1 register |               | 1         | xxxx xxxx                | uuuu uuuu                                      |
| 0Fh                  | TMR1H   | Holding reg        | ister for the I    | Most Signific  | ant Byte of th | e 16-bit TMF        | R1 register |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 10h                  | T1CON   | —                  | —                  | T1CKPS1        | T1CKPS0        | T1OSCEN             | T1SYNC      | TMR1CS        | TMR10N    | 00 0000                  | uu uuuu                                        |
| 11h                  | TMR2    | Timer2 mod         | dule's registe     | r              |                |                     |             |               |           | 0000 0000                | 0000 0000                                      |
| 12h                  | T2CON   | —                  | TOUTPS3            | TOUTPS2        | TOUTPS1        | TOUTPS0             | TMR2ON      | T2CKPS1       | T2CKPS0   | -000 0000                | -000 0000                                      |
| 13h                  | SSPBUF  | Synchronou         | us Serial Por      | t Receive Bu   | ffer/Transmit  | Register            |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 14h                  | SSPCON  | WCOL               | SSPOV              | SSPEN          | CKP            | SSPM3               | SSPM2       | SSPM1         | SSPM0     | 0000 0000                | 0000 0000                                      |
| 15h                  | CCPR1L  | Capture/Co         | mpare/PWM          | 1 (LSB)        |                |                     |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 16h                  | CCPR1H  | Capture/Co         | mpare/PWM          | 1 (MSB)        |                |                     |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 17h                  | CCP1CON | —                  | _                  | CCP1X          | CCP1Y          | CCP1M3              | CCP1M2      | CCP1M1        | CCP1M0    | 00 0000                  | 00 0000                                        |
| 18h                  | RCSTA   | SPEN               | RX9                | SREN           | CREN           | —                   | FERR        | OERR          | RX9D      | 0000 -00x                | 0000 -00x                                      |
| 19h                  | TXREG   | USART Tra          | nsmit Data F       | legister       |                |                     |             |               |           | 0000 0000                | 0000 0000                                      |
| 1Ah                  | RCREG   | USART Re           | ceive Data R       | egister        |                |                     |             |               |           | 0000 0000                | 0000 0000                                      |
| 1Bh                  | CCPR2L  | Capture/Co         | mpare/PWM          | 2 (LSB)        |                |                     |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 1Ch                  | CCPR2H  | Capture/Co         | mpare/PWM          | 2 (MSB)        |                |                     |             |               |           | xxxx xxxx                | uuuu uuuu                                      |
| 1Dh                  | CCP2CON | —                  | —                  | CCP2X          | CCP2Y          | CCP2M3              | CCP2M2      | CCP2M1        | CCP2M0    | 00 0000                  | 00 0000                                        |
| 1Eh-1Fh              | _       | Unimpleme          | nted               |                |                |                     |             |               |           | _                        | _                                              |

TABLE 4-3: SPECIAL FUNCTION REGISTERS FOR THE PIC16C63/R63

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'. Shaded locations are unimplemented, read as '0'.

Note 1: These registers can be addressed from either bank.

2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>)

3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.

4: The IRP and RP1 bits are reserved on the PIC16C63/R63, always maintain these bits clear.

5: PIE1<7:6> and PIR1<7:6> are reserved on the PIC16C63/R63, always maintain these bits clear.

| IABLE                | 4-4:    | E SPECIAL FUNCTION REGISTERS FOR THE PICTOC04/04A/R04 (Cont.d) |                                       |                           |                |              |                 |                |                    |                          |                                                |  |  |  |
|----------------------|---------|----------------------------------------------------------------|---------------------------------------|---------------------------|----------------|--------------|-----------------|----------------|--------------------|--------------------------|------------------------------------------------|--|--|--|
| Address              | Name    | Bit 7                                                          | Bit 6                                 | Bit 5                     | Bit 4          | Bit 3        | Bit 2           | Bit 1          | Bit 0              | Value on:<br>POR,<br>BOR | Value on<br>all other<br>resets <sup>(3)</sup> |  |  |  |
| Bank 1               |         |                                                                |                                       |                           |                |              |                 |                |                    |                          |                                                |  |  |  |
| 80h <sup>(1)</sup>   | INDF    | Addressing                                                     | this location                         | uses conte                | nts of FSR to  | address dat  | a memory (n     | ot a physical  | register)          | 0000 0000                | 0000 0000                                      |  |  |  |
| 81h                  | OPTION  | RBPU                                                           | INTEDG                                | TOCS                      | T0SE           | PSA          | PS2             | PS1            | PS0                | 1111 1111                | 1111 1111                                      |  |  |  |
| 82h <sup>(1)</sup>   | PCL     | Program Co                                                     | ounter's (PC)                         | Least Sig                 | nificant Byte  |              |                 |                |                    | 0000 0000                | 0000 0000                                      |  |  |  |
| 83h <sup>(1)</sup>   | STATUS  | IRP <sup>(5)</sup>                                             | RP1 <sup>(5)</sup>                    | RP0                       | TO             | PD           | Z               | DC             | С                  | 0001 1xxx                | 000q quuu                                      |  |  |  |
| 84h <sup>(1)</sup>   | FSR     | Indirect dat                                                   | a memory ac                           | ddress point              | er             |              |                 |                |                    | xxxx xxxx                | uuuu uuuu                                      |  |  |  |
| 85h                  | TRISA   | _                                                              | —                                     | PORTA Da                  | ta Direction R | egister      |                 |                |                    | 11 1111                  | 11 1111                                        |  |  |  |
| 86h                  | TRISB   | PORTB Da                                                       | DRTB Data Direction Register 1111 111 |                           |                |              |                 |                |                    |                          |                                                |  |  |  |
| 87h                  | TRISC   | PORTC Da                                                       | ORTC Data Direction Register 1111     |                           |                |              |                 |                |                    |                          |                                                |  |  |  |
| 88h                  | TRISD   | PORTD Da                                                       | PORTD Data Direction Register 1       |                           |                |              |                 |                |                    |                          |                                                |  |  |  |
| 89h                  | TRISE   | IBF                                                            | OBF                                   | IBOV                      | PSPMODE        | —            | PORTE Da        | ta Direction I | Bits               | 0000 -111                | 0000 -111                                      |  |  |  |
| 8Ah <sup>(1,2)</sup> | PCLATH  | —                                                              | —                                     | —                         | Write Buffer   | for the uppe | r 5 bits of the | e Program C    | ounter             | 0 0000                   | 0 0000                                         |  |  |  |
| 8Bh <sup>(1)</sup>   | INTCON  | GIE                                                            | PEIE                                  | TOIE                      | INTE           | RBIE         | TOIF            | INTF           | RBIF               | 0000 000x                | 0000 000u                                      |  |  |  |
| 8Ch                  | PIE1    | PSPIE                                                          | (6)                                   | —                         | —              | SSPIE        | CCP1IE          | TMR2IE         | TMR1IE             | 00 0000                  | 00 0000                                        |  |  |  |
| 8Dh                  | -       | Unimpleme                                                      | nted                                  |                           |                |              |                 |                |                    | -                        | —                                              |  |  |  |
| 8Eh                  | PCON    | —                                                              | —                                     | —                         | —              | —            | —               | POR            | BOR <sup>(4)</sup> | qq                       | uu                                             |  |  |  |
| 8Fh                  | _       | Unimpleme                                                      | nted                                  |                           |                |              |                 |                |                    | -                        | —                                              |  |  |  |
| 90h                  | -       | Unimpleme                                                      | nted                                  |                           |                |              |                 |                |                    | _                        | —                                              |  |  |  |
| 91h                  | -       | Unimpleme                                                      | nted                                  |                           |                |              |                 |                |                    | -                        | —                                              |  |  |  |
| 92h                  | PR2     | Timer2 Peri                                                    | iod Register                          |                           |                |              |                 |                |                    | 1111 1111                | 1111 1111                                      |  |  |  |
| 93h                  | SSPADD  | Synchronou                                                     | us Serial Por                         | t (I <sup>2</sup> C mode) | Address Reg    | jister       |                 |                |                    | 0000 0000                | 0000 0000                                      |  |  |  |
| 94h                  | SSPSTAT | _                                                              | —                                     | D/Ā                       | Р              | S            | R/W             | UA             | BF                 | 00 0000                  | 00 0000                                        |  |  |  |
| 95h-9Fh              | _       | Unimpleme                                                      | nted                                  |                           |                |              |                 |                |                    | _                        | —                                              |  |  |  |
|                      |         |                                                                |                                       |                           |                |              |                 |                |                    |                          |                                                |  |  |  |

TABLE 4-4: SPECIAL FUNCTION REGISTERS FOR THE PIC16C64/64A/R64 (Cont.'d)

Legend: x = unknown, u = unchanged, q = value depends on condition, - = unimplemented location read as '0'. Shaded locations are unimplemented, read as '0'.

Note 1: These registers can be addressed from either bank.

2: The upper byte of the Program Counter (PC) is not directly accessible. PCLATH is a holding register for the PC whose contents are transferred to the upper byte of the program counter. (PC<12:8>)

3: Other (non power-up) resets include external reset through MCLR and the Watchdog Timer reset.

4: The BOR bit is reserved on the PIC16C64, always maintain this bit set.

5: The IRP and RP1 bits are reserved on the PIC16C64/64A/R64, always maintain these bits clear.

6: PIE1<6> and PIR1<6> are reserved on the PIC16C64/64A/R64, always maintain these bits clear.

## 6.0 OVERVIEW OF TIMER MODULES

### Applicable Devices

61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

All PIC16C6X devices have three timer modules except for the PIC16C61, which has one timer module. Each module can generate an interrupt to indicate that an event has occurred (i.e., timer overflow). Each of these modules are detailed in the following sections. The timer modules are:

- Timer0 module (Section 7.0)
- Timer1 module (Section 8.0)
- Timer2 module (Section 9.0)

### 6.1 <u>Timer0 Overview</u>

### Applicable Devices

### 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

The Timer0 module is a simple 8-bit overflow counter. The clock source can be either the internal system clock (Fosc/4) or an external clock. When the clock source is an external clock, the Timer0 module can be selected to increment on either the rising or falling edge.

The Timer0 module also has a programmable prescaler option. This prescaler can be assigned to either the Timer0 module or the Watchdog Timer. Bit PSA (OPTION<3>) assigns the prescaler, and bits PS2:PS0 (OPTION<2:0>) determine the prescaler value. TMR0 can increment at the following rates: 1:1 when the prescaler is assigned to Watchdog Timer, 1:2, 1:4, 1:8, 1:16, 1:32, 1:64, 1:128, and 1:256.

Synchronization of the external clock occurs after the prescaler. When the prescaler is used, the external clock frequency may be higher then the device's frequency. The maximum frequency is 50 MHz, given the high and low time requirements of the clock.

### 6.2 <u>Timer1 Overview</u>

| Ap | plicable Devices |
|----|------------------|
|    |                  |

### 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

Timer1 is a 16-bit timer/counter. The clock source can be either the internal system clock (Fosc/4), an external clock, or an external crystal. Timer1 can operate as either a timer or a counter. When operating as a counter (external clock source), the counter can either operate synchronized to the device or asynchronously to the device. Asynchronous operation allows Timer1 to operate during sleep, which is useful for applications that require a real-time clock as well as the power savings of SLEEP mode.

TImer1 also has a prescaler option which allows TMR1 to increment at the following rates: 1:1, 1:2, 1:4, and 1:8. TMR1 can be used in conjunction with the Capture/Compare/PWM module. When used with a CCP module, Timer1 is the time-base for 16-bit capture or 16-bit compare and must be synchronized to the device.

### 6.3 <u>Timer2 Overview</u>

### Applicable Devices

### 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

Timer2 is an 8-bit timer with a programmable prescaler and a programmable postscaler, as well as an 8-bit Period Register (PR2). Timer2 can be used with the CCP module (in PWM mode) as well as the Baud Rate Generator for the Synchronous Serial Port (SSP). The prescaler option allows Timer2 to increment at the following rates: 1:1, 1:4, and 1:16.

The postscaler allows TMR2 register to match the period register (PR2) a programmable number of times before generating an interrupt. The postscaler can be programmed from 1:1 to 1:16 (inclusive).

### 6.4 <u>CCP Overview</u>

| e Devices |
|-----------|
|           |
|           |
|           |

61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

The CCP module(s) can operate in one of three modes: 16-bit capture, 16-bit compare, or up to 10-bit Pulse Width Modulation (PWM).

Capture mode captures the 16-bit value of TMR1 into the CCPRxH:CCPRxL register pair. The capture event can be programmed for either the falling edge, rising edge, fourth rising edge, or sixteenth rising edge of the CCPx pin.

Compare mode compares the TMR1H:TMR1L register pair to the CCPRxH:CCPRxL register pair. When a match occurs, an interrupt can be generated and the output pin CCPx can be forced to a given state (High or Low) and Timer1 can be reset. This depends on control bits CCPxM3:CCPxM0.

PWM mode compares the TMR2 register to a 10-bit duty cycle register (CCPRxH:CCPRxL<5:4>) as well as to an 8-bit period register (PR2). When the TMR2 register = Duty Cycle register, the CCPx pin will be forced low. When TMR2 = PR2, TMR2 is cleared to 00h, an interrupt can be generated, and the CCPx pin (if an output) will be forced high.

### 11.2.1 OPERATION OF SSP MODULE IN SPI MODE

Applicable Devices 61 62 624 R62 63 R63 64 644 R64 65 654 R65 66 67

The SPI mode allows 8-bits of data to be synchronously transmitted and received simultaneously. To accomplish communication, typically three pins are used:

Serial Data Out (SDO)

PIC16C6X

- Serial Data In (SDI)
- Serial Clock (SCK)

Additionally a fourth pin may be used when in a slave mode of operation:

Slave Select (SS)

When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits in the SSPCON register (SSPCON<5:0>). These control bits allow the following to be specified:

- Master Mode (SCK is the clock output)
- · Slave Mode (SCK is the clock input)
- Clock Polarity (Output/Input data on the Rising/ Falling edge of SCK)
- · Clock Rate (Master mode only)
- Slave Select Mode (Slave mode only)

The SSP consists of a transmit/receive Shift Register (SSPSR) and a Buffer register (SSPBUF). The SSPSR shifts the data in and out of the device, MSb first. The SSPBUF holds the data that was written to the SSPSR, until the received data is ready. Once the 8-bits of data have been received, that byte is moved to the SSPBUF register. Then the Buffer Full bit, BF (SSPSTAT<0>) and flag bit SSPIF are set. This double buffering of the received data (SSPBUF) allows the next byte to start reception before reading the data that was just received. Any write to the SSPBUF register during transmission/reception of data will be ignored, and the write collision detect bit, WCOL (SSPCON<7>) will be set. User software must clear bit WCOL so that it can be determined if the following write(s) to the SSPBUF completed successfully. When the application software is expecting to receive valid data, the SSPBUF register should be read before the next byte of data to transfer is written to the SSPBUF register. The Buffer Full bit BF (SSPSTAT<0>) indicates when the SSPBUF register has been loaded with the received data (transmission is complete). When the SSPBUF is read, bit BF is cleared. This data may be irrelevant if the SPI is only a transmitter. Generally the SSP Interrupt is used to determine when the transmission/reception has completed. The SSPBUF register must be read and/or written. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur. Example 11-1 shows the loading of the SSPBUF (SSPSR) register for data transmission. The shaded instruction is only required if the received data is meaningful.

### EXAMPLE 11-1: LOADING THE SSPBUF (SSPSR) REGISTER

|      |       | •       | ,    |                   |
|------|-------|---------|------|-------------------|
|      | BSF   | STATUS, | RP0  | ;Specify Bank 1   |
| LOOP | BTFSS | SSPSTAT | , BF | ;Has data been    |
|      |       |         |      | ;received         |
|      |       |         |      | ;(transmit        |
|      |       |         |      | ;complete)?       |
|      | GOTO  | LOOP    |      | ;No               |
|      | BCF   | STATUS, | RP0  | ;Specify Bank 0   |
|      | MOVF  | SSPBUF, | W    | ;W reg = contents |
|      |       |         |      | ; of SSPBUF       |
|      | MOVWF | RXDATA  |      | ;Save in user RAM |
|      | MOVF  | TXDATA, | W    | ;W reg = contents |
|      |       |         |      | ; of TXDATA       |
|      | MOVWF | SSPBUF  |      | ;New data to xmit |
|      |       |         |      |                   |

The block diagram of the SSP module, when in SPI mode (Figure 11-3), shows that the SSPSR register is not directly readable or writable, and can only be accessed from addressing the SSPBUF register. Additionally, the SSP status register (SSPSTAT) indicates the various status conditions.

### FIGURE 11-3: SSP BLOCK DIAGRAM (SPI MODE)



Steps to follow when setting up an Asynchronous Reception:

- 1. Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, set bit BRGH (Section 12.1).
- 2. Enable the asynchronous serial port by clearing bit SYNC and setting bit SPEN.
- 3. If interrupts are desired, then set enable bit  $\ensuremath{\mathsf{RCIE}}$  .
- 4. If 9-bit reception is desired, then set bit RX9.
- 5. Enable the reception by setting enable bit CREN.

- Flag bit RCIF will be set when reception is complete, and an interrupt will be generated if enable bit RCIE was set.
- Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 8. Read the 8-bit received data by reading the RCREG register.
- 9. If any error occurred, clear the error by clearing enable bit CREN.

| Address | Name  | Bit 7                | Bit 6     | Bit 5   | Bit 4     | Bit 3     | Bit 2  | Bit 1  | Bit 0  | Value on<br>POR,<br>BOR | Value on<br>all other<br>Resets |
|---------|-------|----------------------|-----------|---------|-----------|-----------|--------|--------|--------|-------------------------|---------------------------------|
| 0Ch     | PIR1  | PSPIF <sup>(1)</sup> | (2)       | RCIF    | TXIF      | SSPIF     | CCP1IF | TMR2IF | TMR1IF | 0000 0000               | 0000 0000                       |
| 18h     | RCSTA | SPEN                 | RX9       | SREN    | CREN      | _         | FERR   | OERR   | RX9D   | 0000 -00x               | 0000 -00x                       |
| 1Ah     | RCREG | USART Re             | eceive Re | egister |           |           |        |        |        | 0000 0000               | 0000 0000                       |
| 8Ch     | PIE1  | PSPIE <sup>(1)</sup> | (2)       | RCIE    | TXIE      | SSPIE     | CCP1IE | TMR2IE | TMR1IE | 0000 0000               | 0000 0000                       |
| 98h     | TXSTA | CSRC                 | TX9       | TXEN    | SYNC      | _         | BRGH   | TRMT   | TX9D   | 0000 -010               | 0000 -010                       |
| 99h     | SPBRG | Baud Rate            | Genera    |         | 0000 0000 | 0000 0000 |        |        |        |                         |                                 |

### TABLE 12-7: REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTION

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Reception.

Note 1: PSPIE and PSPIF are reserved on the PIC16C63/R63/66, always maintain these bits clear.

2: PIE1<6> and PIR1<6> are reserved, always maintain these bits clear.

| RETLW                                                                                                                                                                               | Return v                              | vith Liter            | al in W                            |                                         | RETURN            | Return fi                                                                                                 | rom Sub              | routine          |                    |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------|------------------------------------|-----------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------|----------------------|------------------|--------------------|--|--|--|
| Syntax:                                                                                                                                                                             | [ label ]                             | RETLW                 | k                                  |                                         | Syntax:           | [ label ]                                                                                                 | RETUR                | N                |                    |  |  |  |
| Operands:                                                                                                                                                                           | $0 \le k \le 2$                       | 55                    |                                    |                                         | Operands:         | None                                                                                                      |                      |                  |                    |  |  |  |
| Operation:                                                                                                                                                                          | $k \rightarrow (W);$                  |                       |                                    |                                         | Operation:        | $\text{TOS} \to \text{F}$                                                                                 | $TOS \rightarrow PC$ |                  |                    |  |  |  |
|                                                                                                                                                                                     | $TOS \rightarrow F$                   | PC                    |                                    |                                         | Status Affected:  | None                                                                                                      | None                 |                  |                    |  |  |  |
| Status Affected:                                                                                                                                                                    | None                                  | None                  |                                    |                                         | Encoding:         | 00                                                                                                        | 0000                 | 0000             | 1000               |  |  |  |
| Encoding:                                                                                                                                                                           | 11                                    | 01xx                  | kkkk                               | kkkk                                    | Description:      | Return fro                                                                                                | m subrout            | ine. The st      | ack is             |  |  |  |
| Description: The W register is loaded with the eight<br>bit literal 'k'. The program counter is<br>loaded from the top of the stack (the<br>rature addrease). This is a two surface |                                       |                       |                                    |                                         |                   | POPed and the top of the stack (TOS) is loaded into the program counter. This is a two cycle instruction. |                      |                  |                    |  |  |  |
| return address). This is a two cycle<br>instruction.                                                                                                                                |                                       |                       |                                    | Words:                                  | 1                 |                                                                                                           |                      |                  |                    |  |  |  |
| Words:                                                                                                                                                                              | 1                                     |                       |                                    |                                         | Cycles:           | 2                                                                                                         |                      |                  |                    |  |  |  |
| Cycles:                                                                                                                                                                             | 2                                     |                       |                                    |                                         | Q Cycle Activity: | Q1                                                                                                        | Q2                   | Q3               | Q4                 |  |  |  |
| Q Cycle Activity:                                                                                                                                                                   | Q1                                    | Q2                    | Q3                                 | Q4                                      | 1st Cycle         | Decode                                                                                                    | No-<br>Operation     | No-<br>Operation | Pop from the Stack |  |  |  |
| 1st Cycle                                                                                                                                                                           | Decode                                | Read<br>literal 'k'   | No-<br>Operation                   | Write to<br>W, Pop<br>from the<br>Stack | 2nd Cycle         | No-<br>Operation                                                                                          | No-<br>Operation     | No-<br>Operation | No-<br>Operation   |  |  |  |
| 2nd Cycle                                                                                                                                                                           | No-                                   | No-                   | No-                                | No-                                     | Example           | RETURN                                                                                                    |                      |                  |                    |  |  |  |
|                                                                                                                                                                                     | Operation                             | Operation             | Operation                          | Operation                               |                   | After Interrupt                                                                                           |                      |                  |                    |  |  |  |
| Example                                                                                                                                                                             | CALL TABL                             | ;offse                | tains tabl<br>t value<br>has table |                                         |                   |                                                                                                           | PC =                 | TOS              |                    |  |  |  |
| TABLE                                                                                                                                                                               | ADDWF PC<br>RETLW k1<br>RETLW k2<br>• | ;W = 0<br>;Begin<br>; |                                    |                                         |                   |                                                                                                           |                      |                  |                    |  |  |  |
|                                                                                                                                                                                     | RETLW kn                              |                       | of table                           |                                         |                   |                                                                                                           |                      |                  |                    |  |  |  |
|                                                                                                                                                                                     | Before In                             | truction              | 0x07<br>value of k8                | 3                                       |                   |                                                                                                           |                      |                  |                    |  |  |  |

| SUBWF             | Subtract                                                                   | W from f                     |                                   |                      |  |  |  |  |  |  |  |  |
|-------------------|----------------------------------------------------------------------------|------------------------------|-----------------------------------|----------------------|--|--|--|--|--|--|--|--|
| Syntax:           | [ label ]                                                                  | SUBWF                        | f,d                               |                      |  |  |  |  |  |  |  |  |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$ | ,                            |                                   |                      |  |  |  |  |  |  |  |  |
| Operation:        | (f) - (W) $\rightarrow$                                                    | (destina                     | tion)                             |                      |  |  |  |  |  |  |  |  |
| Status Affected:  | C, DC, Z                                                                   |                              |                                   |                      |  |  |  |  |  |  |  |  |
| Encoding:         | 00                                                                         | 0010                         | dfff                              | ffff                 |  |  |  |  |  |  |  |  |
| Description:      | Subtract (2'<br>ister from re<br>stored in the<br>result is sto            | egister 'f'. l<br>e W regist | f 'd' is 0 the<br>er. If 'd' is 1 | result is the        |  |  |  |  |  |  |  |  |
| Words:            | 1                                                                          | 1                            |                                   |                      |  |  |  |  |  |  |  |  |
| Cycles:           | 1                                                                          | 1                            |                                   |                      |  |  |  |  |  |  |  |  |
| Q Cycle Activity: | Q1                                                                         | Q2                           | Q3                                | Q4                   |  |  |  |  |  |  |  |  |
|                   | Decode                                                                     | Read<br>register 'f'         | Process<br>data                   | Write to destination |  |  |  |  |  |  |  |  |
| Example 1:        | SUBWF                                                                      | reg1,1                       |                                   |                      |  |  |  |  |  |  |  |  |
|                   | Before Ins                                                                 | truction                     |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 3                                 |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>?                            |                      |  |  |  |  |  |  |  |  |
|                   | Z                                                                          | =                            | ?                                 |                      |  |  |  |  |  |  |  |  |
|                   | After Instru                                                               | uction                       |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 1                                 |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>1; result is positive        |                      |  |  |  |  |  |  |  |  |
|                   | z                                                                          | =                            | 0                                 | poolavo              |  |  |  |  |  |  |  |  |
| Example 2:        | Before Ins                                                                 | truction                     |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 2                                 |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>?                            |                      |  |  |  |  |  |  |  |  |
|                   | Z                                                                          | =                            | ?                                 |                      |  |  |  |  |  |  |  |  |
|                   | After Instru                                                               | uction                       |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 0                                 |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>1; result is                 | 7010                 |  |  |  |  |  |  |  |  |
|                   | z                                                                          | =                            | 1                                 | 2010                 |  |  |  |  |  |  |  |  |
| Example 3:        | Before Ins                                                                 | truction                     |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 1                                 |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>?                            |                      |  |  |  |  |  |  |  |  |
|                   | z                                                                          | =                            | ?                                 |                      |  |  |  |  |  |  |  |  |
|                   | After Instru                                                               | uction                       |                                   |                      |  |  |  |  |  |  |  |  |
|                   | REG1                                                                       | =                            | 0xFF                              |                      |  |  |  |  |  |  |  |  |
|                   | W<br>C                                                                     | =                            | 2<br>0; result is                 | negative             |  |  |  |  |  |  |  |  |
|                   | z                                                                          | =                            | 0                                 | guivo                |  |  |  |  |  |  |  |  |
|                   |                                                                            |                              |                                   |                      |  |  |  |  |  |  |  |  |

| SWAPF             | Swap Ni                                                                                                                                                               | bbles in                               | f               |                      |  |  |  |  |  |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------|----------------------|--|--|--|--|--|--|
| Syntax:           | [label]                                                                                                                                                               | SWAPF 1                                | ,d              |                      |  |  |  |  |  |  |
| Operands:         | $0 \le f \le 12$<br>$d \in [0,1]$                                                                                                                                     | 27                                     |                 |                      |  |  |  |  |  |  |
| Operation:        | · · ·                                                                                                                                                                 | ightarrow (destin $ ightarrow$ (destin |                 |                      |  |  |  |  |  |  |
| Status Affected:  | None                                                                                                                                                                  |                                        |                 |                      |  |  |  |  |  |  |
| Encoding:         | 0 0                                                                                                                                                                   | 00 1110 dfff f                         |                 |                      |  |  |  |  |  |  |
| Description:      | The upper and lower nibbles of register<br>'f' are exchanged. If 'd' is 0 the result is<br>placed in W register. If 'd' is 1 the result<br>is placed in register 'f'. |                                        |                 |                      |  |  |  |  |  |  |
| Words:            | 1                                                                                                                                                                     |                                        |                 |                      |  |  |  |  |  |  |
| Cycles:           | 1                                                                                                                                                                     |                                        |                 |                      |  |  |  |  |  |  |
| Q Cycle Activity: | Q1                                                                                                                                                                    | Q2                                     | Q3              | Q4                   |  |  |  |  |  |  |
|                   | Decode                                                                                                                                                                | Read<br>register 'f'                   | Process<br>data | Write to destination |  |  |  |  |  |  |
| Example           | SWAPF                                                                                                                                                                 | REG,                                   | 0               |                      |  |  |  |  |  |  |
|                   | Before In                                                                                                                                                             | struction                              |                 |                      |  |  |  |  |  |  |
|                   |                                                                                                                                                                       | REG1                                   | = 0x/           | A5                   |  |  |  |  |  |  |
|                   | After Inst                                                                                                                                                            | truction                               |                 |                      |  |  |  |  |  |  |
|                   |                                                                                                                                                                       | REG1<br>W                              | 0,0,10          |                      |  |  |  |  |  |  |

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

| <b>Applicable Devices</b> | 61 | 60 | 601 | Deg | 60 | Dec | 61 | 611 | DGA | 65 | 65A | Dee | 66 | 67 |
|---------------------------|----|----|-----|-----|----|-----|----|-----|-----|----|-----|-----|----|----|
| Applicable Devices        | 01 | 02 | 02A | n02 | 03 | n03 | 04 | 04A | n04 | 05 | 05A | H00 | 00 | 07 |

|       |                                    | Standard Operating Conditions (unless otherwise stated) |            |       |                                                |          |                                                     |  |
|-------|------------------------------------|---------------------------------------------------------|------------|-------|------------------------------------------------|----------|-----------------------------------------------------|--|
|       |                                    | Operatir                                                | ng temper  | ature | -40°C                                          | ≤ TA     | $\Delta \leq +125^{\circ}C$ for extended,           |  |
|       | RACTERISTICS                       |                                                         |            |       | -40°C $\leq$ TA $\leq$ +85°C for industrial an |          |                                                     |  |
|       | ARACIERISTICS                      |                                                         |            |       | 0°C                                            | ≤ TA     | $\Delta \leq +70^{\circ}$ C for commercial          |  |
|       |                                    | Operatir                                                | ng voltage | VDD r | ange as c                                      | describe | ed in DC spec Section 15.1 and                      |  |
|       |                                    | Section                                                 | 15.2.      |       |                                                |          |                                                     |  |
| Param | Characteristic                     | Sym                                                     | Min        | Typ†  | Max                                            | Units    | Conditions                                          |  |
| No.   |                                    |                                                         |            |       |                                                |          |                                                     |  |
|       | Output High Voltage                |                                                         |            |       |                                                |          |                                                     |  |
| D090  | I/O ports (Note 3)                 | Voh                                                     | VDD-0.7    | -     | -                                              | v        | Iон = -3.0 mA,                                      |  |
|       |                                    |                                                         |            |       |                                                |          | $VDD = 4.5V, -40^{\circ}C \text{ to } +85^{\circ}C$ |  |
| D090A |                                    |                                                         | VDD-0.7    | -     | -                                              | v        | IOH = -2.5 mA,                                      |  |
|       |                                    |                                                         |            |       |                                                |          | VDD = 4.5V, -40°C to +125°C                         |  |
| D092  | OSC2/CLKOUT (RC osc config)        |                                                         | VDD-0.7    | -     | -                                              | V        | IOH = -1.3 mA,                                      |  |
|       |                                    |                                                         |            |       |                                                |          | VDD = 4.5V, -40°C to +85°C                          |  |
| D092A |                                    |                                                         | VDD-0.7    | -     | -                                              | V        | IOH = -1.0 mA,                                      |  |
|       |                                    |                                                         |            |       |                                                |          | VDD = 4.5V, -40°C to +125°C                         |  |
| D150* | Open-Drain High Voltage            | Vod                                                     | -          | -     | 14                                             | V        | RA4 pin                                             |  |
|       | Capacitive Loading Specs on        |                                                         |            |       |                                                |          |                                                     |  |
|       | Output Pins                        |                                                         |            |       |                                                |          |                                                     |  |
| D100  | OSC2 pin                           | Cosc2                                                   |            |       | 15                                             | pF       | In XT, HS and LP modes when                         |  |
|       |                                    |                                                         |            |       |                                                |          | external clock is used to drive                     |  |
|       |                                    |                                                         |            |       |                                                |          | OSC1.                                               |  |
| D101  | All I/O pins and OSC2 (in RC mode) | Cio                                                     |            |       | 50                                             | pF       |                                                     |  |

The parameters are characterized but not tested.

\*

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

Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended that the PIC16C6X be driven with external clock in RC mode.

 The leakage current on the MCLR/VPP pin is strongly dependent on the 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 current sourced by the pin.

Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67



# FIGURE 17-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER TIMING

# TABLE 17-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP TIMER REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                                   | Min | Тур†     | Max | Units | Conditions               |
|------------------|-------|--------------------------------------------------|-----|----------|-----|-------|--------------------------|
| 30*              | TmcL  | MCLR Pulse Width (low)                           | 100 | —        | —   | ns    | VDD = 5V, -40°C to +85°C |
| 31*              | Twdt  | Watchdog Timer Time-out Period<br>(No Prescaler) | 7   | 18       | 33  | ms    | VDD = 5V, -40°C to +85°C |
| 32               | Tost  | Oscillation Start-up Timer Period                | -   | 1024Tosc | _   | -     | TOSC = OSC1 period       |
| 33*              | Tpwrt | Power-up Timer Period                            | 28  | 72       | 132 | ms    | VDD = 5V, -40°C to +85°C |
| 34*              | Tioz  | I/O Hi-impedance from MCLR Low                   |     | _        | 100 | ns    |                          |

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.

Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

### FIGURE 17-7: PARALLEL SLAVE PORT TIMING (PIC16C64)



### TABLE 17-7: PARALLEL SLAVE PORT REQUIREMENTS (PIC16C64)

| Parameter<br>No. | Sym      | Characteristic                                                              |                    | Min | Тур† | Max | Units | Conditions |
|------------------|----------|-----------------------------------------------------------------------------|--------------------|-----|------|-----|-------|------------|
| 62               | TdtV2wrH | Data in valid before $\overline{WR}^{\uparrow}$ or $\overline{CS}$          | ↑ (setup time)     | 20  | Ι    | —   | ns    |            |
| 63*              | TwrH2dtl | $\overline{WR}^{\uparrow}$ or $\overline{CS}^{\uparrow}$ to data–in invalid | PIC16 <b>C</b> 64  | 20  | _    | —   | ns    |            |
|                  |          | (hold time)                                                                 | PIC16 <b>LC</b> 64 | 35  | I    | —   | ns    |            |
| 64               | TrdL2dtV | $\overline{RD}\downarrow$ and $\overline{CS}\downarrow$ to data–out valid   |                    | —   | I    | 80  | ns    |            |
| 65               | TrdH2dtl | $\overline{RD}\uparrow$ or $\overline{CS}\uparrow$ to data–out invalid      |                    | 10  |      | 30  | ns    |            |

\* 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. Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

## 18.0 ELECTRICAL CHARACTERISTICS FOR PIC16C62A/R62/64A/R64

### Absolute Maximum Ratings †

| Ambient temperature under bias                                                                       | 55°C to +125°C                                                    |
|------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| Storage temperature                                                                                  | 65°C to +150°C                                                    |
| Voltage on any pin with respect to Vss (except VDD, MCLR, and RA4)                                   | 0.3V to (VDD + 0.3V)                                              |
| Voltage on VDD with respect to VSS                                                                   | -0.3V to +7.5V                                                    |
| Voltage on MCLR with respect to Vss (Note 2)                                                         | 0V to +14V                                                        |
| Voltage on RA4 with respect to Vss                                                                   | 0V to +14V                                                        |
| Total power dissipation (Note 1)                                                                     | 1.0W                                                              |
| Maximum current out of VSS pin                                                                       |                                                                   |
| Maximum current into VDD pin                                                                         | 250 mA                                                            |
| Input clamp current, Iк (VI < 0 or VI > VDD)                                                         | ±20 mA                                                            |
| Output clamp current, loк (Vo < 0 or Vo > VDD)                                                       | ±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, PORTB, and PORTE (combined)                                           | 200 mA                                                            |
| Maximum current sourced by PORTA, PORTB, and PORTE (combined)                                        | 200 mA                                                            |
| Maximum current sunk by PORTC and PORTD (combined)                                                   | 200 mA                                                            |
| Maximum current sourced by PORTC and PORTD (combined)                                                | 200 mA                                                            |
| Note 1: Power dissipation is calculated as follows: $Pdis = Vop \times (Iop - \sum Iou) + \sum (Vop$ | $V(\alpha u) \times I(\alpha u) + \Sigma(V(\alpha v (\alpha u)))$ |

**Note 1:** Power dissipation is calculated as follows: Pdis = VDD x {IDD -  $\sum$  IOH} +  $\sum$  {(VDD-VOH) x IOH} +  $\sum$ (VOI x IOL)

Note 2: Voltage spikes below Vss at the MCLR pin, inducing currents greater than 80 mA, may cause latch-up. 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.

### TABLE 18-1: CROSS REFERENCE OF DEVICE SPECS FOR OSCILLATOR CONFIGURATIONS AND FREQUENCIES OF OPERATION (COMMERCIAL DEVICES)

| osc | PIC16C62A-04<br>PIC16CR62-04<br>PIC16C64A-04<br>PIC16CR64-04                                                | PIC16C62A-10<br>PIC16CR62-10<br>PIC16C64A-10<br>PIC16CR64-10                                | PIC16C62A-20<br>PIC16CR62-20<br>PIC16C64A-20<br>PIC16CR64-20                                  | PIC16LC62A-04<br>PIC16LCR62-04<br>PIC16LC64A-04<br>PIC16LCR64-04                                        | JW Devices                                                                                              |
|-----|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| RC  | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq:4 MHz max.                     | VDD: 4.5V to 5.5V<br>IDD: 2.0 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.0 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max.   | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 5 μA max. at 3V<br>Freq: 4 MHz max.               | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq:4 MHz max.                 |
| ХТ  | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                    | VDD: 4.5V to 5.5V<br>IDD: 2.0 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max. | VDD: 4.5V to 5.5V<br>IDD: 2.0 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4V<br>Freq: 4 MHz max.   | VDD: 2.5V to 6.0V<br>IDD: 3.8 mA max. at 3.0V<br>IPD: 5 µA max. at 3.0V<br>Freq: 4 MHz max.             | VDD: 4.0V to 6.0V<br>IDD: 5 mA max. at 5.5V<br>IPD: 16 μA max. at 4V<br>Freq: 4 MHz max.                |
| HS  | VpD: 4.5V to 5.5V<br>IDD: 13.5 mA typ. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 4 MHz max.              |                                                                                             | VDD: 4.5V to 5.5V<br>IDD: 20 mA max. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 20 MHz max. | Not recommended for use<br>in HS mode                                                                   | VDD: 4.5V to 5.5V<br>IDD: 20 mA max. at 5.5V<br>IPD: 1.5 μA typ. at 4.5V<br>Freq: 20 MHz max.           |
| LP  | VDD: 4.0V to 6.0V<br>IDD: 52.5 μA typ.<br>at 32 kHz, 4.0V<br>IPD: 0.9 μA typ. at 4.0V<br>Freq: 200 kHz max. | Not recommended for use in LP mode                                                          | Not recommended for use in LP mode                                                            | VDD: 2.5V to 6.0V<br>IDD: 48 μA max. at 32<br>kHz, 3.0V<br>IPD: 5 μA max. at 3.0V<br>Freq: 200 kHz max. | VDD: 2.5V to 6.0V<br>IDD: 48 μA max.<br>at 32 kHz, 3.0V<br>IPD: 5 μA max. at 3.0V<br>Freq: 200 kHz max. |

The shaded sections indicate oscillator selections which are tested for functionality, but not for MIN/MAX specifications. It is recommended that the user select the device type that ensures the specifications required.

<sup>© 1997-2013</sup> Microchip Technology Inc.

### Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67





### TABLE 18-10: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Parameter<br>No. | Sym     | Characteristic         |              | Min        | Max  | Units | Conditions                                       |
|------------------|---------|------------------------|--------------|------------|------|-------|--------------------------------------------------|
| 100*             | Тнідн   | Clock high time        | 100 kHz mode | 4.0        | -    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 0.6        | _    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5TCY     | _    |       |                                                  |
| 101*             | TLOW    | Clock low time         | 100 kHz mode | 4.7        | _    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 1.3        | _    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5TCY     | —    |       |                                                  |
| 102*             | TR      | SDA and SCL rise       | 100 kHz mode | —          | 1000 | ns    |                                                  |
|                  |         | time                   | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 103*             | TF      | SDA and SCL fall time  | 100 kHz mode | _          | 300  | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 90*              | TSU:STA | START condition        | 100 kHz mode | 4.7        | —    | μs    | Only relevant for repeated                       |
|                  |         | setup time             | 400 kHz mode | 0.6        | —    | μs    | START condition                                  |
| 91*              | THD:STA | START condition hold   | 100 kHz mode | 4.0        | —    | μs    | After this period the first clock                |
|                  |         | time                   | 400 kHz mode | 0.6        | _    | μs    | pulse is generated                               |
| 106*             | THD:DAT | Data input hold time   | 100 kHz mode | 0          | _    | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 0          | 0.9  | μs    |                                                  |
| 107*             | TSU:DAT | Data input setup time  | 100 kHz mode | 250        | —    | ns    | Note 2                                           |
|                  |         |                        | 400 kHz mode | 100        | —    | ns    |                                                  |
| 92*              | TSU:STO | STOP condition setup   | 100 kHz mode | 4.7        | —    | μs    |                                                  |
|                  |         | time                   | 400 kHz mode | 0.6        | —    | μs    |                                                  |
| 109*             | ΤΑΑ     | Output valid from      | 100 kHz mode | —          | 3500 | ns    | Note 1                                           |
|                  |         | clock                  | 400 kHz mode | —          | —    | ns    |                                                  |
| 110*             | TBUF    | Bus free time          | 100 kHz mode | 4.7        | —    | μs    | Time the bus must be free                        |
|                  |         |                        | 400 kHz mode | 1.3        | _    | μs    | before a new transmission can start              |
|                  | Cb      | Bus capacitive loading |              | —          | 400  | pF    |                                                  |

\* These parameters are characterized but not tested.

Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

2: A fast-mode (400 kHz) I<sup>2</sup>C-bus device can be used in a standard-mode (100 kHz) I<sup>2</sup>C-bus system, but the requirement tsu;DAT ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line TR max.+tsu;DAT = 1000 + 250 = 1250 ns (according to the standard-mode I<sup>2</sup>C bus specification) before the SCL line is released.

Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

NOTES:

Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

### FIGURE 20-6: TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS



### TABLE 20-5: TIMER0 AND TIMER1 EXTERNAL CLOCK REQUIREMENTS

| Param<br>No. | Sym       | Characteristic                                 |                                                |                    | Min                                              | Тур† | Мах   | Units | Conditions                         |
|--------------|-----------|------------------------------------------------|------------------------------------------------|--------------------|--------------------------------------------------|------|-------|-------|------------------------------------|
| 40*          | Tt0H      | T0CKI High Pulse V                             | Vidth                                          | No Prescaler       | 0.5TCY + 20                                      | -    | —     | ns    | Must also meet                     |
|              |           |                                                | M                                              |                    | 10                                               | -    | —     | ns    | parameter 42                       |
| 41*          | Tt0L      | T0CKI Low Pulse W                              | /idth                                          | No Prescaler       | 0.5TCY + 20                                      | —    | _     | ns    | Must also meet                     |
|              |           |                                                |                                                | With Prescaler     | 10                                               | —    | —     | ns    | parameter 42                       |
| 42*          | Tt0P      | T0CKI Period                                   |                                                | No Prescaler       | TCY + 40                                         | -    | —     | ns    |                                    |
|              |           |                                                |                                                | With Prescaler     | Greater of:<br>20 or <u>Tcy + 40</u><br>N        | -    | _     | ns    | N = prescale value<br>(2, 4,, 256) |
| 45*          | Tt1H      | T1CKI High Time                                | Synchronous, F                                 | Prescaler = 1      | 0.5TCY + 20                                      | -    | _     | ns    | Must also meet                     |
|              |           |                                                | Synchronous,                                   | PIC16 <b>C</b> 6X  | 15                                               | -    | —     | ns    | parameter 47                       |
|              |           |                                                | Prescaler = 2,4,8                              | PIC16 <b>LC</b> 6X | 25                                               | -    | -     | ns    |                                    |
|              |           |                                                | Asynchronous                                   | PIC16 <b>C</b> 6X  | 30                                               | —    | —     | ns    |                                    |
|              |           |                                                |                                                | PIC16 <b>LC</b> 6X | 50                                               | -    | _     | ns    |                                    |
| 46*          | Tt1L      | T1CKI Low Time                                 | Synchronous, F                                 |                    | 0.5TCY + 20                                      | —    | —     | ns    | Must also meet                     |
|              |           |                                                | Synchronous,                                   | PIC16 <b>C</b> 6X  | 15                                               | —    | —     | ns    | parameter 47                       |
|              |           |                                                | Prescaler = 2,4,8                              | PIC16 <b>LC</b> 6X | 25                                               | -    | -     | ns    |                                    |
|              |           |                                                | Asynchronous                                   | PIC16 <b>C</b> 6X  | 30                                               | —    | —     | ns    |                                    |
|              |           |                                                |                                                | PIC16 <b>LC</b> 6X | 50                                               | —    | —     | ns    |                                    |
| 47*          | Tt1P      | T1CKI input period                             | Synchronous                                    | PIC16 <b>C</b> 6X  | <u>Greater of:</u><br>30 OR <u>TCY + 40</u><br>N | -    | _     | ns    | N = prescale value<br>(1, 2, 4, 8) |
|              |           |                                                |                                                | PIC16 <b>LC</b> 6X | <u>Greater of:</u><br>50 OR <u>TCY + 40</u><br>N |      |       |       | N = prescale value<br>(1, 2, 4, 8) |
|              |           |                                                | Asynchronous                                   | PIC16 <b>C</b> 6X  | 60                                               | —    | —     | ns    |                                    |
|              |           |                                                |                                                | PIC16 <b>LC</b> 6X | 100                                              | -    | —     | ns    |                                    |
|              | Ft1       | Timer1 oscillator inp<br>(oscillator enabled b | but frequency range<br>by setting bit T1OSCEN) |                    | DC                                               | -    | 200   | kHz   |                                    |
| 48           | TCKEZtmr1 | Delay from external                            | clock edge to tir                              | ner increment      | 2Tosc                                            | —    | 7Tosc | _     |                                    |

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.

### Applicable Devices 61 62 62A R62 63 R63 64 64A R64 65 65A R65 66 67

## FIGURE 20-11: I<sup>2</sup>C BUS DATA TIMING



### TABLE 20-10: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Parameter<br>No. | Sym     | Characteristic         |              | Min        | Max  | Units | Conditions                                       |
|------------------|---------|------------------------|--------------|------------|------|-------|--------------------------------------------------|
| 100*             | Тнідн   | Clock high time        | 100 kHz mode | 4.0        | —    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 0.6        | _    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5TCY     |      |       |                                                  |
| 101*             | TLOW    | Clock low time         | 100 kHz mode | 4.7        | —    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 1.3        | —    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5TCY     |      |       |                                                  |
| 102*             | TR      | SDA and SCL rise       | 100 kHz mode | —          | 1000 | ns    |                                                  |
|                  |         | time                   | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 103*             | TF      | SDA and SCL fall time  | 100 kHz mode | _          | 300  | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from 10-400 pF             |
| 90*              | TSU:STA | START condition        | 100 kHz mode | 4.7        | —    | μs    | Only relevant for repeated                       |
|                  |         | setup time             | 400 kHz mode | 0.6        | _    | μs    | START condition                                  |
| 91*              | THD:STA | START condition hold   | 100 kHz mode | 4.0        |      | μs    | After this period the first clock                |
|                  |         | time                   | 400 kHz mode | 0.6        |      | μs    | pulse is generated                               |
| 106*             | THD:DAT | Data input hold time   | 100 kHz mode | 0          |      | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 0          | 0.9  | μs    |                                                  |
| 107*             | TSU:DAT | Data input setup time  | 100 kHz mode | 250        |      | ns    | Note 2                                           |
|                  |         |                        | 400 kHz mode | 100        |      | ns    |                                                  |
| 92*              | TSU:STO | STOP condition setup   | 100 kHz mode | 4.7        |      | μS    |                                                  |
|                  |         | time                   | 400 kHz mode | 0.6        |      | μS    |                                                  |
| 109*             | TAA     | Output valid from      | 100 kHz mode | _          | 3500 | ns    | Note 1                                           |
|                  |         | clock                  | 400 kHz mode | _          |      | ns    |                                                  |
| 110*             | TBUF    | Bus free time          | 100 kHz mode | 4.7        | _    | μs    | Time the bus must be free                        |
|                  |         |                        | 400 kHz mode | 1.3        | —    | μs    | before a new transmission can start              |
|                  | Cb      | Bus capacitive loading |              | _          | 400  | pF    |                                                  |

These parameters are characterized but not tested.

Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

2: A fast-mode (400 kHz) I<sup>2</sup>C-bus device can be used in a standard-mode (100 kHz) I<sup>2</sup>C-bus system, but the requirement Tsu:DAT ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line TR max.+tsu;DAT = 1000 + 250 = 1250 ns (according to the standard-mode I<sup>2</sup>C bus specification) before the SCL line is released.

## 24.14 Package Marking Information



| Legend: | MMM                                                                                                                                                                                                          | Microchip part number information                                                                                         |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|--|
|         | XXX                                                                                                                                                                                                          | Customer specific information*                                                                                            |  |  |
|         | AA                                                                                                                                                                                                           | Year code (last 2 digits of calender year)                                                                                |  |  |
|         | BB                                                                                                                                                                                                           | Week code (week of January 1 is week '01')                                                                                |  |  |
|         | С                                                                                                                                                                                                            | Facility code of the plant at which wafer is manufactured.<br>C = Chandler, Arizona, U.S.A.<br>S = Tempe, Arizona, U.S.A. |  |  |
|         | D <sub>1</sub>                                                                                                                                                                                               | Mask revision number for microcontroller                                                                                  |  |  |
|         | D <sub>2</sub>                                                                                                                                                                                               | Mask revision number for EEPROM                                                                                           |  |  |
|         | E                                                                                                                                                                                                            | Assembly code of the plant or country of origin in which<br>part was assembled.                                           |  |  |
| Note:   | In the event the full Microchip part number cannot be marked on one<br>line, it will be carried over to the next line thus limiting the number of<br>available characters for customer specific information. |                                                                                                                           |  |  |

\* Standard OTP marking consists of Microchip part number, year code, week code, facility code, mask revision number, and assembly code. For OTP 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.

-

### Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
  mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, KEELoo, KEELoo logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MTP, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

Analog-for-the-Digital Age, Application Maestro, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, SQI, Serial Quad I/O, Total Endurance, TSHARC, UniWinDriver, WiperLock, ZENA and Z-Scale are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

GestIC and ULPP are registered trademarks of Microchip Technology Germany II GmbH & Co. & KG, a subsidiary of Microchip Technology Inc., in other countries.

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

© 1997-2013, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

ISBN: 9781620769652

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOG® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.