

#### 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              | 25                                                                          |
| Program Memory Size        | 7KB (4K x 14)                                                               |
| Program Memory Type        | FLASH                                                                       |
| EEPROM Size                | -                                                                           |
| RAM Size                   | 256 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             | 28-SOIC (0.295", 7.50mm Width)                                              |
| Supplier Device Package    | 28-SOIC                                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1513t-i-so |

Email: info@E-XFL.COM

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

### 1.0 DEVICE OVERVIEW

The PIC16(L)F1512/3 are described within this data sheet. They are available in 28-pin packages. Figure 1-1 shows a block diagram of the PIC16(L)F1512/3 devices. Table 1-2 shows the pinout descriptions.

Reference Table 1-1 for peripherals available per device.

### TABLE 1-1:DEVICE PERIPHERAL<br/>SUMMARY

| Peripheral                    | PIC16(L)F1512 | PIC16(L)F1513 |   |
|-------------------------------|---------------|---------------|---|
| Analog-to-Digital Converter ( | ADC)          | ٠             | • |
| Fixed Voltage Reference (FV   | /R)           | ٠             | • |
| Temperature Indicator         |               | •             | • |
| Capture/Compare/PWM Mod       | lules         |               |   |
|                               | CCP1          | ٠             | • |
|                               | CCP2          | •             | • |
| EUSARTs                       |               |               |   |
|                               | EUSART        | ٠             | • |
| Master Synchronous Serial F   | Ports         |               |   |
|                               | MSSP          | ٠             | • |
| Timers                        |               |               |   |
|                               | Timer0        | ٠             | • |
|                               | Timer1        | ٠             | • |
|                               | Timer2        | ٠             | • |

|                     |                                                                                                                                                                                                       | R/P-1                                                                                                                                                                                                        | R/P-1                                                                                                                                             | R/P-1                                                                                                                                                            | R/P-1                                                                                                                  | R/P-1                                                                      | U-1   |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------|
|                     |                                                                                                                                                                                                       | FCMEN                                                                                                                                                                                                        | IESO                                                                                                                                              | CLKOUTEN                                                                                                                                                         | BORE                                                                                                                   | N<1:0>                                                                     |       |
|                     |                                                                                                                                                                                                       | bit 13                                                                                                                                                                                                       |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            | bit 8 |
|                     |                                                                                                                                                                                                       | L                                                                                                                                                                                                            |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| R/P-1               | R/P-1                                                                                                                                                                                                 | R/P-1                                                                                                                                                                                                        | R/P-1                                                                                                                                             | R/P-1                                                                                                                                                            | R/P-1                                                                                                                  | R/P-1                                                                      | R/P-1 |
| CP                  | MCLRE                                                                                                                                                                                                 | PWRTE                                                                                                                                                                                                        | WDT                                                                                                                                               | E<1:0>                                                                                                                                                           |                                                                                                                        | FOSC<2:0>                                                                  |       |
| bit 7               |                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            | bit 0 |
|                     |                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| Legend:             |                                                                                                                                                                                                       |                                                                                                                                                                                                              |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| R = Readable b      | it                                                                                                                                                                                                    | P = Programma                                                                                                                                                                                                | ole bit                                                                                                                                           | U = Unimpleme                                                                                                                                                    | nted bit, read as                                                                                                      | '1'                                                                        |       |
| '0' = Bit is cleare | ed                                                                                                                                                                                                    | '1' = Bit is set                                                                                                                                                                                             |                                                                                                                                                   | -n = Value when                                                                                                                                                  | blank or after B                                                                                                       | ulk Erase                                                                  |       |
| bit 13              | FCMEN: Fail-S<br>1 = Fail-Safe C<br>0 = Fail-Safe C                                                                                                                                                   | Cafe Clock Monitor<br>Clock Monitor is en<br>Clock Monitor is dis                                                                                                                                            | Enable bit<br>abled<br>abled                                                                                                                      |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| bit 12              | IESO: Internal<br>1 = Internal/Ex<br>0 = Internal/Ex                                                                                                                                                  | External Switchov<br>ternal Switchover<br>ternal Switchover                                                                                                                                                  | er bit<br>mode is enable<br>mode is disabl                                                                                                        | ed<br>ed                                                                                                                                                         |                                                                                                                        |                                                                            |       |
| bit 11              | CLKOUTEN: C<br>If FOSC Config<br>This bit is i<br>All other FOSC<br>1 = CLKC<br>0 = CLKC                                                                                                              | Clock Out Enable I<br><u>guration bits are se</u><br>ignored, CLKOUT<br><u>cmodes</u> :<br>DUT function is dis<br>DUT function is en                                                                         | bit<br><u>et to LP, XT, HS</u><br>function is disa<br>abled. I/O func<br>abled on the C                                                           | <u>S modes</u> :<br>abled. Oscillator fu<br>tion on the CLKOI<br>LKOUT pin                                                                                       | nction on the CL<br>JT pin.                                                                                            | .KOUT pin.                                                                 |       |
| bit 10-9            | BOREN<1:0>:<br>11 = BOR enal<br>10 = BOR enal<br>01 = BOR cont<br>00 = BOR disa                                                                                                                       | Brown-out Reset<br>bled<br>bled during operat<br>rolled by SBOREI<br>bled                                                                                                                                    | Enable bits<br>ion and disable<br>N bit of the BO                                                                                                 | ed in Sleep<br>RCON register                                                                                                                                     |                                                                                                                        |                                                                            |       |
| bit 8               | Unimplemente                                                                                                                                                                                          | ed: Read as '1'                                                                                                                                                                                              |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| bit 7               | <b>CP</b> : Code Prote<br>1 = Program m<br>0 = Program m                                                                                                                                              | ection bit<br>lemory code prote<br>lemory code prote                                                                                                                                                         | ction is disable<br>ction is enable                                                                                                               | ed<br>d                                                                                                                                                          |                                                                                                                        |                                                                            |       |
| bit 6               | MCLRE: MCLF<br>If LVP bit = 1:<br>This bit is i<br>If LVP bit = 0:<br>1 = MCLR<br>0 = MCLR<br>WPUE                                                                                                    | R/VPP Pin Function<br>gnored.<br>WPP pin function is<br>WPP pin function is<br>3 bit.                                                                                                                        | n Select bit<br>MCLR; Weak<br>digital input; M                                                                                                    | <u>pull-up</u> enabled.<br>CLR internally disa                                                                                                                   | bled; Weak pull-u                                                                                                      | ıp under control of                                                        |       |
| bit 5               | <b>PWRTE</b> : Power<br>1 = PWRT dis<br>0 = PWRT en                                                                                                                                                   | er-up Timer Enable<br>abled<br>abled                                                                                                                                                                         | e bit                                                                                                                                             |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| bit 4-3             | WDTE<1:0>: Watchdog Timer Enable bit<br>11 = WDT enabled<br>10 = WDT enabled while running and disabled in Sleep<br>01 = WDT controlled by the SWDTEN bit in the WDTCON register<br>00 = WDT disabled |                                                                                                                                                                                                              |                                                                                                                                                   |                                                                                                                                                                  |                                                                                                                        |                                                                            |       |
| bit 2-0             | FOSC<2:0>: C<br>111 = ECH: E<br>110 = ECH: E<br>101 = ECL: E<br>100 = INTOSC<br>011 = EXTRC<br>010 = HS osc<br>001 = XT osci<br>000 = LP osci                                                         | Scillator Selection<br>External Clock, Hig<br>External Clock, Me<br>xternal Clock, Low<br>C oscillator: I/O fu<br>C oscillator: Extern<br>illator: High-speec<br>illator: Crystal/reso<br>illator: Low-power | bits<br>h-Power mode<br>dium-Power m<br>-Power mode<br>nction on CLKI<br>al RC circuit co<br>l crystal/resona<br>onator connect<br>crystal connec | e (4-20 MHz): devia<br>iode (0.5-4 MHz): devia<br>(0-0.5 MHz): devia<br>N pin<br>ponnected to CLKIN<br>ator connected bet<br>ed between OSC1<br>ited between OSC | ce clock supplied<br>device clock sup<br>ee clock supplied<br>pin<br>ween OSC1 and<br>and OSC2 pins<br>1 and OSC2 pins | I to CLKIN pin<br>plied to CLKIN pin<br>I to CLKIN pin<br>I OSC2 pins<br>S | I     |

### **REGISTER 4-1: CONFIGURATION WORD 1**



#### FIGURE 5-10: **FSCM TIMING DIAGRAM**

### 8.1.1 WAKE-UP USING INTERRUPTS

When global interrupts are disabled (GIE cleared) and any interrupt source has both its interrupt enable bit and interrupt flag bit set, one of the following will occur:

- If the interrupt occurs **before** the execution of a SLEEP instruction
  - SLEEP instruction will execute as a NOP
  - WDT and WDT prescaler will not be cleared
  - TO bit of the STATUS register will not be set
  - PD bit of the STATUS register will not be cleared

- If the interrupt occurs **during or after** the execution of a **SLEEP** instruction
  - SLEEP instruction will be completely executed
  - Device will immediately wake-up from Sleep
  - WDT and WDT prescaler will be cleared
  - TO bit of the STATUS register will be set
  - PD bit of the STATUS register will be cleared

Even if the flag bits were checked before executing a SLEEP instruction, it may be possible for flag bits to become set before the SLEEP instruction completes. To determine whether a SLEEP instruction executed, test the PD bit. If the PD bit is set, the SLEEP instruction was executed as a NOP.

| CLKIN <sup>(1</sup><br>CLKOUT <sup>(2</sup> | Q1 Q2 Q3 Q4                                                                    | Q1 Q2 Q3  Q4                                                                            | Q1 <br>                                           | Tost(3)        | Q1 Q2 Q3 Q4       | Q1 Q2 Q3 Q4       | Q1 Q2 Q3 Q4<br>    | Q1 Q2 Q3 Q4<br>~ |
|---------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------------------------------|----------------|-------------------|-------------------|--------------------|------------------|
| Interrupt flag                              | I                                                                              | 1<br>H                                                                                  |                                                   |                | Interrupt Laten   | CV <sup>(4)</sup> |                    |                  |
|                                             | I.                                                                             | ı                                                                                       |                                                   | -              | 1                 |                   | · *                | ı ı              |
| GIE bit                                     | , <u> </u>                                                                     | I<br>I                                                                                  | Processor in                                      |                | <u> </u><br>      | <u> </u>          | I                  |                  |
| (INTCON reg                                 | .).                                                                            | 1                                                                                       | Sleep                                             |                | 1                 |                   | 1                  |                  |
|                                             | ; <u> </u>                                                                     | ; <u> </u>                                                                              |                                                   |                | ; <u> </u>        | ;                 | ; <u> </u>         | ¦— — — −¦·       |
| Instruction Flov                            | /                                                                              | 1                                                                                       | 1                                                 |                | 1                 | 1                 | 1                  | · · ·            |
| PC                                          | Х РС                                                                           | X PC + 1                                                                                | Х РС                                              | + 2            | X PC + 2          | X PC + 2          | X 0004h            | X 0005h          |
| Instruction {<br>Fetched                    | Inst(PC) = Sleep                                                               | Inst(PC + 1)                                                                            | 1<br>1<br>1                                       |                | Inst(PC + 2)      | 1<br>1<br>1       | Inst(0004h)        | Inst(0005h)      |
| Instruction {<br>Executed                   | Inst(PC - 1)                                                                   | Sleep                                                                                   | 1<br>1<br>1                                       |                | Inst(PC + 1)      | Forced NOP        | Forced NOP         | Inst(0004h)      |
| Note 1:<br>2:<br>3:                         | External clock. Hig<br>CLKOUT is shown<br>Tost = 1024 Tosc.<br>"Two-Speed Cloc | h, Medium, Low n<br>here for timing re<br>This delay does r<br><b>k Start-up Mode</b> " | node assumed<br>ference.<br>not apply to Er<br>). | 1.<br>C, RC ar | nd INTOSC Oscilla | tor modes or Two  | -Speed Start-up (s | ee Section 5.4   |
| 2:<br>3:                                    | CLKOUT is shown<br>Tost = 1024 Tosc.<br>"Two-Speed Cloc                        | here for timing re<br>This delay does r<br>k Start-up Mode"                             | ference.<br>not apply to E<br>).                  | C, RC ar       | nd INTOSC Oscilla | tor modes or Two  | -Speed Start-up (s | ee Section 5.4   |

### FIGURE 8-1: WAKE-UP FROM SLEEP THROUGH INTERRUPT

\_\_\_\_\_

DS40001624D-page 76

## TABLE 11-1:FLASH MEMORY<br/>ORGANIZATION BY DEVICE

| Device          | Row Erase<br>(words) | Write<br>Latches<br>(words) |
|-----------------|----------------------|-----------------------------|
| PIC16(L)F1512/3 | 32                   | 32                          |

### 11.2.1 READING THE FLASH PROGRAM MEMORY

To read a program memory location, the user must:

- 1. Write the desired address to the PMADRH:PMADRL register pair.
- 2. Clear the CFGS bit of the PMCON1 register.
- 3. Then, set control bit RD of the PMCON1 register.

Once the read control bit is set, the program memory Flash controller will use the second instruction cycle to read the data. This causes the second instruction immediately following the "BSF PMCON1, RD" instruction to be ignored. The data is available in the very next cycle, in the PMDATH:PMDATL register pair; therefore, it can be read as two bytes in the following instructions.

PMDATH: PMDATL register pair will hold this value until another read or until it is written to by the user.

| Note: | The two instructions following a program |  |  |  |  |
|-------|------------------------------------------|--|--|--|--|
|       | memory read are required to be NOPS.     |  |  |  |  |
|       | This prevents the user from executing a  |  |  |  |  |
|       | two-cycle instruction on the next        |  |  |  |  |
|       | instruction after the RD bit is set.     |  |  |  |  |

### FIGURE 11-1:

### FLASH PROGRAM MEMORY READ FLOWCHART



### 12.0 I/O PORTS

Each port has three standard registers for its operation. These registers are:

- TRISx registers (data direction)
- PORTx registers (reads the levels on the pins of the device)
- LATx registers (output latch)

Some ports may have one or more of the following additional registers. These registers are:

- ANSELx (analog select)
- WPUx (weak pull-up)

In general, when a peripheral is enabled on a port pin, that pin cannot be used as a general purpose output. However, the pin can still be read.

### TABLE 12-1: PORT AVAILABILITY PER DEVICE

| Device        | PORTA | РОКТВ | PORTC | PORTE |
|---------------|-------|-------|-------|-------|
| PIC16(L)F1512 | •     | •     | •     | •     |
| PIC16(L)F1513 | •     | •     | •     | •     |

The Data Latch (LATx registers) is useful for read-modify-write operations on the value that the I/O pins are driving.

A write operation to the LATx register has the same effect as a write to the corresponding PORTx register. A read of the LATx register reads of the values held in the I/O PORT latches, while a read of the PORTx register reads the actual I/O pin value.

Ports that support analog inputs have an associated ANSELx register. When an ANSEL bit is set, the digital input buffer associated with that bit is disabled. Disabling the input buffer prevents analog signal levels on the pin between a logic high and low from causing excessive current in the logic input circuitry. A simplified model of a generic I/O port, without the interfaces to other peripherals, is shown in Figure 12-1.

### FIGURE 12-1: GENERIC I/O PORT OPERATION



### EXAMPLE 12-1: INITIALIZING PORTA

; This code example illustrates ; initializing the PORTA register. The ; other ports are initialized in the same ; manner.

| BANKSEL | PORTA       | ;                      |
|---------|-------------|------------------------|
| CLRF    | PORTA       | ;Init PORTA            |
| BANKSEL | LATA        | ;Data Latch            |
| CLRF    | LATA        | i                      |
| BANKSEL | ANSELA      | ;                      |
| CLRF    | ANSELA      | ;digital I/O           |
| BANKSEL | TRISA       | ;                      |
| MOVLW   | B'00111000' | ;Set RA<5:3> as inputs |
| MOVWF   | TRISA       | ;and set RA<2:0> as    |
|         |             | ;outputs               |
|         |             |                        |

| R/W-x/x          | R/W-x/x | R/W-x/x           | R/W-x/x | R/W-x/x        | R/W-x/x          | R/W-x/x          | R/W-x/x     |
|------------------|---------|-------------------|---------|----------------|------------------|------------------|-------------|
| RA7              | RA6     | RA5               | RA4     | RA3            | RA2              | RA1              | RA0         |
| bit 7            |         |                   |         |                |                  |                  | bit 0       |
|                  |         |                   |         |                |                  |                  |             |
| Legend:          |         |                   |         |                |                  |                  |             |
| R = Readable     | bit     | W = Writable      | bit     | U = Unimpler   | mented bit, read | as '0'           |             |
| u = Bit is uncha | anged   | x = Bit is unkn   | iown    | -n/n = Value a | at POR and BOI   | R/Value at all o | ther Resets |
| '1' = Bit is set |         | '0' = Bit is clea | ared    |                |                  |                  |             |
|                  |         |                   |         |                |                  |                  |             |

### **REGISTER 12-2: PORTA: PORTA REGISTER**

bit 7-0 RA<7:0>: PORTA I/O Value bits<sup>(1)</sup> 1 = Port pin is ≥ VIH 0 = Port pin is ≤ VIL

**Note 1:** Writes to PORTA are actually written to corresponding LATA register. Reads from PORTA register is return of actual I/O pin values.

### REGISTER 12-3: TRISA: PORTA TRI-STATE REGISTER

| R/W-1/1 |
|---------|---------|---------|---------|---------|---------|---------|---------|
| TRISA7  | TRISA6  | TRISA5  | TRISA4  | TRISA3  | TRISA2  | TRISA1  | TRISA0  |
| 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 **TRISA<7:0>:** PORTA Tri-State Control bits

1 = PORTA pin configured as an input (tri-stated)

0 = PORTA pin configured as an output

### 12.5 PORTE Registers

PORTE is a 4-bit wide, bidirectional port. The corresponding data direction register is TRISE. Setting a TRISE bit (= 1) will make the corresponding PORTE pin an input (i.e., put the corresponding output driver in a High-Impedance mode). Clearing a TRISE bit (= 0) will make the corresponding PORTE pin an output (i.e., enable the output driver and put the contents of the output latch on the selected pin). The exception is RE3, which is input only and its TRIS bit will always read as '1'. Example 12-1 shows how to initialize an I/O port.

Reading the PORTE register (Register 12-15) reads the status of the pins, whereas writing to it will write to the PORT latch. All write operations are read-modify-write operations. Therefore, a write to a port implies that the port pins are read, this value is modified and then written to the PORT data latch (LATE). RE3 reads '0' when MCLRE = 1.

### 12.5.1 PORTE FUNCTIONS AND OUTPUT PRIORITIES

PORTE has no peripheral outputs, so the PORTE output has no priority function.



### 16.1.5 INTERRUPTS

The ADC module allows for the ability to generate an interrupt upon completion of an Analog-to-Digital conversion. The ADC Interrupt Flag is the ADIF bit in the PIR1 register. The ADC Interrupt Enable is the ADIE bit in the PIE1 register. The ADIF bit must be cleared in software.

| Note 1: | The ADIF bit is set at the completion of                                        |
|---------|---------------------------------------------------------------------------------|
|         | every conversion, regardless of whether<br>or not the ADC interrupt is enabled. |
|         | or not the ABO interrupt to enabled.                                            |

**2:** The ADC operates during Sleep only when the FRC oscillator is selected.

This interrupt can be generated while the device is operating or while in Sleep. If the device is in Sleep, the interrupt will wake-up the device. Upon waking from Sleep, the next instruction following the SLEEP instruction is always executed. If the user is attempting to wake-up from Sleep and resume in-line code execution, the GIE and PEIE bits of the INTCON register must be disabled. If the GIE and PEIE bits of the INTCON register are enabled, execution will switch to the Interrupt Service Routine.

### 16.1.6 RESULT FORMATTING

The 10-bit A/D conversion result can be supplied in two formats, left justified or right justified. The ADFM bit of the ADCON1 register controls the output format.

Figure 16-3 shows the two output formats.

### FIGURE 16-3: 10-BIT A/D CONVERSION RESULT FORMAT



### 16.4 A/D Acquisition Requirements

For the ADC to meet its specified accuracy, the charge holding capacitor (CHOLD) must be allowed to fully charge to the input channel voltage level. The Analog Input model is shown in Figure 16-4. The source impedance (Rs) and the internal sampling switch (Rss) impedance directly affect the time required to charge the capacitor CHOLD. The sampling switch (Rss) impedance varies over the device voltage (VDD), refer to Figure 16-4. **The maximum recommended impedance for analog sources is 10 k** $\Omega$ . As the source impedance is decreased, the acquisition time may be decreased. After the analog input channel is selected (or changed), an A/D acquisition must be done before the conversion can be started. To calculate the minimum acquisition time, Equation 16-1 may be used. This equation assumes that 1/2 LSb error is used (1,024 steps for the ADC). The 1/2 LSb error is the maximum error allowed for the ADC to meet its specified resolution.

### EQUATION 16-1: ACQUISITION TIME EXAMPLE

sumptions: Temperature = 
$$50^{\circ}C$$
 and external impedance of  $10k\Omega 5.0V$  VDD  
 $TACQ = Amplifier Settling Time + Hold Capacitor Charging Time + Temperature Coefficient$   
 $= TAMP + TC + TCOFF$   
 $= 2\mu s + TC + [(Temperature - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$ 

The value for TC can be approximated with the following equations:

$$V_{APPLIED}\left(1 - \frac{1}{(2^{n+1}) - I}\right) = V_{CHOLD} ; [1] V_{CHOLD} charged to within 1/2 lsb$$

$$V_{APPLIED}\left(1 - e^{\frac{-Tc}{RC}}\right) = V_{CHOLD} ; [2] V_{CHOLD} charge response to V_{APPLIED} (1 - \frac{1}{(2^{n+1}) - I}) ; combining [1] and [2]$$

*Note:* Where n = number of bits of the ADC.

Solving for TC:

As

$$Tc = -CHOLD(RIC + RSS + RS) \ln(1/2047)$$
  
= -13.5pF(1k\Omega + 7k\Omega + 10k\Omega) \ln(0.000488)  
= 1.85\us

Therefore:

$$TACQ = 2\mu s + 1.85\mu s + [(50^{\circ}C - 25^{\circ}C)(0.05\mu s/^{\circ}C)]$$
  
5.1\mu s

Note 1: The reference voltage (VREF) has no effect on the equation, since it cancels itself out.

- 2: The charge holding capacitor (CHOLD) is not discharged after each conversion.
- **3:** The maximum recommended impedance for analog sources is  $10 \text{ k}\Omega$ . This is required to meet the pin leakage specification.

### 19.0 TIMER2 MODULE

The Timer2 module incorporates the following features:

- 8-bit Timer and Period registers (TMR2 and PR2, respectively)
- Readable and writable (both registers)
- Software programmable prescaler (1:1, 1:4, 1:16, and 1:64)
- Software programmable postscaler (1:1 to 1:16)
- · Interrupt on TMR2 match with PR2, respectively
- Optional use as the shift clock for the MSSP modules

See Figure 19-1 for a block diagram of Timer2.









© 2012-2016 Microchip Technology Inc.

### 20.7 BAUD RATE GENERATOR

The MSSP module has a Baud Rate Generator available for clock generation in both I<sup>2</sup>C and SPI Master modes. The Baud Rate Generator (BRG) reload value is placed in the SSPADD register (Register 20-7). 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 20-39 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 20-1 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPADD.

### EQUATION 20-1: BRG CLOCK FREQUENCY

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

### FIGURE 20-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 20-1: 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.

### 22.1.2.8 Asynchronous Reception Set-up:

- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 22.4 "EUSART Baud Rate Generator (BRG)").
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- Enable the serial port by setting the SPEN bit. The SYNC bit must be clear for asynchronous operation.
- 4. If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 5. If 9-bit reception is desired, set the RX9 bit.
- 6. Enable reception by setting the CREN bit.
- 7. The RCIF interrupt flag bit will be set when a character is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCIE interrupt enable bit was also set.
- 8. Read the RCSTA register to get the error flags and, if 9-bit data reception is enabled, the ninth data bit.
- 9. Get the received eight Least Significant data bits from the receive buffer by reading the RCREG register.
- 10. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit.

### 22.1.2.9 9-bit Address Detection Mode Set-up

This mode would typically be used in RS-485 systems. To set up an Asynchronous Reception with Address Detect Enable:

- Initialize the SPBRGH, SPBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 22.4 "EUSART Baud Rate Generator (BRG)").
- 2. Clear the ANSEL bit for the RX pin (if applicable).
- Enable the serial port by setting the SPEN bit. The SYNC bit must be clear for asynchronous operation.
- If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 5. Enable 9-bit reception by setting the RX9 bit.
- 6. Enable address detection by setting the ADDEN bit.
- 7. Enable reception by setting the CREN bit.
- The RCIF interrupt flag bit will be set when a character with the ninth bit set is transferred from the RSR to the receive buffer. An interrupt will be generated if the RCIE interrupt enable bit was also set.
- 9. Read the RCSTA register to get the error flags. The ninth data bit will always be set.
- 10. Get the received eight Least Significant data bits from the receive buffer by reading the RCREG register. Software determines if this is the device's address.
- 11. If an overrun occurred, clear the OERR flag by clearing the CREN receiver enable bit.
- 12. If the device has been addressed, clear the ADDEN bit to allow all received data into the receive buffer and generate interrupts.



### FIGURE 22-5: ASYNCHRONOUS RECEPTION

### FIGURE 22-7: AUTO-WAKE-UP BIT (WUE) TIMING DURING NORMAL OPERATION

| 80 3007<br>660 700X            | · ~~~~<br>·<br>·<br>·<br>: | · · · · · · · · · · · · · · · · · · · |  | · · · · · · · · · · · · · · · · · · · |                            |                                                      | <br>،<br>،<br>،                      |
|--------------------------------|----------------------------|---------------------------------------|--|---------------------------------------|----------------------------|------------------------------------------------------|--------------------------------------|
| 96039<br><b>88</b><br>88696 31 | <br>                       |                                       |  | 3190)<br>                             | anti dun ta Èpone Reas<br> | ,<br>3 66300883<br>///////////////////////////////// | ;<br>;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |



St. The SUSARY consists in the white the Willia has a

### 25.4 Thermal Considerations

| Param<br>No. | Sym.      | Characteristic                         | Тур. | Units | Conditions                                               |  |  |
|--------------|-----------|----------------------------------------|------|-------|----------------------------------------------------------|--|--|
| TH01         | θJA       | Thermal Resistance Junction to Ambient | 80   | °C/W  | 28-pin SOIC package                                      |  |  |
|              |           |                                        | 60   | °C/W  | 28-pin SPDIP package                                     |  |  |
|              |           |                                        | 90   | °C/W  | 28-pin SSOP package                                      |  |  |
|              |           |                                        | 27.5 | °C/W  | 28-pin UQFN package                                      |  |  |
| TH02         | θJC       | Thermal Resistance Junction to Case    | 24   | °C/W  | 28-pin SOIC package                                      |  |  |
|              |           |                                        | 31.4 | °C/W  | 28-pin SPDIP package                                     |  |  |
|              |           |                                        | 24   | °C/W  | 28-pin SSOP package                                      |  |  |
|              |           |                                        | 24   | °C/W  | 28-pin UQFN package                                      |  |  |
| TH03         | TJMAX     | Maximum Junction Temperature           | 150  | °C    |                                                          |  |  |
| TH04         | PD        | Power Dissipation                      | _    | W     | PD = PINTERNAL + PI/O                                    |  |  |
| TH05         | PINTERNAL | Internal Power Dissipation             | _    | W     | PINTERNAL = IDD x VDD <sup>(1)</sup>                     |  |  |
| TH06         | Pi/o      | I/O Power Dissipation                  | _    | W     | $PI/O = \Sigma (IOL * VOL) + \Sigma (IOH * (VDD - VOH))$ |  |  |
| TH07         | Pder      | Derated Power                          |      | W     | Pder = PDmax (Тј - Та)/θја <sup>(2)</sup>                |  |  |

Standard Operating Conditions (unless otherwise stated)

Legend: TBD = To Be Determined

Note 1: IDD is current to run the chip alone without driving any load on the output pins.

2: TA = Ambient Temperature; TJ = Junction Temperature.





FIGURE 26-12: IDD MAXIMUM, EC OSCILLATOR, MEDIUM-POWER MODE, PIC16LF1512/3 ONLY





