



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, SPI, UART/USART                                          |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 17                                                                         |
| Program Memory Size        | 14KB (8K x 14)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 512 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 17x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 20-SSOP (0.209", 5.30mm Width)                                             |
| Supplier Device Package    | 20-SSOP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1559-i-ss |
|                            |                                                                            |

Email: info@E-XFL.COM

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

| Address | Name                  | Bit 7                            | Bit 6                                                    | Bit 5          | Bit 4                         | Bit 3          | Bit 2         | Bit 1          | Bit 0         | Value on:<br>POR, BOR | Value on<br>all other<br>Resets |
|---------|-----------------------|----------------------------------|----------------------------------------------------------|----------------|-------------------------------|----------------|---------------|----------------|---------------|-----------------------|---------------------------------|
| Bank 4  |                       |                                  |                                                          |                |                               |                |               |                |               |                       |                                 |
| 200h    | INDF0 <sup>(1)</sup>  | Addressing t                     | his location us                                          | es contents of | FSR0H/FSR0                    | L to address   | data memor    | y (not a physi | cal register) | XXXX XXXX             | uuuu uuuu                       |
| 201h    | INDF1 <sup>(1)</sup>  | Addressing t                     | his location us                                          | es contents of | FSR1H/FSR1                    | L to address   | data memor    | y (not a physi | cal register) | XXXX XXXX             | uuuu uuuu                       |
| 202h    | PCL <sup>(1)</sup>    |                                  |                                                          | Program C      | Counter (PC) L                | east Significa | ant Byte      |                |               | 0000 0000             | 0000 0000                       |
| 203h    | STATUS <sup>(1)</sup> | — — — <u>TO</u> <u>PD</u> Z DC C |                                                          |                |                               |                |               |                | 1 1000        | q quuu                |                                 |
| 204h    | FSR0L <sup>(1)</sup>  |                                  |                                                          | Indirect Da    | ata Memory Ac                 | Idress 0 Low   | Pointer       |                |               | 0000 0000             | uuuu uuuu                       |
| 205h    | FSR0H <sup>(1)</sup>  |                                  |                                                          | Indirect Da    | ita Memory Ad                 | ldress 0 High  | Pointer       |                |               | 0000 0000             | 0000 0000                       |
| 206h    | FSR1L <sup>(1)</sup>  |                                  |                                                          | Indirect Da    | ata Memory Ac                 | Idress 1 Low   | Pointer       |                |               | 0000 0000             | uuuu uuuu                       |
| 207h    | FSR1H <sup>(1)</sup>  |                                  | Indirect Data Memory Address 1 High Pointer              |                |                               |                |               |                |               | 0000 0000             | 0000 0000                       |
| 208h    | BSR <sup>(1)</sup>    | _                                | — — — BSR<4:0>                                           |                |                               |                |               |                |               | 0 0000                | 0 0000                          |
| 209h    | WREG <sup>(1)</sup>   | Working Register                 |                                                          |                |                               |                |               |                | 0000 0000     | uuuu uuuu             |                                 |
| 20Ah    | PCLATH <sup>(1)</sup> | _                                | Write Buffer for the upper 7 bits of the Program Counter |                |                               |                |               |                | -000 0000     | -000 0000             |                                 |
| 20Bh    | INTCON <sup>(1)</sup> | GIE                              | PEIE                                                     | TMR0IE         | INTE                          | IOCIE          | TMR0IF        | INTF           | IOCIF         | 0000 0000             | 0000 0000                       |
| 20Ch    | WPUA                  | _                                | _                                                        | WPUA5          | WPUA4                         | WPUA3          | WPUA2         | WPUA1          | WPUA0         | 11 1111               | 11 1111                         |
| 20Dh    | WPUB <sup>(2)</sup>   |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | _                     | _                               |
|         | WPUB <sup>(3)</sup>   | WPUB7                            | WPUB6                                                    | WPUB5          | WPUB4                         | _              | _             | _              | _             | 1111                  | 1111                            |
| 20Eh    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | —                               |
| 20Fh    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | _                               |
| 210h    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | _                     | _                               |
| 211h    | SSPBUF                |                                  | Sy                                                       | nchronous Ser  | ial Port Recei                | ve Buffer/Trai | nsmit Registe | er             |               | XXXX XXXX             | uuuu uuuu                       |
| 212h    | SSPADD                |                                  | 9                                                        | Synchronous S  | Serial Port (I <sup>2</sup> C | mode) Addre    | ess Register  |                |               | 0000 0000             | 0000 0000                       |
| 213h    | SSPMSK                |                                  | Syn                                                      | chronous Seri  | al Port (I <sup>2</sup> C mo  | ode) Address   | Mask Regist   | er             |               | 1111 1111             | 1111 1111                       |
| 214h    | SSPSTAT               | SMP                              | CKE                                                      | D/A            | Р                             | S              | R/W           | UA             | BF            | 0000 0000             | 0000 0000                       |
| 215h    | SSPCON1               | WCOL                             | SSPOV                                                    | SSPEN          | CKP                           | SSPM3          | SSPM2         | SSPM1          | SSPM0         | 0000 0000             | 0000 0000                       |
| 216h    | SSPCON2               | GCEN                             | ACKSTAT                                                  | ACKDT          | ACKEN                         | RCEN           | PEN           | RSEN           | SEN           | 0000 0000             | 0000 0000                       |
| 217h    | SSPCON3               | ACKTIM                           | PCIE                                                     | SCIE           | BOEN                          | SDAHT          | SBCDE         | AHEN           | DHEN          | 0000 0000             | 0000 0000                       |
| 218h    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | —                               |
| 219h    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | —                               |
| 21Ah    | —                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | —                               |
| 21Bh    | -                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | _                     | _                               |
| 21Ch    | _                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | —                               |
| 21Dh    | _                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | —                     | _                               |
| 21Eh    | _                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | _                     | _                               |
| 21Fh    | _                     |                                  |                                                          |                | Unimplem                      | ented          |               |                |               | _                     | _                               |

#### **TABLE 3-9:** SPECIAL FUNCTION REGISTER SUMMARY (CONTINUED)

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

Note 1: These registers can be accessed from any bank.

PIC16LF1554. 2:

3: PIC16LF1559.

4: These registers/bits are available at two address locations, in Bank 1 and Bank 14.

#### 5.2.2.3 Internal Oscillator Frequency Selection

The system clock speed can be selected via software using the Internal Oscillator Frequency Select bits IRCF<3:0> of the OSCCON register.

The outputs of the 16 MHz HFINTOSC postscaler and the LFINTOSC connect to a multiplexer (see Figure 5-1). The Internal Oscillator Frequency Select bits IRCF<3:0> of the OSCCON register select the frequency. One of the following frequencies can be selected via software:

- 32 MHz (requires 4x PLL)
- 16 MHz
- 8 MHz
- 4 MHz
- 2 MHz
- 1 MHz
- 500 kHz (default after Reset)
- 250 kHz
- 125 kHz
- 62.5 kHz
- 31.25 kHz
- 31 kHz (LFINTOSC)

| Note: | Following any Reset, the IRCF<3:0> bits  |
|-------|------------------------------------------|
|       | of the OSCCON register are set to '0111' |
|       | and the frequency selection is set to    |
|       | 500 kHz. The user can modify the IRCF    |
|       | bits to select a different frequency.    |

The IRCF<3:0> bits of the OSCCON register allow duplicate selections for some frequencies. These duplicate choices can offer system design trade-offs. Lower power consumption can be obtained when changing oscillator sources for a given frequency. Faster transition times can be obtained between frequency changes that use the same oscillator source.

# 5.2.2.4 Internal Oscillator Clock Switch Timing

When switching between the HFINTOSC and the LFINTOSC, the new oscillator may already be shut down to save power (see Figure 5-3). If this is the case, there is a delay after the IRCF<3:0> bits of the OSCCON register are modified before the frequency selection takes place. The OSCSTAT register will reflect the current active status of the HFINTOSC and LFINTOSC oscillators. The sequence of a frequency selection is as follows:

- 1. IRCF<3:0> bits of the OSCCON register are modified.
- 2. If the new clock is shut down, a clock start-up delay is started.
- 3. Clock switch circuitry waits for a falling edge of the current clock.
- 4. Clock switch is complete.

See Figure 5-3 for more details.

If the internal oscillator speed is switched between two clocks of the same source, there is no start-up delay before the new frequency is selected.

Start-up delay specifications are located in the oscillator tables of **Section 25.0** "**Electrical Specifications**".

# 5.2.2.5 32 MHz Internal Oscillator Frequency Selection

The Internal Oscillator Block can be used with the 4x PLL to produce a 32 MHz internal system clock source. The following settings are required to use the 32 MHz internal clock source:

- The FOSC bits in Configuration Word 1 must be set to use the INTOSC source as the device system clock (FOSC<1:0> = 00).
- The SCS bits in the OSCCON register must be cleared to use the clock determined by FOSC<1:0> in Configuration Word 1 (SCS<1:0> = 00).
- The IRCF bits in the OSCCON register must be set to the 8 MHz HFINTOSC set to use (IRCF<3:0> = 1110).
- The SPLLEN bit in the OSCCON register must be set to enable the 4x PLL.

The 4x PLL is not available for use with the internal oscillator when the SCS bits of the OSCCON register are set to '1x'. The SCS bits must be set to '00' to use the 4x PLL with the internal oscillator.





# 6.3 Register Definitions: BOR Control

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

| R/W-1/u | R/W-0/u | U-0 | U-0 | U-0 | U-0 | U-0 | R-q/u  |
|---------|---------|-----|-----|-----|-----|-----|--------|
| SBOREN  | BORFS   | —   | _   | —   | —   | —   | BORRDY |
| bit 7   |         |     |     |     |     |     | bit 0  |

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

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

# 9.1 Independent Clock Source

The WDT derives its time base from the 31 kHz LFINTOSC internal oscillator. Time intervals in this chapter are based on a nominal interval of 1 ms. See **Section 25.0 "Electrical Specifications**" for the LFINTOSC tolerances.

# 9.2 WDT Operating Modes

The Watchdog Timer module has four operating modes controlled by the WDTE<1:0> bits in Configuration Words. See Table 9-1.

#### 9.2.1 WDT IS ALWAYS ON

When the WDTE bits of Configuration Words are set to '11', the WDT is always on.

WDT protection is active during Sleep.

#### 9.2.2 WDT IS OFF IN SLEEP

When the WDTE bits of Configuration Words are set to '10', the WDT is on, except in Sleep.

WDT protection is not active during Sleep.

#### 9.2.3 WDT CONTROLLED BY SOFTWARE

When the WDTE bits of Configuration Words are set to '01', the WDT is controlled by the SWDTEN bit of the WDTCON register.

WDT protection is unchanged by Sleep. See Table 9-1 for more details.

#### TABLE 9-1: WDT OPERATING MODES

| WDTE<1:0> | SWDTEN | Device Mode | WDT Mode |  |
|-----------|--------|-------------|----------|--|
| 11        | Х      | Х           | Active   |  |
| 1.0       | 37     | Awake       | Active   |  |
| 10        | Х      | Sleep       | Disabled |  |
| 01        | 1      | Х           | Active   |  |
| 01        | 0      | Х           | Disabled |  |
| 00        | Х      | Х           | Disabled |  |

#### TABLE 9-2: WDT CLEARING CONDITIONS

#### 9.3 Time-out Period

The WDTPS bits of the WDTCON register set the time-out period from 1 ms to 256 seconds (nominal). After a Reset, the default time-out period is two seconds.

# 9.4 Clearing the WDT

The WDT is cleared when any of the following conditions occur:

- Any Reset
- CLRWDT instruction is executed
- Device enters Sleep
- · Device wakes up from Sleep
- Oscillator fail
- WDT is disabled
- Oscillator Start-up Timer (OST) is running

See Table 9-2 for more information.

# 9.5 Operation During Sleep

When the device enters Sleep, the WDT is cleared. If the WDT is enabled during Sleep, the WDT resumes counting. When the device exits Sleep, the WDT is cleared again.

The WDT remains clear until the OST, if enabled, completes. See **Section 5.0** "**Oscillator Module**" for more information on the OST.

When a WDT time-out occurs while the device is in Sleep, no Reset is generated. Instead, the device wakes up and resumes operation. The TO and PD bits in the STATUS register are changed to indicate the event. The RWDT bit in the PCON register can also be used. See **Section 3.0** "**Memory Organization**" for more information.

| Conditions                                               | WDT                          |  |  |
|----------------------------------------------------------|------------------------------|--|--|
| WDTE<1:0> = 00                                           |                              |  |  |
| WDTE<1:0> = 01 and SWDTEN = 0                            |                              |  |  |
| WDTE<1:0> = 10 and enter Sleep                           | Cleared                      |  |  |
| CLRWDT Command                                           | Cleared                      |  |  |
| Oscillator Fail Detected                                 |                              |  |  |
| Exit Sleep + System Clock = T1OSC, EXTRC, INTOSC, EXTCLK |                              |  |  |
| Exit Sleep + System Clock = XT, HS, LP                   | Cleared until the end of OST |  |  |
| Change INTOSC divider (IRCF bits)                        | Unaffected                   |  |  |

# 10.5 Write Verify

It is considered good programming practice to verify that program memory writes agree with the intended value. Since program memory is stored as a full page then the stored program memory contents are compared with the intended data stored in RAM after the last write is complete.

#### FIGURE 10-8: FLASH PROGRAM MEMORY VERIFY FLOWCHART



# 11.2 Register Definitions: Alternate Pin Function Control

| R/W-0/0                               | R/W-0/0                          | R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W-0/0 | U-0            | R/W-0/0           | R/W-0/0  | R/W-0/0     |  |  |  |
|---------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------|-------------------|----------|-------------|--|--|--|
| RXDTSEL                               | SDOSEL                           | SSSEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SDSEL   | _              | TXCKSEL           | GRDBSEL  | GRDASEL     |  |  |  |
| bit 7                                 |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          | bit         |  |  |  |
|                                       |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| Legend:<br>R = Readable               | > hit                            | W = Writable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | hit     | II = I Inimple | emented bit, read | 1 as '0' |             |  |  |  |
| u = Bit is uncl                       |                                  | x = Bit is unk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                | at POR and BC     |          | ther Resets |  |  |  |
| (1' = Bit is set (0' = Bit is cleared |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
|                                       |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| bit 7                                 | RXDTSEL: F                       | Pin Selection bi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | t(1)    |                |                   |          |             |  |  |  |
|                                       |                                  | unction is on R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
|                                       |                                  | unction is on R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| bit 6                                 |                                  | n Selection bit <sup>(</sup><br>nction is on RC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
|                                       |                                  | iction is on RC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| bit 5                                 | SSSEL: Pin                       | Selection bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |                |                   |          |             |  |  |  |
|                                       | For 14 Pin Device (PIC16LF1554): |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
|                                       |                                  | tion is on RA3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ,       |                |                   |          |             |  |  |  |
|                                       | $1 = \overline{SS}$ funct        | tion is on RC3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |                |                   |          |             |  |  |  |
|                                       |                                  | <u>evice</u> (PIC16LF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | =1559): |                |                   |          |             |  |  |  |
|                                       |                                  | tion is on RA3<br>tion is on RC6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                |                   |          |             |  |  |  |
| bit 4                                 | SDSEL: Pin                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| Sit 1                                 |                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -1554): |                |                   |          |             |  |  |  |
|                                       |                                  | For 14 Pin Device (PIC16LF1554):<br>0 = SDA / SDI function is on RC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |                |                   |          |             |  |  |  |
|                                       |                                  | DI function is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                |                   |          |             |  |  |  |
|                                       |                                  | <u>evice</u> (PIC16LF<br>DI function is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ,       |                |                   |          |             |  |  |  |
|                                       |                                  | DI function is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                |                   |          |             |  |  |  |
| bit 3                                 | Unimplemer                       | nted: Read as                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ʻ0'     |                |                   |          |             |  |  |  |
| bit 2                                 | TXCKSEL: F                       | Pin Selection bi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | t(1)    |                |                   |          |             |  |  |  |
|                                       | 0 = TX/CK f                      | 0 = TX/CK function is on RC4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         |                |                   |          |             |  |  |  |
|                                       | _                                | unction is on R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
| bit 1                                 |                                  | Pin Selection b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |                |                   |          |             |  |  |  |
|                                       |                                  | DB function is on<br>DB function is on the second sec | ,       |                |                   |          |             |  |  |  |
| bit 0                                 |                                  | Pin Selection b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2       |                | I IS UIL RUZ      |          |             |  |  |  |
|                                       |                                  | DA function is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         | RDA function   | is on RC5         |          |             |  |  |  |
|                                       |                                  | DA function is o                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |                |                   |          |             |  |  |  |
| Note 1: Bit                           | t only implemen                  | ted on PIC16L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | F1554.  |                |                   |          |             |  |  |  |

# REGISTER 11-1: APFCON: ALTERNATE PIN FUNCTION CONTROL REGISTER

#### REGISTER 11-14: LATC: PORTC DATA LATCH REGISTER

| R/W-x/u              | R/W-x/u              | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u |
|----------------------|----------------------|---------|---------|---------|---------|---------|---------|
| LATC7 <sup>(1)</sup> | LATC6 <sup>(1)</sup> | LATC5   | LATC4   | LATC3   | LATC2   | LATC1   | LATC0   |
| bit 7                | ·                    |         |         |         |         |         | bit 0   |
|                      |                      |         |         |         |         |         |         |

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

# bit 7-0 LATC<7:0>: PORTC Output Latch Value bits<sup>(2)</sup>

Note 1: Functions not available on PIC16LF1554.

2: Writes to PORTC are actually written to corresponding LATC register. Reads from PORTC register is return of actual I/O pin values.

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

| R/W-1/1              | R/W-1/1              | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1 |
|----------------------|----------------------|---------|---------|---------|---------|---------|---------|
| ANSC7 <sup>(1)</sup> | ANSC6 <sup>(1)</sup> | ANSC5   | ANSC4   | ANSC3   | ANSC2   | ANSC1   | ANSC0   |
| bit 7                |                      |         |         |         |         |         | bit 0   |

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

bit 7-0 **ANSC<7:0>**: Analog Select between Analog or Digital Function on pins RC<7:0>, respectively 1 = Analog input. Pin is assigned as analog input<sup>(2)</sup>. Digital input buffer disabled.

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

Note 1: Functions not available on PIC16LF1554.

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

| Name   | Bit 7                | Bit 6                 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|--------|----------------------|-----------------------|--------|--------|--------|--------|--------|--------|---------------------|
| ANSELC | ANSC7 <sup>(1)</sup> | ANSC6 <sup>(1)</sup>  | ANSC5  | ANSC4  | ANSC3  | ANSC2  | ANSC1  | ANSC0  | 117                 |
| LATC   | LATC7 <sup>(1)</sup> | LATC6 <sup>(1)</sup>  | LATC5  | LATC4  | LATC3  | LATC2  | LATC1  | LATC0  | 117                 |
| PORTC  | RC7 <sup>(1)</sup>   | RC6 <sup>(1)</sup>    | RC5    | RC4    | RC3    | RC2    | RC1    | RC0    | 116                 |
| TRISC  | TRISC7(1)            | TRISC6 <sup>(1)</sup> | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 116                 |

#### TABLE 11-9: SUMMARY OF REGISTERS ASSOCIATED WITH PORTC

**Legend:** x = unknown, u = unchanged, - = unimplemented locations read as '0'. Shaded cells are not used by PORTC.

Note 1: Functions not available on PIC16LF1554.

| Name                | Bit 7                   | Bit 6          | Bit 5  | Bit 4  | Bit 3  | Bit 2       | Bit 1       | Bit 0    | Register<br>on Page |
|---------------------|-------------------------|----------------|--------|--------|--------|-------------|-------------|----------|---------------------|
| ADCON0/<br>AD1CON0  | _                       | CHS4           | CHS3   | CHS2   | CHS1   | CHS0        | GO/DONE1    | AD1ON    | 133                 |
| AD2CON0             | _                       | CHS4           | CHS3   | CHS2   | CHS1   | CHS0        | GO/DONE2    | AD2ON    | 134                 |
| ADCON1/<br>ADCOMCON | ADFM                    | ADFM ADCS<2:0> |        |        | _      | GO/DONE_ALL | ADPREF<1:0> |          | 135                 |
| ADxCON2             | — TRIGSEL<2:0> — — — —  |                |        |        |        | 136         |             |          |                     |
| ADxRESxH            | ADC Resu                | lt Register I  | High   |        |        |             |             |          | 136, 137            |
| ADxRESxL            | ADC Result Register Low |                |        |        |        |             |             | 137, 137 |                     |
| ANSELA              | _                       | _              | ANSA5  | ANSA4  | _      | ANSA2       | ANSA1       | ANSA0    | 109                 |
| ANSELB              | ANSB7                   | ANSB6          | ANSB5  | ANSB4  | _      | —           | _           | _        | 113                 |
| ANSELC              | ANSC7                   | ANSC6          | ANSC5  | ANSC4  | ANSC3  | ANSC2       | ANSC1       | ANSC0    | 117                 |
| INTCON              | GIE                     | PEIE           | TMR0IE | INTE   | IOCIE  | TMR0IF      | INTF        | IOCIF    | 77                  |
| PIE1                | TMR1GIE                 | AD1IE          | RCIE   | TXIE   | SSP1IE |             | TMR2IE      | TMR1IE   | 78                  |
| PIR1                | TMR1GIF                 | AD1IF          | RCIF   | TXIF   | SSP1IF |             | TMR2IF      | TMR1IF   | 80                  |
| TRISA               | _                       | _              | TRISA5 | TRISA4 | —(1)   | TRISA2      | TRISA1      | TRISA0   | 108                 |
| TRISB               | TRISB7                  | TRISB6         | TRISB5 | TRISB4 | _      |             | _           | _        | 112                 |
| TRISC               | TRISC7                  | TRISC6         | TRISC5 | TRISC4 | TRISC3 | TRISC2      | TRISC1      | TRISC0   | 116                 |
| FVRCON              | FVREN                   | FVRRDY         | TSEN   | TSRNG  | _      |             | ADFVR<      | <1:0>    | 124                 |

# TABLE 15-3: SUMMARY OF REGISTERS ASSOCIATED WITH ADC

**Legend:** x = unknown, u = unchanged, – = unimplemented read as '0', q = value depends on condition. Shaded cells are not used for ADC module.

**Note 1:** Unimplemented, read as '1'.



# FIGURE 16-7: DOUBLE SAMPLE CONVERSION SEQUENCE (ADDSEN = 1 AND ADIPEN = 1)

3: The AADxRES1L/H registers are set to zero during this period.

# 18.0 TIMER1 MODULE WITH GATE CONTROL

The Timer1 module is a 16-bit timer/counter with the following features:

- 16-bit timer/counter register pair (TMR1H:TMR1L)
- Programmable internal or external clock source
- · 2-bit prescaler
- · Optionally synchronized comparator out
- Multiple Timer1 gate (count enable) sources

- · Interrupt on overflow
- Wake-up on overflow (external clock, Asynchronous mode only)
- ADC Auto-Conversion Trigger(s)
- Selectable Gate Source Polarity
- · Gate Toggle mode
- Gate Single-Pulse mode
- Gate Value Status
- Gate Event Interrupt

Figure 18-1 is a block diagram of the Timer1 module.



# FIGURE 18-1: TIMER1 BLOCK DIAGRAM

# 20.0 MASTER SYNCHRONOUS SERIAL PORT (MSSP) MODULE

# 20.1 MSSP Module Overview

The Master Synchronous Serial Port (MSSP) module is a serial interface useful for communicating with other peripheral or microcontroller devices. These peripheral devices may be Serial EEPROMs, shift registers, display drivers, ADC converters, etc. The MSSP module can operate in one of two modes:

- Serial Peripheral Interface (SPI)
- Inter-Integrated Circuit (I<sup>2</sup>C)

The SPI interface supports the following modes and features:

- Master mode
- · Slave mode
- Clock Parity
- Slave Select Synchronization (Slave mode only)
- · Daisy-chain connection of slave devices

Figure 20-1 is a block diagram of the SPI interface module.

# **Note:** Register names, I/O pins, and bit names may use the generic designator 'x' to indicate the use of a numeral to distinguish a particular module, when required.

# FIGURE 20-1: MSSP BLOCK DIAGRAM (SPI MODE)



# 20.2 SPI Mode Overview

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

The SPI bus specifies four signal connections:

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

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

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

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

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

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

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

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

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

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

The master device starts a transmission by sending out the MSb from its shift register. The slave device reads this bit from that same line and saves it into the LSb position of its shift register.

During each SPI clock cycle, a full-duplex data transmission occurs. This means that while the master device is sending out the MSb from its shift register (on

its SDO pin) and the slave device is reading this bit and saving it as the LSb of its shift register, that the slave device is also sending out the MSb from its shift register (on its SDO pin) and the master device is reading this bit and saving it as the LSb of its shift register.

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

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

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

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

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

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

## 20.4.9 ACKNOWLEDGE SEQUENCE

The 9th SCL pulse for any transferred byte in  $I^2C$  is dedicated as an Acknowledge. It allows receiving devices to respond back to the transmitter by pulling the SDA line low. The transmitter must release control of the line during this time to shift in the response. The Acknowledge (ACK) is an active-low signal, pulling the SDA line low indicated to the transmitter that the device has received the transmitted data and is ready to receive more.

The result of an  $\overline{\text{ACK}}$  is placed in the ACKSTAT bit of the SSPCON2 register.

Slave software, when the AHEN and DHEN bits are set, allow the user to set the ACK value sent back to the transmitter. The ACKDT bit of the SSPCON2 register is set/cleared to determine the response.

Slave hardware will generate an ACK response if the AHEN and DHEN bits of the SSPCON3 register are clear.

There are certain conditions where an  $\overline{ACK}$  will not be sent by the slave. If the BF bit of the SSPSTAT register or the SSPOV bit of the SSPCON1 register are set when a byte is received.

When the module is addressed, after the 8th falling edge of SCL on the bus, the ACKTIM bit of the SSPCON3 register is set. The ACKTIM bit indicates the acknowledge time of the active bus. The ACKTIM Status bit is only active when the AHEN bit or DHEN bit is enabled.

# 20.5 I<sup>2</sup>C SLAVE MODE OPERATION

The MSSP Slave mode operates in one of four modes selected in the SSPM bits of the SSPCON1 register. The modes can be divided into 7-bit and 10-bit Addressing mode. 10-bit Addressing modes operate the same as 7-bit with some additional overhead for handling the larger addresses.

Modes with Start and Stop bit interrupts operate the same as the other modes with SSP1IF additionally getting set upon detection of a Start, Restart, or Stop condition.

#### 20.5.1 SLAVE MODE ADDRESSES

The SSPADD register (Register 20-6) contains the Slave mode address. The first byte received after a Start or Restart condition is compared against the value stored in this register. If the byte matches, the value is loaded into the SSPBUF register and an interrupt is generated. If the value does not match, the module goes idle and no indication is given to the software that anything happened.

The SSP Mask register (Register 20-5) affects the address matching process. See **Section 20.5.9** "**SSP Mask Register**" for more information.

#### 20.5.1.1 I<sup>2</sup>C Slave 7-Bit Addressing Mode

In 7-bit Addressing mode, the LSb of the received data byte is ignored when determining if there is an address match.

# 20.5.1.2 I<sup>2</sup>C Slave 10-Bit Addressing Mode

In 10-bit Addressing mode, the first received byte is compared to the binary value of '1 1 1 1 0 A9 A8 0'. A9 and A8 are the two MSb of the 10-bit address and stored in bits 2 and 1 of the SSPADD register.

After the acknowledge of the high byte the UA bit is set and SCL is held low until the user updates SSPADD with the low address. The low address byte is clocked in and all eight bits are compared to the low address value in SSPADD. Even if there is not an address match; SSP1IF and UA are set, and SCL is held low until SSPADD is updated to receive a high byte again. When SSPADD is updated the UA bit is cleared. This ensures the module is ready to receive the high address byte on the next communication.

A high and low address match as a write request is required at the start of all 10-bit addressing communication. A transmission can be initiated by issuing a Restart once the slave is addressed, and clocking in the high address with the R/W bit set. The slave hardware will then acknowledge the read request and prepare to clock out data. This is only valid for a slave after it has received a complete high and low address byte match.





#### 20.6.3 WCOL STATUS FLAG

If the user writes the SSPBUF when a Start, Restart, Stop, Receive or Transmit sequence is in progress, the WCOL bit is set and the contents of the buffer are unchanged (the write does not occur). Any time the WCOL bit is set it indicates that an action on SSPBUF was attempted while the module was not Idle.

| Note: | Because queuing of events is not allowed, |  |  |  |  |  |  |  |
|-------|-------------------------------------------|--|--|--|--|--|--|--|
|       | writing to the lower five bits of SSPCON2 |  |  |  |  |  |  |  |
|       | is disabled until the Start condition is  |  |  |  |  |  |  |  |
|       | complete.                                 |  |  |  |  |  |  |  |

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

To initiate a Start condition (Figure 20-26), the user sets the Start Enable bit, SEN bit of the SSPCON2 register. If the SDA and SCL pins are sampled high, the Baud Rate Generator is reloaded with the contents of SSPADD<7:0> and starts its count. If SCL and SDA are both sampled high when the Baud Rate Generator times out (TBRG), the SDA pin is driven low. The action of the SDA being driven low while SCL is high is the

Start condition and causes the S bit of the SSPSTAT1 register to be set. Following this, the Baud Rate Generator is reloaded with the contents of SSPADD<7:0> and resumes its count. When the Baud Rate Generator times out (TBRG), the SEN bit of the SSPCON2 register will be automatically cleared by hardware; the Baud Rate Generator is suspended, leaving the SDA line held low and the Start condition is complete.

- Note 1: If at the beginning of the Start condition, the SDA and SCL pins are already sampled low, or if during the Start condition, the SCL line is sampled low before the SDA line is driven low, a bus collision occurs, the Bus Collision Interrupt Flag, BCLIF, is set, the Start condition is aborted and the I<sup>2</sup>C module is reset into its Idle state.
  - 2: The Philips I<sup>2</sup>C Specification states that a bus collision cannot occur on a Start.

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



#### 20.6.13.3 Bus Collision During a Stop Condition

Bus collision occurs during a Stop condition if:

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

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

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



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



#### 21.5.2 SYNCHRONOUS SLAVE MODE

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

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

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

#### 21.5.2.1 EUSART Synchronous Slave Transmit

The operation of the Synchronous Master and Slave modes are identical (see **Section 21.5.1.3 "Synchronous Master Transmission")**, except in the case of the Sleep mode. If two words are written to the TXREG and then the SLEEP instruction is executed, the following will occur:

- 1. The first character will immediately transfer to the TSR register and transmit.
- 2. The second word will remain in the TXREG register.
- 3. The TXIF bit will not be set.
- After the first character has been shifted out of TSR, the TXREG register will transfer the second character to the TSR and the TXIF bit will now be set.
- 5. If the PEIE and TXIE bits are set, the interrupt will wake the device from Sleep and execute the next instruction. If the GIE bit is also set, the program will call the Interrupt Service Routine.
- 21.5.2.2 Synchronous Slave Transmission Set-up:
- 1. Set the SYNC and SPEN bits and clear the CSRC bit.
- 2. Clear the ANSELx bit for the CK pin (if applicable).
- 3. Clear the CREN and SREN bits.
- If interrupts are desired, set the TXIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 5. If 9-bit transmission is desired, set the TX9 bit.
- 6. Enable transmission by setting the TXEN bit.
- 7. If 9-bit transmission is selected, insert the Most Significant bit into the TX9D bit.
- 8. Start transmission by writing the Least Significant eight bits to the TXREG register.

# TABLE 21-9:SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE<br/>TRANSMISSION

| Name    | Bit 7                         | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register<br>on Page |
|---------|-------------------------------|--------|--------|--------|--------|--------|--------|--------|---------------------|
| BAUDCON | ABDOVF                        | RCIDL  | —      | SCKP   | BRG16  | —      | WUE    | ABDEN  | 245                 |
| INTCON  | GIE                           | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF  | 77                  |
| PIE1    | TMR1GIE                       | AD1IE  | RCIE   | TXIE   | SSP1IE | _      | TMR2IE | TMR1IE | 78                  |
| PIR1    | TMR1GIF                       | AD1IF  | RCIF   | TXIF   | SSP1IF | _      | TMR2IF | TMR1IF | 80                  |
| RCSTA   | SPEN                          | RX9    | SREN   | CREN   | ADDEN  | FERR   | OERR   | RX9D   | 244                 |
| TRISB   | TRISB7                        | TRISB6 | TRISB5 | TRISB4 | _      | _      | —      | _      | 112                 |
| TXREG   | EUSART Transmit Data Register |        |        |        |        |        |        | 236*   |                     |
| TXSTA   | CSRC                          | TX9    | TXEN   | SYNC   | SENDB  | BRGH   | TRMT   | TX9D   | 243                 |

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

\* Page provides register information.

# 25.0 ELECTRICAL SPECIFICATIONS

# 25.1 Absolute Maximum Ratings<sup>(†)</sup>

| Ambient temperature under bias                                                                                                                                               | -40°C to +125°C      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|                                                                                                                                                                              |                      |
| Storage temperature                                                                                                                                                          | 05 C 10 + 150 C      |
| Voltage on pins with respect to Vss                                                                                                                                          |                      |
| on VDD pin                                                                                                                                                                   | 0.3V to +4.0V        |
| on MCLR pin                                                                                                                                                                  | 0.3V to +9.0V        |
| on all other pins                                                                                                                                                            | 0.3V to (VDD + 0.3V) |
| Total power dissipation                                                                                                                                                      | 800 mW               |
| Maximum current <sup>(1)</sup>                                                                                                                                               |                      |
| out of Vss pin, -40°C $\leq$ TA $\leq$ +85°C for industrial                                                                                                                  | 250 mA               |
| out of Vss pin, +85°C $\leq$ TA $\leq$ +125°C for extended                                                                                                                   | 85 mA                |
| into VDD pin, -40°C $\leq$ TA $\leq$ +85°C for industrial                                                                                                                    | 250 mA               |
| into VDD pin, +85°C $\leq$ TA $\leq$ +125°C for extended                                                                                                                     | 85 mA                |
| Clamp current, Iк (VPIN < 0 or VPIN > VDD)                                                                                                                                   | ± 20 mA              |
| Maximum output current                                                                                                                                                       |                      |
| sunk by any I/O pin                                                                                                                                                          | 50 mA                |
| sourced by any I/O pin                                                                                                                                                       | 50 mA                |
| Total power dissipation <sup>(2)</sup>                                                                                                                                       | 800 mW               |
| Note 1: Maximum rating requires even load distribution across I/O pins. Maximum c<br>by the device package power dissipation characterizations, see Table<br>specifications. | <b>C 1</b>           |

2: Power dissipation is calculated as follows: PDIS = VDD x {IDD  $-\Sigma$  IOH} +  $\Sigma$  {(VDD - VOH) x IOH} +  $\Sigma$ (VOI x IOL)

† NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure above maximum rating conditions for extended periods may affect device reliability.

# 25.2 Standard Operating Conditions

.

The standard operating conditions for any device are defined as:

| Operating Voltage:<br>Operating Temperature: | VDDMIN $\leq$ VDD $\leq$ VDDMAX                |        |
|----------------------------------------------|------------------------------------------------|--------|
| VDD — Operating Suppl                        |                                                |        |
|                                              |                                                |        |
|                                              | $Fosc \leq 16 \text{ MHz}$ )                   |        |
| VDDMIN (*                                    | 16 MHz < Fosc $\leq$ 32 MHz)                   | +2.5V  |
| VDDMAX.                                      |                                                | +3.6V  |
| TA — Operating Ambier                        | nt Temperature Range                           |        |
| Industrial Tempera                           | ature                                          |        |
| TA_MIN                                       |                                                | 40°C   |
| TA_MAX                                       |                                                | +85°C  |
| Extended Tempera                             | ature                                          |        |
|                                              |                                                |        |
| TA_MAX                                       |                                                | +125°C |
| Note 1: See Paramete                         | er D001 in DC Characteristics: Supply Voltage. |        |

# 25.4 AC Characteristics

Timing Parameter Symbology has been created with one of the following formats:

1. TppS2ppS

| 2 | Tanc |  |
|---|------|--|
| / | IDDS |  |
|   |      |  |

| <u>2. 1pp0</u> |                                      |     |                |
|----------------|--------------------------------------|-----|----------------|
| т              |                                      |     |                |
| F              | Frequency                            | Т   | Time           |
| Lowerc         | ase letters (pp) and their meanings: |     |                |
| рр             |                                      |     |                |
| СС             | CCP1                                 | OSC | CLKIN          |
| ck             | CLKOUT                               | rd  | RD             |
| CS             | CS                                   | rw  | RD or WR       |
| di             | SDIx                                 | SC  | SCKx           |
| do             | SDO                                  | SS  | SS             |
| dt             | Data in                              | t0  | TOCKI          |
| io             | I/O PORT                             | t1  | T1CKI          |
| mc             | MCLR                                 | wr  | WR             |
| Upperc         | ase letters and their meanings:      |     |                |
| S              |                                      |     |                |
| F              | Fall                                 | Р   | Period         |
| Н              | High                                 | R   | Rise           |
| I              | Invalid (High-impedance)             | V   | Valid          |
| L              | Low                                  | Z   | High-impedance |

### FIGURE 25-3: LOAD CONDITIONS



# FIGURE 25-4: CLOCK TIMING



# Package Marking Information (Continued)

14-Lead TSSOP (4.4 mm)



16-Lead QFN (4x4x0.9 mm)





Example



| Legend | : XXX<br>Y<br>YY<br>WW<br>NNN<br>@3<br>* | Customer-specific information<br>Year code (last digit of calendar year)<br>Year code (last 2 digits of calendar year)<br>Week code (week of January 1 is week '01')<br>Alphanumeric traceability code<br>Pb-free JEDEC <sup>®</sup> designator for Matte Tin (Sn)<br>This package is Pb-free. The Pb-free JEDEC designator (e3)<br>can be found on the outer packaging for this package. |
|--------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note:  | be carried                               | nt the full Microchip part number cannot be marked on one line, it will d over to the next line, thus limiting the number of available s for customer-specific information.                                                                                                                                                                                                               |