



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | Active                                                                    |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | PIC                                                                       |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 32MHz                                                                     |
| Connectivity               | -                                                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                     |
| Number of I/O              | 6                                                                         |
| Program Memory Size        | 1.75KB (1K x 14)                                                          |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 128 x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V                                                               |
| Data Converters            | A/D 4x10b; D/A 1x5b                                                       |
| Oscillator Type            | Internal                                                                  |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                        |
| Mounting Type              | Through Hole                                                              |
| Package / Case             | 8-DIP (0.300", 7.62mm)                                                    |
| Supplier Device Package    | 8-PDIP                                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic12lf1571-e-p |

Email: info@E-XFL.COM

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

NOTES:

### 3.3.6 CORE FUNCTION REGISTERS SUMMARY

The Core Function registers listed in Table 3-9 can be addressed from any bank.

#### TABLE 3-9: CORE FUNCTION REGISTERS SUMMARY

| 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 All<br>Other Resets |
|-----------------|-----------|-------------------------------------------------------|----------------------------------------------------------------------------|---------------|--------------|-------------|-------------|-----------|-----------|----------------------|------------------------------|
| Bank            | Bank 0-31 |                                                       |                                                                            |               |              |             |             |           |           |                      |                              |
| x00h or<br>x80h | INDF0     | Addressing<br>(not a phys                             | this location ical register)                                               | uses conte    | nts of FSR0H | /FSR0L to a | ddress data | memory    |           | xxxx xxxx            | uuuu uuuu                    |
| x01h or<br>x81h | INDF1     | Addressing<br>(not a phys                             | this location ical register)                                               | uses conte    | nts of FSR1H | /FSR1L to a | ddress data | memory    |           | XXXX XXXX            | uuuu uuuu                    |
| x02h or<br>x82h | PCL       | Program C                                             | ounter (PC)                                                                | Least Signifi | cant Byte    |             |             |           |           | 0000 0000            | 0000 0000                    |
| x03h or<br>x83h | STATUS    | _                                                     | _                                                                          |               | TO           | PD          | Z           | DC        | С         | 1 1000               | q quuu                       |
| x04h or<br>x84h | FSR0L     | Indirect Da                                           | Indirect Data Memory Address 0 Low Pointer 0000 0000                       |               |              |             |             |           | uuuu uuuu |                      |                              |
| x05h or<br>x85h | FSR0H     | Indirect Da                                           | Indirect Data Memory Address 0 High Pointer 0000                           |               |              |             |             |           | 0000 0000 | 0000 0000            |                              |
| x06h or<br>x86h | FSR1L     | Indirect Data Memory Address 1 Low Pointer 0000 0000  |                                                                            |               |              |             |             | uuuu uuuu |           |                      |                              |
| x07h or<br>x87h | FSR1H     | Indirect Data Memory Address 1 High Pointer 0000 0000 |                                                                            |               |              |             |             | 0000 0000 |           |                      |                              |
| x08h or<br>x88h | BSR       | —                                                     | _                                                                          | -             |              |             | BSR<4:0>    |           |           | 0 0000               | 0 0000                       |
| x09h or<br>x89h | WREG      | Working Register 0000 0000 1                          |                                                                            |               |              |             |             | uuuu uuuu |           |                      |                              |
| x0Ahor<br>x8Ah  | PCLATH    | _                                                     | Write Buffer for the Upper 7 bits of the Program Counter         -000 0000 |               |              |             |             |           | -000 0000 |                      |                              |
| x0Bhor<br>x8Bh  | INTCON    | GIE                                                   | PEIE                                                                       | TMR0IE        | INTE         | IOCIE       | TMR0IF      | INTF      | IOCIF     | 0000 0000            | 0000 0000                    |

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

#### 4.3 Code Protection

Code protection allows the device to be protected from unauthorized access. 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 the 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 the 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 10.4 "User ID, Device ID and Configuration Word Access"** for more information on accessing these memory locations. For more information on checksum calculation, see the *"PIC12(L)F1571/2 Memory Programming Specification"* (DS40001713).

#### 4.6 Device ID and Revision ID

The 14-bit Device ID word is located at 8006h and the 14-bit Revision ID is located at 8005h. These locations are read-only and cannot be erased or modified. See **Section 10.4 "User ID, Device ID and Configuration Word Access"** for more information on accessing these memory locations.

Development tools, such as device programmers and debuggers, may be used to read the Device ID and Revision ID.

#### 6.1 Power-on Reset (POR)

The POR circuit holds the device in Reset until VDD has reached an acceptable level for minimum operation. Slow rising VDD, fast operating speeds or analog performance may require greater than minimum VDD. The PWRT, BOR or MCLR features can be used to extend the start-up period until all device operation conditions have been met.

#### 6.1.1 POWER-UP TIMER (PWRT)

The Power-up Timer provides a nominal 64 ms time-out on a POR or Brown-out Reset.

The device is held in Reset as long as PWRT is active. The PWRT delay allows additional time for the VDD to rise to an acceptable level. The Power-up Timer is enabled by clearing the PWRTE bit in the Configuration Words.

The Power-up Timer starts after the release of the POR and BOR.

For additional information, refer to Application Note AN607, *"Power-up Trouble Shooting"* (DS0000607).

#### 6.2 Brown-out Reset (BOR)

The BOR circuit holds the device in Reset when VDD reaches a selectable minimum level. Between the POR and BOR, complete voltage range coverage for execution protection can be implemented.

The Brown-out Reset module has four operating modes controlled by the BOREN<1:0> bits in the Configuration Words. The four operating modes are:

- · BOR is always on
- · BOR is off when in Sleep
- · BOR is controlled by software
- · BOR is always off

Refer to Table 6-1 for more information.

The Brown-out Reset voltage level is selectable by configuring the BORV bit in the Configuration Words.

A VDD noise rejection filter prevents the BOR from triggering on small events. If VDD falls below VBOR for a duration greater than parameter, TBORDC, the device will reset. See Figure 6-2 for more information.

| BOREN<1:0> | SBOREN | Device Mode | BOR Mode | Instruction Execution upon:<br>Release of POR or Wake-up from Sleep |
|------------|--------|-------------|----------|---------------------------------------------------------------------|
| 11         | х      | х           | Active   | Waits for BOR ready <sup>(1)</sup><br>(BORRDY = 1)                  |
| 1.0        | 37     | Awake       | Active   | Waits for BOR ready                                                 |
| IU         | Å      | Sleep       | Disabled | (BORRDY = 1)                                                        |
| 01         | 1      | х           | Active   | Waits for BOR ready <sup>(1)</sup><br>(BORRDY = 1)                  |
|            | 0      | Х           | Disabled | Begins immediately                                                  |
| 0.0        | Х      | Х           | Disabled | (BORRDY = x)                                                        |

#### TABLE 6-1:BOR OPERATING MODES

**Note 1:** In these specific cases, "release of POR" and "wake-up from Sleep", there is no delay in start-up. The BOR ready flag (BORRDY = 1) will be set before the CPU is ready to execute instructions because the BOR circuit is forced on by the BOREN<1:0> bits.

#### 7.1 Operation

Interrupts are disabled upon any device Reset. They are enabled by setting the following bits:

- · GIE bit of the INTCON register
- Interrupt enable bit(s) for the specific interrupt event(s)
- PEIE bit of the INTCON register (if the interrupt enable bit of the interrupt event is contained in the PIE1, PIE2 and PIE3 registers)

The INTCON, PIR1, PIR2 and PIR3 registers record individual interrupts via interrupt flag bits. Interrupt flag bits will be set, regardless of the status of the GIE, PEIE and individual interrupt enable bits.

The following events happen when an interrupt event occurs while the GIE bit is set:

- · Current prefetched instruction is flushed
- · GIE bit is cleared
- Current Program Counter (PC) is pushed onto the stack
- Critical registers are automatically saved to the shadow registers (See "Section 7.5 "Automatic Context Saving".")
- · PC is loaded with the interrupt vector, 0004h

The firmware within the Interrupt Service Routine (ISR) should determine the source of the interrupt by polling the interrupt flag bits. The interrupt flag bits must be cleared before exiting the ISR to avoid repeated interrupts. Because the GIE bit is cleared, any interrupt that occurs while executing the ISR will be recorded through its interrupt flag, but will not cause the processor to redirect to the interrupt vector.

The RETFIE instruction exits the ISR by popping the previous address from the stack, restoring the saved context from the shadow registers and setting the GIE bit.

For additional information on a specific interrupt's operation, refer to its peripheral chapter.

- Note 1: Individual interrupt flag bits are set, regardless of the state of any other enable bits.
  - 2: All interrupts will be ignored while the GIE bit is cleared. Any interrupt occurring while the GIE bit is clear will be serviced when the GIE bit is set again.

#### 7.2 Interrupt Latency

Interrupt latency is defined as the time from when the interrupt event occurs to the time code execution at the interrupt vector begins. The latency for synchronous interrupts is three or four instruction cycles. For asynchronous interrupts, the latency is three to five instruction cycles, depending on when the interrupt occurs. See Figure 7-2 and Figure 7-3 for more details.

# PIC12(L)F1571/2

#### EXAMPLE 10-3: WRITING TO FLASH PROGRAM MEMORY

| ;  | This                                                                                        | write routi  | ne assumes the f    | ollowing:                                                  |  |  |  |  |
|----|---------------------------------------------------------------------------------------------|--------------|---------------------|------------------------------------------------------------|--|--|--|--|
| ;  | 1. 32                                                                                       | 2 bytes of d | lata are loaded,    | starting at the address in DATA_ADDR                       |  |  |  |  |
| ;  | 2. Ea                                                                                       | ach word of  | data to be writt    | en is made up of two adjacent bytes in DATA_ADDR,          |  |  |  |  |
| ;  | store                                                                                       | ed in little | e endian format     |                                                            |  |  |  |  |
| ;  | ; 3. A valid starting address (the Least Significant bits = 00000) is loaded in ADDRH:ADDRL |              |                     |                                                            |  |  |  |  |
| ;  | 4. AI                                                                                       | ODRH and ADD | RL are located i    | n shared data memory 0x70 - 0x7F (common RAM)              |  |  |  |  |
| ;  |                                                                                             |              |                     |                                                            |  |  |  |  |
|    |                                                                                             | BCF          | INTCON,GIE          | ; Disable ints so required sequences will execute properly |  |  |  |  |
|    |                                                                                             | BANKSEL      | PMADRH              | ; Bank 3                                                   |  |  |  |  |
|    |                                                                                             | MOVF         | ADDRH,W             | ; Load initial address                                     |  |  |  |  |
|    |                                                                                             | MOVWF        | PMADRH              | ;                                                          |  |  |  |  |
|    |                                                                                             | MOVF         | ADDRL,W             | ;                                                          |  |  |  |  |
|    |                                                                                             | MOVWF        | PMADRL              | ;                                                          |  |  |  |  |
|    |                                                                                             | MOVLW        | LOW DATA_ADDR       | ; Load initial data address                                |  |  |  |  |
|    |                                                                                             | MOVWF        | FSROL               | ;                                                          |  |  |  |  |
|    |                                                                                             | MOVLW        | HIGH DATA_ADDR      | ; Load initial data address                                |  |  |  |  |
|    |                                                                                             | MOVWF        | FSROH               |                                                            |  |  |  |  |
|    |                                                                                             | BCF          | PMCON1,CFGS         | ; Not configuration space                                  |  |  |  |  |
|    |                                                                                             | BSF          | PMCON1,WREN         | ; Enable writes                                            |  |  |  |  |
|    |                                                                                             | BSF          | PMCON1,LWLO         | ; Only Load Write Latches                                  |  |  |  |  |
| LC | OP                                                                                          |              |                     |                                                            |  |  |  |  |
|    |                                                                                             | MOVIW        | FSRU++              | , Load first data byte into lower                          |  |  |  |  |
|    |                                                                                             | MOVWF        | PMDATL              | i                                                          |  |  |  |  |
|    |                                                                                             | MOVIW        | FSRU++              | , Load second data byte into upper                         |  |  |  |  |
|    |                                                                                             | MOAME        | PMDATH              | i                                                          |  |  |  |  |
|    |                                                                                             | MOVE         |                     | Check if lower bits of address are (00000)                 |  |  |  |  |
|    |                                                                                             | YOPLW        | PMADRD,W<br>0√1⊑    | Check if we're on the last of 16 addresses                 |  |  |  |  |
|    |                                                                                             | ANDLW        | 0v1F                | :                                                          |  |  |  |  |
|    |                                                                                             | RTESC        | CTATIC 7            | Exit if last of 16 words                                   |  |  |  |  |
|    |                                                                                             | GOTO         | START WRITE         | :                                                          |  |  |  |  |
|    |                                                                                             | 9010         | START_WRITE         |                                                            |  |  |  |  |
|    |                                                                                             | MOVLW        | 55h                 | ; Start of required write sequence:                        |  |  |  |  |
|    |                                                                                             | MOVWF        | PMCON2              | ; Write 55h                                                |  |  |  |  |
|    | 0                                                                                           | MOVLW        | 0AAh                | 1                                                          |  |  |  |  |
|    | no.                                                                                         | MOVWF        | PMCON2              | ; Write AAh                                                |  |  |  |  |
|    | qui                                                                                         | BSF          | PMCON1,WR           | ; Set WR bit to begin write                                |  |  |  |  |
|    | Sec<br>Sec                                                                                  | NOP          | ,                   | ; NOP instructions are forced as processor                 |  |  |  |  |
|    | - 05                                                                                        |              |                     | ; loads program memory write latches                       |  |  |  |  |
|    |                                                                                             | NOP          |                     | ;                                                          |  |  |  |  |
|    |                                                                                             |              |                     |                                                            |  |  |  |  |
|    |                                                                                             | INCF         | PMADRL, F           | ; Still loading latches Increment address                  |  |  |  |  |
|    |                                                                                             | GOTO         | LOOP                | ; Write next latches                                       |  |  |  |  |
|    |                                                                                             |              |                     |                                                            |  |  |  |  |
| ST | ART_V                                                                                       | VRITE        |                     |                                                            |  |  |  |  |
|    |                                                                                             | BCF          | PMCON1,LWLO         | ; No more loading latches - Actually start Flash program   |  |  |  |  |
|    |                                                                                             |              |                     | ; memory write                                             |  |  |  |  |
|    |                                                                                             | MOTITI       | EEb                 | Chart of required write compared                           |  |  |  |  |
|    |                                                                                             | MOVEW        | DMCON2              | , Start of required write sequence.                        |  |  |  |  |
|    |                                                                                             | MOVWF        | PMCONZ<br>0AAb      | , write 550                                                |  |  |  |  |
|    | ed                                                                                          | MOVEW        | DMCON2              | , Marita DAb                                               |  |  |  |  |
|    | luir<br>ueı                                                                                 | MOVWF        | PMCONZ<br>DMCON1 WP | , WILLE AAN<br>. Set NP bit to begin write                 |  |  |  |  |
|    | Sec                                                                                         | NOD          | PMCON1,WK           | NOD instructions are forged as processor writes            |  |  |  |  |
|    | <u>т</u> 0                                                                                  | 1101         |                     | ; all the program memory write latches simultaneously      |  |  |  |  |
|    |                                                                                             | NOP          |                     | ; to program memory                                        |  |  |  |  |
|    |                                                                                             | 1101         |                     | ; After NOPs the processor                                 |  |  |  |  |
|    | ·                                                                                           |              |                     | ; stalls until the self-write process in complete          |  |  |  |  |
|    |                                                                                             |              |                     | ; after write processor continues with 3rd instruction     |  |  |  |  |
|    |                                                                                             | BCF          | PMCON1,WREN         | Disable writes                                             |  |  |  |  |
|    |                                                                                             | BSF          | INTCON, GIE         | ; Enable interrupts                                        |  |  |  |  |
|    |                                                                                             |              |                     | -                                                          |  |  |  |  |

| Legend: | - : 4 |         | L : 4   |         |                          |         |         |
|---------|-------|---------|---------|---------|--------------------------|---------|---------|
|         |       |         |         |         |                          |         |         |
| bit 7   |       |         |         |         |                          |         | bit 0   |
| —       | —     |         |         | WPUA<   | :5:0> <sup>(1,2,3)</sup> |         |         |
| U-0     | U-0   | R/W-1/1 | R/W-1/1 | R/W-1/1 | R/W-1/1                  | R/W-1/1 | R/W-1/1 |
|         |       |         |         |         |                          |         |         |

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

WPUA<5:0>: Weak Pull-up Register bits<sup>(1,2,3)</sup> bit 5-0

1 = Pull-up is enabled

0 = Pull-up is disabled

Note 1: Global WPUEN bit of the OPTION\_REG register must be cleared for individual pull-ups to be enabled.

- 2: The weak pull-up device is automatically disabled if the pin is configured as an output.
- 3: For the WPUA3 bit, when MCLRE = 1, the weak pull-up is internally enabled, but not reported here.

#### ODCONA: PORTA OPEN-DRAIN CONTROL REGISTER REGISTER 11-7:

| U-0   | U-0 | R/W-0/0 | R/W-0/0 | U-0 | R/W-0/0 | R/W-0/0  | R/W-0/0 |
|-------|-----|---------|---------|-----|---------|----------|---------|
| —     | —   | ODA•    | <5:4>   | —   |         | ODA<2:0> |         |
| bit 7 |     |         |         |     |         |          | bit 0   |

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

| bit 7-6 | Unimplemented: Read as '0'    |
|---------|-------------------------------|
| bit 5-4 | ODA<5:4>: PORTA Open-Drain Er |

ODA<5:4>: PORTA Open-Drain Enable bits

For RA<5:4> Pins, Respectively:

1 = Port pin operates as open-drain drive (sink current only)

- 0 = Port pin operates as standard push-pull drive (source and sink current)
- bit 3 Unimplemented: Read as '0'
- bit 2-0 ODA<2:0>: PORTA Open-Drain Enable bits

For RA<2:0> Pins, Respectively:

- 1 = Port pin operates as open-drain drive (sink current only)
- 0 = Port pin operates as standard push-pull drive (source and sink current)

| REGISTER 11-8: | <b>SLRCONA: PORTA</b> | <b>SLEW RATE CONTROL</b> | REGISTER |
|----------------|-----------------------|--------------------------|----------|
|                |                       |                          |          |

| U-0              | U-0            | R/W-1/1          | R/W-1/1       | U-0                                                   | R/W-1/1          | R/W-1/1  | R/W-1/1 |  |
|------------------|----------------|------------------|---------------|-------------------------------------------------------|------------------|----------|---------|--|
| —                | —              | SLRA             | <5:4>         |                                                       | SLRA<2:0>        |          |         |  |
| bit 7            |                |                  |               |                                                       |                  |          | bit 0   |  |
|                  |                |                  |               |                                                       |                  |          |         |  |
| Legend:          |                |                  |               |                                                       |                  |          |         |  |
| R = Readable     | bit            | W = Writable     | bit           |                                                       |                  |          |         |  |
| u = Bit is unch  | anged          | x = Bit is unk   | nown          | U = Unimpler                                          | mented bit, read | 1 as '0' |         |  |
| '1' = Bit is set |                | '0' = Bit is cle | ared          | -n/n = Value at POR and BOR/Value at all other Resets |                  |          |         |  |
|                  |                |                  |               |                                                       |                  |          |         |  |
| bit 7-6          | Unimplemen     | ted: Read as '   | 0'            |                                                       |                  |          |         |  |
| bit 5-4          | SLRA<5:4>:     | PORTA Slew I     | Rate Enable b | its                                                   |                  |          |         |  |
|                  | For RA<5:4>    | Pins, Respect    | ively:        |                                                       |                  |          |         |  |
|                  | 1 = Port pin s | lew rate is limi | ted           |                                                       |                  |          |         |  |
|                  | 0 = Port pin s | lews at maxim    | um rate       |                                                       |                  |          |         |  |
| bit 3            | Unimplemen     | ted: Read as '   | 0'            |                                                       |                  |          |         |  |
| bit 2-0          | SLRA<2:0>:     | PORTA Slew I     | Rate Enable b | its                                                   |                  |          |         |  |
|                  | For RA<2:0>    | Pins, Respect    |               |                                                       |                  |          |         |  |
|                  | 1 = Port pin s | lew rate is limi | ted           |                                                       |                  |          |         |  |
|                  | 0 = Port pin s | lews at maxim    | um rate       |                                                       |                  |          |         |  |
|                  |                |                  |               |                                                       |                  |          |         |  |

#### REGISTER 11-9: INLVLA: PORTA INPUT LEVEL CONTROL REGISTER

| U-0   | U-0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 | R/W-0/0 |
|-------|-----|---------|---------|---------|---------|---------|---------|
| —     | —   | INLVLA5 | INLVLA4 | INLVLA3 | INLVLA2 | INLVLA1 | INLVLA0 |
| bit 7 |     |         |         |         |         |         | bit 0   |

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

bit 7-6 Unimplemented: Read as '0'

bit 5-0 INLVLA<5:0>: PORTA Input Level Select bits

For RA<5:0> Pins, Respectively:

1 = ST input is used for PORT reads and Interrupt-On-Change

0 = TTL input is used for PORT reads and Interrupt-On-Change

#### 14.0 TEMPERATURE INDICATOR MODULE

This family of devices is equipped with a temperature circuit designed to measure the operating temperature of the silicon die. The circuit's range of operating temperature falls between -40°C and +85°C. The output is a voltage that is proportional to the device temperature. The output of the temperature indicator is internally connected to the device ADC.

The circuit may be used as a temperature threshold detector or a more accurate temperature indicator, depending on the level of calibration performed. A one-point calibration allows the circuit to indicate a temperature closely surrounding that point. A two-point calibration allows the circuit to sense the entire range of temperature more accurately. Reference Application Note AN1333, *"Use and Calibration of the Internal Temperature Indicator"* (DS00001333) for more details regarding the calibration process.

#### 14.1 Circuit Operation

Figure 14-1 shows a simplified block diagram of the temperature circuit. The proportional voltage output is achieved by measuring the forward voltage drop across multiple silicon junctions.

Equation 14-1 describes the output characteristics of the temperature indicator.

#### EQUATION 14-1: VOUT RANGES

High Range: VOUT = VDD - 4 VT

Low Range: VOUT = VDD - 2 VT

The temperature sense circuit is integrated with the Fixed Voltage Reference (FVR) module. See **Section 13.0 "Fixed Voltage Reference (FVR)"** for more information.

The circuit is enabled by setting the TSEN bit of the FVRCON register. When disabled, the circuit draws no current.

The circuit operates in either high or low range. The high range, selected by setting the TSRNG bit of the FVRCON register, provides a wider output voltage. This provides more resolution over the temperature range, but may be less consistent from part to part. This range requires a higher bias voltage to operate and thus, a higher VDD is needed.

The low range is selected by clearing the TSRNG bit of the FVRCON register. The low range generates a lower voltage drop and thus, a lower bias voltage is needed to operate the circuit. The low range is provided for low-voltage operation.

#### FIGURE 14-1: TEMPERATURE CIRCUIT DIAGRAM



### 14.2 Minimum Operating VDD

When the temperature circuit is operated in low range, the device may be operated at any operating voltage that is within specifications.

When the temperature circuit is operated in high range, the device operating voltage, VDD, must be high enough to ensure that the temperature circuit is correctly biased.

Table 14-1 shows the recommended minimum  $\mathsf{V}\mathsf{D}\mathsf{D}$  vs. range setting.

#### TABLE 14-1: RECOMMENDED VDD VS. RANGE

| Min. VDD, TSRNG = 1 | Min. VDD, TSRNG = 0 |  |  |  |  |
|---------------------|---------------------|--|--|--|--|
| 3.6V                | 1.8V                |  |  |  |  |

#### 14.3 Temperature Output

The output of the circuit is measured using the internal Analog-to-Digital Converter. A channel is reserved for the temperature circuit output. Refer to **Section 15.0 "Analog-to-Digital Converter (ADC) Module"** for detailed information.

#### 14.4 ADC Acquisition Time

To ensure accurate temperature measurements, the user must wait at least 200  $\mu$ s after the ADC input multiplexer is connected to the temperature indicator output before the conversion is performed. In addition, the user must wait 200  $\mu$ s between sequential conversions of the temperature indicator output.

#### 15.2.6 ADC CONVERSION PROCEDURE

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

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

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

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

#### EXAMPLE 15-1: ADC CONVERSION

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

#### REGISTER 15-4: ADRESH: ADC RESULT REGISTER HIGH (ADRESH) ADFM = 0

| R/W-x/u          | R/W-x/u | R/W-x/u           | R/W-x/u | R/W-x/u        | R/W-x/u          | R/W-x/u          | R/W-x/u      |
|------------------|---------|-------------------|---------|----------------|------------------|------------------|--------------|
|                  |         |                   | ADRE    | S<9:2>         |                  |                  |              |
| bit 7            |         |                   |         |                |                  |                  | bit 0        |
|                  |         |                   |         |                |                  |                  |              |
| Legend:          |         |                   |         |                |                  |                  |              |
| R = Readable     | bit     | W = Writable I    | oit     |                |                  |                  |              |
| u = Bit is uncha | anged   | x = Bit is unkn   | own     | U = Unimpler   | nented bit, read | d as '0'         |              |
| '1' = Bit is set |         | '0' = Bit is clea | ared    | -n/n = Value a | at POR and BC    | R/Value at all o | other Resets |

bit 7-0 **ADRES<9:2>**: ADC Result Register bits Upper eight bits of 10-bit conversion result.

#### **REGISTER 15-5:** ADRESL: ADC RESULT REGISTER LOW (ADRESL) ADFM = 0

| R/W-x/u    | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u | R/W-x/u R/W-x/u |   | R/W-x/u |
|------------|---------|---------|---------|---------|-----------------|---|---------|
| ADRES<1:0> |         | —       | —       | —       | —               | — | —       |
| bit 7      |         |         |         |         |                 |   | bit 0   |

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

bit 7-6 **ADRES<1:0>**: ADC Result Register bits Lower two bits of 10-bit conversion result.

bit 5-0 **Reserved**: Do not use







#### 19.3 Timer1 Prescaler

Timer1 has four prescaler options, allowing 1, 2, 4 or 8 divisions of the clock input. The T1CKPSx bits of the T1CON register control the prescale counter. The prescale counter is not directly readable or writable; however, the prescaler counter is cleared upon a write to TMR1H or TMR1L.

#### 19.4 Timer1 Operation in Asynchronous Counter Mode

If control bit, T1SYNC, of the T1CON register is set, the external clock input is not synchronized. The timer increments asynchronously to the internal phase clocks. If the external clock source is selected then the timer will continue to run during Sleep and can generate an interrupt on overflow, which will wake-up the processor. However, special precautions in software are needed to read/write the timer (see Section 19.4.1 "Reading and Writing Timer1 in Asynchronous Counter Mode").

Note: When switching from synchronous to asynchronous operation, it is possible to skip an increment. When switching from asynchronous to synchronous operation, it is possible to produce an additional increment.

#### 19.4.1 READING AND WRITING TIMER1 IN ASYNCHRONOUS COUNTER MODE

Reading TMR1H or TMR1L while the timer is running from an external asynchronous clock will ensure a valid read (taken care of in hardware). However, the user should keep in mind that reading the 16-bit timer in two 8-bit values itself, poses certain problems, since the timer may overflow between the reads.

For writes, it is recommended that the user simply stop the timer and write the desired values. A write contention may occur by writing to the timer registers, while the register is incrementing. This may produce an unpredictable value in the TMR1H:TMR1L register pair.

#### 19.5 Timer1 Gate

Timer1 can be configured to count freely or the count can be enabled and disabled using Timer1 gate circuitry. This is also referred to as Timer1 Gate Enable.

Timer1 gate can also be driven by multiple selectable sources.

#### 19.5.1 TIMER1 GATE ENABLE

The Timer1 Gate Enable mode is enabled by setting the TMR1GE bit of the T1GCON register. The polarity of the Timer1 Gate Enable mode is configured using the T1GPOL bit of the T1GCON register.

When Timer1 Gate Enable mode is enabled, Timer1 will increment on the rising edge of the Timer1 clock source. When Timer1 Gate Enable mode is disabled, no incrementing will occur and Timer1 will hold the current count. See Figure 19-3 for timing details.

## TABLE 19-3: TIMER1 GATE ENABLE SELECTIONS

| T1CLK      | T1GPOL | T1G | Timer1 Operation |
|------------|--------|-----|------------------|
| 1          | 0      | 0   | Counts           |
| $\uparrow$ | 0      | 1   | Holds Count      |
| $\uparrow$ | 1      | 0   | Holds Count      |
| $\uparrow$ | 1      | 1   | Counts           |

#### 19.5.2 TIMER1 GATE SOURCE SELECTION

Timer1 gate source selections are shown in Table 19-4. Source selection is controlled by the T1GSS<1:0> bits of the T1GCON register. The polarity for each available source is also selectable. Polarity selection is controlled by the T1GPOL bit of the T1GCON register.

TABLE 19-4: TIMER1 GATE SOURCES

| T1GSS<1:0> | Timer1 Gate Source                                                    |
|------------|-----------------------------------------------------------------------|
| 00         | Timer1 Gate Pin (T1G)                                                 |
| 01         | Overflow of Timer0 (T0_overflow)<br>(TMR0 increments from FFh to 00h) |
| 10         | Comparator 1 Output (C1OUT_sync) <sup>(1)</sup>                       |
| 11         | Reserved                                                              |

Note 1: Optionally synchronized comparator output.

#### 20.1 Timer2 Operation

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

TMR2 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, T2CKPS<1:0> of the T2CON register. The value of TMR2 is compared to that of the Period register, PR2, 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 TMR2 to 00h on the next cycle and drives the output counter/ postscaler (see **Section 20.2 "Timer2 Interrupt"**).

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

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

| Note: | TMR2     | is | not | cleared | when | T2CON | is |
|-------|----------|----|-----|---------|------|-------|----|
|       | written. |    |     |         |      |       |    |

#### 20.2 Timer2 Interrupt

Timer2 can also generate an optional device interrupt. The Timer2 output signal (T2\_match) provides the input for the 4-bit counter/postscaler. This counter generates the TMR2 match interrupt flag which is latched in TMR2IF of the PIR1 register. The interrupt is enabled by setting the TMR2 Match Interrupt Enable bit, TMR2IE of the PIE1 register.

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

#### 20.3 Timer2 Output

The output of TMR2 is T2\_match.

The T2\_match signal is synchronous with the system clock. Figure 20-3 shows two examples of the timing of the T2\_match signal relative to Fosc and prescale value, T2CKPS<1:0>. The upper diagram illustrates 1:1 prescale timing and the lower diagram, 1:X prescale timing.





#### 20.4 Timer2 Operation During Sleep

Timer2 cannot be operated while the processor is in Sleep mode. The contents of the TMR2 and PR2 registers will remain unchanged while the processor is in Sleep mode.

#### 21.1.2 EUSART ASYNCHRONOUS RECEIVER

The Asynchronous mode is typically used in RS-232 systems. The receiver block diagram is shown in Figure 21-2. The data is received on the RX/DT pin and drives the data recovery block. The data recovery block is actually a high-speed shifter operating at 16 times the baud rate, whereas the serial Receive Shift Register (RSR) operates at the bit rate. When all eight or nine bits of the character have been shifted in, they are immediately transferred to a two character First-In-First-Out (FIFO) memory. The FIFO buffering allows reception of two complete characters and the start of a third character before software must start servicing the EUSART receiver. The FIFO and RSR registers are not directly accessible by software. Access to the received data is via the RCREG register.

#### 21.1.2.1 Enabling the Receiver

The EUSART receiver is enabled for asynchronous operation by configuring the following three control bits:

- CREN = 1
- SYNC = 0
- SPEN = 1

All other EUSART control bits are assumed to be in their default state.

Setting the CREN bit of the RCSTA register enables the receiver circuitry of the EUSART. Clearing the SYNC bit of the TXSTA register configures the EUSART for asynchronous operation. Setting the SPEN bit of the RCSTA register enables the EUSART. The programmer must set the corresponding TRIS bit to configure the RX/DT I/O pin as an input.

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

#### 21.1.2.2 Receiving Data

The receiver data recovery circuit initiates character reception on the falling edge of the first bit. The first bit, also known as the Start bit, is always a zero. The data recovery circuit counts one-half bit time to the center of the Start bit and verifies that the bit is still a zero. If it is not a zero then the data recovery circuit aborts character reception, without generating an error, and resumes looking for the falling edge of the Start bit. If the Start bit zero verification succeeds, then the data recovery circuit counts a full bit time to the center of the next bit. The bit is then sampled by a majority detect circuit and the resulting '0' or '1' is shifted into the RSR. This repeats until all data bits have been sampled and shifted into the RSR. One final bit time is measured and the level sampled. This is the Stop bit, which is always a '1'. If the data recovery circuit samples a '0' in the Stop bit position then a framing error is set for this character; otherwise, the framing error is cleared for this character. See Section 21.1.2.4 "Receive Framing Error" for more information on framing errors.

Immediately after all data bits and the Stop bit have been received, the character in the RSR is transferred to the EUSART receive FIFO and the RCIF interrupt flag bit of the PIR1 register is set. The top character in the FIFO is transferred out of the FIFO by reading the RCREG register.

Note: If the receive FIFO is overrun, no additional characters will be received until the overrun condition is cleared. See Section 21.1.2.5 "Receive Overrun Error" for more information on overrun errors.

#### 21.1.2.3 Receive Interrupts

The RCIF interrupt flag bit of the PIR1 register is set whenever the EUSART receiver is enabled and there is an unread character in the receive FIFO. The RCIF interrupt flag bit is read-only, it cannot be set or cleared by software.

RCIF interrupts are enabled by setting all of the following bits:

- RCIE, Interrupt Enable bit of the PIE1 register
- PEIE, Peripheral Interrupt Enable bit of the INTCON register
- GIE, Global Interrupt Enable bit of the INTCON register

The RCIF interrupt flag bit will be set when there is an unread character in the FIFO, regardless of the state of interrupt enable bits.

#### TABLE 21-3: BAUD RATE FORMULAS

| Configuration Bits |       | Bits |                     | Poud Poto Formula |  |  |
|--------------------|-------|------|---------------------|-------------------|--|--|
| SYNC               | BRG16 | BRGH | BRG/EUSART Mode     | Baud Kale Formula |  |  |
| 0                  | 0     | 0    | 8-bit/Asynchronous  | Fosc/[64 (n+1)]   |  |  |
| 0                  | 0     | 1    | 8-bit/Asynchronous  |                   |  |  |
| 0                  | 1     | 0    | 16-bit/Asynchronous |                   |  |  |
| 0                  | 1     | 1    | 16-bit/Asynchronous |                   |  |  |
| 1                  | 0     | x    | 8-bit/Synchronous   | Fosc/[4 (n+1)]    |  |  |
| 1                  | 1     | x    | 16-bit/Synchronous  |                   |  |  |

**Legend:** x = Don't care; n = value of SPBRGH/SPBRGL register pair.

#### TABLE 21-4: SUMMARY OF REGISTERS ASSOCIATED WITH THE BAUD RATE GENERATOR

| 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 | 186                 |
| RCSTA   | SPEN      | RX9   | SREN  | CREN  | ADDEN | FERR  | OERR  | RX9D  | 185                 |
| SPBRGL  | BRG<7:0>  |       |       |       |       |       |       |       |                     |
| SPBRGH  | BRG<15:8> |       |       |       |       |       |       |       | 187*                |
| TXSTA   | CSRC      | TX9   | TXEN  | SYNC  | SENDB | BRGH  | TRMT  | TX9D  | 184                 |

Legend: — = unimplemented location, read as '0'. Shaded cells are not used for the Baud Rate Generator.

\* Page provides register information.





| TABLE 26-10: | CLKOUT | AND I/O | TIMING | PARAMETERS |
|--------------|--------|---------|--------|------------|
|--------------|--------|---------|--------|------------|

| Standard Operating Conditions (unless otherwise stated) |          |                                                               |               |          |          |       |                                                                              |  |  |  |
|---------------------------------------------------------|----------|---------------------------------------------------------------|---------------|----------|----------|-------|------------------------------------------------------------------------------|--|--|--|
| Param.<br>No.                                           | Sym.     | Characteristic                                                | Min.          | Тур†     | Max.     | Units | Conditions                                                                   |  |  |  |
| OS11                                                    | TosH2ckL | Fosc↑ to CLKOUT↓ <sup>(1)</sup>                               | _             | _        | 70       | ns    | $3.3V \le V\text{DD} \le 5.0V$                                               |  |  |  |
| OS12                                                    | TosH2ckH | Fosc↑ to CLKOUT↑ <sup>(1)</sup>                               | —             | -        | 72       | ns    | $3.3V \le V\text{DD} \le 5.0V$                                               |  |  |  |
| OS13                                                    | TckL2ioV | CLKOUT↓ to Port Out Valid <sup>(1)</sup>                      | —             | _        | 20       | ns    |                                                                              |  |  |  |
| OS14                                                    | TioV2ckH | Port Input Valid Before CLKOUT <sup>(1)</sup>                 | Tosc + 200 ns | -        | _        | ns    |                                                                              |  |  |  |
| OS15                                                    | TosH2ioV | Fosc↑ (Q1 cycle) to Port Out Valid                            | —             | 50       | 70*      | ns    | $3.3V \leq V\text{DD} \leq 5.0V$                                             |  |  |  |
| OS16                                                    | TosH2iol | Fosc↑ (Q2 cycle) to Port Input Invalid<br>(I/O in setup time) | 50            | —        | —        | ns    | $3.3V \le V\text{DD} \le 5.0V$                                               |  |  |  |
| OS17                                                    | TioV2osH | Port Input Valid to Fosc↑ (Q2 cycle)<br>(I/O in setup time)   | 20            | -        | —        | ns    |                                                                              |  |  |  |
| OS18*                                                   | TioR     | Port Output Rise Time                                         |               | 40<br>15 | 72<br>32 | ns    | $\begin{array}{l} VDD = 1.8V,\\ 3.3V \leq VDD \leq 5.0V \end{array}$         |  |  |  |
| OS19*                                                   | TioF     | Port Output Fall Time                                         |               | 28<br>15 | 55<br>30 | ns    | $\begin{array}{l} VDD \mbox{ = } 1.8V, \\ 3.3V \le VDD \le 5.0V \end{array}$ |  |  |  |
| OS20*                                                   | Tinp     | INT Pin Input High or Low Time                                | 25            | _        | _        | ns    |                                                                              |  |  |  |
| OS21*                                                   | Tioc     | Interrupt-On-Change New Input Level Time                      | 25            |          | _        | ns    |                                                                              |  |  |  |

\* These parameters are characterized but not tested.

† Data in "Typ" column is at 3.0V, +25°C unless otherwise stated.

Note 1: Measurements are taken in EXTRC mode where CLKOUT output is 4 x Tosc.



FIGURE 27-23: IPD, WATCHDOG TIMER (WDT), PIC12LF1571/2 ONLY







FIGURE 27-31: IPD, ADC NON-CONVERTING, PIC12LF1571/2 ONLY





#### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

### QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

#### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, flexPWR, JukeBlox, KEELoQ, KEELoQ logo, Kleer, LANCheck, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC<sup>32</sup> logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

The Embedded Control Solutions Company and mTouch are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, ECAN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, KleerNet, KleerNet logo, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, RightTouch logo, REAL ICE, SQI, Serial Quad I/O, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2013-2015, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-63277-715-7

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and mulfacture of development systems is ISO 9001:2000 certified.