



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                      | 20MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 22                                                                       |
| Program Memory Size        | 14KB (8K x 14)                                                           |
| Program Memory Type        | ROM                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 368 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 5.5V                                                                |
| Data Converters            | A/D 5x8b                                                                 |
| Oscillator Type            | Internal                                                                 |
| 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/pic16cr76-i-ss |
|                            |                                                                          |

Email: info@E-XFL.COM

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

| D) |
|----|
|    |

| Pin Name          | PDIP<br>SSOP<br>SOIC<br>Pin# | MLF<br>Pin# | I/O/P<br>Type | Buffer<br>Type | Description                                                 |
|-------------------|------------------------------|-------------|---------------|----------------|-------------------------------------------------------------|
|                   |                              |             |               |                | PORTC is a bidirectional I/O port.                          |
| RC0/T1OSO/T1CKI   | 11                           | 8           |               | ST             |                                                             |
| RC0               |                              |             | I/O           |                | Digital I/O.                                                |
| T1OSO             |                              |             | 0             |                | Timer1 oscillator output.                                   |
| T1CKI             |                              |             | Ι             |                | Timer1 external clock input.                                |
| RC1/T1OSI/CCP2    | 12                           | 9           |               | ST             |                                                             |
| RC1               | . –                          | -           | I/O           |                | Digital I/O.                                                |
| T1OSI             |                              |             | 1             |                | Timer1 oscillator input.                                    |
| CCP2              |                              |             | I/O           |                | Capture2 input, Compare2 output, PWM2 output.               |
| RC2/CCP1          | 13                           | 10          |               | ST             |                                                             |
| RC2               |                              |             | I/O           | 0.             | Digital I/O.                                                |
| CCP1              |                              |             | I/O           |                | Capture1 input/Compare1 output/PWM1 output.                 |
| RC3/SCK/SCL       | 14                           | 11          |               | ST             |                                                             |
| RC3               | 17                           |             | I/O           | 01             | Digital I/O.                                                |
| SCK               |                              |             | 1/O           |                | Synchronous serial clock input/output for SPI mode.         |
| SCL               |                              |             | I/O           |                | Synchronous serial clock input/output for $l^2C^{TM}$ mode. |
| RC4/SDI/SDA       | 15                           | 12          | ., C          | ST             |                                                             |
| RC4               | 15                           | 12          | I/O           | 51             | Digital I/O.                                                |
| SDI               |                              |             | 1/0<br>I      |                | SPI data in.                                                |
| SDA               |                              |             | I/O           |                | $I^2 C^{TM}$ data I/O.                                      |
| RC5/SDO           | 16                           | 13          | 1, 0          | ST             |                                                             |
| RC5               | 10                           | 15          | I/O           | 51             | Digital I/O.                                                |
| SDO               |                              |             | 0             |                | SPI data out.                                               |
| RC6/TX/CK         | 17                           | 14          | Ŭ             | ST             |                                                             |
| RC6               | 17                           | 14          | I/O           | 31             | Digital I/O.                                                |
| TX                |                              |             | 0             |                | USART asynchronous transmit.                                |
| CK                |                              |             | 1/O           |                | USART 1 synchronous clock.                                  |
| RC7/RX/DT         | 18                           | 15          | ".            | ST             |                                                             |
| RC7/RX/D1<br>RC7  | 10                           | 10          | I/O           | 31             | Digital I/O.                                                |
| RX                |                              |             | 1             |                | USART asynchronous receive.                                 |
| DT                |                              |             | 1/O           |                | USART synchronous data.                                     |
| Vss               | 8, 19                        | 5, 16       | .,,е<br>Р     |                | Ground reference for logic and I/O pins.                    |
| VDD               | 20                           | 17          | P             |                | Positive supply for logic and I/O pins.                     |
| Legend: I = input |                              | D = output  |               | O = input/out  |                                                             |

— = Not used TTL = TTL input ST = Schmitt Trigger input

Note 1: This buffer is a Schmitt Trigger input when configured as the external interrupt.

2: This buffer is a Schmitt Trigger input when used in Serial Verify mode.

3: This buffer is a Schmitt Trigger input when configured in RC Oscillator mode and a CMOS input otherwise.

# 3.0 READING PROGRAM MEMORY

The ROM Program Memory is readable during normal operation over the entire VDD range. It is indirectly addressed through Special Function Registers (SFR). Up to 14-bit numbers can be stored in memory for use as calibration parameters, serial numbers, packed 7-bit ASCII, etc. Executing a program memory location containing data that forms an invalid instruction results in a NOP.

There are five SFRs used to read the program and memory. These registers are:

- PMCON1
- PMDATA
- PMDATH
- PMADR
- PMADRH

The program memory allows word reads. Program memory access allows for checksum calculation and reading calibration tables.

When interfacing to the program memory block, the PMDATH:PMDATA registers form a two-byte word, which holds the 14-bit data for reads. The PMADRH:PMADR registers form a two-byte word, which holds the 13-bit address of the ROM location being accessed. These devices can have up to 8K words of program ROM, with an address range from 0h to 3FFFh. The unused upper bits in both the PMDATH and PMADRH registers are not implemented and read as '0's.

## 3.1 PMADR

The address registers can address up to a maximum of 8K words of program ROM.

When selecting a program address value, the MSB of the address is written to the PMADRH register and the LSB is written to the PMADR register. The upper MSb's of PMADRH must always be clear.

### 3.2 PMCON1 Register

PMCON1 is the control register for memory accesses.

The control bit RD initiates read operations. This bit cannot be cleared, only set, in software. It is cleared in hardware at the completion of the read operation.

#### REGISTER 3-1: PMCON1: (ADDRESS 18Ch)

| R-1         | U-0 | U-0 | U-0 | U-x | U-0 | U-0 | R/S-0 |
|-------------|-----|-----|-----|-----|-----|-----|-------|
| reserved    | —   | —   | —   | —   | —   | —   | RD    |
| bit 7 bit 0 |     |     |     |     |     |     |       |

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

| bit 7 | Reserved: Read as '1' |
|-------|-----------------------|
|-------|-----------------------|

bit 6-1 **Unimplemented**: Read as '0'

bit 0 **RD**: Read Control bit

1 = Initiates a ROM read, RD is cleared in hardware. The RD bit can only be set (not cleared) in software.

0 = ROM read completed

| U-0                               | U-0                                       | R/W-0            | R/W-0 | R/W-0                              | R/W-0  | R/W-0              | R/W-0  |  |
|-----------------------------------|-------------------------------------------|------------------|-------|------------------------------------|--------|--------------------|--------|--|
| _                                 | —                                         | CCPxX            | CCPxY | CCPxM3                             | CCPxM2 | CCPxM1             | CCPxM0 |  |
| bit 7                             |                                           |                  |       |                                    |        |                    | bit 0  |  |
|                                   |                                           |                  |       |                                    |        |                    |        |  |
| Legend:                           |                                           |                  |       |                                    |        |                    |        |  |
| R = Readable bit W = Writable bit |                                           |                  | bit   | U = Unimplemented bit, read as '0' |        |                    |        |  |
| -n = Value at POR                 |                                           | '1' = Bit is set |       | '0' = Bit is cleared               |        | x = Bit is unknown |        |  |
|                                   |                                           |                  |       |                                    |        |                    |        |  |
| bit 7-6                           | Unimplemen                                | ted: Read as '   | 0'    |                                    |        |                    |        |  |
| bit 5-4                           | bit 5-4 CCPxX:CCPxY: PWM Least Significan |                  |       | its                                |        |                    |        |  |
|                                   | Capture mode:                             |                  |       |                                    |        |                    |        |  |

#### REGISTER 8-1: CCP1CON/CCP2CON: (ADDRESS 17h/1Dh)

| bit 5-4 | CCPxX:CCPxY: PWM Least Significant bits                                                |
|---------|----------------------------------------------------------------------------------------|
|         | Capture mode:                                                                          |
|         | Unused                                                                                 |
|         | Compare mode:                                                                          |
|         | Unused                                                                                 |
|         | PWM mode:                                                                              |
|         | These bits are the two LSbs of the PWM duty cycle. The eight MSbs are found in CCPRxL. |
| bit 3-0 | CCPxM3:CCPxM0: CCPx Mode Select bits                                                   |
|         | 0000 = Capture/Compare/PWM disabled (resets CCPx module)                               |
|         | 0100 = Capture mode, every falling edge                                                |
|         | 0101 = Capture mode, every rising edge                                                 |
|         | 0110 = Capture mode, every 4th rising edge                                             |
|         | And a Construction of the second ACthe size in a data                                  |

- 0111 = Capture mode, every 16th rising edge
- 1000 = Compare mode, set output on match (CCPxIF bit is set)
- 1001 = Compare mode, clear output on match (CCPxIF bit is set)
- 1010 = Compare mode, generate software interrupt on match (CCPxIF bit is set, CCPx pin is unaffected)
- 1011 = Compare mode, trigger special event (CCPxIF bit is set, CCPx pin is unaffected); CCP1 clears Timer1; CCP2 clears Timer1 and starts an A/D conversion (if A/D module is enabled)
- 11xx = PWM mode

# 8.3 Capture Mode

In Capture mode, CCPR1H:CCPR1L captures the 16-bit value of the TMR1 register when an event occurs on pin RC2/CCP1. An event is defined as one of the following and is configured by CCPxCON<3:0>:

- · Every falling edge
- · Every rising edge
- Every 4th rising edge
- Every 16th rising edge

An event is selected by control bits CCP1M3:CCP1M0 (CCP1CON<3:0>). When a capture is made, the interrupt request flag bit CCP1IF (PIR1<2>) is set. The interrupt flag must be cleared in software. If another capture occurs before the value in register CCPR1 is read, the old captured value is overwritten by the new captured value.

#### 8.3.1 CCP PIN CONFIGURATION

In Capture mode, the RC2/CCP1 pin should be configured as an input by setting the TRISC<2> bit.

| Note: | If the RC2/CCP1 pin is configured as an |  |
|-------|-----------------------------------------|--|
|       | output, a write to the port can cause a |  |
|       | capture condition.                      |  |

#### FIGURE 8-1: CAPTURE MODE OPERATION BLOCK DIAGRAM



#### 8.3.2 TIMER1 MODE SELECTION

Timer1 must be running in Timer mode or Synchronized Counter mode for the CCP module to use the capture feature. In Asynchronous Counter mode, the capture operation may not work.

#### 8.3.3 SOFTWARE INTERRUPT

When the Capture mode is changed, a false capture interrupt may be generated. The user should keep bit CCP1IE (PIE1<2>) clear to avoid false interrupts and should clear the flag bit CCP1IF following any such change in operating mode.

#### 8.3.4 CCP PRESCALER

There are four prescaler settings, specified by bits CCP1M3:CCP1M0. Whenever the CCP module is turned off, or the CCP module is not in Capture mode, the prescaler counter is cleared. Any Reset will clear the prescaler counter.

Switching from one capture prescaler to another may generate an interrupt. Also, the prescaler counter will not be cleared, therefore, the first capture may be from a non-zero prescaler. Example 8-1 shows the recommended method for switching between capture prescalers. This example also clears the prescaler counter and will not generate the "false" interrupt.

#### EXAMPLE 8-1: CHANGING BETWEEN CAPTURE PRESCALERS

| CLRF  | CCP1CON     | ;Turn CCP module off    |
|-------|-------------|-------------------------|
| MOVLW | NEW_CAPT_PS | ;Load the W reg with    |
|       |             | ;the new prescaler      |
|       |             | ;move value and CCP ON  |
| MOVWF | CCP1CON     | ;Load CCP1CON with this |
|       |             | ;value                  |
|       |             |                         |

# 8.4 Compare Mode

In Compare mode, the 16-bit CCPR1 register value is constantly compared against the TMR1 register pair value. When a match occurs, the RC2/CCP1 pin is:

- Driven high
- Driven low
- Remains unchanged

The action on the pin is based on the value of control bits CCP1M3:CCP1M0 (CCP1CON<3:0>). At the same time, interrupt flag bit CCP1IF is set.



#### COMPARE MODE OPERATION BLOCK DIAGRAM



Special Event Trigger will:

- clear TMR1H and TMR1L registers
- NOT set interrupt flag bit TMR1F (PIR1<0>)
- (for CCP2 only) set the GO/DONE bit (ADCON0<2>)

# 8.5 PWM Mode (PWM)

FIGURE 8-3:

In Pulse Width Modulation mode, the CCPx pin produces up to a 10-bit resolution PWM output. Since the CCP1 pin is multiplexed with the PORTC data latch, the TRISC<2> bit must be cleared to make the CCP1 pin an output.

| Note: | Clearing the CCP1CON register will force  |
|-------|-------------------------------------------|
|       | the CCP1 PWM output latch to the default  |
|       | low level. This is not the PORTC I/O data |
|       | latch.                                    |

Figure 8-3 shows a simplified block diagram of the CCP module in PWM mode.

For a step-by-step procedure on how to set up the CCP module for PWM operation, see **Section 8.5.3** "**SetUp for PWM Operation**".

SIMPLIFIED PWM BLOCK

|                | D                             | DIAGRAM                                 |
|----------------|-------------------------------|-----------------------------------------|
| Duty Cycle Reg | isters                        | CCP1CON<5:4>                            |
| CCPR1L         |                               | $\leftarrow$                            |
|                | (1)<br>Clear<br>CCP1<br>latch | is concatenated with the 2-bit inter-   |
|                | ime base                      | e 2 bits of the prescaler to create the |

A PWM output (Figure 8-4) has a time base (period) and a time that the output stays high (duty cycle). The frequency of the PWM is the inverse of the period (1/period).



#### 8.5.1 PWM PERIOD

The PWM period is specified by writing to the PR2 register. The PWM period can be calculated using the following formula:

PWM period =  $[(PR2) + 1] \cdot 4 \cdot TOSC \cdot$ 

(TMR2 prescale value)

PWM frequency is defined as 1 / [PWM period].

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCP1 pin is set (exception: if PWM duty cycle = 0%, the CCP1 pin will not be set)
- The PWM duty cycle is latched from CCPR1L into CCPR1H

# 8.5.2 PWM DUTY CYCLE

The PWM duty cycle is specified by writing to the CCPR1L register and to the CCP1CON<5:4> bits. Up to 10-bit resolution is available. The CCPR1L contains the eight MSbs and the CCP1CON<5:4> contains the two LSbs. This 10-bit value is represented by CCPR1L:CCP1CON<5:4>. The following equation is used to calculate the PWM duty cycle in time:

CCPR1L and CCP1CON<5:4> can be written to at any time, but the duty cycle value is not latched into CCPR1H until after a match between PR2 and TMR2 occurs (i.e., the period is complete). In PWM mode, CCPR1H is a read-only register.

The CCPR1H register and a 2-bit internal latch are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

When the CCPR1H and 2-bit latch match TMR2, concatenated with an internal 2-bit Q clock or 2 bits of the TMR2 prescaler, the CCP1 pin is cleared.

The maximum PWM resolution (bits) for a given PWM frequency is given by the formula:

|           | 0,                                                                                                                  |
|-----------|---------------------------------------------------------------------------------------------------------------------|
| Resolutio | $\operatorname{pn} = \frac{\log\left(\frac{\operatorname{Fosc}}{\operatorname{FpWM}}\right)}{\log(2)} \text{ bits}$ |
| Note:     | If the PWM duty cycle value is longer than<br>the PWM period, the CCP1 pin will not be<br>cleared.                  |

Note: The Timer2 postscaler (see Section 8.3 "Capture Mode") is not used in the determination of the PWM frequency. The postscaler could be used to have a servo update rate at a different frequency than the PWM output.

# 9.0 SYNCHRONOUS SERIAL PORT (SSP) MODULE

## 9.1 SSP Module Overview

The Synchronous Serial Port (SSP) module is a serial interface useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be Serial EEPROMs, shift registers, display drivers, A/D converters, etc. The SSP module can operate in one of two modes:

- Serial Peripheral Interface (SPI)
- Inter-Integrated Circuit (I<sup>2</sup>C)

An overview of I<sup>2</sup>C operations and additional information on the SSP module can be found in the "*PIC*<sup>®</sup> *Mid-Range MCU Family Reference Manual*" (DS33023).

Refer to Application Note AN578, "Use of the SSP Module in the  $I^2C^{TM}$  Multi-Master Environment" (DS00578).

# 9.2 SPI Mode

This section contains register definitions and operational characteristics of the SPI module. Additional information on the SPI module can be found in the "*PIC*<sup>®</sup> *Mid-Range MCU Family Reference Manual*" (DS33023).

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) RC5/SDO
- Serial Data In (SDI) RC4/SDI/SDA
- Serial Clock (SCK) RC3/SCK/SCL

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

• Slave Select (SS) RA5/SS/AN4

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>) and SSPSTAT<7:6>. 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 (Idle state of SCK)
- Clock edge (output data on rising/falling edge of SCK)
- Clock Rate (Master mode only)
- Slave Select mode (Slave mode only)

| REGISTER 12-1: | <b>CONFIGURATION WORD:</b> | (ADDRESS 2007h <sup>(1)</sup> ) |
|----------------|----------------------------|---------------------------------|
|                |                            |                                 |

| U-0             | U-0                                                                                                                            | U-0              | U-0    | U-0                      | U-0               | U-0                   |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------|------------------|--------|--------------------------|-------------------|-----------------------|
|                 | _                                                                                                                              | —                | —      | —                        | _                 | —                     |
| bit 13          |                                                                                                                                | ·                |        | •                        |                   | bit                   |
|                 |                                                                                                                                |                  |        |                          |                   |                       |
| R/P-1           | U-0                                                                                                                            | R/P-1            | R/P-1  | R/P-1                    | R/P-1             | R/P-1                 |
| BOREN           | —                                                                                                                              | CP0              | PWRTEN | WDTEN                    | FOSC1             | FOSC0                 |
| bit 6           |                                                                                                                                |                  |        |                          |                   | bit                   |
| Legend:         |                                                                                                                                |                  |        |                          |                   |                       |
| R = Readable    | bit                                                                                                                            | W = Writable bit |        | U = Unimpleme            | ented bit, read a | s '0'                 |
| -n = Value at P | n = Value at POR '1' = Bit is set                                                                                              |                  |        | '0' = Bit is cleared x = |                   | x = Bit is<br>unknown |
| bit 13-7        | Unimplemente                                                                                                                   | ed: Read as '1'  |        |                          |                   |                       |
| bit 6           | BOREN: Brown-out Reset Enable bit<br>1 = BOR enabled<br>0 = BOR disabled                                                       |                  |        |                          |                   |                       |
| bit 5           | Unimplemented: Read as '1'                                                                                                     |                  |        |                          |                   |                       |
| bit 4           | <b>CP0:</b> ROM Program Memory Code Protection bit<br>1 = Code protection off<br>0 = All memory locations code protected       |                  |        |                          |                   |                       |
| bit 3           | <b>PWRTEN</b> : Power-up Timer Enable bit<br>1 = PWRT disabled<br>0 = PWRT enabled                                             |                  |        |                          |                   |                       |
| bit 2           | WDTEN: Watchdog Timer Enable bit<br>1 = WDT enabled<br>0 = WDT disabled                                                        |                  |        |                          |                   |                       |
| bit 1-0         | FOSC1:FOSC0: Oscillator Selection bits<br>11 = RC oscillator<br>10 = HS oscillator<br>01 = XT oscillator<br>00 = LP oscillator |                  |        |                          |                   |                       |

**Note 1:** The erased (unprogrammed) value of the Configuration Word is 3FFFh.

# 12.10 Power Control/Status Register (PCON)

The Power Control/Status Register, PCON, has two bits to indicate the type of Reset that last occurred.

Bit 0 is Brown-out Reset Status bit,  $\overline{\text{BOR}}$ . Bit  $\overline{\text{BOR}}$  is unknown on a Power-on Reset. It must then be set by the user and checked on subsequent Resets to see if

| TABLE 12-3: TIVIE-OUT IN VARIOUS SITUATIONS | TABLE 12-3: | TIME-OUT IN VARIOUS SITUATIONS |
|---------------------------------------------|-------------|--------------------------------|
|---------------------------------------------|-------------|--------------------------------|

bit BOR cleared, indicating a Brown-out Reset occurred. When the Brown-out Reset is disabled, the state of the BOR bit is unpredictable.

Bit 1 is  $\overrightarrow{POR}$  (Power-on Reset Status bit). It is cleared on a Power-on Reset and unaffected otherwise. The user must set this bit following a Power-on Reset.

| Oppillator Configuration | Power-up          |                  | Drown out         | Wake-up from |  |
|--------------------------|-------------------|------------------|-------------------|--------------|--|
| Oscillator Configuration | PWRTE = 0         | <b>PWRTE =</b> 1 | Brown-out         | Sleep        |  |
| XT, HS, LP               | 72 ms + 1024 Tosc | 1024 Tosc        | 72 ms + 1024 Tosc | 1024 Tosc    |  |
| RC                       | 72 ms             | —                | 72 ms             | —            |  |

### TABLE 12-4: STATUS BITS AND THEIR SIGNIFICANCE

| POR<br>(PCON<1>) | BOR<br>(PCON<0>) | TO<br>(STATUS<4>) | PD<br>(STATUS<3>) | Significance                                            |
|------------------|------------------|-------------------|-------------------|---------------------------------------------------------|
| 0                | x                | 1                 | 1                 | Power-on Reset                                          |
| 0                | х                | 0                 | х                 | Illegal, TO is set on POR                               |
| 0                | х                | x                 | 0                 | Illegal, PD is set on POR                               |
| 1                | 0                | 1                 | 1                 | Brown-out Reset                                         |
| 1                | 1                | 0                 | 1                 | WDT Reset                                               |
| 1                | 1                | 0                 | 0                 | WDT Wake-up                                             |
| 1                | 1                | u                 | u                 | MCLR Reset during normal operation                      |
| 1                | 1                | 1                 | 0                 | MCLR Reset during Sleep or interrupt wake-up from Sleep |

# TABLE 12-5: RESET CONDITION FOR SPECIAL REGISTERS

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

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

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

## 12.14 Power-down Mode (Sleep)

Power-down mode is entered by executing a  $\ensuremath{\mathtt{SLEEP}}$  instruction.

If enabled, the Watchdog Timer will be cleared but keeps running, the PD bit (STATUS<3>) is cleared, the TO (STATUS<4>) bit is set, and the oscillator driver is turned off. The I/O ports maintain the status they had before the SLEEP instruction was executed (driving high, low, or high-impendance).

For lowest current consumption in this mode, place all I/O pins at either VDD or VSS, ensure no external circuitry is drawing current from the I/O pin, power-down the A/D and disable external clocks. Pull all I/O pins that are high-impendance inputs, high or low externally, to avoid switching currents caused by floating inputs. The T0CKI input should also be at VDD or VSS for lowest current consumption. The contribution from on-chip pull-ups on PORTB should also be considered.

The MCLR pin must be at a logic high level (VIHMC).

#### 12.14.1 WAKE-UP FROM SLEEP

The device can wake-up from Sleep through one of the following events:

- 1. External Reset input on  $\overline{\text{MCLR}}$  pin.
- 2. Watchdog Timer wake-up (if WDT was enabled).
- 3. Interrupt from INT pin, RB port change or a Peripheral Interrupt.

External MCLR Reset will cause a device Reset. All other events are considered a continuation of program execution and cause a "wake-up". The TO and PD bits in the STATUS register can be used to determine the cause of device Reset. The PD bit, which is set on power-up, is cleared when Sleep is invoked. The TO bit is cleared if a WDT time-out occurred and caused wake-up.

The following peripheral interrupts can wake the device from Sleep:

- 1. PSP read or write (PIC16CR74/77 only).
- 2. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 3. CCP Capture mode interrupt.
- 4. Special event trigger (Timer1 in Asynchronous mode, using an external clock).
- 5. SSP (Start/Stop) bit detect interrupt.
- SSP transmit or receive in Slave mode (SPI/I<sup>2</sup>C).
- 7. USART RX or TX (Synchronous Slave mode).
- 8. A/D conversion (when A/D clock source is RC).

Other peripherals cannot generate interrupts, since during Sleep, no on-chip clocks are present.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is pre-fetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be set (enabled). Wake-up occurs, regardless of the state of the GIE bit. If the GIE bit is clear (disabled), the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is set (enabled), the device executes the instruction after the SLEEP instruction and then branches to the interrupt address (0004h). In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

### 12.14.2 WAKE-UP USING INTERRUPTS

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

- If the interrupt occurs **before** the execution of a SLEEP instruction, the SLEEP instruction will complete as a NOP. Therefore, the WDT and WDT postscaler will not be cleared, the TO bit will not be set and PD bits will not be cleared.
- If the interrupt occurs during or after the execution of a SLEEP instruction, the device will immediately wake-up from Sleep. The SLEEP instruction will be completely executed before the wake-up. Therefore, the WDT and WDT postscaler will be cleared, the TO bit will be set and the PD bit will be cleared.

Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the PD bit. If the PD bit is set, the SLEEP instruction was executed as a NOP.

To ensure that the WDT is cleared, a CLRWDT instruction should be executed before a SLEEP instruction.

# PIC16CR7X

| CALL             | Call Subroutine                                                                                                                                                                                                                                 |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] CALL k                                                                                                                                                                                                                         |
| Operands:        | $0 \le k \le 2047$                                                                                                                                                                                                                              |
| Operation:       | $\begin{array}{l} (PC)\texttt{+} \ 1 \rightarrow TOS, \\ k \rightarrow PC\texttt{<}10:0\texttt{>}, \\ (PCLATH\texttt{<}4:3\texttt{>}) \rightarrow PC\texttt{<}12:11\texttt{>} \end{array}$                                                      |
| Status Affected: | None                                                                                                                                                                                                                                            |
| Description:     | Call Subroutine. First, return<br>address (PC + 1) is pushed onto<br>the stack. The eleven-bit immedi-<br>ate address is loaded into PC bits<br><10:0>. The upper bits of the PC<br>are loaded from PCLATH. CALL is<br>a two-cycle instruction. |

| CLRWDT                         | Clear Watchdog Timer                                                                                                                                                      |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                        | [label] CLRWDT                                                                                                                                                            |
| Operands:                      | None                                                                                                                                                                      |
| Operation:<br>Status Affected: | $\begin{array}{l} 00h \rightarrow WDT \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO} \\ 1 \rightarrow PD \\ \overline{TO}, \ \overline{PD} \end{array}$ |
| Description:                   | CLRWDT instruction resets the<br>Watchdog Timer. It also resets the<br>prescaler of the WDT. Status bits<br>TO and PD are set.                                            |

| CLRF             | Clear f                                                               |
|------------------|-----------------------------------------------------------------------|
| Syntax:          | [label] CLRF f                                                        |
| Operands:        | $0 \le f \le 127$                                                     |
| Operation:       | $\begin{array}{l} 00h \rightarrow (f) \\ 1 \rightarrow Z \end{array}$ |
| Status Affected: | Z                                                                     |
| Description:     | The contents of register 'f' are cleared and the Z bit is set.        |

| COMF             | Complement f                                                                                                                                                   |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] COMF f,d                                                                                                                                               |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                                              |
| Operation:       | $(\overline{f}) \rightarrow (destination)$                                                                                                                     |
| Status Affected: | Z                                                                                                                                                              |
| Description:     | The contents of register 'f' are<br>complemented. If 'd' is '0', the<br>result is stored in W. If 'd' is '1',<br>the result is stored back in<br>register 'f'. |

| CLRW             | Clear W                                                                                    |
|------------------|--------------------------------------------------------------------------------------------|
| Syntax:          | [label] CLRW                                                                               |
| Operands:        | None                                                                                       |
| Operation:       | $\begin{array}{l} \text{00h} \rightarrow (\text{W}) \\ 1 \rightarrow \text{Z} \end{array}$ |
| Status Affected: | Z                                                                                          |
| Description:     | W register is cleared. Zero bit (Z) is set.                                                |

| DECF             | Decrement f                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] DECF f,d                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                                 |
| Operation:       | (f) - 1 $\rightarrow$ (destination)                                                                                                               |
| Status Affected: | Z                                                                                                                                                 |
| Description:     | Decrement register 'f'. If 'd' is '0',<br>the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

# PIC16CR7X

| MOVF             | Move f                                                                                                                                                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] MOVF f,d                                                                                                                                                                                                                                                                           |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                                                                                                                                                                 |
| Operation:       | (f) $\rightarrow$ (destination)                                                                                                                                                                                                                                                            |
| Status Affected: | Z                                                                                                                                                                                                                                                                                          |
| Description:     | The contents of register 'f' are<br>moved to a destination dependant<br>upon the status of 'd'. If 'd' = 0,<br>destination is W register. If 'd' = 1,<br>the destination is file register 'f'<br>itself. 'd' = 1 is useful to test a file<br>register, since status flag Z is<br>affected. |

| NOP              | No Operation  |
|------------------|---------------|
| Syntax:          | [label] NOP   |
| Operands:        | None          |
| Operation:       | No operation  |
| Status Affected: | None          |
| Description:     | No operation. |

| MOVLW            | Move Literal to W                                                                             |  |  |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] MOVLW k                                                                      |  |  |  |  |  |  |  |
| Operands:        | $0 \le k \le 255$                                                                             |  |  |  |  |  |  |  |
| Operation:       | $k \rightarrow (W)$                                                                           |  |  |  |  |  |  |  |
| Status Affected: | None                                                                                          |  |  |  |  |  |  |  |
| Description:     | The eight-bit literal 'k' is loaded into W register. The "don't cares" will assemble as '0's. |  |  |  |  |  |  |  |

| RETFIE           | Return from Interrupt                                   |
|------------------|---------------------------------------------------------|
| Syntax:          | [label] RETFIE                                          |
| Operands:        | None                                                    |
| Operation:       | $\begin{array}{l} TOS \to PC, \\ 1 \to GIE \end{array}$ |
| Status Affected: | None                                                    |

| MOVWF            | Move W to f                                |
|------------------|--------------------------------------------|
| Syntax:          | [label] MOVWF f                            |
| Operands:        | $0 \le f \le 127$                          |
| Operation:       | $(W) \to (f)$                              |
| Status Affected: | None                                       |
| Description:     | Move data from W register to register 'f'. |

| RETLW            | Return with Literal in W                                                                                                                                                                    |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RETLW k                                                                                                                                                                    |
| Operands:        | $0 \le k \le 255$                                                                                                                                                                           |
| Operation:       | $\begin{array}{l} k \rightarrow (W); \\ TOS \rightarrow PC \end{array}$                                                                                                                     |
| Status Affected: | None                                                                                                                                                                                        |
| Description:     | Subtract (2's complement method)<br>W register from register 'f'. If 'd' is<br>'0', the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |

# 15.1 DC Characteristics: PIC16CR73/74/76/77 (Industrial, Extended) (Continued)

| PIC16CR73/74/76/77<br>(Industrial, Extended) |               |                                     |          | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for extended |                      |                      |                                                                                                                                                                                                                                                                    |  |  |
|----------------------------------------------|---------------|-------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Param<br>No.                                 | Sym           | Characteristic                      | Min      | Тур†                                                                                                                                                                                    | Max                  | Units                | Conditions                                                                                                                                                                                                                                                         |  |  |
|                                              | Idd           | Supply Current (Notes 2, 5)         |          |                                                                                                                                                                                         |                      |                      |                                                                                                                                                                                                                                                                    |  |  |
| D010                                         |               | PIC16CR7X                           | _        | 0.5                                                                                                                                                                                     | 2                    | mA                   | XT, RC osc configuration<br>Fosc = 4 MHz, VDD = 3.0V (Note 4)                                                                                                                                                                                                      |  |  |
| D010A                                        |               |                                     | —        | 20                                                                                                                                                                                      | 48                   | μA                   | LP osc configuration<br>Fosc = 32 kHz, VDD = 3.0V, WDT disabled                                                                                                                                                                                                    |  |  |
| D010                                         |               | PIC16CR7X                           |          | 1.1                                                                                                                                                                                     | 4                    | mA                   | XT, RC osc configuration<br>Fosc = 4 MHz, VDD = 5.5V (Note 4)                                                                                                                                                                                                      |  |  |
| D013                                         |               |                                     | —        | 6.3                                                                                                                                                                                     | 15                   | mA                   | HS osc configuration<br>Fosc = 20 MHz, VDD = 5.5V                                                                                                                                                                                                                  |  |  |
| D015*                                        | $\Delta$ Ibor | Brown-out<br>Reset Current (Note 6) |          | 30                                                                                                                                                                                      | 200                  | μA                   | BOR enabled, VDD = 5.0V                                                                                                                                                                                                                                            |  |  |
| D020                                         | IPD           | Power-down Current (Note            | es 3, 5) |                                                                                                                                                                                         |                      |                      |                                                                                                                                                                                                                                                                    |  |  |
| D021                                         |               | PIC16CR7X                           | _        | 2.0<br>0.1                                                                                                                                                                              | 30<br>5              | μΑ<br>μΑ             | VDD = $3.0V$ , WDT enabled, $-40^{\circ}C$ to $+85^{\circ}C$<br>VDD = $3.0V$ , WDT disabled, $-40^{\circ}C$ to $+85^{\circ}C$                                                                                                                                      |  |  |
| D020<br>D021<br>D021A                        |               | PIC16CR7X                           | <br>     | 5<br>0.1<br>10.5<br>1.5                                                                                                                                                                 | 42<br>19<br>57<br>42 | μΑ<br>μΑ<br>μΑ<br>μΑ | VDD = 4.0V, WDT enabled, $-40^{\circ}$ C to $+85^{\circ}$ C<br>VDD = 4.0V, WDT disabled, $-40^{\circ}$ C to $+85^{\circ}$ C<br>VDD = 4.0V, WDT enabled, $-40^{\circ}$ C to<br>$+125^{\circ}$ C<br>VDD = 4.0V, WDT disabled, $-40^{\circ}$ C to<br>$+125^{\circ}$ C |  |  |
| D023*                                        | ΔIBOR         | Brown-out<br>Reset Current (Note 6) |          | 30                                                                                                                                                                                      | 200                  | μA                   | BOR enabled, VDD = 5.0V                                                                                                                                                                                                                                            |  |  |

**Legend:** Shading of rows is to assist in readability of of the table.

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

<u>OSC1</u> = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD MCLR = VDD; WDT enabled/disabled as specified.

- **3:** The power-down current in Sleep mode does not depend on the oscillator type. Power-down current is measured with the part in Sleep mode, with all I/O pins in high-impendance 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.
- 7: When BOR is enabled, the device will operate correctly until the VBOR voltage trip point is reached.



#### TABLE 15-1: EXTERNAL CLOCK TIMING REQUIREMENTS

| Parameter<br>No. | Symbol | Characteristic                     | Min  | Тур† | Max    | Units | Conditions    |
|------------------|--------|------------------------------------|------|------|--------|-------|---------------|
|                  | Fosc   | External CLKIN Frequency           | DC   | _    | 1      | MHz   | XT osc mode   |
|                  |        | (Note 1)                           | DC   | _    | 20     | MHz   | HS osc mode   |
|                  |        |                                    | DC   | _    | 32     | kHz   | LP osc mode   |
|                  |        | Oscillator Frequency               | DC   | _    | 4      | MHz   | RC osc mode   |
|                  |        | (Note 1)                           | 0.1  | _    | 4      | MHz   | XT osc mode   |
|                  |        |                                    | 4    | _    | 20     | MHz   | HS osc mode   |
|                  |        |                                    | 5    | —    | 200    | kHz   | LP osc mode   |
| 1                | Tosc   | External CLKIN Period              | 1000 | _    | —      | ns    | XT osc mode   |
|                  |        | (Note 1)                           | 50   | _    |        | ns    | HS osc mode   |
|                  |        |                                    | 5    | —    |        | ms    | LP osc mode   |
|                  |        | Oscillator Period                  | 250  | _    |        | ns    | RC osc mode   |
|                  |        | (Note 1)                           | 250  | _    | 10,000 | ns    | XT osc mode   |
|                  |        |                                    | 50   | _    | 250    | ns    | HS osc mode   |
|                  |        |                                    | 5    | _    |        | ms    | LP osc mode   |
| 2                | Тсү    | Instruction Cycle Time<br>(Note 1) | 200  | Тсү  | DC     | ns    | Tcy = 4/Fosc  |
| 3                | TosL,  | External Clock in (OSC1)           | 500  | _    |        | ns    | XT oscillator |
|                  | TosH   | High or Low Time                   | 2.5  | _    | —      | ms    | LP oscillator |
|                  |        |                                    | 15   | _    |        | ns    | HS oscillator |
| 4                | TosR,  | External Clock in (OSC1)           | —    | _    | 25     | ns    | XT oscillator |
|                  | TosF   | Rise or 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.



#### RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND **FIGURE 15-5: POWER-UP TIMER TIMING**

#### **FIGURE 15-6: BROWN-OUT RESET TIMING**



#### RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER **TABLE 15-3:** 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 +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                            |     | 1024 Tosc | _   | _     | Tosc = OSC1 period       |
| 33*              | TPWRT | Power-up Timer Period                                        | 28  | 72        | 132 | ms    | VDD = 5V, -40°C to +85°C |
| 34               | Tioz  | I/O High-impendance from MCLR<br>Low or Watchdog Timer Reset | _   | _         | 2.1 | μs    |                          |
| 35               | TBOR  | Brown-out Reset Pulse Width                                  | 100 | _         |     | μs    | $VDD \leq VBOR (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 t only and are not tested.

| Param<br>No. | Symbol  | Characteristic  |              | Min  | Тур | Max | Units | Conditions                   |
|--------------|---------|-----------------|--------------|------|-----|-----|-------|------------------------------|
| 90*          | TSU:STA | Start condition | 100 kHz mode | 4700 |     | _   | ns    | Only relevant for Repeated   |
|              |         | Setup time      | 400 kHz mode | 600  | _   | —   |       | Start condition              |
| 91*          | THD:STA | Start condition | 100 kHz mode | 4000 | _   | —   | ns    | After this period, the first |
|              |         | Hold time       | 400 kHz mode | 600  | _   | —   |       | clock pulse is generated     |
| 92*          | Tsu:sto | Stop condition  | 100 kHz mode | 4700 | _   | _   | ns    |                              |
|              |         | Setup time      | 400 kHz mode | 600  | _   | _   |       |                              |
| 93           | THD:STO | Stop condition  | 100 kHz mode | 4000 | —   |     | ns    |                              |
|              |         | Hold time       | 400 kHz mode | 600  | _   |     |       |                              |

| TABLE 15-8: | I <sup>2</sup> C <sup>™</sup> BUS START/STOP BITS REQUIREMENTS |
|-------------|----------------------------------------------------------------|
|-------------|----------------------------------------------------------------|

\* These parameters are characterized but not tested.





# PIC16CR7X











FIGURE 16-13: TYPICAL, MINIMUM AND MAXIMUM WDT PERIOD vs. Vdd (-40°C TO 125°C)













# 28-Lead Plastic Small Outline (SO) – Wide, 7.50 mm Body [SOIC]

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









|                          | Units          | MILLMETERS |     |      |
|--------------------------|----------------|------------|-----|------|
| Din                      | nension Limits | MIN        | NOM | MAX  |
| Number of Pins           | N              | 28         |     |      |
| Pitch                    | e              | 1.27 BSC   |     |      |
| Overall Height           | А              | -          | -   | 2.65 |
| Molded Package Thickness | A2             | 2.05       | -   | -    |
| Standoff §               | A1             | 0.10       | -   | 0.30 |
| Overall Width            | E              | 10.30 BSC  |     |      |
| Molded Package Width     | E1             | 7.50 BSC   |     |      |
| Overall Length           | D              | 17.90 BSC  |     |      |
| Chamfer (optional)       | h              | 0.25       | -   | 0.75 |
| Foot Length              | L              | 0.40       | -   | 1.27 |
| Footprint                | L1             | 1.40 REF   |     |      |
| Foot Angle Top           | φ              | 0°         | -   | 8°   |
| Lead Thickness           | С              | 0.18       | -   | 0.33 |
| Lead Width               | b              | 0.31       | -   | 0.51 |
| Mold Draft Angle Top     | α              | 5°         | -   | 15°  |
| Mold Draft Angle Bottom  | β              | 5°         | -   | 15°  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. § Significant Characteristic.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-052B

| TRISE Register |    |
|----------------|----|
| IBF Bit        |    |
| IBOV Bit       |    |
| PSPMODE Bit    |    |
| TXSTA Register |    |
| SYNC Bit       | 69 |
| TRMT Bit       | 69 |
| TX9 Bit        | 69 |
| TX9D Bit       | 69 |
| TXEN Bit       | 69 |
|                |    |

# U

| UA                                          |
|---------------------------------------------|
| Universal Synchronous Asynchronous Receiver |
| Transmitter. See USART                      |
| Update Address bit, UA60                    |
| USART                                       |
| Asynchronous Mode73                         |
| Asynchronous Receiver75                     |
| Asynchronous Reception76                    |
| Associated Registers77                      |
| Asynchronous Transmission                   |
| Associated Registers75                      |
| Asynchronous Transmitter73                  |
| Baud Rate Generator (BRG)71                 |
| Baud Rate Formula71                         |
| Baud Rates, Asynchronous Mode (BRGH = 0)72  |
| Baud Rates, Asynchronous Mode (BRGH = 1)72  |
| Sampling71                                  |
| Mode Select (SYNC Bit)69                    |
| Overrun Error (OERR Bit)70                  |
| RC6/TX/CK Pin9, 11                          |
| RC7/RX/DT Pin9, 11                          |
| Serial Port Enable (SPEN Bit)69             |
| Single Receive Enable (SREN Bit)70          |
| Synchronous Master Mode78                   |
| Synchronous Master Reception                |
| Associated Registers81                      |
| Synchronous Master Transmission78           |
| Associated Registers79                      |
| Synchronous Slave Mode81                    |
| Synchronous Slave Reception 82              |
| Associated Registers82                      |
| Synchronous Slave Transmission81            |
| Associated Registers82                      |
| Transmit Data, 9th Bit (TX9D)69             |
| Transmit Enable (TXEN Bit)69                |
| Transmit Enable, Nine-bit (TX9 Bit)69       |
| Transmit Shift Register Status (TRMT Bit)69 |
| User Code 103                               |

# W

| Wake-up from SLEEP                | 89         |
|-----------------------------------|------------|
| Interrupts                        |            |
| MCLR Reset                        |            |
| WDT Reset                         |            |
| Wake-up from Sleep                | 102        |
| Wake-up Using Interrupts          | 102        |
| Watchdog Timer (WDT)              |            |
| Associated Registers              | 101        |
| Enable (WDTE Bit)                 | 101        |
| Postscaler. See Postscaler, WDT   |            |
| Programming Considerations        | 101        |
| RC Oscillator                     |            |
| Time-out Period                   |            |
| WDT Reset, Normal Operation       | 93, 95, 96 |
| WDT Reset, SLEEP                  |            |
| WCOL bit                          |            |
| Write Collision Detect bit (WCOL) | 61         |
| WWW Address                       |            |
| WWW, On-Line Support              |            |
|                                   |            |