

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

| Details                    |                                                                             |
|----------------------------|-----------------------------------------------------------------------------|
| Product Status             | Active                                                                      |
| Core Processor             | PIC                                                                         |
| Core Size                  | 8-Bit                                                                       |
| Speed                      | 32MHz                                                                       |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                   |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                       |
| Number of I/O              | 25                                                                          |
| Program Memory Size        | 7KB (4K x 14)                                                               |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | 224 x 8                                                                     |
| RAM Size                   | 512 x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                 |
| Data Converters            | A/D 24x10b; D/A 1x5b                                                        |
| 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/pic16lf15354-i-so |
|                            |                                                                             |

Email: info@E-XFL.COM

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

# PIC16(L)F15354/55

### TABLE 2: PACKAGES

| Device         | (S)PDIP | SOIC | SSOP | UQFN (4x4) | UQFN (6x6) |
|----------------|---------|------|------|------------|------------|
| PIC16(L)F15354 | •       | •    | •    | •          | •          |
| PIC16(L)F15355 | •       | •    | •    | •          | •          |

## 2.5 External Oscillator Pins

Many microcontrollers have options for at least two oscillators: a high-frequency primary oscillator and a low-frequency secondary oscillator (refer to Section 9.0 "Oscillator Module (with Fail-Safe Clock Monitor)" for details).

The oscillator circuit should be placed on the same side of the board as the device. Place the oscillator circuit close to the respective oscillator pins with no more than 0.5 inch (12 mm) between the circuit components and the pins. The load capacitors should be placed next to the oscillator itself, on the same side of the board.

Use a grounded copper pour around the oscillator circuit to isolate it from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed.

Layout suggestions are shown in Figure 2-3. In-line packages may be handled with a single-sided layout that completely encompasses the oscillator pins. With fine-pitch packages, it is not always possible to completely surround the pins and components. A suitable solution is to tie the broken guard sections to a mirrored ground layer. In all cases, the guard trace(s) must be returned to ground.

In planning the application's routing and I/O assignments, ensure that adjacent port pins, and other signals in close proximity to the oscillator, are benign (i.e., free of high frequencies, short rise and fall times, and other similar noise).

For additional information and design guidance on oscillator circuits, please refer to these Microchip Application Notes, available at the corporate web site (www.microchip.com):

- AN826, "Crystal Oscillator Basics and Crystal Selection for rfPIC<sup>™</sup> and PICmicro<sup>®</sup> Devices"
- AN849, "Basic PICmicro<sup>®</sup> Oscillator Design"
- AN943, "Practical PICmicro<sup>®</sup> Oscillator Analysis and Design"
- AN949, "Making Your Oscillator Work"

# 2.6 Unused I/Os

Unused I/O pins should be configured as outputs and driven to a logic low state. Alternatively, connect a 1 k $\Omega$  to 10 k $\Omega$  resistor to Vss on unused pins and drive the output to logic low.





| Address | Name                                                                                   | Bit 7                                    | Bit 6      | Bit 5   | Bit 4         | Bit 3             | Bit 2     | Bit 1      | Bit 0     | Value on:<br>POR, BOR | V <u>alue o</u> n:<br>MCLR |  |
|---------|----------------------------------------------------------------------------------------|------------------------------------------|------------|---------|---------------|-------------------|-----------|------------|-----------|-----------------------|----------------------------|--|
| Bank 11 |                                                                                        |                                          |            |         |               |                   |           |            |           |                       |                            |  |
|         |                                                                                        |                                          |            | CPU COF | RE REGISTERS; | see Table 4-3 for | specifics |            |           |                       |                            |  |
| 58Ch    | n NCO1ACCL NCO1ACC<7:0>                                                                |                                          |            |         |               |                   |           |            |           |                       |                            |  |
| 58Dh    | NCO1ACCH                                                                               |                                          |            |         | NCO1AC        | C<15:8>           |           |            |           | 0000 0000             | 0000 0000                  |  |
| 58Eh    | NCO1ACCU                                                                               | _                                        | _          | —       | _             |                   | NCO1      | ACC<19:16> |           | 0000                  | 0000                       |  |
| 58Fh    | NCO1INCL                                                                               |                                          |            |         | NCO1IN        | C<7:0>            |           |            |           | 0000 0001             | 0000 0001                  |  |
| 590h    |                                                                                        |                                          |            |         |               |                   |           |            |           | 0000 0000             | 0000 0000                  |  |
| 591h    | NCO1INCU                                                                               | _                                        | _          | _       |               |                   | NCO1      | INC<19:16> |           | 0000                  | 0000                       |  |
| 592h    | NCO1CON                                                                                | N1EN                                     | _          | N1OUT   | N1POL         | _                 | _         | _          | N1PFM     | 0-000                 | 0-000                      |  |
| 593h    | NCO1CLK                                                                                |                                          | N1PWS<2:0> |         | _             | —                 |           | N1CKS<2:0> | >         | 000000                | 000000                     |  |
| 594h    | —                                                                                      |                                          |            |         | Unimpler      | nented            |           |            |           |                       |                            |  |
| 595h    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 596h    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 597h    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 598h    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 599h    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 59Ah    | —                                                                                      |                                          |            |         | Unimpler      | mented            |           |            |           |                       |                            |  |
| 59Bh    | DBh — Unimplemented                                                                    |                                          |            |         |               |                   |           |            |           |                       |                            |  |
| 59Ch    | i9Ch TMR0L Holding Register for the Least Significant Byte of the 16-bit TMR0 Register |                                          |            |         |               |                   |           |            | 0000 0000 | 0000 0000             |                            |  |
| 59Dh    | 9Dh TMR0H Holding Register for the Most Significant Byte of the 16-bit TMR0 Register   |                                          |            |         |               |                   |           |            | 1111 1111 | 1111 1111             |                            |  |
| 59Eh    | T0CON0                                                                                 | TOCONO TOEN — TOOUT TO16BIT TOOUTPS<3:0> |            |         |               |                   |           |            | 0-00 0000 | 0-00 0000             |                            |  |
| 59Fh    | T0CON1                                                                                 |                                          | T0CS<2:0>  |         | TOASYNC       |                   | TOC       | KPS<3:0>   |           | 0000 0000             | 0000 0000                  |  |

## TABLE 4-10: SPECIAL FUNCTION REGISTER SUMMARY BANKS 0-63 (CONTINUED)

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

# 6.0 DEVICE INFORMATION AREA

The Device Information Area (DIA) is a dedicated region in the program memory space; it is a new feature in the PIC16(L)F15354/55 family of devices. The DIA contains the calibration data for the internal temperature indicator module, stores the Microchip Unique Identifier words and the Fixed Voltage Reference voltage readings measured in mV.

The complete DIA table is shown in Table 6-1: Device Information Area, followed by a description of each region and its functionality. The data is mapped from 8100h to 811Fh in the PIC16(L)F15354/55 family. These locations are read-only and cannot be erased or modified. The data is programmed into the device during manufacturing.

| Address Range | Name of Region        | Standard Device Information                           |  |  |  |  |  |
|---------------|-----------------------|-------------------------------------------------------|--|--|--|--|--|
|               | MUI0                  |                                                       |  |  |  |  |  |
|               | MUI1                  |                                                       |  |  |  |  |  |
|               | MUI2                  |                                                       |  |  |  |  |  |
|               | MUI3                  | Microchip Unique Identifier (9 Words)                 |  |  |  |  |  |
| 8100h-8108h   | MUI4                  |                                                       |  |  |  |  |  |
|               | MUI5                  |                                                       |  |  |  |  |  |
|               | MUI6                  |                                                       |  |  |  |  |  |
|               | MUI7                  |                                                       |  |  |  |  |  |
|               | MUI8                  |                                                       |  |  |  |  |  |
| 8109h         | MUI9                  | 1 Word Reserved                                       |  |  |  |  |  |
|               | EUI0                  |                                                       |  |  |  |  |  |
|               | EUI1                  |                                                       |  |  |  |  |  |
|               | EUI2                  |                                                       |  |  |  |  |  |
| 310Ah-8111h - | EUI3                  |                                                       |  |  |  |  |  |
|               | EUI4                  | Unused (8 Words)                                      |  |  |  |  |  |
|               | EUI5                  |                                                       |  |  |  |  |  |
|               | EUI6                  |                                                       |  |  |  |  |  |
|               | EUI7                  |                                                       |  |  |  |  |  |
| 8112h         | TSLR1                 | Temperature Sensor (low range setting)                |  |  |  |  |  |
| 8113h         | TSLR2                 | @ 30°C and @ 90°C (2 Words)                           |  |  |  |  |  |
| 8114h         | TSLR3                 | Unused (1 word)                                       |  |  |  |  |  |
| 8115h         | TSHR1                 | Temperature Sensor (high range setting)               |  |  |  |  |  |
| 8116h         | TSHR2                 | @ 30°C and @ 90°C (2 Words)                           |  |  |  |  |  |
| 8117h         | TSHR3                 | Unused (1 Word)                                       |  |  |  |  |  |
| 8118h         | FVRA1X                | ADC FVR1 Output voltage for 1x setting (in mV)        |  |  |  |  |  |
| 8119h         | FVRA2X                | ADC FVR1 Output Voltage for 2x setting (in mV)        |  |  |  |  |  |
| 811Ah         | FVRA4X <sup>(1)</sup> | ADC FVR1 Output Voltage for 4x setting (in mV)        |  |  |  |  |  |
| 811Bh         | FVRC1X                | Comparator FVR2 output voltage for 1x setting (in mV) |  |  |  |  |  |
| 811Ch         | FVRC2X                | Comparator FVR2 output voltage for 2x setting (in mV) |  |  |  |  |  |
| 811Dh         | FVRC4X <sup>(1)</sup> | Comparator FVR2 output voltage for 4x setting (in mV) |  |  |  |  |  |
| 811Eh-811Fh   |                       | Unused (1 Word)                                       |  |  |  |  |  |

**Note 1:** Value not present on LF devices.

### 8.12 Memory Execution Violation

A Memory Execution Violation Reset occurs if executing an instruction being fetched from outside the valid execution area. The different valid execution areas are defined as follows:

- Flash Memory: Table 4-1 shows the addresses available on the PIC16(L)F15354/55 devices based on user flash size. Execution outside this region generates a memory execution violation.
- Storage Area Flash (SAF): If Storage Area Flash (SAF) is enabled (Section 4.2.3 "Storage Area Flash"), the SAF area (Table 4-2) is not a valid execution area.

Prefetched instructions that are not executed do not cause memory execution violations. For example, a GOTO instruction in the last memory location will prefetch from an invalid location; this is not an error. If an instruction from an invalid location tries to execute, the memory violation is generated immediately, and any concurrent interrupt requests are ignored. When a memory execution violation is generated, the device is reset and flag MEMV is cleared in PCON1 (Register 8-3) to signal the cause. The flag needs to be set in code after a memory execution violation

| 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      |
|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|------------------|------------------|--------------|
| RC2IE            | TX2IE          | RC1IE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TX1IE          | BCL2IE           | SSP2IE           | BCL1IE           | SSP1IE       |
| bit 7            |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                |                  |                  |                  | bit 0        |
|                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                |                  |                  |                  |              |
| Legend:          |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                |                  |                  |                  |              |
| R = Readable     |                | W = Writable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | bit            | U = Unimpler     | mented bit, read | l as '0'         |              |
| u = Bit is unch  | anged          | x = Bit is unkr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                | -n/n = Value a   | at POR and BO    | R/Value at all c | other Resets |
| '1' = Bit is set |                | '0' = Bit is clea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ared           |                  |                  |                  |              |
|                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                |                  |                  |                  |              |
| bit 7            |                | RT Receive Inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •              | bit              |                  |                  |              |
|                  |                | the USART rec<br>the USART rec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |                  |                  |                  |              |
| bit 6            |                | RT Transmit Inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | •              | bit              |                  |                  |              |
|                  |                | the USART tra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | •              |                  |                  |                  |              |
|                  | 0 = Disables   | the USART tra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | nsmit interrup | ot               |                  |                  |              |
| bit 5            | RC1IE: USAF    | RT Receive Inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | errupt Enable  | bit              |                  |                  |              |
|                  |                | the USART rec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | •              |                  |                  |                  |              |
| bit 4            |                | the USART rec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | •              | hit              |                  |                  |              |
| DIL 4            |                | RT Transmit Intention the USART training the USART training the training term of the training term of the training term of the training term of the term of te |                |                  |                  |                  |              |
|                  |                | the USART tra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                |                  |                  |                  |              |
| bit 3            | BCL2IE: MSS    | SP2 Bus Collisi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | on Interrupt E | nable bit        |                  |                  |              |
|                  |                | us Collision inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |                  |                  |                  |              |
|                  |                | us Collision inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | •              |                  |                  |                  |              |
| bit 2            |                | chronous Seria                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                | 2) Interrupt Ena | able bit         |                  |              |
|                  |                | us collision Inte<br>the MSSP Inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                |                  |                  |                  |              |
| bit 1            |                | SP1 Bus Collisi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •              | nable bit        |                  |                  |              |
|                  |                | us collision inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                |                  |                  |                  |              |
|                  | 0 = MSSP bu    | us collision inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | rrupt disabled |                  |                  |                  |              |
| bit 0            | SSP1IE: Syne   | chronous Seria                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | I Port (MSSP   | 1) Interrupt Ena | able bit         |                  |              |
|                  |                | the MSSP inter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                |                  |                  |                  |              |
|                  | 0 = Disables   | the MSSP inte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | rrupt          |                  |                  |                  |              |
|                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                |                  |                  |                  |              |
| Note: Bit        | PEIE of the IN | TCON register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | must be        |                  |                  |                  |              |

## REGISTER 10-5: PIE3: PERIPHERAL INTERRUPT ENABLE REGISTER 3

**Note:** Bit PEIE of the INTCON register must be set to enable any peripheral interrupt controlled by PIE1-PIE7.

| R/W-0/       | 0 R/W-0/0                                       | R/W-0/0                                                                                                | R/W-0/0                        | U-0            | U-0              | R/W-0/0             | R/W-0/0      |
|--------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------|----------------|------------------|---------------------|--------------|
| ADFN         | 1                                               | ADCS<2:0>                                                                                              |                                | —              | —                | ADPRE               | EF<1:0>      |
| bit 7        |                                                 |                                                                                                        |                                |                |                  |                     | bit          |
| Legend:      |                                                 |                                                                                                        |                                |                |                  |                     |              |
| R = Read     | able bit                                        | W = Writable b                                                                                         | bit                            | U = Unimpler   | mented bit, read | 1 as '0'            |              |
| u = Bit is u | unchanged                                       | x = Bit is unkn                                                                                        | own                            | -n/n = Value a | at POR and BO    | R/Value at all      | other Resets |
| '1' = Bit is | set                                             | '0' = Bit is clea                                                                                      | red                            |                |                  |                     |              |
| bit 7        | 1 = Right<br>loade                              | ustified. Six Least                                                                                    | Significant bi                 |                |                  |                     |              |
| bit 6-4      | 111 = AD<br>110 = Fos<br>101 = Fos<br>100 = Fos | sc/16<br>sc/4<br>CRC (dedicated R<br>sc/32<br>sc/8                                                     | C oscillator)                  | ct bits        |                  |                     |              |
| bit 3-2      | Unimplem                                        | nented: Read as '0                                                                                     | ,                              |                |                  |                     |              |
| bit 1-0      | 11 = VREF<br>10 = VREF<br>01 = Rese             | <b>c1:0&gt;:</b> ADC Positiv<br>+ is connected to i<br>+ is connected to<br>erved<br>+ is connected to | nternal Fixed<br>external VREF | Voltage Refere |                  | dule <sup>(1)</sup> |              |
| Note 1:      | -                                               | the VREF+ pin as<br>tists. See Table 37                                                                |                                |                | erence, be awa   | are that a minin    | num voltage  |

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

| R/W-0/u                                                                                                                                                                          | R/W-0/u                                                                                                                                                                                                                                                                                                          | R/W-0/u                                                            | R/W-0/u                         | R/W/HC-0/u                             | R-x/x           | U-0              | U-0          |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------|----------------------------------------|-----------------|------------------|--------------|--|
| GE                                                                                                                                                                               | GPOL                                                                                                                                                                                                                                                                                                             | GTM                                                                | GSPM                            | GGO/DONE                               | GVAL            | —                | _            |  |
| bit 7                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                  |                                                                    |                                 |                                        |                 |                  | bit 0        |  |
|                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                  |                                                                    |                                 |                                        |                 |                  |              |  |
| Legend:                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                  |                                                                    |                                 |                                        |                 |                  |              |  |
| R = Readable                                                                                                                                                                     | bit                                                                                                                                                                                                                                                                                                              | W = Writable                                                       | bit                             | U = Unimpleme                          | ented bit, read | l as '0'         |              |  |
| u = Bit is uncha                                                                                                                                                                 | anged                                                                                                                                                                                                                                                                                                            | x = Bit is unkr                                                    | nown                            | -n/n = Value at                        | POR and BO      | R/Value at all o | other Resets |  |
| '1' = Bit is set                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                  | '0' = Bit is clea                                                  | ared                            | HC = Bit is clea                       | red by hardw    | are              |              |  |
| bit 7                                                                                                                                                                            | $\frac{\text{If ON = 0}}{\text{This bit is ignormalized}}$ $\frac{\text{If ON = 1}}{1 = \text{Timer1 cont}}$                                                                                                                                                                                                     |                                                                    | rolled by the T                 | -<br>imer1 gate functi                 | on              |                  |              |  |
| bit 6                                                                                                                                                                            | 1 = Timer1 g                                                                                                                                                                                                                                                                                                     |                                                                    | gh (Timer1 co                   | unts when gate is<br>ints when gate is |                 |                  |              |  |
| bit 5                                                                                                                                                                            | 1 = Timer1 G<br>0 = Timer1 G                                                                                                                                                                                                                                                                                     | Gate Toggle M<br>ate Toggle mo<br>ate Toggle mo<br>ip-flop toggles | de is enabled<br>de is disabled | and toggle flip-flo                    | op is cleared   |                  |              |  |
| bit 4                                                                                                                                                                            | <b>GSPM:</b> Timer<br>1 = Timer1 G                                                                                                                                                                                                                                                                               | 1 Gate Single-<br>ate Single-Pul<br>ate Single-Pul                 | Pulse Mode b<br>se mode is er   | oit<br>nabled                          |                 |                  |              |  |
| bit 3                                                                                                                                                                            | <ul> <li>GGO/DONE: Timer1 Gate Single-Pulse Acquisition Status bit</li> <li>1 = Timer1 gate single-pulse acquisition is ready, waiting for an edge</li> <li>0 = Timer1 gate single-pulse acquisition has completed or has not been started<br/>This bit is automatically cleared when GSPM is cleared</li> </ul> |                                                                    |                                 |                                        |                 |                  |              |  |
| bit 2 <b>GVAL:</b> Timer1 Gate Value Status bit<br>Indicates the current state of the Timer1 gate that could be provided to TMR1H:TMR1L<br>Unaffected by Timer1 Gate Enable (GE) |                                                                                                                                                                                                                                                                                                                  |                                                                    |                                 |                                        |                 |                  |              |  |
| bit 1-0                                                                                                                                                                          | Unimplemen                                                                                                                                                                                                                                                                                                       | ted: Read as '                                                     | 0'                              |                                        |                 |                  |              |  |

### REGISTER 26-2: T1GCON: TIMER1 GATE CONTROL REGISTER

# PIC16(L)F15354/55

### FIGURE 28-4: SIMPLIFIED PWM BLOCK DIAGRAM



### 28.3.2 SETUP FOR PWM OPERATION

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

- Use the desired output pin RxyPPS control to select CCPx as the source and 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 CCPRxH register with the PWM duty cycle value and configure the CCPxFMT bit of the CCPxCON register to set the proper register alignment.
- 5. Configure and start Timer2:
  - Clear the TMR2IF interrupt flag bit of the PIR4 register. See Note below.
  - Configure the CKPS bits of the T2CON register with the Timer prescale value.
  - Enable the Timer by setting the Timer2 ON bit of the T2CON register.

- 6. Enable PWM output pin:
  - Wait until the Timer overflows and the TMR2IF bit of the PIR4 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.

### 28.3.3 CCP/PWM CLOCK SELECTION

The PIC16(L)F15354/55 allows each individual CCP and PWM module to select the timer source that controls the module. Each module has an independent selection.

PIC16(L)F15354/55

### 30.8 Dead-Band Uncertainty

When the rising and falling edges of the input source are asynchronous to the CWG clock, it creates uncertainty in the dead-band time delay. The maximum uncertainty is equal to one CWG clock period. Refer to Equation 30-1 for more details.

### EQUATION 30-1: DEAD-BAND UNCERTAINTY





# FIGURE 30-8: EXAMPLE OF PWM DIRECTION CHANGE





| R/W-0/0                                                                                                                                                               | U-0         | U-0                                    | U-0            | R/W-x/u        | R/W-x/u          | R/W-x/u          | R/W-x/u      |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------|----------------|----------------|------------------|------------------|--------------|
| LCxPOL                                                                                                                                                                |             | —                                      |                | LCxG4POL       | LCxG3POL         | LCxG2POL         | LCxG1POL     |
| bit 7                                                                                                                                                                 |             |                                        |                |                |                  |                  | bit 0        |
|                                                                                                                                                                       |             |                                        |                |                |                  |                  |              |
| Legend:                                                                                                                                                               |             |                                        |                |                |                  |                  |              |
| R = Readable                                                                                                                                                          | bit         | W = Writable                           | bit            | U = Unimpler   | mented bit, read | l as '0'         |              |
| u = Bit is uncha                                                                                                                                                      | anged       | x = Bit is unkn                        | iown           | -n/n = Value a | at POR and BO    | R/Value at all c | other Resets |
| '1' = Bit is set                                                                                                                                                      |             | '0' = Bit is clea                      | ared           |                |                  |                  |              |
|                                                                                                                                                                       |             |                                        |                |                |                  |                  |              |
| bit 7                                                                                                                                                                 | LCxPOL: CLO | CxOUT Output                           | Polarity Cont  | rol bit        |                  |                  |              |
|                                                                                                                                                                       |             | ut of the logic c                      |                |                |                  |                  |              |
|                                                                                                                                                                       | •           | ut of the logic c                      |                | erted          |                  |                  |              |
| bit 6-4                                                                                                                                                               | Unimplemen  | ted: Read as '                         | כ'             |                |                  |                  |              |
| bit 3                                                                                                                                                                 |             | Gate 3 Output I                        |                |                |                  |                  |              |
|                                                                                                                                                                       |             | •                                      |                | applied to the | logic cell       |                  |              |
|                                                                                                                                                                       | •           | ut of gate 3 is r                      |                |                |                  |                  |              |
| bit 2                                                                                                                                                                 |             | Gate 2 Output I                        | -              |                |                  |                  |              |
|                                                                                                                                                                       | •           | ut of gate 2 is i<br>ut of gate 2 is r |                | applied to the | logic cell       |                  |              |
| bit 1                                                                                                                                                                 | LCxG2POL:   | Gate 1 Output I                        | Polarity Conti | ol bit         |                  |                  |              |
| <ul> <li>1 = The output of gate 1 is inverted when applied to the logic cell</li> <li>0 = The output of gate 1 is not inverted</li> </ul>                             |             |                                        |                |                |                  |                  |              |
| bit 0                                                                                                                                                                 | LCxG1POL:   | Gate 0 Output I                        | Polarity Conti | rol bit        |                  |                  |              |
| bit 0 LCxG1POL: Gate 0 Output Polarity Control bit<br>1 = The output of gate 0 is inverted when applied to the logic cell<br>0 = The output of gate 0 is not inverted |             |                                        |                |                |                  |                  |              |

### REGISTER 31-2: CLCxPOL: SIGNAL POLARITY CONTROL REGISTER

### TABLE 31-4: SUMMARY OF REGISTERS ASSOCIATED WITH CLCx

| Name     | Bit 7  | Bit 6  | Bit 5    | Bit 4       | Bit 3          | Bit 2    | Bit 1        | Bit 0    | Register<br>on Page |
|----------|--------|--------|----------|-------------|----------------|----------|--------------|----------|---------------------|
| INTCON   | GIE    | PEIE   | _        | _           | _              | _        | _            | INTEDG   | 119                 |
| PIR5     | CLC4IF | CLC3IF | CLC2IF   | CLC1IF      | _              | _        | _            | TMR1GIF  | 133                 |
| PIE5     | CLC4IE | CLC4IE | CLC2IE   | CLC1IE      | _              | _        | _            | TMR1GIE  | 125                 |
| CLC1CON  | LC1EN  | _      | LC10UT   | LC1INTP     | LC1INTN        |          | LC1MODE<2:0  | 361      |                     |
| CLC1POL  | LC1POL | _      | _        | _           | LC1G4POL       | LC1G3POL | LC1G2POL     | LC1G1POL | 362                 |
| CLC1SEL0 | _      | _      |          |             | LC1D           | 1S<5:0>  | 1            | 1        | 363                 |
| CLC1SEL1 | _      |        |          |             | LC1D           | 2S<5:0>  |              |          | 363                 |
| CLC1SEL2 | _      | _      |          |             | LC1D           | 3S<5:0>  |              |          | 363                 |
| CLC1SEL3 | _      | _      |          |             | LC1D           | 4S<5:0>  |              |          | 363                 |
| CLC1GLS0 | _      | _      | LC1G1D3T | LC1G1D3N    | LC1G1D2T       | LC1G1D2N | LC1G1D1T     | LC1G1D1N | 364                 |
| CLC1GLS1 | _      | _      | LC1G2D3T | LC1G2D3N    | LC1G2D2T       | LC1G2D2N | LC1G2D1T     | LC1G2D1N | 365                 |
| CLC1GLS2 | _      | _      | LC1G3D3T | LC1G3D3N    | LC1G3D2T       | LC1G3D2N | LC1G3D1T     | LC1G3D1N | 366                 |
| CLC1GLS3 | _      | _      | LC1G4D3T | LC1G4D3N    | LC1G4D2T       | LC1G4D2N | LC1G4D1T     | LC1G4D1N | 367                 |
| CLC2CON  | LC2EN  | _      | LC2OUT   | LC2INTP     | LC2INTN        |          | LC2MODE<2:0  | >        | 361                 |
| CLC2POL  | LC2POL | _      | _        | —           | LC2G4POL       | LC2G3POL | LC2G2POL     | LC2G1POL | 362                 |
| CLC2SEL0 | _      | _      |          | LC2D1S<5:0> |                |          |              |          |                     |
| CLC2SEL1 | _      | _      |          |             | LC2D           | 2S<5:0>  |              |          | 363                 |
| CLC2SEL2 | _      | _      |          |             | LC2D           | 3S<5:0>  |              |          | 363                 |
| CLC2SEL3 | _      | _      |          |             | LC2D           | 4S<5:0>  |              |          | 363                 |
| CLC2GLS0 | _      | _      | LC2G1D3T | LC2G1D3N    | LC2G1D2T       | LC2G1D2N | LC2G1D1T     | LC2G1D1N | 364                 |
| CLC2GLS1 | —      | _      | LC2G2D3T | LC2G2D3N    | LC2G2D2T       | LC2G2D2N | LC2G2D1T     | LC2G2D1N | 365                 |
| CLC2GLS2 | —      | _      | LC2G3D3T | LC2G3D3N    | LC2G3D2T       | LC2G3D2N | LC2G3D1T     | LC2G3D1N | 366                 |
| CLC2GLS3 | _      | _      | LC2G4D3T | LC2G4D3N    | LC2G4D2T       | LC2G4D2N | LC2G4D1T     | LC2G4D1N | 367                 |
| CLC3CON  | LC3EN  | _      | LC3OUT   | LC3INTP     | <b>LC3INTN</b> |          | LC3MODE<2:0  | >        | 361                 |
| CLC3POL  | LC3POL | _      | _        | —           | LC3G4POL       | LC3G3POL | LC3G2POL     | LC3G1POL | 362                 |
| CLC3SEL0 | —      | _      |          |             | LC3D           | 1S<5:0>  |              |          | 363                 |
| CLC3SEL1 | _      | _      |          |             | LC3D           | 2S<5:0>  |              |          | 363                 |
| CLC3SEL2 | _      | _      |          |             | LC3D           | 3S<5:0>  |              |          | 363                 |
| CLC3SEL3 | —      | _      |          |             | LC3D           | 4S<5:0>  |              |          | 363                 |
| CLC3GLS0 | _      | _      | LC3G1D3T | LC3G1D3N    | LC3G1D2T       | LC3G1D2N | LC3G1D1T     | LC3G1D1N | 364                 |
| CLC3GLS1 | _      | _      | LC3G2D3T | LC3G2D3N    | LC3G2D2T       | LC3G2D2N | LC3G2D1T     | LC3G2D1N | 365                 |
| CLC3GLS2 | _      | _      | LC3G3D3T | LC3G3D3N    | LC3G3D2T       | LC3G3D2N | LC3G3D1T     | LC3G3D1N | 366                 |
| CLC3GLS3 | _      | _      | LC3G4D3T | LC3G4D3N    | LC3G4D2T       | LC3G4D2N | LC3G4D1T     | LC3G4D1N | 367                 |
| CLC4CON  | LC4EN  | _      | LC4OUT   | LC4INTP     | LC4INTN        |          | LC4MODE<2:0> | >        | 361                 |
| CLC4POL  | LC4POL | _      | _        | _           | LC4G4POL       | LC4G3POL | LC4G2POL     | LC4G1POL | 362                 |
| CLC4SEL0 | _      | _      |          |             | LC4D           | 1S<5:0>  |              | 1        | 363                 |
| CLC4SEL1 | _      | _      |          |             | LC4D           | 2S<5:0>  |              |          | 363                 |
| CLC4SEL2 | _      | _      |          |             | LC4D           | 3S<5:0>  |              |          | 363                 |
| CLC4SEL3 | _      | _      |          |             | LC4D           | 4S<5:0>  |              |          | 363                 |
| CLC4GLS0 | _      | _      | LC4G1D3T | LC4G1D3N    | LC4G1D2T       | LC4G1D2N | LC4G1D1T     | LC4G1D1N | 364                 |

### 32.2.6 SPI OPERATION IN SLEEP MODE

In SPI Master mode, module clocks may be operating at a different speed than when in Full-Power mode; in the case of the Sleep mode, all clocks are halted.

In SPI Master mode, when the Sleep mode is selected, all module clocks are halted and the transmission/reception will remain in that state until the device wakes. After the device returns to Run mode, the module will resume transmitting and receiving data.

In SPI Slave mode, the SPI Transmit/Receive Shift register operates asynchronously to the device. This allows the device to be placed in Sleep mode and data to be shifted into the SPI Transmit/Receive Shift register. When all eight bits have been received, the MSSP interrupt flag bit will be set and if enabled, will wake the device.

# 32.3 I<sup>2</sup>C MODE OVERVIEW

The Inter-Integrated Circuit  $(I^2C)$  bus is a multi-master serial data communication bus. Devices communicate in a master/slave environment where the master devices initiate the communication. A slave device is controlled through addressing.

The I<sup>2</sup>C bus specifies two signal connections:

- · Serial Clock (SCL)
- · Serial Data (SDA)

Figure 32-11 shows the block diagram of the MSSP module when operating in  $I^2C$  mode.

Both the SCL and SDA connections are bidirectional open-drain lines, each requiring pull-up resistors for the supply voltage. Pulling the line to ground is considered a logical zero and letting the line float is considered a logical one.

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

The I<sup>2</sup>C bus can operate with one or more master devices and one or more slave devices.

There are four potential modes of operation for a given device:

- Master Transmit mode (master is transmitting data to a slave)
- Master Receive mode (master is receiving data from a slave)
- Slave Transmit mode (slave is transmitting data to a master)
- Slave Receive mode (slave is receiving data from the master)

To begin communication, a master device starts out in Master Transmit mode. The master device sends out a Start bit followed by the address byte of the slave it intends to communicate with. This is followed by a single Read/Write bit, which determines whether the master intends to transmit to or receive data from the slave device.

If the requested slave exists on the bus, it will respond with an Acknowledge bit, otherwise known as an ACK. The master then continues in either Transmit mode or Receive mode and the slave continues in the complement, either in Receive mode or Transmit mode, respectively.

## FIGURE 32-11: I<sup>2</sup>C MASTER/ SLAVE CONNECTION



The Acknowledge bit  $(\overline{ACK})$  is an active-low signal, which holds the SDA line low to indicate to the transmitter that the slave device has received the transmitted data and is ready to receive more.

The transition of a data bit is always performed while the SCL line is held low. Transitions that occur while the SCL line is held high are used to indicate Start and Stop bits.

On the last byte of data communicated, the master device may end the transmission by sending a Stop bit. If the master device is in Receive mode, it sends the Stop bit in place of the last ACK bit. A Stop bit is indicated by a low-to-high transition of the SDA line while the SCL line is held high.

In some cases, the master may want to maintain control of the bus and re-initiate another transmission. If so, the master device may send another Start bit in place of the Stop bit.

# PIC16(L)F15354/55

# 32.6.13.1 Bus Collision During a Start Condition

During a Start condition, a bus collision occurs if:

- a) SDA or SCL are sampled low at the beginning of the Start condition (Figure 32-33).
- b) SCL is sampled low before SDA is asserted low (Figure 32-34).

During a Start condition, both the SDA and the SCL pins are monitored.

If the SDA pin is already low, or the SCL pin is already low, then all of the following occur:

- the Start condition is aborted,
- the BCL1IF flag is set and
- the MSSP module is reset to its Idle state (Figure 32-33).

The Start condition begins with the SDA and SCL pins deasserted. When the SDA pin is sampled high, the Baud Rate Generator is loaded and counts down. If the SCL pin is sampled low while SDA is high, a bus collision occurs because it is assumed that another master is attempting to drive a data '1' during the Start condition.

If the SDA pin is sampled low during this count, the BRG is reset and the SDA line is asserted early (Figure 32-35). If, however, a '1' is sampled on the SDA pin, the SDA pin is asserted low at the end of the BRG count. The Baud Rate Generator is then reloaded and counts down to zero; if the SCL pin is sampled as '0' during this time, a bus collision does not occur. At the end of the BRG count, the SCL pin is asserted low.

Note: The reason that bus collision is not a factor during a Start condition is that no two bus masters can assert a Start condition at the exact same time. Therefore, one master will always assert SDA before the other. This condition does not cause a bus collision because the two masters must be allowed to arbitrate the first address following the Start condition. If the address is the same, arbitration must be allowed to continue into the data portion, Repeated Start or Stop conditions.



### FIGURE 32-33: BUS COLLISION DURING START CONDITION (SDA ONLY)

### 33.1.2.3 Receive Interrupts

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

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

- RXxIE, Interrupt Enable bit of the PIE3 register
- PEIE, Peripheral Interrupt Enable bit of the INTCON register
- GIE, Global Interrupt Enable bit of the INTCON register

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

### 33.1.2.4 Receive Framing Error

Each character in the receive FIFO buffer has a corresponding framing error Status bit. A framing error indicates that a Stop bit was not seen at the expected time. The framing error status is accessed via the FERR bit of the RCxSTA register. The FERR bit represents the status of the top unread character in the receive FIFO. Therefore, the FERR bit must be read before reading the RCxREG.

The FERR bit is read-only and only applies to the top unread character in the receive FIFO. A framing error (FERR = 1) does not preclude reception of additional characters. It is not necessary to clear the FERR bit. Reading the next character from the FIFO buffer will advance the FIFO to the next character and the next corresponding framing error.

The FERR bit can be forced clear by clearing the SPEN bit of the RCxSTA register which resets the EUSART. Clearing the CREN bit of the RCxSTA register does not affect the FERR bit. A framing error by itself does not generate an interrupt.

| Note: | If all receive characters in the receive   |
|-------|--------------------------------------------|
|       | FIFO have framing errors, repeated reads   |
|       | of the RCxREG will not clear the FERR bit. |

### 33.1.2.5 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before the FIFO is accessed. When this happens the OERR bit of the RCxSTA register is set. The characters already in the FIFO buffer can be read but no additional characters will be received until the error is cleared. The error must be cleared by either clearing the CREN bit of the RCxSTA register or by resetting the EUSART by clearing the SPEN bit of the RCxSTA register.

### 33.1.2.6 Receiving 9-Bit Characters

The EUSART supports 9-bit character reception. When the RX9 bit of the RCxSTA register is set the EUSART will shift nine bits into the RSR for each character received. The RX9D bit of the RCxSTA register is the ninth and Most Significant data bit of the top unread character in the receive FIFO. When reading 9-bit data from the receive FIFO buffer, the RX9D data bit must be read before reading the eight Least Significant bits from the RCxREG.

### 33.1.2.7 Address Detection

A special Address Detection mode is available for use when multiple receivers share the same transmission line, such as in RS-485 systems. Address detection is enabled by setting the ADDEN bit of the RCxSTA register.

Address detection requires 9-bit character reception. When address detection is enabled, only characters with the ninth data bit set will be transferred to the receive FIFO buffer, thereby setting the RXxIF interrupt bit. All other characters will be ignored.

Upon receiving an address character, user software determines if the address matches its own. Upon address match, user software must disable address detection by clearing the ADDEN bit before the next Stop bit occurs. When user software detects the end of the message, determined by the message protocol used, software places the receiver back into the Address Detection mode by setting the ADDEN bit.

### 33.3.5 RECEIVING A BREAK CHARACTER

The Enhanced EUSART module can receive a Break character in two ways.

The first method to detect a Break character uses the FERR bit of the RCxSTA register and the received data as indicated by RCxREG. The Baud Rate Generator is assumed to have been initialized to the expected baud rate.

A Break character has been received when:

- · RXxIF bit is set
- · FERR bit is set
- RCxREG = 00h

The second method uses the Auto-Wake-up feature described in **Section 33.3.3 "Auto-Wake-up on Break"**. By enabling this feature, the EUSART will sample the next two transitions on RX/DT, cause an RXxIF interrupt, and receive the next data byte followed by another interrupt.

Note that following a Break character, the user will typically want to enable the Auto-Baud Detect feature. For both methods, the user can set the ABDEN bit of the BAUDxCON register before placing the EUSART in Sleep mode.







### FIGURE 33-10: SYNCHRONOUS TRANSMISSION





### 33.4.1.5 Synchronous Master Reception

Data is received at the RX/DT pin. The RX/DT pin output driver is automatically disabled when the EUSART is configured for synchronous master receive operation.

In Synchronous mode, reception is enabled by setting either the Single Receive Enable bit (SREN of the RCxSTA register) or the Continuous Receive Enable bit (CREN of the RCxSTA register).

When SREN is set and CREN is clear, only as many clock cycles are generated as there are data bits in a single character. The SREN bit is automatically cleared at the completion of one character. When CREN is set, clocks are continuously generated until CREN is cleared. If CREN is cleared in the middle of a character the CK clock stops immediately and the partial character is discarded. If SREN and CREN are both set, then SREN is cleared at the completion of the first character and CREN takes precedence. To initiate reception, set either SREN or CREN. Data is sampled at the RX/DT pin on the trailing edge of the TX/CK clock pin and is shifted into the Receive Shift Register (RSR). When a complete character is received into the RSR, the RXxIF bit is set and the character is automatically transferred to the two character receive FIFO. The Least Significant eight bits of the top character in the receive FIFO are available in RCxREG. The RXxIF bit remains set as long as there are unread characters in the receive FIFO.

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

# 33.5 EUSART Operation During Sleep

The EUSART will remain active during Sleep only in the Synchronous Slave mode. All other modes require the system clock and therefore cannot generate the necessary signals to run the Transmit or Receive Shift registers during Sleep.

Synchronous Slave mode uses an externally generated clock to run the Transmit and Receive Shift registers.

# 33.5.1 SYNCHRONOUS RECEIVE DURING SLEEP

To receive during Sleep, all the following conditions must be met before entering Sleep mode:

- RCxSTA and TXxSTA Control registers must be configured for Synchronous Slave Reception (see Section 33.4.2.4 "Synchronous Slave Reception Set-up:").
- If interrupts are desired, set the RXxIE bit of the PIE3 register and the GIE and PEIE bits of the INTCON register.
- The RXxIF interrupt flag must be cleared by reading RCxREG to unload any pending characters in the receive buffer.

Upon entering Sleep mode, the device will be ready to accept data and clocks on the RX/DT and TX/CK pins, respectively. When the data word has been completely clocked in by the external device, the RXxIF interrupt flag bit of the PIR3 register will be set. Thereby, waking the processor from Sleep.

Upon waking from Sleep, the instruction following the SLEEP instruction will be executed. If the Global Interrupt Enable (GIE) bit of the INTCON register is also set, then the Interrupt Service Routine at address 004h will be called.

### 33.5.2 SYNCHRONOUS TRANSMIT DURING SLEEP

To transmit during Sleep, all the following conditions must be met before entering Sleep mode:

- The RCxSTA and TXxSTA Control registers must be configured for synchronous slave transmission (see Section 33.4.2.2 "Synchronous Slave Transmission Set-up:").
- The TXxIF interrupt flag must be cleared by writing the output data to the TXxREG, thereby filling the TSR and transmit buffer.
- If interrupts are desired, set the TXxIE bit of the PIE3 register and the PEIE bit of the INTCON register.
- Interrupt enable bits TXxIE of the PIE3 register and PEIE of the INTCON register must set.

Upon entering Sleep mode, the device will be ready to accept clocks on TX/CK pin and transmit data on the RX/DT pin. When the data word in the TSR has been completely clocked out by the external device, the pending byte in the TXxREG will transfer to the TSR and the TXxIF flag will be set. Thereby, waking the processor from Sleep. At this point, the TXxREG is available to accept another character for transmission, which will clear the TXxIF flag.

Upon waking from Sleep, the instruction following the SLEEP instruction will be executed. If the Global Interrupt Enable (GIE) bit is also set then the Interrupt Service Routine at address 0004h will be called.

# TABLE 37-17: ZERO CROSS DETECT (ZCD) SPECIFICATIONS

| Standard Op<br>VDD = 3.0V, | •        |                                |      |      |      |       |          |
|----------------------------|----------|--------------------------------|------|------|------|-------|----------|
| Param.<br>No.              | Sym.     | Characteristics                | Min. | Тур† | Max. | Units | Comments |
| ZC01                       | VPINZC   | Voltage on Zero Cross Pin      | —    | 0.75 | — )  | V     |          |
| ZC02                       | IZCD_MAX | Maximum source or sink current | —    | _    | 600  | μΑ)   |          |
| ZC03                       | TRESPH   | Response Time, Rising Edge     | —    | 1    | _    | us    |          |
|                            | TRESPL   | Response Time, Falling Edge    | —    | 1    | _    | μs    |          |

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

### FIGURE 37-12: TIMER0 AND TIMER1 EXTERNAL CLOCK TIMINGS



# **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-695-1980 Fax: 905-695-2078

### 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 - Guangzhou Tel: 86-20-8755-8029

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

06/23/16