



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 4MHz                                                                     |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 33                                                                       |
| Program Memory Size        | 14KB (8K x 14)                                                           |
| Program Memory Type        | OTP                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 368 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 6V                                                                |
| Data Converters            | A/D 8x8b                                                                 |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                          |
| Mounting Type              | Through Hole                                                             |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                                 |
| Supplier Device Package    | 40-PDIP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lc77-04-p |
|                            |                                                                          |

Email: info@E-XFL.COM

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

# 1.0 GENERAL DESCRIPTION

The PIC16C7X is a family of low-cost, high-performance, CMOS, fully-static, 8-bit microcontrollers with integrated analog-to-digital (A/D) converters, in the PIC16CXX mid-range family.

All PIC16/17 microcontrollers employ an advanced RISC architecture. The PIC16CXX microcontroller family has enhanced core features, eight-level deep stack, and multiple internal and external interrupt sources. The separate instruction and data buses of the Harvard architecture allow a 14-bit wide instruction word with the separate 8-bit wide data. The two stage instruction pipeline allows all instructions to execute in a single cycle, except for program branches which require two cycles. A total of 35 instructions (reduced instruction set) are available. Additionally, a large register set gives some of the architectural innovations used to achieve a very high performance.

PIC16CXX microcontrollers typically achieve a 2:1 code compression and a 4:1 speed improvement over other 8-bit microcontrollers in their class.

The **PIC16C72** has 128 bytes of RAM and 22 I/O pins. In addition several peripheral features are available including: three timer/counters, one Capture/Compare/ PWM module and one serial port. The Synchronous Serial Port can be configured as either a 3-wire Serial Peripheral Interface (SPI) or the two-wire Inter-Integrated Circuit (I<sup>2</sup>C) bus. Also a 5-channel high-speed 8-bit A/D is provided. The 8-bit resolution is ideally suited for applications requiring low-cost analog interface, e.g. thermostat control, pressure sensing, etc.

The PIC16C73/73A devices have 192 bytes of RAM, while the PIC16C76 has 368 byes of RAM. Each device has 22 I/O pins. In addition, several peripheral features are available including: three timer/counters, two Capture/Compare/PWM modules and two serial ports. The Synchronous Serial Port can be configured as either a 3-wire Serial Peripheral Interface (SPI) or the two-wire Inter-Integrated Circuit (I<sup>2</sup>C) bus. The Universal Syn-Asynchronous Receiver chronous Transmitter (USART) is also known as the Serial Communications Interface or SCI. Also a 5-channel high-speed 8-bit A/ D is provided. The 8-bit resolution is ideally suited for applications requiring low-cost analog interface, e.g. thermostat control, pressure sensing, etc.

The **PIC16C74/74A** devices have 192 bytes of RAM, while the **PIC16C77** has 368 bytes of RAM. Each device has 33 I/O pins. In addition several peripheral features are available including: three timer/counters, two Capture/Compare/PWM modules and two serial ports. The Synchronous Serial Port can be configured as either a 3-wire Serial Peripheral Interface (SPI) or the two-wire Inter-Integrated Circuit (I<sup>2</sup>C) bus. The Universal Synchronous Asynchronous Receiver Transmitter (USART) is also known as the Serial Communications Interface or SCI. An 8-bit Parallel Slave Port is provided. Also an 8-channel high-speed

8-bit A/D is provided. The 8-bit resolution is ideally suited for applications requiring low-cost analog interface, e.g. thermostat control, pressure sensing, etc.

The PIC16C7X family has special features to reduce external components, thus reducing cost, enhancing system reliability and reducing power consumption. There are four oscillator options, of which the single pin RC oscillator provides a low-cost solution, the LP oscillator minimizes power consumption, XT is a standard crystal, and the HS is for High Speed crystals. The SLEEP (power-down) feature provides a power saving mode. The user can wake up the chip from SLEEP through several external and internal interrupts and resets.

A highly reliable Watchdog Timer with its own on-chip RC oscillator provides protection against software lockup.

A UV erasable CERDIP packaged version is ideal for code development while the cost-effective One-Time-Programmable (OTP) version is suitable for production in any volume.

The PIC16C7X family fits perfectly in applications ranging from security and remote sensors to appliance control and automotive. The EPROM technology makes customization of application programs (transmitter codes, motor speeds, receiver frequencies, etc.) extremely fast and convenient. The small footprint packages make this microcontroller series perfect for all applications with space limitations. Low cost, low power, high performance, ease of use and I/O flexibility make the PIC16C7X very versatile even in areas where no microcontroller use has been considered before (e.g. timer functions, serial communication, capture and compare, PWM functions and coprocessor applications).

# 1.1 Family and Upward Compatibility

Users familiar with the PIC16C5X microcontroller family will realize that this is an enhanced version of the PIC16C5X architecture. Please refer to Appendix A for a detailed list of enhancements. Code written for the PIC16C5X can be easily ported to the PIC16CXX family of devices (Appendix B).

# 1.2 Development Support

PIC16C7X devices are supported by the complete line of Microchip Development tools.

Please refer to Section 16.0 for more details about Microchip's development tools.

| 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 1               |         |                      |                               |                           |                  |              |                 |               |          |                          |                                     |
| 80h <sup>(4)</sup>   | INDF    | Addressing           | this location                 | uses conter               | nts of FSR to ac | dress data   | memory (not     | a physical re | egister) | 0000 0000                | 0000 0000                           |
| 81h                  | OPTION  | RBPU                 | INTEDG                        | TOCS                      | TOSE             | PSA          | PS2             | PS1           | PS0      | 1111 1111                | 1111 1111                           |
| 82h <sup>(4)</sup>   | PCL     | Program Co           | ounter's (PC)                 | Least Signif              | ficant Byte      |              |                 |               |          | 0000 0000                | 0000 0000                           |
| 83h <b>(4)</b>       | STATUS  | IRP                  | RP1                           | RP0                       | TO               | PD           | Z               | DC            | С        | 0001 1xxx                | 000q quuu                           |
| 84h <sup>(4)</sup>   | FSR     | Indirect data        | a memory ac                   | dress pointe              | er               |              |                 |               |          | xxxx xxxx                | uuuu uuuu                           |
| 85h                  | TRISA   | _                    | PORTA Data Direction Register |                           |                  |              |                 |               |          | 11 1111                  | 11 1111                             |
| 86h                  | TRISB   | PORTB Dat            | ta Direction F                | Register                  |                  |              |                 |               |          | 1111 1111                | 1111 1111                           |
| 87h                  | TRISC   | PORTC Dat            | ta Direction I                | Register                  |                  |              |                 |               |          | 1111 1111                | 1111 1111                           |
| 88h <b>(5)</b>       | TRISD   | PORTD Dat            | TD Data Direction Register    |                           |                  |              |                 |               |          | 1111 1111                | 1111 1111                           |
| 89h <b>(5)</b>       | TRISE   | IBF                  | OBF                           | IBOV                      | PSPMODE          | _            | PORTE Dat       | a Direction E | Bits     | 0000 -111                | 0000 -111                           |
| 8Ah <sup>(1,4)</sup> | PCLATH  | _                    | —                             | _                         | Write Buffer fo  | or the upper | 5 bits of the l | Program Cou   | Inter    | 0 0000                   | 0 0000                              |
| 8Bh <sup>(4)</sup>   | INTCON  | GIE                  | PEIE                          | TOIE                      | INTE             | RBIE         | TOIF            | INTF          | RBIF     | 0000 000x                | 0000 000u                           |
| 8Ch                  | PIE1    | PSPIE <sup>(3)</sup> | ADIE                          | RCIE                      | TXIE             | SSPIE        | CCP1IE          | TMR2IE        | TMR1IE   | 0000 0000                | 0000 0000                           |
| 8Dh                  | PIE2    | _                    | _                             | —                         | _                | _            | —               | —             | CCP2IE   | 0                        | 0                                   |
| 8Eh                  | PCON    | _                    | —                             | _                         | _                | _            | _               | POR           | BOR      | dd                       | uu                                  |
| 8Fh                  | _       | Unimpleme            | nted                          | •                         |                  | •            |                 | •             | •        | _                        | _                                   |
| 90h                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 91h                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | -                        | _                                   |
| 92h                  | PR2     | Timer2 Peri          | od Register                   |                           |                  |              |                 |               |          | 1111 1111                | 1111 1111                           |
| 93h                  | SSPADD  | Synchronou           | us Serial Por                 | t (I <sup>2</sup> C mode) | Address Regis    | ter          |                 |               |          | 0000 0000                | 0000 0000                           |
| 94h                  | SSPSTAT | SMP                  | CKE                           | D/Ā                       | Р                | S            | R/W             | UA            | BF       | 0000 0000                | 0000 0000                           |
| 95h                  | _       | Unimpleme            | nted                          | •                         |                  |              |                 |               | •        | _                        | _                                   |
| 96h                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 97h                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 98h                  | TXSTA   | CSRC                 | ТХ9                           | TXEN                      | SYNC             | _            | BRGH            | TRMT          | TX9D     | 0000 -010                | 0000 -010                           |
| 99h                  | SPBRG   | Baud Rate            | Generator R                   | egister                   |                  |              |                 |               |          | 0000 0000                | 0000 0000                           |
| 9Ah                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 9Bh                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 9Ch                  | _       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | _                                   |
| 9Dh                  | -       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | _                        | —                                   |
| 9Eh                  | -       | Unimpleme            | nted                          |                           |                  |              |                 |               |          | -                        | —                                   |
| 9Fh                  | ADCON1  | _                    | _                             | _                         | _                | _            | PCFG2           | PCFG1         | PCFG0    | 000                      | 000                                 |

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

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 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'.

NOTES:

# 9.0 TIMER2 MODULE

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

Timer2 is an 8-bit timer with a prescaler and a postscaler. It can be used as the PWM time-base for PWM mode of the CCP module(s). The TMR2 register is readable and writable, and is cleared on any device reset.

The input clock (Fosc/4) has a prescale option of 1:1, 1:4 or 1:16, selected by control bits T2CKPS1:T2CKPS0 (T2CON<1:0>).

The Timer2 module has an 8-bit period register PR2. Timer2 increments from 00h until it matches PR2 and then resets to 00h on the next increment cycle. PR2 is a readable and writable register. The PR2 register is initialized to FFh upon reset.

The match output of TMR2 goes through a 4-bit postscaler (which gives a 1:1 to 1:16 scaling inclusive) to generate a TMR2 interrupt (latched in flag bit TMR2IF, (PIR1<1>)).

Timer2 can be shut off by clearing control bit TMR2ON (T2CON<2>) to minimize power consumption.

Figure 9-2 shows the Timer2 control register.

# 9.1 <u>Timer2 Prescaler and Postscaler</u> Applicable Devices

72 73 73A 74 74A 76 77

The prescaler and postscaler counters are cleared when any of the following occurs:

- a write to the TMR2 register
- a write to the T2CON register
- any device reset (Power-on Reset, MCLR reset, Watchdog Timer reset, or Brown-out Reset)

TMR2 is not cleared when T2CON is written.



The output of TMR2 (before the postscaler) is fed to the Synchronous Serial Port module which optionally uses it to generate shift clock.

# FIGURE 9-1: TIMER2 BLOCK DIAGRAM



# 11.0 SYNCHRONOUS SERIAL PORT (SSP) MODULE

# 11.1 SSP Module Overview

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

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

The SSP module in  $I^2C$  mode works the same in all PIC16C7X devices that have an SSP module. However the SSP Module in SPI mode has differences between the PIC16C76/77 and the other PIC16C7X devices.

The register definitions and operational description of SPI mode has been split into two sections because of the differences between the PIC16C76/77 and the other PIC16C7X devices. The default reset values of both the SPI modules is the same regardless of the device:

| 11.2 | SPI Mode for PIC16C72/73/73A/74/74A | 78 |
|------|-------------------------------------|----|
| 11.3 | SPI Mode for PIC16C76/77            | 83 |
| 11.4 | I2C <sup>™</sup> Overview           | 89 |
| 11.5 | SSP I2C Operation                   | 93 |

Refer to Application Note AN578, "Use of the SSP Module in the  $l^2C$  Multi-Master Environment."

# FIGURE 11-13: SPI MODE TIMING (SLAVE MODE WITH CKE = 1) (PIC16C76/77)



| <b>TABLE 11-2:</b> | <b>REGISTERS ASSOCIATED WITH SPI OPERATION (F</b> | PIC16C76/77) |  |
|--------------------|---------------------------------------------------|--------------|--|
|                    |                                                   |              |  |

| Address               | Name    | Bit 7                | Bit 6       | Bit 5      | Bit 4                         | Bit 3     | Bit 2      | Bit 1  | Bit 0  | Value<br>PC<br>BC | ,    | all o | e on<br>other<br>sets |
|-----------------------|---------|----------------------|-------------|------------|-------------------------------|-----------|------------|--------|--------|-------------------|------|-------|-----------------------|
| 0Bh,8Bh.<br>10Bh,18Bh | INTCON  | GIE                  | PEIE        | TOIE       | INTE                          | RBIE      | TOIF       | INTF   | RBIF   | 0000              | 000x | 0000  | 000u                  |
| 0Ch                   | PIR1    | PSPIF <sup>(1)</sup> | ADIF        | RCIF       | TXIF                          | SSPIF     | CCP1IF     | TMR2IF | TMR1IF | 0000              | 0000 | 0000  | 0000                  |
| 8Ch                   | PIE1    | PSPIE <sup>(1)</sup> | ADIE        | RCIE       | TXIE                          | SSPIE     | CCP1IE     | TMR2IE | TMR1IE | 0000              | 0000 | 0000  | 0000                  |
| 87h                   | TRISC   | PORTC Da             | ta Directio | on Registe | er                            |           |            |        |        | 1111              | 1111 | 1111  | 1111                  |
| 13h                   | SSPBUF  | Synchronou           | us Serial F | Port Recei | ve Buff                       | er/Transm | it Registe | r      |        | xxxx              | xxxx | uuuu  | uuuu                  |
| 14h                   | SSPCON  | WCOL                 | SSPOV       | SSPEN      | СКР                           | SSPM3     | SSPM2      | SSPM1  | SSPM0  | 0000              | 0000 | 0000  | 0000                  |
| 85h                   | TRISA   | —                    | —           | PORTA [    | PORTA Data Direction Register |           |            |        |        | 11                | 1111 | 11    | 1111                  |
| 94h                   | SSPSTAT | SMP                  | CKE         | D/Ā        | Р                             | S         | R/W        | UA     | BF     | 0000              | 0000 | 0000  | 0000                  |

Legend: x = unknown, u = unchanged, - = unimplemented read as '0'. Shaded cells are not used by the SSP in SPI mode. Note 1: Bits PSPIE and PSPIF are reserved on the PIC16C76, always maintain these bits clear.

# 11.4.4 MULTI-MASTER

The  $I^2C$  protocol allows a system to have more than one master. This is called multi-master. When two or more masters try to transfer data at the same time, arbitration and synchronization occur.

### 11.4.4.1 ARBITRATION

Arbitration takes place on the SDA line, while the SCL line is high. The master which transmits a high when the other master transmits a low loses arbitration (Figure 11-22), and turns off its data output stage. A master which lost arbitration can generate clock pulses until the end of the data byte where it lost arbitration. When the master devices are addressing the same device, arbitration continues into the data.

# FIGURE 11-22: MULTI-MASTER ARBITRATION (TWO MASTERS)



Masters that also incorporate the slave function, and have lost arbitration must immediately switch over to slave-receiver mode. This is because the winning master-transmitter may be addressing it.

Arbitration is not allowed between:

- A repeated START condition
- A STOP condition and a data bit
- A repeated START condition and a STOP condition

Care needs to be taken to ensure that these conditions do not occur.

# 11.2.4.2 Clock Synchronization

Clock synchronization occurs after the devices have started arbitration. This is performed using a wired-AND connection to the SCL line. A high to low transition on the SCL line causes the concerned devices to start counting off their low period. Once a device clock has gone low, it will hold the SCL line low until its SCL high state is reached. The low to high transition of this clock may not change the state of the SCL line, if another device clock is still within its low period. The SCL line is held low by the device with the longest low period. Devices with shorter low periods enter a high wait-state, until the SCL line comes high. When the SCL line comes high, all devices start counting off their high periods. The first device to complete its high period will pull the SCL line low. The SCL line high time is determined by the device with the shortest high period, Figure 11-23.

# FIGURE 11-23: CLOCK SYNCHRONIZATION



Steps to follow when setting up an Asynchronous Transmission:

- 1. Initialize the SPBRG register for the appropriate baud rate. If a high speed baud rate is desired, set bit BRGH. (Section 12.1)
- 2. Enable the asynchronous serial port by clearing bit SYNC and setting bit SPEN.
- 3. If interrupts are desired, then set enable bit TXIE.
- 4. If 9-bit transmission is desired, then set transmit bit TX9.
- 5. Enable the transmission by setting bit TXEN, which will also set bit TXIF.
- 6. If 9-bit transmission is selected, the ninth bit should be loaded in bit TX9D.
- 7. Load data to the TXREG register (starts transmission).

# FIGURE 12-8: ASYNCHRONOUS MASTER TRANSMISSION



# FIGURE 12-9: ASYNCHRONOUS MASTER TRANSMISSION (BACK TO BACK)



# TABLE 12-6: REGISTERS ASSOCIATED WITH ASYNCHRONOUS TRANSMISSION

| Address | Name  | Bit 7                | Bit 6    | Bit 5      | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0  | Value on:<br>POR,<br>BOR | Value on<br>all other<br>Resets |
|---------|-------|----------------------|----------|------------|-------|-------|--------|--------|--------|--------------------------|---------------------------------|
| 0Ch     | PIR1  | PSPIF <sup>(1)</sup> | ADIF     | RCIF       | TXIF  | SSPIF | CCP1IF | TMR2IF | TMR1IF | 0000 0000                | 0000 0000                       |
| 18h     | RCSTA | SPEN                 | RX9      | SREN       | CREN  | —     | FERR   | OERR   | RX9D   | 0000 -00x                | 0000 -00x                       |
| 19h     | TXREG | USART Trar           | nsmit Re | gister     |       |       |        |        |        | 0000 0000                | 0000 0000                       |
| 8Ch     | PIE1  | PSPIE <sup>(1)</sup> | ADIE     | RCIE       | TXIE  | SSPIE | CCP1IE | TMR2IE | TMR1IE | 0000 0000                | 0000 0000                       |
| 98h     | TXSTA | CSRC                 | TX9      | TXEN       | SYNC  | _     | BRGH   | TRMT   | TX9D   | 0000 -010                | 0000 -010                       |
| 99h     | SPBRG | Baud Rate (          | Generato | r Register | r     |       |        |        |        | 0000 0000                | 0000 0000                       |

Legend: x = unknown, - = unimplemented locations read as '0'. Shaded cells are not used for Asynchronous Transmission.

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

### 12.2.2 USART ASYNCHRONOUS RECEIVER

The receiver block diagram is shown in Figure 12-10. The data is received on the RC7/RX/DT pin and drives the data recovery block. The data recovery block is actually a high speed shifter operating at x16 times the baud rate, whereas the main receive serial shifter operates at the bit rate or at Fosc.

Once Asynchronous mode is selected, reception is enabled by setting bit CREN (RCSTA<4>).

The heart of the receiver is the receive (serial) shift register (RSR). After sampling the STOP bit, the received data in the RSR is transferred to the RCREG register (if it is empty). If the transfer is complete, flag bit RCIF (PIR1<5>) is set. The actual interrupt can be enabled/ disabled by setting/clearing enable bit RCIE (PIE1<5>). Flag bit RCIF is a read only bit which is cleared by the hardware. It is cleared when the RCREG register has been read and is empty. The RCREG is a

### FIGURE 12-10: USART RECEIVE BLOCK DIAGRAM

double buffered register, i.e. it is a two deep FIFO. It is possible for two bytes of data to be received and transferred to the RCREG FIFO and a third byte begin shifting to the RSR register. On the detection of the STOP bit of the third byte, if the RCREG register is still full then overrun error bit OERR (RCSTA<1>) will be set. The word in the RSR will be lost. The RCREG register can be read twice to retrieve the two bytes in the FIFO. Overrun bit OERR has to be cleared in software. This is done by resetting the receive logic (CREN is cleared and then set). If bit OERR is set, transfers from the RSR register to the RCREG register are inhibited, so it is essential to clear error bit OERR if it is set. Framing error bit FERR (RCSTA<2>) is set if a stop bit is detected as clear. Bit FERR and the 9th receive bit are buffered the same way as the receive data. Reading the RCREG, will load bits RX9D and FERR with new values, therefore it is essential for the user to read the RCSTA register before reading RCREG register in order not to lose the old FERR and RX9D information.







# 13.0 ANALOG-TO-DIGITAL CONVERTER (A/D) MODULE

# Applicable Devices

The analog-to-digital (A/D) converter module has five inputs for the PIC16C72/73/73A/76, and eight for the PIC16C74/74A/77.

The A/D allows conversion of an analog input signal to a corresponding 8-bit digital number (refer to Application Note AN546 for use of A/D Converter). The output of the sample and hold is the input into the converter, which generates the result via successive approximation. The analog reference voltage is software selectable to either the device's positive supply voltage (VDD) or the voltage level on the RA3/AN3/VREF pin. The A/D converter has a unique feature of being able to operate while the device is in SLEEP mode. To operate in sleep, the A/D conversion clock must be derived from the A/D's internal RC oscillator.

The A/D module has three registers. These registers are:

- A/D Result Register (ADRES)
- A/D Control Register 0 (ADCON0)
- A/D Control Register 1 (ADCON1)

The ADCON0 register, shown in Figure 13-1, controls the operation of the A/D module. The ADCON1 register, shown in Figure 13-2, configures the functions of the port pins. The port pins can be configured as analog inputs (RA3 can also be a voltage reference) or as digital I/O.

| R/W-0                                                                                | R/W-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W-0                                                                                                 | R/W-0                                                                            | R/W-0      | R/W-0                                | U-0         | R/W-0     |                                                                                       |  |  |
|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------|--------------------------------------|-------------|-----------|---------------------------------------------------------------------------------------|--|--|
| ADCS1                                                                                | ADCS0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CHS2                                                                                                  | CHS1                                                                             | CHS0       | GO/DONE                              | _           | ADON      | R = Readable bit                                                                      |  |  |
| bit7                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                       |                                                                                  |            |                                      |             | bit0      | W = Writable bit<br>U = Unimplemented bit,<br>read as '0'<br>- n = Value at POR reset |  |  |
| bit 7-6:                                                                             | 00 = Fos<br>01 = Fos<br>10 = Fos                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | c/2<br>c/8<br>c/32                                                                                    |                                                                                  |            | Select bits                          | ·)          |           |                                                                                       |  |  |
| bit 5-3:                                                                             | 000 = cha<br>001 = cha<br>010 = cha<br>011 = cha<br>100 = cha<br>101 = cha                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | annel 0, (F<br>annel 1, (F<br>annel 2, (F<br>annel 3, (F<br>annel 4, (F<br>annel 5, (F<br>annel 6, (F | RĂO/ANO)<br>RA1/AN1)<br>RA2/AN2)<br>RA3/AN3)<br>RA5/AN4)<br>RE0/AN5)<br>RE0/AN5) | [1)        | ts                                   |             |           |                                                                                       |  |  |
| bit 2:                                                                               | GO/DON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | E: A/D Co                                                                                             | nversion S                                                                       | Status bit |                                      |             |           |                                                                                       |  |  |
|                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | onversion                                                                                             |                                                                                  |            | this bit starts t<br>bit is automati |             |           | are when the A/D conversion                                                           |  |  |
| bit 1:                                                                               | Unimpler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nented: F                                                                                             | Read as '0                                                                       | ,          |                                      |             |           |                                                                                       |  |  |
| bit 0:                                                                               | <b>ADON</b> : $A/A = A/D c $ | onverter n                                                                                            |                                                                                  |            | d consumes no                        | o operating | g current |                                                                                       |  |  |
| <b>Note 1:</b> A/D channels 5, 6, and 7 are implemented on the PIC16C74/74A/77 only. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                       |                                                                                  |            |                                      |             |           |                                                                                       |  |  |

# FIGURE 13-1: ADCON0 REGISTER (ADDRESS 1Fh)

# 14.8 Power-down Mode (SLEEP) Applicable Devices 727373A7474A7677

Power-down mode is entered by executing a SLEEP instruction.

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

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

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

#### 14.8.1 WAKE-UP FROM SLEEP

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

- 1. External reset input on MCLR pin.
- 2. Watchdog Timer Wake-up (if WDT was enabled).
- 3. Interrupt from INT pin, RB port change, or some Peripheral Interrupts.

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

The following peripheral interrupts can wake the device from SLEEP:

- 1. TMR1 interrupt. Timer1 must be operating as an asynchronous counter.
- 2. SSP (Start/Stop) bit detect interrupt.
- 3. SSP transmit or receive in slave mode (SPI/ $l^2$ C).
- 4. CCP capture mode interrupt.
- 5. Parallel Slave Port read or write.
- 6. A/D conversion (when A/D clock source is RC).
- 7. Special event trigger (Timer1 in asynchronous mode using an external clock).
- 8. USART TX or RX (synchronous slave mode).

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

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

### 14.8.2 WAKE-UP USING INTERRUPTS

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

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

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

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

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

| RETFIE                       | Return from Interrupt                                                                        |                                                            |                                                           |                            |  |  |  |  |
|------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------|----------------------------|--|--|--|--|
| Syntax:                      | [ label ]                                                                                    | RETFIE                                                     |                                                           |                            |  |  |  |  |
| Operands:                    | None                                                                                         |                                                            |                                                           |                            |  |  |  |  |
| Operation:                   | $\begin{array}{l} \text{TOS} \rightarrow \text{PC}, \\ 1 \rightarrow \text{GIE} \end{array}$ |                                                            |                                                           |                            |  |  |  |  |
| Status Affected:             | None                                                                                         |                                                            |                                                           |                            |  |  |  |  |
| Encoding:                    | 00                                                                                           | 0000                                                       | 0000                                                      | 1001                       |  |  |  |  |
|                              | •                                                                                            | · ·                                                        | ) is load                                                 |                            |  |  |  |  |
|                              | PC. Interru<br>Global Inte                                                                   | upts are er<br>errupt Ena<br><7>). This i                  | ble bit, GIE                                              | setting                    |  |  |  |  |
| Words:                       | PC. Interru<br>Global Inte<br>(INTCON<                                                       | upts are er<br>errupt Ena<br><7>). This i                  | habled by s<br>ble bit, GIE                               | setting                    |  |  |  |  |
| Words:<br>Cycles:            | PC. Interru<br>Global Inte<br>(INTCON-<br>instruction                                        | upts are er<br>errupt Ena<br><7>). This i                  | habled by s<br>ble bit, GIE                               | setting                    |  |  |  |  |
|                              | PC. Interru<br>Global Inte<br>(INTCON-<br>instruction                                        | upts are er<br>errupt Ena<br><7>). This i                  | habled by s<br>ble bit, GIE                               | setting                    |  |  |  |  |
| Cycles:                      | PC. Interru<br>Global Inte<br>(INTCON-<br>instruction<br>1<br>2                              | upts are er<br>errupt Ena<br><7>). This i                  | nabled by s<br>ble bit, GIE<br>is a two cy                | setting<br>cle<br>Q4       |  |  |  |  |
| Cycles:<br>Q Cycle Activity: | PC. Interru<br>Global Inte<br>(INTCON-<br>instruction<br>1<br>2<br>Q1                        | upts are er<br>errupt Ena<br><7>). This i<br><br>Q2<br>No- | abled by s<br>ble bit, GIE<br>s a two cy<br>Q3<br>Set the | setting<br><u>=</u><br>cle |  |  |  |  |

After Interrupt PC = TOS GIE = 1

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

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

#### 17.4 **Timing Parameter Symbology**

The timing parameter symbols have been created following one of the following formats:

| 1. TppS2p             | pS                                      | 3. TCC:ST | (I <sup>2</sup> C specifications only) |
|-----------------------|-----------------------------------------|-----------|----------------------------------------|
| 2. TppS               |                                         | 4. Ts     | (I <sup>2</sup> C specifications only) |
| т                     |                                         |           |                                        |
| F                     | Frequency                               | Т         | Time                                   |
| Lowerca               | ase letters (pp) and their meanings:    |           |                                        |
| рр                    |                                         |           |                                        |
| CC                    | CCP1                                    | OSC       | OSC1                                   |
| ck                    | CLKOUT                                  | rd        | RD                                     |
| CS                    | CS                                      | rw        | $\overline{RD}$ or $\overline{WR}$     |
| di                    | SDI                                     | SC        | SCK                                    |
| do                    | SDO                                     | SS        | SS                                     |
| dt                    | Data in                                 | tO        | TOCKI                                  |
| io                    | I/O port                                | t1        | T1CKI                                  |
| mc                    | MCLR                                    | wr        | WR                                     |
| Upperca               | ase letters and their meanings:         |           |                                        |
| S                     |                                         |           |                                        |
| F                     | Fall                                    | P         | Period                                 |
| Н                     | High                                    | R         | Rise                                   |
| I                     | Invalid (Hi-impedance)                  | V         | Valid                                  |
| L                     | Low                                     | Z         | Hi-impedance                           |
| I <sup>2</sup> C only |                                         |           |                                        |
| AA                    | output access                           | High      | High                                   |
| BUF                   | Bus free                                | Low       | Low                                    |
| Tcc:st (              | (I <sup>2</sup> C specifications only)  | I         |                                        |
| CC                    |                                         |           |                                        |
| HD                    | Hold                                    | SU        | Setup                                  |
| ST                    |                                         |           | Comp                                   |
| DAT                   | DATA input hold                         | STO       | STOP condition                         |
| STA                   | START condition                         |           |                                        |
|                       |                                         |           |                                        |
| FIGURE 1              | 17-1: LOAD CONDITIONS                   |           |                                        |
|                       | Load condition 1                        |           | Load condition 2                       |
|                       | N = = /0                                |           |                                        |
|                       |                                         |           |                                        |
|                       | J                                       |           |                                        |
|                       | $\leq$ RL                               |           |                                        |
|                       | $ \leq $                                | N         |                                        |
|                       | I → I                                   |           | X                                      |
|                       |                                         | F         |                                        |
|                       | • • • • • • • • • • • • • • • • • • • • | ,         | ···· ↓                                 |
|                       | Vss                                     |           | Vss                                    |
|                       | $RL$ = 464 $\Omega$                     |           |                                        |
|                       |                                         |           |                                        |
|                       | $C_L = 50 \text{ pF}$ for all pins ex   | cept 0502 |                                        |

15 pF for OSC2 output

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

# FIGURE 18-11: USART SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING



# TABLE 18-11: USART SYNCHRONOUS TRANSMISSION REQUIREMENTS

| Parameter<br>No. | Sym      | Characteristic                    |                       | Min | Тур† | Max | Units | Conditions |
|------------------|----------|-----------------------------------|-----------------------|-----|------|-----|-------|------------|
| 120              | TckH2dtV | SYNC XMIT (MASTER &<br>SLAVE)     | PIC16 <b>C</b> 73/74  | _   | _    | 80  | ns    |            |
|                  |          | Clock high to data out valid      | PIC16 <b>LC</b> 73/74 | _   | —    | 100 | ns    |            |
| 121              | Tckrf    | Clock out rise time and fall time | PIC16 <b>C</b> 73/74  | _   | —    | 45  | ns    |            |
|                  |          | (Master Mode)                     | PIC16 <b>LC</b> 73/74 | _   | —    | 50  | ns    |            |
| 122              | Tdtrf    | Data out rise time and fall time  | PIC16 <b>C</b> 73/74  | _   | —    | 45  | ns    |            |
|                  |          |                                   | PIC16 <b>LC</b> 73/74 | _   | —    | 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.

# FIGURE 18-12: USART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING



# TABLE 18-12: USART SYNCHRONOUS RECEIVE REQUIREMENTS

| Parameter<br>No. | Sym      | Characteristic                                                                 | Min | Тур† | Мах | Units | Conditions |
|------------------|----------|--------------------------------------------------------------------------------|-----|------|-----|-------|------------|
| 125              | TdtV2ckL | SYNC RCV (MASTER & SLAVE)<br>Data setup before $CK \downarrow (DT setup time)$ | 15  |      | _   | ns    |            |
| 126              | TckL2dtl | Data hold after CK $\downarrow$ (DT hold time)                                 | 15  | —    | —   | ns    |            |

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

# PIC16C7X

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





# TABLE 19-8: SPI MODE REQUIREMENTS

| 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                              | 100      | —    | _   | ns    |            |
| 74               | TscH2diL,<br>TscL2diL | Hold time of SDI data input to SCK edge                               | 100      | _    | —   | 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.

# PIC16C7X

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



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

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

These parameters are characterized but not tested.

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

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

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

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

# FIGURE 20-14: I<sup>2</sup>C BUS DATA TIMING



# TABLE 20-10: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Parameter<br>No. | Sym     | Characteristic         |              | Min        | Мах  | Units | Conditions                                       |
|------------------|---------|------------------------|--------------|------------|------|-------|--------------------------------------------------|
| 100              | Thigh   | Clock high time        | 100 kHz mode | 4.0        | _    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 0.6        | _    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5TCY     | —    |       |                                                  |
| 101              | TLOW    | Clock low time         | 100 kHz mode | 4.7        | _    | μs    | Device must operate at a mini-<br>mum of 1.5 MHz |
|                  |         |                        | 400 kHz mode | 1.3        | _    | μs    | Device must operate at a mini-<br>mum of 10 MHz  |
|                  |         |                        | SSP Module   | 1.5Tcy     | _    |       |                                                  |
| 102              | Tr      | SDA and SCL rise       | 100 kHz mode | _          | 1000 | ns    |                                                  |
|                  |         | time                   | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from<br>10 to 400 pF       |
| 103              | Tf      | SDA and SCL fall time  | 100 kHz mode | -          | 300  | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 20 + 0.1Cb | 300  | ns    | Cb is specified to be from<br>10 to 400 pF       |
| 90               | TSU:STA | START condition        | 100 kHz mode | 4.7        | —    | μs    | Only relevant for repeated                       |
|                  |         | setup time             | 400 kHz mode | 0.6        | —    | μs    | START condition                                  |
| 91               | THD:STA | START condition hold   | 100 kHz mode | 4.0        | —    | μs    | After this period the first clock                |
|                  |         | time                   | 400 kHz mode | 0.6        | —    | μs    | pulse is generated                               |
| 106              | THD:DAT | Data input hold time   | 100 kHz mode | 0          | —    | ns    |                                                  |
|                  |         |                        | 400 kHz mode | 0          | 0.9  | μs    |                                                  |
| 107              | TSU:DAT | Data input setup time  | 100 kHz mode | 250        | —    | ns    | Note 2                                           |
|                  |         |                        | 400 kHz mode | 100        | —    | ns    |                                                  |
| 92               | TSU:STO | STOP condition setup   | 100 kHz mode | 4.7        | —    | μs    |                                                  |
|                  |         | time                   | 400 kHz mode | 0.6        | —    | μs    |                                                  |
| 109              | ΤΑΑ     | Output valid from      | 100 kHz mode | —          | 3500 | ns    | Note 1                                           |
|                  |         | clock                  | 400 kHz mode | —          | —    | ns    |                                                  |
| 110              | TBUF    | Bus free time          | 100 kHz mode | 4.7        | —    | μs    | Time the bus must be free                        |
|                  |         |                        | 400 kHz mode | 1.3        | —    | μs    | before a new transmission can start              |
|                  | Cb      | Bus capacitive loading |              | -          | 400  | pF    |                                                  |

Note 1: As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (min. 300 ns) of the falling edge of SCL to avoid unintended generation of START or STOP conditions.

2: A fast-mode (400 kHz) I<sup>2</sup>C-bus device can be used in a standard-mode (100 kHz) I<sup>2</sup>C-bus system, but the requirement tsu;DAT ≥ 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line TR max.+tsu;DAT = 1000 + 250 = 1250 ns (according to the standard-mode I<sup>2</sup>C bus specification) before the SCL line is released.



# 22.8 44-Lead Plastic Surface Mount (MQFP 10x10 mm Body 1.6/0.15 mm Lead Form) (PQ)

|        | Package Group: Plastic MQFP |        |           |       |            |           |
|--------|-----------------------------|--------|-----------|-------|------------|-----------|
|        | Millimeters                 |        |           |       |            |           |
| Symbol | Min                         | Max    | Notes     | Min   | Max        | Notes     |
| α      | <b>0</b> °                  | 7°     |           | 0°    | <b>7</b> ° |           |
| А      | 2.000                       | 2.350  |           | 0.078 | 0.093      |           |
| A1     | 0.050                       | 0.250  |           | 0.002 | 0.010      |           |
| A2     | 1.950                       | 2.100  |           | 0.768 | 0.083      |           |
| b      | 0.300                       | 0.450  | Typical   | 0.011 | 0.018      | Typical   |
| С      | 0.150                       | 0.180  |           | 0.006 | 0.007      |           |
| D      | 12.950                      | 13.450 |           | 0.510 | 0.530      |           |
| D1     | 9.900                       | 10.100 |           | 0.390 | 0.398      |           |
| D3     | 8.000                       | 8.000  | Reference | 0.315 | 0.315      | Reference |
| E      | 12.950                      | 13.450 |           | 0.510 | 0.530      |           |
| E1     | 9.900                       | 10.100 |           | 0.390 | 0.398      |           |
| E3     | 8.000                       | 8.000  | Reference | 0.315 | 0.315      | Reference |
| е      | 0.800                       | 0.800  |           | 0.031 | 0.032      |           |
| L      | 0.730                       | 1.030  |           | 0.028 | 0.041      |           |
| Ν      | 44                          | 44     |           | 44    | 44         |           |
| CP     | 0.102                       | -      |           | 0.004 | _          |           |

# PIC16C7X

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

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

# **ON-LINE SUPPORT**

Microchip provides two methods of on-line support. These are the Microchip BBS and the Microchip World Wide Web (WWW) site.

Use Microchip's Bulletin Board Service (BBS) to get current information and help about Microchip products. Microchip provides the BBS communication channel for you to use in extending your technical staff with microcontroller and memory experts.

To provide you with the most responsive service possible, the Microchip systems team monitors the BBS, posts the latest component data and software tool updates, provides technical help and embedded systems insights, and discusses how Microchip products provide project solutions.

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

#### Connecting to the Microchip Internet Web Site

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

#### www.microchip.com

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

#### ftp://ftp.futureone.com/pub/microchip

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

- Latest Microchip Press Releases
- Technical Support Section with Frequently Asked
   Questions
- Design Tips
- Device Errata
- Job Postings
- · Microchip Consultant Program Member Listing
- Links to other useful web sites related to Microchip Products

# **Connecting to the Microchip BBS**

Connect worldwide to the Microchip BBS using either the Internet or the CompuServe<sup>®</sup> communications network.

#### Internet:

You can telnet or ftp to the Microchip BBS at the address: mchipbbs.microchip.com

#### CompuServe Communications Network:

When using the BBS via the Compuserve Network, in most cases, a local call is your only expense. The Microchip BBS connection does not use CompuServe membership services, therefore you do not need CompuServe membership to join Microchip's BBS. There is no charge for connecting to the Microchip BBS. The procedure to connect will vary slightly from country to country. Please check with your local CompuServe agent for details if you have a problem. CompuServe service allow multiple users various baud rates depending on the local point of access.

The following connect procedure applies in most locations.

- 1. Set your modem to 8-bit, No parity, and One stop (8N1). This is not the normal CompuServe setting which is 7E1.
- 2. Dial your local CompuServe access number.
- 3. Depress the **<Enter>** key and a garbage string will appear because CompuServe is expecting a 7E1 setting.
- Type +, depress the <Enter> key and "Host Name:" will appear.
- 5. Type MCHIPBBS, depress the **<Enter>** key and you will be connected to the Microchip BBS.

In the United States, to find the CompuServe phone number closest to you, set your modem to 7E1 and dial (800) 848-4480 for 300-2400 baud or (800) 331-7166 for 9600-14400 baud connection. After the system responds with "Host Name:", type NETWORK, depress the **<Enter>** key and follow CompuServe's directions.

For voice information (or calling from overseas), you may call (614) 723-1550 for your local CompuServe number.

Microchip regularly uses the Microchip BBS to distribute technical information, application notes, source code, errata sheets, bug reports, and interim patches for Microchip systems software products. For each SIG, a moderator monitors, scans, and approves or disapproves files submitted to the SIG. No executable files are accepted from the user community in general to limit the spread of computer viruses.

#### Systems Information and Upgrade Hot Line

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

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

1-602-786-7302 for the rest of the world.

970301

**Trademarks:** The Microchip name, logo, PIC, PICSTART, PICMASTER and PRO MATE are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. *Flex*ROM, MPLAB and *fuzzy*LAB, are trademarks and SQTP is a service mark of Microchip in the U.S.A.

*fuzzy*TECH is a registered trademark of Inform Software Corporation. IBM, IBM PC-AT are registered trademarks of International Business Machines Corp. Pentium is a trademark of Intel Corporation. Windows is a trademark and MS-DOS, Microsoft Windows are registered trademarks of Microsoft Corporation. CompuServe is a registered trademark of CompuServe Incorporated.

All other trademarks mentioned herein are the property of their respective companies.