

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

E·XFI

| 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              | 24                                                                          |
| Program Memory Size        | 28KB (16K x 14)                                                             |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 256 x 8                                                                     |
| RAM Size                   | 2K x 8                                                                      |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 11x12b; D/A 1x8b, 3x5b                                                  |
| Oscillator Type            | Internal                                                                    |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                           |
| Mounting Type              | Surface Mount                                                               |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                              |
| Supplier Device Package    | 28-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1788t-i-so |

Email: info@E-XFL.COM

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

## Pin Diagram – 40-Pin UQFN (5x5)



## 3.3.5 CORE FUNCTION REGISTERS SUMMARY

The Core Function registers listed in Table 3-11 can be addressed from any Bank.

| Addr            | Name   | Bit 7                                                    | Bit 6                                       | Bit 5         | Bit 4        | Bit 3        | Bit 2         | Bit 1  | Bit 0     | Value on<br>POR, BOR | Value on all other Resets |
|-----------------|--------|----------------------------------------------------------|---------------------------------------------|---------------|--------------|--------------|---------------|--------|-----------|----------------------|---------------------------|
| Bank            | 0-31   |                                                          |                                             |               |              |              |               |        |           |                      |                           |
| x00h or<br>x80h | INDF0  | Addressing<br>(not a phys                                | this location ical register)                | uses conte    | nts of FSR0H | /FSR0L to ad | ddress data i | memory |           | xxxx xxxx            | uuuu uuuu                 |
| x01h or<br>x81h | INDF1  | Addressing<br>(not a phys                                | this location ical register)                | uses conte    | nts of FSR1H | /FSR1L to a  | ddress data i | memory |           | xxxx xxxx            | uuuu uuuu                 |
| x02h or<br>x82h | PCL    | Program C                                                | ounter (PC)                                 | Least Signifi | cant Byte    |              |               |        |           | 0000 0000            | 0000 0000                 |
| x03h or<br>x83h | STATUS | —                                                        | _                                           |               | ТО           | PD           | Z             | DC     | С         | 1 1000               | q quuu                    |
| x04h or<br>x84h | FSR0L  | Indirect Da                                              | Indirect Data Memory Address 0 Low Pointer  |               |              |              |               |        |           | 0000 0000            | uuuu uuuu                 |
| x05h or<br>x85h | FSR0H  | Indirect Da                                              | Indirect Data Memory Address 0 High Pointer |               |              |              |               |        |           | 0000 0000            | 0000 0000                 |
| x06h or<br>x86h | FSR1L  | Indirect Data Memory Address 1 Low Pointer               |                                             |               |              |              |               |        |           | 0000 0000            | uuuu uuuu                 |
| x07h or<br>x87h | FSR1H  | Indirect Data Memory Address 1 High Pointer              |                                             |               |              |              |               |        | 0000 0000 | 0000 0000            |                           |
| x08h or<br>x88h | BSR    | —                                                        | _                                           |               | BSR4         | BSR3         | BSR2          | BSR1   | BSR0      | 0 0000               | 0 0000                    |
| x09h or<br>x89h | WREG   | Working Register                                         |                                             |               |              |              |               |        |           | 0000 0000            | uuuu uuuu                 |
| x0Ahor<br>x8Ah  | PCLATH | Write Buffer for the upper 7 bits of the Program Counter |                                             |               |              |              |               |        | -000 0000 | -000 0000            |                           |
| x0Bhor<br>x8Bh  | INTCON | GIE                                                      | PEIE                                        | TMR0IE        | INTE         | IOCIE        | TMR0IF        | INTF   | IOCIF     | 0000 0000            | 0000 0000                 |

TABLE 3-11: CORE FUNCTION REGISTERS SUMMARY

Legend:x = unknown, u = unchanged, q = value depends on condition, - = unimplemented, read as '0', r = reserved.Shaded locations are unimplemented, read as '0'.

### 3.5 Stack

All devices have a 16-level x 15-bit wide hardware stack (refer to Figure 3-1). The stack space is not part of either program or data space. The PC is PUSHed onto the stack when CALL or CALLW instructions are executed or an interrupt causes a branch. The stack is POPed in the event of a RETURN, RETLW or a RETFIE instruction execution. PCLATH is not affected by a PUSH or POP operation.

The stack operates as a circular buffer if the STVREN bit is programmed to '0' (Configuration Words). This means that after the stack has been PUSHed sixteen times, the seventeenth PUSH overwrites the value that was stored from the first PUSH. The eighteenth PUSH overwrites the second PUSH (and so on). The STKOVF and STKUNF flag bits will be set on an Overflow/Underflow, regardless of whether the Reset is enabled.

Note: There are no instructions/mnemonics called PUSH or POP. These are actions that occur from the execution of the CALL, CALLW, RETURN, RETLW and RETFIE instructions or the vectoring to an interrupt address.

### 3.5.1 ACCESSING THE STACK

The stack is available through the TOSH, TOSL and STKPTR registers. STKPTR is the current value of the Stack Pointer. TOSH:TOSL register pair points to the TOP of the stack. Both registers are read/writable. TOS is split into TOSH and TOSL due to the 15-bit size of the PC. To access the stack, adjust the value of STKPTR, which will position TOSH:TOSL, then read/write to TOSH:TOSL. STKPTR is five bits to allow detection of overflow and underflow.

| Note: | Care should be taken when modifying the |
|-------|-----------------------------------------|
|       | STKPTR while interrupts are enabled.    |

During normal program operation, CALL, CALLW and interrupts will increment STKPTR while RETLW, RETURN, and RETFIE will decrement STKPTR. At any time, STKPTR can be inspected to see how much stack is left. The STKPTR always points at the currently used place on the stack. Therefore, a CALL or CALLW will increment the STKPTR and then write the PC, and a return will unload the PC and then decrement the STKPTR.

Reference Figure 3-4 through Figure 3-7 for examples of accessing the stack.

### FIGURE 3-4: ACCESSING THE STACK EXAMPLE 1

| TOSH:TOSL 0x0F        | STKPTR = 0x1F Stack Reset Disabled (STVREN = 0)                                       |
|-----------------------|---------------------------------------------------------------------------------------|
| √ 0x0E                |                                                                                       |
| 0x0D                  |                                                                                       |
| 0x0C                  |                                                                                       |
| 0x0B                  |                                                                                       |
| 0x0A                  | Initial Stack Configuration                                                           |
| 0x09                  |                                                                                       |
| 0x08                  | After Reset, the stack is empty. The empty stack is initialized so the Stack          |
| 0x07                  | Pointer is pointing at 0x1F. If the Stack<br>Overflow/Underflow Reset is enabled, the |
| 0x06                  | TOSH/TOSL registers will return '0'. If<br>the Stack Overflow/Underflow Reset is      |
| 0x05                  | disabled, the TOSH/TOSL registers will                                                |
| 0x04                  |                                                                                       |
| 0x03                  |                                                                                       |
| 0x02                  |                                                                                       |
| 0x01                  |                                                                                       |
| 0x00                  |                                                                                       |
| TOSH:TOSL 0x1F 0x0000 | Stack Reset Enabled<br>(STVREN = 1)                                                   |
|                       | N                                                                                     |



## 5.3 Register Definitions: BOR Control

### REGISTER 5-1: BORCON: BROWN-OUT RESET CONTROL REGISTER

| R/W-1/u | R/W-0/u | U-0 | U-0 | U-0 | U-0 | U-0 | R-q/u  |
|---------|---------|-----|-----|-----|-----|-----|--------|
| SBOREN  | BORFS   | —   | —   | —   | —   | —   | BORRDY |
| 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 | q = Value depends on condition                        |

| bit 7   | SBOREN: Software Brown-out Reset Enable bit                                          |
|---------|--------------------------------------------------------------------------------------|
|         | If BOREN <1:0> in Configuration Words ≠ 01:                                          |
|         | SBOREN is read/write, but has no effect on the BOR.                                  |
|         | If BOREN <1:0> in Configuration Words = 01:                                          |
|         | 1 = BOR Enabled                                                                      |
|         | 0 = BOR Disabled                                                                     |
| bit 6   | BORFS: Brown-out Reset Fast Start bit <sup>(1)</sup>                                 |
|         | <u> </u>                                                                             |
|         | BORFS is Read/Write, but has no effect.                                              |
|         | If BOREN <1:0> = 10 (Disabled in Sleep) or BOREN<1:0> = 01 (Under software control): |
|         | 1 = Band gap is forced on always (covers sleep/wake-up/operating cases)              |
|         | 0 = Band gap operates normally, and may turn off                                     |
| bit 5-1 | Unimplemented: Read as '0'                                                           |
| bit 0   | BORRDY: Brown-out Reset Circuit Ready Status bit                                     |
|         | 1 = The Brown-out Reset circuit is active                                            |
|         | 0 = The Brown-out Reset circuit is inactive                                          |
|         |                                                                                      |

**Note 1:** BOREN<1:0> bits are located in Configuration Words.

| FIGURE 5-3:               | RESET START-UP SEQUENCE |
|---------------------------|-------------------------|
|                           |                         |
| Vdd                       |                         |
| Internal POR              |                         |
| Power-up Timer            |                         |
| MCLR                      |                         |
| Internal RESET            |                         |
|                           | Oscillator Modes        |
| External Crystal          | <b>◄</b> Tost           |
| Oscillator Start-up Timer |                         |
| Oscillator                |                         |
| Fosc                      |                         |
| Internal Oscillator       |                         |
| Oscillator                |                         |
| Fosc                      |                         |
| External Clock (EC)       |                         |
| CLKIN                     |                         |
| Fosc                      |                         |
|                           |                         |

## 15.0 FIXED VOLTAGE REFERENCE (FVR)

The Fixed Voltage Reference, or FVR, is a stable voltage reference, independent of VDD, with 1.024V, 2.048V or 4.096V selectable output levels. The output of the FVR can be configured to supply a reference voltage to the following:

- · ADC input channel
- · ADC positive reference
- · Comparator positive input
- Digital-to-Analog Converter (DAC)

The FVR can be enabled by setting the FVREN bit of the FVRCON register.

### 15.1 Independent Gain Amplifiers

The output of the FVR supplied to the ADC, Comparators, and DAC is routed through two independent programmable gain amplifiers. Each amplifier can be programmed for a gain of 1x, 2x or 4x, to produce the three possible voltage levels.

The ADFVR<1:0> bits of the FVRCON register are used to enable and configure the gain amplifier settings for the reference supplied to the ADC module. Reference **Section 17.0 "Analog-to-Digital Converter (ADC) Module"** for additional information.

The CDAFVR<1:0> bits of the FVRCON register are used to enable and configure the gain amplifier settings for the reference supplied to the DAC and comparator module. Reference Section 19.0 "8-Bit Digital-to-Analog Converter (DAC) Module" and Section 21.0 "Comparator Module" for additional information.

### 15.2 FVR Stabilization Period

When the Fixed Voltage Reference module is enabled, it requires time for the reference and amplifier circuits to stabilize. Once the circuits stabilize and are ready for use, the FVRRDY bit of the FVRCON register will be set. See **Section 31.0** "**Electrical Specifications**" for the minimum delay requirement.

## 15.3 FVR Buffer Stabilization Period

When either FVR Buffer1 or FVR Buffer 2 is enabled, the buffer amplifier circuits require 30  $\mu s$  to stabilize. This stabilization time is required even when the FVR is already operating and stable.

| TABLE 16-2: | SUMMARY OF REGISTERS ASSOCIATED WITH THE TEMPERATURE INDICATOR |
|-------------|----------------------------------------------------------------|
|             |                                                                |

| 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 | _     | _     | ADFV  | R<1:0> | 166                 |

Legend: Shaded cells are unused by the temperature indicator module.

## 17.1 ADC Configuration

When configuring and using the ADC the following functions must be considered:

- · Port configuration
- · Channel selection
  - Single-ended
  - Differential
- ADC voltage reference selection
- ADC conversion clock source
- · Interrupt control
- · Result formatting

### 17.1.1 PORT CONFIGURATION

The ADC can be used to convert both analog and digital signals. When converting analog signals, the I/O pin should be configured for analog by setting the associated TRIS and ANSEL bits. Refer to **Section 13.0 "I/O Ports"** for more information.

| Note: | Analog voltages on any pin that is defined |  |  |  |  |  |  |  |
|-------|--------------------------------------------|--|--|--|--|--|--|--|
|       | as a digital input may cause the input     |  |  |  |  |  |  |  |
|       | buffer to conduct excess current.          |  |  |  |  |  |  |  |

### 17.1.2 CHANNEL SELECTION

There are up to 18 channel selections available:

- AN<13:8, 4:0> pins (PIC16(L)F1788 only)
- AN<21, 13:0> pins (PIC16(L)F1789 only)
- Temperature Indicator
- DAC\_output
- FVR (Fixed Voltage Reference) Output

Refer to Section 15.0 "Fixed Voltage Reference (FVR)" and Section 16.0 "Temperature Indicator Module" for more information on these channel selections.

When converting differential signals, the negative input for the channel is selected with the CHSN<3:0> bits of the ADCON2 register. Any positive input can be paired with any negative input to determine the differential channel.

The CHS<4:0> bits of the ADCON0 register determine which positive channel is selected.

When CHSN<3:0> = 1111 then the ADC is effectively a single ended ADC converter.

When changing channels, a delay is required before starting the next conversion.

### 17.1.3 ADC VOLTAGE REFERENCE

The ADPREF bits of the ADCON1 register provide control of the positive voltage reference. The positive voltage reference can be:

- VREF+
- VDD
- FVR Buffer1

The ADNREF bits of the ADCON1 register provide control of the negative voltage reference. The negative voltage reference can be:

- VREF- pin
- Vss

See **Section 15.0** "Fixed Voltage Reference (FVR)" for more details on the Fixed Voltage Reference.

### 17.1.4 CONVERSION CLOCK

The source of the conversion clock is software selectable via the ADCS bits of the ADCON1 register. There are seven possible clock options:

- Fosc/2
- Fosc/4
- Fosc/8
- Fosc/16
- Fosc/32
- Fosc/64
- FRC (dedicated internal FRC oscillator)

The time to complete one bit conversion is defined as TAD. One full 12-bit conversion requires 15 TAD periods as shown in Figure 17-2.

For correct conversion, the appropriate TAD specification must be met. Refer to the ADC conversion requirements in **Section 31.0 "Electrical Specifications"** for more information. Table 17-1 gives examples of appropriate ADC clock selections.

**Note:** Unless using the FRC, any changes in the system clock frequency will change the ADC clock frequency, which may adversely affect the ADC result.

### 17.2.6 A/D CONVERSION PROCEDURE

This is an example procedure for using the ADC to perform an Analog-to-Digital conversion:

- 1. Configure Port:
  - Disable pin output driver (Refer to the TRIS register)
  - Configure pin as analog (Refer to the ANSEL register)
  - Disable weak pull-ups either globally (Refer to the OPTION\_REG register) or individually (Refer to the appropriate WPUx register)
- 2. Configure the ADC module:
  - Select ADC conversion clock
  - Configure voltage reference
  - · Select ADC input channel
  - Turn on ADC module
- 3. Configure ADC interrupt (optional):
  - Clear ADC interrupt flag
  - Enable ADC interrupt
  - · Enable peripheral interrupt
  - Enable global interrupt<sup>(1)</sup>
- 4. Wait the required acquisition time<sup>(2)</sup>.
- 5. Start conversion by setting the GO/DONE bit.
- 6. Wait for ADC conversion to complete by one of the following:
  - Polling the GO/DONE bit
  - Waiting for the ADC interrupt (interrupts enabled)
- 7. Read ADC Result.
- 8. Clear the ADC interrupt flag (required if interrupt is enabled).

**Note 1:** The global interrupt can be disabled if the user is attempting to wake-up from Sleep and resume in-line code execution.

2: Refer to Section 17.4 "ADC Acquisition Requirements".

#### EXAMPLE 17-1: A/D CONVERSION

| ;This cod<br>;for poll | le block confi<br>ing, Vdd and | gures the ADC<br>Vss references, Frc |
|------------------------|--------------------------------|--------------------------------------|
| ;clock                 | 5,                             |                                      |
| MOVWF                  | ADCON1                         | ;Vdd and Vss Vref                    |
| MOVLW                  | B'00001111'                    | ;set negative input                  |
| MOVWF                  | ADCON2                         | ;to negative                         |
|                        |                                | ;reference                           |
| BANKSEL                | TRISA                          | i                                    |
| BSF                    | TRISA,0                        | ;Set RAO to input                    |
| BANKSEL                | ANSEL                          | i                                    |
| BSF                    | ANSEL,0                        | ;Set RAO to analog                   |
| BANKSEL                | WPUA                           | i                                    |
| BCF                    | wpua,0                         | ;Disable weak                        |
|                        | pull-up on R                   | 2A0                                  |
| BANKSEL                | ADCON0                         | ;                                    |
| MOVLW                  | B'0000001'                     | ;Select channel AN0                  |
| MOVWF                  | ADCON0                         | ;Turn ADC On                         |
| CALL                   | SampleTime                     | ;Acquisiton delay                    |
| BSF                    | ADCON0, ADGO                   | ;Start conversion                    |
| BTFSC                  | ADCON0, ADGO                   | ;Is conversion done?                 |
| GOTO                   | \$-1                           | ;No, test again                      |
| BANKSEL                | ADRESH                         | i                                    |
| MOVF                   | ADRESH,W                       | ;Read upper 2 bits                   |
| MOVWF                  | RESULTHI                       | ;store in GPR space                  |
|                        |                                |                                      |

| R/W-0/0                           | R/W-0/0                                                                                                                                                                                                                                                                    | R/W-0/0              | R/W-0/0                            | U-0                                                   | R/W-0/0 | R/W-0/0 | R/W-0/0 |  |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------------------------------------|-------------------------------------------------------|---------|---------|---------|--|
| ADFM                              |                                                                                                                                                                                                                                                                            | ADCS<2:0>            |                                    | _                                                     | ADNREF  | ADPRE   | F<1:0>  |  |
| bit 7                             |                                                                                                                                                                                                                                                                            |                      |                                    |                                                       |         |         | bit 0   |  |
|                                   |                                                                                                                                                                                                                                                                            |                      |                                    |                                                       |         |         |         |  |
| Legend:                           |                                                                                                                                                                                                                                                                            |                      |                                    |                                                       |         |         |         |  |
| R = Readable bit W = Writable bit |                                                                                                                                                                                                                                                                            |                      | U = Unimplemented bit, read as '0' |                                                       |         |         |         |  |
| u = Bit is uncl                   | nanged                                                                                                                                                                                                                                                                     | 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                             | ADFM: ADC Result Format Select bit (see Figure 17-3)<br>1 = 2's complement format.<br>0 = Sign-magnitude result format.                                                                                                                                                    |                      |                                    |                                                       |         |         |         |  |
| bit 6-4                           | ADCS<2:0>: ADC Conversion Clock Select bits<br>111 = FRc (clock supplied from a dedicated FRc oscillator)<br>110 = Fosc/64<br>101 = Fosc/16<br>100 = Fosc/4<br>011 = FRc (clock supplied from a dedicated FRc oscillator)<br>010 = Fosc/32<br>001 = Fosc/8<br>000 = Fosc/2 |                      |                                    |                                                       |         |         |         |  |
| bit 3                             | Unimpleme                                                                                                                                                                                                                                                                  | nted: Read as '0     | )'                                 |                                                       |         |         |         |  |
| bit 2                             | ADNREF: ADC Negative Voltage Reference Configuration bit<br>1 = VREF- is connected to external VREF- pin <sup>(1)</sup><br>0 = VREF- is connected to VSS                                                                                                                   |                      |                                    |                                                       |         |         |         |  |
| bit 1-0                           | ADPREF<1:0>: ADC Positive Voltage Reference Configuration bits<br>11 = VREF+ is connected internally to FVR Buffer 1<br>10 = Reserved<br>01 = VREF+ is connected to VREF+ pin<br>00 = VREF+ is connected to VDD                                                            |                      |                                    |                                                       |         |         |         |  |

**Note 1:** When selecting the FVR or VREF+ pin as the source of the positive reference, be aware that a minimum voltage specification exists. See **Section 31.0 "Electrical Specifications"** for details.

## REGISTER 17-2: ADCON1: ADC CONTROL REGISTER 1

### FIGURE 19-1: DIGITAL-TO-ANALOG CONVERTER BLOCK DIAGRAM







## 24.5 Register Definitions: Timer2 Control

## REGISTER 24-1: T2CON: TIMER2 CONTROL REGISTER

| U-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 |  |  |
|------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------------------|----------------|-------------------------------------------------------|---------|---------|---------|--|--|
| —                                              | T2OUTPS<3:0>                                                                                         |                           |                |                                                       | TMR2ON  | T2CKP   | 'S<1:0> |  |  |
| bit 7                                          |                                                                                                      |                           |                |                                                       |         |         | bit 0   |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| Legend:                                        |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| R = Readable                                   | e bit                                                                                                | W = Writable              | bit            | U = Unimplemented bit, read as '0'                    |         |         |         |  |  |
| u = Bit is unchanged                           |                                                                                                      | x = Bit is unkr           | iown           | -n/n = Value at POR and BOR/Value at all other Resets |         |         |         |  |  |
| '1' = Bit is set                               |                                                                                                      | '0' = Bit is clea         | ared           |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| bit 7                                          | Unimpleme                                                                                            | nted: Read as '           | יט'            |                                                       |         |         |         |  |  |
| bit 6-3                                        | T2OUTPS<3                                                                                            | <b>3:0&gt;:</b> Timer2 Ou | tput Postscale | er Select bits                                        |         |         |         |  |  |
|                                                | 1111 = 1:16                                                                                          | Postscaler                |                |                                                       |         |         |         |  |  |
|                                                | 1110 = 1:15                                                                                          | Postscaler                |                |                                                       |         |         |         |  |  |
|                                                | 1101 = 1:14                                                                                          | Postscaler                |                |                                                       |         |         |         |  |  |
|                                                | 1100 = 1:13 Postscaler                                                                               |                           |                |                                                       |         |         |         |  |  |
|                                                | 1011 = 1:12  Postscaler $1010 = 1:11  Postscaler$ $1001 = 1:10  Postscaler$ $1000 = 1:9  Postscaler$ |                           |                |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
|                                                | 0111 = 1:8 F                                                                                         | Postscaler                |                |                                                       |         |         |         |  |  |
| 0110 = 1:7 F                                   |                                                                                                      | Postscaler                |                |                                                       |         |         |         |  |  |
|                                                | 0101 <b>= 1:6 F</b>                                                                                  | Postscaler                |                |                                                       |         |         |         |  |  |
| 0100 = 1:5 Postscaler<br>0011 = 1:4 Postscaler |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| 0010 = 1:3 Postscaler                          |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| 0001 = 1:2 Postscaler                          |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| <b>h</b> it 0                                  |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
| DIL 2                                          |                                                                                                      | merz On bit               |                |                                                       |         |         |         |  |  |
|                                                | 1 = 11mer21                                                                                          | s on<br>s off             |                |                                                       |         |         |         |  |  |
| hit 1 0                                        |                                                                                                      | 5 Uli<br>Dr. Timor? Clos  | k Drogoolo Sa  | loot hito                                             |         |         |         |  |  |
| DIL I-U                                        | 11 - Drosse                                                                                          |                           | k Flescale Se  |                                                       |         |         |         |  |  |
|                                                |                                                                                                      | er is 64                  |                |                                                       |         |         |         |  |  |
|                                                | 10 = Prescal                                                                                         | eris 10<br>oris 4         |                |                                                       |         |         |         |  |  |
|                                                | 0.0 = Prescal                                                                                        | er is 1                   |                |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |
|                                                |                                                                                                      |                           |                |                                                       |         |         |         |  |  |

## 27.2 SPI Mode Overview

The Serial Peripheral Interface (SPI) bus is a synchronous serial data communication bus that operates in Full-Duplex mode. Devices communicate in a master/slave environment where the master device initiates the communication. A slave device is controlled through a Chip Select known as Slave Select.

The SPI bus specifies four signal connections:

- Serial Clock (SCK)
- Serial Data Out (SDO)
- Serial Data In (SDI)
- Slave Select (SS)

Figure 27-1 shows the block diagram of the MSSP module when operating in SPI mode.

The SPI bus operates with a single master device and one or more slave devices. When multiple slave devices are used, an independent Slave Select connection is required from the master device to each slave device.

Figure 27-4 shows a typical connection between a master device and multiple slave devices.

The master selects only one slave at a time. Most slave devices have tri-state outputs so their output signal appears disconnected from the bus when they are not selected.

Transmissions involve two shift registers, eight bits in size, one in the master and one in the slave. With either the master or the slave device, data is always shifted out one bit at a time, with the Most Significant bit (MSb) shifted out first. At the same time, a new Least Significant bit (LSb) is shifted into the same register.

Figure 27-5 shows a typical connection between two processors configured as master and slave devices.

Data is shifted out of both shift registers on the programmed clock edge and latched on the opposite edge of the clock.

The master device transmits information out on its SDO output pin which is connected to, and received by, the slave's SDI input pin. The slave device transmits information out on its SDO output pin, which is connected to, and received by, the master's SDI input pin.

To begin communication, the master device first sends out the clock signal. Both the master and the slave devices should be configured for the same clock polarity.

The master device starts a transmission by sending out the MSb from its shift register. The slave device reads this bit from that same line and saves it into the LSb position of its shift register. During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the master device is sending out the MSb from its shift register (on its SDO pin) and the slave device is reading this bit and saving it as the LSb of its shift register, that the slave device is also sending out the MSb from its shift register (on its SDO pin) and the master device is reading this bit and saving it as the LSb of its shift register.

After eight bits have been shifted out, the master and slave have exchanged register values.

If there is more data to exchange, the shift registers are loaded with new data and the process repeats itself.

Whether the data is meaningful or not (dummy data), depends on the application software. This leads to three scenarios for data transmission:

- Master sends useful data and slave sends dummy data.
- Master sends useful data and slave sends useful data.
- Master sends dummy data and slave sends useful data.

Transmissions may involve any number of clock cycles. When there is no more data to be transmitted, the master stops sending the clock signal and it deselects the slave.

Every slave device connected to the bus that has not been selected through its slave select line must disregard the clock and transmission signals and must not transmit out any data of its own.



## 28.0 ENHANCED UNIVERSAL SYNCHRONOUS ASYNCHRONOUS RECEIVER TRANSMITTER (EUSART)

The Enhanced Universal Synchronous Asynchronous Receiver Transmitter (EUSART) module is a serial I/O communications peripheral. It contains all the clock generators, shift registers and data buffers necessary to perform an input or output serial data transfer independent of device program execution. The EUSART, also known as a Serial Communications Interface (SCI), can be configured as a full-duplex asynchronous system or half-duplex synchronous system. Full-Duplex mode is useful for communications with peripheral systems, such as CRT terminals and personal computers. Half-Duplex Synchronous mode is intended for communications with peripheral devices, such as A/D or D/A integrated circuits, serial EEPROMs or other microcontrollers. These devices typically do not have internal clocks for baud rate generation and require the external clock signal provided by a master synchronous device.

The EUSART module includes the following capabilities:

- · Full-duplex asynchronous transmit and receive
- Two-character input buffer
- One-character output buffer
- Programmable 8-bit or 9-bit character length
- · Address detection in 9-bit mode
- · Input buffer overrun error detection
- Received character framing error detection
- Half-duplex synchronous master
- · Half-duplex synchronous slave
- Programmable clock polarity in synchronous modes
- · Sleep operation

The EUSART module implements the following additional features, making it ideally suited for use in Local Interconnect Network (LIN) bus systems:

- · Automatic detection and calibration of the baud rate
- Wake-up on Break reception
- 13-bit Break character transmit

Block diagrams of the EUSART transmitter and receiver are shown in Figure 28-1 and Figure 28-2.

### FIGURE 28-1: EUSART TRANSMIT BLOCK DIAGRAM



### 28.1.2 EUSART ASYNCHRONOUS RECEIVER

The Asynchronous mode is typically used in RS-232 systems. The receiver block diagram is shown in Figure 28-2. The data is received on the RX/DT pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all eight or nine bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCREG register.

### 28.1.2.1 Enabling the Receiver

The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits:

- CREN = 1
- SYNC = 0
- SPEN = 1

All other EUSART control bits are assumed to be in their default state.

Setting the CREN bit of the RCSTA register enables the receiver circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART. The programmer must set the corresponding TRIS bit to configure the RX/DT I/O pin as an input.

**Note:** If the RX/DT function is on an analog pin, the corresponding ANSEL bit must be cleared for the receiver to function.

## 28.1.2.2 Receiving Data

The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero then the data recovery circuit aborts character reception, without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position then a framing error is set for this character, otherwise the framing error is cleared for this character. See Section 28.1.2.4 "Receive Framing Error" for more information on framing errors.

Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO and the RCIF interrupt flag bit of the PIR1 register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCREG register.

| Note: | If the receive FIFO is overrun, no additional |  |  |  |  |  |
|-------|-----------------------------------------------|--|--|--|--|--|
|       | characters will be received until the overrun |  |  |  |  |  |
|       | condition is cleared. See Section 28.1.2.5    |  |  |  |  |  |
|       | "Receive Overrun Error" for more              |  |  |  |  |  |
|       | information on overrun errors.                |  |  |  |  |  |

### 28.1.2.3 Receive Interrupts

The RCIF interrupt flag bit of the PIR1 register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCIF interrupt flag bit is read-only, it cannot be set or cleared by software.

RCIF interrupts are enabled by setting all of the following bits:

- RCIE, Interrupt Enable bit of the PIE1 register
- PEIE, Peripheral Interrupt Enable bit of the INTCON register
- GIE, Global Interrupt Enable bit of the INTCON register

The RCIF interrupt flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits.

## TABLE 31-23: I<sup>2</sup>C BUS DATA REQUIREMENTS

| Param.<br>No. | Symbol  | Characteristic             |              | Min.       | Max. | Units | Conditions                                  |  |
|---------------|---------|----------------------------|--------------|------------|------|-------|---------------------------------------------|--|
| SP100*        | Тнідн   | Clock high time            | 100 kHz mode | 4.0        |      | μS    | Device must operate at a minimum of 1.5 MHz |  |
|               |         |                            | 400 kHz mode | 0.6        | _    | μS    | Device must operate at a minimum of 10 MHz  |  |
|               |         |                            | SSP module   | 1.5TCY     | —    |       |                                             |  |
| SP101* TLOW   | TLOW    | Clock low time             | 100 kHz mode | 4.7        | —    | μS    | Device must operate at a minimum of 1.5 MHz |  |
|               |         |                            | 400 kHz mode | 1.3        | _    | μS    | Device must operate at a minimum of 10 MHz  |  |
|               |         |                            | SSP module   | 1.5Tcy     | —    |       |                                             |  |
| SP102*        | TR      | SDA and SCL rise time      | 100 kHz mode | —          | 1000 | ns    |                                             |  |
|               |         |                            | 400 kHz mode | 20 + 0.1Св | 300  | ns    | CB is specified to be from 10-400 pF        |  |
| SP103* TF     | TF      | SDA and SCL fall time      | 100 kHz mode | —          | 250  | ns    |                                             |  |
|               |         |                            | 400 kHz mode | 20 + 0.1Св | 250  | ns    | CB is specified to be from 10-400 pF        |  |
| SP106* THD:D/ | THD:DAT | Data input hold time       | 100 kHz mode | 0          | _    | ns    |                                             |  |
|               |         |                            | 400 kHz mode | 0          | 0.9  | μS    |                                             |  |
| SP107*        | TSU:DAT | Data input setup<br>time   | 100 kHz mode | 250        | —    | ns    | (Note 2)                                    |  |
|               |         |                            | 400 kHz mode | 100        | —    | ns    |                                             |  |
| SP109*        | ΤΑΑ     | Output valid from<br>clock | 100 kHz mode | —          | 3500 | ns    | (Note 1)                                    |  |
|               |         |                            | 400 kHz mode | —          | —    | ns    |                                             |  |
| SP110* -      | TBUF    | Bus free time              | 100 kHz mode | 4.7        | _    | μS    | Time the bus must be free                   |  |
|               |         |                            | 400 kHz mode | 1.3        | —    | μS    | before a new transmission can start         |  |
| SP111         | Св      | Bus capacitive loading     |              |            | 400  | pF    |                                             |  |

### Standard Operating Conditions (unless otherwise stated)

\* These parameters are characterized but not tested.

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

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

## 32.0 DC AND AC CHARACTERISTICS GRAPHS AND CHARTS

The graphs and tables provided in this section are for **design guidance** and are **not tested**.

In some graphs or tables, the data presented are **outside specified operating range** (i.e., outside specified VDD range). This is for **information only** and devices are ensured to operate properly only within the specified range.

Unless otherwise noted, all graphs apply to both the F and LF devices.

**Note:** The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range) and therefore, outside the warranted range.

"Typical" represents the mean of the distribution at 25°C. "Maximum", "Max.", "Minimum" or "Min." represents (mean +  $3\sigma$ ) or (mean -  $3\sigma$ ) respectively, where  $\sigma$  is a standard deviation, over each temperature range.

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

## **Worldwide Sales and Service**

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Austin, TX Tel: 512-257-3370

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

Dallas Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Novi, MI Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

New York, NY Tel: 631-435-6000

San Jose, CA Tel: 408-735-9110

Canada - Toronto Tel: 905-673-0699 Fax: 905-673-6509

### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon

Hong Kong Tel: 852-2943-5100 Fax: 852-2401-3431

Australia - Sydney Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

China - Chengdu Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongqing Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

China - Dongguan Tel: 86-769-8702-9880

**China - Hangzhou** Tel: 86-571-8792-8115 Fax: 86-571-8792-8116

**China - Hong Kong SAR** Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

China - Shanghai Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

**China - Shenyang** Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

### ASIA/PACIFIC

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-3019-1500

Japan - Osaka Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

Malaysia - Penang Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

Singapore Tel: 65-6334-8870 Fax: 65-6334-8850

Taiwan - Hsin Chu Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung Tel: 886-7-213-7828

Taiwan - Taipei Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

Thailand - Bangkok Tel: 66-2-694-1351 Fax: 66-2-694-1350

### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - Dusseldorf Tel: 49-2129-3766400

Germany - Karlsruhe Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

**Italy - Milan** Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Venice Tel: 39-049-7625286

**Netherlands - Drunen** Tel: 31-416-690399 Fax: 31-416-690340

Poland - Warsaw Tel: 48-22-3325737

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**Sweden - Stockholm** Tel: 46-8-5090-4654

**UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820

07/14/15