



#### Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

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

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

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 20MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 22                                                                       |
| Program Memory Size        | 7KB (4K x 14)                                                            |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 192 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                |
| Data Converters            | A/D 5x8b                                                                 |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 28-SSOP (0.209", 5.30mm Width)                                           |
| Supplier Device Package    | 28-SSOP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f73t-i-ss |
|                            |                                                                          |

Email: info@E-XFL.COM

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

#### 1.0 **DEVICE OVERVIEW**

This document contains device specific information about the following devices:

- PIC16F73
- PIC16F74
- PIC16F76
- PIC16F77

PIC16F73/76 devices are available only in 28-pin packages, while PIC16F74/77 devices are available in 40-pin and 44-pin packages. All devices in the PIC16F7X family share common architecture, with the following differences:

- The PIC16F73 and PIC16F76 have one-half of the total on-chip memory of the PIC16F74 and **PIC16F77**
- The 28-pin devices have 3 I/O ports, while the 40/44-pin devices have 5
- · The 28-pin devices have 11 interrupts, while the 40/44-pin devices have 12
- The 28-pin devices have 5 A/D input channels, while the 40/44-pin devices have 8
- The Parallel Slave Port is implemented only on the 40/44-pin devices

PIC16F7X DEVICE FEATURES **PIC16F74 PIC16F76 Key Features PIC16F73 PIC16F77 Operating Frequency** DC - 20 MHz DC - 20 MHz DC - 20 MHz DC - 20 MHz **RESETS** (and Delays) POR, BOR POR. BOR POR. BOR POR, BOR (PWRT, OST) (PWRT, OST) (PWRT, OST) (PWRT, OST) FLASH Program Memory 4K 4K 8K 8K (14-bit words) Data Memory (bytes) 368 192 192 368 Interrupts 11 12 11 12 I/O Ports Ports A,B,C Ports A,B,C Ports A,B,C,D,E Ports A,B,C,D,E Timers 3 3 3 3 Capture/Compare/PWM Modules 2 2 2 2 SSP, USART Serial Communications SSP, USART SSP. USART SSP, USART Parallel Communications PSP PSP 8-bit Analog-to-Digital Module **5 Input Channels** 8 Input Channels 5 Input Channels 8 Input Channels Instruction Set **35 Instructions 35 Instructions** 35 Instructions **35 Instructions** Packaging 28-pin DIP 40-pin PDIP 28-pin DIP 40-pin PDIP 28-pin SOIC 44-pin PLCC 28-pin SOIC 44-pin PLCC 28-pin SSOP 44-pin TQFP 28-pin SSOP 44-pin TQFP 28-pin MLF 28-pin MLF

## **TABLE 1-1:**

The available features are summarized in Table 1-1. Block diagrams of the PIC16F73/76 and PIC16F74/77 devices are provided in Figure 1-1 and Figure 1-2, respectively. The pinouts for these device families are listed in Table 1-2 and Table 1-3.

Additional information may be found in the PICmicro™ Mid-Range Reference Manual (DS33023), which may be obtained from your local Microchip Sales Representative or downloaded from the Microchip website. The Reference Manual should be considered a complementary document to this data sheet, and is highly recommended reading for a better understanding of the device architecture and operation of the peripheral modules.

#### PIC16F77/76 REGISTER FILE MAP FIGURE 2-2:

| A                              | File<br>ddress | A                                          | File<br>ddress |                                            | File<br>Address |                                            | File<br>Addres |
|--------------------------------|----------------|--------------------------------------------|----------------|--------------------------------------------|-----------------|--------------------------------------------|----------------|
| Indirect addr.(*)              | 00h            | Indirect addr.(*)                          | 80h            | Indirect addr.(*)                          | 100h            | Indirect addr.(*)                          | 180h           |
| TMR0                           | 01h            | OPTION_REG                                 | 81h            | TMR0                                       | 101h            | OPTION_REG                                 | 181h           |
| PCL                            | 02h            | PCL                                        | 82h            | PCL                                        | 102h            | PCL                                        | 182h           |
| STATUS                         | 03h            | STATUS                                     | 83h            | STATUS                                     | 103h            | STATUS                                     | 183h           |
| FSR                            | 04h            | FSR                                        | 84h            | FSR                                        | 104h            | FSR                                        | 184h           |
| PORTA                          | 05h            | TRISA                                      | 85h            |                                            | 105h            |                                            | 185h           |
| PORTB                          | 06h            | TRISB                                      | 86h            | PORTB                                      | 106h            | TRISB                                      | 186h           |
| PORTC                          | 07h            | TRISC                                      | 87h            |                                            | 107h            |                                            | 187h           |
| PORTD <sup>(1)</sup>           | 08h            | TRISD <sup>(1)</sup>                       | 88h            |                                            | 108h            |                                            | 188h           |
| PORTE <sup>(1)</sup>           | 09h            | TRISE <sup>(1)</sup>                       | 89h            |                                            | 109h            |                                            | 189h           |
| PCLATH                         | 0Ah            | PCLATH                                     | 8Ah            | PCLATH                                     | 10Ah            | PCLATH                                     | 18Ah           |
| INTCON                         | 0Bh            | INTCON                                     | 8Bh            | INTCON                                     | 10Bh            | INTCON                                     | 18Bh           |
| PIR1                           | 0Ch            | PIE1                                       | 8Ch            | PMDATA                                     | 10Ch            | PMCON1                                     | 18Ch           |
| PIR2                           | 0Dh            | PIE2                                       | 8Dh            | PMADR                                      | 10Dh            |                                            | 18Dh           |
| TMR1L                          | 0Eh            | PCON                                       | 8Eh            | PMDATH                                     | 10Eh            |                                            | 18Eh           |
| TMR1H                          | 0Fh            |                                            | 8Fh            | PMADRH                                     | 10Fh            |                                            | 18Fh           |
| T1CON                          | 10h            |                                            | 90h            |                                            | 110h            |                                            | 190h           |
| TMR2                           | 11h            |                                            | 91h            |                                            | 111h            |                                            | 191h           |
| T2CON                          | 12h            | PR2                                        | 92h            |                                            | 112h            |                                            | 192h           |
| SSPBUF                         | 13h            | SSPADD                                     | 93h            |                                            | 113h            |                                            | 193h           |
| SSPCON                         | 14h            | SSPSTAT                                    | 94h            |                                            | 114h            |                                            | 194h           |
| CCPR1L                         | 15h            |                                            | 95h            |                                            | 115h            |                                            | 195h           |
| CCPR1H                         | 16h            |                                            | 96h            |                                            | 116h            |                                            | 196h           |
| CCP1CON                        | 17h            |                                            | 97h            | General                                    | 117h            | General                                    | 197h           |
| RCSTA                          | 18h            | TXSTA                                      | 98h            | Purpose<br>Register                        | 118h            | Purpose<br>Register                        | 198h           |
| TXREG                          | 19h            | SPBRG                                      | 99h            | 16 Bytes                                   | 119h            | 16 Bytes                                   | 199h           |
| RCREG                          | 1Ah            | OF BITO                                    | 9Ah            |                                            | 11Ah            | ,                                          | 19Ah           |
| CCPR2L                         | 1Bh            |                                            | 9Bh            |                                            | 11Bh            |                                            | 19Bh           |
| CCPR2H                         | 1Ch            |                                            | 9Ch            |                                            | 11Ch            |                                            | 19Ch           |
| CCP2CON                        | 1Dh            |                                            | 9Dh            |                                            | 11Dh            |                                            | 19Dh           |
| ADRES                          | 1Eh            |                                            | 9Eh            |                                            | 11Eh            |                                            | 19Eh           |
| ADCON0                         | 1Fh            | ADCON1                                     | 9Fh            |                                            | 11Fh            |                                            | 19Fh           |
| 71200110                       | 20h            | 7.000111                                   |                |                                            | 120h            |                                            |                |
|                                | 2011           |                                            | A0h            |                                            | 12011           |                                            | 1A0h           |
| General<br>Purpose<br>Register |                | General<br>Purpose<br>Register<br>80 Bytes |                | General<br>Purpose<br>Register<br>80 Bytes |                 | General<br>Purpose<br>Register<br>80 Bytes |                |
| 96 Bytes                       |                | accesses                                   | EFh<br>F0h     | accesses                                   | 16Fh<br>170h    | accesses                                   | 1EFh<br>1F0h   |
|                                | 7Fh            | 70h-7Fh                                    | FFh            | 70h-7Fh                                    | 17Fh            | 70h - 7Fh                                  | 1FFh           |
| Bank 0                         |                | Bank 1                                     |                | Bank 2                                     |                 | Bank 3                                     |                |

Unimplemented data memory locations, read as '0'. \* Not a physical register.

Note 1: These registers are not implemented on 28-pin devices.

| Address              | Name       | Bit 7                | Bit 6                           | Bit 5                      | Bit 4          | Bit 3        | Bit 2           | Bit 1         | Bit 0        | Value on:<br>POR,<br>BOR | Details<br>on page |
|----------------------|------------|----------------------|---------------------------------|----------------------------|----------------|--------------|-----------------|---------------|--------------|--------------------------|--------------------|
| Bank 1               |            |                      |                                 |                            |                |              |                 |               |              |                          |                    |
| 80h <sup>(4)</sup>   | INDF       | Addressin            | g this locatio                  | n uses conte               | ents of FSR to | address dat  | a memory (r     | not a physica | al register) | 0000 0000                | 27, 96             |
| 81h                  | OPTION_REG | RBPU                 | INTEDG                          | TOCS                       | T0SE           | PSA          | PS2             | PS1           | PS0          | 1111 1111                | 20, 44, 96         |
| 82h <sup>(4)</sup>   | PCL        | Program C            | Counter's (PC                   | C) Least Sigr              | ificant Byte   |              |                 |               |              | 0000 0000                | 26, 96             |
| 83h <sup>(4)</sup>   | STATUS     | IRP                  | RP1                             | RP0                        | TO             | PD           | Z               | DC            | С            | 0001 1xxx                | 19, 96             |
| 84h <sup>(4)</sup>   | FSR        | Indirect da          | ata memory a                    |                            | xxxx xxxx      | 27, 96       |                 |               |              |                          |                    |
| 85h                  | TRISA      |                      | — PORTA Data Direction Register |                            |                |              |                 |               |              |                          | 32, 96             |
| 86h                  | TRISB      | PORTB D              | ORTB Data Direction Register    |                            |                |              |                 |               |              |                          | 34, 96             |
| 87h                  | TRISC      | PORTC D              | PORTC Data Direction Register   |                            |                |              |                 |               |              | 1111 1111                | 35, 96             |
| 88h <sup>(5)</sup>   | TRISD      | PORTD D              | ata Direction                   | Register                   |                |              |                 |               |              | 1111 1111                | 36, 96             |
| 89h <sup>(5)</sup>   | TRISE      | IBF                  | OBF                             | IBOV                       | PSPMODE        |              | PORTE Da        | ata Direction | Bits         | 0000 -111                | 38, 96             |
| 8Ah <sup>(1,4)</sup> | PCLATH     | _                    | _                               | _                          | Write Buffer f | or the upper | r 5 bits of the | Program C     | ounter       | 0 0000                   | 21, 96             |
| 8Bh <sup>(4)</sup>   | INTCON     | GIE                  | PEIE                            | TMR0IE                     | INTE           | RBIE         | TMR0IF          | INTF          | RBIF         | 0000 000x                | 23, 96             |
| 8Ch                  | PIE1       | PSPIE <sup>(3)</sup> | ADIE                            | RCIE                       | TXIE           | SSPIE        | CCP1IE          | TMR2IE        | TMR1IE       | 0000 0000                | 22,96              |
| 8Dh                  | PIE2       | _                    | _                               | _                          | _              | _            |                 | _             | CCP2IE       | 0                        | 24, 97             |
| 8Eh                  | PCON       | _                    | _                               | _                          | _              |              | _               | POR           | BOR          | dd                       | 25, 97             |
| 8Fh                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | _                        | —                  |
| 90h                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | _                        | _                  |
| 91h                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | —                        | —                  |
| 92h                  | PR2        | Timer2 Pe            | riod Registe                    | r                          |                |              |                 |               |              | 1111 1111                | 52, 97             |
| 93h                  | SSPADD     | Synchrono            | ous Serial Po                   | ort (I <sup>2</sup> C mode | ) Address Reg  | gister       |                 |               |              | 0000 0000                | 68, 97             |
| 94h                  | SSPSTAT    | SMP                  | CKE                             | D/A                        | Р              | S            | R/W             | UA            | BF           | 0000 0000                | 60, 97             |
| 95h                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | —                        | —                  |
| 96h                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | —                        | —                  |
| 97h                  | —          | Unimplem             | ented                           |                            |                |              | _               |               | -            | —                        | —                  |
| 98h                  | TXSTA      | CSRC                 | TX9                             | TXEN                       | SYNC           |              | BRGH            | TRMT          | TX9D         | 0000 -010                | 69, 97             |
| 99h                  | SPBRG      | Baud Rate            | e Generator I                   | Register                   |                |              |                 |               |              | 0000 0000                | 71, 97             |
| 9Ah                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | —                        |                    |
| 9Bh                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | -                        |                    |
| 9Ch                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | _                        |                    |
| 9Dh                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | _                        |                    |
| 9Eh                  | —          | Unimplem             | ented                           |                            |                |              |                 |               |              | -                        |                    |
| 9Fh                  | ADCON1     | _                    | _                               | _                          | _              | _            | PCFG2           | PCFG1         | PCFG0        | 000                      | 84, 97             |

| TABLE 2-1: SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED) |
|----------------------------------------------------------|
|----------------------------------------------------------|

 $\label{eq:legend: Legend: Legend: u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved.$ Shaded locations are unimplemented, read as '0'.

Note 1: The upper byte of the program counter is not directly accessible. PCLATH is a holding register for the PC<12:8>, whose contents are transferred to the upper byte of the program counter during branches (CALL or GOTO).

2: Other (non power-up) RESETS include external RESET through MCLR and Watchdog Timer Reset. 3: Bits PSPIE and PSPIF are reserved on the 28-pin devices; always maintain these bits clear.

4: These registers can be addressed from any bank.

5: PORTD, PORTE, TRISD, and TRISE are not physically implemented on the 28-pin devices, read as '0'.

6: This bit always reads as a '1'.

### 2.2.2.5 PIR1 Register

The PIR1 register contains the individual flag bits for the peripheral interrupts.

| Note: | Interrupt flag bits are set when an interrupt  |
|-------|------------------------------------------------|
|       | condition occurs, regardless of the state of   |
|       | its corresponding enable bit or the global     |
|       | enable bit, GIE (INTCON<7>). User soft-        |
|       | ware should ensure the appropriate interrupt   |
|       | bits are clear prior to enabling an interrupt. |

# REGISTER 2-5: PIR1 REGISTER (ADDRESS 0Ch)

| R/W-0                | R/W-0 | R-0  | R-0  | R/W-0 | R/W-0  | R/W-0  | R/W-0  |
|----------------------|-------|------|------|-------|--------|--------|--------|
| PSPIF <sup>(1)</sup> | ADIF  | RCIF | TXIF | SSPIF | CCP1IF | TMR2IF | TMR1IF |
| bit 7                |       |      |      |       |        |        | bit 0  |

| bit 7 | <b>PSPIF<sup>(1)</sup>:</b> Parallel Slave Port Read/Write Interrupt Flag bit<br>1 = A read or a write operation has taken place (must be cleared in software)<br>0 = No read or write has occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 6 | ADIF: A/D Converter Interrupt Flag bit<br>1 = An A/D conversion is completed (must be cleared in software)<br>0 = The A/D conversion is not complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit 5 | RCIF: USART Receive Interrupt Flag bit<br>1 = The USART receive buffer is full<br>0 = The USART receive buffer is empty                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit 4 | <b>TXIF</b> : USART Transmit Interrupt Flag bit<br>1 = The USART transmit buffer is empty<br>0 = The USART transmit buffer is full                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bit 3 | <ul> <li>SSPIF: Synchronous Serial Port (SSP) Interrupt Flag</li> <li>1 = The SSP interrupt condition has occurred, and must be cleared in software before returning from the Interrupt Service Routine. The conditions that will set this bit are:</li> <li><u>SPI</u> <ul> <li>A transmission/reception has taken place.</li> <li><u>I<sup>2</sup>C Slave</u></li> <li>A transmission/reception has taken place.</li> <li><u>I<sup>2</sup>C Master</u></li> <li>A transmission/reception has taken place.</li> <li>The initiated START condition was completed by the SSP module.</li> <li>The initiated Restart condition was completed by the SSP module.</li> <li>The initiated Restart condition was completed by the SSP module.</li> <li>A START condition occurred while the SSP module was IDLE (multi-master system).</li> <li>A STOP condition has occurred</li> </ul> </li> </ul> |
| bit 2 | CCP1IF: CCP1 Interrupt Flag bit<br><u>Capture mode:</u><br>1 = A TMR1 register capture occurred (must be cleared in software)<br>0 = No TMR1 register capture occurred<br><u>Compare mode:</u><br>1 = A TMR1 register compare match occurred (must be cleared in software)<br>0 = No TMR1 register compare match occurred<br><u>PWM mode:</u><br>Unused in this mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit 1 | <b>TMR2IF</b> : TMR2 to PR2 Match Interrupt Flag bit<br>1 = TMR2 to PR2 match occurred (must be cleared in software)<br>0 = No TMR2 to PR2 match occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| bit 0 | <ul> <li>TMR1IF: TMR1 Overflow Interrupt Flag bit</li> <li>1 = TMR1 register overflowed (must be cleared in software)</li> <li>0 = TMR1 register did not overflow</li> <li>Note 1: PSPIF is reserved on 28-pin devices; always maintain this bit clear.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | Legend:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       | R = Readable bit $W = Writable bit$ $U = Unimplemented bit, read as '0'$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | N = Readable bit W = Witable bit 0 = Offinite Hendrad bit, fead as 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

'1' = Bit is set

'0' = Bit is cleared

- n = Value at POR reset

x = Bit is unknown

#### 2.2.2.6 PIE2 Register

bit 7-1 bit 0

The PIE2 register contains the individual enable bits for the CCP2 peripheral interrupt.

# REGISTER 2-6: PIE2 REGISTER (ADDRESS 8Dh)

| U-0 U-0 U-0 U-0 U-0 U-0 U-0 R/W-0                                                                                                    |  |                                                                                                                                                  |             |        |  |                 |       |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------|--|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------|--|-----------------|-------|--|--|--|--|
| CCP2IE                                                                                                                               |  |                                                                                                                                                  |             |        |  |                 |       |  |  |  |  |
| bit 7 bit 0                                                                                                                          |  |                                                                                                                                                  |             |        |  |                 |       |  |  |  |  |
| Unimplemented: Read as '0'<br>CCP2IE: CCP2 Interrupt Enable bit<br>1 = Enables the CCP2 interrupt<br>0 = Disables the CCP2 interrupt |  |                                                                                                                                                  |             |        |  |                 |       |  |  |  |  |
| Legend:                                                                                                                              |  |                                                                                                                                                  | vitable bit | 11 11. |  | المناهم المراجع | · (0) |  |  |  |  |
|                                                                                                                                      |  | R = Readable bitW = Writable bitU = Unimplemented bit, read as '0'- n = Value at POR reset'1' = Bit is set'0' = Bit is clearedx = Bit is unknown |             |        |  |                 |       |  |  |  |  |

#### 2.2.2.7 PIR2 Register

The PIR2 register contains the flag bits for the CCP2 interrupt.

| Note: | Interrupt flag bits are set when an interrupt |
|-------|-----------------------------------------------|
|       | condition occurs, regardless of the state of  |
|       | its corresponding enable bit or the global    |
|       | enable bit, GIE (INTCON<7>). User soft-       |
|       | ware should ensure the appropriate inter-     |
|       | rupt flag bits are clear prior to enabling an |
|       | interrupt.                                    |

## REGISTER 2-7: PIR2 REGISTER (ADDRESS 0Dh)



#### bit 7-1 Unimplemented: Read as '0'

bit 0 CCP2IF: CCP2 Interrupt Flag bit

Capture mode:

1 = A TMR1 register capture occurred (must be cleared in software)
 0 = No TMR1 register capture occurred
 <u>Compare mode:</u>
 1 = A TMR1 register compare match occurred (must be cleared in software)

1 = A TMRT register compare match occurred (must be cleared 0 = No TMR1 register compare match occurred

PWM mode:

Unused

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

# 4.2 PORTB and the TRISB Register

PORTB is an 8-bit wide, bi-directional port. The corresponding data direction register is TRISB. Setting a TRISB bit (= '1') will make the corresponding PORTB pin an input (i.e., put the corresponding output driver in a Hi-Impedance mode). Clearing a TRISB bit (= '0') will make the corresponding PORTB pin an output (i.e., put the contents of the output latch on the selected pin).

Each of the PORTB pins has a weak internal pull-up. A single control bit can turn on all the pull-ups. This is performed by clearing bit RBPU (OPTION\_REG<7>). The weak pull-up is automatically turned off when the port pin is configured as an output. The pull-ups are disabled on a Power-on Reset.





Four of the PORTB pins (RB7:RB4) have an interrupt-on-change feature. Only pins configured as inputs can cause this interrupt to occur (i.e., any RB7:RB4 pin configured as an output is excluded from the interrupt-on-change comparison). The input pins (of RB7:RB4) are compared with the old value latched on the last read of PORTB. The "mismatch" outputs of RB7:RB4 are ORed together to generate the RB Port Change Interrupt with flag bit RBIF (INTCON<0>). This interrupt can wake the device from SLEEP. The user, in the Interrupt Service Routine, can clear the interrupt in the following manner:

- a) Any read or write of PORTB. This will end the mismatch condition.
- b) Clear flag bit RBIF.

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

The interrupt-on-change feature is recommended for wake-up on key depression operation and operations where PORTB is only used for the interrupt-on-change feature. Polling of PORTB is not recommended while using the interrupt-on-change feature.

This interrupt on mismatch feature, together with software configureable pull-ups on these four pins, allow easy interface to a keypad and make it possible for wake-up on key depression. Refer to the Embedded Control Handbook, "Implementing Wake-up on Key Stroke" (AN552).

RB0/INT is an external interrupt input pin and is configured using the INTEDG bit (OPTION\_REG<6>).

RB0/INT is discussed in detail in Section 12.11.1.

#### FIGURE 4-4: BLOCK DIAGRAM OF RB7:RB4 PINS



#### 5.2 Using Timer0 with an External Clock

When no prescaler is used, the external clock input is the same as the prescaler output. The synchronization of T0CKI, with the internal phase clocks, is accomplished by sampling the prescaler output on the Q2 and Q4 cycles of the internal phase clocks. Therefore, it is necessary for T0CKI to be high for at least 2Tosc (and a small RC delay of 20 ns) and low for at least 2Tosc (and a small RC delay of 20 ns). Refer to the electrical specification of the desired device.

| REGISTER 5-1: | <b>OPTION_REG REGISTER</b> |
|---------------|----------------------------|
|---------------|----------------------------|

|         | R/W-1                                                                                                            | R/W-1                                         | R/W-1        | R/W-1        | R/W-1      | R/W-1 | R/W-1 | R/W-1 |  |  |  |
|---------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------------|--------------|------------|-------|-------|-------|--|--|--|
|         | RBPU                                                                                                             | INTEDG                                        | TOCS         | T0SE         | PSA        | PS2   | PS1   | PS0   |  |  |  |
|         | bit 7                                                                                                            |                                               |              |              |            |       |       | bit 0 |  |  |  |
|         |                                                                                                                  |                                               |              |              |            |       |       |       |  |  |  |
| bit 7   | RBPU: PC                                                                                                         | ORTB Pull-up                                  | Enable bit   | (see Sectior | n 2.2.2.2) |       |       |       |  |  |  |
| bit 6   | INTEDG:                                                                                                          | Interrupt Edg                                 | e Select bit | (see Section | n 2.2.2.2) |       |       |       |  |  |  |
| bit 5   | TOCS: TM                                                                                                         | IR0 Clock Sc                                  | ource Select | bit          |            |       |       |       |  |  |  |
|         |                                                                                                                  | tion on T0Ck<br>al instruction                |              | (CLKOUT)     |            |       |       |       |  |  |  |
| bit 4   | TOSE: TM                                                                                                         | T0SE: TMR0 Source Edge Select bit             |              |              |            |       |       |       |  |  |  |
|         | 1 = Increment on high-to-low transition on T0CKI pin                                                             |                                               |              |              |            |       |       |       |  |  |  |
|         | 0 = Incren                                                                                                       | nent on low-t                                 | o-high trans | ition on TOC | KI pin     |       |       |       |  |  |  |
| bit 3   | PSA: Pres                                                                                                        | scaler Assigr                                 | nment bit    |              |            |       |       |       |  |  |  |
|         | <ul> <li>1 = Prescaler is assigned to the WDT</li> <li>0 = Prescaler is assigned to the Timer0 module</li> </ul> |                                               |              |              |            |       |       |       |  |  |  |
| bit 2-0 | PS2:PS0:                                                                                                         | Prescaler R                                   | ate Select b | its          |            |       |       |       |  |  |  |
|         | Bit Value                                                                                                        | TMR0 Rate                                     | WDT Rate     |              |            |       |       |       |  |  |  |
|         | 000                                                                                                              | 1:2                                           | 1:1          |              |            |       |       |       |  |  |  |
|         | 001                                                                                                              | 1:4<br>1:8                                    | 1:2<br>1:4   |              |            |       |       |       |  |  |  |
|         | 010<br>011                                                                                                       | 1:16                                          | 1:4          |              |            |       |       |       |  |  |  |
|         | 100                                                                                                              | 1:32                                          | 1:16         |              |            |       |       |       |  |  |  |
|         | 101                                                                                                              | 1:64                                          | 1:32         |              |            |       |       |       |  |  |  |
|         | 110                                                                                                              | 1:128                                         | 1:64         |              |            |       |       |       |  |  |  |
|         | 111                                                                                                              | 1 : 256                                       | 1 : 128      |              |            |       |       |       |  |  |  |
|         | Legend:                                                                                                          |                                               |              |              |            |       |       |       |  |  |  |
|         | R = Readable bit $W$ = Writable bit $U$ = Unimplemented bit, read as '0'                                         |                                               |              |              |            |       |       |       |  |  |  |
|         | - n = Value at POR reset '1' = Bit is set '0' = Bit is cleared $x = Bit$ is unknown                              |                                               |              |              |            |       |       |       |  |  |  |
|         |                                                                                                                  |                                               |              |              |            |       |       |       |  |  |  |
|         |                                                                                                                  | To avoid ar                                   |              |              |            |       |       |       |  |  |  |
|         |                                                                                                                  | Example 5-1<br>caler assigni<br>even if the W | ment betwee  | en Timer0 a  |            |       |       |       |  |  |  |

#### 9.3.2 MASTER MODE

Master mode of operation is supported in firmware using interrupt generation on the detection of the START and STOP conditions. The STOP (P) and START (S) bits are cleared from a RESET or when the SSP module is disabled. The STOP (P) and START (S) bits will toggle based on the START and STOP conditions. Control of the I<sup>2</sup>C bus may be taken when the P bit is set, or the bus is IDLE and both the S and P bits are clear.

In Master mode, the SCL and SDA lines are manipulated by clearing the corresponding TRISC<4:3> bit(s). The output level is always low, irrespective of the value(s) in PORTC<4:3>. So when transmitting data, a '1' data bit must have the TRISC<4> bit set (input) and a '0' data bit must have the TRISC<4> bit cleared (output). The same scenario is true for the SCL line with the TRISC<3> bit. Pull-up resistors must be provided externally to the SCL and SDA pins for proper operation of the I<sup>2</sup>C module.

The following events will cause SSP Interrupt Flag bit, SSPIF, to be set (SSP Interrupt will occur if enabled):

- START condition
- STOP condition
- Data transfer byte transmitted/received

Master mode of operation can be done with either the Slave mode IDLE (SSPM3:SSPM0 = 1011), or with the Slave active. When both Master and Slave modes are enabled, the software needs to differentiate the source(s) of the interrupt.

#### 9.3.3 MULTI-MASTER MODE

In Multi-Master mode, the interrupt generation on the detection of the START and STOP conditions, allows the determination of when the bus is free. The STOP (P) and START (S) bits are cleared from a RESET or when the SSP module is disabled. The STOP (P) and START (S) bits will toggle based on the START and STOP conditions. Control of the  $I^2C$  bus may be taken when bit P (SSPSTAT<4>) is set, or the bus is IDLE and both the S and P bits clear. When the bus is busy, enabling the SSP Interrupt will generate the interrupt when the STOP condition occurs.

In Multi-Master operation, the SDA line must be monitored to see if the signal level is the expected output level. This check only needs to be done when a high level is output. If a high level is expected and a low level is present, the device needs to release the SDA and SCL lines (set TRISC<4:3>). There are two stages where this arbitration can be lost, these are:

- Address Transfer
- Data Transfer

When the slave logic is enabled, the slave continues to receive. If arbitration was lost during the address transfer stage, communication to the device may be in progress. If addressed, an ACK pulse will be generated. If arbitration was lost during the data transfer stage, the device will need to retransfer the data at a later time.

| Address                | Name    | Bit 7                | Bit 6                                                    | Bit 5                  | Bit 4   | Bit 3    | Bit 2   | Bit 1  | Bit 0  | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|------------------------|---------|----------------------|----------------------------------------------------------|------------------------|---------|----------|---------|--------|--------|--------------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh | INTCON  | GIE                  | PEIE                                                     | TMR0IE                 | INTE    | RBIE     | TMR0IF  | INTF   | RBIF   | 0000 000x                | 0000 000u                       |
| 0Ch                    | PIR1    | PSPIF <sup>(1)</sup> | ADIF                                                     | RCIF                   | TXIF    | SSPIF    | CCP1IF  | TMR2IF | TMR1IF | 0000 0000                | 0000 0000                       |
| 8Ch                    | PIE1    | PSPIE <sup>(1)</sup> | ADIE                                                     | RCIE                   | TXIE    | SSPIE    | CCP1IE  | TMR2IE | TMR1IE | 0000 0000                | 0000 0000                       |
| 13h                    | SSPBUF  | Synchrono            | Synchronous Serial Port Receive Buffer/Transmit Register |                        |         |          |         |        |        | xxxx xxxx                | uuuu uuuu                       |
| 93h                    | SSPADD  | Synchrono            | us Serial                                                | Port (I <sup>2</sup> C | mode) A | ddress R | egister |        |        | 0000 0000                | 0000 0000                       |
| 14h                    | SSPCON  | WCOL                 | SSPOV                                                    | SSPEN                  | CKP     | SSPM3    | SSPM2   | SSPM1  | SSPM0  | 0000 0000                | 0000 0000                       |
| 94h                    | SSPSTAT | SMP <sup>(2)</sup>   | CKE <sup>(2)</sup>                                       | D/A                    | Р       | S        | R/W     | UA     | BF     | 0000 0000                | 0000 0000                       |
| 87h                    | TRISC   | PORTC Da             | PORTC Data Direction Register                            |                        |         |          |         |        | •      | 1111 1111                | 1111 1111                       |

 TABLE 9-3:
 REGISTERS ASSOCIATED WITH I<sup>2</sup>C OPERATION

Legend: x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by SSP module in I<sup>2</sup>C mode. **Note 1:** PSPIF and PSPIE are reserved on the PIC16F73/76; always maintain these bits clear.

2: Maintain these bits clear in I<sup>2</sup>C mode.

# 10.0 UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (USART)

The Universal Synchronous Asynchronous Receiver Transmitter (USART) module is one of the two serial I/O modules. (USART is also known as a Serial Communications Interface or SCI.) The USART can be configured as a full duplex asynchronous system that can communicate with peripheral devices, such as CRT terminals and personal computers, or it can be configured as a half duplex synchronous system that can communicate with peripheral devices, such as A/D or D/A integrated circuits, serial EEPROMs, etc. The USART can be configured in the following modes:

- Asynchronous (full duplex)
- Synchronous Master (half duplex)
- Synchronous Slave (half duplex)

Bit SPEN (RCSTA<7>) and bits TRISC<7:6> have to be set in order to configure pins RC6/TX/CK and RC7/RX/DT as the Universal Synchronous Asynchronous Receiver Transmitter.

## REGISTER 10-1: TXSTA: TRANSMIT STATUS AND CONTROL REGISTER (ADDRESS 98h)

|        | R/W-0                     | R/W-0                        | R/W-0         | R/W-0        | U-0      | R/W-0      | R-1          | R/W-0 |
|--------|---------------------------|------------------------------|---------------|--------------|----------|------------|--------------|-------|
|        | CSRC                      | TX9                          | TXEN          | SYNC         |          | BRGH       | TRMT         | TX9D  |
|        | bit 7                     |                              |               |              |          |            |              | bit 0 |
| bit 7  | CSRC: Clo                 | ock Source S                 | Select bit    |              |          |            |              |       |
|        | Asynchron                 | ous mode:                    |               |              |          |            |              |       |
|        | Don't care                |                              |               |              |          |            |              |       |
|        | Synchrono                 |                              |               |              |          |            |              |       |
|        |                           | · mode (clock<br>mode (clock |               |              | om BRG)  |            |              |       |
| bit 6  | <b>TX9</b> : 9-bit        | Transmit Ena                 | able bit      |              |          |            |              |       |
|        |                           | s 9-bit transn               |               |              |          |            |              |       |
| 1.11.5 |                           | s 8-bit transn               |               |              |          |            |              |       |
| bit 5  |                           | nsmit Enable<br>nit enabled  | e dit         |              |          |            |              |       |
|        |                           | nit disabled                 |               |              |          |            |              |       |
|        | Note:                     | SREN/CRE                     | N overrides   | TXEN in Sy   | nc mode. |            |              |       |
| bit 4  | SYNC: US                  | ART Mode S                   | Select bit    |              |          |            |              |       |
|        |                           | ronous mode                  |               |              |          |            |              |       |
|        | -                         | nronous mod                  |               |              |          |            |              |       |
| bit 3  | -                         | ented: Read                  |               |              |          |            |              |       |
| bit 2  | -                         | gh Baud Rate                 | e Select bit  |              |          |            |              |       |
|        | Asynchron                 |                              |               |              |          |            |              |       |
|        | 1 = High sp<br>0 = Low sp |                              |               |              |          |            |              |       |
|        | Synchrono                 |                              |               |              |          |            |              |       |
|        | Unused in                 |                              |               |              |          |            |              |       |
| bit 1  | TRMT: Tra                 | nsmit Shift R                | Register Stat | us bit       |          |            |              |       |
|        | 1 = TSR ei                |                              |               |              |          |            |              |       |
| 1 1 0  | 0 = TSR fu                |                              |               |              |          |            |              |       |
| bit 0  | Can be par                | bit of Transr                | nit Data      |              |          |            |              |       |
|        | oun be pu                 |                              |               |              |          |            |              |       |
|        | Legend:                   |                              |               |              |          |            |              |       |
|        | R = Reada                 | ble bit                      | W = W         | /ritable bit | U = Unir | nplemented | bit, read as | ʻ0'   |

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

# 10.2 USART Asynchronous Mode

In this mode, the USART uses standard non-return-tozero (NRZ) format (one START bit, eight or nine data bits, and one STOP bit). The most common data format is 8-bits. An on-chip, dedicated, 8-bit baud rate generator can be used to derive standard baud rate frequencies from the oscillator. The USART transmits and receives the LSb first. The USART's transmitter and receiver are functionally independent, but use the same data format and baud rate. The baud rate generator produces a clock, either x16 or x64 of the bit shift rate, depending on bit BRGH (TXSTA<2>). Parity is not supported by the hardware, but can be implemented in software (and stored as the ninth data bit). Asynchronous mode is stopped during SLEEP.

Asynchronous mode is selected by clearing bit SYNC (TXSTA<4>).

The USART Asynchronous module consists of the following important elements:

- · Baud Rate Generator
- Sampling Circuit
- Asynchronous Transmitter
- Asynchronous Receiver

#### 10.2.1 USART ASYNCHRONOUS TRANSMITTER

The USART transmitter block diagram is shown in Figure 10-1. The heart of the transmitter is the transmit (serial) shift register (TSR). The shift register obtains its data from the read/write transmit buffer, TXREG. The TXREG register is loaded with data by firmware. The TSR register is not loaded until the STOP bit has been transmitted from the previous load. As soon as the STOP bit is transmitted, the TSR is loaded with new data from the TXREG register (if available). Once the TXREG register transfers the data to the TSR register, the TXREG register is empty. One instruction cycle later, flag bit TXIF (PIR1<4>) and flag bit TRMT (TXSTA<1>)

are set. The TXIF interrupt can be enabled/disabled by setting/clearing enable bit TXIE (PIE1<4>). Flag bit TXIF will be set, regardless of the state of enable bit TXIE and cannot be cleared in software. It will reset only when new data is loaded into the TXREG register. While flag bit TXIF indicates the status of the TXREG register, another bit TRMT (TXSTA<1>) shows the status of the TSR register. Status bit TRMT is a read only bit, which is set one instruction cycle after the TSR register becomes empty, and is cleared one instruction cycle after the TSR register is loaded. No interrupt logic is tied to this bit, so the user has to poll this bit in order to determine if the TSR register is empty.

| Note 1: | The TSR register is not mapped in data      |
|---------|---------------------------------------------|
|         | memory, so it is not available to the user. |
| 2:      | Flag bit TXIF is set when enable bit TXEN   |

is set. TXIF is cleared by loading TXREG.

Transmission is enabled by setting enable bit TXEN (TXSTA<5>). The actual transmission will not occur until the TXREG register has been loaded with data and the baud rate generator (BRG) has produced a shift clock (Figure 10-2). The transmission can also be started by first loading the TXREG register and then setting enable bit TXEN. Normally, when transmission is first started, the TSR register is empty. At that point, transfer to the TXREG register will result in an immediate transfer to TSR, resulting in an empty TXREG. A back-to-back transfer is thus possible (Figure 10-3). Clearing enable bit TXEN during a transmission will cause the transmission to be aborted and will reset the transmitter. As a result, the RC6/TX/CK pin will revert to hi-impedance.

In order to select 9-bit transmission, transmit bit TX9 (TXSTA<6>) should be set and the ninth bit should be written to TX9D (TXSTA<0>). The ninth bit must be written before writing the 8-bit data to the TXREG register. This is because a data write to the TXREG register can result in an immediate transfer of the data to the TSR register (if the TSR is empty). In such a case, an incorrect ninth data bit may be loaded in the TSR register.



## FIGURE 10-1: USART TRANSMIT BLOCK DIAGRAM

Steps to follow when setting up an Asynchronous Transmission:

- 1. Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, set bit BRGH (Section 10.1).
- 2. Enable the asynchronous serial port by clearing bit SYNC and setting bit SPEN.
- 3. If interrupts are desired, then set enable bit TXIE.
- 4. If 9-bit transmission is desired, then set transmit bit TX9.

- 5. Enable the transmission by setting bit TXEN, which will also set bit TXIF.
- 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D.
- 7. Load data to the TXREG register (starts transmission).
- 8. If using interrupts, ensure that GIE and PEIE in the INTCON register are set.

## FIGURE 10-2: ASYNCHRONOUS MASTER TRANSMISSION



#### FIGURE 10-3: ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK)



#### TABLE 10-5: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION

| Address                | Name   | Bit 7                             | Bit 6     | Bit 5   | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0     | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|------------------------|--------|-----------------------------------|-----------|---------|-------|-------|--------|--------|-----------|--------------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh | INTCON | GIE                               | PEIE      | TMR0IE  | INTE  | RBIE  | TMR0IF | INTF   | RBIF      | 0000 000x                | 0000 000u                       |
| 0Ch                    | PIR1   | PSPIF <sup>(1)</sup>              | ADIF      | RCIF    | TXIF  | SSPIF | CCP1IF | TMR2IF | TMR1IF    | 0000 0000                | 0000 0000                       |
| 18h                    | RCSTA  | SPEN                              | RX9       | SREN    | CREN  |       | FERR   | OERR   | RX9D      | x00-000x                 | x00- 0000                       |
| 19h                    | TXREG  | USART Tra                         | ansmit Re | egister |       |       |        |        |           | 0000 0000                | 0000 0000                       |
| 8Ch                    | PIE1   | PSPIE <sup>(1)</sup>              | ADIE      | RCIE    | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE    | 0000 0000                | 0000 0000                       |
| 98h                    | TXSTA  | CSRC                              | TX9       | TXEN    | SYNC  |       | BRGH   | TRMT   | TX9D      | 0000 -010                | 0000 -010                       |
| 99h                    | SPBRG  | Baud Rate Generator Register 0000 |           |         |       |       |        |        | 0000 0000 | 0000 0000                |                                 |

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for asynchronous transmission. Note 1: Bits PSPIE and PSPIF are reserved on the PIC16F73/76; always maintain these bits clear.



#### FIGURE 10-5: ASYNCHRONOUS RECEPTION

Steps to follow when setting up an Asynchronous Reception:

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

- 6. Flag bit RCIF will be set when reception is complete and an interrupt will be generated if enable bit RCIE is set.
- 7. Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 8. Read the 8-bit received data by reading the RCREG register.
- 9. If any error occurred, clear the error by clearing enable bit CREN.
- 10. If using interrupts, ensure that GIE and PEIE in the INTCON register are set.

| Address                | Name   | Bit 7                | Bit 6                        | Bit 5  | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Value on:<br>POR,<br>BOR | Value on<br>all other<br>RESETS |
|------------------------|--------|----------------------|------------------------------|--------|-------|-------|--------|--------|--------|--------------------------|---------------------------------|
| 0Bh, 8Bh,<br>10Bh,18Bh | INTCON | GIE                  | PEIE                         | TMR0IE | INTE  | RBIE  | TMR0IF | INTF   | RBIF   | 0000 000x                | 0000 000u                       |
| 0Ch                    | PIR1   | PSPIF <sup>(1)</sup> | ADIF                         | RCIF   | TXIF  | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 0000                | 0000 0000                       |
| 18h                    | RCSTA  | SPEN                 | RX9                          | SREN   | CREN  |       | FERR   | OERR   | RX9D   | 0000 -00x                | 0000 -00x                       |
| 1Ah                    | RCREG  | USART R              | eceive Re                    | gister |       |       |        |        |        | 0000 0000                | 0000 0000                       |
| 8Ch                    | PIE1   | PSPIE <sup>(1)</sup> | ADIE                         | RCIE   | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 0000                | 0000 0000                       |
| 98h                    | TXSTA  | CSRC                 | TX9                          | TXEN   | SYNC  |       | BRGH   | TRMT   | TX9D   | 0000 -010                | 0000 -010                       |
| 99h                    | SPBRG  | Baud Rate            | Baud Rate Generator Register |        |       |       |        |        |        | 0000 0000                | 0000 0000                       |

## TABLE 10-6: REGISTERS ASSOCIATED WITH ASYNCHRONOUS RECEPTION

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for asynchronous reception. Note 1: Bits PSPIE and PSPIF are reserved on the PIC16F73/76 devices; always maintain these bits clear.

# 11.1 A/D Acquisition Requirements

For the A/D converter to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The analog input model is shown in Figure 11-2. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), see Figure 11-2. The source impedance affects the offset voltage at the analog input (due to pin leakage current). The maximum recommended impedance for analog sources is 10 k $\Omega$ . After the analog input channel is selected (changed), the acquisition period must pass before the conversion can be started.

To calculate the minimum acquisition time, TACQ, see the PICmicro<sup>TM</sup> Mid-Range MCU Family Reference Manual (DS33023). In general, however, given a maximum source impedance of 10 k $\Omega$  and at a temperature of 100°C, TACQ will be no more than 16 µsec.



# TABLE 11-1: TAD vs. MAXIMUM DEVICE OPERATING FREQUENCIES (STANDARD DEVICES (C))

| AD Cloc                 | AD Clock Source (TAD) |          |  |  |  |
|-------------------------|-----------------------|----------|--|--|--|
| Operation               | ADCS1:ADCS0           | Max.     |  |  |  |
| 2Tosc                   | 0.0                   | 1.25 MHz |  |  |  |
| 8Tosc                   | 01                    | 5 MHz    |  |  |  |
| 32Tosc                  | 10                    | 20 MHz   |  |  |  |
| RC <sup>(1, 2, 3)</sup> | 11                    | (Note 1) |  |  |  |

Note 1: The RC source has a typical TAD time of 4 µs but can vary between 2-6 µs.

2: When the device frequencies are greater than 1 MHz, the RC A/D conversion clock source is only recommended for SLEEP operation.

3: For extended voltage devices (LC), please refer to the Electrical Specifications section.

# 13.2 Instruction Descriptions

| ADDLW            | Add Literal and W                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ADDLW k                                                                                                   |
| Operands:        | $0 \le k \le 255$                                                                                                          |
| Operation:       | $(W) + k \to (W)$                                                                                                          |
| Status Affected: | C, DC, Z                                                                                                                   |
| Description:     | The contents of the W register<br>are added to the eight-bit literal 'k'<br>and the result is placed in the W<br>register. |

| ADDWF            | Add W and f                                                                                                                                                                    |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] ADDWF f,d                                                                                                                                                              |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                             |
| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                                          |
| Status Affected: | C, DC, Z                                                                                                                                                                       |
| Description:     | Add the contents of the W register<br>with register 'f'. If 'd' is 0, the result<br>is stored in the W register. If 'd' is<br>1, the result is stored back in<br>register 'f'. |

| BCF              | Bit Clear f                                                         |  |  |  |  |
|------------------|---------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] BCF f,b                                            |  |  |  |  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |  |  |  |  |
| Operation:       | $0 \rightarrow (f < b >)$                                           |  |  |  |  |
| Status Affected: | None                                                                |  |  |  |  |
| Description:     | Bit 'b' in register 'f' is cleared.                                 |  |  |  |  |

| BSF              | Bit Set f                                                           |
|------------------|---------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] BSF f,b                                            |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |
| Operation:       | $1 \rightarrow (f < b >)$                                           |
| Status Affected: | None                                                                |
| Description:     | Bit 'b' in register 'f' is set.                                     |

| ANDLW            | AND Literal with W                                                                                                     |
|------------------|------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] ANDLW k                                                                                               |
| Operands:        | $0 \le k \le 255$                                                                                                      |
| Operation:       | (W) .AND. (k) $\rightarrow$ (W)                                                                                        |
| Status Affected: | Z                                                                                                                      |
| Description:     | The contents of W register are<br>AND'ed with the eight-bit literal<br>'k'. The result is placed in the W<br>register. |

| BTFSS            | Bit Test f, Skip if Set                                                                                                                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSS f,b                                                                                                                                                                                            |
| Operands:        | $0 \le f \le 127$<br>$0 \le b < 7$                                                                                                                                                                             |
| Operation:       | skip if (f <b>) = 1</b>                                                                                                                                                                                        |
| Status Affected: | None                                                                                                                                                                                                           |
| Description:     | If bit 'b' in register 'f' is '0', the next<br>instruction is executed.<br>If bit 'b' is '1', then the next instruc-<br>tion is discarded and a NOP is<br>executed instead, making this a<br>2TcY instruction. |

| ANDWF            | AND W with f                                                                                                                                                |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Syntax:          | [label] ANDWF f,d                                                                                                                                           |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                          |  |
| Operation:       | (W) .AND. (f) $\rightarrow$ (destination)                                                                                                                   |  |
| Status Affected: | Z                                                                                                                                                           |  |
| Description:     | AND the W register with register<br>'f'. If 'd' is 0, the result is stored in<br>the W register. If 'd' is 1, the result<br>is stored back in register 'f'. |  |

| BTFSC            | Bit Test, Skip if Clear                                                                                                                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ label ] BTFSC f,b                                                                                                                                                                                            |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$                                                                                                                                            |
| Operation:       | skip if (f <b>) = 0</b>                                                                                                                                                                                        |
| Status Affected: | None                                                                                                                                                                                                           |
| Description:     | If bit 'b' in register 'f' is '1', the next instruction is executed.<br>If bit 'b', in register 'f', is '0', the next instruction is discarded, and a NOP is executed instead, making this a 2TCY instruction. |

# FIGURE 16-7: AVERAGE FOSC vs. VDD FOR VARIOUS VALUES OF R (RC MODE, C = 20 pF, 25°C)



FIGURE 16-8: AVERAGE Fosc vs. VDD FOR VARIOUS VALUES OF R (RC MODE, C = 100 pF, 25°C)





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







#### FIGURE 16-19: MINIMUM AND MAXIMUM VIN vs. VDD, (TTL INPUT, -40°C TO 125°C)





44-Lead Plastic Thin Quad Flatpack (PT) 10x10x1 mm Body, 1.0/0.10 mm Lead Form (TQFP)



|                          | Units    | INCHES |      |      | MILLIMETERS* |       |       |
|--------------------------|----------|--------|------|------|--------------|-------|-------|
| Dimensior                | n Limits | MIN    | NOM  | MAX  | MIN          | NOM   | MAX   |
| Number of Pins           | n        |        | 44   |      |              | 44    |       |
| Pitch                    | р        |        | .031 |      |              | 0.80  |       |
| Pins per Side            | n1       |        | 11   |      |              | 11    |       |
| Overall Height           | А        | .039   | .043 | .047 | 1.00         | 1.10  | 1.20  |
| Molded Package Thickness | A2       | .037   | .039 | .041 | 0.95         | 1.00  | 1.05  |
| Standoff §               | A1       | .002   | .004 | .006 | 0.05         | 0.10  | 0.15  |
| Foot Length              | L        | .018   | .024 | .030 | 0.45         | 0.60  | 0.75  |
| Footprint (Reference)    | (F)      |        | .039 |      | 1.00         |       |       |
| Foot Angle               | φ        | 0      | 3.5  | 7    | 0            | 3.5   | 7     |
| Overall Width            | Е        | .463   | .472 | .482 | 11.75        | 12.00 | 12.25 |
| Overall Length           | D        | .463   | .472 | .482 | 11.75        | 12.00 | 12.25 |
| Molded Package Width     | E1       | .390   | .394 | .398 | 9.90         | 10.00 | 10.10 |
| Molded Package Length    | D1       | .390   | .394 | .398 | 9.90         | 10.00 | 10.10 |
| Lead Thickness           | С        | .004   | .006 | .008 | 0.09         | 0.15  | 0.20  |
| Lead Width               | В        | .012   | .015 | .017 | 0.30         | 0.38  | 0.44  |
| Pin 1 Corner Chamfer     | СН       | .025   | .035 | .045 | 0.64         | 0.89  | 1.14  |
| Mold Draft Angle Top     | α        | 5      | 10   | 15   | 5            | 10    | 15    |
| Mold Draft Angle Bottom  | β        | 5      | 10   | 15   | 5            | 10    | 15    |

\* Controlling Parameter § Significant Characteristic

Notes:

Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed .010" (0.254mm) per side. JEDEC Equivalent: MS-026 Drawing No. C04-076

| USART Synchronous Transmission       |    |
|--------------------------------------|----|
| (Through TXEN)                       |    |
| Wake-up from SLEEP via Interrupt1    |    |
| Watchdog Timer1                      |    |
| Timing Parameter Symbology1          | 25 |
| Timing Requirements                  |    |
| Capture/Compare/PWM (CCP1 and CCP2)1 |    |
| CLKOUT and I/O1                      |    |
| External Clock1                      | -  |
| I <sup>2</sup> C Bus Data1           | 36 |
| I2C Bus START/STOP Bits1             | 35 |
| Parallel Slave Port1                 | 31 |
| RESET, Watchdog Timer, Oscillator    |    |
| Start-up Timer, Power-up Timer       |    |
| and Brown-out Reset1                 | 28 |
| SPI Mode1                            | 34 |
| Timer0 and Timer1 External Clock1    | 29 |
| USART Synchronous Receive1           |    |
| USART Synchronous Transmission1      |    |
| TMR1CS bit                           |    |
| TMR10N bit                           | 47 |
| TMR2ON bit                           |    |
| TOUTPS<3:0> bits                     | -  |
| TRISA Register                       | -  |
| TRISB Register                       |    |
| TRISC Register                       |    |
| TRISD Register                       |    |
| TRISE Register                       |    |
| IBF Bit                              |    |
| IBOV Bit                             |    |
| PSPMODE bit                          |    |
| TXSTA Register                       | 01 |
| SYNC bit                             | 69 |
| TRMT bit                             |    |
| TX9 bit                              |    |
| TX9 bit                              |    |
| TXEN bit                             |    |
|                                      | 09 |
| U                                    |    |

| UA6                                | 60         |
|------------------------------------|------------|
| Universal Synchronous Asynchronous |            |
| Receiver Transmitter. See USART    |            |
| Update Address bit, UA6            | 60         |
| USART6                             | 39         |
| Asynchronous Mode7                 | '3         |
| Asynchronous Receiver7             | '5         |
| Asynchronous Reception7            | '6         |
| Associated Registers7              | <i>'</i> 6 |
| Asynchronous Transmission          |            |
| Associated Registers7              | <b>'</b> 4 |
| Asynchronous Transmitter7          | '3         |

| Baud Rate Generator (BRG)71                  |
|----------------------------------------------|
| Baud Rate Formula                            |
| Baud Rates, Asynchronous Mode                |
| (BRGH = 0)                                   |
| Baud Rates, Asynchronous Mode                |
| (BRGH = 1)                                   |
| Sampling71                                   |
| Mode Select (SYNC Bit) 69                    |
| Overrun Error (OERR Bit)                     |
| RC6/TX/CK Pin9, 11                           |
| RC7/RX/DT Pin9, 11                           |
| Serial Port Enable (SPEN Bit)                |
| Single Receive Enable (SREN Bit)70           |
| Synchronous Master Mode77                    |
| Synchronous Master Reception                 |
| Associated Registers 80                      |
| Synchronous Master Transmission              |
| Associated Registers                         |
| Synchronous Slave Mode 80                    |
| Synchronous Slave Reception                  |
| Associated Registers 81                      |
| Synchronous Slave Transmission               |
| Associated Registers81                       |
| Transmit Data, 9th Bit (TX9D)69              |
| Transmit Enable (TXEN bit)69                 |
| Transmit Enable, Nine-bit (TX9 bit)          |
| Transmit Shift Register Status (TRMT bit) 69 |

# W

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

# **ON-LINE SUPPORT**

Microchip provides on-line support on the Microchip World Wide Web (WWW) site.

The web site is used by Microchip as a means to make files and information easily available to customers. To view the site, the user must have access to the Internet and a web browser, such as Netscape or Microsoft Explorer. Files are also available for FTP download from our FTP site.

#### Connecting to the Microchip Internet Web Site

The Microchip web site is available by using your favorite Internet browser to attach to:

#### www.microchip.com

The file transfer site is available by using an FTP service to connect to:

#### ftp://ftp.microchip.com

The web site and file transfer site provide a variety of services. Users may download files for the latest Development Tools, Data Sheets, Application Notes, User's Guides, Articles and Sample Programs. A variety of Microchip specific business information is also available, including listings of Microchip sales offices, distributors and factory representatives. Other data available for consideration is:

- Latest Microchip Press Releases
- Technical Support Section with Frequently Asked
   Questions
- Design Tips
- Device Errata
- Job Postings
- Microchip Consultant Program Member Listing
- Links to other useful web sites related to Microchip Products
- Conferences for products, Development Systems, technical information and more
- · Listing of seminars and events

#### Systems Information and Upgrade Hot Line

The Systems Information and Upgrade Line provides system users a listing of the latest versions of all of Microchip's development systems software products. Plus, this line provides information on how customers can receive any currently available upgrade kits.The Hot Line Numbers are:

1-800-755-2345 for U.S. and most of Canada, and

1-480-792-7302 for the rest of the world.

013001