



Welcome to E-XFL.COM

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

## TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### Errata

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

#### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

|                    |          | -           |                                                                             |             |                |                 | (            | /     |           |                      |                                 |  |
|--------------------|----------|-------------|-----------------------------------------------------------------------------|-------------|----------------|-----------------|--------------|-------|-----------|----------------------|---------------------------------|--|
| Addr               | Name     | Bit 7       | Bit 6                                                                       | Bit 5       | Bit 4          | Bit 3           | Bit 2        | Bit 1 | Bit 0     | Value on<br>POR, BOR | Value on<br>all other<br>Resets |  |
| Ban                | k 8      |             |                                                                             |             |                |                 |              |       |           |                      |                                 |  |
| 40Ch               | ANSELF   | ANSF7       | ANSF6                                                                       | ANSF5       | ANSF4          | ANSF3           | ANSF2        | ANSF1 | ANSF0     | 1111 1111            | 1111 1111                       |  |
| 40Dh               | ANSELG   | _           | _                                                                           | _           | ANSG4          | ANSG3           | ANSG2        | ANSG1 | _         | 1 111-               | 1 111-                          |  |
| 40Eh               | —        | Unimpleme   | Jnimplemented                                                               |             |                |                 |              |       |           |                      |                                 |  |
| 40Fh               | —        | Unimpleme   | nted                                                                        |             | _              | _               |              |       |           |                      |                                 |  |
| 410h               | —        | Unimpleme   | nted                                                                        |             | —              | —               |              |       |           |                      |                                 |  |
| 411h               | TMR3L    | Holding Reg | gister for the                                                              | Least Signi | ficant Byte of | f the 16-bit TN | IR3 Register |       |           | xxxx xxxx            | uuuu uuuu                       |  |
| 412h               | TMR3H    | Holding Reg | gister for the                                                              | Most Signif | icant Byte of  | the 16-bit TM   | R3 Register  |       |           | xxxx xxxx            | uuuu uuuu                       |  |
| 413h               | T3CON    | TMR3C       | S<1:0>                                                                      | T3CKF       | PS<1:0>        | SOSCEN          | T3SYNC       | _     | TMR3ON    | 0000 00-0            | uuuu uu-u                       |  |
| 414h               | T3GCON   | TMR3GE      | TMR3GE T3GPOL T3GTM T3GSPM T3GGO/ T3GVAL T3GSS<1:0>                         |             |                |                 |              |       |           | 0000 0x00            | uuuu uxuu                       |  |
| 415h               | TMR4     | Timer 4 Mo  | dule Registe                                                                | r           |                |                 |              |       |           | 0000 0000            | 0000 0000                       |  |
| 416h               | PR4      | Timer 4 Per | Timer 4 Period Register                                                     |             |                |                 |              |       |           |                      |                                 |  |
| 417h               | T4CON    | _           | - T4OUTPS<3:0> TMR4ON T4CKPS<1:0>                                           |             |                |                 |              |       |           | -000 0000            | -000 0000                       |  |
| 418h               | TMR5L    | Holding Reg | Holding Register for the Least Significant Byte of the 16-bit TMR5 Register |             |                |                 |              |       |           |                      |                                 |  |
| 419h               | TMR5H    | Holding Reg | Holding Register for the Most Significant Byte of the 16-bit TMR5 Register  |             |                |                 |              |       |           |                      | uuuu uuuu                       |  |
| 41Ah               | T5CON    | TMR5C       | S<1:0>                                                                      | T5CKF       | PS<1:0>        | SOSCEN          | T5SYNC       | —     | TMR5ON    | 0000 00-0            | uuuu uu-u                       |  |
| 41Bh               | T5GCON   | TMR5GE      | TMR5GE T5GPOL T5GTM T5GSPM T5GGO/<br>DONE T5GVAL T5GSS<1:0>                 |             |                |                 |              |       | 0000 0x00 | uuuu uxuu            |                                 |  |
| 41Ch               | TMR6     | Timer 6 Mo  | dule Registe                                                                | r           |                |                 |              |       |           | 0000 0000            | 0000 0000                       |  |
| 41Dh               | PR6      | Timer 6 Per | iod Register                                                                |             |                |                 |              |       |           | 1111 1111            | 1111 1111                       |  |
| 41Eh               | T6CON    | _           |                                                                             | T6OU1       | FPS<3:0>       |                 | TMR6ON       | T6CKP | S<1:0>    | -000 0000            | -000 0000                       |  |
| 41Fh               | —        | Unimpleme   | nted                                                                        |             |                |                 |              |       |           | _                    | _                               |  |
| Ban                | k 9      |             |                                                                             |             |                |                 |              |       |           |                      |                                 |  |
| 48Ch               | —        | Unimpleme   | nted                                                                        |             |                |                 |              |       |           | —                    | _                               |  |
| 48Dh               | WPUG     | —           | _                                                                           | WPUG5       | _              | _               | —            | _     | _         | 1                    | 1                               |  |
| 48Dh<br>to<br>490h | _        | Unimpleme   | nted                                                                        |             |                |                 |              |       |           | _                    | _                               |  |
| 491h               | RC2REG   | USART Red   | ceive Data R                                                                | legister    |                |                 |              |       |           | 0000 0000            | 0000 0000                       |  |
| 492h               | TX2REG   | USART Tra   | nsmit Data F                                                                | Register    |                |                 |              |       |           | 0000 0000            | 0000 0000                       |  |
| 493h               | SP2BRG   |             |                                                                             |             | BRO            | G<7:0>          |              |       |           | 0000 0000            | 0000 0000                       |  |
| 494h               | SP2BRGH  |             |                                                                             |             | BRG            | 6<15:8>         |              |       |           | 0000 0000            | 0000 0000                       |  |
| 495h               | RC2STA   | SPEN        | RX9                                                                         | SREN        | CREN           | ADDEN           | FERR         | OERR  | RX9D      | 0000 000x            | 0000 000x                       |  |
| 496h               | TX2STA   | CSRC        | TX9                                                                         | TXEN        | SYNC           | SENDB           | BRGH         | TRMT  | TX9D      | 0000 0010            | 0000 0010                       |  |
| 497h               | BAUD2CON | ABDOVF      | RCIDL                                                                       |             | SCKP           | BRG16           | _            | WUE   | ABDEN     | 01-0 0-00            | 01-0 0-00                       |  |
| 498h<br>to<br>49Fh |          | Unimpleme   | nted                                                                        |             |                |                 |              |       |           | _                    | _                               |  |

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

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

Note 1: PIC16F1526/7 only.

2: Unimplemented, read as '1'.

## 4.3 Code Protection

Code protection allows the device to be protected from unauthorized access. Program memory protection is controlled independently. Internal access to the program memory is unaffected by any code protection setting.

#### 4.3.1 PROGRAM MEMORY PROTECTION

The entire program memory space is protected from external reads and writes by the  $\overline{CP}$  bit in Configuration Words. When  $\overline{CP} = 0$ , external reads and writes of program memory are inhibited and a read will return all '0's. The CPU can continue to read program memory, regardless of the protection bit settings. Writing the program memory is dependent upon the write protection setting. See **Section 4.4** "Write **Protection**" for more information.

## 4.4 Write Protection

Write protection allows the device to be protected from unintended self-writes. Applications, such as bootloader software, can be protected while allowing other regions of the program memory to be modified.

The WRT<1:0> bits in Configuration Words define the size of the program memory block that is protected.

## 4.5 User ID

Four memory locations (8000h-8003h) are designated as ID locations where the user can store checksum or other code identification numbers. These locations are readable and writable during normal execution. See **Section 11.5 "User ID, Device ID and Configuration Word Access"** for more information on accessing these memory locations. For more information on checksum calculation, see the "*PIC16F/LF151X/152X Memory Programming Specification*" (DS41422).

## 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 within the oscillator module. The internal oscillator block has two internal oscillators that are used to generate the internal system clock sources: the 16 MHz High-Frequency Internal Oscillator 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 Words 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:
  - Secondary 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 three power modes to select from through Configuration Words:

- High power, 4-20 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.



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

| D 1/a            | 11.0                              | D a/a                          | P 0/a               | 11.0             | 11.0               | P 0/0            | P 0/a        |  |  |  |
|------------------|-----------------------------------|--------------------------------|---------------------|------------------|--------------------|------------------|--------------|--|--|--|
|                  | 0-0                               |                                |                     | 0-0              | 0-0                |                  |              |  |  |  |
| 3030K            |                                   | 0313                           | NFIORK              |                  |                    | LFIOFK           |              |  |  |  |
| DIT /            |                                   |                                |                     |                  |                    |                  | DIT U        |  |  |  |
|                  |                                   |                                |                     |                  |                    |                  |              |  |  |  |
| Legend:          |                                   |                                |                     |                  |                    |                  |              |  |  |  |
| R = Readable     | bit                               | W = Writable                   | bit                 | U = Unimpler     | nented bit, read   | l 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 | other Resets |  |  |  |
| '1' = Bit is set |                                   | '0' = Bit is cle               | ared                | q = Condition    | al                 |                  |              |  |  |  |
|                  |                                   |                                |                     |                  |                    |                  |              |  |  |  |
| bit 7            | SOSCR: Sec                        | ondary Oscillat                | tor Ready bit       |                  |                    |                  |              |  |  |  |
|                  | If SOSCEN =                       | <u>1</u> :                     |                     |                  |                    |                  |              |  |  |  |
|                  | 1 = Secondary oscillator is ready |                                |                     |                  |                    |                  |              |  |  |  |
|                  |                                   |                                | notreauy            |                  |                    |                  |              |  |  |  |
|                  | 1 = Timer1                        | <u>_u</u> .<br>clock source is | alwavs readv        |                  |                    |                  |              |  |  |  |
| bit 6            | Unimplemen                        | ted: Read as '                 | 0'                  |                  |                    |                  |              |  |  |  |
| bit 5            | OSTS: Oscilla                     | ator Start-up Ti               | °<br>mer Status hit |                  |                    |                  |              |  |  |  |
| bit o            | 1 = Running                       | from the clock                 | defined by the      | = FOSC<2.0> I    | oits of the Confi  | guration Words   | s            |  |  |  |
|                  | 0 = Running                       | from an intern                 | al oscillator (F    | OSC<2:0> = 1     | 00)                | garation mora    |              |  |  |  |
| bit 4            | HFIOFR: High                      | h-Frequency Ir                 | nternal Oscillato   | or Ready bit     |                    |                  |              |  |  |  |
|                  | 1 = HFINTOS                       | SC is ready                    |                     |                  |                    |                  |              |  |  |  |
|                  | 0 = HFINTOS                       | SC is not ready                | /                   |                  |                    |                  |              |  |  |  |
| bit 3-2          | Unimplemen                        | ted: Read as '                 | 0'                  |                  |                    |                  |              |  |  |  |
| bit 1            | LFIOFR: Low                       | -Frequency Int                 | ternal Oscillato    | r Ready bit      |                    |                  |              |  |  |  |
|                  | 1 = LFINTOS                       | SC is ready                    |                     |                  |                    |                  |              |  |  |  |
|                  | 0 = LFINTOS                       | SC is not ready                |                     |                  |                    |                  |              |  |  |  |
| bit 0            | HFIOFS: High                      | h-Frequency In                 | ternal Oscillato    | or Stable bit    |                    |                  |              |  |  |  |
|                  | 1 = HFINTOS                       | SC 16 MHz Os                   | cillator is stable  | e and is driving | the INTOSC         |                  |              |  |  |  |
|                  | 0 = HFINTOS                       | SC 16 MHz is r                 | not stable, the \$  | Start-up Oscilla | ator is driving IN | HOSC             |              |  |  |  |

## REGISTER 5-2: OSCSTAT: OSCILLATOR STATUS REGISTER

## TABLE 5-2: SUMMARY OF REGISTERS ASSOCIATED WITH CLOCK SOURCES

| Name    | Bit 7 | Bit 6   | Bit 5   | Bit 4  | Bit 3  | Bit 2   | Bit 1    | Bit 0  | Register<br>on Page |
|---------|-------|---------|---------|--------|--------|---------|----------|--------|---------------------|
| OSCCON  | —     |         | IRCF    | <3:0>  |        | —       | SCS<1:0> |        | 61                  |
| OSCSTAT | SOSCR | —       | OSTS    | HFIOFR | —      | —       | LFIOFR   | HFIOFS | 62                  |
| PIE2    | OSFIE | TMR5GIE | TMR3GIE | -      | BCL1IE | TMR10IE | TMR8IE   | CCP2IE | 78                  |
| PIR2    | OSFIF | TMR5GIF | TMR3GIF | _      | BCL1IF | TMR10IF | TMR8IF   | CCP2IF | 82                  |
| T1CON   | TMR10 | CS<1:0> | T1CKP   | S<1:0> | SOSCEN | T1SYNC  |          | TMR10N | 168                 |

**Legend:** — = unimplemented location, read as '0'. Shaded cells are not used by clock sources.

### TABLE 5-3: SUMMARY OF CONFIGURATION WORD WITH CLOCK SOURCES

| Name    | Bits | Bit -/7 | Bit -/6 | Bit 13/5 | Bit 12/4  | Bit 11/3 | Bit 10/2   | Bit 9/1 | Bit 8/0 | Register<br>on Page |
|---------|------|---------|---------|----------|-----------|----------|------------|---------|---------|---------------------|
| CONFIG1 | 13:8 | —       |         | FCMEN    | IESO      | CLKOUTEN | BOREN<1:0> |         | —       | 40                  |
|         | 7:0  | CP      | MCLRE   | PWRTE    | WDTE<1:0> |          | FOSC<2:0>  |         |         | 43                  |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by clock sources.

## 12.3 PORTA Registers

#### 12.3.1 DATA REGISTER

PORTA is an 8-bit wide, bidirectional port. The corresponding data direction register is TRISA (Register 12-3). Setting a TRISA bit (= 1) will make the corresponding PORTA pin an input (i.e., disable the output driver). Clearing a TRISA bit (= 0) will make the corresponding PORTA pin an output (i.e., enables output driver and puts the contents of the output latch on the selected pin). Example 12-1 shows how to initialize an I/O port.

Reading the PORTA register (Register 12-2) 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 (LATA).

## 12.3.2 DIRECTION CONTROL

The TRISA register (Register 12-3) controls the PORTA pin output drivers, even when they are being used as analog inputs. The user should ensure the bits in the TRISA register are maintained set when using them as analog inputs. I/O pins configured as analog input always read '0'.

## 12.3.3 ANALOG CONTROL

The ANSELA register (Register 12-5) is used to configure the Input mode of an I/O pin to analog. Setting the appropriate ANSELA bit high will cause all digital reads on the pin to be read as '0' and allow analog functions on the pin to operate correctly.

The state of the ANSELA bits has no effect on digital output functions. A pin with TRIS clear and ANSEL set will still operate as a digital output, but the Input mode will be analog. This can cause unexpected behavior when executing read-modify-write instructions on the affected port.

Note: The ANSELA bits default to the Analog mode after Reset. To use any pins as digital general purpose or peripheral inputs, the corresponding ANSEL bits must be initialized to '0' by user software.

#### EXAMPLE 12-1: INITIALIZING PORTA

| ; This code example illustrates<br>; initializing the PORTA register. The<br>; other ports are initialized in the same<br>; manner. |             |                        |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------|--|--|--|--|--|--|
| BANKSEL                                                                                                                             | PORTA       | ;                      |  |  |  |  |  |  |
| CLRF                                                                                                                                | PORTA       | ;Init PORTA            |  |  |  |  |  |  |
| BANKSEL                                                                                                                             | LATA        | ;Data Latch            |  |  |  |  |  |  |
| CLRF                                                                                                                                | LATA        | ;                      |  |  |  |  |  |  |
| 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               |  |  |  |  |  |  |

#### 12.3.4 PORTA FUNCTIONS AND OUTPUT PRIORITIES

Each PORTA pin is multiplexed with other functions. The pins, their combined functions and their output priorities are shown in Table 12-2.

When multiple outputs are enabled, the actual pin control goes to the peripheral with the highest priority.

Analog input functions, such as ADC, are not shown in the priority lists. These inputs are active when the I/O pin is set for Analog mode using the ANSELx registers. Digital output functions may control the pin when it is in Analog mode with the priority shown in the priority list

| <b>FABLE 12-2:</b> | PORTA | OUTPUT | PRIORITY |
|--------------------|-------|--------|----------|
|--------------------|-------|--------|----------|

| Pin Name | Function Priority <sup>(1)</sup> |
|----------|----------------------------------|
| RA0      | RA0                              |
| RA1      | RA1                              |
| RA2      | RA2                              |
| RA3      | RA3                              |
| RA4      | RA4                              |
| RA5      | RA5                              |
| RA6      | CLKOUT<br>OSC2<br>RA6            |
| RA7      | RA7                              |

Note 1: Priority listed from highest to lowest.

| U-0                               | U-0   | R/W-1/1         | U-0  | R/W-1/1                                               | R/W-1/1 | R/W-1/1 | R/W-1/1 |  |  |  |  |
|-----------------------------------|-------|-----------------|------|-------------------------------------------------------|---------|---------|---------|--|--|--|--|
| —                                 | —     | ANSA5           | —    | ANSA3                                                 | ANSA2   | ANSA1   | ANSA0   |  |  |  |  |
| bit 7 bit 0                       |       |                 |      |                                                       |         |         |         |  |  |  |  |
|                                   |       |                 |      |                                                       |         |         |         |  |  |  |  |
| Legend:                           |       |                 |      |                                                       |         |         |         |  |  |  |  |
| R = Readable bit W = Writable bit |       |                 | bit  | U = Unimplemented bit, read as '0'                    |         |         |         |  |  |  |  |
| u = Bit is unch                   | anged | x = Bit is unkr | nown | -n/n = Value at POR and BOR/Value at all other Resets |         |         |         |  |  |  |  |

## REGISTER 12-5: ANSELA: PORTA ANALOG SELECT REGISTER

'0' = Bit is cleared

| bit 7-6 | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                    |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 5   | <ul> <li>ANSA5: Analog Select between Analog or Digital Function on pins RA5, respectively</li> <li>1 = Analog input. Pin is assigned as analog input<sup>(1)</sup>. Digital input buffer disabled.</li> <li>0 = Digital I/O. Pin is assigned to port or digital special function.</li> </ul> |
| bit 4   | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                    |
| bit 3-0 | <b>ANSA&lt;3:0&gt;</b> : Analog Select between Analog or Digital Function on pins RA<3:0>, respectively<br>1 = Analog input. Pin is assigned as analog input <sup>(1)</sup> . Digital input buffer disabled.<br>0 = Digital I/O. Pin is assigned to port or digital special function.         |
|         | When a string a give to an end on the second string TDIO bit must be acted by the second string to an                                                                                                                                                                                         |

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

| Name       | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2   | Bit 1    | Bit 0   | Register<br>on Page |
|------------|--------|--------|--------|--------|--------|---------|----------|---------|---------------------|
| ANSELA     | _      | _      | ANSA5  | _      | ANSA3  | ANSA2   | ANSA1    | ANSA0   | 115                 |
| APFCON     | _      | _      | —      | _      | _      | —       | T3CKISEL | CCP2SEL | 112                 |
| LATA       | LATA7  | LATA6  | LATA5  | LATA4  | LATA3  | LATA2   | LATA1    | LATA0   | 114                 |
| OPTION_REG | WPUEN  | INTEDG | TMR0CS | TMR0SE | PSA    | PS<2:0> |          |         | 158                 |
| PORTA      | RA7    | RA6    | RA5    | RA4    | RA3    | RA2     | RA1      | RA0     | 114                 |
| TRISA      | TRISA7 | TRISA6 | TRISA5 | TRISA4 | TRISA3 | TRISA2  | TRISA1   | TRISA0  | 114                 |

## TABLE 12-3: SUMMARY OF REGISTERS ASSOCIATED WITH PORTA

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

#### TABLE 12-4: SUMMARY OF CONFIGURATION WORD WITH PORTA

| Name    | Bits | Bit -/7  | Bit -/6 | Bit 13/5 | Bit 12/4 | Bit 11/3 | Bit 10/2   | Bit 9/1   | Bit 8/0 | Register<br>on Page |
|---------|------|----------|---------|----------|----------|----------|------------|-----------|---------|---------------------|
|         | 13:8 |          |         | FCMEN    | IESO     | CLKOUTEN | BOREN<1:0> |           | —       | 45                  |
| CONFIGT | 7:0  | CP MCLRE |         | PWRTE    | WDTE     | E<1:0>   |            | FOSC<2:0> |         | 40                  |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by PORTA.

'1' = Bit is set









## 20.1.4 CCP PRESCALER

There are four prescaler settings specified by the CCPxM<3:0> bits of the CCPxCON register. Whenever the CCP module is turned off, or the CCP module is not in Capture mode, the prescaler counter is cleared. Any Reset will clear the prescaler counter.

Switching from one capture prescaler to another does not clear the prescaler and may generate a false interrupt. To avoid this unexpected operation, turn the module off by clearing the CCPxCON register before changing the prescaler. Equation 20-1 demonstrates the code to perform this function.

#### EXAMPLE 20-1: CHANGING BETWEEN CAPTURE PRESCALERS

| BANKSEI | L CCPxCON   | ;Set Bank bits to point |
|---------|-------------|-------------------------|
|         |             | ;to CCPxCON             |
| CLRF    | CCPxCON     | ;Turn CCP module off    |
| MOVLW   | NEW_CAPT_PS | ;Load the W reg with    |
|         |             | ;the new prescaler      |
|         |             | ;move value and CCP ON  |
| MOVWF   | CCPxCON     | ;Load CCPxCON with this |
|         |             | ;value                  |
|         |             |                         |

## 20.1.5 CAPTURE DURING SLEEP

Capture mode depends upon the Timer1/3/5 module for proper operation. There are two options for driving the Timer1/3/5 module in Capture mode. It can be driven by the instruction clock (Fosc/4), or by an external clock source.

When Timer1/3/5 is clocked by Fosc/4, Timer1/3/5 will not increment during Sleep. When the device wakes from Sleep, Timer1/3/5 will continue from its previous state.

Capture mode will operate during Sleep when Timer1/3/5 is clocked by an external clock source.

## 20.1.6 ALTERNATE PIN LOCATIONS

This module incorporates I/O pins that can be moved to other locations with the use of the alternate pin function register, APFCON. To determine which pins can be moved and what their default locations are upon a reset, see **Section 12.1 "Alternate Pin Function"** for more information.

## 21.4 I<sup>2</sup>C MODE OPERATION

All MSSPx I<sup>2</sup>C communication is byte oriented and shifted out MSb first. Six SFR registers and 2 interrupt flags interface the module with the PIC<sup>®</sup> microcontroller and user software. Two pins, SDAx and SCLx, are exercised by the module to communicate with other external I<sup>2</sup>C devices.

### 21.4.1 BYTE FORMAT

All communication in  $I^2C$  is done in 9-bit segments. A byte is sent from a master to a slave or vice-versa, followed by an Acknowledge bit sent back. After the 8th falling edge of the SCLx line, the device outputting data on the SDAx changes that pin to an input and reads in an acknowledge value on the next clock pulse.

The clock signal, SCLx, is provided by the master. Data is valid to change while the SCLx signal is low, and sampled on the rising edge of the clock. Changes on the SDAx line while the SCLx line is high define special conditions on the bus, explained below.

## 21.4.2 DEFINITION OF I<sup>2</sup>C TERMINOLOGY

There is language and terminology in the description of I<sup>2</sup>C communication that have definitions specific to I<sup>2</sup>C. That word usage is defined below and may be used in the rest of this document without explanation. This table was adapted from the Philips I<sup>2</sup>C specification.

#### 21.4.3 SDAX AND SCLX PINS

Selection of any I<sup>2</sup>C mode with the SSPEN bit set, forces the SCLx and SDAx pins to be open-drain. These pins should be set by the user to inputs by setting the appropriate TRIS bits.

| Note: | Data | is   | tied | to   | output | zero | when | an | I <sup>2</sup> C |
|-------|------|------|------|------|--------|------|------|----|------------------|
|       | mode | e is | enat | blec | l.     |      |      |    |                  |

#### 21.4.4 SDAX HOLD TIME

The hold time of the SDAx pin is selected by the SDAHT bit of the SSPxCON3 register. Hold time is the time SDAx is held valid after the falling edge of SCLx. Setting the SDAHT bit selects a longer 300 ns minimum hold time and may help on buses with large capacitance.

## TABLE 21-2:I<sup>2</sup>C BUS TERMS

| TERM                | Description                                                                                                                                                                                        |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter         | The device which shifts data out onto the bus.                                                                                                                                                     |
| Receiver            | The device which shifts data in from the bus.                                                                                                                                                      |
| Master              | The device that initiates a transfer,<br>generates clock signals and<br>terminates a transfer.                                                                                                     |
| Slave               | The device addressed by the master.                                                                                                                                                                |
| Multi-master        | A bus with more than one device that can initiate data transfers.                                                                                                                                  |
| Arbitration         | Procedure to ensure that only one master at a time controls the bus. Winning arbitration ensures that the message is not corrupted.                                                                |
| Synchronization     | Procedure to synchronize the clocks of two or more devices on the bus.                                                                                                                             |
| Idle                | No master is controlling the bus,<br>and both SDAx and SCLx lines are<br>high.                                                                                                                     |
| Active              | Any time one or more master devices are controlling the bus.                                                                                                                                       |
| Addressed<br>Slave  | Slave device that has received a matching address and is actively being clocked by a master.                                                                                                       |
| Matching<br>Address | Address byte that is clocked into a slave that matches the value stored in SSPxADD.                                                                                                                |
| Write Request       | Slave receives a matching<br>address with R/W bit clear, and is<br>ready to clock in data.                                                                                                         |
| Read Request        | Master sends an address byte with<br>the R/W bit set, indicating that it<br>wishes to clock data out of the<br>Slave. This data is the next and all<br>following bytes until a Restart or<br>Stop. |
| Clock Stretching    | When a device on the bus hold SCLx low to stall communication.                                                                                                                                     |
| Bus Collision       | Any time the SDAx line is sampled<br>low by the module while it is out-<br>putting and expected high state                                                                                         |

#### 21.4.9 ACKNOWLEDGE SEQUENCE

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

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

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

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

There are certain conditions where an ACK will not be sent by the slave. If the BF bit of the SSPxSTAT register or the SSPOV bit of the SSPxCON1 register are set when a byte is received.

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

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

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

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

#### 21.5.1 SLAVE MODE ADDRESSES

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

The SSPx Mask register (Register 21-5) affects the address matching process. See **Section 21.5.9 "SSPx Mask Register"** for more information.

21.5.1.1 I<sup>2</sup>C Slave 7-bit Addressing Mode

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

21.5.1.2 I<sup>2</sup>C Slave 10-bit Addressing Mode

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

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

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

| Name     | Bit 7                                  | Bit 6           | Bit 5          | Bit 4  | Bit 3 Bit 2 |                      | Bit 1  | Bit 0  | Reset<br>Values on<br>Page: |  |  |
|----------|----------------------------------------|-----------------|----------------|--------|-------------|----------------------|--------|--------|-----------------------------|--|--|
| INTCON   | GIE                                    | PEIE            | TMR0IE         | INTE   | IOCIE       | IE TMR0IF INTF IOCIF |        | IOCIF  | 76                          |  |  |
| PIE1     | TMR1GIE                                | ADIE            | RC1IE          | TX1IE  | SSP1IE      | CCP1IE               | TMR2IE | TMR1IE | 77                          |  |  |
| PIE2     | OSFIE                                  | TMR5GIE         | TMR3GIE        | _      | BCL1IE      | TMR10IE              | TMR8IE | CCP2IE | 78                          |  |  |
| PIE4     | CCP10IE                                | CCP9IE          | RC2IE          | TX2IE  | CCP8IE      | CCP7IE               | BCL2IE | SSP2IE | 80                          |  |  |
| PIR1     | TMR1GIF                                | ADIF            | RC1IF          | TX1IF  | SSP1IF      | CCP1IF               | TMR2IF | TMR1IF | 81                          |  |  |
| PIR2     | OSFIF                                  | TMR5GIF         | TMR3GIF        | _      | BCL1IF      | TMR10IF              | TMR8IF | CCP2IF | 82                          |  |  |
| PIR4     | CCP10IF                                | CCP9IF          | RC2IF          | TX2IF  | CCP8IF      | CCP7IF               | BCL2IF | SSP2IF | 84                          |  |  |
| SSP1ADD  | ADD<7:0>                               |                 |                |        |             |                      |        |        |                             |  |  |
| SSP2ADD  | ADD<7:0>                               |                 |                |        |             |                      |        |        |                             |  |  |
| SSP1BUF  | MSSPx Receive Buffer/Transmit Register |                 |                |        |             |                      |        |        |                             |  |  |
| SSP2BUF  | MSSPx Rec                              | eive Buffer/Tra | ansmit Registe | er     |             |                      |        |        | 197*                        |  |  |
| SSP1CON1 | WCOL                                   | SSPOV           | SSPEN          | CKP    |             | SSPM                 | <3:0>  |        | 244                         |  |  |
| SSP2CON1 | WCOL                                   | SSPOV           | SSPEN          | CKP    |             | SSPM                 | <3:0>  |        | 244                         |  |  |
| SSP1CON2 | GCEN                                   | ACKSTAT         | ACKDT          | ACKEN  | RCEN        | PEN                  | RSEN   | SEN    | 245                         |  |  |
| SSP2CON2 | GCEN                                   | ACKSTAT         | ACKDT          | ACKEN  | RCEN        | PEN                  | RSEN   | SEN    | 245                         |  |  |
| SSP1CON3 | ACKTIM                                 | PCIE            | SCIE           | BOEN   | SDAHT       | SBCDE                | AHEN   | DHEN   | 246                         |  |  |
| SSP2CON3 | ACKTIM                                 | PCIE            | SCIE           | BOEN   | SDAHT       | SBCDE                | AHEN   | DHEN   | 246                         |  |  |
| SSP1MSK  |                                        |                 |                | MSK<   | <7:0>       |                      |        |        | 247                         |  |  |
| SSP2MSK  | MSK<7:0>                               |                 |                |        |             |                      |        |        |                             |  |  |
| SSP1STAT | SMP                                    | CKE             | D/A            | Р      | S           | R/W                  | UA     | BF     | 242                         |  |  |
| SSP2STAT | SMP                                    | CKE             | D/A            | Р      | S           | R/W                  | UA     | BF     | 242                         |  |  |
| TRISC    | TRISC7                                 | TRISC6          | TRISC5         | TRISC4 | TRISC3      | TRISC2               | TRISC1 | TRISC0 | 120                         |  |  |
| TRISD    | TRISD7                                 | TRISD6          | TRISD5         | TRISD4 | TRISD3      | TRISD2               | TRISD1 | TRISD0 | 123                         |  |  |

## TABLE 21-3: SUMMARY OF REGISTERS ASSOCIATED WITH I<sup>2</sup>C OPERATION

Legend: — = unimplemented location, read as '0'. Shaded cells are not used by the MSSP module in I<sup>2</sup>C mode.

\* Page provides register information.

**Note 1:** PIC16(L)F1527 only.

## FIGURE 22-2: EUSART RECEIVE BLOCK DIAGRAM



The operation of the EUSART module is controlled through three registers:

- Transmit Status and Control (TXxSTA)
- Receive Status and Control (RCxSTA)
- Baud Rate Control (BAUDxCON)

These registers are detailed in Register 22-1, Register 22-2 and Register 22-3, respectively.

For all modes of EUSART operation, the TRIS control bits corresponding to the RXx/DTx and TXx/CKx pins should be set to '1'. The EUSART control will automatically reconfigure the pin from input to output, as needed.

When the receiver or transmitter section is not enabled then the corresponding RXx/DTx or TXx/CKx pin may be used for general purpose input and output.

|                     | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1 |            |                             |                   |            |                             |                   |            |                             |                |                    |                             |  |
|---------------------|------------------------------------------------------|------------|-----------------------------|-------------------|------------|-----------------------------|-------------------|------------|-----------------------------|----------------|--------------------|-----------------------------|--|
| BAUD                | Fosc = 20.000 MHz                                    |            |                             | Fosc = 18.432 MHz |            |                             | Fosc = 16.000 MHz |            |                             | Fosc           | Fosc = 11.0592 MHz |                             |  |
| RATE Actual<br>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       | 16665                       | 300.0             | 0.00       | 15359                       | 300.0             | 0.00       | 13332                       | 300.0          | 0.00               | 9215                        |  |
| 1200                | 1200                                                 | -0.01      | 4166                        | 1200              | 0.00       | 3839                        | 1200.1            | 0.01       | 3332                        | 1200           | 0.00               | 2303                        |  |
| 2400                | 2400                                                 | 0.02       | 2082                        | 2400              | 0.00       | 1919                        | 2399.5            | -0.02      | 1666                        | 2400           | 0.00               | 1151                        |  |
| 9600                | 9597                                                 | -0.03      | 520                         | 9600              | 0.00       | 479                         | 9592              | -0.08      | 416                         | 9600           | 0.00               | 287                         |  |
| 10417               | 10417                                                | 0.00       | 479                         | 10425             | 0.08       | 441                         | 10417             | 0.00       | 383                         | 10433          | 0.16               | 264                         |  |
| 19.2k               | 19.23k                                               | 0.16       | 259                         | 19.20k            | 0.00       | 239                         | 19.23k            | 0.16       | 207                         | 19.20k         | 0.00               | 143                         |  |
| 57.6k               | 57.47k                                               | -0.22      | 86                          | 57.60k            | 0.00       | 79                          | 57.97k            | 0.64       | 68                          | 57.60k         | 0.00               | 47                          |  |
| 115.2k              | 116.3k                                               | 0.94       | 42                          | 115.2k            | 0.00       | 39                          | 114.29k           | -0.79      | 34                          | 115.2k         | 0.00               | 23                          |  |

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

|        | SYNC = 0, BRGH = 1, BRG16 = 1 or SYNC = 1, BRG16 = 1 |            |                             |                  |            |                             |                   |            |                             |                  |            |                             |
|--------|------------------------------------------------------|------------|-----------------------------|------------------|------------|-----------------------------|-------------------|------------|-----------------------------|------------------|------------|-----------------------------|
| BAUD   | Fosc = 8.000 MHz                                     |            |                             | Fosc = 4.000 MHz |            |                             | Fosc = 3.6864 MHz |            |                             | Fosc = 1.000 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       | 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                           | _                | _          | _                           |

## 22.5.1.4 Synchronous Master Transmission Set-up:

- Initialize the SPxBRGH, SPxBRGL register pair and the BRGH and BRG16 bits to achieve the desired baud rate (see Section 22.4 "EUSART Baud Rate Generator (BRG)").
- 2. Set the RXx/DTx and TXx/CKx TRIS controls to '1'.
- Enable the synchronous master serial port by setting bits SYNC, SPEN and CSRC. Set the TRIS bits corresponding to the RXx/DTx and TXx/CKx I/O pins.

- 4. Disable Receive mode by clearing bits SREN and CREN.
- 5. Enable Transmit mode by setting the TXEN bit.
- 6. If 9-bit transmission is desired, set the TX9 bit.
- 7. If interrupts are desired, set the TXxIE, GIE and PEIE interrupt enable bits.
- 8. If 9-bit transmission is selected, the ninth bit should be loaded in the TX9D bit.
- 9. Start transmission by loading data to the TXx-REG register.



## FIGURE 22-10: SYNCHRONOUS TRANSMISSION

## FIGURE 22-11: SYNCHRONOUS TRANSMISSION (THROUGH TXEN)



#### **TABLE 25-4**: **RESET, WATCHDOG TIMER, OSCILLATOR START-UP TIMER, POWER-UP TIMER** AND BROWN-OUT RESET PARAMETERS

| Standard Operating Conditions (unless otherwise stated)Operating Temperature $-40^{\circ}C \le TA \le +125^{\circ}C$ |        |                                                          |      |      |      |       |                                        |  |  |
|----------------------------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------|------|------|------|-------|----------------------------------------|--|--|
| Param<br>No.                                                                                                         | Sym.   | Characteristic                                           | Min. | Тур† | Max. | Units | Conditions                             |  |  |
| 30                                                                                                                   | TMCL   | MCLR Pulse Width (low)                                   | 2    | —    | _    | μS    |                                        |  |  |
| 30A                                                                                                                  | TMCLR  |                                                          | _    | _    | _    | _     |                                        |  |  |
| 31                                                                                                                   | TWDTLP | Low-Power Watchdog Timer<br>Time-out Period              | 10   | 16   | 27   | ms    | VDD = 3.3V-5V,<br>1:512 prescaler used |  |  |
| 32                                                                                                                   | Tost   | Oscillator Start-up Timer Period <sup>(1)</sup>          | _    | 1024 | _    | Tosc  | (Note 3)                               |  |  |
| 33*                                                                                                                  | TPWRT  | Power-up Timer Period, $\overline{PWRTE} = 0$            | 40   | 65   | 140  | ms    |                                        |  |  |
| 34*                                                                                                                  | Tioz   | I/O high impedance from MCLR Low or Watchdog Timer Reset |      | —    | 2.0  | μS    |                                        |  |  |
| 35                                                                                                                   | VBOR   | Brown-out Reset Voltage <sup>(2)</sup>                   | 2.55 | 2.70 | 2.85 | V     | BORV = 0, PIC16(L)F1526/7              |  |  |
|                                                                                                                      |        |                                                          | 2.35 | 2.45 | 2.58 | V     | BORV = 1, PIC16F1526/7                 |  |  |
|                                                                                                                      |        |                                                          | 1.80 | 1.90 | 2.00 | V     | BORV = 1, PIC16LF1526/7                |  |  |
| 36*                                                                                                                  | VHYST  | Brown-out Reset Hysteresis                               | 0    | 25   | 60   | mV    | -40°C to +85°C                         |  |  |
| 37*                                                                                                                  | TBORDC | Brown-out Reset DC Response<br>Time                      | 1    | 3    | 35   | μS    | Vdd ≤ Vbor                             |  |  |
| 38                                                                                                                   | Vlpbor | Low-Power Brown-out Reset<br>Voltage                     | 1.8  | 2.1  | 2.5  | V     | LPBOR = 1                              |  |  |
| * Those parameters are characterized but not tested                                                                  |        |                                                          |      |      |      |       |                                        |  |  |

These parameters are characterized but not tested.

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

Note 1: By design, the Oscillator Start-up Timer (OST) counts the first 1024 cycles, independent of frequency.

2: To ensure these voltage tolerances, VDD and Vss must be capacitively decoupled as close to the device as possible. 0.1  $\mu\text{F}$  and 0.01  $\mu\text{F}$  values in parallel are recommended.





FIGURE 26-12: IDD MAXIMUM, EXTERNAL CLOCK (ECM), MEDIUM-POWER MODE, PIC16LF1526 ONLY





FIGURE 26-13: IDD TYPICAL, EXTERNAL CLOCK (ECM), MEDIUM-POWER MODE, PIC16F1526/7

FIGURE 26-14: IDD MAXIMUM, EXTERNAL CLOCK (ECM), MEDIUM-POWER MODE, PIC16F1526/7 ONLY



## 27.2 MPLAB XC Compilers

The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16, and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X.

For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE.

The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications.

MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- · Flexible macro language
- MPLAB X IDE compatibility

## 27.3 MPASM Assembler

The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs.

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging.

The MPASM Assembler features include:

- Integration into MPLAB X IDE projects
- User-defined macros to streamline
   assembly code
- Conditional assembly for multipurpose source files
- Directives that allow complete control over the assembly process

## 27.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

## 27.5 MPLAB Assembler, Linker and Librarian for Various Device Families

MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- Rich directive set
- Flexible macro language
- MPLAB X IDE compatibility

## 64-Lead Plastic Thin Quad Flatpack (PT)-10x10x1 mm Body, 2.00 mm Footprint [TQFP]

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



## RECOMMENDED LAND PATTERN

|                          | MILLIMETERS |      |          |      |  |
|--------------------------|-------------|------|----------|------|--|
| Dimension                | MIN         | NOM  | MAX      |      |  |
| Contact Pitch            | E           |      | 0.50 BSC |      |  |
| Contact Pad Spacing      | C1          |      | 11.40    |      |  |
| Contact Pad Spacing      | C2          |      | 11.40    |      |  |
| Contact Pad Width (X28)  | X1          |      |          | 0.30 |  |
| Contact Pad Length (X28) | Y1          |      |          | 1.50 |  |
| Distance Between Pads    | G           | 0.20 |          |      |  |

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing C04-2085B Sheet 1 of 1