



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        | 28KB (16K × 14)                                                           |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | 256 x 8                                                                   |
| RAM Size                   | 2K x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 2.3V ~ 5.5V                                                               |
| Data Converters            | A/D 14x12b; D/A 1x8b, 3x5b                                                |
| 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/pic16f1789-i-mv |

Email: info@E-XFL.COM

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

# **PIN ALLOCATION TABLE**

| TAB | ABLE 1: 28-PIN ALLOCATION TABLE (PIC16(L)F1788) |             |      |                                                           |                                      |                         |                                              |                |                                              |                     |                                        |                                          |            |         |                        |
|-----|-------------------------------------------------|-------------|------|-----------------------------------------------------------|--------------------------------------|-------------------------|----------------------------------------------|----------------|----------------------------------------------|---------------------|----------------------------------------|------------------------------------------|------------|---------|------------------------|
| 0/1 | 28-Pin SPDIP,<br>SOIC, SSOP                     | 28-Pin QFN, | ADC  | Reference                                                 | Comparator                           | Operation<br>Amplifiers | 8-bit/<br>5-bit DAC                          | Timers         | PSMC                                         | ссь                 | EUSART                                 | MSSP                                     | Interrupt  | dn-lluq | Basic                  |
| RA0 | 2                                               | 27          | AN0  | —                                                         | C1IN0-<br>C2IN0-<br>C3IN0-<br>C4IN0- | —                       | —                                            | _              | —                                            | _                   | _                                      | <u>SS</u> (1)                            | IOC        | Y       | _                      |
| RA1 | 3                                               | 28          | AN1  | _                                                         | C1IN1-<br>C2IN1-<br>C3IN1-<br>C4IN1- | OPA1OUT                 | _                                            | _              | _                                            |                     |                                        |                                          | IOC        | Y       | _                      |
| RA2 | 4                                               | 1           | AN2  | VREF-<br>DAC1VREF-                                        | C1IN0+<br>C2IN0+<br>C3IN0+<br>C4IN0+ |                         | DAC1OUT1                                     | _              | _                                            | _                   | _                                      | _                                        | IOC        | Y       | _                      |
| RA3 | 5                                               | 2           | AN3  | VREF+<br>DAC1VREF+<br>DAC2VREF+<br>DAC3VREF+<br>DAC4VREF+ | C1IN1+                               | _                       | _                                            | _              | _                                            | _                   | _                                      | _                                        | IOC        | Y       | _                      |
| RA4 | 6                                               | 3           | —    | —                                                         | C10UT                                | OPA1IN+                 | DAC4OUT1                                     | TOCKI          | -                                            | —                   | —                                      | —                                        | IOC        | Υ       | —                      |
| RA5 | 7                                               | 4           | AN4  | _                                                         | C2OUT                                | OPA1IN-                 | DAC2OUT1                                     | _              | -                                            | -                   | _                                      | SS                                       | IOC        | Υ       | _                      |
| RA6 | 10                                              | 7           | _    | -                                                         | C2OUT <sup>(1)</sup>                 | _                       | -                                            | —              | -                                            | _                   | _                                      | _                                        | IOC        | Y       | VCAP<br>OSC2<br>CLKOUT |
| RA7 | 9                                               | 6           | _    | _                                                         | _                                    | _                       | _                                            | _              | PSMC1CLK<br>PSMC2CLK<br>PSMC3CLK<br>PSMC4CLK | _                   | _                                      | _                                        | IOC        | Y       | CLKIN<br>OSC1          |
| RB0 | 21                                              | 18          | AN12 | _                                                         | C2IN1+                               | _                       | _                                            | —              | PSMC1IN<br>PSMC2IN<br>PSMC3IN<br>PSMC4IN     | CCP1 <sup>(1)</sup> | _                                      | —                                        | INT<br>IOC | Y       | —                      |
| RB1 | 22                                              | 19          | AN10 | _                                                         | C1IN3-<br>C2IN3-<br>C3IN3-<br>C4IN3- | OPA2OUT                 | _                                            | —              | _                                            |                     |                                        | —                                        | IOC        | Y       | _                      |
| RB2 | 23                                              | 20          | AN8  | —                                                         | _                                    | OPA2IN-                 | DAC3OUT1                                     | _              | —                                            |                     |                                        | —                                        | IOC        | Υ       | CLKR                   |
| RB3 | 24                                              | 21          | AN9  | _                                                         | C1IN2-<br>C2IN2-<br>C3IN2-           | OPA2IN+                 | _                                            | —              | _                                            | CCP2 <sup>(1)</sup> | _                                      | _                                        | IOC        | Y       | _                      |
| RB4 | 25                                              | 22          | AN11 | —                                                         | C3IN1+                               | —                       | -                                            | _              | —                                            | -                   |                                        | SS <sup>(1)</sup>                        | IOC        | Υ       | -                      |
| RB5 | 26                                              | 23          | AN13 | _                                                         | C4IN2-<br>C3OUT                      | _                       | _                                            | T1G            | _                                            | CCP3 <sup>(1)</sup> |                                        | SDO <sup>(1)</sup>                       | IOC        | Y       | _                      |
| RB6 | 27                                              | 24          |      | _                                                         | C4IN1+                               | _                       | _                                            | _              | _                                            | _                   | CK <sup>(1)</sup>                      | SDA <sup>(1)</sup>                       | IOC        | Y       | ICSPCLK                |
| RB7 | 28                                              | 25          |      | —                                                         | —                                    | —                       | DAC1OUT2<br>DAC2OUT2<br>DAC3OUT2<br>DAC4OUT2 | _              | —                                            |                     | RX <sup>(1)</sup><br>DT <sup>(1)</sup> | SCK <sup>(1)</sup><br>SCL <sup>(1)</sup> | IOC        | Y       | ICSPDAT                |
| RC0 | 11                                              | 8           | -    | -                                                         | —                                    | —                       | —                                            | T1CKI<br>T1OSO | PSMC1A                                       | —                   | -                                      | —                                        | IOC        | Y       | —                      |
| RC1 | 12                                              | 9           | _    | —                                                         | —                                    | —                       | —                                            | T10SI          | PSMC1B                                       | CCP2                | _                                      |                                          | IOC        | Y       | —                      |
| RC2 | 13                                              | 10          | _    | _                                                         | —                                    | —                       | —                                            | —              | PSMC1C<br>PSMC3B                             | CCP1                | _                                      | -                                        | 100        | Y       | —                      |
| RC3 | 14                                              | 11          | _    | _                                                         | _                                    | _                       | _                                            | _              | PSMC1D<br>PSMC4A                             | _                   | _                                      | SCK<br>SCL                               |            | Y       | _                      |
| RC4 | 15                                              | 12          | _    | _                                                         | —                                    | —                       | _                                            | _              | PSMC1E<br>PSMC4B                             | —                   | _                                      | SDI<br>SDA                               |            | Y       | _                      |
| RC5 | 16                                              | 13          | _    | _                                                         | _                                    | _                       | _                                            | _              | PSMC1F<br>PSMC3A                             |                     |                                        | 500                                      | IUC        | Y       | _                      |

| TARI F 1. | 28-PIN ALLOCATION TABLE (PIC16(L)E1788) |
|-----------|-----------------------------------------|
| IADLL I.  | 20-FIN ALLOCATION TABLE (FIGTOLE) 17001 |

Note 1: Alternate pin function selected with the APFCON1 (Register 13-1) and APFCON2 (Register 13-2) registers.

# TABLE 3-6:PIC16(L)F1788/9 MEMORYMAP (BANK 10 DETAILS)



Note 1: PIC16(L)F1789 only.

# TABLE 3-7:PIC16(L)F1788/9 MEMORYMAP (BANK 11 DETAILS)

| BANK 11                                                                                                        |                                |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------|--------------------------------|--|--|--|--|--|--|
| 58Ch                                                                                                           |                                |  |  |  |  |  |  |
|                                                                                                                | Unimplemented<br>Read as '0'   |  |  |  |  |  |  |
| 590h                                                                                                           |                                |  |  |  |  |  |  |
| 591h                                                                                                           | DAC2CON0                       |  |  |  |  |  |  |
| 592h                                                                                                           | DAC2CON1                       |  |  |  |  |  |  |
| 593h                                                                                                           | DAC3CON0                       |  |  |  |  |  |  |
| 594h                                                                                                           | DAC3CON1                       |  |  |  |  |  |  |
| 595h                                                                                                           | DAC4CON0                       |  |  |  |  |  |  |
| 596h                                                                                                           | DAC4CON1                       |  |  |  |  |  |  |
| 597h                                                                                                           |                                |  |  |  |  |  |  |
|                                                                                                                | Unimplemented<br>Read as '0'   |  |  |  |  |  |  |
| 59Fh                                                                                                           |                                |  |  |  |  |  |  |
| and a second | — I halasa baasa anta di alata |  |  |  |  |  |  |

Legend: Unimplemented data memory locations, read as '0'.

# TABLE 3-8:PIC16(L)F1788/9 MEMORYMAP (BANK 31 DETAILS)

BANK 31

| F8Ch<br>FE3h | Unimplemented<br>Read as '0' |
|--------------|------------------------------|
| FE4h         | STATUS_SHAD                  |
| FE5h         | WREG_SHAD                    |
| FE6h         | BSR_SHAD                     |
| FE7h         | PCLATH_SHAD                  |
| FE8h         | FSR0L_SHAD                   |
| FE9h         | FSR0H_SHAD                   |
| FEAh         | FSR1L_SHAD                   |
| FEBh         | FSR1H_SHAD                   |
| FECh         | —                            |
| FEDh         | STKPTR                       |
| FEEh         | TOSL                         |
| FEFh         | TOSH                         |

Legend: Unimplemented data memory locations, read as '0'.

# 6.2.1.6 External RC Mode

The external Resistor-Capacitor (RC) modes support the use of an external RC circuit. This allows the designer maximum flexibility in frequency choice while keeping costs to a minimum when clock accuracy is not required.

The RC circuit connects to OSC1. OSC2/CLKOUT is available for general purpose I/O or CLKOUT. The function of the OSC2/CLKOUT pin is determined by the CLKOUTEN bit in Configuration Words.

Figure 6-6 shows the external RC mode connections.



FIGURE 6-6: EXTERNAL RC MODES

The RC oscillator frequency is a function of the supply voltage, the resistor (REXT) and capacitor (CEXT) values and the operating temperature. Other factors affecting the oscillator frequency are:

- threshold voltage variation
- component tolerances
- · packaging variations in capacitance

The user also needs to take into account variation due to tolerance of external RC components used.

## 6.2.2 INTERNAL CLOCK SOURCES

The device may be configured to use the internal oscillator block as the system clock by performing one of the following actions:

- Program the FOSC<2:0> bits in Configuration Words to select the INTOSC clock source, which will be used as the default system clock upon a device Reset.
- Write the SCS<1:0> bits in the OSCCON register to switch the system clock source to the internal oscillator during run-time. See Section 6.3 "Clock Switching"for more information.

In **INTOSC** mode, OSC1/CLKIN is available for general purpose I/O. OSC2/CLKOUT is available for general purpose I/O or CLKOUT.

The function of the OSC2/CLKOUT pin is determined by the CLKOUTEN bit in Configuration Words.

The internal oscillator block has two independent oscillators and a dedicated Phase-Lock Loop, HFPLL that can produce one of three internal system clock sources.

- The HFINTOSC (High-Frequency Internal Oscillator) is factory calibrated and operates at 16 MHz. The HFINTOSC source is generated from the 500 kHz MFINTOSC source and the dedicated Phase-Lock Loop, HFPLL. The frequency of the HFINTOSC can be user-adjusted via software using the OSCTUNE register (Register 6-3).
- 2. The **MFINTOSC** (Medium-Frequency Internal Oscillator) is factory calibrated and operates at 500 kHz. The frequency of the MFINTOSC can be user-adjusted via software using the OSCTUNE register (Register 6-3).
- 3. The **LFINTOSC** (Low-Frequency Internal Oscillator) is uncalibrated and operates at 31 kHz.

# 8.0 INTERRUPTS

The interrupt feature allows certain events to preempt normal program flow. Firmware is used to determine the source of the interrupt and act accordingly. Some interrupts can be configured to wake the MCU from Sleep mode.

This chapter contains the following information for Interrupts:

- Operation
- Interrupt Latency
- Interrupts During Sleep
- INT Pin
- · Automatic Context Saving

Many peripherals produce interrupts. Refer to the corresponding chapters for details.

A block diagram of the interrupt logic is shown in Figure 8-1.

#### FIGURE 8-1: INTERRUPT LOGIC



#### 12.3.2 ERASING FLASH PROGRAM MEMORY

While executing code, program memory can only be erased by rows. To erase a row:

- 1. Load the EEADRH:EEADRL register pair with the address of new row to be erased.
- 2. Clear the CFGS bit of the EECON1 register.
- 3. Set the EEPGD, FREE, and WREN bits of the EECON1 register.
- 4. Write 55h, then AAh, to EECON2 (Flash programming unlock sequence).
- 5. Set control bit WR of the EECON1 register to begin the erase operation.
- 6. Poll the FREE bit in the EECON1 register to determine when the row erase has completed.

#### See Example 12-4.

After the "BSF EECON1, WR" instruction, the processor requires two cycles to set up the erase operation. The user must place two NOP instructions after the WR bit is set. The processor will halt internal operations for the typical 2 ms erase time. This is not Sleep mode as the clocks and peripherals will continue to run. After the erase cycle, the processor will resume operation with the third instruction after the EECON1 write instruction.

# 12.3.3 WRITING TO FLASH PROGRAM MEMORY

Program memory is programmed using the following steps:

- 1. Load the starting address of the word(s) to be programmed.
- 2. Load the write latches with data.
- 3. Initiate a programming operation.
- 4. Repeat steps 1 through 3 until all data is written.

Before writing to program memory, the word(s) to be written must be erased or previously unwritten. Program memory can only be erased one row at a time. No automatic erase occurs upon the initiation of the write.

Program memory can be written one or more words at a time. The maximum number of words written at one time is equal to the number of write latches. See Figure 12-2 (block writes to program memory with 32 write latches) for more details. The write latches are aligned to the address boundary defined by EEADRL as shown in Table 12-1. Write operations do not cross these boundaries. At the completion of a program memory write operation, the write latches are reset to contain 0x3FFF.

The following steps should be completed to load the write latches and program a block of program memory. These steps are divided into two parts. First, all write latches are loaded with data except for the last program memory location. Then, the last write latch is loaded and the programming sequence is initiated. A special

unlock sequence is required to load a write latch with data or initiate a Flash programming operation. This unlock sequence should not be interrupted.

- 1. Set the EEPGD and WREN bits of the EECON1 register.
- 2. Clear the CFGS bit of the EECON1 register.
- Set the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '1', the write sequence will only load the write latches and will not initiate the write to Flash program memory.
- 4. Load the EEADRH:EEADRL register pair with the address of the location to be written.
- 5. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The write latch is now loaded.
- 7. Increment the EEADRH:EEADRL register pair to point to the next location.
- 8. Repeat steps 5 through 7 until all but the last write latch has been loaded.
- Clear the LWLO bit of the EECON1 register. When the LWLO bit of the EECON1 register is '0', the write sequence will initiate the write to Flash program memory.
- 10. Load the EEDATH:EEDATL register pair with the program memory data to be written.
- 11. Write 55h, then AAh, to EECON2, then set the WR bit of the EECON1 register (Flash programming unlock sequence). The entire latch block is now written to Flash program memory.

It is not necessary to load the entire write latch block with user program data. However, the entire write latch block will be written to program memory.

An example of the complete write sequence for eight words is shown in Example 12-5. The initial address is loaded into the EEADRH:EEADRL register pair; the eight words of data are loaded using indirect addressing.

After the "BSF EECON1, WR" instruction, the processor requires two cycles to set up the write operation. The user must place two NOP instructions after the WR bit is set. The processor will halt internal operations for the typical 2 ms, only during the cycle in which the write takes place (i.e., the last word of the block write). This is not Sleep mode as the clocks and peripherals will continue to run. The processor does not stall when LWLO = 1, loading the write latches. After the write cycle, the processor will resume operation with the third instruction after the EECON1 WRITE instruction.

NOTES:

# **19.6 Register Definitions: DAC Control**

#### REGISTER 19-1: DAC1CON0: VOLTAGE REFERENCE CONTROL REGISTER 0

| R/W-0/0          | U-0                                                                                                                                                                                                              | R/W-0/0           | R/W-0/0 | R/W-0/0        | R/W-0/0            | U-0              | R/W-0/0    |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------|----------------|--------------------|------------------|------------|--|
| DAC1EN           | —                                                                                                                                                                                                                | DAC10E1           | DAC10E2 | DAC1F          | PSS<1:0>           | —                | DAC1NSS    |  |
| bit 7            |                                                                                                                                                                                                                  | •                 |         |                |                    |                  | bit 0      |  |
|                  |                                                                                                                                                                                                                  |                   |         |                |                    |                  |            |  |
| Legend:          |                                                                                                                                                                                                                  |                   |         |                |                    |                  |            |  |
| R = Readable b   | it                                                                                                                                                                                                               | W = Writable b    | oit     | U = Unimplem   | nented bit, read a | is '0'           |            |  |
| u = Bit is uncha | nged                                                                                                                                                                                                             | x = Bit is unkno  | own     | -n/n = Value a | t POR and BOR      | Value at all oth | ier Resets |  |
| '1' = Bit is set |                                                                                                                                                                                                                  | '0' = Bit is clea | red     |                |                    |                  |            |  |
|                  |                                                                                                                                                                                                                  |                   |         |                |                    |                  |            |  |
| bit 7            | t 7 DAC1EN: DAC1 Enable bit<br>1 = DAC1 is enabled<br>0 = DAC1 is disclosed                                                                                                                                      |                   |         |                |                    |                  |            |  |
| bit 6            |                                                                                                                                                                                                                  | ed: Read as '0'   |         |                |                    |                  |            |  |
| bit 5            | DAC10E1: DAC1 Voltage Output 1 Enable bit<br>1 = DAC1 voltage level is also an output on the DAC10UT1 pin<br>0 = DAC1 voltage level is disconnected from the DAC10UT1 pin                                        |                   |         |                |                    |                  |            |  |
| bit 4            | <ul> <li>DACT voltage level is disconnected from the DACTOUT2 pin</li> <li>DAC1 voltage level is also an output on the DAC1OUT2 pin</li> <li>DAC1 voltage level is disconnected from the DAC1OUT2 pin</li> </ul> |                   |         |                |                    |                  |            |  |
| bit 3-2          | bit 3-2 <b>DAC1PSS&lt;1:0&gt;:</b> DAC1 Positive Source Select bits<br>11 = Reserved, do not use<br>10 = FVR Buffer2 output<br>01 = VREF+ pin<br>00 = VDD                                                        |                   |         |                |                    |                  |            |  |
| bit 1            | Unimplement                                                                                                                                                                                                      | ed: Read as '0'   |         |                |                    |                  |            |  |
| bit 0            | DAC1NSS: DAC1 Negative Source Select bits<br>1 = VREF- pin<br>0 = Vss                                                                                                                                            |                   |         |                |                    |                  |            |  |

#### REGISTER 19-2: DAC1CON1: VOLTAGE REFERENCE 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 |  |
|------------------|---------|------------------|---------|--------------|--------------------|---------|---------|--|
| DAC1R<7:0>       |         |                  |         |              |                    |         |         |  |
| bit 7            |         |                  |         |              |                    |         | bit 0   |  |
|                  |         |                  |         |              |                    |         |         |  |
| Legend:          |         |                  |         |              |                    |         |         |  |
| R = Readable bit |         | W = Writable bit | t       | U = Unimplem | nented bit, read a | as '0'  |         |  |

bit 7-0 DAC1R<7:0>: DAC1 Voltage Output Select bits

x = Bit is unknown

'0' = Bit is cleared

#### TABLE 19-1: SUMMARY OF REGISTERS ASSOCIATED WITH THE DAC MODULE

| Name     | Bit 7      | Bit 6  | Bit 5 Bit 4 |         | Bit 3 Bit 2  |  | Bit 1 Bit 0 |         | Register<br>on page |
|----------|------------|--------|-------------|---------|--------------|--|-------------|---------|---------------------|
| FVRCON   | FVREN      | FVRRDY | TSEN        | TSRNG   | CDAFVR<1:0>  |  | ADFVR<1:0>  |         | 167                 |
| DAC1CON0 | DAC1EN     | —      | DAC10E1     | DAC10E2 | DAC1PSS<1:0> |  | —           | DAC1NSS | 192                 |
| DAC1CON1 | DAC1R<7:0> |        |             |         |              |  |             |         |                     |

**Legend:** — = Unimplemented location, read as '0'. Shaded cells are not used with the DAC module.

u = Bit is unchanged

'1' = Bit is set

-n/n = Value at POR and BOR/Value at all other Resets

# 25.3 PWM Overview

Pulse-Width Modulation (PWM) is a scheme that provides power to a load by switching quickly between fully on and fully off states. The PWM signal resembles a square wave where the high portion of the signal is considered the on state and the low portion of the signal is considered the off state. The high portion, also known as the pulse width, can vary in time and is defined in steps. A larger number of steps applied, which lengthens the pulse width, also supplies more power to the load. Lowering the number of steps applied, which shortens the pulse width, supplies less power. The PWM period is defined as the duration of one complete cycle or the total amount of on and off time combined.

PWM resolution defines the maximum number of steps that can be present in a single PWM period. A higher resolution allows for more precise control of the pulse width time and in turn the power that is applied to the load.

The term duty cycle describes the proportion of the on time to the off time and is expressed in percentages, where 0% is fully off and 100% is fully on. A lower duty cycle corresponds to less power applied and a higher duty cycle corresponds to more power applied.

Figure 25-3 shows a typical waveform of the PWM signal.

#### 25.3.1 STANDARD PWM OPERATION

The standard PWM function described in this section is available and identical for all CCP modules.

The standard PWM mode generates a Pulse-Width Modulation (PWM) signal on the CCPx pin with up to ten bits of resolution. The period, duty cycle, and resolution are controlled by the following registers:

- · PR2 registers
- T2CON registers
- · CCPRxL registers
- · CCPxCON registers

Figure 25-4 shows a simplified block diagram of PWM operation.

- Note 1: The corresponding TRIS bit must be cleared to enable the PWM output on the CCPx pin.
  - 2: Clearing the CCPxCON register will relinquish control of the CCPx pin.

#### FIGURE 25-3: CCP PWM OUTPUT SIGNAL





SIMPLIFIED PWM BLOCK DIAGRAM



## 25.3.2 SETUP FOR PWM OPERATION

The following steps should be taken when configuring the CCP module for standard PWM operation:

- 1. Disable the CCPx pin output driver by setting the associated TRIS bit.
- 2. Load the PR2 register with the PWM period value.
- Configure the CCP module for the PWM mode by loading the CCPxCON register with the appropriate values.
- Load the CCPRxL register and the DCxBx bits of the CCPxCON register, with the PWM duty cycle value.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIRx register. See Note below.
  - Configure the T2CKPS bits of the T2CON register with the Timer prescale value.
  - Enable the Timer by setting the TMR2ON bit of the T2CON register.
- 6. Enable PWM output pin:
  - Wait until the Timer overflows and the TMR2IF bit of the PIR1 register is set. See Note below.
  - Enable the CCPx pin output driver by clearing the associated TRIS bit.

| Note: | In order to send a complete duty cycle and      |
|-------|-------------------------------------------------|
|       | period on the first PWM output, the above       |
|       | steps must be included in the setup             |
|       | sequence. If it is not critical to start with a |
|       | complete PWM signal on the first output,        |
|       | then step 6 may be ignored.                     |

## 25.3.3 TIMER2 TIMER RESOURCE

The PWM standard mode makes use of the 8-bit Timer2 timer resources to specify the PWM period.

#### 25.3.4 PWM PERIOD

The PWM period is specified by the PR2 register of Timer2. The PWM period can be calculated using the formula of Equation 25-1.

# EQUATION 25-1: PWM PERIOD

 $PWM Period = [(PR2) + 1] \bullet 4 \bullet Tosc \bullet$ (TMR2 Prescale Value)

Note 1: Tosc = 1/Fosc

When TMR2 is equal to PR2, the following three events occur on the next increment cycle:

- TMR2 is cleared
- The CCPx pin is set. (Exception: If the PWM duty cycle = 0%, the pin will not be set.)
- The PWM duty cycle is latched from CCPRxL into CCPRxH.

Note: The Timer postscaler (see Section 24.1 "Timer2 Operation") is not used in the determination of the PWM frequency.

#### 25.3.5 PWM DUTY CYCLE

The PWM duty cycle is specified by writing a 10-bit value to multiple registers: CCPRxL register and DCxB<1:0> bits of the CCPxCON register. The CCPRxL contains the eight MSbs and the DCxB<1:0> bits of the CCPxCON register contain the two LSbs. CCPRxL and DCxB<1:0> bits of the CCPxCON register can be written to at any time. The duty cycle value is not latched into CCPRxH until after the period completes (i.e., a match between PR2 and TMR2 registers occurs). While using the PWM, the CCPRxH register is read-only.

Equation 25-2 is used to calculate the PWM pulse width.

Equation 25-3 is used to calculate the PWM duty cycle ratio.

## EQUATION 25-2: PULSE WIDTH

Pulse Width = (CCPRxL:CCPxCON < 5:4>) •

TOSC • (TMR2 Prescale Value)

# EQUATION 25-3: DUTY CYCLE RATIO

 $Duty Cycle Ratio = \frac{(CCPRxL:CCPxCON < 5:4>)}{4(PR2 + 1)}$ 

The CCPRxH register and a 2-bit internal latch are used to double buffer the PWM duty cycle. This double buffering is essential for glitchless PWM operation.

The 8-bit timer TMR2 register is concatenated with either the 2-bit internal system clock (FOSC), or two bits of the prescaler, to create the 10-bit time base. The system clock is used if the Timer2 prescaler is set to 1:1.

When the 10-bit time base matches the CCPRxH and 2-bit latch, then the CCPx pin is cleared (see Figure 25-4).

#### 26.3.9 ECCP COMPATIBLE FULL-BRIDGE PWM

This mode of operation is designed to match the Full-Bridge mode from the ECCP module. It is called ECCP compatible as the term "full-bridge" alone has different connotations in regards to the output waveforms.

Full-Bridge Compatible mode uses the same waveform events as the single PWM mode to generate the output waveforms.

There are both Forward and Reverse modes available for this operation, again to match the ECCP implementation. Direction is selected with the mode control bits.

#### 26.3.9.1 Mode Features

- · Dead-band control available on direction switch
  - Changing from forward to reverse uses the falling edge dead-band counters.
  - Changing from reverse to forward uses the rising edge dead-band counters.
- · No steering control available
- PWM is output on the following four pins only:
  - PSMCxA
  - PSMCxB
  - PSMCxC
  - PSMCxD

# 26.3.9.2 Waveform Generation - Forward

In this mode of operation, three of the four pins are static. PSMCxA is the only output that changes based on rising edge and falling edge events.

#### Static Signal Assignment

- · Outputs set to active state
  - PSMCxD
- · Outputs set to inactive state
  - PSMCxB
  - PSMCxC

#### Rising Edge Event

· PSMCxA is set active

Falling Edge Event

· PSMCxA is set inactive

#### 26.3.9.3 Waveform Generation – Reverse

In this mode of operation, three of the four pins are static. Only PSMCxB toggles based on rising edge and falling edge events.

Static Signal Assignment

- · Outputs set to active state
  - PSMCxC
- · Outputs set to inactive state
  - PSMCxA
- PSMCxD
- Rising Edge Event
- PSMCxB is set active

#### Falling Edge Event

· PSMCxB is set inactive

#### FIGURE 26-12: ECCP COMPATIBLE FULL-BRIDGE PWM WAVEFORM – PSMCXSTR0 = 0FH

| PWM Period Number  | 1 | 2        | 3      |                       | 5 | 6        | 7       | 8        | -9       | 10           | —11—        | -12 |
|--------------------|---|----------|--------|-----------------------|---|----------|---------|----------|----------|--------------|-------------|-----|
|                    | • | Forward  | mode o | peration <sup>.</sup> |   |          | Reverse | e mode c | peration |              |             |     |
| Period Event       | ┃ | <u> </u> |        | <u></u>               |   |          | ]       | ]        | ]        | [            |             |     |
| Falling Edge Event |   |          |        |                       |   |          |         |          |          |              |             |     |
| PSMCxA             |   |          |        |                       |   |          |         |          |          |              |             | -   |
| PSMCxB             |   |          |        |                       |   |          |         |          |          |              | 1<br>1<br>1 | _   |
| PSMCxC             |   |          |        |                       |   |          |         |          |          |              | 1           |     |
|                    |   |          |        |                       | _ |          |         |          | Rising   | Edge De<br>→ | ad Band     | 3   |
| PSMCxD             |   |          |        |                       |   | - railir | iy ⊏age |          |          |              |             |     |

# 26.5 Output Steering

Output steering allows for PWM signals generated by the PSMC module to be placed on different pins under software control. Synchronized steering will hold steering changes until the first period event after the PSMCxLD bit is set. Unsynchronized steering changes will take place immediately.

Output steering is available in the following modes:

- 3-phase PWM
- Single PWM
- Complementary PWM

#### 26.5.1 3-PHASE STEERING

3-phase steering is available in the 3-Phase Modulation mode only. For more details on 3-phase steering refer to **Section 26.3.12 "3-Phase PWM"**.

#### 26.5.2 SINGLE PWM STEERING

In Single PWM Steering mode, the single PWM signal can be routed to any combination of the PSMC output pins. Examples of unsynchronized single PWM steering are shown in Figure 26-16.



| PxSTRB                                                                                            |  |
|---------------------------------------------------------------------------------------------------|--|
| PxSTR <u>C</u>                                                                                    |  |
|                                                                                                   |  |
|                                                                                                   |  |
| PxSTRFPSMCxF<br>With synchronization disabled, it is possible to get glitches on the PWM outputs. |  |
|                                                                                                   |  |

# 27.4 I<sup>2</sup>C MODE OPERATION

All MSSP I<sup>2</sup>C communication is byte oriented and shifted out MSb first. Six SFR registers and two interrupt flags interface the module with the  $PIC^{\mathbb{R}}$  microcontroller and user software. Two pins, SDA and SCL, are exercised by the module to communicate with other external I<sup>2</sup>C devices.

#### 27.4.1 BYTE FORMAT

All communication in  $I^2C$  is done in 9-bit segments. A byte is sent from a master to a slave or vice-versa, followed by an Acknowledge bit sent back. After the 8th falling edge of the SCL line, the device outputting data on the SDA changes that pin to an input and reads in an acknowledge value on the next clock pulse.

The clock signal, SCL, is provided by the master. Data is valid to change while the SCL signal is low, and sampled on the rising edge of the clock. Changes on the SDA line while the SCL line is high define special conditions on the bus, explained below.

#### 27.4.2 DEFINITION OF I<sup>2</sup>C TERMINOLOGY

There is language and terminology in the description of I<sup>2</sup>C communication that have definitions specific to I<sup>2</sup>C. That word usage is defined below and may be used in the rest of this document without explanation. This table was adapted from the Philips I<sup>2</sup>C specification.

### 27.4.3 SDA AND SCL PINS

Selection of any  $I^2C$  mode with the SSPEN bit set, forces the SCL and SDA pins to be open-drain. These pins should be set by the user to inputs by setting the appropriate TRIS bits.

Note: Data is tied to output zero when an I<sup>2</sup>C mode is enabled.

#### 27.4.4 SDA HOLD TIME

The hold time of the SDA pin is selected by the SDAHT bit of the SSPCON3 register. Hold time is the time SDA is held valid after the falling edge of SCL. Setting the SDAHT bit selects a longer 300 ns minimum hold time and may help on buses with large capacitance.

# TABLE 27-2: I<sup>2</sup>C BUS TERMS

| TERM                | Description                                                                                                                                                                                        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter         | The device which shifts data out onto the bus.                                                                                                                                                     |
| Receiver            | The device which shifts data in from the bus.                                                                                                                                                      |
| Master              | The device that initiates a transfer,<br>generates clock signals and<br>terminates a transfer.                                                                                                     |
| Slave               | The device addressed by the master.                                                                                                                                                                |
| Multi-master        | A bus with more than one device that can initiate data transfers.                                                                                                                                  |
| Arbitration         | Procedure to ensure that only one master at a time controls the bus. Winning arbitration ensures that the message is not corrupted.                                                                |
| Synchronization     | Procedure to synchronize the clocks of two or more devices on the bus.                                                                                                                             |
| Idle                | No master is controlling the bus,<br>and both SDA and SCL lines are<br>high.                                                                                                                       |
| Active              | Any time one or more master devices are controlling the bus.                                                                                                                                       |
| Addressed<br>Slave  | Slave device that has received a matching address and is actively being clocked by a master.                                                                                                       |
| Matching<br>Address | Address byte that is clocked into a slave that matches the value stored in SSPADD.                                                                                                                 |
| Write Request       | Slave receives a matching address with R/W bit clear, and is ready to clock in data.                                                                                                               |
| Read Request        | Master sends an address byte with<br>the R/W bit set, indicating that it<br>wishes to clock data out of the<br>Slave. This data is the next and all<br>following bytes until a Restart or<br>Stop. |
| Clock Stretching    | When a device on the bus hold SCL low to stall communication.                                                                                                                                      |
| Bus Collision       | Any time the SDA line is sampled<br>low by the module while it is out-<br>putting and expected high state                                                                                          |

#### 27.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.

ving this, the Baud Rate with the contents of s its count. When the Baud (TBRG), the SEN bit of the pautomatically, cleared by

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



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

its Idle state.

the SDA and SCL pins are already

sampled low, or if during the Start condi-

tion, 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

2: The Philips I<sup>2</sup>C specification states that a

#### 27.6.13.3 Bus Collision During a Stop Condition

Bus collision occurs during a Stop condition if:

- a) After the SDA pin has been deasserted and allowed to float high, SDA is sampled low after the BRG has timed out.
- b) After the SCL pin is deasserted, SCL is sampled low before SDA goes high.

The Stop condition begins with SDA asserted low. When SDA is sampled low, the SCL pin is allowed to float. When the pin is sampled high (clock arbitration), the Baud Rate Generator is loaded with SSPADD and counts down to 0. After the BRG times out, SDA is sampled. If SDA is sampled low, a bus collision has occurred. This is due to another master attempting to drive a data '0' (Figure 27-37). If the SCL pin is sampled low before SDA is allowed to float high, a bus collision occurs. This is another case of another master attempting to drive a data '0' (Figure 27-38).

## FIGURE 27-38: BUS COLLISION DURING A STOP CONDITION (CASE 1)

![](_page_14_Figure_7.jpeg)

## FIGURE 27-39: BUS COLLISION DURING A STOP CONDITION (CASE 2)

![](_page_14_Figure_9.jpeg)

#### REGISTER 27-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

| RX/DT<br>pin<br>TX/CK pin<br>(SCKP = 0) | X     bit 0     bit 2     bit 3     bit 4     bit 5     bit 6     bit 7 | _       |
|-----------------------------------------|-------------------------------------------------------------------------|---------|
| TX/CK pin<br>(SCKP = 1)<br>Write to     |                                                                         | _       |
| SREN bit                                |                                                                         |         |
| RCIF bit<br>(Interrupt) ————            |                                                                         | <u></u> |
| RCREG                                   | gram demonstrates Sync Master mode with bit SREN = 1 and bit BRGH = 0.  |         |

## FIGURE 28-12: SYNCHRONOUS RECEPTION (MASTER MODE, SREN)

# TABLE 28-8: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER RECEPTION RECEPTION

| Name    | Bit 7                        | Bit 6   | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0   | Register<br>on Page |
|---------|------------------------------|---------|--------|--------|--------|--------|--------|---------|---------------------|
| APFCON1 | C2OUTSEL                     | CC1PSEL | SDOSEL | SCKSEL | SDISEL | TXSEL  | RXSEL  | CCP2SEL | 132                 |
| BAUDCON | ABDOVF                       | RCIDL   | _      | SCKP   | BRG16  | _      | WUE    | ABDEN   | 356                 |
| INTCON  | GIE                          | PEIE    | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF   | 97                  |
| PIE1    | TMR1GIE                      | ADIE    | RCIE   | TXIE   | SSP1IE | CCP1IE | TMR2IE | TMR1IE  | 98                  |
| PIR1    | TMR1GIF                      | ADIF    | RCIF   | TXIF   | SSP1IF | CCP1IF | TMR2IF | TMR1IF  | 102                 |
| RCREG   | EUSART Receive Data Register |         |        |        |        |        |        | 349*    |                     |
| RCSTA   | SPEN                         | RX9     | SREN   | CREN   | ADDEN  | FERR   | OERR   | RX9D    | 355                 |
| SPBRGL  | BRG<7:0>                     |         |        |        |        |        |        | 357     |                     |
| SPBRGH  | BRG<15:8>                    |         |        |        |        |        |        | 357     |                     |
| TRISC   | TRISC7                       | TRISC6  | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0  | 147                 |
| TXSTA   | CSRC                         | TX9     | TXEN   | SYNC   | SENDB  | BRGH   | TRMT   | TX9D    | 354                 |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used for synchronous master reception.

\* Page provides register information.

| MOVWF            | Move W to f                                                                                               |  |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Syntax:          | [ <i>label</i> ] MOVWF f                                                                                  |  |  |  |  |  |
| Operands:        | $0 \leq f \leq 127$                                                                                       |  |  |  |  |  |
| Operation:       | $(W) \rightarrow (f)$                                                                                     |  |  |  |  |  |
| Status Affected: | None                                                                                                      |  |  |  |  |  |
| Description:     | Move data from W register to<br>register 'f'.                                                             |  |  |  |  |  |
| Words:           | 1                                                                                                         |  |  |  |  |  |
| Cycles:          | 1                                                                                                         |  |  |  |  |  |
| Example:         | MOVWF OPTION_REG                                                                                          |  |  |  |  |  |
|                  | Before Instruction<br>OPTION_REG = 0xFF<br>W = 0x4F<br>After Instruction<br>OPTION_REG = 0x4F<br>W = 0x4F |  |  |  |  |  |

| ΜΟΥΨΙ            | 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] \\ \textbf{-32} \leq k \leq 31 \end{array}$                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| Operation:       | $\label{eq:W} \begin{split} W &\rightarrow INDFn \\ \text{Effective address is determined by} \\ \bullet \ FSR + 1 \ (preincrement) \\ \bullet \ FSR + 1 \ (preincrement) \\ \bullet \ FSR + k \ (relative offset) \\ \text{After the Move, the FSR value will} \\ \text{be either:} \\ \bullet \ FSR + 1 \ (all increments) \\ \bullet \ FSR - 1 \ (all increments) \\ \text{Unchanged} \end{split}$ |  |  |  |  |  |
| Status Affected: | None                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

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

#### TABLE 31-4: I/O PORTS

Standard Operating Conditions (unless otherwise stated)

| Param<br>No.                           | Sym. | Characteristic                       | Min.       | Тур† | Max.     | Units | Conditions                       |  |  |
|----------------------------------------|------|--------------------------------------|------------|------|----------|-------|----------------------------------|--|--|
|                                        | VIL  | Input Low Voltage                    |            |      |          |       |                                  |  |  |
|                                        |      | I/O PORT:                            | /O PORT:   |      |          |       |                                  |  |  |
| D034                                   |      | with TTL buffer                      | —          | _    | 0.8      | V     | $4.5V \leq V\text{DD} \leq 5.5V$ |  |  |
| D034A                                  |      |                                      | _          |      | 0.15 Vdd | V     | $1.8V \leq V\text{DD} \leq 4.5V$ |  |  |
| D035                                   |      | with Schmitt Trigger buffer          | —          |      | 0.2 Vdd  | V     | $2.0V \leq V\text{DD} \leq 5.5V$ |  |  |
|                                        |      | with I <sup>2</sup> C levels         | _          | _    | 0.3 Vdd  | V     |                                  |  |  |
|                                        |      | with SMBus levels                    | _          |      | 0.8      | V     | $2.7V \leq V\text{DD} \leq 5.5V$ |  |  |
| D036                                   |      | MCLR, OSC1 (RC mode) <sup>(1)</sup>  | _          |      | 0.2 Vdd  | V     |                                  |  |  |
| D036A                                  |      | OSC1 (HS mode)                       | _          |      | 0.3 Vdd  | V     |                                  |  |  |
|                                        | VIH  | Input High Voltage                   |            |      |          |       |                                  |  |  |
|                                        |      | I/O ports:                           |            |      |          |       |                                  |  |  |
| D040                                   |      | with TTL buffer                      | 2.0        | _    | _        | V     | $4.5V \leq V\text{DD} \leq 5.5V$ |  |  |
| D040A                                  |      |                                      | 0.25 VDD + | _    | _        | V     | $1.8V \leq V\text{DD} \leq 4.5V$ |  |  |
|                                        |      |                                      | 0.8        |      |          |       |                                  |  |  |
| D041                                   |      | with Schmitt Trigger buffer          | 0.8 VDD    | _    | —        | V     | $2.0V \leq V\text{DD} \leq 5.5V$ |  |  |
|                                        |      | with I <sup>2</sup> C levels         | 0.7 Vdd    |      |          | V     |                                  |  |  |
|                                        |      | with SMBus levels                    | 2.1        |      |          | V     | $2.7V \leq V\text{DD} \leq 5.5V$ |  |  |
| D042                                   |      | MCLR                                 | 0.8 VDD    |      |          | V     |                                  |  |  |
| D043A                                  |      | OSC1 (HS mode)                       | 0.7 Vdd    |      | —        | V     |                                  |  |  |
| D043B                                  |      | OSC1 (RC mode)                       | 0.9 Vdd    |      | —        | V     | (Note 1)                         |  |  |
|                                        | lı∟  | Input Leakage Current <sup>(2)</sup> |            |      |          |       |                                  |  |  |
| D060                                   |      | I/O ports                            | —          | ± 5  | ± 125    | nA    | $Vss \leq VPIN \leq VDD, Pin at$ |  |  |
|                                        |      |                                      |            |      |          |       | high-impedance @ 85°C            |  |  |
| 5.001                                  |      |                                      |            | ± 5  | ± 1000   | nA    | 125°C                            |  |  |
| D061                                   |      | MCLR(*)                              | _          | ± 50 | ± 200    | nA    | $VSS \le VPIN \le VDD @ 85°C$    |  |  |
| D 0 70+                                | IPUR | Weak Pull-up Current                 | 0.5        | 400  | 000      | 1     |                                  |  |  |
| D070*                                  |      |                                      | 25         | 100  | 200      |       | VDD = 3.3V, $VPIN = VSS$         |  |  |
|                                        |      | Output Low Voltage <sup>(4)</sup>    | 20         | 140  | 300      | μΑ    | VDD - 5.0V, VPIN - VSS           |  |  |
| 000                                    | VOL  |                                      | 1          |      |          | 1     | $ \alpha  = 8mA$ )/pp = 5)/      |  |  |
| D060                                   |      | i/O ports                            | _          | _    | 0.6      | V     | OL = 6 MA, VDD = 3 V             |  |  |
|                                        |      |                                      |            |      | 0.0      | v     | IOL = 1.8mA, VDD = 1.8V          |  |  |
| VOH Output High Voltage <sup>(4)</sup> |      |                                      |            |      |          | · -   |                                  |  |  |
| D090                                   | -    | I/O ports                            |            |      |          |       | Юн = 3.5mA, VDD = 5V             |  |  |
|                                        |      |                                      | Vdd - 0.7  | —    | —        | V     | ІОН = 3mA, VDD = 3.3V            |  |  |
|                                        |      |                                      |            |      |          |       | юн = 1mA, Vdd = 1.8V             |  |  |

These parameters are characterized but not tested.

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

Note 1: In RC oscillator configuration, the OSC1/CLKIN pin is a Schmitt Trigger input. It is not recommended to use an external clock in RC mode.

2: Negative current is defined as current sourced by the pin.

3: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages.

4: Including OSC2 in CLKOUT mode.

\*

![](_page_19_Figure_1.jpeg)

#### FIGURE 31-12: ADC CONVERSION TIMING (NORMAL MODE)

![](_page_19_Figure_3.jpeg)

![](_page_19_Figure_4.jpeg)

**Note 1:** If the ADC clock source is selected as RC, a time of TCY is added before the ADC clock starts. This allows the SLEEP instruction to be executed.

# APPENDIX A: DATA SHEET REVISION HISTORY

# Revision A (02/2013)

Initial release.

# Revision B (09/2014)

Change from Preliminary to Final data sheet.

Corrected the following Tables: Family Types Table on page 3, Table 3-3, Table 3-8, Table 20-3, Table 22-2, Table 22-3, Table 23-1, Table 25-3, Table 30-1, Table 30-2, Table 30-3, Table 30-6, Table 30-7, Table 30-13, Table 30-14, Table 30-15, Table 30-16, Table 30-20.

Corrected the following Sections: Section 3.2, Section 9.2, Section 13.3, Section 17.1.6, Section 15.1, Section 15.3, Section 17.2.5, Section 18.2, Section 18.3, Section 19.0, Section 22.6.5, Section 22.9, Section 23.0, Section 23.1, Section 24.2.4, Section 24.2.5, Section 24.2.7, Section 24.8, Section 25.0, Section 26.6.7.4, Section 30.3.

Corrected the following Registers: Register 4-2, Register 8-2, Register 8-5, Register 17-3, Register 18-1, Register 24-3, Register 24-4.

Corrected Equation 17-1.

Corrected Figure 30-9. Removed Figure 24-21.

# Revision C (12/2015)

Updated the following Tables: Table 1-1, Table 30-3, Table 31-17, Table 31-18. Updated the following Figures: Figure 18-1, Figure 19-1 and Figure 32-128. Updated Register 18-1 and Register 21-2. Updated the following Sections: Section 26.3.10.2, Section 28.4.2 and Section 31.1; Other minor corrections.