

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

-XF

| Product Status             | Active                                                                     |
|----------------------------|----------------------------------------------------------------------------|
| Core Processor             | PIC                                                                        |
| Core Size                  | 8-Bit                                                                      |
| Speed                      | 32MHz                                                                      |
| Connectivity               | I <sup>2</sup> C, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, LCD, POR, PWM, WDT                                 |
| Number of I/O              | 25                                                                         |
| Program Memory Size        | 14KB (8K x 14)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | 256 x 8                                                                    |
| RAM Size                   | 512 x 8                                                                    |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                                |
| Data Converters            | A/D 11x10b                                                                 |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 28-UFQFN Exposed Pad                                                       |
| Supplier Device Package    | 28-UQFN (4x4)                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic16lf1936-e-mv |

Email: info@E-XFL.COM

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

# PIC16(L)F1934/6/7





#### **TABLE 1-2:** PIC16(L)F1934/6/7 PINOUT DESCRIPTION (CONTINUED)

| Name                                                                    | Function | Input<br>Type | Output<br>Type | Description                                                                                        |
|-------------------------------------------------------------------------|----------|---------------|----------------|----------------------------------------------------------------------------------------------------|
| RA6/OSC2/CLKOUT/VCAP <sup>(2)</sup> /                                   | RA6      | TTL           | CMOS           | General purpose I/O.                                                                               |
| SEG1                                                                    | OSC2     | _             | XTAL           | Crystal/Resonator (LP, XT, HS modes).                                                              |
|                                                                         | CLKOUT   | _             | CMOS           | Fosc/4 output.                                                                                     |
|                                                                         | VCAP     | Power         | Power          | Filter capacitor for Voltage Regulator (PIC16F1934/6/7 only).                                      |
|                                                                         | SEG1     | _             | AN             | LCD Analog output.                                                                                 |
| RA7/OSC1/CLKIN/SEG2                                                     | RA7      | TTL           | CMOS           | General purpose I/O.                                                                               |
|                                                                         | OSC1     | XTAL          | —              | Crystal/Resonator (LP, XT, HS modes).                                                              |
|                                                                         | CLKIN    | CMOS          | _              | External clock input (EC mode).                                                                    |
|                                                                         | SEG2     |               | AN             | LCD Analog output.                                                                                 |
| RB0/AN12/CPS0/CCP4/SRI/INT/<br>SEG0                                     | RB0      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up. |
|                                                                         | AN12     | AN            | _              | A/D Channel 12 input.                                                                              |
|                                                                         | CPS0     | AN            | —              | Capacitive sensing input 0.                                                                        |
|                                                                         | CCP4     | ST            | CMOS           | Capture/Compare/PWM4.                                                                              |
|                                                                         | SRI      | _             | ST             | SR Latch input.                                                                                    |
|                                                                         | INT      | ST            | —              | External interrupt.                                                                                |
|                                                                         | SEG0     | —             | AN             | LCD analog output.                                                                                 |
| RB1/AN10/C12IN3-/CPS1/P1C/<br>VLCD1                                     | RB1      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up. |
|                                                                         | AN10     | AN            | _              | A/D Channel 10 input.                                                                              |
|                                                                         | C12IN3-  | AN            | —              | Comparator C1 or C2 negative input.                                                                |
|                                                                         | CPS1     | AN            | _              | Capacitive sensing input 1.                                                                        |
|                                                                         | P1C      | _             | CMOS           | PWM output.                                                                                        |
|                                                                         | VLCD1    | AN            | _              | LCD analog input.                                                                                  |
| RB2/AN8/CPS2/P1B/VLCD2                                                  | RB2      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up. |
|                                                                         | AN8      | AN            | _              | A/D Channel 8 input.                                                                               |
|                                                                         | CPS2     | AN            | —              | Capacitive sensing input 2.                                                                        |
|                                                                         | P1B      | —             | CMOS           | PWM output.                                                                                        |
|                                                                         | VLCD2    | AN            | —              | LCD analog input.                                                                                  |
| RB3/AN9/C12IN2-/CPS3/<br>CCP2 <sup>(1)</sup> /P2A <sup>(1)</sup> /VLCD3 | RB3      | TTL           | CMOS           | General purpose I/O. Individually controlled interrupt-on-change.<br>Individually enabled pull-up. |
|                                                                         | AN9      | AN            | —              | A/D Channel 9 input.                                                                               |
|                                                                         | C12IN2-  | AN            | _              | Comparator C1 or C2 negative input.                                                                |
|                                                                         | CPS3     | AN            | _              | Capacitive sensing input 3.                                                                        |
|                                                                         | CCP2     | ST            | CMOS           | Capture/Compare/PWM2.                                                                              |
|                                                                         | P2A      | _             | CMOS           | PWM output.                                                                                        |
|                                                                         | VLCD3    | AN            | —              | LCD analog input.                                                                                  |

Legend: AN = Analog input or output CMOS = CMOS compatible input or output OD = Open Drain TTL = TTL compatible input ST = Schmitt Trigger input with CMOS levels  $I^2C^{TM}$  = Schmitt Trigger input with  $I^2C$ HV = High Voltage XTAL = Crystal

levels

Note 1: Pin function is selectable via the APFCON register.

2: PIC16F1934/6/7 devices only.

3: PIC16(L)F1936 devices only.

4: PORTD is available on PIC16(L)F1934/7 devices only.

5: RE<2:0> are available on PIC16(L)F1934/7 devices only.

# 5.2 Clock Source Types

Clock sources can be classified as external or internal.

External clock sources rely on external circuitry for the clock source to function. Examples are: oscillator modules (EC mode), quartz crystal resonators or ceramic resonators (LP, XT and HS modes) and Resistor-Capacitor (RC) mode circuits.

Internal clock sources are contained internally within the oscillator module. The internal oscillator block has two internal oscillators and a dedicated Phase-Lock Loop (HFPLL) that are used to generate three internal system clock sources: the 16 MHz High-Frequency Internal Oscillator (HFINTOSC), 500 kHz (MFINTOSC) and the 31 kHz Low-Frequency Internal Oscillator (LFINTOSC).

The system clock can be selected between external or internal clock sources via the System Clock Select (SCS) bits in the OSCCON register. See **Section 5.3 "Clock Switching"** for additional information.

### 5.2.1 EXTERNAL CLOCK SOURCES

An external clock source can be used as the device system clock by performing one of the following actions:

- Program the FOSC<2:0> bits in the Configuration Word 1 to select an external clock source that will be used as the default system clock upon a device Reset.
- Write the SCS<1:0> bits in the OSCCON register to switch the system clock source to:
  - Timer1 Oscillator during run-time, or
  - An external clock source determined by the value of the FOSC bits.

See Section 5.3 "Clock Switching" for more information.

# 5.2.1.1 EC Mode

The External Clock (EC) mode allows an externally generated logic level signal to be the system clock source. When operating in this mode, an external clock source is connected to the OSC1 input. OSC2/CLKOUT is available for general purpose I/O or CLKOUT. Figure 5-2 shows the pin connections for EC mode.

EC mode has 3 power modes to select from through Configuration Word 1:

- High power, 4-32 MHz (FOSC = 111)
- Medium power, 0.5-4 MHz (FOSC = 110)
- Low power, 0-0.5 MHz (FOSC = 101)

The Oscillator Start-up Timer (OST) is disabled when EC mode is selected. Therefore, there is no delay in operation after a Power-on Reset (POR) or wake-up from Sleep. Because the PIC<sup>®</sup> MCU design is fully static, stopping the external clock input will have the effect of halting the device while leaving all data intact. Upon restarting the external clock, the device will resume operation as if no time had elapsed.

FIGURE 5-2:

#### EXTERNAL CLOCK (EC) MODE OPERATION



# 5.2.1.2 LP, XT, HS Modes

The LP, XT and HS modes support the use of quartz crystal resonators or ceramic resonators connected to OSC1 and OSC2 (Figure 5-3). The three modes select a low, medium or high gain setting of the internal inverter-amplifier to support various resonator types and speed.

**LP** Oscillator mode selects the lowest gain setting of the internal inverter-amplifier. LP mode current consumption is the least of the three modes. This mode is designed to drive only 32.768 kHz tuning-fork type crystals (watch crystals).

**XT** Oscillator mode selects the intermediate gain setting of the internal inverter-amplifier. XT mode current consumption is the medium of the three modes. This mode is best suited to drive resonators with a medium drive level specification.

**HS** Oscillator mode selects the highest gain setting of the internal inverter-amplifier. HS mode current consumption is the highest of the three modes. This mode is best suited for resonators that require a high drive setting.

Figure 5-3 and Figure 5-4 show typical circuits for quartz crystal and ceramic resonators, respectively.

# 5.6 Oscillator Control Registers

| R/W-0/0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W-0/0                                                                                                 | R/W-1/1                                                                                                              | R/W-1/1                                                                  | R/W-1/1          | U-0                | R/W-0/0          | R/W-0/0      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------|--------------------|------------------|--------------|
| SPLLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                         | IRCF                                                                                                                 | <3:0>                                                                    |                  | _                  | SCS              | <1:0>        |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                         |                                                                                                                      |                                                                          |                  |                    | -                | bit 0        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                         |                                                                                                                      |                                                                          |                  |                    |                  |              |
| Legend:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                         |                                                                                                                      |                                                                          |                  |                    |                  |              |
| R = Readab                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ole bit                                                                                                 | W = Writable                                                                                                         | bit                                                                      | U = Unimpler     | nented bit, read   | d as '0'         |              |
| u = Bit is unchanged                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                         | x = Bit is unkr                                                                                                      | nown                                                                     | -n/n = Value a   | at POR and BC      | R/Value at all o | other Resets |
| '1' = Bit is se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | et                                                                                                      | '0' = Bit is cle                                                                                                     | ared                                                                     |                  |                    |                  |              |
| bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>SPLLEN:</b> So<br><u>If PLLEN in</u><br>SPLLEN bit<br><u>If PLLEN in</u><br>1 = 4x PLL<br>0 = 4x PLL | oftware PLL Ena<br><u>Configuration W</u><br>is ignored. 4x P<br><u>Configuration W</u><br>Is enabled<br>is disabled | able bit<br>′ <u>ord 1 = 1:</u><br>LL is always e<br>′ <u>ord 1 = 0:</u> | enabled (subject | t to oscillator re | equirements)     |              |
| $0 = 4x PLL \text{ is disabled}$ bit 6-3 $IRCF<3:0>: Internal Oscillator Frequency Select bits$ $000x = 31 \text{ kHz LF}$ $0010 = 31.25 \text{ kHz MF}$ $0011 = 31.25 \text{ kHz HF}^{(1)}$ $0100 = 62.5 \text{ kHz MF}$ $0101 = 125 \text{ kHz MF}$ $0110 = 250 \text{ kHz MF}$ $0111 = 500 \text{ kHz MF} (default upon Reset)$ $1000 = 125 \text{ kHz HF}^{(1)}$ $1001 = 250 \text{ kHz HF}^{(1)}$ $1001 = 250 \text{ kHz HF}^{(1)}$ $1011 = 1 \text{ MHz HF}$ $1100 = 2 \text{ MHz HF}$ $1101 = 4 \text{ MHz HF}$ $1110 = 8 \text{ MHz or 32 MHz HF}(see Section 5.2.2.1 "HFINTOSC")$ |                                                                                                         |                                                                                                                      |                                                                          |                  |                    |                  |              |
| bit 2<br>bit 1-0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Unimpleme<br>SCS<1:0>: 3<br>1x = Interna<br>01 = Timer1                                                 | nted: Read as '<br>System Clock S<br>I oscillator block<br>oscillator                                                | 0'<br>elect bits                                                         |                  |                    |                  |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00 = Clock (                                                                                            | determined by F                                                                                                      | OSC<2:0> in                                                              | Configuration W  | /ord 1.            |                  |              |
| Note 1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Duplicate freque                                                                                        | ncy derived from                                                                                                     | HFINTOSC.                                                                |                  |                    |                  |              |

# REGISTER 5-1: OSCCON: OSCILLATOR CONTROL REGISTER

| FIGURE 7  | 7-2: I       | NTERRUPT      | LATENCY           |                       |       |             |                  |             |
|-----------|--------------|---------------|-------------------|-----------------------|-------|-------------|------------------|-------------|
|           |              |               |                   |                       |       |             |                  |             |
| OSC1      |              |               |                   | \\\\\<br> Q1 Q2 Q3 Q4 |       |             | ∩<br>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 Inst | ruction at PC | Inst(PC)          | NOP                   | NOP   | Inst(0004h) | L                |             |
|           |              |               |                   |                       |       |             |                  |             |
| Interrupt |              |               | l                 |                       |       |             |                  |             |
| GIE       |              |               |                   |                       |       |             |                  |             |
| PC        | PC-1         | PC            | PC+1/FSR<br>ADDR  | New PC/<br>PC+1       | 0004h | 0005h       |                  |             |
| Execute-  | 2 Cycle Inst | ruction at PC | Inst(PC)          | NOP                   | NOP   | Inst(0004h) |                  |             |
|           |              |               |                   | 1                     |       |             |                  |             |
| Interrupt |              |               |                   |                       |       |             |                  |             |
| GIE       |              |               |                   |                       |       |             |                  |             |
| PC        | PC-1         | PC            | FSR ADDR          | PC+1                  | PC+2  | 0004h       | 0005h            | )           |
| Execute   | 3 Cycle Inst | ruction at PC | INST(PC)          | NOP                   | NOP   | NOP         | Inst(0004h)      | Inst(0005h) |
| Interrupt |              |               |                   |                       |       |             |                  |             |
| GIE       |              |               |                   |                       |       |             |                  |             |
| PC        | PC-1         | РС            | FSR ADDR          | PC+1                  | PC    | +2          | 0004h            | 0005h       |
| Execute   | 3 Cycle Inst | ruction at PC | INST(PC)          | NOP                   | NOP   | NOP         | NOP              | Inst(0004h) |
|           |              |               |                   |                       |       |             |                  |             |

| EXAMPLE 11-2: | DATA EEPROM WRITE |
|---------------|-------------------|
|               |                   |

|      |     | BANKSEL | EEADRL   |       | i                             |  |  |  |  |  |
|------|-----|---------|----------|-------|-------------------------------|--|--|--|--|--|
|      |     | MOVLW   | DATA_EE_ | ADDR  | ;                             |  |  |  |  |  |
|      |     | MOVWF   | EEADRL   |       | ;Data Memory Address to write |  |  |  |  |  |
|      |     | MOVLW   | DATA_EE_ | DATA  | ;                             |  |  |  |  |  |
|      |     | MOVWF   | EEDATL   |       | ;Data Memory Value to write   |  |  |  |  |  |
|      |     | BCF     | EECON1,  | CFGS  | ;Deselect Configuration space |  |  |  |  |  |
|      |     | BCF     | EECON1,  | EEPGD | ;Point to DATA memory         |  |  |  |  |  |
|      |     | BSF     | EECON1,  | WREN  | ;Enable writes                |  |  |  |  |  |
|      |     |         |          |       |                               |  |  |  |  |  |
|      |     | BCF     | INTCON,  | GIE   | ;Disable INTs.                |  |  |  |  |  |
|      | -   | MOVLW   | 55h      |       | ;                             |  |  |  |  |  |
| ð    | e   | MOVWF   | EECON2   |       | ;Write 55h                    |  |  |  |  |  |
| uire | len | MOVLW   | 0AAh     |       | ;                             |  |  |  |  |  |
| Seq  | edr | MOVWF   | EECON2   |       | ;Write AAh                    |  |  |  |  |  |
| ш    | S   | BSF     | EECON1,  | WR    | ;Set WR bit to begin write    |  |  |  |  |  |
|      | -   | BSF     | INTCON,  | GIE   | ;Enable Interrupts            |  |  |  |  |  |
|      |     | BCF     | EECON1,  | WREN  | ;Disable writes               |  |  |  |  |  |
|      |     | BTFSC   | EECON1,  | WR    | ;Wait for write to complete   |  |  |  |  |  |
|      |     | GOTO    | \$-2     |       | ;Done                         |  |  |  |  |  |
|      |     |         |          |       |                               |  |  |  |  |  |





#### 15.2.7 ADC REGISTER DEFINITIONS

The following registers are used to control the operation of the ADC.

#### REGISTER 15-1: ADCON0: A/D CONTROL REGISTER 0

| U-0   | R/W-0/0 | R/W-0/0 | R/W-0/0 | 0 R/W-0/0 R/W-0/0 |  | R/W-0/0 | R/W-0/0 |
|-------|---------|---------|---------|-------------------|--|---------|---------|
| —     |         |         | GO/DONE | ADON              |  |         |         |
| 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   |          | Unimplemented: Read as '0'                                                             |
|---------|----------|----------------------------------------------------------------------------------------|
| bit 6-2 | 2        | CHS<4:0>: Analog Channel Select bits                                                   |
|         |          | 00000 <b>= ANO</b>                                                                     |
|         |          | 00001 <b>= AN1</b>                                                                     |
|         |          | 00010 <b>= AN2</b>                                                                     |
|         |          | 00011 <b>= AN3</b>                                                                     |
|         |          | 00100 = AN4                                                                            |
|         |          | $00101 = AN5^{(4)}$                                                                    |
|         |          | $00110 = AN6^{(4)}$                                                                    |
|         |          | $00111 = AN7^{(4)}$                                                                    |
|         |          | 01000 = AN8                                                                            |
|         |          | 01001 = AN9                                                                            |
|         |          | 01010 = AN10                                                                           |
|         |          | 01011 = AN11                                                                           |
|         |          | 01100 = AN12                                                                           |
|         |          | 01110 - Reserved No channel connected                                                  |
|         |          | •                                                                                      |
|         |          | •                                                                                      |
|         |          | •                                                                                      |
|         |          | 11100 = Reserved. No channel connected.                                                |
|         |          | 11101 = Temperature Indicator <sup>(3)</sup>                                           |
|         |          | 11110 = DAC output <sup>(1)</sup>                                                      |
|         |          | 11111 = FVR (Fixed Voltage Reference) Buffer 1 Output <sup>(2)</sup>                   |
| bit 1   |          | GO/DONE: A/D Conversion Status bit                                                     |
|         |          | 1 = A/D conversion cycle in progress. Setting this bit starts an A/D conversion cycle. |
|         |          | This bit is automatically cleared by hardware when the A/D conversion has completed.   |
|         |          | 0 = A/D conversion completed/not in progress                                           |
| bit 0   |          | ADON: ADC Enable bit                                                                   |
|         |          | 1 = ADC is enabled                                                                     |
|         |          | 0 = ADC is disabled and consumes no operating current                                  |
| Note    | 1:       | See Section 17.0 "Digital-to-Analog Converter (DAC) Module" for more information       |
|         | 2.       | See Section 14.0 "Fixed Voltage Reference (EVR)" for more information                  |
|         | 2.<br>2. | See Section 16.0 "Temperature Indicator Medule" for more information                   |
|         | J:       | See Section 16.0 remperature indicator module for more information.                    |

4: Not available on the PIC16(L)F1936.

# 21.12 Timer1 Gate Control Register

The Timer1 Gate Control register (T1GCON), shown in Register 21-2, is used to control Timer1 gate.

| R/W-0/u                                                                                                                                                                                 | R/W-0/u                                                              | R/W-0/u                                                               | R/W-0/u                                                          | R/W/HC-0/u                        | R-x/x                          | R/W-0/u          | R/W-0/u     |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------|-----------------------------------|--------------------------------|------------------|-------------|--|--|--|
| TMR1GE                                                                                                                                                                                  | T1GPOL                                                               | T1GTM                                                                 | T1GSPM                                                           | T1GGO/<br>DONE                    | T1GVAL                         | T1GSS            | 6<1:0>      |  |  |  |
| bit 7                                                                                                                                                                                   |                                                                      | I                                                                     | L                                                                |                                   |                                | I                | bit 0       |  |  |  |
|                                                                                                                                                                                         |                                                                      |                                                                       |                                                                  |                                   |                                |                  |             |  |  |  |
| Legend:                                                                                                                                                                                 |                                                                      |                                                                       |                                                                  |                                   |                                |                  |             |  |  |  |
| R = Readable                                                                                                                                                                            | bit                                                                  | W = Writable                                                          | bit                                                              | U = Unimplen                      | nented bit, read               | d as '0'         |             |  |  |  |
| u = Bit is unch                                                                                                                                                                         | anged                                                                | x = Bit is unkr                                                       | nown                                                             | -n/n = Value a                    | at POR and BO                  | R/Value at all o | ther Resets |  |  |  |
| '1' = Bit is set                                                                                                                                                                        |                                                                      | '0' = Bit is clea                                                     | ared                                                             | HC = Bit is cle                   | eared by hardw                 | are              |             |  |  |  |
| bit 7 <b>TMR1GE:</b> Timer1 Gate Enable bit<br>If <u>TMR1ON = 0</u> :<br>This bit is ignored<br>If <u>TMR1ON = 1</u> :<br>1 = Timer1 counting is controlled by the Timer1 gate function |                                                                      |                                                                       |                                                                  |                                   |                                |                  |             |  |  |  |
| bit 6                                                                                                                                                                                   | <b>T1GPOL:</b> Tim<br>1 = Timer1 ga<br>0 = Timer1 ga                 | ner1 Gate Pola<br>ate is active-hig<br>ate is active-lo               | rity bit<br>gh (Timer1 cou<br>w (Timer1 cou                      | unts when gate<br>nts when gate i | is high)<br>s low)             |                  |             |  |  |  |
| bit 5                                                                                                                                                                                   | <b>T1GTM:</b> Time<br>1 = Timer1 G<br>0 = Timer1 G<br>Timer1 gate fl | er1 Gate Toggle<br>ate Toggle mo<br>ate Toggle mo<br>lip-flop toggles | e Mode bit<br>de is enabled<br>de is disabled<br>on every rising | and toggle flip                   | flop is cleared                |                  |             |  |  |  |
| bit 4                                                                                                                                                                                   | T1GSPM: Tin                                                          | ner1 Gate Sing                                                        | le-Pulse Mode                                                    | e bit                             |                                |                  |             |  |  |  |
|                                                                                                                                                                                         | 1 = Timer1 ga<br>0 = Timer1 ga                                       | ate Single-Puls<br>ate Single-Puls                                    | se mode is ena<br>se mode is disa                                | bled and is cor<br>abled          | ntrolling Timer1               | gate             |             |  |  |  |
| bit 3                                                                                                                                                                                   | T1GGO/DON                                                            | E: Timer1 Gate                                                        | e Single-Pulse                                                   | Acquisition Sta                   | atus bit                       |                  |             |  |  |  |
|                                                                                                                                                                                         | 1 = Timer1 ga<br>0 = Timer1 ga                                       | ate single-pulse<br>ate single-pulse                                  | e acquisition is<br>e acquisition h                              | ready, waiting as completed c     | for an edge<br>or has not been | started          |             |  |  |  |
| bit 2                                                                                                                                                                                   | T1GVAL: Tim                                                          | er1 Gate Curre                                                        | ent State bit                                                    |                                   |                                |                  |             |  |  |  |
|                                                                                                                                                                                         | Indicates the<br>Unaffected by                                       | current state of<br>Timer1 Gate I                                     | f the Timer1 ga<br>Enable (TMR1                                  | ate that could b<br>GE).          | e provided to T                | MR1H:TMR1L.      |             |  |  |  |
| bit 1-0                                                                                                                                                                                 | T1GSS<1:0>                                                           | : Timer1 Gate                                                         | Source Select                                                    | bits                              |                                |                  |             |  |  |  |
|                                                                                                                                                                                         | 00 = Timer1 g<br>01 = Timer0 g<br>10 = Compar<br>11 = Compar         | gate pin<br>overflow output<br>ator 1 optionall<br>ator 2 optionall   | :<br>y synchronize<br>y synchronize                              | d output (SYNC<br>d output (SYNC  | CC1OUT)<br>CC2OUT)             |                  |             |  |  |  |

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

# 22.1 Timer2/4/6 Operation

The clock input to the Timer2/4/6 modules is the system instruction clock (Fosc/4).

TMRx increments from 00h on each clock edge.

A 4-bit counter/prescaler on the clock input allows direct input, divide-by-4 and divide-by-16 prescale options. These options are selected by the prescaler control bits, TxCKPS<1:0> of the TxCON register. The value of TMRx is compared to that of the Period register, PRx, on each clock cycle. When the two values match, the comparator generates a match signal as the timer output. This signal also resets the value of TMRx to 00h on the next cycle and drives the output counter/postscaler (see Section 22.2 "Timer2/4/6 Interrupt").

The TMRx and PRx registers are both directly readable and writable. The TMRx register is cleared on any device Reset, whereas the PRx register initializes to FFh. Both the prescaler and postscaler counters are cleared on the following events:

- · a write to the TMRx register
- · a write to the TxCON register
- Power-on Reset (POR)
- Brown-out Reset (BOR)
- MCLR Reset
- Watchdog Timer (WDT) Reset
- · Stack Overflow Reset
- Stack Underflow Reset
- RESET Instruction



# 22.2 Timer2/4/6 Interrupt

Timer2/4/6 can also generate an optional device interrupt. The Timer2/4/6 output signal (TMRx-to-PRx match) provides the input for the 4-bit counter/postscaler. This counter generates the TMRx match interrupt flag which is latched in TMRxIF of the PIRx register. The interrupt is enabled by setting the TMRx Match Interrupt Enable bit, TMRxIE, of the PIEx register.

A range of 16 postscale options (from 1:1 through 1:16 inclusive) can be selected with the postscaler control bits, TxOUTPS<3:0>, of the TxCON register.

# 22.3 Timer2/4/6 Output

The unscaled output of TMRx is available primarily to the CCP modules, where it is used as a time base for operations in PWM mode.

Timer2 can be optionally used as the shift clock source for the MSSP module operating in SPI mode. Additional information is provided in **Section 24.0 "Master Synchronous Serial Port Module"** 

# 22.4 Timer2/4/6 Operation During Sleep

The Timer2/4/6 timers cannot be operated while the processor is in Sleep mode. The contents of the TMRx and PRx registers will remain unchanged while the processor is in Sleep mode.

# 24.2.2 SPI MODE OPERATION

When initializing the SPI, several options need to be specified. This is done by programming the appropriate control bits (SSPCON1<5:0> and SSPSTAT<7:6>). These control bits allow the following to be specified:

- · Master mode (SCK is the clock output)
- · Slave mode (SCK is the clock input)
- Clock Polarity (Idle state of SCK)
- Data Input Sample Phase (middle or end of data output time)
- Clock Edge (output data on rising/falling edge of SCK)
- Clock Rate (Master mode only)
- · Slave Select mode (Slave mode only)

To enable the serial port, SSP Enable bit, SSPEN of the SSPCON1 register, must be set. To reset or reconfigure SPI mode, clear the SSPEN bit, re-initialize the SSPCONx registers and then set the SSPEN bit. This configures the SDI, SDO, SCK and SS pins as serial port pins. For the pins to behave as the serial port function, some must have their data direction bits (in the TRIS register) appropriately programmed as follows:

- · SDI must have corresponding TRIS bit set
- · SDO must have corresponding TRIS bit cleared
- SCK (Master mode) must have corresponding TRIS bit cleared
- SCK (Slave mode) must have corresponding
   TRIS bit set
- SS must have corresponding TRIS bit set

Any serial port function that is not desired may be overridden by programming the corresponding data direction (TRIS) register to the opposite value. The MSSP consists of a transmit/receive shift register (SSPSR) and a buffer register (SSPBUF). The SSPSR shifts the data in and out of the device, MSb first. The SSPBUF holds the data that was written to the SSPSR until the received data is ready. Once the 8 bits of data have been received, that byte is moved to the SSPBUF register. Then, the Buffer Full Detect bit, BF of the SSPSTAT register, and the interrupt flag bit, SSPIF, are set. This double-buffering of the received data (SSPBUF) allows the next byte to start reception before reading the data that was just received. Any write to the SSPBUF register during transmission/reception of data will be ignored and the write collision detect bit WCOL of the SSPCON1 register, will be set. User software must clear the WCOL bit to allow the following write(s) to the SSPBUF register to complete successfully.

When the application software is expecting to receive valid data, the SSPBUF should be read before the next byte of data to transfer is written to the SSPBUF. The Buffer Full bit, BF of the SSPSTAT register, indicates when SSPBUF has been loaded with the received data (transmission is complete). When the SSPBUF is read, the BF bit is cleared. This data may be irrelevant if the SPI is only a transmitter. Generally, the MSSP interrupt is used to determine when the transmission/reception has completed. If the interrupt method is not going to be used, then software polling can be done to ensure that a write collision does not occur.

The SSPSR is not directly readable or writable and can only be accessed by addressing the SSPBUF register. Additionally, the SSPSTAT register indicates the various status conditions.



#### FIGURE 24-5: SPI MASTER/SLAVE CONNECTION

PIC16(L)F1934/6/7



# 24.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 24-6). 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 24-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 24-4 demonstrates clock rates based on instruction cycles and the BRG value loaded into SSPADD.

#### **EQUATION 24-1:**

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

# FIGURE 24-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 24-4: MSSP CLOCK RATE W/BRG

| Fosc   | Fcy   | BRG Value | FcLock<br>(2 Rollovers of BRG) |
|--------|-------|-----------|--------------------------------|
| 32 MHz | 8 MHz | 13h       | 400 kHz <sup>(1)</sup>         |
| 32 MHz | 8 MHz | 19h       | 308 kHz                        |
| 32 MHz | 8 MHz | 4Fh       | 100 kHz                        |
| 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.

|        | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BR |            |                             |                   |            |                             |                   |            | BRG16 = 1                   |                    |            |                             |
|--------|-----------------------------------------------|------------|-----------------------------|-------------------|------------|-----------------------------|-------------------|------------|-----------------------------|--------------------|------------|-----------------------------|
| BAUD   | Fosc = 32.000 MHz                             |            |                             | Fosc = 20.000 MHz |            |                             | Fosc = 18.432 MHz |            |                             | Fosc = 11.0592 MHz |            |                             |
| RATE   | Actual<br>Rate                                | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate    | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate     | %<br>Error | SPBRG<br>value<br>(decimal) |
| 300    | 300.0                                         | 0.00       | 26666                       | 300.0             | 0.00       | 16665                       | 300.0             | 0.00       | 15359                       | 300.0              | 0.00       | 9215                        |
| 1200   | 1200                                          | 0.00       | 6666                        | 1200              | -0.01      | 4166                        | 1200              | 0.00       | 3839                        | 1200               | 0.00       | 2303                        |
| 2400   | 2400                                          | 0.01       | 3332                        | 2400              | 0.02       | 2082                        | 2400              | 0.00       | 1919                        | 2400               | 0.00       | 1151                        |
| 9600   | 9604                                          | 0.04       | 832                         | 9597              | -0.03      | 520                         | 9600              | 0.00       | 479                         | 9600               | 0.00       | 287                         |
| 10417  | 10417                                         | 0.00       | 767                         | 10417             | 0.00       | 479                         | 10425             | 0.08       | 441                         | 10433              | 0.16       | 264                         |
| 19.2k  | 19.18k                                        | -0.08      | 416                         | 19.23k            | 0.16       | 259                         | 19.20k            | 0.00       | 239                         | 19.20k             | 0.00       | 143                         |
| 57.6k  | 57.55k                                        | -0.08      | 138                         | 57.47k            | -0.22      | 86                          | 57.60k            | 0.00       | 79                          | 57.60k             | 0.00       | 47                          |
| 115.2k | 115.9k                                        | 0.64       | 68                          | 116.3k            | 0.94       | 42                          | 115.2k            | 0.00       | 39                          | 115.2k             | 0.00       | 23                          |

# TABLE 25-5: BAUD RATES FOR ASYNCHRONOUS MODES (CONTINUED)

|              | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1 |            |                             |                  |            |                             |                |            |                             |                |            |                             |
|--------------|------------------------------------------------------|------------|-----------------------------|------------------|------------|-----------------------------|----------------|------------|-----------------------------|----------------|------------|-----------------------------|
| BAUD<br>RATE | Fosc = 8.000 MHz                                     |            |                             | Fosc = 4.000 MHz |            | Fosc = 3.6864 MHz           |                |            | Fosc = 1.000 MHz            |                |            |                             |
|              | Actual<br>Rate                                       | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate   | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) | Actual<br>Rate | %<br>Error | SPBRG<br>value<br>(decimal) |
| 300          | 300.0                                                | 0.00       | 6666                        | 300.0            | 0.01       | 3332                        | 300.0          | 0.00       | 3071                        | 300.1          | 0.04       | 832                         |
| 1200         | 1200                                                 | -0.02      | 1666                        | 1200             | 0.04       | 832                         | 1200           | 0.00       | 767                         | 1202           | 0.16       | 207                         |
| 2400         | 2401                                                 | 0.04       | 832                         | 2398             | 0.08       | 416                         | 2400           | 0.00       | 383                         | 2404           | 0.16       | 103                         |
| 9600         | 9615                                                 | 0.16       | 207                         | 9615             | 0.16       | 103                         | 9600           | 0.00       | 95                          | 9615           | 0.16       | 25                          |
| 10417        | 10417                                                | 0          | 191                         | 10417            | 0.00       | 95                          | 10473          | 0.53       | 87                          | 10417          | 0.00       | 23                          |
| 19.2k        | 19.23k                                               | 0.16       | 103                         | 19.23k           | 0.16       | 51                          | 19.20k         | 0.00       | 47                          | 19.23k         | 0.16       | 12                          |
| 57.6k        | 57.14k                                               | -0.79      | 34                          | 58.82k           | 2.12       | 16                          | 57.60k         | 0.00       | 15                          | —              | —          | —                           |
| 115.2k       | 117.6k                                               | 2.12       | 16                          | 111.1k           | -3.55      | 8                           | 115.2k         | 0.00       | 7                           | _              | _          | _                           |

# 25.4.2.3 EUSART Synchronous Slave Reception

The operation of the Synchronous Master and Slave modes is identical (Section 25.4.1.5 "Synchronous Master Reception"), with the following exceptions:

- Sleep
- CREN bit is always set, therefore the receiver is never Idle
- · SREN bit, which is a "don't care" in Slave mode

A character may be received while in Sleep mode by setting the CREN bit prior to entering Sleep. Once the word is received, the RSR register will transfer the data to the RCREG register. If the RCIE enable bit is set, the interrupt generated will wake the device from Sleep and execute the next instruction. If the GIE bit is also set, the program will branch to the interrupt vector.

- 25.4.2.4 Synchronous Slave Reception Set-up:
- 1. Set the SYNC and SPEN bits and clear the CSRC bit.
- 2. Clear the ANSEL bit for both the CK and DT pins (if applicable).
- 3. If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- 4. If 9-bit reception is desired, set the RX9 bit.
- 5. Set the CREN bit to enable reception.
- The RCIF bit will be set when reception is complete. An interrupt will be generated if the RCIE bit was set.
- 7. If 9-bit mode is enabled, retrieve the Most Significant bit from the RX9D bit of the RCSTA register.
- 8. Retrieve the 8 Least Significant bits from the receive FIFO by reading the RCREG register.
- 9. 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.

| 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  | 302                 |
| INTCON  | GIE                          | PEIE   | TMR0IE | INTE   | IOCIE  | TMR0IF | INTF   | IOCIF  | 98                  |
| PIE1    | TMR1GIE                      | ADIE   | RCIE   | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 99                  |
| PIR1    | TMR1GIF                      | ADIF   | RCIF   | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 102                 |
| RCREG   | EUSART Receive Data Register |        |        |        |        |        |        |        |                     |
| RCSTA   | SPEN                         | RX9    | SREN   | CREN   | ADDEN  | FERR   | OERR   | RX9D   | 301                 |
| TRISC   | TRISC7                       | TRISC6 | TRISC5 | TRISC4 | TRISC3 | TRISC2 | TRISC1 | TRISC0 | 142                 |
| TXSTA   | CSRC                         | TX9    | TXEN   | SYNC   | SENDB  | BRGH   | TRMT   | TX9D   | 300                 |

# TABLE 25-10: SUMMARY OF REGISTERS ASSOCIATED WITH SYNCHRONOUS SLAVE RECEPTION

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

\* Page provides register information.

# 25.5 EUSART Operation During Sleep

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

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

#### 25.5.1 SYNCHRONOUS RECEIVE DURING SLEEP

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

- RCSTA and TXSTA Control registers must be configured for Synchronous Slave Reception (see Section 25.4.2.4 "Synchronous Slave Reception Set-up:").
- If interrupts are desired, set the RCIE bit of the PIE1 register and the GIE and PEIE bits of the INTCON register.
- The RCIF interrupt flag must be cleared by reading RCREG to unload any pending characters in the receive buffer.

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

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

#### 25.5.2 SYNCHRONOUS TRANSMIT DURING SLEEP

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

- RCSTA and TXSTA Control registers must be configured for Synchronous Slave Transmission (see Section 25.4.2.2 "Synchronous Slave Transmission Set-up:").
- The TXIF interrupt flag must be cleared by writing the output data to the TXREG, thereby filling the TSR and transmit buffer.
- If interrupts are desired, set the TXIE bit of the PIE1 register and the PEIE bit of the INTCON register.
- Interrupt enable bits TXIE of the PIE1 register and PEIE of the INTCON register must set.

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

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

# 26.5 Timer Resources

To measure the change in frequency of the capacitive sensing oscillator, a fixed time base is required. For the period of the fixed time base, the capacitive sensing oscillator is used to clock either Timer0 or Timer1. The frequency of the capacitive sensing oscillator is equal to the number of counts in the timer divided by the period of the fixed time base.

# 26.6 Fixed Time Base

To measure the frequency of the capacitive sensing oscillator, a fixed time base is required. Any timer resource or software loop can be used to establish the fixed time base. It is up to the end user to determine the method in which the fixed time base is generated.

| Note: | The fixed time base can not be generated  |  |  |  |  |  |
|-------|-------------------------------------------|--|--|--|--|--|
|       | by the timer resource that the capacitive |  |  |  |  |  |
|       | sensing oscillator is clocking.           |  |  |  |  |  |

#### 26.6.1 TIMER0

To select Timer0 as the timer resource for the CPS module:

- Set the T0XCS bit of the CPSCON0 register.
- Clear the TMR0CS bit of the OPTION\_REG register.

When Timer0 is chosen as the timer resource, the capacitive sensing oscillator will be the clock source for Timer0. Refer to **Section 20.0** "**Timer0 Module**" for additional information.

# 26.6.2 TIMER1

To select Timer1 as the timer resource for the CPS module, set the TMR1CS<1:0> of the T1CON register to '11'. When Timer1 is chosen as the timer resource, the capacitive sensing oscillator will be the clock source for Timer1. Because the Timer1 module has a gate control, developing a time base for the frequency measurement can be simplified by using the Timer0 overflow flag.

It is recommend that the Timer0 overflow flag, in conjunction with the Toggle mode of the Timer1 gate, be used to develop the fixed time base required by the software portion of the CPS module. Refer to **Section 21.12 "Timer1 Gate Control Register"** for additional information.

TABLE 26-2: TIMER1 ENABLE FUNCTION

| TMR10N | TMR1GE | Timer1 Operation       |
|--------|--------|------------------------|
| 0      | 0      | Off                    |
| 0      | 1      | Off                    |
| 1      | 0      | On                     |
| 1      | 1      | Count Enabled by input |

# 26.7 Software Control

The software portion of the CPS module is required to determine the change in frequency of the capacitive sensing oscillator. This is accomplished by the following:

- Setting a fixed time base to acquire counts on Timer0 or Timer1.
- Establishing the nominal frequency for the capacitive sensing oscillator.
- Establishing the reduced frequency for the capacitive sensing oscillator due to an additional capacitive load.
- Set the frequency threshold.

#### 26.7.1 NOMINAL FREQUENCY (NO CAPACITIVE LOAD)

To determine the nominal frequency of the capacitive sensing oscillator:

- Remove any extra capacitive load on the selected CPSx pin.
- At the start of the fixed time base, clear the timer resource.
- At the end of the fixed time base save the value in the timer resource.

The value of the timer resource is the number of oscillations of the capacitive sensing oscillator for the given time base. The frequency of the capacitive sensing oscillator is equal to the number of counts on in the timer divided by the period of the fixed time base.

### 26.7.2 REDUCED FREQUENCY (ADDITIONAL CAPACITIVE LOAD)

The extra capacitive load will cause the frequency of the capacitive sensing oscillator to decrease. To determine the reduced frequency of the capacitive sensing oscillator:

- Add a typical capacitive load on the selected CPSx pin.
- Use the same fixed time base as the nominal frequency measurement.
- At the start of the fixed time base, clear the timer resource.
- At the end of the fixed time base save the value in the timer resource.

The value of the timer resource is the number of oscillations of the capacitive sensing oscillator with an additional capacitive load. The frequency of the capacitive sensing oscillator is equal to the number of counts on in the timer divided by the period of the fixed time base. This frequency should be less than the value obtained during the nominal frequency measurement.



FIGURE 27-12: TYPE-B WAVEFORMS IN 1/2 MUX, 1/3 BIAS DRIVE



# **30.6** Thermal Considerations

| Standard Operating Conditions (unless otherwise stated)<br>Operating temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |           |                                        |      |       |                                                          |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------|------|-------|----------------------------------------------------------|--|--|--|--|
| Param<br>No.                                                                                                             | Sym.      | Characteristic                         | Тур. | Units | Conditions                                               |  |  |  |  |
| TH01                                                                                                                     | θJA       | Thermal Resistance Junction to Ambient | 60   | °C/W  | 28-pin SPDIP package                                     |  |  |  |  |
|                                                                                                                          |           |                                        | 80   | °C/W  | 28-pin SOIC package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 90   | °C/W  | 28-pin SSOP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 27.5 | °C/W  | 28-pin UQFN 4x4mm package                                |  |  |  |  |
|                                                                                                                          |           |                                        | 27.5 | °C/W  | 28-pin QFN 6x6mm package                                 |  |  |  |  |
|                                                                                                                          |           |                                        | 47.2 | °C/W  | 40-pin PDIP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 46   | °C/W  | 44-pin TQFP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 24.4 | °C/W  | 44-pin QFN 8x8mm package                                 |  |  |  |  |
| TH02                                                                                                                     | θJC       | Thermal Resistance Junction to Case    | 31.4 | °C/W  | 28-pin SPDIP package                                     |  |  |  |  |
|                                                                                                                          |           |                                        | 24   | °C/W  | 28-pin SOIC package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 24   | °C/W  | 28-pin SSOP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 24   | °C/W  | 28-pin UQFN 4x4mm package                                |  |  |  |  |
|                                                                                                                          |           |                                        | 24   | °C/W  | 28-pin QFN 6x6mm package                                 |  |  |  |  |
|                                                                                                                          |           |                                        | 24.7 | °C/W  | 40-pin PDIP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 14.5 | °C/W  | 44-pin TQFP package                                      |  |  |  |  |
|                                                                                                                          |           |                                        | 20   | °C/W  | 44-pin QFN 8x8mm 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 (Τj - Τa)/θja <sup>(2)</sup>                |  |  |  |  |

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

**2:** TA = Ambient Temperature

3: T<sub>J</sub> = Junction Temperature

# 28-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) – 4x4x0.5 mm Body [UQFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging



|                        | MILLIMETERS |           |      |      |  |
|------------------------|-------------|-----------|------|------|--|
| Dimensior              | n Limits    | MIN       | NOM  | MAX  |  |
| Number of Pins         | N           |           | 28   | -    |  |
| Pitch                  | e           | 0.40 BSC  |      |      |  |
| Overall Height         | A           | 0.45      | 0.50 | 0.55 |  |
| Standoff               | A1          | 0.00      | 0.02 | 0.05 |  |
| Contact Thickness      | A3          | 0.127 REF |      |      |  |
| Overall Width          | E           | 4.00 BSC  |      |      |  |
| Exposed Pad Width      | E2          | 2.55      | 2.65 | 2.75 |  |
| Overall Length         | D           | 4.00 BSC  |      |      |  |
| Exposed Pad Length     | D2          | 2.55      | 2.65 | 2.75 |  |
| Contact Width          | b           | 0.15      | 0.20 | 0.25 |  |
| Contact Length         | L           | 0.30      | 0.40 | 0.50 |  |
| Contact-to-Exposed Pad | K           | 0.20      | -    | -    |  |

#### Notes:

- 1. Pin 1 visual index feature may vary, but must be located within the hatched area.
- 2. Package is saw singulated.
- 3. Dimensioning and tolerancing per ASME Y14.5M.
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances.
    - REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-152A Sheet 2 of 2