

# PIC18F2480/2580/4480/4580 Silicon Errata and Data Sheet Clarification

The PIC18F2480/2580/4480/4580 family devices that you have received conform functionally to the current Device Data Sheet (DS39637**D**), except for the anomalies described in this document.

The silicon issues discussed in the following pages are for silicon revisions with the Device and Revision IDs listed in Table 1. The silicon issues are summarized in Table 2.

The errata described in this document will be addressed in future revisions of the PIC18F2480/2580/4480/4580 silicon.

Note: This document summarizes all silicon errata issues from all revisions of silicon, previous as well as current. Only the issues indicated in the last column of Table 2 apply to the current silicon revision (B2).

Data Sheet clarifications and corrections start on page 12, following the discussion of silicon issues.

The silicon revision level can be identified using the current version of MPLAB<sup>®</sup> IDE and Microchip's programmers, debuggers, and emulation tools, which are available at the Microchip corporate web site (www.microchip.com).

For example, to identify the silicon revision level using MPLAB IDE in conjunction with a hardware debugger:

- Using the appropriate interface, connect the device to the hardware debugger.
- 2. Open an MPLAB IDE project.
- Configure the MPLAB IDE project for the appropriate device and hardware debugger.
- 4. Based on the version of MPLAB IDE you are using, do one of the following:
  - a) For MPLAB IDE 8, select <u>Programmer ></u> Reconnect.
  - b) For MPLAB X IDE, select <u>Window > Dashboard</u> and click the **Refresh Debug**Tool Status icon ( ).
- Depending on the development tool used, the part number and Device Revision ID value appear in the **Output** window.

**Note:** If you are unable to extract the silicon revision level, please contact your local Microchip sales office for assistance.

The DEVREV values for the various PIC18F2480/2580/4480/4580 silicon revisions are shown in Table 1.

### TABLE 1: SILICON DEVREY VALUES

| Part Number | Device ID <sup>(1)</sup> | Revision ID for Silicon Revision <sup>(2)</sup> |     |    |  |  |
|-------------|--------------------------|-------------------------------------------------|-----|----|--|--|
| Part Number | Device ID( )             | A1                                              | В0  | B2 |  |  |
| PIC18F2480  | 1AEh                     |                                                 |     |    |  |  |
| PIC18F2580  | 1ACh                     | 1h                                              | Ole | 4h |  |  |
| PIC18F4480  | 1AAh                     | ] ""                                            | 2h  | 40 |  |  |
| PIC18F4580  | 1A8h                     |                                                 |     |    |  |  |

- **Note 1:** The Device IDs (DEVID and DEVREV) are located at the last two implemented addresses of configuration memory space. They are shown in hexadecimal in the format "DEVID DEVREV".
  - 2: Refer to the "PIC18F2XXX/4XXXX Family Flash Microcontroller Programming Specification" (DS39622) for detailed information on Device and Revision IDs for your specific device.

TABLE 2: SILICON ISSUE SUMMARY

| Module                                        | Feature                       | Item   | Issue Summary                                                                                                                                         |            | Affected |    |
|-----------------------------------------------|-------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------|----|
|                                               |                               | Number |                                                                                                                                                       | <b>A</b> 1 | В0       | B2 |
| Master Synchro-<br>nous Serial Port<br>(MSSP) | I <sup>2</sup> C              | 1.     | Slave reception receives incorrect data if not read at the correct time.                                                                              | Х          | Х        | х  |
| Brown-out Reset (BOR)                         | Trip Level                    | 2.     | Trip levels are off at high frequencies.                                                                                                              |            | Х        |    |
| ECCP                                          | Special Event<br>Trigger      | 3.     | The Special Event Trigger Reset does not occur on the next rollover of the prescaler counter.                                                         | Х          |          |    |
| EUSART                                        | Transmission                  | 4.     | 9-bit timing can be corrupted if the TX9D bit is not written immediately after TXIF is set.                                                           | Х          |          |    |
| Timer1/3                                      | 16-Bit Mode                   | 5.     | The TMR1H/TMR3H Buffer registers may lengthen the duration of the period between the increments of the timer.                                         | Х          |          |    |
| Interrupts                                    | 2-Cycle<br>Instruction        | 6.     | f an interrupt occurs during a 2-cycle nstruction modifying the STATUS, BSR or WREG register, the previous value is saved to he Fast Return register. |            |          |    |
| ECAN™ Technology                              | Transmit<br>Buffer ID         | 7.     | The first five bits of a transmitted identifier may not match the transmit buffer ID.                                                                 | Х          |          |    |
| ECAN Technology                               | Error<br>Interruption<br>Flag | 8.     | The error interrupt flag may not be able to be cleared in software if the TXERRCNT or RXERRCNT counters exceed 127.                                   | Х          |          |    |
| ECAN Technology                               | Configuration<br>Mode         | 9.     | After an error on the bus, the module is unable to switch directly from Listen Only mode to Configuration mode.                                       | Х          |          |    |
| ECAN Technology                               | TXBnSIDH<br>Register          | 10.    | May become corrupted.                                                                                                                                 | Х          |          |    |
| ECAN Technology                               | Listen Only<br>Mode           | 11.    | IRXIF, RXB0IF and RXFUL flags are consistently set after 129 or more consistent error frames.                                                         | Х          |          |    |
| 10-Bit Analog-to-<br>Digital Converter        | EIL and EDL                   | 12.    | EIL and EDL may exceed data sheet specifications at codes, 511 and 512.                                                                               |            |          |    |
| MSSP                                          | SPI                           | 13.    | SDO output may change after inactive lock edge of Bit 0.                                                                                              |            |          |    |
| Timer1/3                                      | Interrupt                     | 14.    | When the timer is operated in Asynchronous External Input mode, unexpected interrupt flag generation may occur.                                       | Х          | Х        | Х  |

**Note 1:** Only those issues indicated in the last column apply to the current silicon revision.

### Silicon Errata Issues

Note:

This document summarizes all silicon errata issues from all revisions of silicon, previous as well as current. Only the issues indicated by the shaded column in the following tables apply to the current silicon revision (**B2**).

# 1. Module: Master Synchronous Serial Port (MSSP)

When configured for I<sup>2</sup>C slave reception, the MSSP module may not receive the correct data, in extremely rare cases. This occurs only if the Serial Receive/Transmit Buffer register (SSPBUF) is not read within a window after the SSPIF interrupt (PIR1<3>) has occurred.

### Work around

The issue can be resolved in either of these ways:

 Prior to the I<sup>2</sup>C slave reception, enable the clock stretching feature.

This is done by setting the SEN bit (SSPCON2<0>).

 Each time the SSPIF is set, read the SSPBUF before the first rising clock edge of the next byte being received.

### **Affected Silicon Revisions**

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
| Χ          | Χ  | Χ  |  |  |  |

# 28.1 DC Characteristics: Supply Voltage

PIC18F2480/2580/4480/4580 (Industrial, Extended) PIC18LF2480/2580/4480/4580 (Industrial)

| Param<br>No. | Symbol | Characteristic          | Min.                  | Тур. | Max. | Units | Conditions    |  |  |
|--------------|--------|-------------------------|-----------------------|------|------|-------|---------------|--|--|
| D005         | VBOR   | Brown-out Reset Voltage | own-out Reset Voltage |      |      |       |               |  |  |
|              |        | BORV<1:0> = 01          | 4.47                  | 4.69 | 4.91 | V     | Fosc > 26 MHz |  |  |
|              |        | BORV<1:0> = 00          | 4.72                  | 4.95 | 5.18 | V     | Fosc > 26 MHz |  |  |

### Work around

To address this situation:

- Reduce Fosc to 25 MHz
- Use the lower of the two affected BOR voltage thresholds, BORV<1:0> (CONFIG2L<4:3>) = 01

This will ensure detection of VDD below 5.0V.

### **Affected Silicon Revisions**

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
|            | Χ  |    |  |  |  |

### 2. Module: Brown-out Reset (BOR)

The BOR module may reset above the parameter D005 value specified in **Section 28.1** "DC Characteristics: Supply Voltage" when:

- BORV<1:0> = 01 or 00
- Fosc is above 26 MHz

The updated BOR voltage specifications are shown in the **Section 28.1** table.

#### 3. Module: ECCP

When operating either Timer1 or Timer3 as a counter, with a prescale value other than 1:1 and operating the ECCP in Compare mode with the Special Event Trigger (CCP1CON bits, CCP1M<3:0> = 1011), the Special Event Trigger Reset of the timer occurs as soon as there is a match between TMRxH:TMRxL and CCPR1H:CCPR1L.

This differs from the PIC18F458, where the Special Event Trigger Reset of the timer occurs on the next rollover of the prescale counter, after the match between TMRxH:TMRxL and CCPR1H:CCPR1L.

### Work around

To achieve the same timer Reset period as the PIC18F458 devices, for a given clock source, add 1 to the value in CCPR1H:CCPR1L. If CCPR1H:CCPR1L = x for the PIC18F458, achieve the same Reset period on a PIC18F2480/2580/4480/4580 device by using CCPR1H:CCPR1L = x + 1, where the prescale is 1, 2, 4 or 8 (depending on the T1CKPS<1:0> bit values).

#### **Affected Silicon Revisions**

| <b>A1</b> | В0 | B2 |  |  |  |
|-----------|----|----|--|--|--|
| Χ         |    |    |  |  |  |

### 4. Module: EUSART

When performing back-to-back transmission in 9-bit mode (TX9D bit in the TXSTA register is set), an ongoing transmission's timing can be corrupted if the TX9D bit (for the next transmission) is not written immediately following the setting of TXIF. This is because any write to the TXSTA register results in a Reset of the Baud Rate Generator which will effect any ongoing transmission.

#### Work around

Load TX9D just after TXIF is set, either by polling TXIF or by writing TX9D at the beginning of the Interrupt Service Routine. Alternately, only write to TX9D when a transmission is not in progress (TRMT = 1).

### Affected Silicon Revisions

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
| Χ          |    |    |  |  |  |

### 5. Module: Timer1/3

When Timer1/Timer3 is operating in 16-bit mode and the prescale setting is not 1:1, a write to the TMR1H/TMR3H Buffer registers may lengthen the duration of the period between the increments of the timer for the period in which TMR1H/TMR3H were written. It does not change the actual prescale value.

### Work around

Do not write to TMR1H/TMR3H while Timer1/Timer3 is running, or else write to TMR1L/TMR3L immediately following a write to TMR1H/TMR3H.

Do not write to TMR1H/TMR3H and then wait for another event before also updating TMR1L/TMR3L.

#### **Affected Silicon Revisions**

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
| Χ          |    |    |  |  |  |

### 6. Module: Interrupts

If an interrupt occurs during a 2-cycle instruction that modifies the STATUS, BSR or WREG register, the unmodified value of the register will be saved to the corresponding Fast Return (shadow) register. Upon a fast return from the interrupt, the unmodified value will be restored to the STATUS, BSR or WREG register.

For example, if a high-priority interrupt occurs during the instruction, MOVFF TEMP, WREG, the MOVFF instruction will be completed and WREG will be loaded with the value of TEMP before branching to the ISR. However, the previous value of WREG will be saved to the Fast Return register during ISR branching. Upon return from the interrupt with a fast return, the previous value of WREG in the Fast Return register will be written to WREG.

This results in WREG containing the value it had before execution of MOVFF TEMP, WREG.

Affected instructions are:

```
MOVFF Fs, Fd
```

Where Fd is WREG, BSR or STATUS

MOVSF Zs, Fd

Where Fd is WREG, BSR or STATUS

```
MOVSS [Zs], [Zd]
```

Where the destination is WREG, BSR or STATUS

#### Work around

1. Assembly Language Programming:

If any 2-cycle instruction is used to modify the WREG, BSR or STATUS register, do not use the RETFIE FAST instruction to return from the interrupt. Instead, save and then restore WREG, BSR and STATUS via software, as shown in Example 8-1 in the Device Data Sheet.

Alternatively, in the case of MOVFF, use the MOVF instruction to write to WREG instead. For example:

#### Use

| MOVF  | TEMP, | W |
|-------|-------|---|
| MOVWF | BSR   |   |

#### Instead of

```
MOVFF TEMP, BSR
```

As another alternative, the work-around in Example 1 can be used. This example overwrites the Fast Return register by making a dummy call to Foo with the fast option in the high-priority service routine.

### **EXAMPLE 1: ASSEMBLY LANGUAGE INTERRUPT SERVICE**

```
ISR @ 0x0008

CALL Foo, FAST ; store current value of WREG, BSR, STATUS for a second time

Foo:

POP ; clears return address of Foo call
: ; insert high priority ISR code here
:
RETFIE FAST
```

### 2. C Language Programming:

The exact work-around depends on the compiler in use. Consult the C compiler's documentation for details.

If using the Microchip MPLAB® C18 C Compiler, define both high and low-priority interrupt handler functions as "low priority" by using the pragma interruptlow directive. This directive instructs the compiler to not use

the RETFIE FAST instruction. If the proper high-priority interrupt bit is set in the IPRx register, the interrupt is treated as high priority in spite of the pragma interruptlow directive.

The code segment, shown in Example 2, demonstrates the work around using the C18 compiler.

### **EXAMPLE 2: INTERRUPT SERVICE ROUTINE IN C**

```
#pragma interruptlow MyLowISR
void MyLowISR(void)
    // Handle low priority interrupts.
// Although MyHighISR is a high priority interrupt, use interruptlow pragma so that
// the compiler will not use retfie FAST.
#pragma interruptlow MyHighISR
void MyHighISR(void)
    // Handle high priority interrupts.
#pragma code highVector=0x08
void HighVector (void)
    _asm goto MyHighISR _endasm
#pragma code /* return to default code section */
#pragma code lowVector=0x18
void LowVector (void)
    _asm goto MyLowISR _endasm
#pragma code /* return to default code section */
```

An optimized C18 version, illustrating how to reduce the instruction cycle count to three, is provided in Example 3.

### **Affected Silicon Revisions**

| A1 | В0 | B2 |  |  |  |
|----|----|----|--|--|--|
| Χ  |    |    |  |  |  |

### **EXAMPLE 3: OPTIMIZED INTERRUPT SERVICE ROUTINE**

### 7. Module: ECAN™ Technology

Under specific conditions, the first five bits of a transmitted identifier may not match the value in the Transmit Buffer ID register, TXBnSIDH. The following conditions must exist for the corruption to occur:

- · A transmit message must be pending
- The ECAN module must detect a Start-of-Frame (SOF) in the third bit of the interframe space.

### Work around

None.

### **Affected Silicon Revisions**

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
| Χ          |    |    |  |  |  |

### 8. Module: ECAN Technology

The Error Interrupt Flag, ERRIF (PIR3<5>), may not be able to be cleared in software after either of the following counter registers exceeds 127:

- Transmit Error Counter Register (TXERRCNT)
- Receive Error Counter Register (RXERRCNT)

### Work around

Monitor the EWARN (COMSTAT<0>) bit to determine if either the TXERRCNT or the RXERRCNT exceeds 95 and clear the ERRIF flag before either counter reaches 127.

### **Affected Silicon Revisions**

| A1 | В0 | B2 |  |  |  |
|----|----|----|--|--|--|
| Χ  |    |    |  |  |  |

### 9. Module: ECAN Technology

Following an error on the bus, the ECAN module is unable to switch from Listen Only mode directly to Configuration mode.

### Work around

Use the REQOP (CANCON<7:5>) bits to select Normal mode as an intermediate step when switching from Listen Only mode to Configuration mode.

### **Affected Silicon Revisions**

| <b>A1</b> | В0 | B2 |  |  |  |
|-----------|----|----|--|--|--|
| Χ         |    |    |  |  |  |

### 10. Module: ECAN Technology

Under specific conditions, the TXBnSIDH register of the pending message for transmission may be corrupted. This occurs when the following conditions exist:

- A transmit message is pending.
- All of the receive buffers are full and a received message is in the Message Assembly Buffer (MAB).
- A receive buffer is made available (RXFUL (RXBxCON<7>) set to '0') at either of the following times:
  - When a Start-of-Frame (SOF) is recognized on the CAN bus
  - On the instruction cycle prior to the SOF

The timing of this event is crucial.

### Work around

Ensure that a receive buffer overflow condition does not occur and/or ensure that a transmit request is not pending if a receive buffer overflow condition does exist.

The pseudo code segment in Example 4 is an example of how to disable a pending transmission. This code is for illustration purposes only.

### **Affected Silicon Revisions**

| A1 | В0 | B2 |  |  |  |
|----|----|----|--|--|--|
| Χ  |    |    |  |  |  |

### **EXAMPLE 4: DISABLING A PENDING TRANSMISSION**

```
If (RXBnOVFL == 1)
                                      // Has an overflow occurred?
                                     // Is a transmission pending?
          If (TXREQ == 1)
               TXREQ = 0;
                 // Clear transmit request
                                     // Store transmission aborted status value
                       MyFlag = 1;
          }
   Temp_RXREG = RXBx;
                                      // Read receive buffer
   If (MyFlag)
                                      // Was previous transmission aborted?
          TXREQ = 1;
   {
                                      // Set transmit request
          MyFlag = 0;
                                      // Reset stored transmission aborted status
```

### 11. Module: ECAN Technology

In Listen Only mode, the module may persistently set the IRXIF and RXB0IF interrupt flags, and the RXFUL status flag, after receiving 129 or more consecutive error frames. In this case, the flags can be cleared, but then will become set again immediately and continuously without receiving a bus message.

### Work around

Place the ECAN module in Configuration mode before receiving 129 consecutive error frames and then place it back into Listen Only mode.

### **Affected Silicon Revisions**

| A1 | В0 | B2 |  |  |  |
|----|----|----|--|--|--|
| Χ  |    |    |  |  |  |

# 12. Module: 10-Bit Analog-to-Digital Converter

When the AD clock source is selected as 2 Tosc or RC (when ADCS<2:0> = 000 or  $\times11$ ), in extremely rare cases, the EIL (Integral Linearity Error) and EDL (Differential Linearity Error) may exceed the data sheet specifications at codes, 511 and 512 only.

### Work around

Select the AD clock source as 4 Tosc, 8 Tosc, 16 Tosc, 32 Tosc or 64 Tosc and avoid selecting 2 Tosc or RC.

### **Affected Silicon Revisions**

| <b>A</b> 1 | В0 | B2 |  |  |  |
|------------|----|----|--|--|--|
| Χ          |    |    |  |  |  |

### 13. Module: MSSP

In SPI mode, the SDO output may change after the inactive clock edge of the Bit 0 output. This may affect some SPI components that read data over 300 ns after the inactive edge of SCK.

### Work around

None.

### **Affected Silicon Revisions**

| <b>A1</b> | В0 | B2 |  |  |  |
|-----------|----|----|--|--|--|
| Χ         |    |    |  |  |  |

### 14. Module: Timer1/3

When Timer1 or Timer3 is operated in Asynchronous External Input mode, unexpected interrupt flag generation may occur if an external clock edge arrives too soon following a firmware write to the TMRxH:TMRxL registers. An unexpected interrupt flag event may also occur when enabling the module or switching from Synchronous to Asynchronous mode.

### Work around

This issue only applies when operating the timer in Asynchronous mode. Whenever possible, operate the timer module in Synchronous mode to avoid spurious timer interrupts.

If Asynchronous mode must be used in the application, potential strategies to mitigate the issue may include any of the following:

- Design the firmware so it does not rely on the TMRxIF flag or keep the respective interrupt disabled. The timer still counts normally and does not reset to 0x0000 when the spurious interrupt flag event is generated.
- Design the firmware so that it does not write to the TMRxH:TMRxL registers or does not periodically disable/enable the timer, or switch modes. Reading from the timer does not trigger the spurious interrupt flag events.
- If the firmware must use the timer interrupts and must write to the timer (or disable/enable, or mode switch the timer), implement code to suppress the spurious interrupt event, should it occur. This can be achieved by following the process shown in Example 5.

# EXAMPLE 5: ASYNCHRONOUS TIMER MODE WORK AROUND TO AVOID SPURIOUS INTERRUPT

```
/Timer1 update procedure in asynchronous mode
//The code below uses Timer1 as example
                             //Stop timer from incrementing
T1CONbits.TMR1ON = 0;
PIE1bits.TMR1IE = 0;
                             //Temporarily disable Timer1 interrupt vectoring
TMR1H = 0x00;
                              //Update timer value
TMR1L = 0x00;
T1CONbits.TMR1ON = 1;
                              //Turn on timer
//Now wait at least two full T1CKI periods + 2	ext{T}_{	ext{CY}} before re-enabling Timer1 interrupts.
//Depending upon clock edge timing relative to TMR1H/TMR1L firmware write operation,
/a spurious TMR1IF flag event may sometimes assert. If this happens, to suppress
//the actual interrupt vectoring, the TMR1IE bit should be kept clear until
//after the "window of opportunity" (for the spurious interrupt flag event has passed).
//After the window is passed, no further spurious interrupts occur, at least
//until the next timer write (or mode switch/enable event).
while(TMR1L < 0 \times 02);
                              //Wait for 2 timer increments more than the Updated Timer
                              //value (indicating more than 2 full T1CKI clock periods elapsed)
NOP();
                              //Wait two more instruction cycles
NOP();
PIR1bits.TMR1IF = 0;
                              //Clear TMR1IF flag, in case it was spuriously set
PIE1bits.TMR1IE = 1;
                              //Now re-enable interrupt vectoring for timer 1
```

#### **Affected Silicon Revisions**

| A1 | В0 | B2 |  |  |  |
|----|----|----|--|--|--|
| Х  | Х  | Х  |  |  |  |

### **Data Sheet Clarifications**

The following typographic corrections and clarifications are to be noted for the latest version of the device data sheet (DS39637**D**):

**Note:** Corrections are shown in **bold**. Where possible, the original bold text formatting has been removed for clarity.

# 1. Module: Packaging Information

The "Pin 1" dot on the 28-Lead QFN package, in the Package Marking Information section, is incorrectly placed. The correct placement is indicated in **Section 29.1 "28-Lead QFN Package Marking Information"** below:

# 29.1 28-Lead QFN Package Marking Information



# APPENDIX A: DOCUMENT REVISION HISTORY

# Rev A Document (2/2010)

Original release of this errata, combining previous errata for silicon revisions, A1 and B0, and superseding the data sheet errata. Added the B2 silicon revision, which had no issues. No data sheet issues were included as they had been resolved with a data sheet revision.

This document replaces these errata documents:

- DS80419B, "PIC18F2480/2580/4480/4580 Rev. B0 Silicon Errata"
- DS80219E, "PIC18F2480/2580/4480/4580 Rev. A1 Silicon Errata"
- DS80267C, "PIC18F2480/2580/4480/4580 Data Sheet Frrata"

### Rev B Document (3/2010)

Corrected an erroneous silicon revision reference in the revision history.

# Rev C Document (3/2010)

Removed issue #1 from the document and renumbered the previous issues 2-14. Added B2 silicon as being affected by issue 1 (formerly 2) and removed A1 silicon from issue 2 (formerly 3).

### **Rev D Document (7/2014)**

Updated errata to new format; Added MPLAB X IDE; Added Module 14, Timer1/3, to Silicon Errata Issues section.

## Rev D Document (4/2016)

Added Module 1, Package Marking Information, to the Data Sheet Clarifications section. Other minor corrections.

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

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 manufacture of development systems is ISO 9001:2000 certified.

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

#### **Trademarks**

The Microchip name and logo, the Microchip logo, AnyRate, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq, KeeLoq logo, Kleer, LANCheck, LINK MD, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 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.

ClockWorks, The Embedded Control Solutions Company, ETHERSYNCH, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and QUIET-WIRE are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker, Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, 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.

 $\ensuremath{\mathsf{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 trademarks 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.

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

ISBN: 978-1-5224-0527-6



# **Worldwide Sales and Service**

#### **AMERICAS**

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199

Tel: 480-792-7200 Fax: 480-792-7277 Technical Support:

http://www.microchip.com/ support

Web Address:

www.microchip.com
Atlanta

Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

**Austin, TX** Tel: 512-257-3370

Boston

Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL

Tel: 630-285-0071 Fax: 630-285-0075

Cleveland

Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** 

Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

**Detroit** Novi, MI

Tel: 248-848-4000

Houston, TX

Tel: 281-894-5983 Indianapolis

Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles

Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110

**Canada - Toronto** Tel: 905-673-0699 Fax: 905-673-6509

### ASIA/PACIFIC

Asia Pacific Office

Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon

Hong Kong

Tel: 852-2943-5100 Fax: 852-2401-3431

**Australia - Sydney** Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

China - Beijing

Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

**China - Chengdu** Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

**China - Chongqing** Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

**China - Dongguan** Tel: 86-769-8702-9880

**China - Hangzhou** Tel: 86-571-8792-8115 Fax: 86-571-8792-8116

**China - Hong Kong SAR** Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460

Fax: 86-25-8473-2470
China - Qingdao

Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

**China - Shenyang** Tel: 86-24-2334-2829

Fax: 86-24-2334-2393
China - Shenzhen

Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300

Fax: 86-27-5980-5118
China - Xian

Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

### ASIA/PACIFIC

China - Xiamen

Tel: 86-592-2388138 Fax: 86-592-2388130

China - Zhuhai

Tel: 86-756-3210040 Fax: 86-756-3210049

India - Bangalore

Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New Delhi

Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune

Tel: 91-20-3019-1500

**Japan - Osaka** Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770

Fax: 81-3-6880-3771 Korea - Daegu

Tel: 82-53-744-4301 Fax: 82-53-744-4302

**Korea - Seoul** Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857

Fax: 60-3-6201-9859

Malaysia - Penang
Tel: 60-4-227-8870

Fax: 60-4-227-4068

Philippines - Manila

Tel: 63-2-634-9065 Fax: 63-2-634-9069

**Singapore** 

Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung

Tel: 886-7-213-7828

**Taiwan - Taipei** Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### **EUROPE**

Austria - Wels

Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen

Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris

Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - Dusseldorf Tel: 49-2129-3766400

Germany - Karlsruhe Tel: 49-721-625370

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

Italy - Milan Tel: 39-0331-742611

Fax: 39-0331-466781

Italy - Venice Tel: 39-049-7625286

Netherlands - Drunen Tel: 31-416-690399

Fax: 31-416-690340 Poland - Warsaw

Poland - Warsaw Tel: 48-22-3325737

Spain - Madrid

Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

Sweden - Stockholm Tel: 46-8-5090-4654

**UK - Wokingham** Tel: 44-118-921-5800 Fax: 44-118-921-5820

07/14/15