



Welcome to E-XFL.COM

# What is "Embedded - Microcontrollers"?

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

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

# Details

| Product Status             | Obsolete                                                                   |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 4MHz                                                                       |
| Connectivity               | I²C, SPI, UART/USART                                                       |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 33                                                                         |
| Program Memory Size        | 14KB (8K x 14)                                                             |
| Program Memory Type        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 368 × 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V                                                                  |
| Data Converters            | -                                                                          |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 44-TQFP                                                                    |
| Supplier Device Package    | 44-TQFP (10x10)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc67t-04-pt |
|                            |                                                                            |

Email: info@E-XFL.COM

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



FIGURE 3-2: PIC16C62/62A/R62/64/64A/R64 BLOCK DIAGRAM

NOTES:

-

# 5.0 I/O PORTS

# Applicable Devices

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

Some pins for these I/O ports are multiplexed with an alternate function(s) for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

# 5.1 PORTA and TRISA Register

# Applicable Devices

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

All devices have a 6-bit wide PORTA, except for the PIC16C61 which has a 5-bit wide PORTA.

Pin RA4/T0CKI is a Schmitt Trigger input and an open drain output. All other RA port pins have TTL input levels and full CMOS output drivers. All pins have data direction bits (TRIS registers) which can configure these pins as output or input.

Setting a bit in the TRISA register puts the corresponding output driver in a hi-impedance mode. Clearing a bit in the TRISA register puts the contents of the output latch on the selected pin.

Reading PORTA register reads the status of the pins whereas writing to it will write to the port latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified, and then written to the port data latch.

Pin RA4 is multiplexed with Timer0 module clock input to become the RA4/T0CKI pin.

# EXAMPLE 5-1: INITIALIZING PORTA

| BCF   | STATUS, | RP0 | ; |                       |
|-------|---------|-----|---|-----------------------|
| BCF   | STATUS, | RP1 | ; | PIC16C66/67 only      |
| CLRF  | PORTA   |     | ; | Initialize PORTA by   |
|       |         |     | ; | clearing output       |
|       |         |     | ; | data latches          |
| BSF   | STATUS, | RP0 | ; | Select Bank 1         |
| MOVLW | 0xCF    |     | ; | Value used to         |
|       |         |     | ; | initialize data       |
|       |         |     | ; | direction             |
| MOVWF | TRISA   |     | ; | Set RA<3:0> as inputs |
|       |         |     | ; | RA<5:4> as outputs    |
|       |         |     | ; | TRISA<7:6> are always |
|       |         |     | ; | read as '0'.          |

### FIGURE 5-1: BLOCK DIAGRAM OF THE RA3:RA0 PINS AND THE RA5 PIN



# FIGURE 5-2: BLOCK DIAGRAM OF THE RA4/T0CKI PIN



# 5.7 Parallel Slave Port

### Applicable Devices

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

PORTD operates as an 8-bit wide parallel slave port (microprocessor port) when control bit PSPMODE (TRISE<4>) is set. In slave mode it is asynchronously readable and writable by the external world through  $\overline{\text{RD}}$  control input (RE0/ $\overline{\text{RD}}$ ) and  $\overline{\text{WR}}$  control input pin (RE1/ $\overline{\text{WR}}$ ).

It can directly interface to an 8-bit microprocessor data bus. The external microprocessor can read or write the PORTD latch as an 8-bit latch. Setting PSPMODE enables port pin RE0/RD to be the RD input, RE1/WR to be the WR input and RE2/CS to be the CS (chip select) input. For this functionality, the corresponding data direction bits of the TRISE register (TRISE<2:0>) must be configured as inputs (set).

There are actually two 8-bit latches, one for data-out (from the PIC16/17) and one for data input. The user writes 8-bit data to PORTD data latch and reads data from the port pin latch (note that they have the same address). In this mode, the TRISD register is ignored since the microprocessor is controlling the direction of data flow.

A write to the PSP occurs when both the  $\overline{CS}$  and  $\overline{WR}$  lines are first detected low. When either the  $\overline{CS}$  or  $\overline{WR}$  lines become high (level triggered), then the Input Buffer Full status flag bit IBF (TRISE<7>) is set on the Q4 clock cycle, following the next Q2 cycle, to signal the write is complete (Figure 5-12). The interrupt flag bit PSPIF (PIR1<7>) is also set on the same Q4 clock cycle. IBF can only be cleared by reading the PORTD input latch. The input Buffer Overflow status flag bit IBOV (TRISE<5>) is set if a second write to the Parallel Slave Port is attempted when the previous byte has not been read out of the buffer.

A read from the PSP occurs when both the  $\overline{CS}$  and  $\overline{RD}$  lines are first detected low. The Output Buffer Full status flag bit OBF (TRISE<6>) is cleared immediately (Figure 5-13) indicating that the PORTD latch is waiting to be read by the external bus. When either the  $\overline{CS}$  or  $\overline{RD}$  pin becomes high (level triggered), the interrupt flag bit PSPIF is set on the Q4 clock cycle, following the next Q2 cycle, indicating that the read is complete. OBF remains low until data is written to PORTD by the user firmware.

When not in Parallel Slave Port mode, the IBF and OBF bits are held clear. However, if flag bit IBOV was previously set, it must be cleared in firmware.

An interrupt is generated and latched into flag bit PSPIF when a read or write operation is completed. PSPIF must be cleared by the user in firmware and the interrupt can be disabled by clearing the interrupt enable bit PSPIE (PIE1<7>).

# FIGURE 5-11: PORTD AND PORTE AS A PARALLEL SLAVE PORT





### TIMER0 TIMING: INTERNAL CLOCK/PRESCALE 1:2 FIGURE 7-3:

### FIGURE 7-4: **TMR0 INTERRUPT TIMING**



| Addr                 | 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 |
|----------------------|---------|----------------------|---------------|---------------------|---------------------|---------|--------|---------|---------|--------------------------|---------------------------------|
| 0Bh,8Bh<br>10Bh,18Bh | INTCON  | GIE                  | PEIE          | TOIE                | INTE                | RBIE    | TOIF   | INTF    | RBIF    | 0000<br>000x             | 0000<br>000u                    |
| 0Ch                  | PIR1    | PSPIF <sup>(2)</sup> | (3)           | RCIF <sup>(1)</sup> | TXIF <sup>(1)</sup> | SSPIF   | CCP1IF | TMR2IF  | TMR1IF  | 0000                     | 0000                            |
| 0Dh <sup>(4)</sup>   | PIR2    | —                    | _             | _                   | _                   | _       | _      | _       | CCP2IF  |                          | <br>0                           |
| 8Ch                  | PIE1    | PSPIE <sup>(2)</sup> | (3)           | RCIE <sup>(1)</sup> | TXIE <sup>(1)</sup> | SSPIE   | CCP1IE | TMR2IE  | TMR1IE  | 0000                     | 0000                            |
| 8Dh <sup>(4)</sup>   | PIE2    | —                    | _             | -                   | _                   | -       | _      | -       | CCP2IE  |                          | <br>0                           |
| 87h                  | TRISC   | PORTC [              | Data Directio | on register         |                     |         |        |         |         | 1111<br>1111             | 1111<br>1111                    |
| 11h                  | TMR2    | Timer2 m             | iodule's regi | ster                |                     |         |        |         |         | 0000                     | 0000                            |
| 92h                  | PR2     | Timer2 m             | iodule's Per  | iod register        |                     |         |        |         |         | 1111<br>1111             | 1111<br>1111                    |
| 12h                  | T2CON   | —                    | TOUTPS3       | TOUTPS2             | TOUTPS1             | TOUTPS0 | TMR2ON | T2CKPS1 | T2CKPS0 | -000<br>0000             | -000<br>0000                    |
| 15h                  | CCPR1L  | Capture/0            | Compare/P     | VM1 (LSB)           | 1                   |         |        |         |         | xxxx<br>xxxx             | uuuu<br>uuuu                    |
| 16h                  | CCPR1H  | Capture/0            | Compare/P     | VM1 (MSB            | )                   |         |        |         |         | xxxx<br>xxxx             | นนนน<br>นนนน                    |
| 17h                  | CCP1CON | —                    | —             | CCP1X               | CCP1Y               | CCP1M3  | CCP1M2 | CCP1M1  | CCP1M0  | 00<br>0000               | 00<br>0000                      |
| 1Bh <sup>(4)</sup>   | CCPR2L  | Capture/0            | Compare/P     | VM2 (LSB)           | 1                   |         | 1      |         |         | xxxx<br>xxxx             | นนนน<br>นนนน                    |
| 1Ch <sup>(4)</sup>   | CCPR2H  | Capture/0            | Compare/P\    | VM2 (MSB            | )                   |         |        |         |         | xxxx<br>xxxx             | นนนน<br>นนนน                    |
| 1Dh <sup>(4)</sup>   | CCP2CON | -                    | —             | CCP2X               | CCP2Y               | CCP2M3  | CCP2M2 | CCP2M1  | CCP2M0  | 00<br>0000               | 00<br>0000                      |

# TABLE 10-5: REGISTERS ASSOCIATED WITH PWM AND TIMER2

 Legend:
 x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used in this mode.

 Note
 1:
 These bits are associated with the USART module, which is implemented on the PIC16C63/R63/65/65A/R65/66/67 only.

2: Bits PSPIE and PSPIF are reserved on the PIC16C62/62A/R62/63/R63/66, always maintain these bits clear.

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

4: These registers are associated with the CCP2 module, which is only implemented on the PIC16C63/R63/65/65A/R65/66/67.

To enable the serial port, SSP enable bit SSPEN (SSPCON<5>) must be set. To reset or reconfigure SPI mode, clear enable bit SSPEN, re-initialize SSPCON register, and then set enable bit SSPEN. This configures the SDI, SDO, SCK, and  $\overline{SS}$  pins as serial port pins. For the pins to behave as the serial port function, they must have their data direction bits (in the TRIS register) appropriately programmed. That is:

- SDI must have TRISC<4> set
- SDO must have TRISC<5> cleared
- SCK (Master mode) must have TRISC<3> cleared
- SCK (Slave mode) must have TRISC<3> set
- SS must have TRISA<5> set (if implemented)

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. An example would be in master mode where you are only sending data (to a display driver), then both SDI and SS could be used as general purpose outputs by clearing their corresponding TRIS register bits.

Figure 11-4 shows a typical connection between two microcontrollers. The master controller (Processor 1) initiates the data transfer by sending the SCK signal. Data is shifted out of both shift registers on their programmed clock edge, and latched on the opposite edge of the clock. Both processors should be programmed to the same Clock Polarity (CKP), then both controllers would send and receive data at the same time. Whether the data is meaningful (or dummy data) depends on the application software. This leads to three scenarios for data transmission:

- Master sends data Slave sends dummy data
- Master sends data Slave sends data
- · Master sends dummy data Slave sends data



# FIGURE 11-4: SPI MASTER/SLAVE CONNECTION

The master can initiate the data transfer at any time because it controls the SCK. The master determines when the slave (Processor 2) is to broadcast data by the software protocol.

In master mode the data is transmitted/received as soon as the SSPBUF register is written to. If the SPI is only going to receive, the SCK output could be disabled (programmed as an input). The SSPSR register will continue to shift in the signal present on the SDI pin at the programmed clock rate. As each byte is received, it will be loaded into the SSPBUF register as if a normal received byte (interrupts and status bits appropriately set). This could be useful in receiver applications as a "line activity monitor" mode.

In slave mode, the data is transmitted and received as the external clock pulses appear on SCK. When the last bit is latched interrupt flag bit SSPIF (PIR1<3>) is set.

The clock polarity is selected by appropriately programming bit CKP (SSPCON<4>). This then would give waveforms for SPI communication as shown in Figure 11-5 and Figure 11-6 where the MSB is transmitted first. In master mode, the SPI clock rate (bit rate) is user programmable to be one of the following:

- Fosc/4 (or TCY)
- Fosc/16 (or 4 TCY)
- Fosc/64 (or 16 TCY)
- Timer2 output/2

This allows a maximum bit clock frequency (at 20 MHz) of 5 MHz. When in slave mode the external clock must meet the minimum high and low times.

In sleep mode, the slave can transmit and receive data and wake the device from sleep.

# 11.5 <u>SSP I<sup>2</sup>C Operation</u>

The SSP module in  $I^2C$  mode fully implements all slave functions, except general call support, and provides interrupts on start and stop bits in hardware to facilitate firmware implementations of the master functions. The SSP module implements the standard mode specifications as well as 7-bit and 10-bit addressing. Two pins are used for data transfer. These are the RC3/SCK/SCL pin, which is the clock (SCL), and the RC4/SDI/SDA pin, which is the data (SDA). The user must configure these pins as inputs or outputs through the TRISC<4:3> bits. The SSP module functions are enabled by setting SSP Enable bit SSPEN (SSP-CON<5>).

# FIGURE 11-24: SSP BLOCK DIAGRAM (I<sup>2</sup>C MODE)



The SSP module has five registers for  $I^2C$  operation. These are the:

- SSP Control Register (SSPCON)
- SSP Status Register (SSPSTAT)
- Serial Receive/Transmit Buffer (SSPBUF)
- SSP Shift Register (SSPSR) Not directly accessible
- SSP Address Register (SSPADD)

The SSPCON register allows control of the  $I^2C$  operation. Four mode selection bits (SSPCON<3:0>) allow one of the following  $I^2C$  modes to be selected:

- I<sup>2</sup>C Slave mode (7-bit address)
- I<sup>2</sup>C Slave mode (10-bit address)
- I<sup>2</sup>C Slave mode (7-bit address), with start and stop bit interrupts enabled
- I<sup>2</sup>C Slave mode (10-bit address), with start and stop bit interrupts enabled
- I<sup>2</sup>C Firmware controlled Master Mode, slave is idle

Selection of any  $I^2C$  mode, with the SSPEN bit set, forces the SCL and SDA pins to be open drain, provided these pins are programmed to inputs by setting the appropriate TRISC bits.

The SSPSTAT register gives the status of the data transfer. This information includes detection of a START or STOP bit, specifies if the received byte was data or address if the next byte is the completion of 10-bit address, and if this will be a read or write data transfer. The SSPSTAT register is read only.

The SSPBUF is the register to which transfer data is written to or read from. The SSPSR register shifts the data in or out of the device. In receive operations, the SSPBUF and SSPSR create a doubled buffered receiver. This allows reception of the next byte to begin before reading the last byte of received data. When the complete byte is received, it is transferred to the SSPBUF register and flag bit SSPIF is set. If another complete byte is received before the SSPBUF register is read, a receiver overflow has occurred and bit SSPOV (SSPCON<6>) is set and the byte in the SSPSR is lost.

The SSPADD register holds the slave address. In 10-bit mode, the user first needs to write the high byte of the address (1111 0 A9 A8 0). Following the high byte address match, the low byte of the address needs to be loaded (A7:A0).

# 11.5.1 SLAVE MODE

PIC16C6X

In slave mode, the SCL and SDA pins must be configured as inputs (TRISC<4:3> set). The SSP module will override the input state with the output data when required (slave-transmitter).

When an address is matched or the data transfer after an address match is received, the hardware automatically will generate the acknowledge ( $\overline{ACK}$ ) pulse, and then load the SSPBUF register with the received value currently in the SSPSR register.

There are certain conditions that will cause the SSP module not to give this ACK pulse. These are if either (or both):

- a) The buffer full bit BF (SSPSTAT<0>) was set before the transfer was received.
- b) The overflow bit SSPOV (SSPCON<6>) was set before the transfer was received.

In this case, the SSPSR register value is not loaded into the SSPBUF, but bit SSPIF (PIR1<3>) is set. Table 11-4 shows what happens when a data transfer byte is received, given the status of bits BF and SSPOV. The shaded cells show the condition where user software did not properly clear the overflow condition. Flag bit BF is cleared by reading the SSPBUF register while bit SSPOV is cleared through software.

The SCL clock input must have a minimum high and low for proper operation. The high and low times of the  $I^2C$  specification as well as the requirement of the SSP module is shown in timing parameter #100 and parameter #101.

### 11.5.1.1 ADDRESSING

Once the SSP module has been enabled, it waits for a START condition to occur. Following the START condition, the 8-bits are shifted into the SSPSR register. All incoming bits are sampled with the rising edge of the clock (SCL) line. The value of register SSPSR<7:1> is compared to the value of the SSPADD register. The

address is compared on the falling edge of the eighth clock (SCL) pulse. If the addresses match, and the BF and SSPOV bits are clear, the following events occur:

- a) The SSPSR register value is loaded into the SSPBUF register.
- b) The buffer full bit, BF is set.
- c) An ACK pulse is generated.
- d) SSP interrupt flag bit, SSPIF (PIR1<3>) is set (interrupt is generated if enabled) - on the falling edge of the ninth SCL pulse.

In 10-bit address mode, two address bytes need to be received by the slave (Figure 11-16). The five Most Significant bits (MSbs) of the first address byte specify if this is a 10-bit address. Bit  $R/\overline{W}$  (SSPSTAT-<2>) must specify a write so the slave device will receive the second address byte. For a 10-bit address the first byte would equal '1111 0 A9 A8 0', where A9 and A8 are the two MSbs of the address. The sequence of events for 10-bit address is as follows, with steps 7-9 for slave-transmitter:

- 1. Receive first (high) byte of Address (bits SSPIF, BF, and bit UA (SSPSTAT<1>) are set).
- Update the SSPADD register with second (low) byte of Address (clears bit UA and releases the SCL line).
- 3. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 4. Receive second (low) byte of Address (bits SSPIF, BF, and UA are set).
- Update the SSPADD register with the first (high) byte of Address, if match releases SCL line, this will clear bit UA.
- 6. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.
- 7. Receive repeated START condition.
- 8. Receive first (high) byte of Address (bits SSPIF and BF are set).
- 9. Read the SSPBUF register (clears bit BF) and clear flag bit SSPIF.

# TABLE 11-4: DATA TRANSFER RECEIVED BYTE ACTIONS

| Status Bits as Data<br>Transfer is Received |       |                    |                       | Set bit SSPIF                        |  |  |
|---------------------------------------------|-------|--------------------|-----------------------|--------------------------------------|--|--|
| BF                                          | SSPOV | $SSPSR \to SSPBUF$ | Generate ACK<br>Pulse | (SSP Interrupt occurs<br>if enabled) |  |  |
| 0                                           | 0     | Yes                | Yes                   | Yes                                  |  |  |
| 1                                           | 0     | No                 | No                    | Yes                                  |  |  |
| 1                                           | 1     | No                 | No                    | Yes                                  |  |  |
| 0                                           | 1     | No                 | No                    | Yes                                  |  |  |

# 13.5.1 INT INTERRUPT

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

### 13.5.2 TMR0 INTERRUPT

An overflow (FFh  $\rightarrow$  00h) in the TMR0 register will set flag bit T0IF (INTCON<2>). The interrupt can be enabled/disabled by setting/clearing enable bit T0IE (INTCON<5>) (Section 7.0).

### 13.5.3 PORTB INTERRUPT ON CHANGE

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

Note: For the PIC16C61/62/64/65, if a change on the I/O pin should occur when the read operation is being executed (start of the Q2 cycle), then flag bit RBIF may not get set.



# FIGURE 13-19: INT PIN INTERRUPT TIMING

| NOP               | No Operation       |                  |                  |                  |  |  |  |  |  |  |
|-------------------|--------------------|------------------|------------------|------------------|--|--|--|--|--|--|
| Syntax:           | [ label ]          | NOP              |                  |                  |  |  |  |  |  |  |
| Operands:         | None               |                  |                  |                  |  |  |  |  |  |  |
| Operation:        | No operation       |                  |                  |                  |  |  |  |  |  |  |
| Status Affected:  | None               |                  |                  |                  |  |  |  |  |  |  |
| Encoding:         | 000 0000 0xx0 0000 |                  |                  |                  |  |  |  |  |  |  |
| Description:      | No operat          | ion.             |                  |                  |  |  |  |  |  |  |
| Words:            | 1                  |                  |                  |                  |  |  |  |  |  |  |
| Cycles:           | 1                  |                  |                  |                  |  |  |  |  |  |  |
| Q Cycle Activity: | Q1                 | Q2               | Q3               | Q4               |  |  |  |  |  |  |
|                   | Decode             | No-<br>Operation | No-<br>Operation | No-<br>Operation |  |  |  |  |  |  |
| Example           | NOP                |                  |                  |                  |  |  |  |  |  |  |

| RETFIE                       | Return fi                                                                                                                     | rom Inter                     | rupt                                         |                       |  |  |  |  |  |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------------------------------------|-----------------------|--|--|--|--|--|
| Syntax:                      | [ label ]                                                                                                                     | RETFIE                        |                                              |                       |  |  |  |  |  |
| Operands:                    | None                                                                                                                          |                               |                                              |                       |  |  |  |  |  |
| Operation:                   | $\begin{array}{l} TOS \to PC, \\ 1 \to GIE \end{array}$                                                                       |                               |                                              |                       |  |  |  |  |  |
| Status Affected:             | None                                                                                                                          |                               |                                              |                       |  |  |  |  |  |
| Encoding:                    | 00                                                                                                                            | 0000                          | 0000                                         | 1001                  |  |  |  |  |  |
|                              | PC. Interrupts are enabled by setting<br>Global Interrupt Enable bit, GIE<br>(INTCON<7>). This is a two cycle<br>instruction. |                               |                                              |                       |  |  |  |  |  |
|                              | Global Inte<br>(INTCON<                                                                                                       | ,<br>errupt Ena<br><7>). This | ble bit, ĠIE                                 | Ē                     |  |  |  |  |  |
| Words:                       | Global Inte<br>(INTCON<                                                                                                       | ,<br>errupt Ena<br><7>). This | ble bit, ĠIE                                 | Ē                     |  |  |  |  |  |
| Words:<br>Cycles:            | Global Inte<br>(INTCON<<br>instruction                                                                                        | ,<br>errupt Ena<br><7>). This | ble bit, ĠIE                                 | Ē                     |  |  |  |  |  |
|                              | Global Inte<br>(INTCON<<br>instruction                                                                                        | ,<br>errupt Ena<br><7>). This | ble bit, ĠIE                                 | Ē                     |  |  |  |  |  |
| Cycles:                      | Global Inte<br>(INTCON<<br>instruction<br>1<br>2                                                                              | errupt Ena<br>(7>). This      | ble bit, GIE<br>is a two cy                  | E<br>cle              |  |  |  |  |  |
| Cycles:<br>Q Cycle Activity: | Global Inte<br>(INTCON-<br>instruction<br>1<br>2<br>Q1                                                                        | Q2<br>No-                     | ble bit, GIE<br>is a two cy<br>Q3<br>Set the | cle<br>Q4<br>Pop from |  |  |  |  |  |

After Interrupt PC = TOS GIE = 1

| OPTION                            | Load Option Register                                                                                                                                                                                                                                    |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                           | [label] OPTION                                                                                                                                                                                                                                          |
| Operands:                         | None                                                                                                                                                                                                                                                    |
| Operation:                        | $(W) \rightarrow OPTION$                                                                                                                                                                                                                                |
| Status Affected:                  | None                                                                                                                                                                                                                                                    |
| Encoding:                         | 00 0000 0110 0010                                                                                                                                                                                                                                       |
| Description:<br>Words:<br>Cycles: | The contents of the W register are<br>loaded in the OPTION register. This<br>instruction is supported for code com-<br>patibility with PIC16C5X products.<br>Since OPTION is a readable/writable<br>register, the user can directly address<br>it.<br>1 |
| Example                           | To maintain upward compatibility<br>with future PIC16CXX products, do<br>not use this instruction.                                                                                                                                                      |

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

# 15.5 <u>Timing Diagrams and Specifications</u>

# FIGURE 15-2: EXTERNAL CLOCK TIMING



# TABLE 15-2: EXTERNAL CLOCK TIMING REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                   | Min | Тур† | Мах    | Units | Conditions         |
|------------------|-------|----------------------------------|-----|------|--------|-------|--------------------|
|                  | Fosc  | External CLKIN Frequency         | DC  | _    | 4      | MHz   | XT and RC osc mode |
|                  |       | (Note 1)                         | DC  | _    | 4      | MHz   | HS osc mode (-04)  |
|                  |       |                                  | DC  | _    | 20     | MHz   | HS osc mode (-20)  |
|                  |       |                                  | DC  | _    | 200    | kHz   | LP osc mode        |
|                  |       | Oscillator Frequency             | DC  | _    | 4      | MHz   | RC osc mode        |
|                  |       | (Note 1)                         | 0.1 | _    | 4      | MHz   | XT osc mode        |
|                  |       |                                  | 1   | _    | 4      | MHz   | HS osc mode (-04)  |
|                  |       |                                  | 1   | _    | 20     | MHz   | HS osc mode (-20)  |
| 1                | Tosc  | External CLKIN Period            | 250 | _    | _      | ns    | XT and RC osc mode |
|                  |       | (Note 1)                         | 250 | _    | _      | ns    | HS osc mode (-04)  |
|                  |       |                                  | 50  | _    | _      | ns    | HS osc mode (-20)  |
|                  |       |                                  | 5   | _    | —      | μs    | LP osc mode        |
|                  |       | Oscillator Period                | 250 | _    | _      | ns    | RC osc mode        |
|                  |       | (Note 1)                         | 250 | _    | 10,000 | ns    | XT osc mode        |
|                  |       |                                  | 250 | _    | 1,000  | ns    | HS osc mode (-04)  |
|                  |       |                                  | 50  | _    | 1,000  | ns    | HS osc mode (-20)  |
|                  |       |                                  | 5   | _    | —      | μs    | LP osc mode        |
| 2                | Тсү   | Instruction Cycle Time (Note 1)  | 1.0 | Тсү  | DC     | μs    | TCY = 4/Fosc       |
| 3                | TosL, | External Clock in (OSC1) High or | 50  | _    | _      | ns    | XT oscillator      |
|                  | TosH  | Low Time                         | 2.5 | _    | —      | μs    | LP oscillator      |
|                  |       |                                  | 10  | _    | —      | ns    | HS oscillator      |
| 4                | TosR, | External Clock in (OSC1) Rise or | 25  | _    | _      | ns    | XT oscillator      |
|                  | TosF  | Fall Time                        | 50  | _    | —      | ns    | LP oscillator      |
|                  |       |                                  | 15  | _    | _      | ns    | HS oscillator      |

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

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





# TABLE 19-8: SPI MODE REQUIREMENTS

| Parameter<br>No. | Sym                   | TssL2scH, SS↓ to SCK↓ or SCK↑ input      |          | Тур† | Max | Units | Conditions |
|------------------|-----------------------|------------------------------------------|----------|------|-----|-------|------------|
| 70               | TssL2scH,<br>TssL2scL |                                          |          | —    | —   | ns    |            |
| 71               | TscH                  | SCK input high time (slave mode)         | Tcy + 20 | _    | _   | ns    |            |
| 72               | TscL                  | SCK input low time (slave mode)          | Tcy + 20 | _    | _   | ns    |            |
| 73               | TdiV2scH,<br>TdiV2scL | Setup time of SDI data input to SCK edge | 50       | —    | —   | ns    |            |
| 74               | TscH2diL,<br>TscL2diL | Hold time of SDI data input to SCK edge  | 50       | _    | —   | ns    |            |
| 75               | TdoR                  | SDO data output rise time                |          | 10   | 25  | ns    |            |
| 76               | TdoF                  | SDO data output fall time                |          | 10   | 25  | ns    |            |
| 77               | TssH2doZ              | SS↑ to SDO output hi-impedance           | 10       | _    | 50  | ns    |            |
| 78               | TscR                  | SCK output rise time (master mode)       |          | 10   | 25  | ns    |            |
| 79               | TscF                  | SCK output fall time (master mode)       | _        | 10   | 25  | ns    |            |
| 80               | TscH2doV,<br>TscL2doV | SDO data output valid after SCK edge     | _        | _    | 50  | ns    |            |

† 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 19-9: I<sup>2</sup>C BUS START/STOP BITS TIMING



# TABLE 19-9: I<sup>2</sup>C BUS START/STOP BITS REQUIREMENTS

| Parameter<br>No. | Sym     | Characteristic  |              | Min  | Тур | Мах | Units | Conditions                        |
|------------------|---------|-----------------|--------------|------|-----|-----|-------|-----------------------------------|
| 90               | TSU:STA | START condition | 100 kHz mode | 4700 | —   | —   | ns    | Only relevant for repeated START  |
|                  |         | Setup time      | 400 kHz mode | 600  | —   |     | 110   | condition                         |
| 91               | THD:STA | START condition | 100 kHz mode | 4000 | _   | —   | ns    | After this period the first clock |
|                  |         | Hold time       | 400 kHz mode | 600  | —   | _   | 115   | pulse is generated                |
| 92               | TSU:STO | STOP condition  | 100 kHz mode | 4700 | —   | _   | ns    |                                   |
|                  |         | Setup time      | 400 kHz mode | 600  | —   | _   | 115   |                                   |
| 93               | THD:STO | STOP condition  | 100 kHz mode | 4000 | —   | -   | ns    |                                   |
|                  |         | Hold time       | 400 kHz mode | 600  | —   | -   | 115   |                                   |

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

# FIGURE 20-3: CLKOUT AND I/O TIMING



| TABLE 20-3: | CLKOUT AND I/O TIMING REQUIREMENTS |
|-------------|------------------------------------|
|             |                                    |

| Parameter<br>No. | Sym      | Characteristic                                |                       | Min        | Тур† | Max         | Units  | Conditions |
|------------------|----------|-----------------------------------------------|-----------------------|------------|------|-------------|--------|------------|
| 10*              | TosH2ckL | OSC1↑ to CLKOUT↓                              | _                     | 75         | 200  | ns          | Note 1 |            |
| 11*              | TosH2ckH | OSC1↑ to CLKOUT↑                              |                       | _          | 75   | 200         | ns     | Note 1     |
| 12*              | TckR     | CLKOUT rise time                              |                       | _          | 35   | 100         | ns     | Note 1     |
| 13*              | TckF     | CLKOUT fall time                              |                       | —          | 35   | 100         | ns     | Note 1     |
| 14*              | TckL2ioV | CLKOUT $\downarrow$ to Port out valid         |                       | _          | _    | 0.5TCY + 20 | ns     | Note 1     |
| 15*              | TioV2ckH | Port in valid before CLKOUT ↑                 |                       | Tosc + 200 | _    | -           | ns     | Note 1     |
| 16*              | TckH2iol | Port in hold after CLKOUT ↑                   |                       | 0          | _    | _           | ns     | Note 1     |
| 17*              | TosH2ioV | OSC1 <sup>↑</sup> (Q1 cycle) to Port out val  | lid                   | _          | 50   | 150         | ns     |            |
| 18*              | TosH2iol | OSC1↑ (Q2 cycle) to Port input                | PIC16 <b>C</b> 63/65A | 100        | _    | _           | ns     |            |
|                  |          | invalid (I/O in hold time)                    | PIC16LC63/65A         | 200        | _    | _           | ns     |            |
| 19*              | TioV2osH | Port input valid to OSC1 <sup>↑</sup> (I/O in | setup time)           | 0          | _    | _           | ns     |            |
| 20*              | TioR     | Port output rise time                         | PIC16 <b>C</b> 63/65A | _          | 10   | 40          | ns     |            |
|                  |          |                                               | PIC16LC63/65A         | _          | _    | 80          | ns     |            |
| 21*              | TioF     | Port output fall time                         | PIC16 <b>C</b> 63/65A | _          | 10   | 40          | ns     |            |
|                  |          |                                               | PIC16LC63/65A         | _          | _    | 80          | ns     |            |
| 22††*            | Tinp     | INT pin high or low time                      | 1                     | TCY        | _    | _           | ns     |            |
| 23††*            | Trbp     | RB7:RB4 change INT high or low                | / time                | Тсү        | —    | _           | 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.

tt These parameters are asynchronous events not related to any internal clock edge.

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

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



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

# FIGURE 20-5: BROWN-OUT RESET TIMING



# TABLE 20-4: RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER, AND BROWN-OUT RESET REQUIREMENTS

| Parameter<br>No. | Sym   | Characteristic                                   | Min | Тур†      | Max | Units | Conditions                |
|------------------|-------|--------------------------------------------------|-----|-----------|-----|-------|---------------------------|
| 30               | TmcL  | MCLR Pulse Width (low)                           | 2   | —         |     | μs    | VDD = 5V, -40°C to +125°C |
| 31*              | Twdt  | Watchdog Timer Time-out Period<br>(No Prescaler) | 7   | 18        | 33  | ms    | VDD = 5V, -40°C to +125°C |
| 32               | Tost  | Oscillation Start-up Timer Period                | -   | 1024 Tosc |     | _     | TOSC = OSC1 period        |
| 33*              | Tpwrt | Power-up Timer Period                            | 28  | 72        | 132 | ms    | VDD = 5V, -40°C to +125°C |
| 34               | Tioz  | I/O Hi-impedance from MCLR Low or WDT reset      |     | _         | 2.1 | μs    |                           |
| 35               | TBOR  | Brown-out Reset Pulse Width                      | 100 | —         |     | μs    | $V$ DD $\leq$ BVDD (D005) |

\* 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-7: CAPTURE/COMPARE/PWM TIMINGS (CCP1 AND CCP2)

TABLE 20-6: CAPTURE/COMPARE/PWM REQUIREMENTS (CCP1 AND CCP2)

| Parameter<br>No. | Sym  | Characteristic                         |                            |                        | Min                   | Тур† | Max | Units | Conditions                         |
|------------------|------|----------------------------------------|----------------------------|------------------------|-----------------------|------|-----|-------|------------------------------------|
| 50*              | TccL | CCP1 and CCP2                          | No Prescaler               |                        | 0.5Tcy + 20           | _    | _   | ns    |                                    |
|                  |      | input low time                         | With Prescaler             | PIC16 <b>C</b> 63/65A  | 10                    | —    |     | ns    |                                    |
|                  |      |                                        |                            | PIC16LC63/65A          | 20                    | —    |     | ns    |                                    |
| 51*              | TccH | CCP1 and CCP2                          | No Prescaler               |                        | 0.5TCY + 20           | —    |     | ns    |                                    |
|                  |      | input high time                        | With Prescaler             | PIC16 <b>C</b> 63/65A  | 10                    | —    |     | ns    |                                    |
|                  |      |                                        |                            | PIC16 <b>LC</b> 63/65A | 20                    | -    |     | ns    |                                    |
| 52*              | TccP | CCP1 and CCP2 ir                       | nput period                |                        | <u>3Tcy + 40</u><br>N | -    |     | ns    | N = prescale value<br>(1,4, or 16) |
| 53*              | TccR | CCP1 and CCP2 o                        | output rise time PIC16C63/ |                        | _                     | 10   | 25  | ns    |                                    |
|                  |      |                                        | _                          | 25                     | 45                    | ns   |     |       |                                    |
| 54*              | TccF | CCP1 and CCP2 output fall time PIC16C6 |                            | PIC16 <b>C</b> 63/65A  | _                     | 10   | 25  | ns    |                                    |
|                  |      |                                        |                            | PIC16 <b>LC</b> 63/65A | _                     | 25   | 45  | 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

# 21.2 DC Characteristics: PIC16LCR63/R65-04 (Commercial, Industrial)

|              |                                                                  |               |         | •        |              | •     | inless otherwise stated)                                             |
|--------------|------------------------------------------------------------------|---------------|---------|----------|--------------|-------|----------------------------------------------------------------------|
| DC CHA       | RACTERISTICS                                                     | Operatir      | ng temp | perature | e -40<br>0°C |       | TA $\leq$ +85°C for industrial and<br>TA $\leq$ +70°C for commercial |
| Param<br>No. | Characteristic                                                   | Sym           | Min     | Тур†     | Max          | Units | Conditions                                                           |
| D001         | Supply Voltage                                                   | Vdd           | 3.0     | -        | 5.5          | ٧     | LP, XT, RC osc configuration (DC - 4 MHz)                            |
| D002*        | RAM Data Retention<br>Voltage (Note 1)                           | Vdr           | -       | 1.5      | -            | V     |                                                                      |
| D003         | VDD start voltage to<br>ensure internal Power-on<br>Reset signal | VPOR          | -       | Vss      | -            | V     | See section on Power-on Reset for details                            |
| D004*        | VDD rise rate to ensure<br>internal Power-on Reset<br>signal     | SVDD          | 0.05    | -        | -            | V/ms  | See section on Power-on Reset for details                            |
| D005         | Brown-out Reset Voltage                                          | BVDD          | 3.7     | 4.0      | 4.3          | V     | BODEN configuration bit is enabled                                   |
| D010         | Supply Current (Note 2, 5)                                       | IDD           | -       | 2.0      | 3.8          | mA    | XT, RC osc configuration<br>Fosc = 4 MHz, VDD = 3.0V (Note 4)        |
| D010A        |                                                                  |               | -       | 22.5     | 48           | μA    | LP osc configuration<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled      |
| D015*        | Brown-out Reset Current<br>(Note 6)                              | $\Delta$ IBOR | -       | 350      | 425          | μA    | BOR enabled, VDD = 5.0V                                              |
| D020         | Power-down Current                                               | IPD           | -       | 7.5      | 30           | μA    | VDD = 3.0V, WDT enabled, -40°C to +85°C                              |
| D021         | (Note 3, 5)                                                      |               | -       | 0.9      | 5            | μA    | VDD = $3.0V$ , WDT disabled, $0^{\circ}C$ to $+70^{\circ}C$          |
| D021A        |                                                                  |               | -       | 0.9      | 5            | μA    | VDD = 3.0V, WDT disabled, -40°C to +85°C                             |
| D023*        | Brown-out Reset Current<br>(Note 6)                              | $\Delta$ IBOR | -       | 350      | 425          | μA    | BOR enabled, VDD = 5.0V                                              |

These parameters are characterized but not tested.

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

Note 1: This is the limit to which VDD can be lowered without losing RAM data.

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

The test conditions for all IDD measurements in active operation mode are:

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

- $\overline{MCLR} = VDD$ ; WDT enabled/disabled as specified.
- 3: The power-down current in SLEEP mode does not depend on the oscillator type. Power-down current is measured with the part in SLEEP mode, with all I/O pins in hi-impedance state and tied to VDD and VSS.
- 4: For RC osc configuration, current through Rext is not included. The current through the resistor can be estimated by the formula Ir = VDD/2Rext (mA) with Rext in kOhm.
- 5: Timer1 oscillator (when enabled) adds approximately 20 μA to the specification. This value is from characterization and is for design guidance only. This is not tested.
- 6: The ∆ current is the additional current consumed when this peripheral is enabled. This current should be added to the base IDD or IPD measurement.









# FIGURE 23-27: TYPICAL IDD vs. FREQUENCY (XT MODE, 25°C)







# Data based on matrix samples. See first page of this section for details.



Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



| Package Group: Ceramic CERDIP Dual In-Line (CDP) |        |             |           |        |       |           |  |  |
|--------------------------------------------------|--------|-------------|-----------|--------|-------|-----------|--|--|
| Symbol                                           |        | Millimeters |           | Inches |       |           |  |  |
|                                                  | Min    | Мах         | Notes     | Min    | Мах   | Notes     |  |  |
| α                                                | 0°     | 10°         |           | 0°     | 10°   |           |  |  |
| А                                                | 4.318  | 5.715       |           | 0.170  | 0.225 |           |  |  |
| A1                                               | 0.381  | 1.778       |           | 0.015  | 0.070 |           |  |  |
| A2                                               | 3.810  | 4.699       |           | 0.150  | 0.185 |           |  |  |
| A3                                               | 3.810  | 4.445       |           | 0.150  | 0.175 |           |  |  |
| В                                                | 0.355  | 0.585       |           | 0.014  | 0.023 |           |  |  |
| B1                                               | 1.270  | 1.651       | Typical   | 0.050  | 0.065 | Typical   |  |  |
| С                                                | 0.203  | 0.381       | Typical   | 0.008  | 0.015 | Typical   |  |  |
| D                                                | 51.435 | 52.705      |           | 2.025  | 2.075 |           |  |  |
| D1                                               | 48.260 | 48.260      | Reference | 1.900  | 1.900 | Reference |  |  |
| E                                                | 15.240 | 15.875      |           | 0.600  | 0.625 |           |  |  |
| E1                                               | 12.954 | 15.240      |           | 0.510  | 0.600 |           |  |  |
| e1                                               | 2.540  | 2.540       | Reference | 0.100  | 0.100 | Reference |  |  |
| eA                                               | 14.986 | 16.002      | Typical   | 0.590  | 0.630 | Typical   |  |  |
| eB                                               | 15.240 | 18.034      |           | 0.600  | 0.710 |           |  |  |
| L                                                | 3.175  | 3.810       |           | 0.125  | 0.150 |           |  |  |
| Ν                                                | 40     | 40          |           | 40     | 40    |           |  |  |
| S                                                | 1.016  | 2.286       |           | 0.040  | 0.090 |           |  |  |
| S1                                               | 0.381  | 1.778       |           | 0.015  | 0.070 |           |  |  |