



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, PSMC, PWM, WDT                               |
| Number of I/O              | 35                                                                        |
| Program Memory Size        | 14KB (8K x 14)                                                            |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 1K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                               |
| Data Converters            | A/D 14x12b; D/A 1x8b                                                      |
| 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/pic16f1787-i-ml |

Email: info@E-XFL.COM

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

#### SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED) TABLE 3-12

|      |                        |              |               |                 |                 |                       |                | /          |           |                   |                                 |
|------|------------------------|--------------|---------------|-----------------|-----------------|-----------------------|----------------|------------|-----------|-------------------|---------------------------------|
| Addr | Name                   | Bit 7        | Bit 6         | Bit 5           | Bit 4           | Bit 3                 | Bit 2          | Bit 1      | Bit 0     | Value on POR, BOR | Value on<br>all other<br>Resets |
| Ban  | k 2                    |              |               |                 |                 |                       |                |            |           |                   |                                 |
| 10Ch | LATA                   | PORTA Data L | .atch         |                 |                 |                       |                |            |           | xxxx xxxx         | uuuu uuuu                       |
| 10Dh | LATB                   | PORTB Data L | atch          |                 |                 |                       |                |            |           | xxxx xxxx         | uuuu uuuu                       |
| 10Eh | LATC                   | PORTC Data I | atch          |                 |                 |                       |                |            |           | xxxx xxxx         | uuuu uuuu                       |
| 10Fh | LATD <sup>(3)</sup>    | PORTD Data I | atch          |                 |                 |                       |                |            |           | xxxx xxxx         | uuuu uuuu                       |
| 110h | LATE <sup>(3)</sup>    |              |               |                 |                 | _                     | LATE2          | LATE1      | LATE0     | 111               | 111                             |
| 111h | CM1CON0                | C10N         | C1OUT         | C10E            | C1POL           | C1ZLF                 | C1SP           | C1HYS      | C1SYNC    | 0000 0100         | 0000 0100                       |
| 112h | CM1CON1                | C1INTP       | C1INTN        |                 | C1PCH<2:0>      |                       |                | C1NCH<2:0> |           | 0000 0000         | 0000 0000                       |
| 113h | CM2CON0                | C2ON         | C2OUT         | C2OE            | C2POL           | C2ZLF                 | C2SP           | C2HYS      | C2SYNC    | 0000 0100         | 0000 0100                       |
| 114h | CM2CON1                | C2INTP       | C2INTN        |                 | C2PCH<2:0>      |                       |                | C2NCH<2:0> |           | 0000 0000         | 0000 0000                       |
| 115h | CMOUT                  | _            | _             | _               | _               | MC4OUT <sup>(3)</sup> | MC3OUT         | MC2OUT     | MC1OUT    | 0000              | 0000                            |
| 116h | BORCON                 | SBOREN       | BORFS         | _               | _               | _                     | _              | _          | BORRDY    | 1xq               | uuu                             |
| 117h | FVRCON                 | FVREN        | FVRRDY        | TSEN            | TSRNG           | CDAFV                 | R<1:0>         | ADFV       | R<1:0>    | 0q00 0000         | 0q00 0000                       |
| 118h | DAC1CON0               | DAC1EN       |               | DAC10E1         | DAC10E2         | DAC1PS                | SS<1:0>        |            | DAC1NSS   | 0-00 00-0         | 0-00 00-0                       |
| 119h | DAC1CON1               |              |               |                 | DAC1R           | <7:0>                 |                |            |           | 0000 0000         | 0000 0000                       |
| 11Ah | CM4CON0                | C4ON         | C4OUT         | C4OE            | C4POL           | C4ZLF                 | C4SP           | C4HYS      | C4SYNC    | 0000 0100         | 0000 0100                       |
| 11Bh | CM4CON1                | C4INTP       | C4INTN        | C4PCI           | H<1:0>          | —                     | -              | C4NC       | H<1:0>    | 000000            | 000000                          |
| 11Ch | APFCON2                | —            | _             | -               | —               | _                     | _              | —          | CCP3SEL   | 0                 | 0                               |
| 11Dh | APFCON1                | C2OUTSEL     | CC1PSEL       | SDOSEL          | SCKSEL          | SDISEL                | TXSEL          | RXSEL      | CCP2SEL   | 0000 0000         | 0000 0000                       |
| 11Eh | CM3CON0                | C3ON         | C3OUT         | C3OE            | C3POL           | C3ZLF                 | C3SP           | C3HYS      | C3SYNC    | 0000 0100         | 0000 0100                       |
| 11Fh | CM3CON1                | C3INTP       | C3INTN        |                 | C3PCH<2:0>      | •                     |                | C3NCH<2:0> |           | 0000 0000         | 0000 0000                       |
| Ban  | k 3                    | •            |               |                 |                 |                       |                |            |           |                   |                                 |
| 18Ch | ANSELA                 | ANSA7        | _             | ANSA5           | ANSA4           | ANSA3                 | ANSA2          | ANSA1      | ANSA0     | 1-11 1111         | 1-11 1111                       |
| 18Dh | ANSELB                 | _            | ANSB6         | ANSB5           | ANSB4           | ANSB3                 | ANSB2          | ANSB1      | ANSB0     | -111 1111         | -111 1111                       |
| 18Eh | Unimplemente           | d            |               |                 |                 |                       |                |            | _         | _                 | _                               |
| 18Fh | ANSELD <sup>(3)</sup>  | _            | _             | —               | _               | _                     | ANSD2          | ANSD1      | ANSD0     | 111               | 111                             |
| 190h | ANSELE <sup>(3)</sup>  | _            | _             | _               | —               | _                     | ANSE2          | ANSE1      | ANSE0     | 111               | 111                             |
| 191h | EEADRL                 | EEPROM / Pro | ogram Memor   | y Address Reg   | ister Low Byte  |                       |                |            |           | 0000 0000         | 0000 0000                       |
| 192h | EEADRH                 | (2)          | EEPROM / F    | Program Memor   | ry Address Reg  | ister High Byte       |                |            |           | 1000 0000         | 1000 0000                       |
| 193h | EEDATL                 | EEPROM / Pro | ogram Memor   | y Read Data R   | egister Low Byt | e                     |                |            |           | xxxx xxxx         | uuuu uuuu                       |
| 194h | EEDATH                 | _            | _             | EEPROM / Pro    | ogram Memory    | Read Data Re          | gister High By | te         |           | xx xxxx           | uu uuuu                         |
| 195h | EECON1                 | EEPGD        | CFGS          | LWLO            | FREE            | WRERR                 | WREN           | WR         | RD        | $000x \ 0000$     | 0000 q000                       |
| 196h | EECON2                 | EEPROM / Pro | ogram Memor   | y Control Regis | ster 2          |                       |                |            |           | 0000 0000         | 0000 0000                       |
| 197h | VREGCON <sup>(4)</sup> | —            | _             | —               | —               | —                     | —              | VREGPM     | Reserved  | 01                | 01                              |
| 198h | —                      | Unimplemente | d             |                 |                 |                       |                |            |           | _                 | _                               |
| 199h | RCREG                  | EUSART Rece  | eive Data Reg | ister           |                 |                       |                |            |           | 0000 0000         | 0000 0000                       |
| 19Ah | TXREG                  | EUSART Trans | smit Data Reg | gister          |                 |                       |                |            |           | 0000 0000         | 0000 0000                       |
| 19Bh | SPBRG                  | BRG<7:0>     |               |                 |                 |                       |                |            | 0000 0000 | 0000 0000         |                                 |
| 19Ch | SPBRGH                 |              |               |                 | BRG<            | 15:8>                 |                |            |           | 0000 0000         | 0000 0000                       |
| 19Dh | RCSTA                  | SPEN         | RX9           | SREN            | CREN            | ADDEN                 | FERR           | OERR       | RX9D      | 0000 0000         | 0000 0000                       |
| 19Eh | TXSTA                  | CSRC         | TX9           | TXEN            | SYNC            | SENDB                 | BRGH           | TRMT       | TX9D      | 0000 0010         | 0000 0010                       |
| 19Fh | BAUDCON                | ABDOVF       | RCIDL         |                 | SCKP            | BRG16                 | _              | WUE        | ABDEN     | 01-0 0-00         | 01-0 0-00                       |

x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved. Shaded locations are unimplemented, read as '0'. These registers can be addressed from any bank. Unimplemented, read as '1'. Legend:

1:

2:

PIC16(L)F1784/7 only. 3:

4: PIC16F1784/6/7 only.

Note

| U-0                                                                                      | U-0         | U-0                  | R/W-0/0  | U-0                                                   | U-0 | U-0 | U-0   |  |  |
|------------------------------------------------------------------------------------------|-------------|----------------------|----------|-------------------------------------------------------|-----|-----|-------|--|--|
| —                                                                                        | —           | —                    | CCP3IE   | —                                                     | —   | —   | —     |  |  |
| bit 7                                                                                    |             |                      |          |                                                       |     |     | bit 0 |  |  |
|                                                                                          |             |                      |          |                                                       |     |     |       |  |  |
| Legend:                                                                                  |             |                      |          |                                                       |     |     |       |  |  |
| R = Readable                                                                             | bit         | W = Writable I       | bit      | U = Unimplemented bit, read as '0'                    |     |     |       |  |  |
| u = Bit is uncha                                                                         | anged       | 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-5                                                                                  | Unimplemen  | ted: Read as 'd      | כי       |                                                       |     |     |       |  |  |
| bit 4                                                                                    | CCP3IE: CCF | 3 Interrupt Ena      | able bit |                                                       |     |     |       |  |  |
| <ul><li>1 = Enables the CCP3 interrupt</li><li>0 = Disables the CCP3 interrupt</li></ul> |             |                      |          |                                                       |     |     |       |  |  |
| bit 3-0                                                                                  | Unimplemen  | ted: Read as 'd      | )'       |                                                       |     |     |       |  |  |

## REGISTER 8-4: PIE3: PERIPHERAL INTERRUPT ENABLE REGISTER 3

| Name       | Bit 7   | Bit 6    | Bit 5    | Bit 4    | Bit 3  | Bit 2    | Bit 1    | Bit 0    | Register<br>on Page |
|------------|---------|----------|----------|----------|--------|----------|----------|----------|---------------------|
| INTCON     | GIE     | PEIE     | TMR0IE   | INTE     | IOCIE  | TMR0IF   | INTF     | IOCIF    | 93                  |
| OPTION_REG | WPUEN   | INTEDG   | TMR0CS   | TMR0SE   | PSA    |          | PS<2:0>  |          | 198                 |
| PIE1       | TMR1GIE | ADIE     | RCIE     | TXIE     | SSP1IE | CCP1IE   | TMR2IE   | TMR1IE   | 94                  |
| PIE2       | OSFIE   | C2IE     | C1IE     | EEIE     | BCL1IE | C4IE     | C3IE     | CCP2IE   | 95                  |
| PIE3       | —       | _        | _        | CCP3IE   | _      | —        | _        | —        | 96                  |
| PIE4       | —       | PSMC3TIE | PSMC2TIE | PSMC1TIE | —      | PSMC3SIE | PSMC2SIE | PSMC1SIE | 97                  |
| PIR1       | TMR1GIF | ADIF     | RCIF     | TXIF     | SSP1IF | CCP1IF   | TMR2IF   | TMR1IF   | 98                  |
| PIR2       | OSFIF   | C2IF     | C1IF     | EEIF     | BCL1IF | C4IF     | C3IF     | CCP2IF   | 99                  |
| PIR3       | _       | _        | _        | CCP3IF   | _      | _        | _        | _        | 100                 |
| PIR4       | _       | PSMC3TIF | PSMC2TIF | PSMC1TIF | _      | PSMC3SIF | PSMC2SIF | PSMC1SIF | 101                 |

## TABLE 8-1: SUMMARY OF REGISTERS ASSOCIATED WITH INTERRUPTS

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

## 9.0 POWER-DOWN MODE (SLEEP)

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

Upon entering Sleep mode, the following conditions exist:

- 1. WDT will be cleared but keeps running, if enabled for operation during Sleep.
- 2. PD bit of the STATUS register is cleared.
- 3. TO bit of the STATUS register is set.
- 4. CPU clock is disabled.
- 5. 31 kHz LFINTOSC is unaffected and peripherals that operate from it may continue operation in Sleep.
- 6. Timer1 and peripherals that operate from Timer1 continue operation in Sleep when the Timer1 clock source selected is:
  - LFINTOSC
  - T1CKI
  - Timer1 oscillator
- 7. ADC is unaffected, if the dedicated FRC oscillator is selected.
- I/O ports maintain the status they had before SLEEP was executed (driving high, low or high-impedance).
- 9. Resets other than WDT are not affected by Sleep mode.

Refer to individual chapters for more details on peripheral operation during Sleep.

To minimize current consumption, the following conditions should be considered:

- I/O pins should not be floating
- External circuitry sinking current from I/O pins
- · Internal circuitry sourcing current from I/O pins
- · Current draw from pins with internal weak pull-ups
- Modules using 31 kHz LFINTOSC
- Modules using Timer1 oscillator

I/O pins that are high-impedance inputs should be pulled to VDD or Vss externally to avoid switching currents caused by floating inputs.

Examples of internal circuitry that might be sourcing current include modules such as the DAC and FVR modules. See Section 19.0 "Digital-to-Analog Converter (DAC) Module" and Section 15.0 "Fixed Voltage Reference (FVR)" for more information on these modules.

#### 9.1 Wake-up from Sleep

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

- 1. External Reset input on MCLR pin, if enabled
- 2. BOR Reset, if enabled
- 3. POR Reset
- 4. Watchdog Timer, if enabled
- 5. Any external interrupt
- 6. Interrupts by peripherals capable of running during Sleep (see individual peripheral for more information)

The first three events will cause a device Reset. The last three events are considered a continuation of program execution. To determine whether a device Reset or wake-up event occurred, refer to **Section 5.12 "Determining the Cause of a Reset"**.

When the SLEEP instruction is being executed, the next instruction (PC + 1) is prefetched. For the device to wake-up through an interrupt event, the corresponding interrupt enable bit must be enabled. Wake-up will occur regardless of the state of the GIE bit. If the GIE bit is disabled, the device continues execution at the instruction after the SLEEP instruction. If the GIE bit is enabled, the device executes the instruction after the SLEEP instruction, the device will then call the Interrupt Service Routine. In cases where the execution of the instruction following SLEEP is not desirable, the user should have a NOP after the SLEEP instruction.

The WDT is cleared when the device wakes up from Sleep, regardless of the source of wake-up.

## 13.4 Register Definitions: PORTA

### **REGISTER 13-3: PORTA: PORTA REGISTER**

| R/W-x/x                             | R/W-x/x | R/W-x/x           | R/W-x/x | R/W-x/x                            | R/W-x/x        | R/W-x/x           | R/W-x/x   |
|-------------------------------------|---------|-------------------|---------|------------------------------------|----------------|-------------------|-----------|
| RA7                                 | RA6     | RA5               | RA4     | RA3                                | RA2            | RA1               | RA0       |
| bit 7                               |         |                   |         |                                    |                |                   | bit 0     |
|                                     |         |                   |         |                                    |                |                   |           |
| Legend:                             |         |                   |         |                                    |                |                   |           |
| R = Readable bit W =                |         | W = Writable bit  |         | U = Unimplemented bit, read as '0' |                |                   |           |
| u = Bit is unchanged x = Bit is unk |         |                   | own     | -n/n = Value a                     | t POR and BOR/ | Value at all othe | er Resets |
| '1' = Bit is set                    |         | '0' = Bit is clea | red     |                                    |                |                   |           |

bit 7-0 RA<7:0>: PORTA I/O Value bits<sup>(1)</sup> 1 = Port pin is ≥ VIH 0 = Port pin is ≤ VIL

## REGISTER 13-4: TRISA: PORTA TRI-STATE REGISTER

| R/W-1/1 |
|---------|---------|---------|---------|---------|---------|---------|---------|
| TRISA7  | TRISA6  | TRISA5  | TRISA4  | TRISA3  | TRISA2  | TRISA1  | TRISA0  |
| 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

- TRISA<7:0>: PORTA Tri-State Control bits
  - 1 = PORTA pin configured as an input (tri-stated)

0 = PORTA pin configured as an output

#### REGISTER 13-5: LATA: PORTA DATA LATCH REGISTER

| R/W-x/u |
|---------|---------|---------|---------|---------|---------|---------|---------|
| LATA7   | LATA6   | LATA5   | LATA4   | LATA3   | LATA2   | LATA1   | LATA0   |
| 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-4 LATA<7:0>: PORTA Output Latch Value bits<sup>(1)</sup>

**Note 1:** Writes to PORTA are actually written to corresponding LATA register. Reads from PORTA register is return of actual I/O pin values.

**Note 1:** Writes to PORTA are actually written to corresponding LATA register. Reads from PORTA register is return of actual I/O pin values.

## 17.2 ADC Operation

#### 17.2.1 STARTING A CONVERSION

To enable the ADC module, the ADON bit of the ADCON0 register must be set to a '1'. Setting the GO/DONE bit of the ADCON0 register to a '1' will clear the ADRESH and ADRESL registers and start the Analog-to-Digital conversion.

| Note: | The GO/DONE bit should not be set in the |
|-------|------------------------------------------|
|       | same instruction that turns on the ADC.  |
|       | Refer to Section 17.2.6 "A/D Conversion  |
|       | Procedure".                              |

## 17.2.2 COMPLETION OF A CONVERSION

When the conversion is complete, the ADC module will:

- Clear the GO/DONE bit
- · Set the ADIF Interrupt Flag bit

#### 17.2.3 TERMINATING A CONVERSION

When a conversion is terminated before completion by clearing the GO/DONE bit then the partial results are discarded and the results in the ADRESH and ADRESL registers from the previous conversion remain unchanged.

**Note:** A device Reset forces all registers to their Reset state. Thus, the ADC module is turned off and any pending conversion is terminated.

### 17.2.4 ADC OPERATION DURING SLEEP

The ADC module can operate during Sleep. This requires the ADC clock source to be set to the FRC option. When the FRC oscillator source is selected, the ADC waits one additional instruction before starting the conversion. This allows the SLEEP instruction to be executed, which can reduce system noise during the conversion. If the ADC interrupt is enabled, the device will wake-up from Sleep when the conversion completes. If the ADC interrupt is disabled, the ADC module is turned off after the conversion completes, although the ADON bit remains set.

When the ADC clock source is something other than FRC, a SLEEP instruction causes the present conversion to be aborted and the ADC module is turned off, although the ADON bit remains set.

## 17.2.5 AUTO-CONVERSION TRIGGER

The Auto-conversion Trigger allows periodic ADC measurements without software intervention. When a rising edge of the selected source occurs, the GO/DONE bit is set by hardware.

The Auto-conversion Trigger source is selected with the TRIGSEL<3:0> bits of the ADCON2 register.

Using the Auto-conversion Trigger does not assure proper ADC timing. It is the user's responsibility to ensure that the ADC timing requirements are met.

Auto-conversion sources are:

- CCP1
- CCP2
- CCP3
- PSMC1<sup>(1)</sup>
- PSMC2<sup>(1)</sup>

Note: The PSMC clock frequency, after the prescaler, must be less than Fosc/4 to ensure that the ADC detects the auto-conversion trigger. This limitation can be overcome by synchronizing a slave PSMC, running at the required slower clock frequency, to the first PSMC and triggering the conversion from the slave PSMC.

PSMC3

## 20.3 Comparator Hysteresis

A selectable amount of separation voltage can be added to the input pins of each comparator to provide a hysteresis function to the overall operation. Hysteresis is enabled by setting the CxHYS bit of the CMxCON0 register.

See **Section 30.0 "Electrical Specifications"** for more information.

## 20.4 Timer1 Gate Operation

The output resulting from a comparator operation can be used as a source for gate control of Timer1. See **Section 22.6 "Timer1 Gate"** for more information. This feature is useful for timing the duration or interval of an analog event.

It is recommended that the comparator output be synchronized to Timer1. This ensures that Timer1 does not increment while a change in the comparator is occurring.

#### 20.4.1 COMPARATOR OUTPUT SYNCHRONIZATION

The output from a comparator can be synchronized with Timer1 by setting the CxSYNC bit of the CMx-CON0 register.

Once enabled, the comparator output is latched on the falling edge of the Timer1 source clock. If a prescaler is used with Timer1, the comparator output is latched after the prescaling function. To prevent a race condition, the comparator output is latched on the falling edge of the Timer1 clock source and Timer1 increments on the rising edge of its clock source. See the Comparator Block Diagram (Figure 20-2) and the Timer1 Block Diagram (Figure 22-1) for more information.

## 20.5 Comparator Interrupt

An interrupt can be generated upon a change in the output value of the comparator for each comparator, a rising edge detector and a falling edge detector are present.

When either edge detector is triggered and its associated enable bit is set (CxINTP and/or CxINTN bits of the CMxCON1 register), the Corresponding Interrupt Flag bit (CxIF bit of the PIR2 register) will be set.

To enable the interrupt, you must set the following bits:

- CxON, CxPOL and CxSP bits of the CMxCON0 register
- CxIE bit of the PIE2 register
- CxINTP bit of the CMxCON1 register (for a rising edge detection)
- CxINTN bit of the CMxCON1 register (for a falling edge detection)
- · PEIE and GIE bits of the INTCON register

The associated interrupt flag bit, CxIF bit of the PIR2 register, must be cleared in software. If another edge is detected while this flag is being cleared, the flag will still be set at the end of the sequence.

## 20.6 Comparator Positive Input Selection

Configuring the CxPCH<2:0> bits of the CMxCON1 register directs an internal voltage reference or an analog pin to the non-inverting input of the comparator:

- CxIN+ analog pin
- DAC output
- FVR (Fixed Voltage Reference)
- Vss (Ground)

See Section 15.0 "Fixed Voltage Reference (FVR)" for more information on the Fixed Voltage Reference module.

See Section 19.0 "Digital-to-Analog Converter (DAC) Module" for more information on the DAC input signal.

Any time the comparator is disabled (CxON = 0), all comparator inputs are disabled.

**Note:** Although a comparator is disabled, an interrupt can be generated by changing the output polarity with the CxPOL bit of the CMxCON0 register, or by switching the comparator on or off with the CxON bit of the CMxCON0 register.

### 24.3.5 PUSH-PULL PWM WITH FOUR FULL-BRIDGE OUTPUTS

The full-bridge push-pull PWM is used to drive transistor bridge circuits as well as synchronous switches on the secondary side of the bridge.

- 24.3.5.1 Mode Features
- No Dead-band control
- No Steering control available
- PWM is output on the following four pins only:
  - PSMCxA
  - PSMCxB
  - PSMCxC
  - PSMCxD

Note: PSMCxA and PSMCxC are identical waveforms, and PSMCxB and PSMCxD are identical waveforms. Note: This is a subset of the 6-pin output of the push-pull PWM output, which is why pin functions are fixed in these positions, so they are compatible with that mode. See Section 24.3.6 "Push-Pull PWM with Four Full-Bridge and Complementary Outputs".

## 24.3.5.2 Waveform generation

Push-pull waveforms generate alternating outputs on the output pairs. Therefore, there are two sets of rising edge events and two sets of falling edge events.

Odd numbered period rising edge event:

PSMCxOUT0 and PSMCxOUT2 is set active

Odd numbered period falling edge event:

- PSMCxOUT0 and PSMCxOUT2 is set inactive
- Even numbered period rising edge event:
- PSMCxOUT1 and PSMCxOUT3 is set active
- Even numbered period falling edge event:
- PSMCxOUT1 and PSMCxOUT3 is set inactive

### FIGURE 24-8: PUSH-PULL PWM WITH 4 FULL-BRIDGE OUTPUTS

| PWM Period Number  | 1 | 2 | 3 |
|--------------------|---|---|---|
| Period Event       |   |   |   |
| Rising Edge Event  |   |   |   |
| Falling Edge Event |   |   |   |
| PSMCxA             |   |   |   |
| PSMCxC             |   |   |   |
| PSMCxB             |   |   |   |
| PSMCxD             |   |   |   |

## 24.10 Register Updates

There are 10 double-buffered registers that can be updated "on the fly". However, due to the asynchronous nature of the potential updates, a special hardware system is used for the updates.

There are two operating cases for the PSMC:

- module is enabled
- · module is disabled

#### 24.10.1 DOUBLE BUFFERED REGISTERS

The double-buffered registers that are affected by the special hardware update system are:

- PSMCxPRL
- PSMCxPRH
- PSMCxDCL
- PSMCxDCH
- PSMCxPHL
- PSMCxPHH
- PSMCxDBR
- PSMCxDBF
- PSMCxBLKR
- PSMCxBLKF
- PSMCxSTR0 (when the PxSSYNC bit is set)

#### 24.10.2 MODULE DISABLED UPDATES

When the PSMC module is disabled (PSMCxEN = 0), any write to one of the buffered registers will also write directly to the buffer. This means that all buffers are loaded and ready for use when the module is enabled.

#### 24.10.3 MODULE ENABLED UPDATES

When the PSMC module is enabled (PSMCxEN = 1), the PSMCxLD bit of the PSMC Control (PSMCxCON) register (Register 24-1) must be used.

When the PSMCxLD bit is set, the transfer from the register to the buffer occurs on the next period event. The PSMCxLD bit is automatically cleared by hardware after the transfer to the buffers is complete.

The reason that the PSMCxLD bit is required is that depending on the customer application and operation conditions, all 10 registers may not be updated in one PSMC period. If the buffers are loaded at different times (i.e., DCL gets updated, but DCH does not OR DCL and DCL are updated by PRH and PRL are not), then unintended operation may occur.

The sequence for loading the buffer registers when the PSMC module is enabled is as follows:

- 1. Software updates all registers.
- 2. Software sets the PSMCxLD bit.
- 3. Hardware updates all buffers on the next period event.
- 4. Hardware clears PSMCxLD bit.

## 24.11 Operation During Sleep

The PSMC continues to operate in Sleep with the following clock sources:

- Internal 64 MHz
- External clock

### REGISTER 24-31: PSMCxSTR0: PSMC STEERING CONTROL REGISTER 0

| bit 1 | PxSTRB: PWM Steering PSMCxB Output Enable bit                                                                                                                                                                                      |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | If PxMODE<3:0> = 0000 (Single-phase PWM):1 = Single PWM output is active on pin PSMCxOUT10 = Single PWM output is not active on pin PSMCxOUT1. PWM drive is in inactive state                                                      |
|       | <u>If PxMODE&lt;3:0&gt; = 0001 (Complementary Single-phase PWM):</u><br>1 = Complementary PWM output is active on pin PSMCxB<br>0 = Complementary PWM output is not active on pin PSMCxB. PWM drive is in inactive state           |
|       | IF PxMODE<3:0> = 1100 (3-phase Steering):(1)1 = PSMCxA and PSMCxF are high. PSMCxB, PMSCxC, PSMCxD and PMSCxE are low.0 = 3-phase output combination is not active                                                                 |
| bit 0 | PxSTRA: PWM Steering PSMCxA Output Enable bit<br>If PxMODE<3:0> = 000x (Single-phase PWM or Complementary PWM):                                                                                                                    |
|       | <ul> <li>Single PWM output is active on pin PSMCxA</li> <li>Single PWM output is not active on pin PSMCxA. PWM drive is in inactive state</li> </ul>                                                                               |
|       | <ul> <li><u>IF PxMODE&lt;3:0&gt; = 1100 (3-phase Steering)</u>:<sup>(1)</sup></li> <li>1 = PSMCxA and PSMCxD are high. PSMCxB, PMSCxC, PSMCxE and PMSCxF are low.</li> <li>0 = 3-phase output combination is not active</li> </ul> |

- **Note 1:** In 3-phase Steering mode, only one PSTRx bit should be set at a time. If more than one is set, then the lowest bit number steering combination has precedence.
  - **2:** These bits are not implemented on PSMC2.

#### 26.6.4 I<sup>2</sup>C MASTER MODE START CONDITION TIMING

To initiate a Start condition, the user sets the Start Enable bit, SEN bit of the SSPCON2 register. If the SDA and SCL pins are sampled high, the Baud Rate Generator is reloaded with the contents of SSPADD<7:0> and starts its count. If SCL and SDA are both sampled high when the Baud Rate Generator times out (TBRG), the SDA pin is driven low. The action of the SDA being driven low while SCL is high is the Start condition and causes the S bit of the SSPSTAT1 register to be set. Following this, the Baud Rate Generator is reloaded with the contents of SSPADD<7:0> and resumes its count. When the Baud Rate Generator times out (TBRG), the SEN bit of the SSPCON2 register will be automatically cleared by hardware; the Baud Rate Generator is suspended, leaving the SDA line held low and the Start condition is complete.

the SDA and SCL pins are already sampled low, or if during the Start condition, the SCL line is sampled low before the SDA line is driven low, a bus collision occurs, the Bus Collision Interrupt Flag, BCL1IF, is set, the Start condition is aborted and the I<sup>2</sup>C module is reset into its Idle state.

Note 1: If at the beginning of the Start condition,

2: The Philips I<sup>2</sup>C specification states that a bus collision cannot occur on a Start.

### FIGURE 26-26: FIRST START BIT TIMING



### REGISTER 26-1: SSPSTAT: SSP STATUS REGISTER (CONTINUED)

bit 0

BF: Buffer Full Status bit

Receive (SPI and I<sup>2</sup>C modes):

1 = Receive complete, SSPBUF is full

0 = Receive not complete, SSPBUF is empty

Transmit (I<sup>2</sup>C mode only):

- 1 = Data transmit in progress (does not include the ACK and Stop bits), SSPBUF is full
- 0 = Data transmit complete (does not include the  $\overline{ACK}$  and Stop bits), SSPBUF is empty

### 27.4.1 AUTO-BAUD DETECT

The EUSART module supports automatic detection and calibration of the baud rate.

In the Auto-Baud Detect (ABD) mode, the clock to the BRG is reversed. Rather than the BRG clocking the incoming RX signal, the RX signal is timing the BRG. The Baud Rate Generator is used to time the period of a received 55h (ASCII "U") which is the Sync character for the LIN bus. The unique feature of this character is that it has five rising edges including the Stop bit edge.

Setting the ABDEN bit of the BAUDCON register starts the auto-baud calibration sequence (Figure 27-6). While the ABD sequence takes place, the EUSART state machine is held in idle. On the first rising edge of the receive line, after the Start bit, the SPBRG begins counting up using the BRG counter clock as shown in Table 27-6. The fifth rising edge will occur on the RX pin at the end of the eighth bit period. At that time, an accumulated value totaling the proper BRG period is left in the SPBRGH, SPBRGL register pair, the ABDEN bit is automatically cleared and the RCIF interrupt flag is set. The value in the RCREG needs to be read to clear the RCIF interrupt. RCREG content should be discarded. When calibrating for modes that do not use the SPBRGH register the user can verify that the SPBRGL register did not overflow by checking for 00h in the SPBRGH register.

The BRG auto-baud clock is determined by the BRG16 and BRGH bits as shown in Table 27-6. During ABD, both the SPBRGH and SPBRGL registers are used as a 16-bit counter, independent of the BRG16 bit setting. While calibrating the baud rate period, the SPBRGH and SPBRGL registers are clocked at 1/8th the BRG base clock rate. The resulting byte measurement is the average bit time when clocked at full speed.

- Note 1: If the WUE bit is set with the ABDEN bit, auto-baud detection will occur on the byte following the Break character (see Section 27.4.3 "Auto-Wake-up on Break").
  - 2: It is up to the user to determine that the incoming character baud rate is within the range of the selected BRG clock source. Some combinations of oscillator frequency and EUSART baud rates are not possible.
  - 3: During the auto-baud process, the auto-baud counter starts counting at 1. Upon completion of the auto-baud sequence, to achieve maximum accuracy, subtract 1 from the SPBRGH:SPBRGL register pair.

#### TABLE 27-6: BRG COUNTER CLOCK RATES

| BRG16 | BRGH | BRG Base<br>Clock | BRG ABD<br>Clock |  |  |
|-------|------|-------------------|------------------|--|--|
| 0     | 0    | Fosc/64           | Fosc/512         |  |  |
| 0     | 1    | Fosc/16           | Fosc/128         |  |  |
| 1     | 0    | Fosc/16           | Fosc/128         |  |  |
| 1     | 1    | Fosc/4            | Fosc/32          |  |  |

**Note:** During the ABD sequence, SPBRGL and SPBRGH registers are both used as a 16-bit counter, independent of BRG16 setting.

#### 0000h XXXXh 001Ch **BRG** Value Edge #5 Edge #1 Edge #2 Edge #3 Edge #4 bit 0 bit 1 bit 2 bit 3 bit 4 bit 5 bit 6 bit 7 RX pin Start Stop bit Auto Cleared Set by User ABDEN bit RCIDL RCIF bit (Interrupt) Read RCREG SPBRGL XXh 1Ch XXh 00h SPBRGH Note 1: The ABD sequence requires the EUSART module to be configured in Asynchronous mode.

#### FIGURE 27-6: AUTOMATIC BAUD RATE CALIBRATION

## 27.5 EUSART Synchronous Mode

Synchronous serial communications are typically used in systems with a single master and one or more slaves. The master device contains the necessary circuitry for baud rate generation and supplies the clock for all devices in the system. Slave devices can take advantage of the master clock by eliminating the internal clock generation circuitry.

There are two signal lines in Synchronous mode: a bidirectional data line and a clock line. Slaves use the external clock supplied by the master to shift the serial data into and out of their respective receive and transmit shift registers. Since the data line is bidirectional, synchronous operation is half-duplex only. Half-duplex refers to the fact that master and slave devices can receive and transmit data but not both simultaneously. The EUSART can operate as either a master or slave device.

Start and Stop bits are not used in synchronous transmissions.

#### 27.5.1 SYNCHRONOUS MASTER MODE

The following bits are used to configure the EUSART for synchronous master operation:

- SYNC = 1
- CSRC = 1
- SREN = 0 (for transmit); SREN = 1 (for receive)
- CREN = 0 (for transmit); CREN = 1 (for receive)
- SPEN = 1

Setting the SYNC bit of the TXSTA register configures the device for synchronous operation. Setting the CSRC bit of the TXSTA register configures the device as a master. Clearing the SREN and CREN bits of the RCSTA register ensures that the device is in the Transmit mode, otherwise the device will be configured to receive. Setting the SPEN bit of the RCSTA register enables the EUSART.

## 27.5.1.1 Master Clock

Synchronous data transfers use a separate clock line, which is synchronous with the data. A device configured as a master transmits the clock on the TX/CK line. The TX/CK pin output driver is automatically enabled when the EUSART is configured for synchronous transmit or receive operation. Serial data bits change on the leading edge to ensure they are valid at the trailing edge of each clock. One clock cycle is generated for each data bit. Only as many clock cycles are generated as there are data bits.

#### 27.5.1.2 Clock Polarity

A clock polarity option is provided for Microwire compatibility. Clock polarity is selected with the SCKP bit of the BAUDCON register. Setting the SCKP bit sets the clock Idle state as high. When the SCKP bit is set, the data changes on the falling edge of each clock. Clearing the SCKP bit sets the Idle state as low. When the SCKP bit is cleared, the data changes on the rising edge of each clock.

### 27.5.1.3 Synchronous Master Transmission

Data is transferred out of the device on the RX/DT pin. The RX/DT and TX/CK pin output drivers are automatically enabled when the EUSART is configured for synchronous master transmit operation.

A transmission is initiated by writing a character to the TXREG register. If the TSR still contains all or part of a previous character the new character data is held in the TXREG until the last bit of the previous character has been transmitted. If this is the first character, or the previous character has been completely flushed from the TSR, the data in the TXREG is immediately transferred to the TSR. The transmission of the character commences immediately following the transfer of the data to the TSR from the TXREG.

Each data bit changes on the leading edge of the master clock and remains valid until the subsequent leading clock edge.

Note: The TSR register is not mapped in data memory, so it is not available to the user.

- 27.5.1.4 Synchronous Master Transmission Set-up:
- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 27.4 "EUSART Baud Rate Generator (BRG)").
- 2. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 3. Disable Receive mode by clearing bits SREN and CREN.
- 4. Enable Transmit mode by setting the TXEN bit.
- 5. If 9-bit transmission is desired, set the TX9 bit.
- If interrupts are desired, set the TXIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 7. If 9-bit transmission is selected, the ninth bit should be loaded in the TX9D bit.
- 8. Start transmission by loading data to the TXREG register.

| ΜΟΥΨΙ      | Move W to INDFn                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syntax:    | [ <i>label</i> ] MOVWI ++FSRn<br>[ <i>label</i> ] MOVWIFSRn<br>[ <i>label</i> ] MOVWI FSRn++<br>[ <i>label</i> ] MOVWI FSRn<br>[ <i>label</i> ] MOVWI k[FSRn]                                                                                                                                                                                                                                                   |
| Operands:  | $\begin{array}{l} n \in [0,1] \\ mm \in [00,01,10,11] \\ -32 \leq k \leq 31 \end{array}$                                                                                                                                                                                                                                                                                                                        |
| Operation: | $\label{eq:states} \begin{array}{l} W \rightarrow INDFn \\ Effective \ address \ is \ determined \ by \\ \bullet \ FSR + 1 \ (preincrement) \\ \bullet \ FSR - 1 \ (predecrement) \\ \bullet \ FSR + k \ (relative \ offset) \\ After \ the \ Move, \ the \ FSR \ value \ will \\ be \ either: \\ \bullet \ FSR + 1 \ (all \ increments) \\ \bullet \ FSR - 1 \ (all \ decrements) \\ Unchanged \\ \end{array}$ |

| Status | Affected. | None |
|--------|-----------|------|
| olulus | / moolou. |      |

| Mode          | Syntax | mm |
|---------------|--------|----|
| Preincrement  | ++FSRn | 00 |
| Predecrement  | FSRn   | 01 |
| Postincrement | FSRn++ | 10 |
| Postdecrement | FSRn   | 11 |

Description:

This instruction is used to move data between W and one of the indirect registers (INDFn). Before/ after this move, the pointer (FSRn) is updated by pre/post incrementing/decrementing it.

**Note:** The INDFn registers are not physical registers. Any instruction that accesses an INDFn register actually accesses the register at the address specified by the FSRn.

FSRn is limited to the range 0000h - FFFFh. Incrementing/ decrementing it beyond these bounds will cause it to wraparound.

The increment/decrement operation on FSRn WILL NOT affect any Status bits.

| NOP              | No Operation  |  |  |  |
|------------------|---------------|--|--|--|
| Syntax:          | [label] NOP   |  |  |  |
| Operands:        | None          |  |  |  |
| Operation:       | No operation  |  |  |  |
| Status Affected: | None          |  |  |  |
| Description:     | No operation. |  |  |  |
| Words:           | 1             |  |  |  |
| Cycles:          | 1             |  |  |  |
| Example:         | NOP           |  |  |  |

| OPTION           | Load OPTION_REG Register<br>with W                   |  |  |  |  |
|------------------|------------------------------------------------------|--|--|--|--|
| Syntax:          | [label] OPTION                                       |  |  |  |  |
| Operands:        | None                                                 |  |  |  |  |
| Operation:       | $(W) \rightarrow OPTION\_REG$                        |  |  |  |  |
| Status Affected: | None                                                 |  |  |  |  |
| Description:     | Move data from W register to<br>OPTION_REG register. |  |  |  |  |

| RESET            | Software Reset                                                           |  |  |
|------------------|--------------------------------------------------------------------------|--|--|
| Syntax:          | [label] RESET                                                            |  |  |
| Operands:        | None                                                                     |  |  |
| Operation:       | Execute a device Reset. Resets the RI flag of the PCON register.         |  |  |
| Status Affected: | None                                                                     |  |  |
| Description:     | This instruction provides a way to execute a hardware Reset by software. |  |  |

| TRIS             | Load TRIS Register with W                                                                                                                            |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [label] TRIS f                                                                                                                                       |  |  |  |  |
| Operands:        | $5 \leq f \leq 7$                                                                                                                                    |  |  |  |  |
| Operation:       | (W) $\rightarrow$ TRIS register 'f'                                                                                                                  |  |  |  |  |
| Status Affected: | None                                                                                                                                                 |  |  |  |  |
| Description:     | Move data from W register to<br>TRIS register.<br>When 'f' = 5, TRISA is loaded.<br>When 'f' = 6, TRISB is loaded.<br>When 'f' = 7, TRISC is loaded. |  |  |  |  |

| XORLW            | Exclusive OR literal with W                                                                                            |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] XORLW k                                                                                               |  |  |  |  |
| Operands:        | $0 \leq k \leq 255$                                                                                                    |  |  |  |  |
| Operation:       | (W) .XOR. $k \rightarrow (W)$                                                                                          |  |  |  |  |
| Status Affected: | Z                                                                                                                      |  |  |  |  |
| Description:     | The contents of the W register<br>are XOR'ed with the 8-bit<br>literal 'k'. The result is placed in<br>the W register. |  |  |  |  |

| XORWF            | Exclusive OR W with f                                                                                                                                                           |  |  |  |  |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Syntax:          | [ <i>label</i> ] XORWF f,d                                                                                                                                                      |  |  |  |  |
| Operands:        | $0 \le f \le 127$<br>$d \in [0,1]$                                                                                                                                              |  |  |  |  |
| Operation:       | (W) .XOR. (f) $\rightarrow$ (destination)                                                                                                                                       |  |  |  |  |
| Status Affected: | Z                                                                                                                                                                               |  |  |  |  |
| Description:     | Exclusive OR 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'. |  |  |  |  |

## TABLE 30-17: DIGITAL-TO-ANALOG CONVERTER (DAC) SPECIFICATIONS

| <b>Operating Conditions:</b> VDD = 3V, Temperature = 25°C (unless otherwise stated). |                                              |                              |   |         |       |     |  |  |
|--------------------------------------------------------------------------------------|----------------------------------------------|------------------------------|---|---------|-------|-----|--|--|
| Param<br>No.                                                                         | Sym.CharacteristicsMin.Typ.Max.UnitsComments |                              |   |         |       |     |  |  |
| DAC01*                                                                               | CLSB                                         | Step Size                    | _ | VDD/256 |       | V   |  |  |
| DAC02*                                                                               | CACC                                         | Absolute Accuracy            | — | —       | ± 1.5 | LSb |  |  |
| DAC03*                                                                               | CR                                           | Unit Resistor Value (R)      | _ | 600     | _     | Ω   |  |  |
| DAC04*                                                                               | CST                                          | Settling Time <sup>(1)</sup> | _ | —       | 10    | μS  |  |  |

\* These parameters are characterized but not tested.

**Note 1:** Settling time measured while DACR<7:0> transitions from '0x00' to '0xFF'.

#### FIGURE 30-14: EUSART SYNCHRONOUS TRANSMISSION (MASTER/SLAVE) TIMING



### TABLE 30-18: EUSART SYNCHRONOUS TRANSMISSION REQUIREMENTS

| Standard Operating Conditions (unless otherwise stated) |               |                                   |          |      |      |       |            |
|---------------------------------------------------------|---------------|-----------------------------------|----------|------|------|-------|------------|
| Param.<br>No.                                           | Symbol        | Characteristic                    |          | Min. | Max. | Units | Conditions |
| US120                                                   | TCKH2DTV      | SYNC XMIT (Master and Slave)      | 3.0-5.5V | —    | 80   | ns    |            |
|                                                         |               | Clock high to data-out valid      | 1.8-5.5V |      | 100  | ns    |            |
| US121                                                   | TCKRF         | Clock out rise time and fall time | 3.0-5.5V | _    | 45   | ns    |            |
|                                                         | (Master mode) | 1.8-5.5V                          | _        | 50   | ns   |       |            |
| US122                                                   | TDTRF         | Data-out rise time and fall time  | 3.0-5.5V |      | 45   | ns    |            |
|                                                         |               |                                   | 1.8-5.5V | _    | 50   | ns    |            |

## FIGURE 30-15: EUSART SYNCHRONOUS RECEIVE (MASTER/SLAVE) TIMING



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



**FIGURE 31-109:** Op Amp, Output Voltage Histogram, VDD = 3.0V, VCM = VDD/2.



**FIGURE 31-110:** Op Amp, Offset Over Common Mode Voltage, VDD = 3.0V, Temp. = 25°C.



**FIGURE 31-111:** Op Amp, Offset Over Common Mode Voltage, VDD = 5.0V, Temp. = 25°C, PIC16F1784/6/7 Only.



FIGURE 31-113: Op Amp, Output Slew Rate, Falling Edge, PIC16LF1784/6/7 Only.



FIGURE 31-112: Op Amp, Output Slew Rate, Rising Edge, PIC16LF1784/6/7 Only.



FIGURE 31-114: Op Amp, Output Slew Rate, Rising Edge, PIC16F1784/6/7 Only.

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



FIGURE 31-115: Op Amp, Output Slew Rate, Falling Edge, PIC16F1784/6/7 Only.



**FIGURE 31-116:** Comparator Hysteresis, NP Mode (CxSP = 1), VDD = 3.0V, Typical Measured Values.



**FIGURE 31-117:** Comparator Offset, NP Mode (CxSP = 1), VDD = 3.0V, Typical Measured Values at 25°C.



**FIGURE 31-118:** Comparator Offset, NP Mode (CxSP = 1), VDD = 3.0V, Typical Measured Values From -40°C to 125°C.



**FIGURE 31-119:** Comparator Hysteresis, NP Mode (CxSP = 1), VDD = 5.5V, Typical Measured Values, PIC16F1784/6/7 Only.



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



Microchip Technology Drawing C04-103C Sheet 1 of 2