



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                   |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | PIC                                                                      |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 20MHz                                                                    |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                        |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                    |
| Number of I/O              | 36                                                                       |
| Program Memory Size        | 7KB (4K x 14)                                                            |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 368 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4V ~ 5.5V                                                                |
| Data Converters            | A/D 14x10b                                                               |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 44-VQFN Exposed Pad                                                      |
| Supplier Device Package    | 44-QFN (8x8)                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16f747-i-ml |

Email: info@E-XFL.COM

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

#### **Pin Diagrams**



# 1.0 DEVICE OVERVIEW

This document contains device specific information about the following devices:

- PIC16F737 PIC16F767
- PIC16F747 PIC16F777

PIC16F737/767 devices are available only in 28-pin packages, while PIC16F747/777 devices are available in 40-pin and 44-pin packages. All devices in the PIC16F7X7 family share common architecture with the following differences:

- The PIC16F737 and PIC16F767 have one-half of the total on-chip memory of the PIC16F747 and PIC16F777.
- The 28-pin devices have 3 I/O ports, while the 40/44-pin devices have 5.
- The 28-pin devices have 16 interrupts, while the 40/44-pin devices have 17.
- The 28-pin devices have 11 A/D input channels, while the 40/44-pin devices have 14.
- The Parallel Slave Port is implemented only on the 40/44-pin devices.
- Low-Power modes: RC\_RUN allows the core and peripherals to be clocked from the INTRC, while SEC\_RUN allows the core and peripherals to be clocked from the low-power Timer1. Refer to Section 4.7 "Power-Managed Modes" for further details.
- Internal RC oscillator with eight selectable frequencies, including 31.25 kHz, 125 kHz, 250 kHz, 500 kHz, 1 MHz, 2 MHz, 4 MHz and 8 MHz. The INTRC can be configured as a primary or secondary clock source. Refer to Section 4.5 "Internal Oscillator Block" for further details.

- The Timer1 module current consumption has been greatly reduced from 20 μA (previous PIC16 devices) to 1.8 μA typical (32 kHz at 2V), which is ideal for real-time clock applications. Refer to Section 7.0 "Timer1 Module" for further details.
- Extended Watchdog Timer (WDT) that can have a programmable period from 1 ms to 268s. The WDT has its own 16-bit prescaler. Refer to **Section 15.17** "Watchdog Timer (WDT)" for further details.
- Two-Speed Start-up: When the oscillator is configured for LP, XT or HS, this feature will clock the device from the INTRC while the oscillator is warming up. This, in turn, will enable almost immediate code execution. Refer to Section 15.17.3 "Two-Speed Clock Start-up Mode" for further details.
- Fail-Safe Clock Monitor: This feature will allow the device to continue operation if the primary or secondary clock source fails by switching over to the INTRC.

The available features are summarized in Table 1-1. Block diagrams of the PIC16F737/767 and PIC16F747/777 devices are provided in Figure 1-1 and Figure 1-2, respectively. The pinouts for these device families are listed in Table 1-2 and Table 1-3.

Additional information may be found in the "*PIC*<sup>®</sup> *Mid-Range MCU Family Reference Manual*" (DS33023) which may be obtained from your local Microchip Sales Representative or downloaded from the Microchip web site. The Reference Manual should be considered a complementary document to this data sheet and is highly recommended reading for a better understanding of the device architecture and operation of the peripheral modules.

| Key Features                        | PIC16F737                                               | PIC16F747                                | PIC16F767                                               | PIC16F777                                |
|-------------------------------------|---------------------------------------------------------|------------------------------------------|---------------------------------------------------------|------------------------------------------|
| Operating Frequency                 | DC – 20 MHz                                             | DC – 20 MHz                              | DC – 20 MHz                                             | DC – 20 MHz                              |
| Resets (and Delays)                 | POR, BOR<br>(PWRT, OST)                                 | POR, BOR<br>(PWRT, OST)                  | POR, BOR<br>(PWRT, OST)                                 | POR, BOR<br>(PWRT, OST)                  |
| Flash Program Memory (14-bit words) | 4K                                                      | 4K                                       | 8K                                                      | 8K                                       |
| Data Memory (bytes)                 | 368                                                     | 368                                      | 368                                                     | 368                                      |
| Interrupts                          | 16                                                      | 17                                       | 16                                                      | 17                                       |
| I/O Ports                           | Ports A, B, C                                           | Ports A, B, C, D, E                      | Ports A, B, C                                           | Ports A, B, C, D, E                      |
| Timers                              | 3                                                       | 3                                        | 3                                                       | 3                                        |
| Capture/Compare/PWM Modules         | 3                                                       | 3                                        | 3                                                       | 3                                        |
| Master Serial Communications        | MSSP, AUSART                                            | MSSP, AUSART                             | MSSP, AUSART                                            | MSSP, AUSART                             |
| Parallel Communications             | —                                                       | PSP                                      | —                                                       | PSP                                      |
| 10-bit Analog-to-Digital Module     | 11 Input Channels                                       | 14 Input Channels                        | 11 Input Channels                                       | 14 Input Channels                        |
| Instruction Set                     | 35 Instructions                                         | 35 Instructions                          | 35 Instructions                                         | 35 Instructions                          |
| Packaging                           | 28-pin PDIP<br>28-pin SOIC<br>28-pin SSOP<br>28-pin QFN | 40-pin PDIP<br>44-pin QFN<br>44-pin TQFP | 28-pin PDIP<br>28-pin SOIC<br>28-pin SSOP<br>28-pin QFN | 40-pin PDIP<br>44-pin QFN<br>44-pin TQFP |

#### TABLE 1-1: PIC16F7X7 DEVICE FEATURES

| Pin Name            | PDIP<br>Pin # | QFN<br>Pin # | TQFP<br>Pin # | I/O/P<br>Type                           | Buffer<br>Type                          | Description                                      |
|---------------------|---------------|--------------|---------------|-----------------------------------------|-----------------------------------------|--------------------------------------------------|
|                     |               |              |               | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                                  |
|                     | 45            |              |               |                                         | от                                      | PORTC is a bidirectional i/O port.               |
| RC0/110S0/11CKI     | 15            | 34           | 32            | 1/0                                     | 51                                      | Digital I/O                                      |
|                     |               |              |               | 0                                       |                                         | Digital 1/O.<br>Timer1 oscillator output         |
| TICKI               |               |              |               | I I                                     |                                         | Timer1 external clock input                      |
|                     | 16            | 25           | 25            | •                                       | ст                                      |                                                  |
| RC1                 | 10            | - 55         | - 55          | 1/0                                     | 51                                      | Digital I/O                                      |
| TIOSI               |               |              |               | 1/0                                     |                                         | Timer1 oscillator input                          |
| CCP2 <sup>(5)</sup> |               |              |               | I/O                                     |                                         | Capture 2 input. Compare 2 output. PWM 2 output. |
| RC2/CCP1            | 17            | 36           | 36            |                                         | ST                                      | and the first first states and the               |
| RC2                 |               | 50           | 50            | 1/0                                     | 01                                      | Digital I/O                                      |
| CCP1                |               |              |               | 1/0                                     |                                         | Capture 1 input. Compare 1 output. PWM 1 output. |
| PC2/SCK/SCI         | 10            | 27           | 27            | ., 0                                    | ет                                      |                                                  |
| RC3                 | 10            | 57           | 57            | 1/0                                     | 51                                      | Digital I/O                                      |
| SCK                 |               |              |               | 1/0                                     |                                         | Synchronous serial clock input/output            |
| 0011                |               |              |               | ., 0                                    |                                         | for SPI mode.                                    |
| SCL                 |               |              |               | I/O                                     |                                         | Synchronous serial clock input/output            |
|                     |               |              |               |                                         |                                         | for I <sup>2</sup> C <sup>™</sup> mode.          |
| RC4/SDI/SDA         | 23            | 42           | 42            |                                         | ST                                      |                                                  |
| RC4                 |               |              |               | I/O                                     |                                         | Digital I/O.                                     |
| SDI                 |               |              |               | I                                       |                                         | SPI data in.                                     |
| SDA                 |               |              |               | I/O                                     |                                         | I <sup>2</sup> C data I/O.                       |
| RC5/SDO             | 24            | 43           | 43            |                                         | ST                                      |                                                  |
| RC5                 |               |              |               | I/O                                     |                                         | Digital I/O.                                     |
| SDO                 |               |              |               | 0                                       |                                         | SPI data out.                                    |
| RC6/TX/CK           | 25            | 44           | 44            |                                         | ST                                      |                                                  |
| RC6                 |               |              |               | I/O                                     |                                         | Digital I/O.                                     |
| ТХ                  |               |              |               | 0                                       |                                         | AUSART asynchronous transmit.                    |
| СК                  |               |              |               | I/O                                     |                                         | AUSART synchronous clock.                        |
| RC7/RX/DT           | 26            | 1            | 1             |                                         | ST                                      |                                                  |
| RC7                 |               |              |               | I/O                                     |                                         | Digital I/O.                                     |
| RX                  |               |              |               | I                                       |                                         | AUSART asynchronous receive.                     |
| DT                  |               |              |               | I/O                                     |                                         | AUSART synchronous data.                         |
| Legend: I = input   |               | 0 = ou       | ıtput         |                                         | I/O = inpu                              | ut/output P = power                              |

#### **TABLE 1-3**: PIC16F747 AND PIC16F777 PINOUT DESCRIPTION (CONTINUED)

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

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

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

3: This buffer is a Schmitt Trigger input when configured as a general purpose I/O and a TTL input when used in the Parallel Slave Port mode (for interfacing to a microprocessor bus).

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

5: Pin location of CCP2 is determined by the CCPMX bit in Configuration Word Register 1.

#### 2.2.2.1 Status Register

The Status register contains the arithmetic status of the ALU, the Reset status and the bank select bits for data memory.

The Status register can be the destination for any instruction, as with any other register. If the Status register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the TO and PD bits are not writable, therefore, the result of an instruction with the Status register as destination may be different than intended.

For example, CLRF STATUS, will clear the upper three bits and set the Z bit. This leaves the Status register as  $000u \ uluu$  (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the Status register because these instructions do not affect the Z, C or DC bits from the Status register. For other instructions not affecting any Status bits, see Section 16.0 "Instruction Set Summary".

Note 1: The <u>C</u> and <u>DC</u> bits operate as a borrow and digit borrow bit, respectively, in subtraction. See the SUBLW and SUBWF instructions for examples.

#### REGISTER 2-1: STATUS: ARITHMETIC STATUS REGISTER (ADDRESS 03h, 83h, 103h, 183h)

| 11/00-0                                                       | R/W-0                                                                       | R/W-0                            | R-1                                | R-1                            | R/W-x                     | R/W-x                    | R/W-x                       |
|---------------------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------|------------------------------------|--------------------------------|---------------------------|--------------------------|-----------------------------|
| IRP                                                           | RP1                                                                         | RP0                              | TO                                 | PD                             | Z                         | DC                       | С                           |
| bit 7                                                         |                                                                             |                                  |                                    |                                |                           |                          | bit 0                       |
| IRP: Regis                                                    | ter Bank Sele                                                               | ct bit (used f                   | or indirect ac                     | ddressing)                     |                           |                          |                             |
| 0 = Bank 0                                                    | , 1 (00h-FFh)                                                               | ,                                |                                    |                                |                           |                          |                             |
| RP1:RP0:                                                      | Register Banl                                                               | Select bits                      | used for dire                      | ect addressi                   | ng)                       |                          |                             |
| 11 = Bank<br>10 = Bank<br>01 = Bank<br>00 = Bank<br>Each bank | 3 (180h-1FFr<br>2 (100h-17Fh<br>1 (80h-FFh)<br>0 (00h-7Fh)<br>is 128 bytes. | ı)<br>))                         |                                    |                                |                           |                          |                             |
| TO: Time-c                                                    | out bit                                                                     |                                  |                                    |                                |                           |                          |                             |
| 1 = After p<br>0 = A WDT                                      | ower-up, CLR                                                                | WDT instructio                   | ON OF SLEEP                        | instruction                    |                           |                          |                             |
| PD: Power                                                     | -Down bit                                                                   |                                  |                                    |                                |                           |                          |                             |
| 1 = After p<br>0 = By exe                                     | ower-up or by cution of the s                                               | the CLRWDT                       | instruction<br>ction               |                                |                           |                          |                             |
| Z: Zero bit                                                   |                                                                             |                                  |                                    |                                |                           |                          |                             |
| 1 = The re:<br>0 = The re:                                    | sult of an arith<br>sult of an arith                                        | imetic or logi<br>imetic or logi | c operation is<br>c operation is   | s zero<br>s not zero           |                           |                          |                             |
| DC: Digit C                                                   | arry/borrow b                                                               | it (addwf, ai                    | DLW, SUBI                          | LW, SUBWF                      | instruction               | s)                       |                             |
| 1 = A carry<br>0 = No car                                     | v-out from the<br>ry-out from the                                           | 4th low-orde<br>e 4th low-ord    | r bit of the re<br>er bit of the i | esult occurre<br>result        | ed                        |                          |                             |
| C: Carry/bo                                                   | orrow bit (ADD                                                              | WF, ADDLW                        | , SUBLW, S                         | SUBWF instr                    | uctions)                  |                          |                             |
| 1 = A carry<br>0 = No car                                     | ry-out from the                                                             | Most Signific<br>e Most Signif   | ant bit of the                     | e result occu<br>ne result occ | urred<br>curred           |                          |                             |
| Note:                                                         | For borrow, two's comple                                                    | the polarity                     | is reversed<br>second oper         | . A subtract<br>and. For rot   | ction is exe<br>ate (RRF, | ecuted by<br>RLF) instru | adding the<br>ictions, this |

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

| Current<br>System<br>Clock      | SCS bits<1:0><br>Modified to:                | Delay                                         | OSTS<br>bit | IOFS<br>bit      | T1RUN<br>bit | New<br>System<br>Clock                              | Comments                                                                                                                                                                                                                                                                                             |
|---------------------------------|----------------------------------------------|-----------------------------------------------|-------------|------------------|--------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LP, XT, HS,<br>T1OSC,<br>EC, RC | 10<br>(INTRC)<br>FOSC<2:0> = LP,<br>XT or HS | 8 Clocks of<br>INTRC                          | 0           | 1 <sup>(1)</sup> | 0            | INTRC<br>or<br>INTOSC<br>or<br>INTOSC<br>Postscaler | The internal RC oscillator<br>frequency is dependant upon<br>the IRCF bits.                                                                                                                                                                                                                          |
| LP, XT, HS,<br>INTRC,<br>EC, RC | 01<br>(T1OSC)<br>FOSC<2:0> = LP,<br>XT or HS | 8 Clocks of<br>T1OSC                          | 0           | N/A              | 1            | T1OSC                                               | T1OSCEN bit must be enabled.                                                                                                                                                                                                                                                                         |
| INTRC<br>T1OSC                  | 00<br>FOSC<2:0> = EC<br>or<br>FOSC<2:0> = RC | 8 Clocks of<br>EC<br>or<br>RC                 | 1           | N/A              | 0            | EC<br>or<br>RC                                      |                                                                                                                                                                                                                                                                                                      |
| INTRC<br>T1OSC                  | 00<br>FOSC<2:0> = LP,<br>XT, HS              | 1024 Clocks<br>+<br>8 Clocks of<br>LP, XT, HS | 1           | N/A              | 0            | LP, XT, HS                                          | During the 1024 clocks,<br>program execution is clocked<br>from the secondary oscillator<br>until the primary oscillator<br>becomes stable.                                                                                                                                                          |
| LP, XT, HS                      | 00<br>(Due to Reset)<br>LP, XT, HS           | 1024 Clocks                                   | 1           | N/A              | 0            | LP, XT, HS                                          | When a Reset occurs, there is<br>no clock transition sequence.<br>Instruction<br>execution and/or peripheral<br>operation is suspended unless<br>Two-Speed Start-up mode is<br>enabled, after which the INTRC<br>will act as the system clock<br>until the Oscillator Start-up<br>Timer has expired. |

TABLE 4-4: CLOCK SWITCHING MODES

Note 1: If the new clock source is the INTOSC or INTOSC postscaler, then the IOFS bit will be set 4 ms (approx.) after the clock change.

# 5.0 I/O PORTS

Some pins for these I/O ports are multiplexed with an alternate function for the peripheral features on the device. In general, when a peripheral is enabled, that pin may not be used as a general purpose I/O pin.

Additional information on I/O ports may be found in the *"PIC<sup>®</sup> Mid-Range MCU Family Reference Manual"* (DS33023).

# 5.1 PORTA and the TRISA Register

PORTA is a 8-bit wide, bidirectional port. The corresponding data direction register is TRISA. Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input (i.e., put the corresponding output driver in a high-impedance mode). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output (i.e., put the contents of the output latch on the selected pin).

Reading the PORTA register reads the status of the pins, whereas writing to it, will write to the port latch.

The RA4 pin is multiplexed with the Timer0 module clock input and one of the comparator outputs to become the RA4/T0CKI/C1OUT pin. Pins RA6 and RA7 are multiplexed with the main oscillator pins; they are enabled as oscillator or I/O pins by the selection of the main oscillator in Configuration Register 1H (see **Section 15.1 "Configuration Bits"** for details). When they are not used as port pins, RA6 and RA7 and their associated TRIS and LAT bits are read as '0'.

The other PORTA pins are multiplexed with analog inputs, the analog VREF+ and VREF- inputs and the comparator voltage reference output. The operation of pins RA3:RA0 and RA5 as A/D converter inputs is selected by clearing/setting the control bits in the ADCON1 register (A/D Control Register 1). Pins RA0 through RA5 may also be used as comparator inputs or outputs by setting the appropriate bits in the CMCON register.

| Note: | On a Power-on Reset, RA5 and RA3:RA0          |
|-------|-----------------------------------------------|
|       | are configured as analog inputs and read      |
|       | as '0'. RA4 is configured as a digital input. |

The RA4/T0CKI/C1OUT pin is a Schmitt Trigger input and an open-drain output. All other PORTA pins have TTL input levels and full CMOS output drivers.

The TRISA register controls the direction of the RA pins even when they are being used as analog inputs. The user must ensure the bits in the TRISA register are maintained set when using them as analog inputs.

#### EXAMPLE 5-1: INITIALIZING PORTA

| BCF   | STATUS, | RP0 | ;                       |
|-------|---------|-----|-------------------------|
| BCF   | STATUS, | RP1 | ; Bank0                 |
| CLRF  | PORTA   |     | ; Initialize PORTA by   |
|       |         |     | ; clearing output       |
|       |         |     | ; data latches          |
| BSF   | STATUS, | RP0 | ; Select Bank 1         |
| MOVLW | 0x0F    |     | ; Configure all pins    |
| MOVWF | ADCON1  |     | ; as digital inputs     |
| MOVLW | 0xCF    |     | ; Value used to         |
|       |         |     | ; initialize data       |
|       |         |     | ; direction             |
| MOVWF | TRISA   |     | ; Set RA<3:0> as inputs |
|       |         |     | ; RA<5:4> as outputs    |
|       |         |     | ; TRISA<7:6>are always  |
|       |         |     | ; read as '0'.          |
| 1     |         |     |                         |

# 5.3 PORTC and the TRISC Register

PORTC is an 8-bit wide, bidirectional port. The corresponding data direction register is TRISC. Setting a TRISC bit (= 1) will make the corresponding PORTC pin an input (i.e., put the corresponding output driver in a high-impedance mode). Clearing a TRISC bit (= 0) will make the corresponding PORTC pin an output (i.e., put the contents of the output latch on the selected pin).

PORTC is multiplexed with several peripheral functions (Table 5-5). PORTC pins have Schmitt Trigger input buffers.

When enabling peripheral functions, care should be taken in defining TRIS bits for each PORTC pin. Some peripherals override the TRIS bit to make a pin an output, while other peripherals override the TRIS bit to make a pin an input. Since the TRIS bit override is in effect while the peripheral is enabled, read-modifywrite instructions (BSF, BCF, XORWF) with TRISC as destination should be avoided. The user should refer to the corresponding peripheral section for the correct TRIS bit settings and to **Section 16.1 "Read-Modify-Write Operations"** for additional information on read-modify-write operations.

#### FIGURE 5-16: PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<2:0>, RC<7:5> PINS



 Peripheral OE (Output Enable) is only activated if Peripheral Select is active.

# FIGURE 5-17:

#### PORTC BLOCK DIAGRAM (PERIPHERAL OUTPUT OVERRIDE) RC<4:3> PINS



| REGISTER 10-2: | SSPCON                                                                     | : MSSP CC                                                                                     | NTROL (SI                                                                                                                  | PI MODE)                                                              | REGISTE                                           | R 1 (ADDR                                        | ESS 14h)                                      |                                   |
|----------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------------------------|--------------------------------------------------|-----------------------------------------------|-----------------------------------|
|                | R/W-0                                                                      | R/W-0                                                                                         | R/W-0                                                                                                                      | R/W-0                                                                 | R/W-0                                             | R/W-0                                            | R/W-0                                         | R/W-0                             |
|                | WCOL                                                                       | SSPOV                                                                                         | SSPEN                                                                                                                      | CKP                                                                   | SSPM3                                             | SSPM2                                            | SSPM1                                         | SSPM0                             |
|                | bit 7                                                                      |                                                                                               |                                                                                                                            |                                                                       | -                                                 |                                                  |                                               | bit 0                             |
| bit 7          | WCOL: W                                                                    | /rite Collisior                                                                               | Detect bit (T                                                                                                              | ransmit mo                                                            | ode only)                                         |                                                  |                                               |                                   |
|                | 1 = The S<br>(Must<br>0 = No co                                            | SSPBUF regi<br>t be cleared i<br>ollision                                                     | ster is writter<br>n software.)                                                                                            | n while it is                                                         | still transmit                                    | ting the prev                                    | vious word.                                   |                                   |
| bit 6          | SSPOV: F                                                                   | Receive Over                                                                                  | rflow Indicato                                                                                                             | r bit                                                                 |                                                   |                                                  |                                               |                                   |
|                | SPI Slave<br>1 = A nev<br>of ove<br>must<br>(Must<br>0 = No ove            | <u>mode:</u><br>w byte is rece<br>erflow, the da<br>read the SSI<br>t be cleared i<br>verflow | ived while the<br>ata in SSPSR<br>PBUF, even it<br>in software.)                                                           | e SSPBUF<br>t is lost. Ov<br>f only trans                             | register is sti<br>verflow can c<br>mitting data, | ill holding the<br>only occur in<br>to avoid set | e previous d<br>I Slave mod<br>tting overflov | ata. In case<br>e. The user<br>w. |
|                | Note:                                                                      | In Master<br>transmission                                                                     | mode, the o                                                                                                                | overflow b<br>by writing                                              | it is not set<br>to the SSPE                      | t since eac<br>3UF register                      | ch new rece                                   | eption (and                       |
| bit 5          | SSPEN: S                                                                   | Synchronous                                                                                   | Serial Port E                                                                                                              | nable bit                                                             |                                                   |                                                  |                                               |                                   |
|                | 1 = Enabl<br>0 = Disabl                                                    | es serial port<br>les serial por                                                              | t and configui<br>t and configu                                                                                            | res SCK, S<br>res these p                                             | DO, SDI and<br>bins as I/O po                     | l <u>SS</u> as seria<br>ort pins                 | al port pins                                  |                                   |
|                | Note:                                                                      | When ena                                                                                      | bled, these pi                                                                                                             | ins must be                                                           | properly co                                       | nfigured as                                      | input or outp                                 | out.                              |
| bit 4          | CKP: Cloo                                                                  | ck Polarity S                                                                                 | elect bit                                                                                                                  |                                                                       |                                                   |                                                  |                                               |                                   |
|                | 1 = Idle st<br>0 = Idle st                                                 | ate for clock<br>ate for clock                                                                | is a high level<br>is a low level                                                                                          | el<br>I                                                               |                                                   |                                                  |                                               |                                   |
| bit 3-0        | SSPM3:S                                                                    | SPM0: Sync                                                                                    | hronous Seri                                                                                                               | al Port Mod                                                           | de Select bits                                    | 6                                                |                                               |                                   |
|                | 0101 = SF<br>0100 = SF<br>0011 = SF<br>0010 = SF<br>0001 = SF<br>0000 = SF | PI Slave moo<br>PI Slave moo<br>PI Master mo<br>PI Master mo<br>PI Master mo<br>PI Master mo  | le, clock = SC<br>de, clock = SC<br>ode, clock = T<br>ode, clock = T<br>ode, clock = F<br>ode, clock = F<br>ode, clock = F | CK pin. SS<br>CK pin. SS<br>MR2 outpu<br>cosc/64<br>cosc/16<br>cosc/4 | oin control di<br>pin control e<br>ut/2           | sabled. SS o                                     | can be used                                   | as I/O pin.                       |
|                | Note:                                                                      | Bit combin<br>I <sup>2</sup> C mode o                                                         | ations not sp<br>only.                                                                                                     | ecifically lis                                                        | sted here are                                     | either rese                                      | rved or impl                                  | emented in                        |
|                | Legend:                                                                    |                                                                                               |                                                                                                                            |                                                                       |                                                   |                                                  |                                               |                                   |

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

#### 10.3.3 ENABLING SPI I/O

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

- SDI is automatically controlled by the SPI module
- SDO must have TRISC<5> bit cleared
- SCK (Master mode) must have TRISC<3> bit cleared
- SCK (Slave mode) must have TRISC<3> bit set
- SS must have TRISA<5> bit set

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value.

#### 10.3.4 TYPICAL CONNECTION

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

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



#### 10.4.4 CLOCK STRETCHING

Both 7-bit and 10-bit Slave modes implement automatic clock stretching during a transmit sequence.

The SEN bit (SSPCON2<0>) allows clock stretching to be enabled during receives. Setting SEN will cause the SCL pin to be held low at the end of each data receive sequence.

#### 10.4.4.1 Clock Stretching for 7-bit Slave Receive Mode (SEN = 1)

In 7-bit Slave Receive mode, on the falling edge of the ninth clock, at the end of the ACK sequence if the BF bit is set, the CKP bit in the SSPCON register is automatically cleared, forcing the SCL output to be held low. The CKP being cleared to '0' will assert the SCL line low. The CKP bit must be set in the user's ISR before reception is allowed to continue. By holding the SCL line low, the user has time to service the ISR and read the contents of the SSPBUF before the master device can initiate another receive sequence. This will prevent buffer overruns from occurring (see Figure 10-13).

- Note 1: If the user reads the contents of the SSPBUF before the falling edge of the ninth clock, thus clearing the BF bit, the CKP bit will not be cleared and clock stretching will not occur.
  - 2: The CKP bit can be set in software regardless of the state of the BF bit. The user should be careful to clear the BF bit in the ISR before the next receive sequence in order to prevent an overflow condition.

#### 10.4.4.2 Clock Stretching for 10-bit Slave Receive Mode (SEN = 1)

In 10-bit Slave Receive mode during the address sequence, clock stretching automatically takes place but CKP is not cleared. During this time, if the UA bit is set after the ninth clock, clock stretching is initiated. The UA bit is set after receiving the upper byte of the 10-bit address and following the receive of the second byte of the 10-bit address, with the R/W bit cleared to '0'. The release of the clock line occurs upon updating SSPADD. Clock stretching will occur on each data receive sequence as described in 7-bit mode.

**Note:** If the user polls the UA bit and clears it by updating the SSPADD register before the falling edge of the ninth clock occurs and if the user hasn't cleared the BF bit by reading the SSPBUF register before that time, then the CKP bit will still NOT be asserted low. Clock stretching on the basis of the state of the BF bit only occurs during a data sequence, not an address sequence.

#### 10.4.4.3 Clock Stretching for 7-bit Slave Transmit Mode

7-bit Slave Transmit mode implements clock stretching by clearing the CKP bit after the falling edge of the ninth clock, if the BF bit is clear. This occurs regardless of the state of the SEN bit.

The user's ISR must set the CKP bit before transmission is allowed to continue. By holding the SCL line low, the user has time to service the ISR and load the contents of the SSPBUF before the master device can initiate another transmit sequence (see Figure 10-9).

- Note 1: If the user loads the contents of SSPBUF, setting the BF bit before the falling edge of the ninth clock, the CKP bit will not be cleared and clock stretching will not occur.
  - 2: The CKP bit can be set in software regardless of the state of the BF bit.

#### 10.4.4.4 Clock Stretching for 10-bit Slave Transmit Mode

In 10-bit Slave Transmit mode, clock stretching is controlled during the first two address sequences by the state of the UA bit, just as it is in 10-bit Slave Receive mode. The first two addresses are followed by a third address sequence, which contains the highorder bits of the 10-bit address and the R/W bit set to '1'. After the third address sequence is performed, the UA bit is not set, the module is now configured in Transmit mode and clock stretching is controlled by the BF flag as in 7-bit Slave Transmit mode (see Figure 10-11).

#### 10.4.6 MASTER MODE

Master mode is enabled by setting and clearing the appropriate SSPM bits in SSPCON and by setting the SSPEN bit. In Master mode, the SCL and SDA lines are manipulated by the MSSP hardware.

Master mode of operation is supported by interrupt generation on the detection of the Start and Stop conditions. The Stop (P) and Start (S) bits are cleared from a Reset or when the MSSP module is disabled. Control of the  $I^2C$  bus may be taken when the P bit is set or the bus is Idle, with both the S and P bits clear.

In Firmware Controlled Master mode, user code conducts all  $I^2C$  bus operations based on Start and Stop bit conditions.

Once Master mode is enabled, the user has six options:

- 1. Assert a Start condition on SDA and SCL.
- 2. Assert a Repeated Start condition on SDA and SCL.
- 3. Write to the SSPBUF register, initiating transmission of data/address.
- 4. Configure the I<sup>2</sup>C port to receive data.
- 5. Generate an Acknowledge condition at the end of a received byte of data.
- 6. Generate a Stop condition on SDA and SCL.

Note: The MSSP module, when configured in I<sup>2</sup>C Master mode, does not allow queueing of events. For instance, the user is not allowed to initiate a Start condition and immediately write the SSPBUF register to initiate transmission before the Start condition is complete. In this case, the SSPBUF will not be written to and the WCOL bit will be set, indicating that a write to the SSPBUF did not occur.

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

- · Start condition
- Stop condition
- Data transfer byte transmitted/received
- Acknowledge Transmit
- Repeated Start



© 2003-2013 Microchip Technology Inc.

#### 15.8 Low-Voltage Detect

In many applications, the ability to determine if the device voltage (VDD) is below a specified voltage level is a desirable feature. A window of operation for the application can be created where the application software can do "housekeeping tasks" before the device voltage exits the valid operating range. This can be done using the Low-Voltage Detect module.

This module is a software programmable circuitry where a device voltage trip point can be specified. When the voltage of the device becomes lower then the specified point, an interrupt flag is set. If the interrupt is enabled, the program execution will branch to the interrupt vector address and the software can then respond to that interrupt source.

The Low-Voltage Detect circuitry is completely under software control. This allows the circuitry to be turned off by the software which minimizes the current consumption for the device.

Figure 15-3 shows a possible application voltage curve (typically for batteries). Over time, the device voltage decreases. When the device voltage equals voltage VA, the LVD logic generates an interrupt. This occurs at

time TA. The application software then has the time, until the device voltage is no longer in valid operating range, to shut-down the system. Voltage point VB is the minimum valid operating voltage specification. This occurs at time TB. The difference, TB - TA, is the total time for shutdown.

The block diagram for the LVD module is shown in Figure 15-4. A comparator uses an internally generated reference voltage as the set point. When the selected tap output of the device voltage crosses the set point (is lower than), the LVDIF bit is set.

Each node in the resistor divider represents a "trip point" voltage. The "trip point" voltage is the minimum supply voltage level at which the device can operate before the LVD module asserts an interrupt. When the supply voltage is equal to the trip point, the voltage tapped off of the resistor array is equal to the 1.2V internal reference voltage generated by the voltage reference module. The comparator then generates an interrupt signal setting the LVDIF bit. This voltage is software programmable to any one of 16 values (see Figure 15-4). The trip point is selected by programming the LVDL3:LVDL0 bits (LVDCON<3:0>).





### 15.10.1 REFERENCE VOLTAGE SET POINT

The internal reference voltage of the LVD module may be used by other internal circuitry (the Programmable Brown-out Reset). If these circuits are disabled (lower current consumption), the reference voltage circuit requires a time to become stable before a low-voltage condition can be reliably detected. This time is invariant of system clock speed. This start-up time is specified in electrical specification parameter #36. The low-voltage interrupt flag will not be enabled until a stable reference voltage is reached. Refer to the waveform in Figure 15-6.

#### 15.10.2 CURRENT CONSUMPTION

When the module is enabled, the LVD comparator and voltage divider are enabled and will consume static current. The voltage divider can be tapped from multiple places in the resistor array. Total current consumption, when enabled, is specified in electrical specification parameter #D022B.

# 15.11 Operation During Sleep

When enabled, the LVD circuitry continues to operate during Sleep. If the device voltage crosses the trip point, the LVDIF bit will be set and the device will wakeup from Sleep. Device execution will continue from the interrupt vector address if interrupts have been globally enabled.

# 15.12 Effects of a Reset

A device Reset forces all registers to their Reset state. This forces the LVD module to be turned off.

Note: If the LVD is enabled and the BOR module is not enabled, the band gap will require a start-up time of no more than 50 μs before the band gap reference is stable. Before enabling the LVD interrupt, the user should ensure that the band gap reference voltage is stable by monitoring the IRVST bit in the LVDCON register. The LVD could cause erroneous interrupts before the band gap is stable.

#### 15.13 Time-out Sequence

On power-up, the time-out sequence is as follows: the PWRT delay starts (if enabled) when a POR occurs; then, OST starts counting 1024 oscillator cycles when PWRT ends (LP, XT, HS); when the OST ends, the device comes out of Reset.

If MCLR is kept low long enough, all delays will expire. Bringing MCLR high will begin execution immediately. This is useful for testing purposes or to synchronize more than one PIC16F7X7 device operating in parallel.

Table 15-3 shows the Reset conditions for the Status, PCON and PC registers, while Table 15-4 shows the Reset conditions for all the registers.

### 15.14 Power Control/Status Register (PCON)

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

Bit 0 is Brown-out Reset status bit, BOR. Bit BOR is unknown on a Power-on Reset. It must then be set by the user and checked on subsequent Resets to see if bit BOR cleared, indicating a Brown-out Reset occurred. When the Brown-out Reset is disabled, the state of the BOR bit is unpredictable.

Bit 1 is Power-on Reset Status bit, POR. It is cleared on a Power-on Reset and unaffected otherwise. The user must set this bit following a Power-on Reset.

f,b

Bit 'b' in register 'f' is cleared.

# 16.2 Instruction Descriptions

ADDWF

Syntax: Operands:

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

| are added to the eight-bit literal 'k'<br>and the result is placed in the W<br>register. | Description: |
|------------------------------------------------------------------------------------------|--------------|
| Add W and f                                                                              | BSF          |
| [label] ADDWF f,d                                                                        | Syntax:      |
| $0 \le f \le 127$<br>$d \in [0,1]$                                                       | Operands:    |
| (W) + (f) $\rightarrow$ (destination)                                                    | Operation:   |

BCF

Syntax:

Operands:

Operation:

Status Affected:

| Operation:       | (W) + (f) $\rightarrow$ (destination)                                                                                                                                  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status Affected: | C, DC, Z                                                                                                                                                               |
| Description:     | Add the contents of the W register with register 'f'. If 'd' is '0', the result is stored in the W register. If 'd' is '1', the result is stored back in register 'f'. |

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

Bit Clear f

[ label ] BCF

 $\begin{array}{l} 0 \leq f \leq 127 \\ 0 \leq b \leq 7 \end{array}$ 

 $0 \rightarrow (f < b >)$ 

None

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

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

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

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

| RLF              | Rotate Left f through Carry                                                                                                                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RLF f,d                                                                                                                                                                                          |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                                   |
| Operation:       | See description below                                                                                                                                                                                             |
| Status Affected: | С                                                                                                                                                                                                                 |
| Description:     | The contents of register 'f' are<br>rotated one bit to the left through the<br>Carry flag. If 'd' is '0', the result is<br>placed in the W register. If 'd' is '1',<br>the result is stored back in register 'f'. |

| SLEEP            | Enter Sleep mode                                                                                                                                                                                                                                     |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] SLEEP                                                                                                                                                                                                                                        |
| Operands:        | None                                                                                                                                                                                                                                                 |
| Operation:       | $\begin{array}{l} 00h \rightarrow WDT, \\ 0 \rightarrow WDT \ prescaler, \\ 1 \rightarrow \overline{TO}, \\ 0 \rightarrow \overline{PD} \end{array}$                                                                                                 |
| Status Affected: | TO, PD                                                                                                                                                                                                                                               |
| Description:     | The Power-Down status bit, $\overline{\text{PD}}$ ,<br>is cleared. Time-out status bit,<br>$\overline{\text{TO}}$ , is set. Watchdog Timer and<br>its prescaler are cleared.<br>The processor is put into Sleep<br>mode with the oscillator stopped. |

| RETURN           | Return from Subroutine                                                                                                                                     |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [label] RETURN                                                                                                                                             |
| Operands:        | None                                                                                                                                                       |
| Operation:       | $TOS \rightarrow PC$                                                                                                                                       |
| Status Affected: | None                                                                                                                                                       |
| Description:     | Return from subroutine. The stack<br>is POPed and the top of the stack<br>(TOS) is loaded into the program<br>counter. This is a two-cycle<br>instruction. |

| RRF              | Rotate Right f through Carry                                                                                                                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] RRF f,d                                                                                                                                                                                              |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d \in [0,1] \end{array}$                                                                                                                                                       |
| Operation:       | See description below                                                                                                                                                                                                 |
| Status Affected: | С                                                                                                                                                                                                                     |
| Description:     | The contents of register 'f' are<br>rotated one bit to the right through<br>the Carry flag. If 'd' is '0', the<br>result is placed in the W register.<br>If 'd' is '1', the result is placed<br>back in register 'f'. |
|                  | C Register f                                                                                                                                                                                                          |

| SUBLW            | Subtract W from Literal                                                                                                      |
|------------------|------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] SUBLW k                                                                                                     |
| Operands:        | $0 \leq k \leq 255$                                                                                                          |
| Operation:       | $k - (W) \rightarrow (W)$                                                                                                    |
| Status Affected: | C, DC, Z                                                                                                                     |
| Description:     | The W register is subtracted (2's complement method) from the eight-bit literal 'k'. The result is placed in the W register. |

| SUBWF            | Subtract W from f                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:          | [ <i>label</i> ] SUBWF f,d                                                                                                                                                                  |
| Operands:        | $\begin{array}{l} 0 \leq f \leq 127 \\ d  \in  [0,1] \end{array}$                                                                                                                           |
| Operation:       | (f) – (W) $\rightarrow$ (destination)                                                                                                                                                       |
| Status Affected: | C, DC, Z                                                                                                                                                                                    |
| Description:     | Subtract (2's complement method)<br>W register from register 'f'. If 'd' is<br>'0', the result is stored in the W<br>register. If 'd' is '1', the result is<br>stored back in register 'f'. |





TABLE 18-8: CAPTURE/COMPARE/PWM REQUIREMENTS (ALL CCP MODULES)

| Param<br>No. | Symbol | Characteristic                            |                |            | Min                    | Тур† | Max | Units | Conditions                         |
|--------------|--------|-------------------------------------------|----------------|------------|------------------------|------|-----|-------|------------------------------------|
| 50*          | TCCL   | CCP1, CCP2 and<br>CCP3 Input Low<br>Time  | No prescaler   |            | 0.5 TCY + 20           | _    | _   | ns    |                                    |
|              |        |                                           | With prescaler | PIC16F7X7  | 10                     | —    | —   | ns    |                                    |
|              |        |                                           |                | PIC16LF7X7 | 20                     | _    | —   | ns    |                                    |
| 51*          | ТссН   | CCP1, CCP2 and<br>CCP3 Input High<br>Time | No prescaler   |            | 0.5 TCY + 20           |      | —   | ns    |                                    |
|              |        |                                           | With prescaler | PIC16F7X7  | 10                     |      | —   | ns    |                                    |
|              |        |                                           |                | PIC16LF7X7 | 20                     | _    | _   | ns    |                                    |
| 52*          | TCCP   | CCP1, CCP2 and CCP3 Input Period          |                |            | <u>3 Tcy + 40</u><br>N | _    | _   | ns    | N = prescale<br>value (1, 4 or 16) |
| 53*          | TccR   | CCP1, CCP2 and CCP3 Output                |                | PIC16F7X7  | —                      | 10   | 25  | ns    |                                    |
|              |        | Rise Time                                 |                | PIC16LF7X7 | —                      | 25   | 50  | ns    |                                    |
| 54*          | TCCF   | CCP1, CCP2 and (                          | CCP3 Output    | PIC16F7X7  | —                      | 10   | 25  | ns    |                                    |
|              |        | Fall Time                                 |                | PIC16LF7X7 | _                      | 25   | 45  | 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.

# PIC16F7X7





# FIGURE 19-4: MAXIMUM IDD vs. Fosc OVER VDD (XT MODE)







#### FIGURE 19-12: AVERAGE FOSC vs. VDD FOR VARIOUS VALUES OF R (RC MODE, C = 100 pF, +25°C)



DS30498D-page 240

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

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



# RECOMMENDED LAND PATTERN

|                          | MILLIMETERS |      |          |      |  |  |
|--------------------------|-------------|------|----------|------|--|--|
| Dimension                | MIN         | NOM  | MAX      |      |  |  |
| Contact Pitch            | E           |      | 1.27 BSC |      |  |  |
| Contact Pad Spacing      | С           |      | 9.40     |      |  |  |
| Contact Pad Width (X28)  | X           |      |          | 0.60 |  |  |
| Contact Pad Length (X28) | Y           |      |          | 2.00 |  |  |
| Distance Between Pads    | Gx          | 0.67 |          |      |  |  |
| Distance Between Pads    | G           | 7.40 |          |      |  |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

Microchip Technology Drawing No. C04-2052A

# PIC16F7X7

NOTES: