



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 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 ~ 6V                                                                   |
| Data Converters            | A/D 5x8b                                                                  |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                           |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 28-DIP (0.300", 7.62mm)                                                   |
| Supplier Device Package    | 28-SPDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16c73a-10-sp |

Email: info@E-XFL.COM

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

| Address              | Name    | Bit 7                | Bit 6              | Bit 5          | Bit 4            | Bit 3         | Bit 2        | Bit 1         | Bit 0    | Value on:<br>POR,<br>BOR | Value on all<br>other resets<br>(2) |
|----------------------|---------|----------------------|--------------------|----------------|------------------|---------------|--------------|---------------|----------|--------------------------|-------------------------------------|
| Bank 0               | )       |                      |                    |                |                  |               |              |               |          |                          |                                     |
| 00h <sup>(4)</sup>   | INDF    | Addressing           | this location      | uses conten    | ts of FSR to a   | ddress data r | memory (not  | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 01h                  | TMR0    | Timer0 mod           | lule's registe     | r              |                  |               |              |               |          | xxxx xxxx                | uuuu uuuu                           |
| 02h <sup>(4)</sup>   | PCL     | Program Co           | ounter's (PC)      | Least Signif   | icant Byte       |               |              |               |          | 0000 0000                | 0000 0000                           |
| 03h <sup>(4)</sup>   | STATUS  | IRP <sup>(7)</sup>   | RP1 <sup>(7)</sup> | RP0            | TO               | PD            | Z            | DC            | С        | 0001 1xxx                | 000q quuu                           |
| 04h <sup>(4)</sup>   | FSR     | Indirect data        | a memory ac        | dress pointe   | er               | •             |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 05h                  | PORTA   | _                    | _                  | PORTA Dat      | a Latch when     | written: POR  | TA pins wher | n read        |          | 0x 0000                  | 0u 0000                             |
| 06h                  | PORTB   | PORTB Dat            | ta Latch whe       | n written: PC  | ORTB pins whe    | n read        |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 07h                  | PORTC   | PORTC Dat            | ta Latch whe       | n written: PC  | ORTC pins whe    | en read       |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 08h <sup>(5)</sup>   | PORTD   | PORTD Dat            | ta Latch whe       | n written: PC  | ORTD pins whe    | en read       |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 09h <b>(5)</b>       | PORTE   | —                    | _                  | _              | _                | _             | RE2          | RE1           | RE0      | xxx                      | uuu                                 |
| 0Ah <sup>(1,4)</sup> | PCLATH  | —                    |                    |                |                  |               |              |               | 0 0000   | 0 0000                   |                                     |
| 0Bh <sup>(4)</sup>   | INTCON  | GIE                  | PEIE               | TOIE           | INTE             | RBIE          | TOIF         | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 0Ch                  | PIR1    | PSPIF <sup>(3)</sup> | ADIF               | RCIF           | TXIF             | SSPIF         | CCP1IF       | TMR2IF        | TMR1IF   | 0000 0000                | 0000 0000                           |
| 0Dh                  | PIR2    | —                    | —                  | —              | -                | -             | —            | —             | CCP2IF   | 0                        | 0                                   |
| 0Eh                  | TMR1L   | Holding reg          | ister for the L    | _east Signific | cant Byte of the | e 16-bit TMR  | 1 register   |               |          | XXXX XXXX                | uuuu uuuu                           |
| 0Fh                  | TMR1H   | Holding reg          | ister for the I    | Most Signific  | ant Byte of the  | 16-bit TMR1   | register     |               |          | XXXX XXXX                | uuuu uuuu                           |
| 10h                  | T1CON   | —                    | —                  | T1CKPS1        | T1CKPS0          | T1OSCEN       | T1SYNC       | TMR1CS        | TMR10N   | 00 0000                  | uu uuuu                             |
| 11h                  | TMR2    | Timer2 mod           | lule's registe     | r              |                  |               |              |               |          | 0000 0000                | 0000 0000                           |
| 12h                  | T2CON   | —                    | TOUTPS3            | TOUTPS2        | TOUTPS1          | TOUTPS0       | TMR2ON       | T2CKPS1       | T2CKPS0  | -000 0000                | -000 0000                           |
| 13h                  | SSPBUF  | Synchronou           | is Serial Port     | Receive Bu     | ffer/Transmit R  | egister       |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 14h                  | SSPCON  | WCOL                 | SSPOV              | SSPEN          | СКР              | SSPM3         | SSPM2        | SSPM1         | SSPM0    | 0000 0000                | 0000 0000                           |
| 15h                  | CCPR1L  | Capture/Co           | mpare/PWM          | Register1 (I   | _SB)             |               |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 16h                  | CCPR1H  | Capture/Co           | mpare/PWM          | Register1 (I   | MSB)             |               |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 17h                  | CCP1CON | —                    | —                  | CCP1X          | CCP1Y            | CCP1M3        | CCP1M2       | CCP1M1        | CCP1M0   | 00 0000                  | 00 0000                             |
| 18h                  | RCSTA   | SPEN                 | RX9                | SREN           | CREN             | _             | FERR         | OERR          | RX9D     | 0000 -00x                | 0000 -00x                           |
| 19h                  | TXREG   | USART Trai           | nsmit Data R       | egister        | •                |               |              |               |          | 0000 0000                | 0000 0000                           |
| 1Ah                  | RCREG   | USART Red            | ceive Data R       | egister        |                  |               |              |               |          | 0000 0000                | 0000 0000                           |
| 1Bh                  | CCPR2L  | Capture/Co           | mpare/PWM          | Register2 (I   | _SB)             |               |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 1Ch                  | CCPR2H  | Capture/Co           | mpare/PWM          | Register2 (I   | MSB)             |               |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 1Dh                  | CCP2CON | —                    | —                  | CCP2X          | CCP2Y            | CCP2M3        | CCP2M2       | CCP2M1        | CCP2M0   | 00 0000                  | 00 0000                             |
| 1Eh                  | ADRES   | A/D Result           | Register           |                |                  |               |              |               |          | XXXX XXXX                | uuuu uuuu                           |
| 1Fh                  | ADCON0  | ADCS1                | ADCS0              | CHS2           | CHS1             | CHS0          | GO/DONE      | _             | ADON     | 0000 00-0                | 0000 00-0                           |

 TABLE 4-2:
 PIC16C73/73A/74/74A SPECIAL FUNCTION REGISTER SUMMARY

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

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

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

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

4: These registers can be addressed from either bank.

5: PORTD and PORTE are not physically implemented on the PIC16C73/73A, read as '0'.

6: Brown-out Reset is not implemented on the PIC16C73 or the PIC16C74, read as '0'.

7: The IRP and RP1 bits are reserved on the PIC16C73/73A/74/74A, always maintain these bits clear.

|                       |        |              |                |               |                 |               |               |               | , en,    |                          |                                     |
|-----------------------|--------|--------------|----------------|---------------|-----------------|---------------|---------------|---------------|----------|--------------------------|-------------------------------------|
| Address               | Name   | Bit 7        | Bit 6          | Bit 5         | Bit 4           | Bit 3         | Bit 2         | Bit 1         | Bit 0    | Value on:<br>POR,<br>BOR | Value on all<br>other resets<br>(2) |
| Bank 2                |        |              |                |               |                 |               |               |               | •        |                          |                                     |
| 100h <sup>(4)</sup>   | INDF   | Addressing   | this location  | uses conter   | nts of FSR to a | ddress data ı | memory (not   | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 101h                  | TMR0   | Timer0 mod   | dule's registe | r             |                 |               |               |               |          | xxxx xxxx                | uuuu uuuu                           |
| 102h <sup>(4)</sup>   | PCL    | Program Co   | ounter's (PC)  | Least Signi   | ficant Byte     |               |               |               |          | 0000 0000                | 0000 0000                           |
| 103h <sup>(4)</sup>   | STATUS | IRP          | RP1            | RP0           | TO              | PD            | Z             | DC            | С        | 0001 1xxx                | 000q quuu                           |
| 104h <sup>(4)</sup>   | FSR    | Indirect dat | a memory ac    | dress pointe  | er              | 1             |               |               | 1        | xxxx xxxx                | uuuu uuuu                           |
| 105h                  | _      | Unimpleme    | nted           |               |                 |               |               |               |          | _                        | _                                   |
| 106h                  | PORTB  | PORTB Da     | ta Latch whe   | n written: PC | ORTB pins whe   | en read       |               |               |          | xxxx xxxx                | uuuu uuuu                           |
| 107h                  | —      | Unimpleme    | nimplemented   |               |                 |               |               |               |          | —                        | —                                   |
| 108h                  | —      | Unimpleme    | nimplemented   |               |                 |               |               |               |          | —                        | —                                   |
| 109h                  | —      | Unimpleme    | Inimplemented  |               |                 |               |               |               | —        | —                        |                                     |
| 10Ah <sup>(1,4)</sup> | PCLATH | —            | _              | _             | Write Buffer f  | or the upper  | 5 bits of the | Program Cou   | Inter    | 0 0000                   | 0 0000                              |
| 10Bh <b>(4)</b>       | INTCON | GIE          | PEIE           | TOIE          | INTE            | RBIE          | TOIF          | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 10Ch-<br>10Fh         | _      | Unimpleme    | nted           | •             |                 | •             | •             |               |          | _                        | _                                   |
| Bank 3                |        |              |                |               |                 |               |               |               |          |                          |                                     |
| 180h <sup>(4)</sup>   | INDF   | Addressing   | this location  | uses conter   | nts of FSR to a | ddress data ı | memory (not   | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 181h                  | OPTION | RBPU         | INTEDG         | TOCS          | TOSE            | PSA           | PS2           | PS1           | PS0      | 1111 1111                | 1111 1111                           |
| 182h <sup>(4)</sup>   | PCL    | Program Co   | ounter's (PC)  | Least Sigr    | nificant Byte   |               |               | •             | •        | 0000 0000                | 0000 0000                           |
| 183h <sup>(4)</sup>   | STATUS | IRP          | RP1            | RP0           | TO              | PD            | Z             | DC            | с        | 0001 1xxx                | 000q quuu                           |
| 184h <sup>(4)</sup>   | FSR    | Indirect dat | a memory ac    | dress pointe  | er              |               |               | 1             |          | xxxx xxxx                | uuuu uuuu                           |
| 185h                  | _      | Unimpleme    | nted           |               |                 |               |               |               |          | _                        | _                                   |
| 186h                  | TRISB  | PORTB Da     | ta Direction F | Register      |                 |               |               |               |          | 1111 1111                | 1111 1111                           |
| 187h                  | _      | Unimpleme    | nted           |               |                 |               |               |               |          | _                        | _                                   |
| 188h                  | _      | Unimpleme    | nted           |               |                 |               |               |               |          | _                        | _                                   |
| 189h                  | —      | Unimpleme    | nted           |               |                 |               |               |               |          | —                        | —                                   |
| 18Ah <sup>(1,4)</sup> | PCLATH | _            | _              | _             | Write Buffer f  | or the upper  | 5 bits of the | Program Cou   | Inter    | 0 0000                   | 0 0000                              |
| 18Bh <sup>(4)</sup>   | INTCON | GIE          | PEIE           | TOIE          | INTE            | RBIE          | TOIF          | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 18Ch-<br>18Fh         | _      | Unimpleme    | nted           |               |                 |               |               |               |          | _                        | _                                   |

TABLE 4-3: PIC16C76/77 SPECIAL FUNCTION REGISTER SUMMARY (Cont.'d)

 $\label{eq:logarder} \begin{array}{ll} \mbox{Legend:} & x = \mbox{unknown}, \mbox{$u$} = \mbox{unknown}, \mbox{$q$} = \mbox{value depends on condition, $-$ = unimplemented read as '0'.} \\ & \mbox{Shaded locations are unimplemented, read as '0'.} \end{array}$ 

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

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

3: Bits PSPIE and PSPIF are reserved on the PIC16C76, always maintain these bits clear.

4: These registers can be addressed from any bank.

5: PORTD and PORTE are not physically implemented on the PIC16C76, read as '0'.

4.2.2.5 PIR1 REGISTER

Applicable Devices

This register contains the individual flag bits for the Peripheral interrupts.

FIGURE 4-12: PIR1 REGISTER PIC16C72 (ADDRESS 0Ch)

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

#### U-0 R/W-0 U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 ADIF SSPIF CCP1IF TMR2IF TMR1IF = Readable bit R = Writable bit W bit0 bit7 = Unimplemented bit, U read as '0' n = Value at POR reset bit 7: Unimplemented: Read as '0' bit 6: ADIF: A/D Converter Interrupt Flag bit 1 = An A/D conversion completed (must be cleared in software) 0 = The A/D conversion is not complete bit 5-4: Unimplemented: Read as '0' bit 3: SSPIF: Synchronous Serial Port Interrupt Flag bit 1 = The transmission/reception is complete (must be cleared in software) 0 = Waiting to transmit/receive bit 2: CCP1IF: CCP1 Interrupt Flag bit Capture Mode 1 = A TMR1 register capture occurred (must be cleared in software) 0 = No TMR1 register capture occurred Compare Mode 1 = A TMR1 register compare match occurred (must be cleared in software) 0 = No TMR1 register compare match occurred PWM Mode Unused in this mode TMR2IF: TMR2 to PR2 Match Interrupt Flag bit bit 1: 1 = TMR2 to PR2 match occurred (must be cleared in software) 0 = No TMR2 to PR2 match occurred bit 0: TMR1IF: TMR1 Overflow Interrupt Flag bit 1 = TMR1 register overflowed (must be cleared in software) 0 = TMR1 register did not overflow Interrupt flag bits get set when an interrupt condition occurs regardless of the state of its corresponding enable bit or the global enable bit, GIE (INTCON<7>). User software should ensure the appropriate interrupt flag bits are clear prior to enabling an interrupt.

4.2.2.6 PIE2 REGISTER Applicable Devices 72 73 73 74 74 76 77

This register contains the individual enable bit for the CCP2 peripheral interrupt.

#### FIGURE 4-14: PIE2 REGISTER (ADDRESS 8Dh)



## 4.3 PCL and PCLATH Applicable Devices 72/73/73A/74/74A/76/77

The program counter (PC) is 13-bits wide. The low byte comes from the PCL register, which is a readable and writable register. The upper bits (PC<12:8>) are not readable, but are indirectly writable through the PCLATH register. On any reset, the upper bits of the PC will be cleared. Figure 4-17 shows the two situations for the loading of the PC. The upper example in the figure shows how the PC is loaded on a write to PCL (PCLATH<4:0>  $\rightarrow$  PCH). The lower example in the figure shows how the PC is loaded during a CALL or GOTO instruction (PCLATH<4:3>  $\rightarrow$  PCH).

#### FIGURE 4-17: LOADING OF PC IN DIFFERENT SITUATIONS



#### 4.3.1 COMPUTED GOTO

A computed GOTO is accomplished by adding an offset to the program counter (ADDWF PCL). When doing a table read using a computed GOTO method, care should be exercised if the table location crosses a PCL memory boundary (each 256 byte block). Refer to the application note *"Implementing a Table Read"* (AN556).

#### 4.3.2 STACK

The PIC16CXX family has an 8 level deep x 13-bit wide hardware stack. The stack space is not part of either program or data space and the stack pointer is not readable or writable. The PC is PUSHed onto the stack when a CALL instruction is executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer. This means that after the stack has been PUSHed eight times, the ninth push overwrites the value that was stored from the first push. The tenth push overwrites the second push (and so on).

- **Note 1:** There are no status bits to indicate stack overflow or stack underflow conditions.
- Note 2: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, RETURN, RETLW, and RETFIE instructions, or the vectoring to an interrupt address.

#### 4.4 Program Memory Paging Applicable Devices 72|73|73A|74|74A|76|77

PIC16C7X devices are capable of addressing a continuous 8K word block of program memory. The CALL and GOTO instructions provide only 11 bits of address to allow branching within any 2K program memory page. When doing a CALL or GOTO instruction the upper 2 bits of the address are provided by PCLATH<4:3>. When doing a CALL or GOTO instruction, the user must ensure that the page select bits are programmed so that the desired program memory page is addressed. If a return from a CALL instruction (or interrupt) is executed, the entire 13-bit PC is pushed onto the stack. Therefore, manipulation of the PCLATH<4:3> bits are not required for the return instructions (which POPs the address from the stack).

Note: PIC16C7X devices with 4K or less of program memory ignore paging bit PCLATH<4>. The use of PCLATH<4> as a general purpose read/write bit is not recommended since this may affect upward compatibility with future products.

#### 5.7 Parallel Slave Port Applicable Devices 72 73 73 74 74 76 77

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

It can directly interface to an 8-bit microprocessor data bus. The external microprocessor can read or write the PORTD latch as an 8-bit latch. Setting bit PSPMODE enables port pin RE0/RD/AN5 to be the RD input, RE1/ WR/AN6 to be the WR input and RE2/CS/AN7 to be the CS (chip select) input. For this functionality, the corresponding data direction bits of the TRISE register (TRISE<2:0>) must be configured as inputs (set) and the A/D port configuration bits PCFG2:PCFG0 (ADCON1<2:0>) must be set, which will configure pins RE2:RE0 as digital I/O.

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

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

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

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

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

#### FIGURE 5-11: PORTD AND PORTE BLOCK DIAGRAM (PARALLEL SLAVE PORT)



# PIC16C7X



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

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



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

| <u>U-0</u> | U-0                                                                          | R/W-0                                                                                                                                     | R/W-0                                                                                                                                                                                                                                           | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W-0                                                                                                      | R/W-0                                                                                     | R/W-0                                                    |                                                                   |
|------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------|
| —          | —                                                                            | CCPxX                                                                                                                                     | CCPxY                                                                                                                                                                                                                                           | CCPxM3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CCPxM2                                                                                                     | CCPxM1                                                                                    | CCPxM0                                                   | R = Readable bit                                                  |
| bit7       |                                                                              |                                                                                                                                           |                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                            |                                                                                           | bit0                                                     | W = Writable bit                                                  |
|            |                                                                              |                                                                                                                                           |                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                            |                                                                                           |                                                          | U = Unimplemented bit,                                            |
|            |                                                                              |                                                                                                                                           |                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                            |                                                                                           |                                                          | - n =Value at POR reset                                           |
| bit 7-6:   | Unim                                                                         | plemente                                                                                                                                  | d: Read a                                                                                                                                                                                                                                       | s '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                            |                                                                                           |                                                          |                                                                   |
| bit 5-4:   | CCPx<br>Captu<br>Comp<br>PWM                                                 | X:CCPxY<br>ire Mode:<br>bare Mode<br>Mode: Th                                                                                             | : PWM Le<br>Unused<br>: Unused<br>ese bits a                                                                                                                                                                                                    | ast Signific<br>re the two L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ant bits<br>.Sbs of the F                                                                                  | PWM duty c                                                                                | cycle. The eig                                           | ht MSbs are found in CCPRxL.                                      |
| bit 3-0:   | CCPx<br>0000<br>0100<br>0101<br>0110<br>0111<br>1000<br>1001<br>1010<br>1011 | <b>M3:CCPx</b><br>= Capture<br>= Capture<br>= Capture<br>= Capture<br>= Capture<br>= Compar<br>= Compar<br>= Compar<br>and sta<br>= PWM m | <b>MO</b> : CCP2<br>a/Compare<br>a mode, ev<br>a mode, ev<br>re mode, g<br>re mode, t<br>re mode, t<br>re mode, t<br>re mode, t<br>re mode, t<br>re mode, t | K Mode Sele<br>(PWM off (<br>very falling e<br>very rising e<br>very 4th risin<br>very 16th risin<br>very 16t | ect bits<br>resets CCP:<br>edge<br>ng edge<br>n match (CC<br>on match (CC<br>al event (CC<br>n (if A/D mod | x module)<br>CPxIF bit is<br>CCPxIF bit is<br>upt on matc<br>CPxIF bit is<br>dule is enab | set)<br>is set)<br>h (CCPxIF b<br>set; CCP1 re<br>iled)) | it is set, CCPx pin is unaffected)<br>sets TMR1; CCP2 resets TMR1 |

# 10.1 <u>Capture Mode</u>

Applicable Devices

72 73 73A 74 74A 76 77

In Capture mode, CCPR1H:CCPR1L captures the 16-bit value of the TMR1 register when an event occurs on pin RC2/CCP1. An event is defined as:

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

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

#### 10.1.1 CCP PIN CONFIGURATION

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

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

#### FIGURE 10-2: CAPTURE MODE OPERATION BLOCK DIAGRAM



#### 10.1.2 TIMER1 MODE SELECTION

Timer1 must be running in timer mode or synchronized counter mode for the CCP module to use the capture feature. In asynchronous counter mode, the capture operation may not work.

#### 10.1.3 SOFTWARE INTERRUPT

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

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.



#### 11.4 <u>I<sup>2</sup>C<sup>™</sup> Overview</u>

This section provides an overview of the Inter-Integrated Circuit ( $I^2C$ ) bus, with Section 11.5 discussing the operation of the SSP module in  $I^2C$  mode.

The  $l^2C$  bus is a two-wire serial interface developed by the Philips Corporation. The original specification, or standard mode, was for data transfers of up to 100 Kbps. The enhanced specification (fast mode) is also supported. This device will communicate with both standard and fast mode devices if attached to the same bus. The clock will determine the data rate.

The  $l^2C$  interface employs a comprehensive protocol to ensure reliable transmission and reception of data. When transmitting data, one device is the "master" which initiates transfer on the bus and generates the clock signals to permit that transfer, while the other device(s) acts as the "slave." All portions of the slave protocol are implemented in the SSP module's hardware, except general call support, while portions of the master protocol need to be addressed in the PIC16CXX software. Table 11-3 defines some of the  $l^2C$  bus terminology. For additional information on the  $l^2C$  interface specification, refer to the Philips document "*The*  $l^2C$  bus and how to use it."#939839340011, which can be obtained from the Philips Corporation.

In the I<sup>2</sup>C interface protocol each device has an address. When a master wishes to initiate a data transfer, it first transmits the address of the device that it wishes to "talk" to. All devices "listen" to see if this is their address. Within this address, a bit specifies if the master wishes to read-from/write-to the slave device. The master and slave are always in opposite modes (transmitter/receiver) of operation during a data transfer. That is they can be thought of as operating in either of these two relations:

- Master-transmitter and Slave-receiver
- · Slave-transmitter and Master-receiver

In both cases the master generates the clock signal.

The output stages of the clock (SCL) and data (SDA) lines must have an open-drain or open-collector in order to perform the wired-AND function of the bus. External pull-up resistors are used to ensure a high level when no device is pulling the line down. The number of devices that may be attached to the I<sup>2</sup>C bus is limited only by the maximum bus loading specification of 400 pF.

# 11.4.1 INITIATING AND TERMINATING DATA TRANSFER

During times of no data transfer (idle time), both the clock line (SCL) and the data line (SDA) are pulled high through the external pull-up resistors. The START and STOP conditions determine the start and stop of data transmission. The START condition is defined as a high to low transition of the SDA when the SCL is high. The STOP condition is defined as a low to high transition of the SDA when the SCL is high. The START and STOP conditions for starting and terminating data transfer. Due to the definition of the START and STOP conditions, when data is being transmitted, the SDA line can only change state when the SCL line is low.

#### FIGURE 11-14: START AND STOP CONDITIONS



| Term            | Description                                                                                                                                 |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter     | The device that sends the data to the bus.                                                                                                  |
| Receiver        | The device that receives the data from the bus.                                                                                             |
| Master          | The device which initiates the transfer, generates the clock and terminates the transfer.                                                   |
| Slave           | The device addressed by a master.                                                                                                           |
| Multi-master    | More than one master device in a system. These masters can attempt to control the bus at the same time without corrupting the message.      |
| Arbitration     | Procedure that ensures that only one of the master devices will control the bus. This ensure that the transfer data does not get corrupted. |
| Synchronization | Procedure where the clock signals of two or more devices are synchronized.                                                                  |

## TABLE 11-3: I<sup>2</sup>C BUS TERMINOLOGY

#### 12.4 USART Synchronous Slave Mode

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

Synchronous slave mode differs from the Master mode in the fact that the shift clock is supplied externally at the RC6/TX/CK pin (instead of being supplied internally in master mode). This allows the device to transfer or receive data while in SLEEP mode. Slave mode is entered by clearing bit CSRC (TXSTA<7>).

#### 12.4.1 USART SYNCHRONOUS SLAVE TRANSMIT

The operation of the synchronous master and slave modes are identical except in the case of the SLEEP mode.

If two words are written to the TXREG and then the SLEEP instruction is executed, the following will occur:

- a) The first word will immediately transfer to the TSR register and transmit.
- b) The second word will remain in TXREG register.
- c) Flag bit TXIF will not be set.
- d) When the first word has been shifted out of TSR, the TXREG register will transfer the second word to the TSR and flag bit TXIF will now be set.
- e) If enable bit TXIE is set, the interrupt will wake the chip from SLEEP and if the global interrupt is enabled, the program will branch to the interrupt vector (0004h).

Steps to follow when setting up a Synchronous Slave Transmission:

- 1. Enable the synchronous slave serial port by setting bits SYNC and SPEN and clearing bit CSRC.
- 2. Clear bits CREN and SREN.
- 3. If interrupts are desired, then set enable bit TXIE.
- 4. If 9-bit transmission is desired, then set bit TX9.
- 5. Enable the transmission by setting enable bit TXEN.
- 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D.
- 7. Start transmission by loading data to the TXREG register.

#### 12.4.2 USART SYNCHRONOUS SLAVE RECEPTION

The operation of the synchronous master and slave modes is identical except in the case of the SLEEP mode. Also, bit SREN is a don't care in slave mode.

If receive is enabled, by setting bit CREN, prior to the SLEEP instruction, then a word may be received during SLEEP. On completely receiving the word, the RSR register will transfer the data to the RCREG register and if enable bit RCIE bit is set, the interrupt generated will wake the chip from SLEEP. If the global interrupt is enabled, the program will branch to the interrupt vector (0004h).

Steps to follow when setting up a Synchronous Slave Reception:

- 1. Enable the synchronous master serial port by setting bits SYNC and SPEN and clearing bit CSRC.
- 2. If interrupts are desired, then set enable bit RCIE.
- 3. If 9-bit reception is desired, then set bit RX9.
- 4. To enable reception, set enable bit CREN.
- 5. Flag bit RCIF will be set when reception is complete and an interrupt will be generated, if enable bit RCIE was set.
- 6. Read the RCSTA register to get the ninth bit (if enabled) and determine if any error occurred during reception.
- 7. Read the 8-bit received data by reading the RCREG register.
- 8. If any error occurred, clear the error by clearing bit CREN.

NOTES:

## 14.5 Interrupts Applicable Devices 72 73 73 74 74 76 77

The PIC16C7X family has up to 12 sources of interrupt. The interrupt control register (INTCON) records individual interrupt requests in flag bits. It also has individual and global interrupt enable bits.

| Note: | Individual interrupt flag bits are set regard- |
|-------|------------------------------------------------|
|       | less of the status of their corresponding      |
|       | mask bit or the GIE bit.                       |

A global interrupt enable bit, GIE (INTCON<7>) enables (if set) all un-masked interrupts or disables (if cleared) all interrupts. When bit GIE is enabled, and an interrupt's flag bit and mask bit are set, the interrupt will vector immediately. Individual interrupts can be disabled through their corresponding enable bits in various registers. Individual interrupt bits are set regardless of the status of the GIE bit. The GIE bit is cleared on reset.

The "return from interrupt" instruction, RETFIE, exits the interrupt routine as well as sets the GIE bit, which re-enables interrupts.

The RB0/INT pin interrupt, the RB port change interrupt and the TMR0 overflow interrupt flags are contained in the INTCON register.

The peripheral interrupt flags are contained in the special function registers PIR1 and PIR2. The corresponding interrupt enable bits are contained in special function registers PIE1 and PIE2, and the peripheral interrupt enable bit is contained in special function register INTCON.

When an interrupt is responded to, the GIE bit is cleared to disable any further interrupt, the return address is pushed onto the stack and the PC is loaded with 0004h. Once in the interrupt service routine the source(s) of the interrupt can be determined by polling the interrupt flag bits. The interrupt flag bit(s) must be cleared in software before re-enabling interrupts to avoid recursive interrupts.

For external interrupt events, such as the INT pin or PORTB change interrupt, the interrupt latency will be three or four instruction cycles. The exact latency depends when the interrupt event occurs (Figure 14-17). The latency is the same for one or two cycle instructions. Individual interrupt flag bits are set regardless of the status of their corresponding mask bit or the GIE bit.

- Note: For the PIC16C73/74, if an interrupt occurs while the Global Interrupt Enable (GIE) bit is being cleared, the GIE bit may unintentionally be re-enabled by the user's Interrupt Service Routine (the RETFIE instruction). The events that would cause this to occur are:
  - 1. An instruction clears the GIE bit while an interrupt is acknowledged.
  - 2. The program branches to the Interrupt vector and executes the Interrupt Service Routine.
  - The Interrupt Service Routine completes with the execution of the RET-FIE instruction. This causes the GIE bit to be set (enables interrupts), and the program returns to the instruction after the one which was meant to disable interrupts.

Perform the following to ensure that interrupts are globally disabled:

| LOOP | BCF   | INTCON, | GIE | ; | Disable global   |
|------|-------|---------|-----|---|------------------|
|      |       |         |     | ; | interrupt bit    |
|      | BTFSC | INTCON, | GIE | ; | Global interrupt |
|      |       |         |     | ; | disabled?        |
|      | GOTO  | LOOP    |     | ; | NO, try again    |
|      | :     |         |     | ; | Yes, continue    |
|      |       |         |     | ; | with program     |
|      |       |         |     | ; | flow             |

# PIC16C7X

| BCF               | Bit Clear                        | r f                     |                 |                       | BTFSC             | E        | Bit Test,                   | Skip if Cl                | ear                 |                  |
|-------------------|----------------------------------|-------------------------|-----------------|-----------------------|-------------------|----------|-----------------------------|---------------------------|---------------------|------------------|
| Syntax:           | [ <i>label</i> ] B0              | CF f,b                  |                 |                       | Syntax:           | [        | <i>label</i> ] BT           | FSC f,b                   |                     |                  |
| Operands:         | $0 \le f \le 12$ $0 \le b \le 7$ | 27                      |                 |                       | Operands:         | (        | ) ≤ f ≤ 12<br>) ≤ b ≤ 7     | 7                         |                     |                  |
| Operation:        | $0 \rightarrow (f < b)$          | >)                      |                 |                       | Operation:        | 5        | skip if (f<                 | b>) = 0                   |                     |                  |
| Status Affected:  | None                             |                         |                 |                       | Status Affecte    | ed: N    | None                        |                           |                     |                  |
| Encoding:         | 01                               | 00bb                    | bfff            | ffff                  | Encoding:         | Γ        | 01                          | 10bb                      | bfff                | ffff             |
| Description:      | Bit 'b' in re                    | egister 'f' is          | s cleared.      |                       | Description:      | l        | f bit 'b' in i              | register 'f' is           | '1' then th         | ne next          |
| Words:            | 1                                |                         |                 |                       |                   | ii<br>It | nstruction<br>f bit 'b', in | is executed register 'f'. | d.<br>is '0' then ' | the next         |
| Cycles:           | 1                                |                         |                 |                       |                   | i        | nstruction                  | is discarde               | d, and a N          | IOP is           |
| Q Cycle Activity: | Q1                               | Q2                      | Q3              | Q4                    |                   | e        | executed in                 | nstead, ma                | king this a         | 2Tcy             |
|                   | Decode                           | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' | Words:<br>Cycles: |          | l<br>1(2)                   |                           |                     |                  |
| Example           | BCF                              | FLAG_                   | REG, 7          |                       | Q Cycle Activ     | vity:    | Q1                          | Q2                        | Q3                  | Q4               |
|                   | Before In                        | struction               |                 |                       |                   |          | Decode                      | Read<br>register 'f'      | Process<br>data     | No-<br>Operation |
|                   | After Inst                       | FLAG_RE                 | =G = 0xC7       |                       | lf Sk             | kip: (   | (2nd Cyc                    | le)                       |                     |                  |
|                   |                                  | FLAG_RE                 | EG = 0x47       |                       |                   |          | Q1                          | Q2                        | Q3                  | Q4               |
|                   |                                  |                         |                 |                       |                   |          | No-<br>Operation            | No-<br>Operation          | No-<br>Operation    | No-<br>Operation |
|                   |                                  |                         |                 |                       | Example           |          | HERE<br>FALSE<br>TRUE       | BTFSC<br>GOTO<br>•        | FLAG,1<br>PROCESS_  | _CODE            |

| BSF               | Bit Set f                                                           |                         |                 |                       |  |  |
|-------------------|---------------------------------------------------------------------|-------------------------|-----------------|-----------------------|--|--|
| Syntax:           | [ <i>label</i> ] BSF f,b                                            |                         |                 |                       |  |  |
| Operands:         | $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ |                         |                 |                       |  |  |
| Operation:        | $1 \rightarrow (f < b >)$                                           |                         |                 |                       |  |  |
| Status Affected:  | None                                                                |                         |                 |                       |  |  |
| Encoding:         | 01                                                                  | 01bb                    | bfff            | ffff                  |  |  |
| Description:      | Bit 'b' in register 'f' is set.                                     |                         |                 |                       |  |  |
| Words:            | 1                                                                   |                         |                 |                       |  |  |
| Cycles:           | 1                                                                   |                         |                 |                       |  |  |
| Q Cycle Activity: | Q1                                                                  | Q2                      | Q3              | Q4                    |  |  |
|                   | Decode                                                              | Read<br>register<br>'f' | Process<br>data | Write<br>register 'f' |  |  |
| Example           | BSF                                                                 | FLAG_F                  | REG, 7          |                       |  |  |
|                   | Before In                                                           | struction<br>FLAG_RE    | EG = 0x0A       | A                     |  |  |
|                   | After Inst                                                          | ruction<br>FLAG_RE      | EG = 0x8A       | Ą                     |  |  |

#### Before Instruction PC = address HERE

•

|             | 0    | _    | aaarooo  |       |
|-------------|------|------|----------|-------|
| After Insti | ruct | ion  |          |       |
| i           | f FL | AG<′ | l > = 0, |       |
| I           | PC = | =    | address  | TRUE  |
| i           | f FL | AG<′ | l>=1,    |       |
| I           | PC = | =    | address  | FALSE |
|             |      |      |          |       |

| COMF                         | Complement f                                                                                                                             | DECFSZ            | Decrement f, Skip if 0                                                                                                                                             |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:                      | [ <i>label</i> ] COMF f,d                                                                                                                | Syntax:           | [label] DECFSZ f,d                                                                                                                                                 |
| Operands:                    | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                        | Operands:         | 0 ≤ f ≤ 127<br>d ∈ [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-                                                                                                 | Encoding:         | 00 1011 dfff ffff                                                                                                                                                  |
| Wordo:                       | 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<br>back in register 'f' |
| vvoras:                      |                                                                                                                                          |                   | If the result is 1, the next instruction, is                                                                                                                       |
| Cycles:<br>Q Cycle Activity: | 1<br>Q1 Q2 Q3 Q4                                                                                                                         |                   | executed instead making it a 2Tcy instruc-<br>tion.                                                                                                                |
|                              | Decode Read Process Write to                                                                                                             | Words:            | 1                                                                                                                                                                  |
|                              | register data destination                                                                                                                | Cycles:           | 1(2)                                                                                                                                                               |
|                              |                                                                                                                                          | Q Cycle Activity: | Q1 Q2 Q3 Q4                                                                                                                                                        |
| Example                      | COMF REG1,0<br>Before Instruction                                                                                                        |                   | Decode Read register 'f' Process Write to data destination                                                                                                         |
|                              | REG1 = 0x13                                                                                                                              | If Skip:          | (2nd Cycle)                                                                                                                                                        |
|                              | After Instruction<br>REG1 = $0x13$                                                                                                       |                   | Q1 Q2 Q3 Q4                                                                                                                                                        |
|                              | W = 0xEC                                                                                                                                 |                   | No-No-No-OperationOperationOperation                                                                                                                               |
| DECF                         | Decrement f                                                                                                                              | Evenale           |                                                                                                                                                                    |
| Syntax:                      | [ <i>label</i> ] DECF f,d                                                                                                                | Example           | HERE DECFSZ CNT, I<br>GOTO LOOP                                                                                                                                    |
| Operands:                    | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in \ [0,1] \end{array}$                                                                        |                   | CONTINUE •                                                                                                                                                         |
| Operation:                   | (f) - 1 $\rightarrow$ (destination)                                                                                                      |                   | Before Instruction                                                                                                                                                 |
| Status Affected:             | Z                                                                                                                                        |                   | PC = address HERE                                                                                                                                                  |
| Encoding:                    | 00 0011 dfff ffff                                                                                                                        |                   | CNT = CNT - 1                                                                                                                                                      |
| Description:                 | 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'. |                   | if CNT = 0,<br>PC = address CONTINUE                                                                                                                               |
| Words:                       | 1                                                                                                                                        |                   | PC = address HERE+1                                                                                                                                                |
| Cycles:                      | 1                                                                                                                                        |                   |                                                                                                                                                                    |
| Q Cycle Activity:            | Q1 Q2 Q3 Q4                                                                                                                              |                   |                                                                                                                                                                    |
|                              | Decode Read Process Write to                                                                                                             |                   |                                                                                                                                                                    |
|                              | register data destination                                                                                                                |                   |                                                                                                                                                                    |
| Example                      | DECF CNT, 1                                                                                                                              |                   |                                                                                                                                                                    |
| Example                      | DECF CNT, 1<br>Before Instruction<br>CNT = 0x01                                                                                          |                   |                                                                                                                                                                    |

| GOTO              | Unconditional Branch                                                                                                                                                                          |                     |                  |                  | II        | NCF                | Increme                                                                                                                                                             | nt f                    |                 |                      |  |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------|------------------|-----------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|----------------------|--|
| Syntax:           | [ label ]                                                                                                                                                                                     | GOTO                | k                |                  | S         | Syntax:            | [ label ]                                                                                                                                                           | INCF f                  | ,d              |                      |  |
| Operands:         | $0 \le k \le 2047$                                                                                                                                                                            |                     |                  | C                | Operands: | $0 \le f \le 127$  |                                                                                                                                                                     |                         |                 |                      |  |
| Operation:        | $k \rightarrow PC < 10:0 >$                                                                                                                                                                   |                     |                  |                  |           | d ∈ [0,1]          |                                                                                                                                                                     |                         |                 |                      |  |
|                   | $PCLATH<4:3> \rightarrow PC<12:11>$                                                                                                                                                           |                     |                  |                  | C         | Operation:         | (f) + 1 $\rightarrow$ (destination)                                                                                                                                 |                         |                 |                      |  |
| Status Affected:  | None                                                                                                                                                                                          |                     |                  |                  | S         | Status Affected:   | Z                                                                                                                                                                   |                         |                 |                      |  |
| Encoding:         | 10                                                                                                                                                                                            | 1kkk                | kkkk             | kkkk             | E         | ncoding:           | 00                                                                                                                                                                  | 1010                    | dfff            | ffff                 |  |
| Description:      | GOTO is an unconditional branch. The<br>eleven bit immediate value is loaded<br>into PC bits <10:0>. The upper bits of<br>PC are loaded from PCLATH<4:3>.<br>GOTO is a two cycle instruction. |                     |                  |                  | C         | Description:       | The contents of register 'f' are incre-<br>mented. If 'd' is 0 the result is placed in<br>the W register. If 'd' is 1 the result is<br>placed back in register 'f'. |                         |                 |                      |  |
| Words:            | 1                                                                                                                                                                                             |                     |                  |                  | V         | Vords:             | 1                                                                                                                                                                   |                         |                 |                      |  |
| Cycles:           | 2                                                                                                                                                                                             |                     |                  |                  | C         | Cycles:            | 1                                                                                                                                                                   |                         |                 |                      |  |
| Q Cycle Activity: | Q1                                                                                                                                                                                            | Q2                  | Q3               | Q4               | C         | Q Cycle Activity:  | Q1                                                                                                                                                                  | Q2                      | Q3              | Q4                   |  |
| 1st Cycle         | Decode                                                                                                                                                                                        | Read<br>literal 'k' | Process<br>data  | Write to<br>PC   |           |                    | Decode                                                                                                                                                              | Read<br>register<br>'f' | Process<br>data | Write to destination |  |
| 2nd Cycle         | No-<br>Operation                                                                                                                                                                              | No-<br>Operation    | No-<br>Operation | No-<br>Operation |           |                    |                                                                                                                                                                     |                         |                 |                      |  |
|                   |                                                                                                                                                                                               |                     |                  |                  | E         | Example            | INCF                                                                                                                                                                | CNT,                    | 1               |                      |  |
| Example           | GOTO THERE                                                                                                                                                                                    |                     |                  |                  |           | Before Instruction |                                                                                                                                                                     |                         |                 |                      |  |
| After Instruction |                                                                                                                                                                                               |                     |                  |                  |           | CNT<br>7           | = 0xF                                                                                                                                                               | F                       |                 |                      |  |
|                   | PC = Address THERE                                                                                                                                                                            |                     |                  |                  |           | After Inst         | ruction                                                                                                                                                             | = 0                     |                 |                      |  |
|                   |                                                                                                                                                                                               |                     |                  |                  |           |                    |                                                                                                                                                                     | CNT                     | = 0x0           | 0                    |  |
|                   |                                                                                                                                                                                               |                     |                  |                  |           |                    |                                                                                                                                                                     | 7                       | - 1             |                      |  |

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

## FIGURE 17-8: SPI MODE TIMING



| TABI F 17-7.      | SPI MODE I | REQUIREMENTS |
|-------------------|------------|--------------|
| $IADLL II^{-1}$ . |            |              |

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

† Data in "Typ" column is at 5V, 25°C unless otherwise stated. These parameters are for design guidance only and are not tested. 
 Applicable Devices
 72
 73
 73A
 74
 76
 77

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

#### FIGURE 20-2: EXTERNAL CLOCK TIMING



#### TABLE 20-2: EXTERNAL CLOCK TIMING REQUIREMENTS

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

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

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

## 22.0 PACKAGING INFORMATION



## 22.1 28-Lead Ceramic Side Brazed Dual In-Line with Window (300 mil)(JW)

| Package Group: Ceramic Side Brazed Dual In-Line (CER) |        |             |           |        |       |       |  |  |
|-------------------------------------------------------|--------|-------------|-----------|--------|-------|-------|--|--|
| Symbol                                                |        | Millimeters |           | Inches |       |       |  |  |
|                                                       | Min    | Мах         | Notes     | Min    | Max   | Notes |  |  |
| α                                                     | 0°     | 10°         |           | 0°     | 10°   |       |  |  |
| А                                                     | 3.937  | 5.030       |           | 0.155  | 0.198 |       |  |  |
| A1                                                    | 1.016  | 1.524       |           | 0.040  | 0.060 |       |  |  |
| A2                                                    | 2.921  | 3.506       |           | 0.115  | 0.138 |       |  |  |
| A3                                                    | 1.930  | 2.388       |           | 0.076  | 0.094 |       |  |  |
| В                                                     | 0.406  | 0.508       |           | 0.016  | 0.020 |       |  |  |
| B1                                                    | 1.219  | 1.321       | Typical   | 0.048  | 0.052 |       |  |  |
| С                                                     | 0.228  | 0.305       | Typical   | 0.009  | 0.012 |       |  |  |
| D                                                     | 35.204 | 35.916      |           | 1.386  | 1.414 |       |  |  |
| D1                                                    | 32.893 | 33.147      | Reference | 1.295  | 1.305 |       |  |  |
| Е                                                     | 7.620  | 8.128       |           | 0.300  | 0.320 |       |  |  |
| E1                                                    | 7.366  | 7.620       |           | 0.290  | 0.300 |       |  |  |
| e1                                                    | 2.413  | 2.667       | Typical   | 0.095  | 0.105 |       |  |  |
| eA                                                    | 7.366  | 7.874       | Reference | 0.290  | 0.310 |       |  |  |
| eB                                                    | 7.594  | 8.179       |           | 0.299  | 0.322 |       |  |  |
| L                                                     | 3.302  | 4.064       |           | 0.130  | 0.160 |       |  |  |
| N                                                     | 28     | 28          |           | 28     | 28    |       |  |  |
| S                                                     | 1.143  | 1.397       |           | 0.045  | 0.055 |       |  |  |
| S1                                                    | 0.533  | 0.737       |           | 0.021  | 0.029 |       |  |  |

NOTES: