

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 20MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                      |
| Number of I/O              | 36                                                                         |
| 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 28x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 44-TQFP                                                                    |
| Supplier Device Package    | 44-TQFP (10x10)                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1517-i-pt |

Email: info@E-XFL.COM

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

#### 2.0 ENHANCED MID-RANGE CPU

This family of devices contain an enhanced mid-range 8-bit CPU core. The CPU has 49 instructions. Interrupt capability includes automatic context saving. The hardware stack is 16 levels deep and has Overflow and Underflow Reset capability. Direct, Indirect, and Relative addressing modes are available. Two File Select Registers (FSRs) provide the ability to read program and data memory.

- · Automatic Interrupt Context Saving
- 16-level Stack with Overflow and Underflow
- File Select Registers
- Instruction Set



FIGURE 2-1: CORE BLOCK DIAGRAM

#### 3.3.1.1 STATUS Register

The STATUS register, shown in Register 3-1, contains:

- · the arithmetic status of the ALU
- · the Reset status

The STATUS register can be the destination for any instruction, like any other register. If the STATUS register is the destination for an instruction that affects the Z, DC or C bits, then the write to these three bits is disabled. These bits are set or cleared according to the device logic. Furthermore, the  $\overline{TO}$  and  $\overline{PD}$  bits are not writable. Therefore, the result of an instruction with the STATUS register as destination may be different than intended.

#### 3.4 **Register Definitions: Status**

For example, CLRF STATUS will clear the upper three bits and set the Z bit. This leaves the STATUS register as '000u uluu' (where u = unchanged).

It is recommended, therefore, that only BCF, BSF, SWAPF and MOVWF instructions are used to alter the STATUS register, because these instructions do not affect any Status bits. For other instructions not affecting any Status bits (Refer to Section 24.0 "Instruction Set Summary").

Note 1: The C and DC bits operate as Borrow and Digit Borrow out bits, respectively, in subtraction.

#### **REGISTER 3-1:** STATUS: STATUS REGISTER

|       | • • • • • • • |     |       |       |         |                   |                  |
|-------|---------------|-----|-------|-------|---------|-------------------|------------------|
| U-0   | U-0           | U-0 | R-1/q | R-1/q | R/W-0/u | R/W-0/u           | R/W-0/u          |
| —     | _             | _   | TO    | PD    | Z       | DC <sup>(1)</sup> | C <sup>(1)</sup> |
| 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-5 | Unimplemented: Read as '0'                                                                                                                                              |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 4   | TO: Time-out bit                                                                                                                                                        |
|         | 1 = After power-up, CLRWDT instruction or SLEEP instruction<br>0 = A WDT time-out occurred                                                                              |
| bit 3   | PD: Power-down bit                                                                                                                                                      |
|         | <ul> <li>1 = After power-up or by the CLRWDT instruction</li> <li>0 = By execution of the SLEEP instruction</li> </ul>                                                  |
| bit 2   | Z: Zero bit                                                                                                                                                             |
|         | <ul> <li>1 = The result of an arithmetic or logic operation is zero</li> <li>0 = The result of an arithmetic or logic operation is not zero</li> </ul>                  |
| bit 1   | <b>DC:</b> Digit Carry/Digit Borrow bit <sup>(1)</sup>                                                                                                                  |
|         | <ul> <li>1 = A carry-out from the 4th low-order bit of the result occurred</li> <li>0 = No carry-out from the 4th low-order bit of the result</li> </ul>                |
| bit 0   | C: Carry/Borrow bit <sup>(1)</sup>                                                                                                                                      |
|         | <ul> <li>1 = A carry-out from the Most Significant bit of the result occurred</li> <li>0 = No carry-out from the Most Significant bit of the result occurred</li> </ul> |
| Note 1: | For Borrow, the polarity is reversed. A subtraction is executed by adding the two's complement                                                                          |

nt of the second operand.

FIGURE 3-6: ACCESSING THE STACK EXAMPLE 2



| FIGURE 7  | 7-2: II       | NTERRUPT      | LATENCY           |                  |       |             |             |             |
|-----------|---------------|---------------|-------------------|------------------|-------|-------------|-------------|-------------|
|           |               |               |                   |                  |       |             |             |             |
| OSC1      |               |               |                   |                  | ΛΛΛΛ  | ΛΛΛΛ        |             | ЛЛЛЛ        |
|           |               |               | Q1 Q2 Q3 Q4       | Q1 Q2 Q3 Q4      |       |             | Q1 Q2 Q3 Q4 | Q1 Q2 Q3 Q4 |
| CLKOUT    |               |               | Interru<br>during | pt Sampled<br>Q1 |       |             |             |             |
| Interrupt |               |               |                   |                  |       |             |             |             |
| GIE       |               |               |                   |                  |       |             |             |             |
| PC        | PC-1          | PC            | PC                | +1               | 0004h | 0005h       |             | ()          |
| Execute   | 1 Cycle Instr | ruction at PC | Inst(PC)          | NOP              | NOP   | Inst(0004h) |             |             |
|           |               |               |                   |                  |       |             |             |             |
| Interrupt |               |               |                   |                  |       |             |             |             |
| GIE       |               |               |                   |                  |       |             |             |             |
| PC        | PC-1          | PC            | PC+1/FSR<br>ADDR  | New PC/<br>PC+1  | 0004h | 0005h       |             | )           |
| Execute-  | 2 Cycle Instr | uction at PC  | Inst(PC)          | NOP              | NOP   | Inst(0004h) |             |             |
|           |               | /             |                   | 1                |       |             |             |             |
| Interrupt |               |               |                   |                  |       |             |             |             |
|           | ,             | [             |                   |                  |       | \           |             |             |
| PC        | PC-1          | PC            | FSR ADDR          | PC+1             | PC+2  | 0004h       | 0005h       | ]           |
| Execute   | 3 Cycle Instr | ruction at PC | INST(PC)          | NOP              | NOP   | NOP         | Inst(0004h) | Inst(0005h) |
| Interrupt |               |               |                   |                  | -     |             |             |             |
| GIE       |               |               |                   |                  |       |             |             |             |
| PC        | PC-1          | PC            | FSR ADDR          | PC+1             | P     | 0+2         | 0004h       | 0005h       |
| Execute   | 3 Cycle Instr | ruction at PC | INST(PC)          | NOP              | NOP   | NOP         | NOP         | Inst(0004h) |
|           |               |               |                   |                  |       |             |             |             |

#### 11.0 FLASH PROGRAM MEMORY CONTROL

The Flash program memory is readable and writable during normal operation over the full VDD range. Program memory is indirectly addressed using Special Function Registers (SFRs). The SFRs used to access program memory are:

- PMCON1
- PMCON2
- PMDATL
- PMDATH
- PMADRL
- PMADRH

When accessing the program memory, the PMDATH:PMDATL register pair forms a 2-byte word that holds the 14-bit data for read/write, and the PMADRH:PMADRL register pair forms a 2-byte word that holds the 15-bit address of the program memory location being read.

The write time is controlled by an on-chip timer. The write/ erase voltages are generated by an on-chip charge pump rated to operate over the operating voltage range of the device.

The Flash program memory can be protected in two ways; by code protection (CP bit in Configuration Words) and write protection (WRT<1:0> bits in Configuration Words).

Code protection  $(\overline{CP} = 0)^{(1)}$ , disables access, reading and writing, to the Flash program memory via external device programmers. Code protection does not affect the self-write and erase functionality. Code protection can only be reset by a device programmer performing a Bulk Erase to the device, clearing all Flash program memory, Configuration bits and User IDs.

Write protection prohibits self-write and erase to a portion or all of the Flash program memory as defined by the bits WRT<1:0>. Write protection does not affect a device programmers ability to read, write or erase the device.

| Note 1: | Code    | protection        | of   | the    | entire  | Fla | sh  |
|---------|---------|-------------------|------|--------|---------|-----|-----|
|         | progra  | m m <u>em</u> ory | ar   | ray i  | s enab  | led | by  |
|         | clearin | g the CP bit      | of C | Config | uration | Wor | ds. |

#### 11.1 **PMADRL and PMADRH Registers**

The PMADRH:PMADRL register pair can address up to a maximum of 32K words of program memory. When selecting a program address value, the MSB of the address is written to the PMADRH register and the LSB is written to the PMADRL register.

#### 11.1.1 PMCON1 AND PMCON2 REGISTERS

PMCON1 is the control register for Flash program memory accesses.

Control bits RD and WR initiate read and write, respectively. These bits cannot be cleared, only set, in software. They are cleared by hardware at completion of the read or write operation. The inability to clear the WR bit in software prevents the accidental, premature termination of a write operation.

The WREN bit, when set, will allow a write operation to occur. On power-up, the WREN bit is clear. The WRERR bit is set when a write operation is interrupted by a Reset during normal operation. In these situations, following Reset, the user can check the WRERR bit and execute the appropriate error handling routine.

The PMCON2 register is a write-only register. Attempting to read the PMCON2 register will return all '0's.

To enable writes to the program memory, a specific pattern (the unlock sequence), must be written to the PMCON2 register. The required unlock sequence prevents inadvertent writes to the program memory write latches and Flash program memory.

#### 11.2 Flash Program Memory Overview

It is important to understand the Flash program memory structure for erase and programming operations. Flash program memory is arranged in rows. A row consists of a fixed number of 14-bit program memory words. A row is the minimum size that can be erased by user software.

After a row has been erased, the user can reprogram all or a portion of this row. Data to be written into the program memory row is written to 14-bit wide data write latches. These write latches are not directly accessible to the user, but may be loaded via sequential writes to the PMDATH:PMDATL register pair.

Note: If the user wants to modify only a portion of a previously programmed row, then the contents of the entire row must be read and saved in RAM prior to the erase. Then, new data and retained data can be written into the write latches to reprogram the row of Flash program memory. However, any unprogrammed locations can be written without first erasing the row. In this case, it is not necessary to save and rewrite the other previously programmed locations.

See Table 11-1 for Erase Row size and the number of write latches for Flash program memory.

#### **REGISTER 12-21:** LATE: PORTE DATA LATCH REGISTER<sup>(2)</sup>

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-x/u | R/W-x/u | R/W-x/u |
|-------|-----|-----|-----|-----|---------|---------|---------|
| —     | _   | _   | _   | _   | LATE2   | LATE1   | LATE0   |
| 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-3 | Unimplemented: | Read | as | '0' |
|---------|----------------|------|----|-----|
|         |                |      |    | -   |

bit 2-0 LATE<2:0>: PORTE Output Latch Value bits<sup>(1)</sup>

- **Note 1:** Writes to PORTE are actually written to corresponding LATE register. Reads from PORTE register is the return of actual I/O pin values.
  - 2: PIC16(L)F1517/9 only.

#### REGISTER 12-22: ANSELE: PORTE ANALOG SELECT REGISTER<sup>(2)</sup>

| U-0   | U-0 | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 |
|-------|-----|-----|-----|-----|-------|-------|-------|
| —     | _   | —   | —   | _   | ANSE2 | ANSE1 | ANSE0 |
| 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-3 Unimplemented: Read as '0'

bit 2-0 ANSE<2:0>: Analog Select between Analog or Digital Function on pins RE<2:0>, respectively

- 0 = Digital I/O. Pin is assigned to port or digital special function.
- 1 = Analog input. Pin is assigned as analog input<sup>(1)</sup>. Digital input buffer disabled.
- **Note 1:** 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.
  - 2: PIC16(L)F1517/9 only.

### 16.0 ANALOG-TO-DIGITAL CONVERTER (ADC) MODULE

The Analog-to-Digital Converter (ADC) allows conversion of an analog input signal to a 10-bit binary representation of that signal. This device uses analog inputs, which are multiplexed into a single sample and hold circuit. The output of the sample and hold is connected to the input of the converter. The converter generates a 10-bit binary result via successive approximation and stores the conversion result into the ADC result registers (ADRESH:ADRESL register pair). Figure 16-1 shows the block diagram of the ADC.

The ADC voltage reference is software selectable to be either internally generated or externally supplied.

#### FIGURE 16-1: ADC BLOCK DIAGRAM

The ADC can generate an interrupt upon completion of a conversion. This interrupt can be used to wake up the device from Sleep.



#### 16.2.6 ADC CONVERSION PROCEDURE

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

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

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

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

#### EXAMPLE 16-1: ADC CONVERSION

;This code block configures the ADC ; for polling, Vdd and Vss references, Frc ;clock and ANO input. ;Conversion start & polling for completion ; are included. BANKSEL ADCON1 ; B'11110000' ;Right justify, Frc MOVLW ;clock MOVWF ADCON1 ;Vdd and Vss Vref BANKSEL TRISA ; BSF TRISA,0 ;Set RA0 to input BANKSEL ANSEL ; BSF ANSEL,0 ;Set RA0 to analog BANKSEL WPUA wpua, O BCF ;Disable weak pullup on RAO BANKSEL ADCON0 B'00000001' ;Select channel AN0 MOVLW MOVWF ADCON0 ; Turn ADC On CALL SampleTime ;Acquisiton delay BSF ADCON0, ADGO ;Start conversion ADCON0, ADGO ; Is conversion done? BTFSC GOTO \$-1 ;No, test again BANKSEL ADRESH ; ADRESH,W ;Read upper 2 bits MOVF RESULTHI ;store in GPR space MOVWE BANKSEL ADRESL ; MOVF ADRESL,W ;Read lower 8 bits MOVWF RESULTLO ;Store in GPR space

### 19.5 Register Definitions: Timer2 Control

| U-0             | R/W-0/0                    | R/W-0/0           | R/W-0/0        | R/W-0/0        | R/W-0/0          | R/W-0/0        | R/W-0/0      |
|-----------------|----------------------------|-------------------|----------------|----------------|------------------|----------------|--------------|
| —               |                            | T2OUTPS<3:0>      |                |                | TMR2ON           | T2CKP          | S<1:0>       |
| bit 7           |                            |                   |                |                |                  |                | bit (        |
| Legend:         |                            |                   |                |                |                  |                |              |
| R = Readabl     | e bit                      | W = Writable      | bit            | U = Unimpler   | mented bit, read | l as '0'       |              |
| u = Bit is unc  | hanged                     | x = Bit is unkr   | nown           | -n/n = Value a | at POR and BO    | R/Value at all | other Resets |
| '1' = Bit is se | t                          | '0' = Bit is clea | ared           |                |                  |                |              |
|                 |                            |                   | - 1            |                |                  |                |              |
| bit /           | Unimpleme                  | nted: Read as     | 0'<br><b>.</b> |                |                  |                |              |
| bit 6-3         | T2OUTPS<                   | 3:0>: Timer2 Ou   | tput Postscale | er Select bits |                  |                |              |
|                 | 1111 = 1:16                | Postscaler        |                |                |                  |                |              |
|                 | 1110 = 1.15                | Postscaler        |                |                |                  |                |              |
|                 | 1101 - 1.14<br>1100 = 1.13 | Postscaler        |                |                |                  |                |              |
|                 | 1011 = 1:12                | Postscaler        |                |                |                  |                |              |
|                 | 1010 = 1:11                | Postscaler        |                |                |                  |                |              |
|                 | 1001 <b>= 1:10</b>         | Postscaler        |                |                |                  |                |              |
|                 | 1000 <b>= 1:9  </b>        | Postscaler        |                |                |                  |                |              |
|                 | 0111 <b>= 1:8</b>          | Postscaler        |                |                |                  |                |              |
|                 | 0110 = 1:7                 | Postscaler        |                |                |                  |                |              |
|                 | 0101 = 1.6                 |                   |                |                |                  |                |              |
|                 | 0100 = 1.51                |                   |                |                |                  |                |              |
|                 | 0011 = 1.41                | Postscaler        |                |                |                  |                |              |
|                 | 0001 = 1:2                 | Postscaler        |                |                |                  |                |              |
|                 | 0000 = 1:1                 | Postscaler        |                |                |                  |                |              |
| bit 2           | TMR2ON: T                  | imer2 On bit      |                |                |                  |                |              |
|                 | 1 = Timer2                 | is ON             |                |                |                  |                |              |
|                 | 0 = Timer2                 | is OFF            |                |                |                  |                |              |
| bit 1-0         | T2CKPS<1:                  | 0>: Timer2 Cloc   | k Prescale Se  | elect bits     |                  |                |              |
|                 | 11 = Presca                | ler is 64         |                |                |                  |                |              |
|                 | 10 = Presca                | ler is 16         |                |                |                  |                |              |
|                 | 01 = Presca                | ler is 4          |                |                |                  |                |              |
|                 | 00 = Presca                | ler is 1          |                |                |                  |                |              |

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

#### 21.5.8 GENERAL CALL ADDRESS SUPPORT

The addressing procedure for the  $I^2C$  bus is such that the first byte after the Start condition usually determines which device will be the slave addressed by the master device. The exception is the general call address which can address all devices. When this address is used, all devices should, in theory, respond with an acknowledge.

The general call address is a reserved address in the  $I^{2}C$  protocol, defined as address 0x00. When the GCEN bit of the SSPCON2 register is set, the slave module will automatically ACK the reception of this address regardless of the value stored in SSPADD. After the slave clocks in an address of all zeros with

the  $R/\overline{W}$  bit clear, an interrupt is generated and slave software can read SSPBUF and respond. Figure 21-24 shows a General Call reception sequence.

In 10-bit Address mode, the UA bit will not be set on the reception of the general call address. The slave will prepare to receive the second byte as data, just as it would in 7-bit mode.

If the AHEN bit of the SSPCON3 register is set, just as with any other address reception, the slave hardware will stretch the clock after the 8th falling edge of SCL. The slave must then set its ACKDT value and release the clock with communication progressing as it would normally.

#### FIGURE 21-24: SLAVE MODE GENERAL CALL ADDRESS SEQUENCE



#### 21.5.9 SSP MASK REGISTER

An SSP Mask (SSPMSK) register (Register 21-7) is available in I<sup>2</sup>C Slave mode as a mask for the value held in the SSPSR register during an address comparison operation. A zero ('0') bit in the SSPMSK register has the effect of making the corresponding bit of the received address a "don't care".

This register is reset to all '1's upon any Reset condition and, therefore, has no effect on standard SSP operation until written with a mask value.

The SSP Mask register is active during:

- 7-bit Address mode: address compare of A<7:1>.
- 10-bit Address mode: address compare of A<7:0> only. The SSP mask has no effect during the reception of the first (high) byte of the address.

#### 21.7 BAUD RATE GENERATOR

The MSSP module has a Baud Rate Generator available for clock generation in both  $I^2C$  and SPI Master modes. The Baud Rate Generator (BRG) reload value is placed in the SSPADD register (Register 21-8). When a write occurs to SSPBUF, the Baud Rate Generator will automatically begin counting down.

Once the given operation is complete, the internal clock will automatically stop counting and the clock pin will remain in its last state.

An internal signal "Reload" in Figure 21-40 triggers the value from SSPADD to be loaded into the BRG counter. This occurs twice for each oscillation of the module

clock line. The logic dictating when the reload signal is asserted depends on the mode the MSSP is being operated in.

Table 21-2 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPADD.

EQUATION 21-1: BRG CLOCK FREQUENCY

$$FCLOCK = \frac{FOSC}{(SSPxADD + 1)(4)}$$

#### FIGURE 21-40: BAUD RATE GENERATOR BLOCK DIAGRAM



**Note:** Values of 0x00, 0x01 and 0x02 are not valid for SSPADD when used as a Baud Rate Generator for I<sup>2</sup>C. This is an implementation limitation.

#### TABLE 21-2: MSSP CLOCK RATE W/BRG

| Fosc   | Fcy   | BRG Value | FcLock<br>(2 Rollovers of BRG) |
|--------|-------|-----------|--------------------------------|
| 16 MHz | 4 MHz | 09h       | 400 kHz <sup>(1)</sup>         |
| 16 MHz | 4 MHz | 0Ch       | 308 kHz                        |
| 16 MHz | 4 MHz | 27h       | 100 kHz                        |
| 4 MHz  | 1 MHz | 09h       | 100 kHz                        |

**Note 1:** The I<sup>2</sup>C interface does not conform to the 400 kHz I<sup>2</sup>C specification (which applies to rates greater than 100 kHz) in all details, but may be used with care where higher rates are required by the application.







## TABLE 22-5:SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS MASTER<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  | 232                 |
| INTCON  | GIE                           | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF  | 74                  |
| PIE1    | TMR1GIE                       | ADIE   | RCIE   | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 75                  |
| PIR1    | TMR1GIF                       | ADIF   | RCIF   | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 77                  |
| RCSTA   | SPEN                          | RX9    | SREN   | CREN   | ADDEN  | FERR   | OERR   | RX9D   | 231                 |
| SPBRGL  | BRG<7:0>                      |        |        |        |        |        |        |        |                     |
| SPBRGH  | BRG<15:8>                     |        |        |        |        |        |        |        | 233*                |
| TRISC   | TRISC7                        | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 114                 |
| TXREG   | EUSART Transmit Data Register |        |        |        |        |        |        |        |                     |
| TXSTA   | CSRC                          | TX9    | TXEN   | SYNC   | SENDB  | BRGH   | TRMT   | TX9D   | 230                 |

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

#### 22.5.1.5 Synchronous Master Reception

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

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

When SREN is set and CREN is clear, only as many clock cycles are generated as there are data bits in a single character. The SREN bit is automatically cleared at the completion of one character. When CREN is set, clocks are continuously generated until CREN is cleared. If CREN is cleared in the middle of a character the CK clock stops immediately and the partial character is discarded. If SREN and CREN are both set, then SREN is cleared at the completion of the first character and CREN takes precedence.

To initiate reception, set either SREN or CREN. Data is sampled at the RX/DT pin on the trailing edge of the TX/CK clock pin and is shifted into the Receive Shift Register (RSR). When a complete character is received into the RSR, the RCIF bit is set and the character is automatically transferred to the two character receive FIFO. The Least Significant eight bits of the top character in the receive FIFO are available in RCREG. The RCIF bit remains set as long as there are unread characters in the receive FIFO.

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

#### 22.5.1.6 Slave Clock

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

| Note: | If the device is | configured  | d as a | a slave   | and |
|-------|------------------|-------------|--------|-----------|-----|
|       | the TX/CK funct  | ion is on a | n ana  | alog pin, | the |
|       | corresponding    | ANSEL       | bit    | must      | be  |
|       | cleared.         |             |        |           |     |

#### 22.5.1.7 Receive Overrun Error

The receive FIFO buffer can hold two characters. An overrun error will be generated if a third character, in its entirety, is received before RCREG is read to access the FIFO. When this happens the OERR bit of the RCSTA register is set. Previous data in the FIFO will not be overwritten. The two characters in the FIFO buffer can be read, however, no additional characters will be received until the error is cleared. The OERR bit can only be cleared by clearing the overrun condition. If the overrun error occurred when the SREN bit is set and CREN is clear then the error is cleared by reading RCREG. If the overrun occurred when the CREN bit is set then the error condition is cleared by either clearing the CREN bit of the RCSTA register or by clearing the SPEN bit which resets the EUSART.

#### 22.5.1.8 Receiving 9-Bit Characters

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

## 22.5.1.9 Synchronous Master Reception Setup:

- 1. Initialize the SPBRGH, SPBRGL register pair for the appropriate baud rate. Set or clear the BRGH and BRG16 bits, as required, to achieve the desired baud rate.
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- 3. Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC.
- 4. Ensure bits CREN and SREN are clear.
- 5. If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 6. If 9-bit reception is desired, set bit RX9.
- 7. Start reception by setting the SREN bit or for continuous reception, set the CREN bit.
- 8. Interrupt flag bit RCIF will be set when reception of a character is complete. An interrupt will be generated if the enable bit RCIE was set.
- Read the RCSTA register to get the 9th bit (if enabled) and determine if any error occurred during reception.
- 10. Read the 8-bit received data by reading the RCREG register.
- 11. If an overrun error occurs, clear the error by either clearing the CREN bit of the RCSTA register or by clearing the SPEN bit which resets the EUSART.

### 25.2 Standard Operating Conditions

| The standard operating co | onditions for any device are defined as:           |        |
|---------------------------|----------------------------------------------------|--------|
| Operating Voltage:        | $V\text{DDMIN} \leq V\text{DD} \leq V\text{DDMAX}$ |        |
| Operating Temperature:    | $TA\_MIN \le TA \le TA\_MAX$                       |        |
| VDD — Operating Supply    | / Voltage <sup>(1)</sup>                           |        |
| PIC16LF1516/7/8/9         | )                                                  |        |
| VDDMIN (F                 | osc ≤ 16 MHz)                                      |        |
| VDDMIN (10                | 6 MHz ≤Fosc ≤ 20 MHz)                              |        |
| VDDMAX                    |                                                    |        |
| PIC16F1516/7/8/9          |                                                    |        |
| VDDMIN (F                 | osc ≤ 16 MHz)                                      |        |
| VDDMIN (10                | 6 MHz ≤Fosc ≤ 20 MHz)                              |        |
| VDDMAX                    |                                                    |        |
| TA — Operating Ambient    | t Temperature Range                                |        |
| Industrial Temperate      | ure                                                |        |
| TA_MIN                    |                                                    | 40°C   |
| Та_мах                    |                                                    |        |
| Extended Temperat         | ture                                               |        |
| TA_MIN                    |                                                    | -40°C  |
| Та_мах                    |                                                    | +125°C |
| Note 1: See Paramete      | r D001, DC Characteristics: Supply Voltage         | e.     |

| $\label{eq:picture} \begin{tabular}{lllllllllllllllllllllllllllllllllll$ |        |                                                           |            |      |                         | s (unless otherwise stated)<br>$^{\circ}C \le TA \le +85^{\circ}C$ for industrial<br>$^{\circ}C \le TA \le +125^{\circ}C$ for extended |                                                                                                               |  |
|--------------------------------------------------------------------------|--------|-----------------------------------------------------------|------------|------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|--|
| PIC16F1516/7/8/9 Standard Operating Condit<br>Operating temperature      |        |                                                           |            |      | ondition:<br>40'<br>40' | ditions (unless otherwise stated)<br>-40°C $\leq$ TA $\leq$ +85°C for industrial<br>-40°C $\leq$ TA $\leq$ +125°C for extended         |                                                                                                               |  |
| Param.<br>No.                                                            | Sym.   | Characteristic                                            | Min.       | Тур† | Max.                    | Units                                                                                                                                  | Conditions                                                                                                    |  |
| D001                                                                     | Vdd    | Supply Voltage (VDDMIN, VDDMAX)                           |            |      |                         |                                                                                                                                        |                                                                                                               |  |
|                                                                          |        |                                                           | 1.8<br>2.5 |      | 3.6<br>3.6              | V<br>V                                                                                                                                 | Fosc $\leq$ 16 MHz:<br>Fosc $\leq$ 20 MHz                                                                     |  |
| D001                                                                     |        |                                                           | 2.3<br>2.5 | _    | 5.5<br>5.5              | V<br>V                                                                                                                                 | Fosc $\leq$ 16 MHz:<br>Fosc $\leq$ 20 MHz                                                                     |  |
| D002*                                                                    | Vdr    | RAM Data Retention Voltage <sup>(1)</sup>                 |            |      |                         |                                                                                                                                        |                                                                                                               |  |
|                                                                          |        |                                                           | 1.5        | —    | —                       | V                                                                                                                                      | Device in Sleep mode                                                                                          |  |
| D002*                                                                    |        |                                                           | 1.7        |      | —                       | V                                                                                                                                      | Device in Sleep mode                                                                                          |  |
| D002A*                                                                   | VPOR   | Power-on Reset Release Voltage                            | —          | 1.6  | _                       | V                                                                                                                                      |                                                                                                               |  |
| D002B*                                                                   | VPORR  | Power-on Reset Rearm Voltage                              |            |      |                         |                                                                                                                                        |                                                                                                               |  |
|                                                                          |        |                                                           | —          | 0.8  | —                       | V                                                                                                                                      |                                                                                                               |  |
| D002B*                                                                   |        |                                                           | —          | 1.42 | —                       | V                                                                                                                                      |                                                                                                               |  |
| D003                                                                     | VADFVR | Fixed Voltage Reference Voltage for ADC                   | -8         | _    | 6                       | %                                                                                                                                      | $\begin{array}{l} 1.024V, \ VDD \geq 2.5V \\ 2.048V, \ VDD \geq 2.5V \\ 4.096V, \ VDD \geq 4.75V \end{array}$ |  |
| D004*                                                                    | SVDD   | VDD Rise Rate to ensure internal<br>Power-on Reset signal | 0.05       | _    | _                       | V/ms                                                                                                                                   | See Section 6.1 "Power-On Reset (POR)" for details.                                                           |  |

### 25.3 DC Characteristics: Supply Voltage

These parameters are characterized but not tested.

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

Note 1: This is the limit to which VDD can be lowered in Sleep mode without losing RAM data.

| 25.4 DC Characteristics: Supply Current (IDE | istics: Supply Current (IDD) |
|----------------------------------------------|------------------------------|
|----------------------------------------------|------------------------------|

| PIC16LF                                   | 1516/7/8/9      | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |                       |                                                                                                                                                                                                                                                                |       |     |                                                        |  |  |  |
|-------------------------------------------|-----------------|------------------------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|--------------------------------------------------------|--|--|--|
| PIC16F1                                   | 516/7/8/9       |                                                      | Standard<br>Operating | $\begin{array}{ll} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for industrial} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for extended} \end{array}$ |       |     |                                                        |  |  |  |
| Param                                     | Device          | Min.                                                 | Typt                  | Max.                                                                                                                                                                                                                                                           | Units |     | Conditions                                             |  |  |  |
| NO.                                       | Characteristics |                                                      |                       |                                                                                                                                                                                                                                                                |       | Vdd | Note                                                   |  |  |  |
| Supply Current (IDD) <sup>(1, 2, 3)</sup> |                 |                                                      |                       |                                                                                                                                                                                                                                                                |       |     |                                                        |  |  |  |
| D010                                      |                 | —                                                    | 8.0                   | 14                                                                                                                                                                                                                                                             | μA    | 1.8 | Fosc = 32 kHz                                          |  |  |  |
|                                           |                 | —                                                    | 12.0                  | 31                                                                                                                                                                                                                                                             | μA    | 3.0 | LP Oscillator<br>-40°C $\leq$ TA $\leq$ +85°C          |  |  |  |
| D010                                      |                 | —                                                    | 11                    | 28                                                                                                                                                                                                                                                             | μA    | 2.3 | Fosc = 32 kHz                                          |  |  |  |
|                                           |                 |                                                      | 13                    | 38                                                                                                                                                                                                                                                             | μA    | 3.0 | LP Oscillator<br>$-40^{\circ}C < T_{A} < +85^{\circ}C$ |  |  |  |
|                                           |                 | —                                                    | 14                    | 45                                                                                                                                                                                                                                                             | μA    | 5.0 |                                                        |  |  |  |
| D011                                      |                 | —                                                    | 60                    | 95                                                                                                                                                                                                                                                             | μA    | 1.8 | Fosc = 1 MHz                                           |  |  |  |
|                                           |                 | —                                                    | 110                   | 180                                                                                                                                                                                                                                                            | μA    | 3.0 | XT Oscillator                                          |  |  |  |
| D011                                      |                 | _                                                    | 92                    | 170                                                                                                                                                                                                                                                            | μA    | 2.3 | Fosc = 1 MHz                                           |  |  |  |
|                                           |                 | _                                                    | 140                   | 230                                                                                                                                                                                                                                                            | μΑ    | 3.0 | XT Oscillator                                          |  |  |  |
|                                           |                 | —                                                    | 170                   | 350                                                                                                                                                                                                                                                            | μA    | 5.0 |                                                        |  |  |  |
| D012                                      |                 | _                                                    | 150                   | 240                                                                                                                                                                                                                                                            | μA    | 1.8 | Fosc = 4 MHz                                           |  |  |  |
|                                           |                 | —                                                    | 260                   | 430                                                                                                                                                                                                                                                            | μΑ    | 3.0 | X1 Oscillator                                          |  |  |  |
| D012                                      |                 | _                                                    | 190                   | 450                                                                                                                                                                                                                                                            | μΑ    | 2.3 | Fosc = 4 MHz                                           |  |  |  |
|                                           |                 |                                                      | 310                   | 500                                                                                                                                                                                                                                                            | μΑ    | 3.0 |                                                        |  |  |  |
|                                           |                 | —                                                    | 370                   | 650                                                                                                                                                                                                                                                            | μΑ    | 5.0 |                                                        |  |  |  |
| D013                                      |                 | _                                                    | 25                    | 31                                                                                                                                                                                                                                                             | μA    | 1.8 | Fosc = 500 kHz                                         |  |  |  |
|                                           |                 | —                                                    | 35                    | 50                                                                                                                                                                                                                                                             | μA    | 3.0 | Low-Power mode                                         |  |  |  |
| D013                                      |                 | —                                                    | 25                    | 40                                                                                                                                                                                                                                                             | μA    | 2.3 | Fosc = 500 kHz                                         |  |  |  |
|                                           |                 |                                                      | 35                    | 55                                                                                                                                                                                                                                                             | μA    | 3.0 | LC Oscillator                                          |  |  |  |
|                                           |                 | —                                                    | 40                    | 60                                                                                                                                                                                                                                                             | μA    | 5.0 |                                                        |  |  |  |
| D014                                      |                 | _                                                    | 120                   | 210                                                                                                                                                                                                                                                            | μA    | 1.8 | Fosc = 4 MHz                                           |  |  |  |
|                                           |                 | —                                                    | 210                   | 380                                                                                                                                                                                                                                                            | μA    | 3.0 | A Medium-Power mode                                    |  |  |  |
| D014                                      |                 | _                                                    | 160                   | 250                                                                                                                                                                                                                                                            | μA    | 2.3 | Fosc = 4 MHz                                           |  |  |  |
|                                           |                 | _                                                    | 260                   | 380                                                                                                                                                                                                                                                            | μA    | 3.0 | EC Oscillator<br>Medium-Power mode                     |  |  |  |
|                                           |                 | _                                                    | 330                   | 480                                                                                                                                                                                                                                                            | μA    | 5.0 |                                                        |  |  |  |

\* These parameters are characterized but not tested.

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

**Note 1:** The test conditions for all IDD measurements in active operation mode are: OSC1 = external square wave, from rail-to-rail; all I/O pins tri-stated, pulled to VDD; MCLR = VDD; WDT disabled.

- 2: The supply current is mainly a function of the operating voltage and frequency. Other factors, such as I/O pin loading and switching rate, oscillator type, internal code execution pattern and temperature, also have an impact on the current consumption.
- 3: 0.1 µF capacitor on VCAP pin, PIC16F1516/7/8/9 only.
- 4: For RC oscillator configurations, current through REXT is not included. The current through the resistor can be extended by the formula IR = VDD/2REXT (mA) with REXT in kΩ.

| DC CHARACTERISTICS |       |                                                  | $\begin{array}{l} \mbox{Standard Operating Conditions (unless otherwise stated)} \\ \mbox{Operating temperature -40°C $\le$ TA $\le$ +85°C for industrial} \\ \mbox{-40°C $\le$ TA $\le$ +125°C for extended} \end{array}$ |      |      |       |                                                                            |  |  |  |
|--------------------|-------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|----------------------------------------------------------------------------|--|--|--|
| Param<br>No.       | Sym.  | Characteristic                                   | Min.                                                                                                                                                                                                                       | Тур† | Max. | Units | Conditions                                                                 |  |  |  |
|                    | Voн   | Output High Voltage <sup>(4)</sup>               |                                                                                                                                                                                                                            |      |      |       |                                                                            |  |  |  |
| D090               |       | I/O ports                                        | Vdd - 0.7                                                                                                                                                                                                                  | _    | _    | V     | IOH = 3.5 mA, VDD = 5V<br>IOH = 3 mA, VDD = 3.3V<br>IOH = 1 mA, VDD = 1.8V |  |  |  |
|                    |       | Capacitive Loading Specs on Output Pins          |                                                                                                                                                                                                                            |      |      |       |                                                                            |  |  |  |
| D101*              | COSC2 | OSC2 pin                                         | _                                                                                                                                                                                                                          | —    | 15   | pF    | In XT, HS and LP modes when<br>external clock is used to drive<br>OSC1     |  |  |  |
| D101A*             | Сю    | All I/O pins                                     | —                                                                                                                                                                                                                          | _    | 50   | pF    |                                                                            |  |  |  |
|                    |       | VCAP Capacitor Charging                          |                                                                                                                                                                                                                            |      |      |       |                                                                            |  |  |  |
| D102*              |       | Charging current                                 | —                                                                                                                                                                                                                          | _    | 200  | μA    |                                                                            |  |  |  |
| D102A*             |       | Source/Sink capability when<br>charging complete | —                                                                                                                                                                                                                          | _    | 0.0  | mA    |                                                                            |  |  |  |

#### 25.6 DC Characteristics: I/O Ports (Continued)

These parameters are characterized but not tested.

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

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

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

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

4: Including OSC2 in CLKOUT mode.





|--|

| Param<br>No. | Symbol  | Charact         | Min.         | Тур  | Max. | Unit<br>s | Conditions |                              |
|--------------|---------|-----------------|--------------|------|------|-----------|------------|------------------------------|
| SP90*        | TSU:STA | Start condition | 100 kHz mode | 4700 | —    |           | ns         | Only relevant for Repeated   |
|              |         | Setup time      | 400 kHz mode | 600  | —    |           |            | Start condition              |
| SP91*        | THD:STA | Start condition | 100 kHz mode | 4000 | _    | -         | ns         | After this period, the first |
|              |         | Hold time       | 400 kHz mode | 600  | —    | _         |            | clock pulse is generated     |
| SP92*        | Tsu:sto | Stop condition  | 100 kHz mode | 4700 |      | _         | ns         |                              |
|              |         | Setup time      | 400 kHz mode | 600  | _    | -         |            |                              |
| SP93         | THD:STO | Stop condition  | 100 kHz mode | 4000 | —    | _         | ns         |                              |
|              |         | Hold time       | 400 kHz mode | 600  | _    |           |            |                              |

\* These parameters are characterized but not tested.





4.0

VDD (V)

4.5

5.0

#### FIGURE 26-2: IDD, LP OSCILLATOR MODE, FOSC = 32 kHz, PIC16F1516/7/8/9 ONLY

2.5

3.0

3.5

5

0 L 2.0

5.5

6.0





