



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                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 36                                                                         |
| Program Memory Size        | 28KB (16K × 14)                                                            |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 128 x 8                                                                    |
| RAM Size                   | 2K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 28x10b; D/A 4x5b, 4x10b                                                |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 40-UFQFN Exposed Pad                                                       |
| Supplier Device Package    | 40-UQFN (5x5)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1779-i-mv |

Email: info@E-XFL.COM

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

| Name                                           | Function              | Input<br>Type | Output<br>Type | Description                                  |
|------------------------------------------------|-----------------------|---------------|----------------|----------------------------------------------|
| RA3/AN3/VREF+/DAC1REF0+/                       | RA3                   | TTL/ST        | CMOS           | General purpose I/O.                         |
| DAC2REF0+/DAC3REF0+/                           | AN3                   | AN            |                | ADC Channel 3 input.                         |
| DAC4REF0+/DAC5REF0+/<br>DAC7REF0+/C1IN1+/MD1CI | VREF+                 | AN            |                | ADC positive reference.                      |
|                                                | DAC1REF0+             | AN            |                | DAC1 positive reference.                     |
|                                                | DAC2REF0+             | AN            |                | DAC2 positive reference.                     |
|                                                | DAC3REF0+             | AN            |                | DAC3 positive reference.                     |
|                                                | DAC4REF0+             | AN            | _              | DAC4 positive reference.                     |
|                                                | DAC5REF0+             | AN            | _              | DAC5 positive reference.                     |
|                                                | DAC7REF0+             | AN            | _              | DAC7 positive reference.                     |
|                                                | C1IN1+                | AN            | _              | Comparator 1 positive input.                 |
|                                                | MD1CL <sup>(1)</sup>  | TTL/ST        |                | Data signal modulator 1 low carrier input.   |
| RA4/OPA1IN0+/PRG1R/                            | RA4                   | TTL/ST        | CMOS           | General purpose I/O.                         |
| MD1CH/DAC4OUT1/T0CKI                           | OPA1IN0+              | AN            |                | Operational Amplifier 1 non-inverting input. |
|                                                | PRG1R <sup>(1)</sup>  | TTL/ST        |                | Ramp generator set_rising input.             |
|                                                | MD1CH <sup>(1)</sup>  | TTL/ST        |                | Data signal modulator 1 high carrier input.  |
|                                                | DAC4OUT1              | _             | AN             | DAC4 voltage output.                         |
|                                                | T0CKI <sup>(1)</sup>  | TTL/ST        | _              | Timer0 clock input.                          |
| RA5/AN4/OPA1IN0-/                              | RA5                   | TTL/ST        | CMOS           | General purpose I/O.                         |
| DAC2OUT1/PRG1F/                                | AN4                   | AN            | _              | ADC Channel 4 input.                         |
| MD IMOD/SS                                     | OPA1IN0-              | AN            |                | Operational amplifier 1 inverting input.     |
|                                                | DAC2OUT1              |               | AN             | DAC2 voltage output.                         |
|                                                | PRG1F <sup>(1)</sup>  | TTL/ST        |                | Ramp generator set_falling input.            |
|                                                | MD1MOD <sup>(1)</sup> | TTL/ST        |                | Data signal modulator modulation input.      |
|                                                | SS                    | ST            | —              | Slave Select input.                          |
| RA6/CLKOUT/C6IN1+/OSC2                         | RA6                   | TTL/ST        | CMOS           | General purpose I/O.                         |
|                                                | CLKOUT                |               | CMOS           | Fosc/4 output.                               |
|                                                | C6IN1+                | AN            |                | Comparator 6 positive input.                 |
|                                                | OSC2                  | XTAL          |                | Crystal/Resonator (LP, XT, HS modes).        |
| RA7/CLKIN/OSC1                                 | RA7                   | TTL/ST        | CMOS           | General purpose I/O.                         |
|                                                | CLKIN                 | TTL/ST        |                | CLC input.                                   |
|                                                | OSC1                  | XTAL          |                | Crystal/Resonator (LP, XT, HS modes).        |
| RB0/AN12/ZCD/HIB0/C2IN1+/                      | RB0                   | TTL/ST        | CMOS           | General purpose I/O.                         |
| COG1IN                                         | AN12                  | AN            |                | ADC Channel 12 input.                        |
|                                                | ZCD                   | AN            |                | Zero-cross detection input.                  |
|                                                | HIB0                  | HP            | HP             | High-Power output.                           |
|                                                | C2IN1+                | AN            |                | Comparator 2 positive input.                 |
|                                                | COG1IN <sup>(1)</sup> | TTL/ST        | —              | Complementary output generator 1 input.      |

TABLE 1-2: PIC16(L)F1778 PINOUT DESCRIPTION (CONTINUED)

Legend:AN = Analog input or outputCMOS = CMOS compatible input or outputOD= Open-DrainTTL = TTL compatible inputST= Schmitt Trigger input with CMOS levelsI<sup>2</sup>C= Schmitt Trigger input with I<sup>2</sup>CHP = High PowerXTAL= Crystal levels

Note 1: Default peripheral input. Alternate pins can be selected as the peripheral input with the PPS input selection registers.
 All pin digital outputs default to PORT latch data. Alternate outputs can be selected as the peripheral digital output with the PPS output selection registers.

3: These peripheral functions are bidirectional. The output pin selections must be the same as the input pin selections.

| Name   | Bit 7  | Bit 6  | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1 | Bit 0  | Register<br>on Page |
|--------|--------|--------|-------|-------|--------|-------|-------|--------|---------------------|
| BORCON | SBOREN | BORFS  |       | _     | _      | _     | _     | BORRDY | 121                 |
| PCON   | STKOVF | STKUNF | _     | RWDT  | RMCLR  | RI    | POR   | BOR    | 125                 |
| STATUS | _      | _      | _     | TO    | PD     | Z     | DC    | С      | 40                  |
| WDTCON | _      |        |       | V     | SWDTEN | 154   |       |        |                     |

#### TABLE 6-5: SUMMARY OF REGISTERS ASSOCIATED WITH RESETS

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by Resets.

| REGISTER 11-20: L | LATC: PORTC DATA LATCH REGISTER |
|-------------------|---------------------------------|
|-------------------|---------------------------------|

| R/W-x/u     | R/W-x/u |
|---------|---------|---------|---------|---------|---------|-------------|---------|
| LATC7   | LATC6   | LATC5   | LATC4   | LATC3   | LATC2   | LATC2 LATC1 |         |
| bit 7   |         |         |         |         |         |             | bit 0   |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-0 LATC<7:0>: PORTC Output Latch Value bits

#### REGISTER 11-21: ANSELC: PORTC ANALOG SELECT REGISTER

| R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | U-0 | U-0   |
|---------|---------|---------|---------|---------|---------|-----|-------|
| ANSC7   | ANSC6   | ANSC5   | ANSC4   | ANSC3   | ANSC2   | —   | —     |
| bit 7   |         |         |         |         |         |     | bit 0 |

| Legend:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared |                                                       |

bit 7-2 ANSC<7:2>: Analog Select between Analog or Digital Function on pins RC<7:2><sup>(1)</sup>

1 = Analog input. Pin is assigned as analog input<sup>(1)</sup>. Digital input buffer disabled.

0 = Digital I/O. Pin is assigned to port or digital special function.

bit 1-0 Unimplemented: Read as '0'

**Note 1:** When setting a pin to an analog input, the corresponding TRIS bit must be set to Input mode in order to allow external control of the voltage on the pin.

| Peripheral                       | xxxPPS    | Default Pin<br>Selection | Reset Value<br>(xxxPPS<5:0>) |     | Port Selection<br>PIC16(L)F1777/9 |   | tion<br>777/9 |   | Por<br>PIC | t Selec<br>16(L)F1 | tion<br>1778 |
|----------------------------------|-----------|--------------------------|------------------------------|-----|-----------------------------------|---|---------------|---|------------|--------------------|--------------|
| _                                | Register  | PIC16(L)F1777/8/9        | PIC16(L)F1777/8/9            | A B |                                   | С | D             | Е | Α          | В                  | С            |
| Interrupt-on-change              | INTPPS    | RB0                      | 001000                       | • • |                                   |   |               |   | •          | •                  |              |
| Timer0clock                      | T0CKIPPS  | RA4                      | 000100                       | •   | •                                 |   |               |   | •          | •                  |              |
| Timer1clock                      | T1CKIPPS  | RC0                      | 010000                       | •   |                                   | • |               |   | •          |                    | •            |
| Timer1 gate                      | T1GPPS    | RB5                      | 001101                       |     | •                                 | • |               |   |            | •                  | •            |
| Timer3 clock                     | T3CKIPPS  | RC0                      | 010000                       |     | •                                 | ٠ |               |   |            | •                  | •            |
| Timer3 gate                      | T3GPPS    | RC0                      | 010000                       | •   |                                   | • |               |   | •          |                    | •            |
| Timer5 clock                     | T5CKIPPS  | RC2                      | 010010                       | •   |                                   | • |               |   | •          |                    | •            |
| Timer5 gate                      | T5GPPS    | RB4                      | 001100                       |     | •                                 |   | •             |   |            | •                  | •            |
| Timer2 input                     | T2INPPS   | RC3                      | 010011                       | ٠   |                                   | ٠ |               |   | •          |                    | •            |
| Timer4 input                     | T4INPPS   | RC5                      | 010101                       |     | •                                 | • |               |   |            | ٠                  | •            |
| Timer6 input                     | T6INPPS   | RB7                      | 001111                       |     | •                                 |   | •             |   |            | •                  | •            |
| Timer8 input                     | T8INPPS   | RC4                      | 010100                       |     | •                                 |   | •             |   |            | •                  | •            |
| CCP1                             | CCP1PPS   | RC2                      | 010010                       |     | •                                 | • |               |   |            | •                  | •            |
| CCP2                             | CCP2PPS   | RC1                      | 010001                       |     | •                                 | • |               |   |            | •                  | •            |
| CCP7                             | CCP7PPS   | RB5                      | 001101                       |     | •                                 |   | •             |   |            | •                  | •            |
| CCP8 <sup>(1)</sup>              | CCP8PPS   | RB0                      | 001000                       |     | •                                 |   | •             |   |            | •                  | •            |
| COG1                             | COG1INPPS | RB0                      | 001000                       |     | •                                 |   | •             |   |            | •                  | •            |
| COG2                             | COG2INPPS | RB1                      | 001001                       |     | •                                 |   | •             |   |            | •                  | •            |
| COG3                             | COG3INPPS | RB2                      | 001010                       |     | •                                 |   | •             |   |            | •                  | •            |
| COG4 <sup>(1)</sup>              | COG4INPPS | RB3                      | 001011                       |     | •                                 |   | •             |   |            |                    |              |
| DSM1 low carrier                 | MD1CLPPS  | RA3                      | 000011                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM1 high carrier                | MD1CHPPS  | RA4                      | 000100                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM1 modulation                  | MD1MODPPS | RA5                      | 000101                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM2 low carrier                 | MD2CLPPS  | RC3                      | 010011                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM2 high carrier                | MD2CHPPS  | RC4                      | 010100                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM2 modulation                  | MD2MODPPS | RC5                      | 010101                       | •   |                                   |   | •             |   | •          |                    | •            |
| DSM3 low carrier                 | MD3CLPPS  | RB3                      | 001011                       |     | •                                 |   | •             |   |            | •                  | •            |
| DSM3 high carrier                | MD3CHPPS  | RB4                      | 001100                       |     | •                                 |   | •             |   |            | •                  | •            |
| DSM3 modulation                  | MD3MODPPS | RB5                      | 001101                       |     | •                                 |   | •             |   |            | •                  | •            |
| DSM4 low carrier <sup>(1)</sup>  | MD4CLPPS  | RB0                      | 001000                       |     | •                                 |   | •             |   |            |                    |              |
| DSM4 high carrier <sup>(1)</sup> | MD4CHPPS  | RB1                      | 001001                       |     | •                                 |   | •             |   |            |                    |              |
| DSM4 modulation <sup>(1)</sup>   | MD4MODPPS | RB2                      | 001010                       |     | •                                 |   | •             |   |            |                    |              |
| PRG1 set rising                  | PRG1RPPS  | RA4                      | 000100                       | •   |                                   |   | •             |   | •          |                    | •            |
| PRG1 set falling                 | PRG1FPPS  | RA5                      | 000101                       | •   |                                   |   | •             |   | •          |                    | •            |
| PRG2 set rising                  | PRG2RPPS  | RC1                      | 010001                       | •   |                                   |   | •             |   | •          |                    | •            |
| PRG2 set falling                 | PRG2FPPS  | RC2                      | 010010                       | •   |                                   |   | •             |   | •          |                    | •            |
| PRG3 set rising                  | PRG3RPPS  | RC4                      | 010100                       |     | •                                 |   | •             |   |            | •                  | •            |
| PRG3 set falling                 | PRG3FPPS  | RC5                      | 010101                       |     | •                                 |   | •             |   |            | •                  | •            |
| PRG4 set rising <sup>(1)</sup>   | PRG4RPPS  | RB1                      | 010100                       |     | •                                 |   | •             |   |            |                    |              |
| PRG4set falling <sup>(1)</sup>   | PRG4FPPS  | RB2                      | 010101                       |     | •                                 |   | •             |   |            |                    |              |
| ADC trigger                      | ADCACTPPS | RB4                      | 001100                       |     | •                                 |   | •             |   |            | •                  | •            |

TABLE 12-1: PPS INPUT REGISTER RESET VALUES

**Example:** CCP1PPS = 0x13 selects RC3 as the CCP1 input.

**Note 1:** PIC16(L)F1777/9 only

## TABLE 12-3: SUMMARY OF REGISTERS ASSOCIATED WITH THE PPS MODULE (CONTINUED)

| Name       | Bit 7 | Bit 6 | Bit 5 | Bit 4          | Bit 3 | Bit 2     | Bit 1 | Bit 0 | Register<br>on page |  |  |  |
|------------|-------|-------|-------|----------------|-------|-----------|-------|-------|---------------------|--|--|--|
| CLC1IN1PPS |       |       |       |                | CLCIN | 1PPS<5:0> |       |       | 205                 |  |  |  |
| CLC1IN2PPS | —     | —     |       |                | CLCIN | 2PPS<5:0> |       |       | 205                 |  |  |  |
| CLC1IN3PPS |       | _     |       |                | CLCIN | 3PPS<5:0> |       |       | 205                 |  |  |  |
| ADCACTPPS  | _     | _     |       | ADCACTPPS<5:0> |       |           |       |       |                     |  |  |  |
| SSPCLKPPS  | _     | _     |       |                | SSPCL | KPPS<5:0> | •     |       | 205                 |  |  |  |
| SSPDATPPS  | _     | _     |       |                | SSPDA | TPPS<5:0> | •     |       | 205                 |  |  |  |
| SSPSSPPS   | _     | _     |       | SSPSSPPS<5:0>  |       |           |       |       |                     |  |  |  |
| RXPPS      |       |       |       | RXPPS<5:0>     |       |           |       |       |                     |  |  |  |
| CKPPS      |       |       |       |                | CKP   | PS<5:0>   |       |       | 205                 |  |  |  |

**Legend:** — = unimplemented, read as '0'. Shaded cells are unused by the PPS module.

**Note 1:** PIC16(L)F1777/9 only.



#### FIGURE 13-1: INTERRUPT-ON-CHANGE BLOCK DIAGRAM (PORTA EXAMPLE)

| U-0   | U-0 | U-0 | U-0 | R/W/HS-0/0 | U-0 | U-0 | U-0   |
|-------|-----|-----|-----|------------|-----|-----|-------|
| —     | —   | -   | —   | IOCEF3     | —   | —   | —     |
| bit 7 |     |     |     |            |     |     | bit 0 |
|       |     |     |     |            |     |     |       |

| Legena:              |                      |                                                       |
|----------------------|----------------------|-------------------------------------------------------|
| R = Readable bit     | W = Writable bit     | U = Unimplemented bit, read as '0'                    |
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | HS - Bit is set in hardware                           |

bit 7-4 Unimplemented: Read as '0'

Lanandi

bit 3 IOCEF3: Interrupt-on-Change PORTE Flag bits

1 = An enabled change was detected on the associated pin.
 Set when IOCEPx = 1 and a rising edge was detected on REx, or when IOCENx = 1 and a falling edge was detected on REx.

0 = No change was detected, or the user cleared the detected change.

bit 2-0 Unimplemented: Read as '0'

#### TABLE 13-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPT-ON-CHANGE

| Name   | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2                 | Bit 1                 | Bit 0                 | Register<br>on Page |
|--------|--------|--------|--------|--------|--------|-----------------------|-----------------------|-----------------------|---------------------|
| ANSELA | —      | —      | ANSA5  | ANSA4  | ANSA3  | ANSA2                 | ANSA1                 | ANSA0                 | 177                 |
| ANSELB | —      | —      | ANSB5  | ANSB4  | ANSB3  | ANSB2                 | ANSB1                 | ANSB0                 | 182                 |
| ANSELC | ANSC7  | ANSC6  | ANSC5  | ANSC4  | ANSC3  | ANSC2                 | —                     | —                     | 187                 |
| INTCON | GIE    | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF                | INTF                  | IOCIF                 | 132                 |
| IOCAF  | IOCAF7 | IOCAF6 | IOCAF5 | IOCAF4 | IOCAF3 | IOCAF2                | IOCAF1                | IOCAF0                | 216                 |
| IOCAN  | IOCAN7 | IOCAN6 | IOCAN5 | IOCAN4 | IOCAN3 | IOCAN2                | IOCAN1                | IOCAN0                | 215                 |
| IOCAP  | IOCAP7 | IOCAP6 | IOCAP5 | IOCAP4 | IOCAP3 | IOCAP2                | IOCAP1                | IOCAP0                | 215                 |
| IOCBF  | IOCBF7 | IOCBF6 | IOCBF5 | IOCBF4 | IOCBF3 | IOCBF2                | IOCBF1                | IOCBF0                | 217                 |
| IOCBN  | IOCBN7 | IOCBN6 | IOCBN5 | IOCBN4 | IOCBN3 | IOCBN2                | IOCBN1                | IOCBN0                | 216                 |
| IOCBP  | IOCBP7 | IOCBP6 | IOCBP5 | IOCBP4 | IOCBP3 | IOCBP2                | IOCBP1                | IOCBP0                | 216                 |
| IOCCF  | IOCCF7 | IOCCF6 | IOCCF5 | IOCCF4 | IOCCF3 | IOCCF2                | IOCCF1                | IOCCF0                | 218                 |
| IOCCN  | IOCCN7 | IOCCN6 | IOCCN5 | IOCCN4 | IOCCN3 | IOCCN2                | IOCCN1                | IOCCN0                | 218                 |
| IOCCP  | IOCCP7 | IOCCP6 | IOCCP5 | IOCCP4 | IOCCP3 | IOCCP2                | IOCCP1                | IOCCP0                | 218                 |
| IOCEP  | _      | —      | _      | _      | IOCEP3 | _                     | _                     | _                     | 219                 |
| IOCEN  | _      | —      | _      | _      | IOCEN3 | —                     | —                     | —                     | 219                 |
| IOCEF  | —      | —      | —      | _      | IOCEF3 | —                     | —                     | —                     | 220                 |
| TRISA  | TRISA7 | TRISA6 | TRISA5 | TRISA4 | TRISA3 | TRISA2                | TRISA1                | TRISA0                | 176                 |
| TRISB  | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2                | TRISB1                | TRISB0                | 181                 |
| TRISC  | TRISC7 | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2                | TRISC1                | TRISC0                | 186                 |
| TRISE  | _      | —      | —      | —      | (1)    | TRISE2 <sup>(2)</sup> | TRISE1 <sup>(2)</sup> | TRISE0 <sup>(2)</sup> | 199                 |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by interrupt-on-change.

Note 1: Unimplemented, read as '1'.

2: Unimplemented on PIC16(L)F1778.

## 20.2 ZCD Logic Output

The ZCD module includes a Status bit, which can be read to determine whether the current source or sink is active. The OUT bit of the ZCDCON register is set when the current sink is active, and cleared when the current source is active. The OUT bit is affected by the polarity bit.

### 20.3 ZCD Logic Polarity

The POL bit of the ZCDxCON register inverts the OUT bit relative to the current source and sink output. When the POL bit is set, a OUT high indicates that the current source is active, and a low output indicates that the current sink is active.

The POL bit affects the ZCD interrupts. See **Section 20.4 "ZCD Interrupts**".

#### 20.4 ZCD Interrupts

An interrupt will be generated upon a change in the ZCD logic output when the appropriate interrupt enables are set. A rising edge detector and a falling edge detector are present in the ZCD for this purpose.

The ZCDIF bit of the PIR3 register will be set when either edge detector is triggered and its associated enable bit is set. The INTP enables rising edge interrupts and the INTN bit enables falling edge interrupts. Both are located in the ZCDxCON register.

To fully enable the interrupt, the following bits must be set:

- · ZCDIE bit of the PIE3 register
- INTP bit of the ZCDxCON register (for a rising edge detection)
- INTN bit of the ZCDxCON register (for a falling edge detection)
- PEIE and GIE bits of the INTCON register

Changing the POL bit will cause an interrupt, regardless of the level of the EN bit.

The ZCDIF bit of the PIR3 register must be cleared in software as part of the interrupt service. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence.

### 20.5 Correcting for ZCPINV Offset

The actual voltage at which the ZCD switches is the reference voltage at the non-inverting input of the ZCD op amp. For external voltage source waveforms other than square waves this voltage offset from zero causes the zero-cross event to occur either too early or too late.

#### 20.5.1 CORRECTION BY AC COUPLING

When the external voltage source is sinusoidal, the effects of the ZCPINV offset can be eliminated by isolating the external voltage source from the ZCD pin with a capacitor in addition to the voltage reducing resistor. The capacitor will cause a phase shift resulting in the ZCD output switch in advance of the actual zero-crossing event. The phase shift will be the same for both rising and falling zero crossings, which can be compensated for by either delaying the CPU response to the ZCD switch by a timer or other means, or selecting a capacitor value large enough that the phase shift is negligible.

To determine the series resistor and capacitor values for this configuration, start by computing the impedance, Z, to obtain a peak current of 300  $\mu$ A. Next, arbitrarily select a suitably large non-polar capacitor and compute its reactance, X<sub>c</sub>, at the external voltage source frequency. Finally, compute the series resistor, capacitor peak voltage, and phase shift by the formulas shown in Equation 20-2.

#### EQUATION 20-2: R-C CALCULATIONS

$$V_{\text{peak}} = \text{external voltage source peak voltage}$$

$$f = \text{external voltage source frequency}$$

$$C = \text{series capacitor}$$

$$R = \text{series resistor}$$

$$V_{c} = \text{Peak capacitor voltage}$$

$$\phi = \text{Capacitor induced zero crossing phase}$$

$$advance in radians$$

$$T_{\phi} = \text{Time ZC event occurs before actual zero}$$

$$crossing$$

$$Z = \frac{V_{PEAK}}{3x10^{-4}}$$

$$X_{c} = \frac{1}{(2\pi fC)}$$

$$R = \sqrt{Z^{2} - X_{c}}$$

$$V_{c} = X_{c}(3x10^{-4})$$

$$\phi = Tan^{-1}(\frac{X_{c}}{R})$$

$$T_{\phi} = \frac{\phi}{(2\pi f)}$$

$$V_{rms} = 120$$

## EQUATION 20-3: R-C CALCULATIONS EXAMPLE

$$V_{peak} = V_{rms} \cdot \sqrt{2} = 169.7$$
  
f = 60 Hz  
C = 0.1 µf  

$$Z = \frac{V_{peak}}{3 \times 10^{-4}} = \frac{169.7}{3 \times 10^{-4}} = 565.7 \ kOhms$$

$$X_c = \frac{1}{(2\pi fC)} = \frac{1}{(2\pi \cdot 60 \cdot 1 \cdot 10^{-7})} = 26.53 \ kOhms$$
R = 560 kOhms  

$$Z_R = \sqrt{(R^2 + X_c^2)} = 560.6 \ kOhm \ (using actual resistor)$$

$$I_{peak} = \frac{V_{peak}}{Z_R} = 302.7 \cdot 10^{-6}$$

$$V_c = X_c \cdot I_{peak} = 8.0 \ V$$

$$\phi = Tan^{-1} \left(\frac{X_c}{R}\right) = 0.047 \ radians$$

$$T_{\phi} = \frac{\phi}{(2\pi f)} = 125.6 \ \mu s$$

#### 23.6.8 LEVEL RESET, EDGE-TRIGGERED HARDWARE LIMIT ONE-SHOT MODES

In Level -Triggered One-Shot mode the timer count is reset on the external signal level and starts counting on the rising/falling edge of the transition from Reset level to the active level while the ON bit is set. Reset levels are selected as follows:

- Low Reset level (MODE<4:0> = 01110)
- High Reset level (MODE<4:0> = 01111)

When the timer count matches the PRx period count, the timer is reset and the ON bit is cleared. When the ON bit is cleared by either a PRx match or by software control a new external signal edge is required after the ON bit is set to start the counter.

When Level-Triggered Reset One-Shot mode is used in conjunction with the CCP PWM operation the PWM drive goes active with the external signal edge that starts the timer. The PWM drive goes inactive when the timer count equals the CCPRx pulse width count. The PWM drive does not go active when the timer count clears at the PRx period count match.

### 24.6 CCP/PWM Clock Selection

This device allows each individual CCP and PWM module to select the timer source that controls the module. Each module has an independent selection.

As there are four 8-bit timers with auto-reload (Timer2, Timer4, Timer6 and Timer8). The PWM mode on the CCP and 10-bit PWM modules can use any of these timers.

The CCPTMRS register is used to select which timer is used.

## 24.7 Register Definitions: CCP/PWM Timers Control

#### REGISTER 24-5: CCPTMRS1: PWM TIMER SELECTION CONTROL REGISTER 1

| R/W-0/0                    | R/W-0/0 | R/W-0/0 | R/W-0/0     | R/W-0/0 | R/W-0/0     | R/W-0/0 | R/W-0/0     |  |
|----------------------------|---------|---------|-------------|---------|-------------|---------|-------------|--|
| C8TSEL<1:0> <sup>(1)</sup> |         | C7TSE   | C7TSEL<1:0> |         | C2TSEL<1:0> |         | C1TSEL<1:0> |  |
| bit 7                      |         |         |             |         |             |         | bit 0       |  |

| Legend:      |               |                                 |                                                       |
|--------------|---------------|---------------------------------|-------------------------------------------------------|
| R = Reada    | able bit      | W = Writable bit                | U = Unimplemented bit, read as '0'                    |
| u = Bit is u | inchanged     | x = Bit is unknown              | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is | set           | '0' = Bit is cleared            |                                                       |
|              |               |                                 |                                                       |
| bit 7-6      | C8TSEL        | <1:0>: CCP8 (PWM8) Timer Sel    | ection bits <sup>(1)</sup>                            |
|              | 11 = C        | CP8 is based off Timer8 in PWM  | mode                                                  |
|              | 10 = C        | CP8 is based off Timer6 in PWM  | mode                                                  |
|              | 01 = C        | CP8 is based off Timer4 in PWM  | mode                                                  |
|              | 00 = C        | CP8 is based off Timer2 in PWM  | mode                                                  |
| bit 5-4      | C7TSEL        | -<1:0>: CCP7 (PWM7) Timer Sel   | ection bits                                           |
|              | 11 = C        | CP7 is based off Timer8 in PWM  | mode                                                  |
|              | 10 = C        | CP7 is based off Timer6 in PWM  | mode                                                  |
|              | 01 = C        | CP7 is based off Timer4 in PWM  | mode                                                  |
|              | 00 = C        | CP7 is based of Timer2 in PVVV  | mode                                                  |
| bit 3-2      | C2TSEL        | -<1:0>: CCP2 (PWM2) Timer Sel   | ection bits                                           |
|              | 11 = C        | CP2 is based off Timer8 in PWM  | mode                                                  |
|              | 10 = C        | CP2 is based off Timer6 in PWM  | mode                                                  |
|              | 01 = C        | CP2 is based off Timer4 in PVVM | mode                                                  |
|              |               |                                 |                                                       |
| DIT 1-0      | CTISEL        | -<1:0>: CCP1 (PWM1) Timer Set   |                                                       |
|              | 11 = C        | CP1 is based off Timer8 in PWM  | mode                                                  |
|              | 10 = C        | CP1 is based off Timero in PVVM | mode                                                  |
|              | 01 = C        | CP1 is based off Timer2 in PW/M | mode                                                  |
|              | 00 <b>- C</b> |                                 | mout                                                  |
| Note 1:      | PIC16(L)F17   | 77/9 only.                      |                                                       |

| R/W-0/0          | R/W-0/0              | R/W-0/0                 | R/W-0/0          | R/W-0/0             | R/W-0/0          | R/W-0/0          | R/W-0/0      |
|------------------|----------------------|-------------------------|------------------|---------------------|------------------|------------------|--------------|
| P10TSEL          | <1:0> <sup>(1)</sup> | P9TSEL<1:0>             |                  | P4TSI               | EL<1:0>          | P3TSE            | L<1:0>       |
| bit 7            |                      |                         |                  |                     |                  |                  | bit 0        |
|                  |                      |                         |                  |                     |                  |                  |              |
| Legend:          |                      |                         |                  |                     |                  |                  |              |
| R = Readable b   | bit                  | W = Writable I          | oit              | U = Unimpler        | mented bit, read | d as '0'         |              |
| u = Bit is uncha | inged                | x = Bit is unkn         | lown             | -n/n = Value a      | at POR and BC    | R/Value at all o | other Resets |
| '1' = Bit is set |                      | '0' = Bit is clea       | ared             |                     |                  |                  |              |
|                  |                      |                         |                  |                     |                  |                  |              |
| bit 7-6          | P10TSEL<1:           | <b>0&gt;:</b> PWM10 Tir | ner Selection I  | bits <sup>(1)</sup> |                  |                  |              |
|                  | 11 = PWM1            | 0 is based off T        | imer8 in PWN     | l mode              |                  |                  |              |
|                  | 10 = PWM10           | 0 is based off T        | imer6 in PWM     | l mode              |                  |                  |              |
|                  | 01 = PWM10           | 0 is based off T        | imer4 in PWN     | l mode              |                  |                  |              |
|                  | 00 = PWM10           | 0 is based off T        | imer2 in PWN     | l mode              |                  |                  |              |
| bit 5-4          | P9TSEL<1:0:          | >: PWM9 Time            | r Selection bits | 3                   |                  |                  |              |
|                  | 11 = PWM9            | is based off Tir        | mer8 in PWM      | mode                |                  |                  |              |
|                  | 10 = PWM9            | is based off Tir        | mer6 in PWM      | mode                |                  |                  |              |
|                  | 01 = PWM9            | is based off Tir        | mer4 in PWM      | mode                |                  |                  |              |
|                  | 00 = PWM9            | is based off I in       | mer2 in PWM i    | mode                |                  |                  |              |
| bit 3-2          | P4TSEL<1:0:          | >: PWM4 Time            | r Selection bits | 6                   |                  |                  |              |
|                  | 11 = PWM4            | is based off Tir        | mer8 in PWM      | mode                |                  |                  |              |
|                  | 10 = PWM4            | is based off Tir        | mer6 in PWM      | mode                |                  |                  |              |
|                  | 01 = PWM4            | is based off Tir        | mer4 in PWM      | mode                |                  |                  |              |
|                  | 00 = PWM4            | is based off Tir        | mer2 in PWM i    | mode                |                  |                  |              |
| bit 1-0          | P3TSEL<1:0:          | >: PWM3 Time            | r Selection bits | 5                   |                  |                  |              |
|                  | 11 = PWM3            | is based off Tir        | mer8 in PWM      | mode                |                  |                  |              |
|                  | 10 = PWM3            | is based off Tir        | mer6 in PWM      | mode                |                  |                  |              |
|                  | 01 = PWM3            | is based off Tir        | mer4 in PWM      | mode                |                  |                  |              |
|                  | 00 = PVVIVI3         | is based off Th         |                  | mode                |                  |                  |              |

## REGISTER 24-6: CCPTMRS2: PWM TIMER SELECTION CONTROL REGISTER 2

**Note 1:** PIC16(L)F1777/9 only.

### REGISTER 29-4: OPAxPCHS: OP AMP POSITIVE CHANNEL SOURCE SELECT REGISTER

| U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0<br>PCH<3:0><br>bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Legena: |     |     |     |          |         | 01      |         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|-----|-----|----------|---------|---------|---------|
| U-0         U-0         U-0         R/W-0/0         R/W-0/0 <th>Lanandi</th> <th></th> <th></th> <th></th> <th></th> <th></th> <th></th> <th></th>    | Lanandi |     |     |     |          |         |         |         |
| U-0         U-0         U-0         R/W-0/0         R/W-0/0 <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td>           |         |     |     |     |          |         |         |         |
| U-0         U-0         U-0         R/W-0/0         R/W-0/0 <td>bit 7</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>bit 0</td> | bit 7   |     |     |     |          |         |         | bit 0   |
| U-0 U-0 U-0 U-0 U-0 R/W-0/0 R/W-0/0 R/W-0/0 R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —       | _   | —   | —   | PCH<3:0> |         |         |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | U-0     | U-0 | U-0 | U-0 | R/W-0/0  | R/W-0/0 | R/W-0/0 | R/W-0/0 |

| R = Readable bit     | VV = VVritable bit   | U = Unimplemented bit, read as 'U'                    |
|----------------------|----------------------|-------------------------------------------------------|
| u = Bit is unchanged | x = Bit is unknown   | -n/n = Value at POR and BOR/Value at all other Resets |
| '1' = Bit is set     | '0' = Bit is cleared | g = Value depends on condition                        |

bit 7-4 Unimplemented: Read as '0'

bit 3-0 PCH<3:0>: Op Amp Non-Inverting Input Channel Selection bits See Table 29-5: Non-Inverting Input Sources

### TABLE 29-5: NON-INVERTING INPUT SOURCES

| NCH<3:0> | OPA1                 | OPA2                 | OPA3                    | OPA4 <sup>(1)</sup>  |
|----------|----------------------|----------------------|-------------------------|----------------------|
| 1111     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1110     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1101     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1100     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1011     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1010     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1001     | Reserved. Do not use | Reserved. Do not use | Reserved. Do not use    | Reserved. Do not use |
| 1000     | PRG2_out             | PRG2_out             | PRG4_out <sup>(1)</sup> | PRG4_out             |
| 0111     | PRG1_out             | PRG1_out             | PRG3_out                | PRG3_out             |
| 0110     | FVR_Buffer1          | FVR_Buffer1          | FVR_Buffer2             | FVR_Buffer2          |
| 0101     | DAC4_out             | DAC4_out             | DAC8_out <sup>(1)</sup> | DAC8_out             |
| 0100     | DAC3_out             | DAC3_out             | DAC7_out                | DAC7_out             |
| 0011     | DAC2_out             | DAC2_out             | DAC6_out <sup>(1)</sup> | DAC6_out             |
| 0010     | DAC1_out             | DAC1_out             | DAC5_out                | DAC5_out             |
| 0001     | OPA1IN1+             | OPA2IN1+             | OPA3IN1+ <sup>(1)</sup> | OPA4IN1+             |
| 0000     | OPA1IN0+             | OPA2IN0+             | OPA3IN0+                | OPA4IN0+             |

Note 1: PIC16(L)F1777/9 only.

| FIGURE 31-5:              | CARRIER LOW SYNCHRONIZATION (MDCHSYNC = 0, MDCLSYNC = 1) |
|---------------------------|----------------------------------------------------------|
| Carrier High (CARH)       |                                                          |
| Carrier Low (CARL)        |                                                          |
| Modulator (MOD)           |                                                          |
| MDx_out                   |                                                          |
| Active Carrier<br>State - |                                                          |



#### 32.6.6 I<sup>2</sup>C MASTER MODE TRANSMISSION

Transmission of a data byte, a 7-bit address or the other half of a 10-bit address is accomplished by simply writing a value to the SSPxBUF register. This action will set the Buffer Full flag bit, BF, and allow the Baud Rate Generator to begin counting and start the next transmission. Each bit of address/data will be shifted out onto the SDA pin after the falling edge of SCL is asserted. SCL is held low for one Baud Rate Generator rollover count (TBRG). Data should be valid before SCL is released high. When the SCL pin is released high, it is held that way for TBRG. The data on the SDA pin must remain stable for that duration and some hold time after the next falling edge of SCL. After the eighth bit is shifted out (the falling edge of the eighth clock), the BF flag is cleared and the master releases SDA. This allows the slave device being addressed to respond with an  $\overline{ACK}$  bit during the ninth bit time if an address match occurred, or if data was received properly. The status of ACK is written into the ACKSTAT bit on the rising edge of the ninth clock. If the master receives an Acknowledge, the Acknowledge Status bit, ACKSTAT, is cleared. If not, the bit is set. After the ninth clock, the SSPxIF bit is set and the master clock (Baud Rate Generator) is suspended until the next data byte is loaded into the SSPxBUF, leaving SCL low and SDA unchanged (Figure 32-28).

After the write to the SSPxBUF, each bit of the address will be shifted out on the falling edge of SCL until all seven address bits and the R/W bit are completed. On the falling edge of the eighth clock, the master will release the SDA pin, allowing the slave to respond with an Acknowledge. On the falling edge of the ninth clock, the master will sample the SDA pin to see if the address was recognized by a slave. The status of the ACK bit is loaded into the ACKSTAT Status bit of the SSPxCON2 register. Following the falling edge of the ninth clock transmission of the address, the SSPxIF is set, the BF flag is cleared and the Baud Rate Generator is turned off until another write to the SSPxBUF takes place, holding SCL low and allowing SDA to float.

#### 32.6.6.1 BF Status Flag

In Transmit mode, the BF bit of the SSPxSTAT register is set when the CPU writes to SSPxBUF and is cleared when all eight bits are shifted out.

#### 32.6.6.2 WCOL Status Flag

If the user writes the SSPxBUF when a transmit is already in progress (i.e., SSPSR is still shifting out a data byte), the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur).

WCOL must be cleared by software before the next transmission.

### 32.6.6.3 ACKSTAT Status Flag

In Transmit mode, the ACKSTAT bit of the SSPxCON2 register is cleared when the slave has sent an Acknowledge ( $\overrightarrow{ACK} = 0$ ) and is set when the slave does not Acknowledge ( $\overrightarrow{ACK} = 1$ ). A slave sends an Acknowledge when it has recognized its address (including a general call), or when the slave has properly received its data.

32.6.6.4 Typical Transmit Sequence:

- 1. The user generates a Start condition by setting the SEN bit of the SSPxCON2 register.
- 2. SSPxIF is set by hardware on completion of the Start.
- 3. SSPxIF is cleared by software.
- 4. The MSSP module will wait the required start time before any other operation takes place.
- 5. The user loads the SSPxBUF with the slave address to transmit.
- 6. Address is shifted out the SDA pin until all eight bits are transmitted. Transmission begins as soon as SSPxBUF is written to.
- The MSSP module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSPxCON2 register.
- The MSSP module generates an interrupt at the end of the ninth clock cycle by setting the SSPxIF bit.
- 9. The user loads the SSPxBUF with eight bits of data.
- 10. Data is shifted out the SDA pin until all eight bits are transmitted.
- 11. The MSSP module shifts in the ACK bit from the slave device and writes its value into the ACKSTAT bit of the SSPxCON2 register.
- 12. Steps 8-11 are repeated for all transmitted data bytes.
- 13. The user generates a Stop or Restart condition by setting the PEN or RSEN bits of the SSPxCON2 register. Interrupt is generated once the Stop/Restart condition is complete.

### TABLE 36-6: THERMAL CHARACTERISTICS

| Standard | Onorating | Conditiona | (unless | othonwice | atotod) |
|----------|-----------|------------|---------|-----------|---------|
| Standard | Operating | Conditions | luniess | otherwise | stated  |

| Param | Sym.      | Characteristic                         | Тур.  | Units | Conditions                                               |
|-------|-----------|----------------------------------------|-------|-------|----------------------------------------------------------|
| NO.   |           |                                        |       |       |                                                          |
| TH01  | θJA       | Thermal Resistance Junction to Ambient | 60.0  | °C/W  | 28-pin SPDIP package                                     |
|       |           |                                        | 80.0  | °C/W  | 28-pin SOIC package                                      |
|       |           |                                        | 90.0  | °C/W  | 28-pin SSOP package                                      |
|       |           |                                        | 48    | °C/W  | 28-pin UQFN 4x4mm package                                |
|       |           |                                        | 47.2  | °C/W  | 40-pin PDIP package                                      |
|       |           |                                        | 46.0  | °C/W  | 44-pin TQFP package                                      |
|       |           |                                        | 41.0  | °C/W  | 40-pin UQFN 5x5mm package                                |
| TH02  | θJC       | Thermal Resistance Junction to Case    | 31.4  | °C/W  | 28-pin SPDIP package                                     |
|       |           |                                        | 24    | °C/W  | 28-pin SOIC package                                      |
|       |           |                                        | 24    | °C/W  | 28-pin SSOP package                                      |
|       |           |                                        | 12    | °C/W  | 28-pin UQFN 4x4mm package                                |
|       |           |                                        | 24.70 | °C/W  | 40-pin PDIP package                                      |
|       |           |                                        | 14.5  | °C/W  | 44-pin TQFP package                                      |
|       |           |                                        | 5.5   | °C/W  | 40-pin UQFN 5x5mm package                                |
| TH03  | Тјмах     | Maximum Junction Temperature           | 150   | °C    |                                                          |
| TH04  | PD        | Power Dissipation                      | _     | W     | PD = PINTERNAL + PI/O                                    |
| TH05  | PINTERNAL | Internal Power Dissipation             | _     | W     | PINTERNAL = IDD x VDD <sup>(1)</sup>                     |
| TH06  | Pi/o      | I/O Power Dissipation                  | _     | W     | $PI/O = \Sigma (IOL * VOL) + \Sigma (IOH * (VDD - VOH))$ |
| TH07  | PDER      | Derated Power                          |       | W     | Pder = PDmax (Tj - Ta)/θja <sup>(2)</sup>                |

Note 1: IDD is current to run the chip alone without driving any load on the output pins.

2: TA = Ambient Temperature, TJ = Junction Temperature



#### RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER AND POWER-UP **FIGURE 36-8:**

Note: Unless otherwise noted, VIN = 5V, Fosc = 300 kHz, CIN = 0.1  $\mu$ F, TA = 25°C.



**FIGURE 37-7:** IDD, EC Oscillator LP Mode, Fosc = 32 kHz, PIC16LF1777/8/9 Only.



**FIGURE 37-8:** IDD, EC Oscillator LP Mode, Fosc = 32 kHz, PIC16F1777/8/9 Only.



FIGURE 37-9: IDD, EC Oscillator LP Mode, Fosc = 500 kHz, PIC16LF1777/8/9 Only.



**FIGURE 37-10:** IDD, EC Oscillator LP Mode, Fosc = 500 kHz, PIC16F1777/8/9 Only.



FIGURE 37-11: IDD Typical, EC Oscilla MP Mode, PIC16LF1777/8/9 Only.



FIGURE 37-12: IDD Maximum, EC Oscillator MP Mode, PIC16LF1777/8/9 Only.

Note: Unless otherwise noted, VIN = 5V, Fosc = 300 kHz, CIN = 0.1  $\mu$ F, TA = 25°C.



FIGURE 37-13: IDD Typical, EC Oscillator MP Mode, PIC16F1777/8/9 Only.



FIGURE 37-14: IDD Maximum, EC Oscillator MP Mode, PIC16F1777/8/9 Only.



FIGURE 37-15: IDD Typical, EC Oscillator HP Mode, PIC16LF1777/8/9 Only.



FIGURE 37-16: IDD Maximum, EC Oscillator HP Mode, PIC16LF1777/8/9 Only.



FIGURE 37-17: IDD Typical, EC Oscillator HP Mode, PIC16F1777/8/9 Only.



FIGURE 37-18: IDD Maximum, EC Oscillator HP Mode, PIC16F1777/8/9 Only.

### 38.6 MPLAB X SIM Software Simulator

The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers.

The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool.

#### 38.7 MPLAB REAL ICE In-Circuit Emulator System

The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE.

The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5).

The emulator is field upgradeable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables.

#### 38.8 MPLAB ICD 3 In-Circuit Debugger System

The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE.

The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a highspeed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers.

## 38.9 PICkit 3 In-Circuit Debugger/ Programmer

The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a fullspeed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>).

## 38.10 MPLAB PM3 Device Programmer

The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications.