

# dsPIC33EPXXGS50X FAMILY

# dsPIC33EPXXGS50X Family Silicon Errata and Data Sheet Clarification

The dsPIC33EPXXGS50X family devices that you have received conform functionally to the current Device Data Sheet (DS70005127**C**), 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 dsPIC33EPXXGS50X family 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 (**B3**).

Data Sheet clarifications and corrections start on Page 15, 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:

- 1. Using the appropriate interface, connect the device to the hardware debugger.
- 2. Open an MPLAB IDE project.
- 3. 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> <u>Reconnect</u>.
  - b) For MPLAB X IDE, select <u>Window > Dash-board</u> and click the Refresh Debug Tool Status icon ( ).
- 5. 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 silicon revisions of the dsPIC33EPXXGS50X family are shown in Table 1.

| Dent Neurise     | Device ID <sup>(1)</sup> | Revision ID for S | licon Revision <sup>(2)</sup> |
|------------------|--------------------------|-------------------|-------------------------------|
| Part Number      |                          | B2                | B3                            |
| dsPIC33EP16GS502 | 0x4E01                   |                   |                               |
| dsPIC33EP16GS504 | 0x4E02                   |                   |                               |
| dsPIC33EP16GS505 | 0x4E02                   |                   |                               |
| dsPIC33EP16GS506 | 0x4E03                   |                   |                               |
| dsPIC33EP32GS502 | 0x4E11                   | _                 |                               |
| dsPIC33EP32GS504 | 0x4E12                   | 04005             | 04000                         |
| dsPIC33EP32GS505 | 0x4E12                   | 0x4005            | 0x4006                        |
| dsPIC33EP32GS506 | 0x4E13                   | _                 |                               |
| dsPIC33EP64GS502 | 0x4E21                   |                   |                               |
| dsPIC33EP64GS504 | 0x4E22                   |                   |                               |
| dsPIC33EP64GS505 | 0x4E22                   |                   |                               |
| dsPIC33EP64GS506 | 0x4E23                   |                   |                               |

# TABLE 1: SILICON DEVREV VALUES

**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".

<sup>2:</sup> Refer to the "dsPIC33EPXXGS50X Family Flash Programming Specification" (DS70005160) for detailed information on Device and Revision IDs for your specific device.

# dsPIC33EPXXGS50X FAMILY

# TABLE 2: SILICON ISSUE SUMMARY

| Module            | Feature                                                                                                                      | ltem<br>Number | Issue Summary                                                                                                                                                                                | Affe<br>Revisi | cted<br>ons <sup>(1)</sup> |
|-------------------|------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------|
|                   |                                                                                                                              | Number         |                                                                                                                                                                                              | B2             | B3                         |
| Auxiliary PLL     | APLL Lock                                                                                                                    | 1.             | The APLL lock bit is asserted directly after enabling the APLL.                                                                                                                              | Х              | Х                          |
| CPU               | div.sd                                                                                                                       | 2.             | When using the div.sd instruction, the Overflow bit is not getting set when an overflow occurs.                                                                                              | Х              | Х                          |
| CPU               | DO Loop         3.         PSV access, including Table Reads or Writes in the last instruction of a DO loop, is not allowed. |                | Х                                                                                                                                                                                            | Х              |                            |
|                   |                                                                                                                              | 4.             | _                                                                                                                                                                                            |                |                            |
| Comparator        | EXTREF                                                                                                                       | 5.             | The comparator does not function when the external reference is used as the DAC reference voltage.                                                                                           | Х              | Х                          |
| l <sup>2</sup> C  | Slave Mode                                                                                                                   | 6.             | Bus data can get corrupted when it matches with one of the slave addresses connected to the bus.                                                                                             | Х              | Х                          |
| PWM               | PWM Module<br>Enabled                                                                                                        | 7.             | A glitch may be observed on the PWM pins when the PWM module is enabled after assignment of pin ownership to the PWM module.                                                                 | Х              | Х                          |
| Input<br>Capture  | Cascade Mode                                                                                                                 | 8.             | When ICx is used in Cascaded mode, the even timer does<br>not increment immediately when the odd timer rolls over,<br>but instead, increments one cycle after the rollover.                  | Х              | Х                          |
| PWM               | Push-Pull<br>Mode                                                                                                            | 9.             | When EIPU = 0, a period update may produce<br>back-to-back pulses.                                                                                                                           | Х              | Х                          |
| Input<br>Capture  | Synchronous<br>Cascade Mode                                                                                                  | 10.            | An even numbered timer does not reset on a source clock rollover in a synchronous cascaded operation.                                                                                        |                | Х                          |
| Output<br>Compare | PWM Mode                                                                                                                     | 11.            | In the scaled down timer source for the output compare module, the first PWM pulse may not appear on the OCx pin.                                                                            |                | Х                          |
| Output<br>Compare | Interrupt                                                                                                                    | 12.            | Under certain circumstances, an output compare match<br>may cause the Output Compare x Interrupt Flag (OCxIF)<br>bit to become set prior to the Change-of-State (COS) of the<br>OCx pin.     | Х              | Х                          |
| PWM               | Redundant/<br>Push-Pull<br>Output Mode                                                                                       | 13.            | Changing the duty cycle value from a non-zero value to zero will produce a glitch pulse equal to 1 PWM clock.                                                                                | Х              | Х                          |
| PWM               | Trigger<br>Compare<br>Match                                                                                                  | 14.            | The first PWM/ADC trigger event on a TRIGx/STRIGx match may not occur under certain conditions.                                                                                              | Х              | Х                          |
| UART              | Break<br>Character<br>Generation                                                                                             | 15.            | The Transmit Shift Register Empty (TRMT) bit is unreliable when there are back-to-back Break character transmissions.                                                                        | Х              | Х                          |
| ADC               | ADC Sampling                                                                                                                 | 16.            | Under specific conditions, multi-core ADC sampling<br>cross-talk noise might be present.                                                                                                     | Х              | Х                          |
| PWM               | Push-Pull<br>Mode                                                                                                            | 17.            | When EIPU = 1, Period register writes may produce<br>back-to-back pulses under certain conditions.                                                                                           |                | Х                          |
| I <sup>2</sup> C  | Slave Mode                                                                                                                   | 18.            | In 10-Bit Addressing Slave mode, on receiving the upper<br>address byte (A9 and A8 bits), the Acknowledge Time<br>Status bit (ACKTIM) is not asserted during the<br>Acknowledgment sequence. |                | Х                          |
| I <sup>2</sup> C  | Slave Receive<br>Mode                                                                                                        | 19.            | The Acknowledge Time Status bit (ACKTIM) is asserted<br>only if Address Hold Enable (AHEN) or Data Hold Enable<br>(DHEN) is enabled.                                                         | Х              | X                          |

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

| Module                                                                                                                      | Feature                          | ltem<br>Number                                                  | Issue Summary                                                                                                                                                                                                                                                                                    |    | cted<br>ions <sup>(1)</sup> |
|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----------------------------|
|                                                                                                                             |                                  | Number                                                          |                                                                                                                                                                                                                                                                                                  | B2 | B3                          |
| PWM         Master Time<br>Base Mode         20.         Changes to the PHASEx register may result in missing<br>dead time. |                                  | Changes to the PHASEx register may result in missing dead time. | Х                                                                                                                                                                                                                                                                                                | Х  |                             |
| ADC                                                                                                                         | DNL                              | 21.                                                             | DNL is out of specification at the mid-code boundary in Single-Ended mode.                                                                                                                                                                                                                       | Х  | Х                           |
| PWM                                                                                                                         | Center-Aligned<br>Complementary  | 22.                                                             | Dead time between transitions of the PWMxH and PWMxL outputs may not be asserted when SWAP mode is disabled.                                                                                                                                                                                     | Х  | X                           |
| ADC                                                                                                                         | Single-Ended<br>Offset Error     | 23.                                                             | Offset error is out of specification in Single-Ended mode.                                                                                                                                                                                                                                       | Х  |                             |
| CPU                                                                                                                         | Variable<br>Interrupt<br>Latency | 24.                                                             | When Variable Interrupt Latency is selected (VAR = 1), an address error trap or incorrect application behavior may occur.                                                                                                                                                                        | Х  | X                           |
| CPU                                                                                                                         | Context<br>Switching             | 25.                                                             | When nesting more than one interrupt (without the Alternate Working register set) within the interrupts which are using Alternate Working register sets, there will be an unexpected change in the CCTXI<2:0> bits in the CTXTSTAT register while returning from the highest priority interrupt. | X  | X                           |
| I <sup>2</sup> C                                                                                                            | Address Hold                     | 26.                                                             | In Slave mode when AHEN = 1 (Address Hold Enable), if ACKDT (Acknowledge Data bit) is set at the beginning of address reception, clock stretching will not happen after the 8th clock.                                                                                                           | Х  | Х                           |
| I <sup>2</sup> C                                                                                                            | Data Hold                        | 27.                                                             | In Slave mode when DHEN = 1 (Data Hold Enable), if ACKDT (Acknowledge Data bit) is set at the beginning of data reception, then a slave interrupt will not occur after the 8th clock.                                                                                                            | Х  | Х                           |
| SPI                                                                                                                         | SPI Enable                       | 28.                                                             | When SPI is enabled for the first time, there may be a spurious clock on the SCK which causes mismatch between the clock and data lines.                                                                                                                                                         | Х  | X                           |
| Comparator                                                                                                                  | Comparator<br>Output Jitter      | 29.                                                             | The comparator module may generate erroneous triggers/interrupts.                                                                                                                                                                                                                                | Х  | Х                           |
| I/O                                                                                                                         | 5V Tolerant                      | 30.                                                             | Limited input current to I/O pins that support 5V operation.                                                                                                                                                                                                                                     | Х  | Х                           |
| I/O                                                                                                                         | Schmitt Trigger                  | 31.                                                             | Schmitt Trigger output may produce glitches.                                                                                                                                                                                                                                                     | Х  | Х                           |
| I <sup>2</sup> C                                                                                                            | Bus Collisions                   | 32.                                                             | In Slave mode, false bus collision triggers are generated when bus collision is enabled (SBCDE = 1).                                                                                                                                                                                             | Х  | Х                           |
| I <sup>2</sup> C                                                                                                            | Hold Time                        | 33.                                                             | Minimum hold time of 300 ns is not achieved when the data hold time bit (SDAHT) is set.                                                                                                                                                                                                          | Х  | Х                           |

# TABLE 2: SILICON ISSUE SUMMARY (CONTINUED)

| Note 1: | Only those i | 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 (**B3**).

#### 1. Module: Auxiliary PLL

The Auxiliary PLL Lock bit (ACLKCON<14>) is asserted directly after enabling the APLL module (ACLKCON<15>).

#### Work around

Add a 50  $\mu s$  delay routine after enabling the APLL lock bit.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 2. Module: CPU

When using the Signed 32-by-16-bit Division instruction, div.sd, the Overflow bit does not always get set when an overflow occurs.

#### Work around

Test for and handle overflow conditions outside of the  ${\tt div.sd}$  instruction.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 3. Module: CPU

Table Write (TBLWTL, TBLWTH) instructions cannot be the first or last instruction of a DO loop.

#### Work around

None.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

#### 4. Module: -

Silicon errata issue 4 has been corrected and does not apply to the current silicon revision.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
|    |    |  |  |  |

#### 5. Module: Comparator

When the External Voltage Reference bit is enabled (EXTREF = 1) in the CMPxCON<5> register, the dedicated Digital-to-Analog Converter (DAC) will not be connected to the respective analog comparators inverting/negative input terminals.

#### Work around

Configure the External Reference bit, EXTREF = 0in the CMPxCON<5> register, to select AVDD as the reference for the respective Digital-to-Analog Converter (DAC).

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

# 6. Module: I<sup>2</sup>C

In applications with multiple I<sup>2</sup>C slaves, bus data can become corrupted when the data payload sent to an addressed slave device matches the bus address of another (unaddressed) slave device.

#### Work around

Keep track of the bus address and data phases in software. When Address Hold Enable is used (the AHEN bit is set), the application can assert a NACK for any of the received bytes (invalid addresses and data bytes for other slave devices) until a Stop bit is received.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 7. Module: PWM

The PENH and PENL bits in the IOCONx register are used to assign ownership of the pins to either the PWM module or the GPIO module. The correct procedure to configure the PWM module is to first assign pin ownership to the PWM module and then enable it using the PTEN bit in the PTCON register.

If the PWM module is enabled using the above sequence, then a glitch may be observed on the PWM pins before the actual switching of the PWM outputs begins. This glitch may cause a momentary turn-on of power MOSFETs that are driven by the PWM pins and may cause damage to the application hardware.

#### Work around

Perform the following steps to avoid any glitches from appearing on the PWM outputs at the time of enabling:

 Configure the respective PWM pins to digital inputs using the TRISx registers. This step will put the PWM pins in a high-impedance state. The PWM outputs must be maintained in a safe state by using pull-up or pull-down resistors.

- Assign pin ownership to the GPIO module by configuring the PENH bit (IOCONx<15> = 0) and the PENL bit (IOCONx<14> = 0).
- Specify the PWM override state to the desired safe state for the PWM pins using the OVRDAT<1:0> bits field in the IOCONx register.
- Override the PWM outputs by setting the OVRENH bit (IOCONx<9> = 1) and the OVRENL bit (IOCONx<8> = 1).
- 5. Enable the PWM module by setting the PTEN bit (PTCON<15> = 1).
- Remove the PWM overrides by making the OVRENH bit (IOCONx<9> = 0) and the OVRENL bit (IOCONx<8> = 0).
- 7. Ensure a delay of at least one full PWM cycle.
- Assign pin ownership to the PWM module by setting the PENH bit (IOCONx<15> = 1) and the PENL bit (IOCONx<14> = 1).

The code in Example 1 illustrates the use of this work around.

#### EXAMPLE 1: CONFIGURE PWM MODULE TO PREVENT GLITCHES ON PWM1H AND PWM1L PINS AT THE TIME OF ENABLING

| <pre>TRISAbits.TRISA4 = 1;<br/>TRISAbits.TRISA3 = 1;</pre>   | <pre>// Configure PWM1H/RA4 as digital input // Ensure output is in safe state using pull-up or pull-down resistors // Configure PWM1L/RA3 as digital input // Ensure output is in safe state using pull-up or pull-down resistors</pre> |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>IOCON1bits.PENH = 0;<br/>IOCON1bits.PENL = 0;</pre>     | // Assign pin ownership of PWM1H/RA4 to GPIO module<br>// Assign pin ownership of PWM1L/RA3 to GPIO module                                                                                                                               |
| IOCON1bits.OVRDAT = 0;                                       | // Configure PWM outputs override state to the desired safe state                                                                                                                                                                        |
|                                                              | // Override PWM1H output<br>// Override PWM1L output                                                                                                                                                                                     |
| PTCONbits.PTEN = 1;                                          | // Enable PWM module                                                                                                                                                                                                                     |
| <pre>IOCON1bits.OVRENH = 0;<br/>IOCON1bits.OVRENL = 0;</pre> | // Remove override for PWM1H output<br>// Remove override for PWM1L output                                                                                                                                                               |
| Delay(x);                                                    | // Introduce a delay greater than one full PWM cycle                                                                                                                                                                                     |
| IOCON1bits.PENH = 1;<br>IOCON1bits.PENL = 1;                 | // Assign pin ownership of PWM1H/RA4 to PWM module<br>// Assign pin ownership of PWM1L/RA3 to PWM module                                                                                                                                 |

Example 1 applies when the PWMLOCK Configuration bit is disabled. If the PWMLOCK bit is enabled, unlock/lock routines are required to write to the IOCONx registers.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 8. Module: Input Capture

When the IC is used in Cascaded mode, the even timer does not increment immediately when the odd timer rolls over, but instead, occurs one cycle after the rollover.

In the cascaded configuration, ICy:ICx (ICy represents the even numbered modules and ICx represents the odd numbered modules) form a single 32-bit module. In such a configuration, when ICx counts for a 16-bit value (65535 cycles) and rolls over to 0 during the next clock cycle (65536th cycle), ICy should immediately increment by 1. Instead, the ICy timer remains at 0, and during the next clock cycle (65537th cycle), both ICx and ICy timers increment by 1.

#### Work around

None.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

#### 9. Module: PWM

When the PWM module is configured for Push-Pull mode (IOCONx<11:10> = 0b10) with the Enable Immediate Period Update bit disabled (PTCON<10> = 0), and when operating in (ITB = 0) Master Time Base mode (PWMCONx<9> = 0), a write to the Period register occurs on the PWMx cycle boundaries. This may cause the push-pull output logic to produce back-to-back pulses on the PWMx pins.

#### Work around

Work around 1: Ensure that the Enable Immediate Period Update bit (PTCON <10> = 1) is set.

Work around 2: Configure the PWM phase-shift value (PHASEx<15:0>) with a value more than 0x0007.

When multiple PWM generators are configured in Push-Pull mode, configure the PWM phase shift value (PHASEx<15:0>) with a value more than 0x0007 for the respective PWM generators.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 10. Module: Input Capture

The even numbered timer does not reset on a source clock rollover in Synchronous Cascaded mode operation.

In the cascaded configuration, ICy:ICx (ICy represents the even numbered modules and ICx represents the odd numbered modules), ICy and ICx form a single 32-bit module. In Synchronous Cascaded mode (IC32 = 1, ICTRIG = 0 and the SYNCSEL<4:0> bits are not equal to 0h), both timers, ICyTMR:ICxTMR, must reset on a Sync\_trig input from the 32-bit source timers, but only the odd timer (ICxTMR) is getting reset on a Sync Trigger input.

#### Work around

None.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

#### 11. Module: Output Compare

The first PWM pulse may not appear on the OCx pin if the timer source of the Output Compare x module is scaled down.

The first pulse on the OCx pin is missed in PWM mode when the timer source for the Output Compare x module is scaled down (1:8, 1:64 or 1:256) using the Timerx Input Clock Prescale Select bits, TCKPS<1:0> (TxCON<5:4>).

#### Work around

- Configure the prescaler for the source timer to 1:1 for output compare.
- The scaled down timer (1:8, 1:64 or 1:256) can be used as a source for the output compare.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 12. Module: Output Compare

Under certain circumstances, an output compare match may cause the Output Compare x Interrupt Flag (OCxIF) bit to become set prior to the Change-of-State (COS) of the OCx pin. This has been observed when all of the following are true:

- The module is in One-Shot mode (OCM<2:0> = 0b001, 0b010 or 0b100)
- One of the timer modules is being used as the time base
- A timer prescaler other than 1:1 is selected

If the module is re-initialized by clearing the OCM<2:0> bits after the One-Shot mode compare, the OCx pin may not be driven as expected.

#### Work around

After OCxIF is set, allow an interval (in CPU cycles) of at least twice the prescaler factor to elapse before clearing the OCM<2:0> bits. For example, for a prescaler value of 1:8, allow 16 CPU cycles to elapse after the interrupt.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 13. Module: PWM

In the Redundant Output mode (IOCONx<11:10> = 0b01) and Push-Pull Output mode (IOCONx < 11:10 > = 0b10), with the Immediate Update Enable bit disabled (PWMCONx<0> = 0), when the Duty Cycle register is updated from a non-zero value to zero, a glitch pulse of a width equal to 1 PWM clock will appear at the next PWM period boundary, as shown in Figure 1 (for the Redundant Output mode). The Duty Cycle register refers to the PDCx register if PWMCONx < 8 > = 0 or the MDC register is PWMCONx < 8 > = 1.

#### FIGURE 1: EXAMPLE FOR REDUNDANT OUTPUT MODE



#### Work around

If the application requires a zero duty cycle output, there are two possible work around methods:

- Use the PWM override feature to override the PWM output to a low state instead of writing to the Duty Cycle register. In order to switch back to a non-zero duty cycle output, turn off the PWM override. The override-on and override-off events must be timed close to the PWM period boundary if the IOCONx register has been configured with IOCONx<0> = 0 (i.e., output overrides through the OVDDAT<1:0> bits occur on the next CPU clock boundary).
- Enable the Immediate Update Enable bit (PWMCONx<0> = 1) while configuring the PWMx module (i.e., before enabling the PWMx module, PTCON<15> = 1). With the Immediate Update enabled, writes to the Duty Cycle register can have an immediate effect on the PWM output. Therefore, the duty cycle write operations must be timed close to the PWM period boundary in order to avoid distortions in the PWM output.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

### 14. Module: PWM

The triggers generated by the PWMx Primary Trigger Compare Value register (TRIGx) and the PWMx Secondary Trigger Compare Value register (STRIGx) will not trigger at the point defined by the TRIGx/STRIGx register values on the first instance for the configurations listed below. Subsequent trigger instances are not affected.

- Trigger compare values for TRIGx, STRIGx are less than 8 counts
- Trigger Output Divider bits, TRGDIV<3:0> (TRGCONx<15:12>), are greater than '0'
- Trigger Postscaler Start Enable Select bits, TRGSTRT<5:0> (TRGCONx<5:0>), are equal to '0'

#### Work around

Configure the PWMx Primary Trigger Compare Value Register (TRIGx) and PWMx Secondary Trigger Compare Value Register (STRIGx) values to be equal to or greater than 8.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 15. Module: UART

The Transmit Shift Register Empty (TRMT) bit is unreliable when there are back-to-back Break character transmissions.

For back-to-back Break characters, the TRMT bit may not reflect the actual status. If user software is polling for this bit to be set, it may result in dummy bytes getting transmitted instead of Break characters.

#### Work around

Poll the UARTx Transmit Break bit, UTXBRK (UxSTA<11>), to be cleared instead of the TRMT bit (UxSTA<8>) to be set. The UTXBRK status bit will be cleared after a Break character transmission.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

#### 16. Module: ADC

When using multiple ADC cores, if one of the ADC cores completes conversion while other ADC cores are still converting, the data in the ADC cores which are converting may be randomly corrupted.

#### Work around

Work around 1: When using multiple ADC cores, the ADC triggers are to be sufficiently staggered in time to ensure that the end of conversion of one or more cores doesn't occur during the conversion process of other cores.

Work around 2: For simultaneous conversion requirements, make sure the following conditions are met:

- 1. All the ADC cores for simultaneous conversion should have the same configurations.
- 2. Avoid shared ADC core conversion with any of the dedicated ADC cores. They can be sequential.
- 3. The trigger to initiate ADC conversion should be from the same source and at the same time.

#### Affected Silicon Revisions

| E | 32 | B3 |  |  |  |
|---|----|----|--|--|--|
|   | Х  | Х  |  |  |  |

#### 17. Module: PWM

When the PWM module is configured for Push-Pull mode (IOCONx<11:10> = 0b10) with the Enable Immediate Period Update bit enabled (PTCON <10> = 1), a write to the Period register that coincides with the period rollover event may cause the push-pull output logic to produce back-to-back pulses on the PWMx pins (Figure 2).

#### FIGURE 2:



#### Work around

Ensure that the update to the PWM Period register occurs away from the PWM rollover event by setting the EIPU bit (PTCON<10> = 1). Use either the PWM Special Event Trigger (SEVTCMP) or the PWM Primary Trigger (TRIGx) to generate a PWM Interrupt Service Routine (ISR) near the start of the PWM cycle. This ISR will ensure that period writes do not occur near the PWM period rollover event.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

## 18. Module: I<sup>2</sup>C

In I<sup>2</sup>C Slave 10-Bit Addressing mode, on receiving the upper address byte (A9 and A8 bits), the Acknowledge Time Status bit (ACKTIM) is not asserted during the Acknowledgment sequence. This issue is not seen during the reception of the lower address byte (A7 to A0) and data bytes.

The hardware asserts the ACKTIM on the falling edge of the eighth clock and deasserts on the rising edge of the ninth clock. In this case, ACKTIM is not asserted on the upper address byte reception. When AHEN = 1, the clock is stretched after the 8th falling edge and the ACKTIM bit is asserted until the clock is released. If AHEN = 0, the clock is not stretched and ACKTIM is asserted during the Acknowledgment sequence, which is of a short duration. Therefore, the user application can see this issue of the ACKTIM bit not getting asserted when AHEN = 1.

#### Work around

Instead of polling for ACKTIM to be asserted, poll for the RBF flag.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 19. Module: I<sup>2</sup>C

In I<sup>2</sup>C Slave Receive mode, the Acknowledge Time Status bit (ACKTIM) has no effect if Address Hold Enable (AHEN) and Data Hold Enable (DHEN) are disabled (AHEN = 0 and DHEN = 0). The Acknowledge Time Status bit (ACKTIM) is asserted only if Address Hold Enable (AHEN) or Data hold Enable (DHEN) is enabled.

#### Work around

Instead of polling for the ACKTIM bit to be asserted, poll for the RBF flag.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 20. Module: PWM

In Edge-Aligned PWM mode with Master Time Base (PWMCONx<9> = 0) and Immediate Update disabled (PWMCONx<0> = 0), after enabling the PWMx module (PTCON<15> = 1), changes to the PHASEx register, where PHASEx < DTRx or PHASEx > PDCx, will result in missing dead time at the PWMxH-PWMxL transition that will occur at the next master period boundary.

#### Work around

None.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 21. Module: ADC

When the ADC SAR core is configured to operate in Single-Ended mode, the core's DNL performance may be out of specification at the mid-code boundary.

#### Work around

None.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 22. Module: PWM

In Center-Aligned Complementary mode with Independent Time Base, the expected dead time between transitions of the PWMxH and PWMxL outputs may not be asserted when SWAP is disabled under the following conditions:

- PWMx module is enabled (PTEN = 1)
- SWAP is enabled prior to this event

#### Work around

None.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 23. Module: ADC

When the ADC SAR core is configured to operate in Single-Ended mode, the core's offset error may be out of specification. The affected revisions have the following offset error specifications.

### TABLE 3: ADC SAR CORE OFFSET ERROR

| AD24b | EOFF | Offset Error<br>(Dedicated Core) | > 18 | 39 | < 58 | LSb | AVSS = 0V, AVDD = 3.3V |
|-------|------|----------------------------------|------|----|------|-----|------------------------|
|       |      | Offset Error<br>(Shared Core)    | > 8  | 25 | < 38 | LSb |                        |

#### Work around

None.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  |    |  |  |  |

#### 24. Module: CPU

An address error trap or incorrect application behavior may occur if the variable exception processing latency is enabled by setting the VAR bit (CORCON<15> = 1).

#### Work around

Enable the Fixed Interrupt Latency mode by clearing the VAR bit (CORCON<15> = 0).

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 25. Module: CPU

When returning from an Interrupt Service Routine (ISR) by executing the RETFIE instruction, in the case of a nested interrupt, the Interrupt Priority Control bits (IPC<3:0>) associated with the lower priority interrupt are compared with the CTXTn bits field in the FLTREG Configuration register:

- If there is a match with either of the CTXTn bits field, then the corresponding Alternate Working Register Set is chosen and the Current Context Identifier bits (CCTXI<2:0>) in the CTXTSTAT register are updated to reflect the new Alternate Working Register Set.
- If there is no match with either of the CTXTn bits field, then the expected behavior is to keep the context (defined by the value of the Current Context Identifier bits, CCTXI<2:0> in the CTXTSTAT register) unchanged. However, the

context gets changed. A new context, corresponding to the value in the Manual Context Identifier bits (MCTXI<2:0>) in the CTXTSTAT register, is selected by the hardware and the CCTXI<2:0> bits in the CTXTSTAT register are modified to reflect this change.

When using interrupts with the Alternate Working Register Set (automatic context assignment), no more than one ISR without an Alternate Working Register Set must be nested within an ISR with an Alternate Working Register Set.

Issue and work around are illustrated in Figure 3 and Figure 4, respectively. The figures show the status bits, CCTXI<2:0> and MCTXI<2:0>, after entering into an ISR from a lower priority ISR (left pane), and after returning to the same ISR from a higher priority ISR (right pane).

## FIGURE 3: MISMATCH OF WORKING REGISTER SET WHEN NESTING MORE THAN ONE INTERRUPT WITHIN INTERRUPTS THAT USE ALTERNATE WORKING REGISTER SETS



# dsPIC33EPXXGS50X FAMILY

#### FIGURE 4: WORKAROUND FOR MISMATCH OF WORKING REGISTER SET WHEN NESTING MORE THAN ONE INTERRUPT WITHIN INTERRUPTS THAT USE ALTERNATE WORKING REGISTER SETS



#### Work around

Work around 1: When using interrupts with the Alternate Working Register Set, at the entry of all ISRs that do not have an Alternate Working Register Set and have a higher IPL level than the ISRs with an Alternate Working Register Set, perform a manual context swap to Context #0 as:

asm("CTXTSWP #0");

Note: The application software must not perform a manual context swap (using the CTXTSWP instruction) to a context other than Context #0. Work around 2: Always assign higher IPLs for the ISRs that use an Alternate Working Register Set than for the ISRs that do not use an Alternate Working Register Set.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 26. Module: I<sup>2</sup>C

In Slave mode, when AHEN = 1 (Address Hold Enable), if the ACKDT bit (Acknowledge Data) is set at the beginning of address reception, clock stretching will not happen after the 8th clock.

#### Work around

In Slave mode, user software should clear ACKDT on receiving the Start bit.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

# 27. Module: I<sup>2</sup>C

In Slave mode, when DHEN = 1 (Data Hold Enable), if the ACKDT bit (Acknowledge Data) is set at the beginning of data reception, then the slave interrupt will not occur after the 8th clock.

#### Work around

In Slave mode, user software should clear ACKDT on receiving the Start bit.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 28. Module: SPI

When SPI is enabled for the first time, there may be a spurious clock on the SCK. This may result in one bit of data shifted out on the data line, resulting in a mismatch between the clock and data lines.

This issue may also occur when the SPI is disabled during data transmission and enabled subsequently.

#### Work around

- 1. Disable the SPI module after two SPI cycles and then re-enable SPI; this will synchronize the clock and data.
- 2. If the SPI is configured on PPS pins, first enable the SPI without configuring the PPS, then allow two SPI clocks to pass and then configure the PPS to connect to the SPI module. This will prevent the spurious SPI clock going out on the pin. If the SPI module is turned off periodically, ensure to turn off the PPS as well.

#### Affected Silicon Revisions

| B2 | <b>B</b> 3 |  |  |  |
|----|------------|--|--|--|
| Х  | Х          |  |  |  |

#### 29. Module: Comparator

Analog comparator output may have a jitter when it is operating and this will generate erroneous triggers/interrupts. If the PWM module is configured to be controlled by an analog comparator, the output of the PWM generator may be affected by jitter in the analog comparator output.

#### Work around

Configure the Comparator Hysteresis Select bits, HYSSEL<1:0>, as '0b11' (20 mV hysteresis) and set the Digital Filter Enable bit, FLTREN (CMPxCON<10>), to '1'.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 30. Module: I/O

Undesired pin failure may occur on the RC15, RD0, RD4, RD5, RD10, RD12 and RD15 5V tolerant I/O pins.

#### Work around

If 5V input operation is desired on I/O pins RC15, RD0, RD4, RD5, RD10, RD12 and RD15, use a current-limiting resistor of at least 1 kOhm.

#### Affected Silicon Revisions

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

#### 31. Module: I/O

If the input signal rise or fall time is greater than 300 nS, the I/O Schmitt trigger output may have glitches.

#### Work around

The rise/fall times must be less than 300 nS.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

# 32. Module: I<sup>2</sup>C

In Slave mode, false bus collision triggers are generated when bus collision is enabled (SBCDE = 1).

#### Work around

None.

#### **Affected Silicon Revisions**

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

# 33. Module: I<sup>2</sup>C

Minimum hold time of 300 ns on SDAx after the falling edge of SCLx is not achieved when the Data Hold Time bit (SDAHT) is set.

#### Work around

None.

| B2 | B3 |  |  |  |
|----|----|--|--|--|
| Х  | Х  |  |  |  |

## **Data Sheet Clarifications**

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

| Note: | Corrections are shown in <b>bold</b> . Where |  |  |  |  |  |  |
|-------|----------------------------------------------|--|--|--|--|--|--|
|       | possible, the original bold text formatting  |  |  |  |  |  |  |
|       | has been removed for clarity.                |  |  |  |  |  |  |

#### 1. Module: ADC

Trigger Source Selection for Corresponding Analog Inputs bits options were stated incorrectly in the data sheet. The correct options are as follows:

bit 4-0 TRGSRC(4x)<4:0>: Trigger Source Selection for Corresponding Analog Inputs bits

- 11111 = ADTRG31
- 11110 = Reserved
- 11101 = Reserved
- 11100 = PWM Generator 5 current-limit trigger
- 11011 = PWM Generator 4 current-limit trigger
- 11010 = PWM Generator 3 current-limit trigger
- 11001 = PWM Generator 2 current-limit trigger
- 11000 = PWM Generator 1 current-limit trigger
- 10111 = Output Compare 2 trigger
- 10110 = Output Compare 1 trigger
- 10101 = Reserved
- 10100 = Reserved
- 10011 = PWM Generator 5 secondary trigger
- 10010 = PWM Generator 4 secondary trigger
- 10001 = PWM Generator 3 secondary trigger
- 10000 = PWM Generator 2 secondary trigger
- 01111 = PWM Generator 1 secondary trigger
- 01110 = PWM secondary Special Event Trigger
- 01101 = Timer2 period match
- 01100 = Timer1 period match
- 01011 = Reserved
- 01010 = Reserved
- 01001 = PWM Generator 5 primary trigger
- 01000 = PWM Generator 4 primary trigger
- 00111 = PWM Generator 3 primary trigger
- 00110 = PWM Generator 2 primary trigger
- 00101 = PWM Generator 1 primary trigger
- 00100 = PWM Special Event Trigger
- 00011 = Reserved
- 00010 = Level software trigger
- 00001 = Common software trigger
- 00000 = No trigger is enabled

#### 2. Module: ADC Module Specifications

In Table 26-43, text is added under the Conditions column for AVDD, which is as follows:

| AC CHARACTERISTICS                  |      |                   | $\begin{array}{l} \mbox{Standard Operating Conditions: } 3.0V \mbox{ to } 3.6V \\ \mbox{(unless otherwise stated)}^{(5)} \\ \mbox{Operating temperature} & -40^{\circ}\mbox{C} \leq \mbox{TA} \leq +85^{\circ}\mbox{C for Industrial} \\ & -40^{\circ}\mbox{C} \leq \mbox{TA} \leq +125^{\circ}\mbox{C for Extended} \end{array}$ |             |                                   |       |                                                                                                                               |
|-------------------------------------|------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| Param<br>No. Symbol Characteristics |      |                   | Min.                                                                                                                                                                                                                                                                                                                              | Typical     | Max.                              | Units | Conditions                                                                                                                    |
|                                     |      |                   | De                                                                                                                                                                                                                                                                                                                                | vice Supply | у                                 |       |                                                                                                                               |
| AD01                                | AVdd | Module VDD Supply | Greater of:<br>VDD – 0.3<br>or 3.0                                                                                                                                                                                                                                                                                                | _           | Lesser of:<br>VDD + 0.3<br>or 3.6 | V     | The difference between AVDD<br>supply and VDD supply must<br>not exceed ±300 mV at all<br>times, including device<br>power-up |

#### TABLE 26-43: ADC MODULE SPECIFICATIONS

### 3. Module: Packaging Information

In the "dsPIC33EPXXGS50X Family Data Sheet", Section 28.2 "Package Details", dimensions for the 48-Lead Thin Quad Flatpack (PT) - 7x7x1.0 mm Body [TQFP] With Exposed Pad is mentioned. However, the dsPIC33EPXXGS50X family devices are not available in this package with the exposed pad. The dsPIC33EPXXGS50X family devices are available in the 48-Lead Thin Quad Flatpack (Y8) - 7x7x1.0 mm Body [TQFP] without Exposed Pad and the package dimensions are shown on the following drawings.

# 48-Lead Thin Quad Flatpack (Y8) - 7x7x1.0 mm Body [TQFP]

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



Microchip Technology Drawing C04-300-Y8 Rev A Sheet 1 of 2

# 48-Lead Thin Quad Flatpack (Y8) - 7x7x1.0 mm Body [TQFP]

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



SECTION A-A

|                          | N   | <b>IILLIMETER</b> | S    |      |  |
|--------------------------|-----|-------------------|------|------|--|
| Dimension                | MIN | NOM               | MAX  |      |  |
| Number of Leads          | N   |                   | 48   |      |  |
| Lead Pitch               | е   | 0.50 BSC          |      |      |  |
| Overall Height           | Α   | -                 | -    | 1.20 |  |
| Standoff                 | A1  | 0.05              | -    | 0.15 |  |
| Molded Package Thickness | A2  | 0.95              | 1.00 | 1.05 |  |
| Foot Length              | L   | 0.45              | 0.60 | 0.75 |  |
| Footprint                | L1  | 1.00 REF          |      |      |  |
| Foot Angle               | ¢   | 0°                | 3.5° | 7°   |  |
| Overall Width            | E   | 9.00 BSC          |      |      |  |
| Overall Length           | D   | 9.00 BSC          |      |      |  |
| Molded Package Width     | E1  | 7.00 BSC          |      |      |  |
| Molded Package Length    | D1  | 7.00 BSC          |      |      |  |
| Lead Thickness           | С   | 0.09              | -    | 0.16 |  |
| Lead Width               | b   | 0.17              | 0.22 | 0.27 |  |
| Mold Draft Angle Top     | α   | 11°               | 12°  | 13°  |  |
| Mold Draft Angle Bottom  | β   | 11°               | 12°  | 13°  |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. Chamfers at corners are optional; size may vary.

- Dimensions D1 and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.25mm per side.
- 4. Dimensioning and tolerancing per ASME Y14.5M
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances. REF: Reference Dimension, usually without tolerance, for information purposes only.
- 5. Datums A-B and D to be determined at center line between leads where leads exit plastic body at datum plane [H]

Microchip Technology Drawing C04-300-Y8 Rev A Sheet 2 of 2

# 48-Lead Thin Quad Flatpack (Y8) - 7x7x1.0 mm Body [TQFP]



# RECOMMENDED LAND PATTERN

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

Notes:

1. Dimensioning and tolerancing per ASME Y14.5M

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

2. For best soldering results, thermal vias, if used, should be filled or tented to avoid solder loss during reflow process

Microchip Technology Drawing C04-2300-Y8 Rev A

# APPENDIX A: DOCUMENT REVISION HISTORY

Rev A Document (5/2015)

Initial version of this document; issued for silicon revision B2.

Rev B Document (10/2015)

Adds silicon revision B3.

Adds new silicon issue 23 (ADC).

Rev C Document (3/2016)

Adds new silicon issues 24 (CPU), 25 (CPU), 26 (I<sup>2</sup>C), 27 (I<sup>2</sup>C), 28 (SPI) and 29 (Comparator).

Adds data sheet clarifications 1 (ADC), 2 (ADC Module Specifications) and 3 (Packaging Information).

Rev D Document (4/2017)

Adds new silicon issues 30 (I/O), 31 (I/O), 32 (I<sup>2</sup>C) and 33 (I<sup>2</sup>C).

Adds additional text following Example 1 in silicon issue 7 (PWM).

Removes silicon issue 4 (PWM) because the issue with dead time not being asserted when PDCx is updated has been corrected in the current silicon revision.

#### 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, KEEL00® 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, AVR, AVR logo, AVR Freaks, BeaconThings, BitCloud, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KEELOQ, KEELOQ logo, Kleer, LANCheck, LINK MD, maXStylus, maXTouch, MediaLB, megaAVR, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, Prochip Designer, QTouch, RightTouch, SAM-BA, SpyNIC, SST, SST Logo, SuperFlash, tinyAVR, UNI/O, and XMEGA 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.

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

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.

© 2015-2017, Microchip Technology Incorporated, All Rights Reserved.

ISBN: 978-1-5224-1635-7



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

**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 Tel: 317-536-2380

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

Raleigh, NC Tel: 919-844-7510

New York, NY Tel: 631-435-6000

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

**Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078

#### 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 - Guangzhou Tel: 86-20-8755-8029

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

China - Hong Kong SAR Tel: 852-2943-5100

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

Fax: 852-2401-3431

**China - Qingdao** Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-3326-8000 Fax: 86-21-3326-8021

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-7830 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

Finland - Espoo Tel: 358-9-4520-820

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

France - Saint Cloud Tel: 33-1-30-60-70-00

**Germany - Garching** Tel: 49-8931-9700 **Germany - Haan** Tel: 49-2129-3766400

Germany - Heilbronn Tel: 49-7131-67-3636

Germany - Karlsruhe Tel: 49-721-625370

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

**Germany - Rosenheim** Tel: 49-8031-354-560

Israel - Ra'anana Tel: 972-9-744-7705

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - Padova Tel: 39-049-7625286

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

Norway - Trondheim Tel: 47-7289-7561

Poland - Warsaw Tel: 48-22-3325737

**Romania - Bucharest** Tel: 40-21-407-87-50

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

Sweden - Gothenberg Tel: 46-31-704-60-40

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

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