



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

| Details                    |                                                                            |
|----------------------------|----------------------------------------------------------------------------|
| Product Status             | Active                                                                     |
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 10MHz                                                                      |
| 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        | OTP                                                                        |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 192 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | $4V \sim 6V$                                                               |
| Data Converters            | A/D 5x8b                                                                   |
| Oscillator Type            | External                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                             |
| Supplier Device Package    | 28-SOIC                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c73a-10i-so |
|                            |                                                                            |

Email: info@E-XFL.COM

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

|            |                                                 | PIC16C710                           | PIC16C71            | PIC16C711                           | PIC16C715                           | PIC16C72                   | PIC16CR72 <sup>(1)</sup>   |
|------------|-------------------------------------------------|-------------------------------------|---------------------|-------------------------------------|-------------------------------------|----------------------------|----------------------------|
| Clock      | Maximum Frequency<br>of Operation (MHz)         | 20                                  | 20                  | 20                                  | 20                                  | 20                         | 20                         |
|            | EPROM Program Memory<br>(x14 words)             | 512                                 | 1K                  | 1K                                  | 2К                                  | 2К                         | —                          |
| lemory     | ROM Program Memory<br>(14K words)               | _                                   | _                   | _                                   | _                                   | _                          | 2К                         |
|            | Data Memory (bytes)                             | 36                                  | 36                  | 68                                  | 128                                 | 128                        | 128                        |
|            | Timer Module(s)                                 | TMR0                                | TMR0                | TMR0                                | TMR0                                | TMR0,<br>TMR1,<br>TMR2     | TMR0,<br>TMR1,<br>TMR2     |
| eripherals | Capture/Compare/<br>PWM Module(s)               | —                                   | _                   | —                                   | —                                   | 1                          | 1                          |
|            | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | _                                   | _                   | —                                   | —                                   | SPI/I <sup>2</sup> C       | SPI/I <sup>2</sup> C       |
|            | Parallel Slave Port                             | _                                   | —                   | —                                   | _                                   | _                          | —                          |
|            | A/D Converter (8-bit) Channels                  | 4                                   | 4                   | 4                                   | 4                                   | 5                          | 5                          |
|            | Interrupt Sources                               | 4                                   | 4                   | 4                                   | 4                                   | 8                          | 8                          |
|            | I/O Pins                                        | 13                                  | 13                  | 13                                  | 13                                  | 22                         | 22                         |
|            | Voltage Range (Volts)                           | 3.0-6.0                             | 3.0-6.0             | 3.0-6.0                             | 3.0-5.5                             | 2.5-6.0                    | 3.0-5.5                    |
| atures     | In-Circuit Serial Programming                   | Yes                                 | Yes                 | Yes                                 | Yes                                 | Yes                        | Yes                        |
|            | Brown-out Reset                                 | Yes                                 | —                   | Yes                                 | Yes                                 | Yes                        | Yes                        |
|            | Packages                                        | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 18-pin DIP,<br>SOIC;<br>20-pin SSOP | 28-pin SDIP,<br>SOIC, SSOP | 28-pin SDIP,<br>SOIC, SSOP |

# TABLE 1-1: PIC16C7XX FAMILY OF DEVCES

|             |                                                   | PIC16C73A                   | PIC16C74A                                 | PIC16C76                    | PIC16C77                                  |
|-------------|---------------------------------------------------|-----------------------------|-------------------------------------------|-----------------------------|-------------------------------------------|
| Clock       | Maximum Frequency of Oper-<br>ation (MHz)         | 20                          | 20                                        | 20                          | 20                                        |
| Memory      | EPROM Program Memory<br>(x14 words)               | 4K                          | 4K                                        | 8K                          | 8K                                        |
|             | Data Memory (bytes)                               | 192                         | 192                                       | 368                         | 368                                       |
|             | Timer Module(s)                                   | TMR0,<br>TMR1,<br>TMR2      | TMR0,<br>TMR1,<br>TMR2                    | TMR0,<br>TMR1,<br>TMR2      | TMR0,<br>TMR1,<br>TMR2                    |
| Peripherals | Capture/Compare/PWM Mod-<br>ule(s)                | 2                           | 2                                         | 2                           | 2                                         |
|             | Serial Port(s) (SPI/I <sup>2</sup> C, US-<br>ART) | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART               | SPI/I <sup>2</sup> C, USART | SPI/I <sup>2</sup> C, USART               |
|             | Parallel Slave Port                               | —                           | Yes                                       | —                           | Yes                                       |
|             | A/D Converter (8-bit) Channels                    | 5                           | 8                                         | 5                           | 8                                         |
|             | Interrupt Sources                                 | 11                          | 12                                        | 11                          | 12                                        |
|             | I/O Pins                                          | 22                          | 33                                        | 22                          | 33                                        |
|             | Voltage Range (Volts)                             | 2.5-6.0                     | 2.5-6.0                                   | 2.5-6.0                     | 2.5-6.0                                   |
| eatures     | In-Circuit Serial Programming                     | Yes                         | Yes                                       | Yes                         | Yes                                       |
|             | Brown-out Reset                                   | Yes                         | Yes                                       | Yes                         | Yes                                       |
|             | Packages                                          | 28-pin SDIP,<br>SOIC        | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP | 28-pin SDIP,<br>SOIC        | 40-pin DIP;<br>44-pin PLCC,<br>MQFP, TQFP |

All PIC16/17 Family devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC16C7XX Family devices use serial programming with clock pin RB6 and data pin RB7.

Note 1: Please contact your local Microchip sales office for availability of these devices.

NOTES:

# 3.0 ARCHITECTURAL OVERVIEW

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

The table below lists program memory (EPROM) and data memory (RAM) for each PIC16C7X device.

| Device    | Program<br>Memory | Data Memory |
|-----------|-------------------|-------------|
| PIC16C72  | 2K x 14           | 128 x 8     |
| PIC16C73  | 4K x 14           | 192 x 8     |
| PIC16C73A | 4K x 14           | 192 x 8     |
| PIC16C74  | 4K x 14           | 192 x 8     |
| PIC16C74A | 4K x 14           | 192 x 8     |
| PIC16C76  | 8K x 14           | 368 x 8     |
| PIC16C77  | 8K x 14           | 386 x 8     |

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

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

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

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

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





# FIGURE 4-4: PIC16C72 REGISTER FILE MAP

| File<br>Address   | 3                     |                     | File<br>Address |
|-------------------|-----------------------|---------------------|-----------------|
| 00h               | INDF <sup>(1)</sup>   | INDF <sup>(1)</sup> | 80h             |
| 01h               | TMR0                  | OPTION              | 81h             |
| 02h               | PCL                   | PCL                 |                 |
| 03h               | STATUS                | STATUS              |                 |
| 04h               | FSR                   | FSR                 |                 |
| 05h               | PORTA                 | TRISA               | 85h             |
| 06h               | PORTB                 | TRISB               | 86h             |
| 07h               | PORTC                 | TRISC               |                 |
| 08h               |                       |                     |                 |
| 09h               |                       |                     | 89h             |
| 0Ah               | PCLATH                | PCLATH              | 8Ah             |
| 0Bh               | INTCON                | INTCON              | 8Bh             |
| 0Ch               | PIR1                  | PIE1                | 8Ch             |
| 0Dh               |                       |                     | 8Dh             |
| 0Eh               | TMR1L                 | PCON                | 8Eh             |
| 0Fh               | TMR1H                 |                     | 8Fh             |
| 10h               | T1CON                 |                     | 90h             |
| 11h               | TMR2                  |                     | 91h             |
| 12h               | T2CON                 | PR2                 | 92h             |
| 13h               | SSPBUF                | SSPADD              | 93h             |
| 14h               | SSPCON                | SSPSTAT             |                 |
| 15h               | CCPR1L                |                     | 95h             |
| 16h               | CCPR1H                |                     | 96h             |
| 17h               | CCP1CON               |                     | 97h             |
| 18h               |                       |                     | 98h             |
| 19h               |                       |                     | 99h             |
| 1Ah               |                       |                     | 9Ah             |
| 1Bh               |                       |                     | 9Bh             |
| 1Ch               |                       |                     | 9Ch             |
| 1Dh               |                       |                     | 9Dh             |
| 1Eh               | ADRES                 |                     | 9Eh             |
| 1Fh               | ADCON0                | ADCON1              | 9Fh             |
| 20h               |                       |                     | A0h             |
|                   | General<br>Purpose    | General<br>Purpose  |                 |
|                   | Register              | Register            |                 |
|                   | U U                   |                     | BFh             |
|                   |                       |                     | C0h             |
|                   |                       |                     |                 |
| 1                 |                       |                     |                 |
|                   |                       |                     |                 |
| 7Fh               |                       |                     | FFh             |
|                   | Bank 0                | Bank 1              |                 |
|                   |                       |                     |                 |
|                   | nimplemented data     | a memory locations  | s, read as      |
| '0'.<br>Note 1: 1 | Not a physical regis  | stor                |                 |
|                   | tot a priysical regit | лот.                |                 |
|                   |                       |                     |                 |

#### FIGURE 4-5: PIC16C73/73A/74/74A REGISTER FILE MAP

| REGISTER FILE MAP |                                                               |                                |                 |  |  |  |  |  |  |
|-------------------|---------------------------------------------------------------|--------------------------------|-----------------|--|--|--|--|--|--|
| File<br>Addres    | SS                                                            |                                | File<br>Address |  |  |  |  |  |  |
| 00h               | INDF <sup>(1)</sup>                                           | INDF <sup>(1)</sup>            | 80h             |  |  |  |  |  |  |
| 01h               | TMR0                                                          | OPTION                         |                 |  |  |  |  |  |  |
| 02h               | PCL                                                           | PCL                            | 82h             |  |  |  |  |  |  |
| 03h               | STATUS                                                        | STATUS                         | 83h             |  |  |  |  |  |  |
| 04h               | FSR                                                           | FSR                            |                 |  |  |  |  |  |  |
| 05h               | PORTA                                                         | TRISA                          | 85h             |  |  |  |  |  |  |
| 06h               | PORTB                                                         | TRISB                          | 86h             |  |  |  |  |  |  |
| 07h               | PORTC                                                         | TRISC                          |                 |  |  |  |  |  |  |
| 08h               | PORTD <sup>(2)</sup>                                          | TRISD <sup>(2)</sup>           |                 |  |  |  |  |  |  |
| 09h               | PORTE <sup>(2)</sup>                                          | TRISE <sup>(2)</sup>           | 89h             |  |  |  |  |  |  |
| 0Ah               | PCLATH                                                        | PCLATH                         | 8Ah             |  |  |  |  |  |  |
| 0Bh               | INTCON                                                        | INTCON                         | 8Bh             |  |  |  |  |  |  |
| 0Ch               | PIR1                                                          | PIE1                           | 8Ch             |  |  |  |  |  |  |
| 0Dh               | PIR2                                                          | PIE2                           | 8Dh             |  |  |  |  |  |  |
| 0Eh               | TMR1L                                                         | PCON                           | 8Eh             |  |  |  |  |  |  |
| 0Fh               | TMR1H                                                         |                                | 8Fh             |  |  |  |  |  |  |
| 10h               | T1CON                                                         |                                | 90h             |  |  |  |  |  |  |
| 11h               | TMR2                                                          |                                | 91h             |  |  |  |  |  |  |
| 12h               | T2CON                                                         | PR2                            |                 |  |  |  |  |  |  |
| 13h               | SSPBUF                                                        | SSPADD                         | 93h             |  |  |  |  |  |  |
| 14h               | SSPCON                                                        | SSPSTAT                        | 94h             |  |  |  |  |  |  |
| 15h               | CCPR1L                                                        |                                | 95h             |  |  |  |  |  |  |
| 16h               | CCPR1H                                                        |                                | 96h             |  |  |  |  |  |  |
| 17h               | CCP1CON                                                       |                                | 97h             |  |  |  |  |  |  |
| 18h               | RCSTA                                                         | TXSTA                          |                 |  |  |  |  |  |  |
| 19h               | TXREG                                                         | SPBRG                          | 99h             |  |  |  |  |  |  |
| 1Ah               | RCREG                                                         |                                | 9Ah             |  |  |  |  |  |  |
| 1Bh               | CCPR2L                                                        |                                | 9Bh             |  |  |  |  |  |  |
| 1Ch               | CCPR2H                                                        |                                | 9Ch             |  |  |  |  |  |  |
| 1Dh               | CCP2CON                                                       |                                | 9Dh             |  |  |  |  |  |  |
| 1Eh               | ADRES                                                         |                                | 9Eh             |  |  |  |  |  |  |
| 1Fh               | ADCON0                                                        | ADCON1                         | 9Fh             |  |  |  |  |  |  |
| 20h               |                                                               |                                | A0h             |  |  |  |  |  |  |
|                   | General<br>Purpose<br>Register                                | General<br>Purpose<br>Register |                 |  |  |  |  |  |  |
| 7Fh               |                                                               |                                | FFh             |  |  |  |  |  |  |
|                   | Bank 0                                                        | Bank 1                         |                 |  |  |  |  |  |  |
|                   | Unimplemented da                                              | -                              | ons, read as    |  |  |  |  |  |  |
| Note 1:<br>2:     | Not a physical reg<br>These registers ar<br>mented on the PIC | e not physically               |                 |  |  |  |  |  |  |
|                   |                                                               |                                |                 |  |  |  |  |  |  |

#### FIGURE 4-6: PIC16C76/77 REGISTER FILE MAP

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

**Note:** The upper 16 bytes of data memory in banks 1, 2, and 3 are mapped in Bank 0. This may require relocation of data memory usage in the user application code if upgrading to the PIC16C76/77.

# PIC16C7X



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

#### FIGURE 7-4: TIMER0 INTERRUPT TIMING



The  $\overline{SS}$  pin allows a synchronous slave mode. The SPI must be in slave mode (SSPCON<3:0> = 04h) and the TRISA<5> bit must be set the for synchronous slave mode to be enabled. When the  $\overline{SS}$  pin is low, transmission and reception are enabled and the SDO pin is driven. When the  $\overline{SS}$  pin goes high, the SDO pin is no longer driven, even if in the middle of a transmitted byte, and becomes a floating output. If the  $\overline{SS}$  pin is taken low without resetting SPI mode, the transmission will continue from the

point at which it was taken high. External pull-up/ pull-down resistors may be desirable, depending on the application.

To emulate two-wire communication, the SDO pin can be connected to the SDI pin. When the SPI needs to operate as a receiver the SDO pin can be configured as an input. This disables transmissions from the SDO. The SDI can always be left as an input (SDI function) since it cannot create a bus conflict.









|  | <b>TABLE 11-1:</b> | <b>REGISTERS ASSOCIATED WITH SPI OPERATION</b> |
|--|--------------------|------------------------------------------------|
|--|--------------------|------------------------------------------------|

| Address | Name    | Bit 7                  | Bit 6       | Bit 5               | Bit 4                         | Bit 3     | Bit 2    | Bit 1  | Bit 0  | Value<br>POF<br>BOF | ٦,   | all o | e on<br>ther<br>ets |
|---------|---------|------------------------|-------------|---------------------|-------------------------------|-----------|----------|--------|--------|---------------------|------|-------|---------------------|
| 0Bh,8Bh | INTCON  | GIE                    | PEIE        | TOIE                | INTE                          | RBIE      | TOIF     | INTF   | RBIF   | 0000 0              | 200x | 0000  | 000u                |
| 0Ch     | PIR1    | PSPIF <sup>(1,2)</sup> | ADIF        | RCIF <sup>(2)</sup> | TXIF <sup>(2)</sup>           | SSPIF     | CCP1IF   | TMR2IF | TMR1IF | 0000 0              | 0000 | 0000  | 0000                |
| 8Ch     | PIE1    | PSPIE <sup>(1,2)</sup> | ADIE        | RCIE <sup>(2)</sup> | TXIE <sup>(2)</sup>           | SSPIE     | CCP1IE   | TMR2IE | TMR1IE | 0000 0              | 0000 | 0000  | 0000                |
| 87h     | TRISC   | PORTC Da               | ta Directio | on Registe          | er                            |           |          |        |        | 1111 1              | 1111 | 1111  | 1111                |
| 13h     | SSPBUF  | Synchronou             | us Serial I | Port Rece           | ive Buffer                    | /Transmit | Register |        |        | XXXX X              | xxxx | uuuu  | uuuu                |
| 14h     | SSPCON  | WCOL                   | SSPOV       | SSPEN               | CKP                           | SSPM3     | SSPM2    | SSPM1  | SSPM0  | 0000 0              | 0000 | 0000  | 0000                |
| 85h     | TRISA   | _                      | _           | PORTA I             | PORTA Data Direction Register |           |          |        |        |                     |      | 11    | 1111                |
| 94h     | SSPSTAT | —                      | —           | D/Ā                 | Р                             | S         | R/W      | UA     | BF     | 00 C                | 0000 | 00    | 0000                |

Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by the SSP in SPI mode.

Note 1: Bits PSPIE and PSPIF are reserved on the PIC16C73/73A, always maintain these bits clear.

2: The PIC16C72 does not have a Parallel Slave Port or USART, these bits are unimplemented, read as '0'.

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

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

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

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

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

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

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

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

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

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

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

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



#### 12.1.1 SAMPLING

The data on the RC7/RX/DT pin is sampled three times by a majority detect circuit to determine if a high or a low level is present at the RX pin. If bit BRGH (TXSTA<2>) is clear (i.e., at the low baud rates), the sampling is done on the seventh, eighth and ninth falling edges of a x16 clock (Figure 12-3). If bit BRGH is set (i.e., at the high baud rates), the sampling is done on the 3 clock edges preceding the second rising edge after the first falling edge of a x4 clock (Figure 12-4 and Figure 12-5).

#### FIGURE 12-3: RX PIN SAMPLING SCHEME. BRGH = 0 (PIC16C73/73A/74/74A)



#### FIGURE 12-4: RX PIN SAMPLING SCHEME, BRGH = 1 (PIC16C73/73A/74/74A)







| COMF                                                                                                                          | Complement f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DECFSZ            | Decrement f, Skip if 0                                                                                                                                                                                                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                                                                                                                       | [ <i>label</i> ] COMF f,d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Syntax:           | [ <i>label</i> ] DECFSZ f,d                                                                                                                                                                                                                                                                        |
| Operands:                                                                                                                     | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \left[0,1\right] \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Operands:         | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                 |
| Operation:                                                                                                                    | $(\overline{f}) \rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Operation:        | (f) - 1 $\rightarrow$ (destination);                                                                                                                                                                                                                                                               |
| Status Affected:                                                                                                              | Z                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   | skip if result = 0                                                                                                                                                                                                                                                                                 |
| Encoding:                                                                                                                     | 00 1001 dfff ffff                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Status Affected:  | None                                                                                                                                                                                                                                                                                               |
| Description:                                                                                                                  | The contents of register 'f' are comple-<br>mented. If 'd' is 0 the result is stored in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Encoding:         | 00 1011 dfff ffff                                                                                                                                                                                                                                                                                  |
|                                                                                                                               | W. If 'd' is 1 the result is stored back in register 'f'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Description:      | The contents of register 'f' are decre-<br>mented. If 'd' is 0 the result is placed in the<br>W register. If 'd' is 1 the result is placed                                                                                                                                                         |
| Words:                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   | back in register 'f'.<br>If the result is 1, the next instruction, is                                                                                                                                                                                                                              |
| Cycles:                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   | executed. If the result is 0, then a NOP is<br>executed instead making it a 2TCY instruc-                                                                                                                                                                                                          |
| Q Cycle Activity:                                                                                                             | Q1 Q2 Q3 Q4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   | tion.                                                                                                                                                                                                                                                                                              |
|                                                                                                                               | Decode Read Process Write to register data destination                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Words:            | 1                                                                                                                                                                                                                                                                                                  |
|                                                                                                                               | f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Cycles:           | 1(2)                                                                                                                                                                                                                                                                                               |
|                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Q Cycle Activity: | Q1 Q2 Q3 Q4                                                                                                                                                                                                                                                                                        |
| Example                                                                                                                       | COMF REG1,0<br>Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   | Decode Read register 'f' Process Write to destination                                                                                                                                                                                                                                              |
|                                                                                                                               | REG1 = 0x13<br>After Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | If Skip:          | (2nd Cycle)                                                                                                                                                                                                                                                                                        |
|                                                                                                                               | REG1 = 0x13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   | Q1 Q2 Q3 Q4                                                                                                                                                                                                                                                                                        |
|                                                                                                                               | W = 0xEC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                   | No-No-No-OperationOperationOperation                                                                                                                                                                                                                                                               |
|                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                                                                                                                                                                                                                                                                                    |
| DECF                                                                                                                          | Decrement f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | E                 |                                                                                                                                                                                                                                                                                                    |
| DECF<br>Syntax:                                                                                                               | Decrement f<br>[ <i>label</i> ] DECF f,d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Example           | HERE DECFSZ CNT, 1<br>GOTO LOOP                                                                                                                                                                                                                                                                    |
| _                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Example           |                                                                                                                                                                                                                                                                                                    |
| Syntax:                                                                                                                       | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Example           | GOTO LOOP                                                                                                                                                                                                                                                                                          |
| Syntax:<br>Operands:                                                                                                          | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Example           | CONTINUE •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•                                                                                                                                                                                               |
| Syntax:<br>Operands:<br>Operation:                                                                                            | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Example           | GOTO LOOP<br>CONTINUE •<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•<br>•                                                                                                                                                                                  |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:                                                                        | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)<br>Z<br>00 0011 dfff fff<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Example           | GOTO LOOP<br>CONTINUE •<br>•<br>•<br>Before Instruction<br>PC = address HERE<br>After Instruction<br>CNT = CNT - 1<br>if CNT = 0,<br>PC = address CONTINUE                                                                                                                                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:                                           | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f' If 'd' is 0 the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                 | $[label] DECF f,d$ $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (destination) Z $\boxed{00  0011  dfff  ffff}$ Decrement register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is 1 the result is stored back in register 'f'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Example           | GOTO LOOP<br>CONTINUE •<br>•<br>•<br>Before Instruction<br>PC = address HERE<br>After Instruction<br>CNT = CNT - 1<br>if CNT = 0,<br>PC = address CONTINUE                                                                                                                                         |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                      | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)<br>Z<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.<br>1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:                                 | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)<br>Z<br>00  0011  dfff  ffff<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:                      | $[label] DECF f,d$ $0 \le f \le 127$ $d \in [0,1]$ (f) - 1 $\rightarrow$ (destination) Z $00  0011  dfff  ffff$ Decrement register 'f'. If 'd' is 0 the result is stored in the W register. If 'd' is 1 the result is stored back in register 'f'. 1 1 2 2 2 2 2 2 2 2 2 2 3 2 4 2 2 2 2 3 2 4 2 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 3 2 4 2 2 | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Q Cycle Activity: | [ <i>label</i> ] DECF f,d<br>0 ≤ f ≤ 127<br>d ∈ [0,1]<br>(f) - 1 → (destination)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.<br>1<br>1<br>Q1 Q2 Q3 Q4<br>Decode Read Process Write to<br>data destination<br>DECF CNT, 1<br>Before Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Q Cycle Activity: | [ <i>label</i> ] DECF f,d<br>$0 \le f \le 127$<br>$d \in [0,1]$<br>(f) - 1 $\rightarrow$ (destination)<br>Z<br>$\boxed{00  0011  dfff  ffff}$<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.<br>1<br>1<br>$\boxed{Q1  Q2  Q3  Q4}$<br>$\boxed{Decode  Read  Process  Write to \ destination \ 'f'}$<br>DECF CNT, 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Q Cycle Activity: | [ <i>label</i> ] DECF f,d<br>0 ≤ f ≤ 127<br>d ∈ [0,1]<br>(f) - 1 → (destination)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.<br>1<br>1<br>2<br>Q1 Q2 Q3 Q4<br>Decode Read Process Write to<br>data destination<br>DECF CNT, 1<br>Before Instruction<br>CNT = 0x01<br>Z = 0<br>After Instruction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |
| Syntax:<br>Operands:<br>Operation:<br>Status Affected:<br>Encoding:<br>Description:<br>Words:<br>Cycles:<br>Q Cycle Activity: | [ <i>label</i> ] DECF f,d<br>0 ≤ f ≤ 127<br>d ∈ [0,1]<br>(f) - 1 → (destination)<br>Z<br>00 0011 dfff ffff<br>Decrement register 'f'. If 'd' is 0 the<br>result is stored in the W register. If 'd' is<br>1 the result is stored back in register 'f'.<br>1<br>1<br>Q1 Q2 Q3 Q4<br>Decode Read Process Write to<br>data destination<br>DECF CNT, 1<br>Before Instruction<br>CNT = 0x01<br>Z = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Example           | $\begin{array}{rcl} & GOTO & LOOP \\ \hline CONTINUE & & \\ & & \\ & & \\ & & \\ \end{array}$ Before Instruction $\begin{array}{rcl} PC & = & address \ here \\ After Instruction \\ CNT & = & CNT \ -1 \\ & if \ CNT & = & 0, \\ PC & = & address \ CONTINUE \\ & if \ CNT \neq & 0, \end{array}$ |

# 16.0 DEVELOPMENT SUPPORT

#### 16.1 <u>Development Tools</u>

The PIC16/17 microcontrollers are supported with a full range of hardware and software development tools:

- PICMASTER/PICMASTER CE Real-Time In-Circuit Emulator
- ICEPIC Low-Cost PIC16C5X and PIC16CXXX In-Circuit Emulator
- PRO MATE<sup>®</sup> II Universal Programmer
- PICSTART<sup>®</sup> Plus Entry-Level Prototype Programmer
- PICDEM-1 Low-Cost Demonstration Board
- PICDEM-2 Low-Cost Demonstration Board
- PICDEM-3 Low-Cost Demonstration Board
- MPASM Assembler
- MPLAB-SIM Software Simulator
- MPLAB-C (C Compiler)
- Fuzzy logic development system (*fuzzy*TECH<sup>®</sup>–MP)

#### 16.2 <u>PICMASTER: High Performance</u> <u>Universal In-Circuit Emulator with</u> <u>MPLAB IDE</u>

The PICMASTER Universal In-Circuit Emulator is intended to provide the product development engineer with a complete microcontroller design tool set for all microcontrollers in the PIC12C5XX, PIC14C000, PIC16C5X, PIC16CXXX and PIC17CXX families. PICMASTER is supplied with the MPLAB<sup>™</sup> Integrated Development Environment (IDE), which allows editing, "make" and download, and source debugging from a single environment.

Interchangeable target probes allow the system to be easily reconfigured for emulation of different processors. The universal architecture of the PICMASTER allows expansion to support all new Microchip microcontrollers.

The PICMASTER Emulator System has been designed as a real-time emulation system with advanced features that are generally found on more expensive development tools. The PC compatible 386 (and higher) machine platform and Microsoft Windows<sup>®</sup> 3.x environment were chosen to best make these features available to you, the end user.

A CE compliant version of PICMASTER is available for European Union (EU) countries.

#### 16.3 ICEPIC: Low-cost PIC16CXXX In-Circuit Emulator

ICEPIC is a low-cost in-circuit emulator solution for the Microchip PIC16C5X and PIC16CXXX families of 8-bit OTP microcontrollers.

ICEPIC is designed to operate on PC-compatible machines ranging from 286-AT<sup>®</sup> through Pentium<sup>™</sup> based machines under Windows 3.x environment. ICEPIC features real time, non-intrusive emulation.

#### 16.4 PRO MATE II: Universal Programmer

The PRO MATE II Universal Programmer is a full-featured programmer capable of operating in stand-alone mode as well as PC-hosted mode.

The PRO MATE II has programmable VDD and VPP supplies which allows it to verify programmed memory at VDD min and VDD max for maximum reliability. It has an LCD display for displaying error messages, keys to enter commands and a modular detachable socket assembly to support various package types. In standalone mode the PRO MATE II can read, verify or program PIC16C5X, PIC16CXXX, PIC17CXX and PIC14000 devices. It can also set configuration and code-protect bits in this mode.

#### 16.5 <u>PICSTART Plus Entry Level</u> <u>Development System</u>

The PICSTART programmer is an easy-to-use, lowcost prototype programmer. It connects to the PC via one of the COM (RS-232) ports. MPLAB Integrated Development Environment software makes using the programmer simple and efficient. PICSTART Plus is not recommended for production programming.

PICSTART Plus supports all PIC12C5XX, PIC14000, PIC16C5X, PIC16CXXX and PIC17CXX devices with up to 40 pins. Larger pin count devices such as the PIC16C923 and PIC16C924 may be supported with an adapter socket.

| Applic       | able Devices 72 73 73A 74                                                                                                                                                                                                                                                 | 74A 76 | 6 77              |     |         |       |                                                             |  |  |  |  |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|-----|---------|-------|-------------------------------------------------------------|--|--|--|--|--|
| 18.3         | PIC16C73/74-10 (Commercial, Industrial)<br>PIC16C73/74-20 (Commercial, Industrial)<br>PIC16LC73/74-04 (Commercial, Industrial)                                                                                                                                            |        |                   |     |         |       |                                                             |  |  |  |  |  |
|              | Standard Operating Conditions (unless otherwise stated)                                                                                                                                                                                                                   |        |                   |     |         |       |                                                             |  |  |  |  |  |
| DC CH4       | DC CHARACTERISTICSOperating temperature<br>$0^{\circ}C$ $-40^{\circ}C$ $\leq TA \leq +85^{\circ}C$ for industrial and<br>$0^{\circ}C$ $\leq TA \leq +70^{\circ}C$ for commercial<br>Operating voltage VDD range as described in DC spec Section 18.1 and<br>Section 18.2. |        |                   |     |         |       |                                                             |  |  |  |  |  |
| Param<br>No. | Characteristic                                                                                                                                                                                                                                                            | Sym    | Min               | Тур | Max     | Units | Conditions                                                  |  |  |  |  |  |
| INO.         |                                                                                                                                                                                                                                                                           |        |                   | †   |         |       |                                                             |  |  |  |  |  |
|              | Input Low Voltage<br>I/O ports                                                                                                                                                                                                                                            | VIL    |                   |     |         |       |                                                             |  |  |  |  |  |
| D030         | with TTL buffer                                                                                                                                                                                                                                                           | VIL    | Vss               | -   | 0.15VDD | v     | For entire VDD range                                        |  |  |  |  |  |
| D030A        |                                                                                                                                                                                                                                                                           |        | VSS               | _   | 0.10VDD | v     | $4.5V \le VDD \le 5.5V$                                     |  |  |  |  |  |
| D031         | with Schmitt Trigger buffer                                                                                                                                                                                                                                               |        | VSS               | -   | 0.2VDD  | v     |                                                             |  |  |  |  |  |
| D032         | MCLR, OSC1 (in RC mode)                                                                                                                                                                                                                                                   |        | Vss               | -   | 0.2VDD  | v     |                                                             |  |  |  |  |  |
| D033         | OSC1 (in XT, HS and LP)                                                                                                                                                                                                                                                   |        | Vss               | -   | 0.3VDD  | V     | Note1                                                       |  |  |  |  |  |
|              | Input High Voltage                                                                                                                                                                                                                                                        |        |                   |     |         |       |                                                             |  |  |  |  |  |
|              | I/O ports                                                                                                                                                                                                                                                                 | Vih    |                   | -   |         |       |                                                             |  |  |  |  |  |
| D040         | with TTL buffer                                                                                                                                                                                                                                                           |        | 2.0               | -   | Vdd     | V     | $4.5V \le VDD \le 5.5V$                                     |  |  |  |  |  |
| D040A        |                                                                                                                                                                                                                                                                           |        | 0.25VDD<br>+ 0.8V | -   | Vdd     | V     | For entire VDD range                                        |  |  |  |  |  |
| D041         | with Schmitt Trigger buffer                                                                                                                                                                                                                                               |        | 0.8Vdd            | -   | Vdd     | v     | For entire VDD range                                        |  |  |  |  |  |
| D041         | MCLR                                                                                                                                                                                                                                                                      |        | 0.8VDD            | _   | VDD     | v     | Tor entire VDD range                                        |  |  |  |  |  |
| D042A        | OSC1 (XT, HS and LP)                                                                                                                                                                                                                                                      |        | 0.7VDD            | -   | VDD     | v     | Note1                                                       |  |  |  |  |  |
| D043         | OSC1 (in RC mode)                                                                                                                                                                                                                                                         |        | 0.9VDD            | -   | VDD     | v     |                                                             |  |  |  |  |  |
| D070         | PORTB weak pull-up current                                                                                                                                                                                                                                                | IPURB  | 50                | 250 |         | μA    | VDD = 5V, VPIN = VSS                                        |  |  |  |  |  |
|              | Input Leakage Current<br>(Notes 2, 3)                                                                                                                                                                                                                                     |        |                   |     |         | Pr    |                                                             |  |  |  |  |  |
| D060         | I/O ports                                                                                                                                                                                                                                                                 | lıL    | -                 | -   | ±1      | μA    | Vss $\leq$ VPIN $\leq$ VDD, Pin at hi-impedance             |  |  |  |  |  |
| D061         | MCLR, RA4/T0CKI                                                                                                                                                                                                                                                           |        | -                 | -   | ±5      | μA    | $Vss \le VPIN \le VDD$                                      |  |  |  |  |  |
| D063         | OSC1                                                                                                                                                                                                                                                                      |        | -                 | -   | ±5      | μA    | Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |  |  |  |  |
|              | Output Low Voltage                                                                                                                                                                                                                                                        | 1      |                   |     |         |       |                                                             |  |  |  |  |  |
| D080         | I/O ports                                                                                                                                                                                                                                                                 | Vol    | -                 | -   | 0.6     | V     | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C                 |  |  |  |  |  |
| D083         | OSC2/CLKOUT (RC osc config)                                                                                                                                                                                                                                               |        | -                 | -   | 0.6     | V     | lOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C                 |  |  |  |  |  |
|              | Output High Voltage                                                                                                                                                                                                                                                       |        |                   |     |         |       |                                                             |  |  |  |  |  |
| D090         | I/O ports (Note 3)                                                                                                                                                                                                                                                        | Voh    | Vdd - 0.7         | -   | -       | V     | IOH = -3.0 mA, VDD = 4.5V,<br>-40°С to +85°С                |  |  |  |  |  |
| D092         | OSC2/CLKOUT (RC osc config)                                                                                                                                                                                                                                               |        | Vdd - 0.7         | -   | -       | V     | IOH = -1.3 mA, VDD = 4.5V,<br>-40°С to +85°С                |  |  |  |  |  |
| D150*        | Open-Drain High Voltage                                                                                                                                                                                                                                                   | Vod    | -                 | -   | 14      | V     | RA4 pin                                                     |  |  |  |  |  |
| L            |                                                                                                                                                                                                                                                                           | L      | L                 | I   | I       | I     | · ·                                                         |  |  |  |  |  |

These parameters are characterized but not tested.

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

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

2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as current sourced by the pin.

| 19.3                                                                                                                                                                        | PIC16<br>PIC16                                                                                                                                                                    | 6C73A/<br>6C73A/<br>6C73A/ | 74A-04<br>74A-10         | )<br>(Co<br>(Co | ommerci<br>ommerci | ial, Inc<br>ial, Inc | dustrial, Extended)<br>dustrial, Extended)<br>dustrial, Extended)<br>dustrial)            |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--------------------------|-----------------|--------------------|----------------------|-------------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                                                                                                             | Standard Operating Conditions (unless otherwise stated)Operating temperature $-40^{\circ}$ C $\leq$ TA $\leq$ +125°C for extended,-40°C $\leq$ TA $\leq$ +85°C for industrial and |                            |                          |                 |                    |                      |                                                                                           |  |  |  |  |
| <b>DC CHARACTERISTICS</b><br>$0^{\circ}C \leq TA \leq +70^{\circ}C$ for commercial<br>Operating voltage VDD range as described in DC spec Section 19.1 and<br>Section 19.2. |                                                                                                                                                                                   |                            |                          |                 |                    |                      |                                                                                           |  |  |  |  |
| Param<br>No.                                                                                                                                                                | Characteristic                                                                                                                                                                    | Sym                        | Min                      | Тур<br>†        | Max                | Units                | Conditions                                                                                |  |  |  |  |
|                                                                                                                                                                             | Input Low Voltage                                                                                                                                                                 | VIL                        |                          |                 |                    |                      |                                                                                           |  |  |  |  |
| D030<br>D030A                                                                                                                                                               | with TTL buffer                                                                                                                                                                   |                            | Vss<br>Vss               | -               | 0.15Vdd<br>0.8V    |                      | For entire VDD range $4.5V \le VDD \le 5.5V$                                              |  |  |  |  |
| D031<br>D032                                                                                                                                                                | with Schmitt Trigger buffer<br>MCLR, OSC1 (in RC mode)                                                                                                                            |                            | Vss<br>Vss               | -               | 0.2VDD<br>0.2VDD   | V<br>V               | Neder                                                                                     |  |  |  |  |
| D033                                                                                                                                                                        | OSC1 (in XT, HS and LP) Input High Voltage                                                                                                                                        | Ин                         | Vss                      | -               | 0.3Vdd             | V                    | Note1                                                                                     |  |  |  |  |
| D040<br>D040A                                                                                                                                                               | I/O ports<br>with TTL buffer                                                                                                                                                      | VIH                        | 2.0<br>0.25VDD<br>+ 0.8V | -               | Vdd<br>Vdd         | V<br>V               | $4.5V \le VDD \le 5.5V$<br>For entire VDD range                                           |  |  |  |  |
| D041<br>D042                                                                                                                                                                | with Schmitt Trigger buffer                                                                                                                                                       |                            | 0.8Vdd<br>0.8Vdd         | -               | Vdd<br>Vdd         | V<br>V               | For entire VDD range                                                                      |  |  |  |  |
| D042A<br>D043                                                                                                                                                               | OSC1 (XT, HS and LP)<br>OSC1 (in RC mode)                                                                                                                                         |                            | 0.7VDD<br>0.9VDD         | -               | VDD<br>VDD         | V<br>V               | Note1                                                                                     |  |  |  |  |
| D070                                                                                                                                                                        | PORTB weak pull-up current Input Leakage Current                                                                                                                                  | IPURB                      | 50                       | 250             | 400                | μA                   | VDD = 5V, VPIN = VSS                                                                      |  |  |  |  |
| D060                                                                                                                                                                        | (Notes 2, 3)<br>I/O ports                                                                                                                                                         | lı∟                        | -                        | -               | ±1                 | μA                   | Vss $\leq$ VPIN $\leq$ VDD, Pin at hi-impedance                                           |  |  |  |  |
| D061<br>D063                                                                                                                                                                | MCLR, RA4/T0CKI<br>OSC1                                                                                                                                                           |                            | -                        | -               | ±5<br>±5           | μΑ<br>μΑ             | Vss $\leq$ VPIN $\leq$ VDD<br>Vss $\leq$ VPIN $\leq$ VDD, XT, HS and LP osc configuration |  |  |  |  |
| D080                                                                                                                                                                        | Output Low Voltage<br>I/O ports                                                                                                                                                   | Vol                        | -                        | -               | 0.6                | V                    | IOL = 8.5 mA, VDD = 4.5V,<br>-40°C to +85°C                                               |  |  |  |  |
| D080A                                                                                                                                                                       |                                                                                                                                                                                   |                            | -                        | -               | 0.6                | V                    | IOL = 7.0  mA,  VDD = 4.5 V,<br>-40°C to +125°C                                           |  |  |  |  |
| D083                                                                                                                                                                        | OSC2/CLKOUT (RC osc config)                                                                                                                                                       |                            | -                        | -               | 0.6                | V                    | lOL = 1.6 mA, VDD = 4.5V,<br>-40°C to +85°C                                               |  |  |  |  |
| D083A                                                                                                                                                                       | These parameters are characteriz                                                                                                                                                  |                            | -                        | -               | 0.6                | V                    | IOL = 1.2 mA, VDD = 4.5V,<br>-40°C to +125°C                                              |  |  |  |  |

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

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

2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

3: Negative current is defined as current sourced by the pin.

# PIC16C7X

# Applicable Devices 72 73 73A 74 74A 76 77



| TABLE 20-3: | <b>CLKOUT AND I/O TIMING REQUIREMENTS</b> |
|-------------|-------------------------------------------|
| IADEE 20-3. |                                           |

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

These parameters are characterized but not tested.

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

t These parameters are asynchronous events not related to any internal clock edges.

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

# Applicable Devices 72 73 73A 74 74A 76 77

#### TABLE 20-13: A/D CONVERTER CHARACTERISTICS:

PIC16C76/77-04 (Commercial, Industrial, Extended) PIC16C76/77-10 (Commercial, Industrial, Extended) PIC16C76/77-20 (Commercial, Industrial, Extended) PIC16LC76/77-04 (Commercial, Industrial)

| Param<br>No. | Sym  | Characteristic                               |                       | Min       | Тур†       | Мах        | Units | Conditions                                                                                                  |
|--------------|------|----------------------------------------------|-----------------------|-----------|------------|------------|-------|-------------------------------------------------------------------------------------------------------------|
| A01          | NR   | Resolution                                   |                       |           |            | 8-bits     | bit   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A02          | EABS | Total Absolute error                         |                       |           | _          | <±1        | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A03          | EIL  | Integral linearity error                     |                       | _         | _          | <±1        | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A04          | EDL  | Differential linearity error                 |                       | —         | _          | <±1        | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A05          | EFS  | Full scale error                             |                       | —         | —          | <±1        | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A06          | EOFF | Offset error                                 |                       | —         | —          | <±1        | LSb   | $\label{eq:VREF} \begin{array}{l} VREF = VDD = 5.12V,\\ VSS \leq VAIN \leq VREF \end{array}$                |
| A10          | —    | Monotonicity                                 |                       | —         | guaranteed | -          | _     | $VSS \leq VAIN \leq VREF$                                                                                   |
| A20          | Vref | Reference voltage                            |                       | 3.0V      | —          | Vdd + 0.3  | V     |                                                                                                             |
| A25          | VAIN | Analog input voltage                         |                       | Vss - 0.3 | —          | Vref + 0.3 | V     |                                                                                                             |
| A30          | ZAIN | Recommended impedan<br>analog voltage source | ice of                |           | _          | 10.0       | kΩ    |                                                                                                             |
| A40          | IAD  | A/D conversion current                       | PIC16 <b>C</b> 76/77  | —         | 180        | _          | μΑ    | Average current consump-                                                                                    |
|              |      | (VDD)                                        | PIC16 <b>LC</b> 76/77 | —         | 90         |            | μΑ    | tion when A/D is on.<br>(Note 1)                                                                            |
| A50          | IREF | VREF input current (Note                     | 2)                    | 10        | _          | 1000       | μA    | During VAIN acquisition.<br>Based on differential of<br>VHOLD to VAIN to charge<br>CHOLD, see Section 13.1. |
|              |      |                                              |                       |           | _          | 10         | μA    | During A/D Conversion cycle                                                                                 |

These parameters are characterized but not tested.

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

Note 1: When A/D is off, it will not consume any current other than minor leakage current. The power-down current spec includes any such leakage from the A/D module.

2: VREF current is from RA3 pin or VDD pin, whichever is selected as reference input.





## **APPENDIX A:**

The following are the list of modifications over the PIC16C5X microcontroller family:

- 1. Instruction word length is increased to 14-bits. This allows larger page sizes both in program memory (2K now as opposed to 512 before) and register file (128 bytes now versus 32 bytes before).
- 2. A PC high latch register (PCLATH) is added to handle program memory paging. Bits PA2, PA1, PA0 are removed from STATUS register.
- 3. Data memory paging is redefined slightly. STATUS register is modified.
- Four new instructions have been added: RETURN, RETFIE, ADDLW, and SUBLW. Two instructions TRIS and OPTION are being phased out although they are kept for compati-bility with PIC16C5X.
- 5. OPTION and TRIS registers are made addressable.
- 6. Interrupt capability is added. Interrupt vector is at 0004h.
- 7. Stack size is increased to 8 deep.
- 8. Reset vector is changed to 0000h.
- Reset of all registers is revisited. Five different reset (and wake-up) types are recognized. Registers are reset differently.
- 10. Wake up from SLEEP through interrupt is added.
- 11. Two separate timers, Oscillator Start-up Timer (OST) and Power-up Timer (PWRT) are included for more reliable power-up. These timers are invoked selectively to avoid unnecessary delays on power-up and wake-up.
- 12. PORTB has weak pull-ups and interrupt on change feature.
- 13. T0CKI pin is also a port pin (RA4) now.
- 14. FSR is made a full eight bit register.
- "In-circuit serial programming" is made possible. The user can program PIC16CXX devices using only five pins: VDD, Vss, MCLR/VPP, RB6 (clock) and RB7 (data in/out).
- PCON status register is added with a Power-on Reset status bit (POR).
- 17. Code protection scheme is enhanced such that portions of the program memory can be protected, while the remainder is unprotected.
- Brown-out protection circuitry has been added. Controlled by configuration word bit BODEN. Brown-out reset ensures the device is placed in a reset condition if VDD dips below a fixed setpoint.

## APPENDIX B: COMPATIBILITY

To convert code written for PIC16C5X to PIC16CXX, the user should take the following steps:

- 1. Remove any program memory page select operations (PA2, PA1, PA0 bits) for CALL, GOTO.
- 2. Revisit any computed jump operations (write to PC or add to PC, etc.) to make sure page bits are set properly under the new scheme.
- 3. Eliminate any data memory page switching. Redefine data variables to reallocate them.
- 4. Verify all writes to STATUS, OPTION, and FSR registers since these have changed.
- 5. Change reset vector to 0000h.

# APPENDIX E: PIC16/17 MICROCONTROLLERS

#### E.1 PIC12CXXX Family of Devices

|             |                                         | PIC12C508       | PIC12C509       | PIC12C671       | PIC12C672       |
|-------------|-----------------------------------------|-----------------|-----------------|-----------------|-----------------|
| Clock       | Maximum Frequency<br>of Operation (MHz) | 4               | 4               | 4               | 4               |
| lomony      | EPROM Program Memory                    | 512 x 12        | 1024 x 12       | 1024 x 14       | 2048 x 14       |
| lemory      | Data Memory (bytes)                     | 25              | 41              | 128             | 128             |
|             | Timer Module(s)                         | TMR0            | TMR0            | TMR0            | TMR0            |
| Peripherals | A/D Converter (8-bit) Channels          | —               | —               | 4               | 4               |
|             | Wake-up from SLEEP on<br>pin change     | Yes             | Yes             | Yes             | Yes             |
|             | I/O Pins                                | 5               | 5               | 5               | 5               |
|             | Input Pins                              | 1               | 1               | 1               | 1               |
| eatures     | Internal Pull-ups                       | Yes             | Yes             | Yes             | Yes             |
|             | Voltage Range (Volts)                   | 2.5-5.5         | 2.5-5.5         | 2.5-5.5         | 2.5-5.5         |
|             | In-Circuit Serial Programming           | Yes             | Yes             | Yes             | Yes             |
|             | Number of Instructions                  | 33              | 33              | 35              | 35              |
|             | Packages                                | 8-pin DIP, SOIC | 8-pin DIP, SOIC | 8-pin DIP, SOIC | 8-pin DIP, SOIC |

All PIC12C5XX devices have Power-on Reset, selectable Watchdog Timer, selectable code protect and high I/O current capability. All PIC12C5XX devices use serial programming with data pin GP1 and clock pin GP0.

# E.2 PIC14C000 Family of Devices

|             |                                                 | PIC14C000                                                                                                                                                                        |
|-------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock       | Maximum Frequency of Operation (MHz)            | 20                                                                                                                                                                               |
|             | EPROM Program Memory (x14 words)                | 4K                                                                                                                                                                               |
| Memory      | Data Memory (bytes)                             | 192                                                                                                                                                                              |
| Memory      | Timer Module(s)                                 | TMR0<br>ADTMR                                                                                                                                                                    |
| Peripherals | Serial Port(s)<br>(SPI/I <sup>2</sup> C, USART) | I <sup>2</sup> C with SMBus<br>Support                                                                                                                                           |
|             | Slope A/D Converter Channels                    | 8 External; 6 Internal                                                                                                                                                           |
|             | Interrupt Sources                               | 11                                                                                                                                                                               |
|             | I/O Pins                                        | 22                                                                                                                                                                               |
|             | Voltage Range (Volts)                           | 2.7-6.0                                                                                                                                                                          |
| Features    | In-Circuit Serial Programming                   | Yes                                                                                                                                                                              |
|             | Additional On-chip Features                     | Internal 4MHz Oscillator, Bandgap Reference, Temperature Sensor,<br>Calibration Factors, Low Voltage Detector, SLEEP, HIBERNATE,<br>Comparators with Programmable References (2) |
|             | Packages                                        | 28-pin DIP (.300 mil), SOIC, SSOP                                                                                                                                                |

# PIC16C7X

| Figure 20-9:     | SPI Master Mode Timing (CKE = 0) 232        |
|------------------|---------------------------------------------|
| Figure 20-10:    | SPI Master Mode Timing (CKE = 1)232         |
| Figure 20-11:    | SPI Slave Mode Timing (CKE = $0$ )          |
|                  |                                             |
| Figure 20-12:    | SPI Slave Mode Timing (CKE = 1)             |
| Figure 20-13:    | I <sup>2</sup> C Bus Start/Stop Bits Timing |
| Figure 20-14:    | I <sup>2</sup> C Bus Data Timing236         |
|                  |                                             |
| Figure 20-15:    | USART Synchronous Transmission              |
|                  | (Master/Slave) Timing237                    |
| Figure 20-16:    | USART Synchronous Receive                   |
| 0                | (Master/Slave) Timing 237                   |
| Figure 20 17:    |                                             |
| Figure 20-17:    | A/D Conversion Timing                       |
| Figure 21-1:     | Typical IPD vs. VDD (WDT Disabled,          |
|                  | RC Mode)241                                 |
| Figure 21-2:     | Maximum IPD vs. VDD (WDT                    |
| rigaro Er E.     |                                             |
| -                | Disabled, RC Mode)                          |
| Figure 21-3:     | Typical IPD vs. VDD @ 25°C (WDT             |
|                  | Enabled, RC Mode)242                        |
| Figure 21-4:     | Maximum IPD vs. VDD (WDT                    |
| riguio 21°4.     |                                             |
|                  | Enabled, RC Mode)242                        |
| Figure 21-5:     | Typical RC Oscillator                       |
|                  | Frequency vs. VDD242                        |
| Figure 21-6:     | Typical RC Oscillator                       |
| riguic 21-0.     |                                             |
|                  | Frequency vs. VDD242                        |
| Figure 21-7:     | Typical RC Oscillator                       |
|                  | Frequency vs. VDD                           |
| Figure 21-8:     | Typical IPD vs. VDD Brown-out               |
| riguio 21-0.     |                                             |
|                  | Detect Enabled (RC Mode)                    |
| Figure 21-9:     | Maximum IPD vs. VDD Brown-out               |
|                  | Detect Enabled                              |
|                  | (85°C to -40°C, RC Mode)                    |
| Einung 04 40.    |                                             |
| Figure 21-10:    | Typical IPD vs. Timer1 Enabled              |
|                  | (32 kHz, RC0/RC1= 33 pF/33 pF,              |
|                  | RC Mode)243                                 |
| Figure 21-11:    | Maximum IPD vs. Timer1 Enabled              |
| Figure 21-11.    |                                             |
|                  | (32 kHz, RC0/RC1 = 33                       |
|                  | pF/33 pF, 85°C to -40°C, RC Mode) 243       |
| Figure 21-12:    | Typical IDD vs. Frequency                   |
|                  | (RC Mode @ 22 pF, 25°C)                     |
|                  |                                             |
| Figure 21-13:    | Maximum IDD vs. Frequency                   |
|                  | (RC Mode @ 22 pF, -40°C to 85°C) 244        |
| Figure 21-14:    | Typical IDD vs. Frequency                   |
| 0.0              | (RC Mode @ 100 pF, 25°C)245                 |
| E                |                                             |
| Figure 21-15:    | Maximum IDD vs. Frequency (                 |
|                  | RC Mode @ 100 pF, -40°C to 85°C) 245        |
| Figure 21-16:    | Typical IDD vs. Frequency                   |
|                  | (RC Mode @ 300 pF, 25°C)                    |
| E: 04.47         |                                             |
| Figure 21-17:    | Maximum IDD vs. Frequency                   |
|                  | (RC Mode @ 300 pF, -40°C to 85°C) 246       |
| Figure 21-18:    | Typical IDD vs. Capacitance @               |
|                  |                                             |
| <b>E</b> : 04.40 | 500 kHz (RC Mode)                           |
| Figure 21-19:    | Transconductance(gm) of                     |
|                  | HS Oscillator vs. VDD247                    |
| Figure 21-20:    | Transconductance(gm) of LP                  |
|                  | Oscillator vs. VDD                          |
| Einung 04 04.    |                                             |
| Figure 21-21:    | Transconductance(gm) of XT                  |
|                  | Oscillator vs. VDD247                       |
| Figure 21-22:    | Typical XTAL Startup Time vs. VDD           |
| J <b></b> .      | (LP Mode, 25°C)                             |
|                  |                                             |
| Figure 21-23:    | Typical XTAL Startup Time vs. VDD           |
|                  | (HS Mode, 25°C)248                          |
| Figure 21-24:    | Typical XTAL Startup Time vs. VDD           |
| 5                | (XT Mode, 25°C)                             |
| Einung 04 05     | Turnical Idd.va Francesco                   |
| Figure 21-25:    | Typical Idd vs. Frequency                   |
|                  | (LP Mode, 25°C)249                          |
| Figure 21-26:    | Maximum IDD vs. Frequency                   |
| 3 0.             | (LP Mode, 85°C to -40°C)                    |
|                  | (LI WOUE, 05 C to -40 C)                    |
|                  |                                             |

| Figure 21-27: | Typical IDD vs. Frequency    |
|---------------|------------------------------|
|               | (XT Mode, 25°C) 249          |
| Figure 21-28: | Maximum IDD vs. Frequency    |
|               | (XT Mode, -40°C to 85°C) 249 |
| Figure 21-29: | Typical IDD vs. Frequency    |
|               | (HS Mode, 25°C) 250          |
| Figure 21-30: | Maximum IDD vs. Frequency    |
|               | (HS Mode, -40°C to 85°C) 250 |