



Welcome to E-XFL.COM

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

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

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

#### Details

| Betans                     |                                                                                |
|----------------------------|--------------------------------------------------------------------------------|
| Product Status             | Active                                                                         |
| Core Processor             | PIC                                                                            |
| Core Size                  | 16-Bit                                                                         |
| Speed                      | 60 MIPs                                                                        |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, QEI, SPI, UART/USART                           |
| Peripherals                | Brown-out Detect/Reset, DMA, Motor Control PWM, POR, PWM, WDT                  |
| Number of I/O              | 35                                                                             |
| Program Memory Size        | 512KB (170K x 24)                                                              |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | · ·                                                                            |
| RAM Size                   | 24K x 16                                                                       |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                      |
| Data Converters            | A/D 9x10b/12b                                                                  |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 44-VFTLA Exposed Pad                                                           |
| Supplier Device Package    | 44-VTLA (6x6)                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24ep512mc204-e-tl |
|                            |                                                                                |

Email: info@E-XFL.COM

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





### 4.8 Interfacing Program and Data Memory Spaces

The dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/ 50X and PIC24EPXXXGP/MC20X architecture uses a 24-bit-wide Program Space (PS) and a 16-bit-wide Data Space (DS). The architecture is also a modified Harvard scheme, meaning that data can also be present in the Program Space. To use this data successfully, it must be accessed in a way that preserves the alignment of information in both spaces.

Aside from normal execution, the architecture of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X devices provides two methods by which Program Space can be accessed during operation:

- Using table instructions to access individual bytes or words anywhere in the Program Space
- Remapping a portion of the Program Space into the Data Space (Program Space Visibility)

Table instructions allow an application to read or write to small areas of the program memory. This capability makes the method ideal for accessing data tables that need to be updated periodically. It also allows access to all bytes of the program word. The remapping method allows an application to access a large block of data on a read-only basis, which is ideal for look-ups from a large table of static data. The application can only access the least significant word of the program word.

### TABLE 4-65: PROGRAM SPACE ADDRESS CONSTRUCTION

|                        | Access        | Program Space Address       |           |                     |                     |     |  |
|------------------------|---------------|-----------------------------|-----------|---------------------|---------------------|-----|--|
| Access Type            | Space         | <23>                        | <22:16>   | <15>                | <14:1>              | <0> |  |
| Instruction Access     | User          | 0                           |           | PC<22:1>            |                     | 0   |  |
| (Code Execution)       |               | 0xx xxxx xxxx xxxx xxxx xxx |           |                     |                     |     |  |
| TBLRD/TBLWT            | User          | TBLPAG<7:0> Data EA<15:0    |           |                     |                     |     |  |
| (Byte/Word Read/Write) |               | 0                           | 0xxx xxxx |                     | XXXX XXXX XXXX XXXX |     |  |
|                        | Configuration | TBLPAG<7:0>                 |           | Data EA<15:0>       |                     |     |  |
|                        |               | 1                           | xxx xxxx  | XXXX XXXX XXXX XXXX |                     |     |  |

### FIGURE 4-22: DATA ACCESS FROM PROGRAM SPACE ADDRESS GENERATION



### 6.1 Reset Resources

Many useful resources are provided on the main product page of the Microchip web site for the devices listed in this data sheet. This product page, which can be accessed using this link, contains the latest updates and additional information.

| Note: | In the event you are not able to access the |
|-------|---------------------------------------------|
|       | product page using the link above, enter    |
|       | this URL in your browser:                   |
|       | http://www.microchip.com/wwwproducts/       |
|       | Devices.aspx?dDocName=en555464              |

#### 6.1.1 KEY RESOURCES

- "Reset" (DS70602) in the "dsPIC33/PIC24 Family Reference Manual"
- · Code Samples
- · Application Notes
- · Software Libraries
- Webinars
- All Related *"dsPIC33/PIC24 Family Reference Manual"* Sections
- Development Tools

### dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| R/S-0                | U-0                                                                          | U-0              | U-0                   | U-0              | U-0              | U-0             | U-0     |  |  |  |  |
|----------------------|------------------------------------------------------------------------------|------------------|-----------------------|------------------|------------------|-----------------|---------|--|--|--|--|
| FORCE <sup>(1)</sup> |                                                                              | _                | _                     | —                |                  | _               |         |  |  |  |  |
| bit 15               |                                                                              |                  |                       |                  |                  |                 | bit 8   |  |  |  |  |
|                      |                                                                              |                  |                       |                  |                  |                 |         |  |  |  |  |
| R/W-0                | R/W-0                                                                        | R/W-0            | R/W-0                 | R/W-0            | R/W-0            | R/W-0           | R/W-0   |  |  |  |  |
| IRQSEL7              | IRQSEL6                                                                      | IRQSEL5          | IRQSEL4               | IRQSEL3          | IRQSEL2          | IRQSEL1         | IRQSEL0 |  |  |  |  |
| bit 7                |                                                                              |                  |                       |                  |                  |                 | bit     |  |  |  |  |
| Legend:              |                                                                              | S = Settable b   | oit                   |                  |                  |                 |         |  |  |  |  |
| R = Readable         | bit                                                                          | W = Writable     | bit                   | U = Unimpler     | mented bit, read | d as '0'        |         |  |  |  |  |
| -n = Value at F      | POR                                                                          | '1' = Bit is set |                       | '0' = Bit is cle | ared             | x = Bit is unkr | nown    |  |  |  |  |
|                      |                                                                              |                  |                       |                  |                  |                 |         |  |  |  |  |
| bit 15               | FORCE: Force                                                                 | e DMA Transfe    | er bit <sup>(1)</sup> |                  |                  |                 |         |  |  |  |  |
|                      | 1 = Forces a single DMA transfer (Manual mode)                               |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 0 = Automatic DMA transfer initiation by DMA request                         |                  |                       |                  |                  |                 |         |  |  |  |  |
| bit 14-8             | Unimplemen                                                                   | ted: Read as 'd  | )'                    |                  |                  |                 |         |  |  |  |  |
| bit 7-0              | IRQSEL<7:0>: DMA Peripheral IRQ Number Select bits                           |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 01000110 = ECAN1 – TX Data Request <sup>(2)</sup>                            |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00100110 = IC4 – Input Capture 4                                             |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00100101 = IC3 - Input Capture 3                                             |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00100010 = ECAN1 - RX Data Ready(2)                                          |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00100001 = SPI2 Transfer Done<br>00011111 = UART2TX – UART2 Transmitter      |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00011111 = UART2TX - UART2 Transmitter $00011110 = UART2RX - UART2 Receiver$ |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00011100 = TMR5 - Timer5                                                     |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00011011 = TMR4 – Timer4                                                     |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00011010 = OC4 – Output Compare 4                                            |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00011001 = OC3 – Output Compare 3                                            |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00001101 = ADC1 – ADC1 Convert done                                          |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00001100 = UART1TX – UART1 Transmitter                                       |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00001011 = UART1RX – UART1 Receiver                                          |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00001010 = SPI1 – Transfer Done<br>00001000 = TMR3 – Timer3                  |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00001000 = TMRS - TimerS<br>00000111 = TMR2 - Timer2                         |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00000111 - 10002 - 100012<br>00000110 = OC2 - Output Compare 2               |                  |                       |                  |                  |                 |         |  |  |  |  |
|                      |                                                                              | IC2 – Input Ca   |                       |                  |                  |                 |         |  |  |  |  |
|                      | 0000010 =                                                                    | OC1 – Output (   | Compare 1             |                  |                  |                 |         |  |  |  |  |
|                      |                                                                              | IC1 – Input Ca   |                       |                  |                  |                 |         |  |  |  |  |
|                      | 00000000 =                                                                   | INT0 – Externa   | I Interrupt 0         |                  |                  |                 |         |  |  |  |  |

#### REGISTER 8-2: DMAXREQ: DMA CHANNEL x IRQ SELECT REGISTER

- **Note 1:** The FORCE bit cannot be cleared by user software. The FORCE bit is cleared by hardware when the forced DMA transfer is complete or the channel is disabled (CHEN = 0).
  - 2: This selection is available in dsPIC33EPXXXGP/MC50X devices only.

## dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

|                 | 12. 2007.00                                                                                                                        |                                                           |              |                   |                  |                 |        |  |  |  |  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--------------|-------------------|------------------|-----------------|--------|--|--|--|--|
| U-0             | U-0                                                                                                                                | U-0                                                       | U-0          | U-0               | U-0              | U-0             | U-0    |  |  |  |  |
| —               | —                                                                                                                                  | —                                                         | —            | —                 | —                | —               | —      |  |  |  |  |
| bit 15          |                                                                                                                                    |                                                           |              |                   |                  |                 | bit 8  |  |  |  |  |
|                 |                                                                                                                                    |                                                           |              |                   |                  |                 |        |  |  |  |  |
| U-0             | U-0                                                                                                                                | U-0                                                       | U-0          | R-0               | R-0              | R-0             | R-0    |  |  |  |  |
| —               |                                                                                                                                    | —                                                         | —            | RQCOL3            | RQCOL2           | RQCOL1          | RQCOL0 |  |  |  |  |
| bit 7           |                                                                                                                                    |                                                           |              |                   |                  |                 | bit 0  |  |  |  |  |
|                 |                                                                                                                                    |                                                           |              |                   |                  |                 |        |  |  |  |  |
| Legend:         |                                                                                                                                    |                                                           |              |                   |                  |                 |        |  |  |  |  |
| R = Readable    | bit                                                                                                                                | W = Writable                                              | bit          | U = Unimpler      | mented bit, read | l as '0'        |        |  |  |  |  |
| -n = Value at F | POR                                                                                                                                | '1' = Bit is set                                          |              | '0' = Bit is cle  | ared             | x = Bit is unkr | nown   |  |  |  |  |
|                 |                                                                                                                                    |                                                           |              |                   |                  |                 |        |  |  |  |  |
| bit 15-4        | Unimplemen                                                                                                                         | ted: Read as '                                            | כ'           |                   |                  |                 |        |  |  |  |  |
| bit 3           | RQCOL3: DN                                                                                                                         | RQCOL3: DMA Channel 3 Transfer Request Collision Flag bit |              |                   |                  |                 |        |  |  |  |  |
|                 | <ul> <li>1 = User force and interrupt-based request collision is detected</li> <li>0 = No request collision is detected</li> </ul> |                                                           |              |                   |                  |                 |        |  |  |  |  |
| <b>h</b> # 0    | •                                                                                                                                  |                                                           |              | est Callisian Fl  | aa hit           |                 |        |  |  |  |  |
| bit 2           |                                                                                                                                    | /IA Channel 2 T<br>ce and interrupt                       | •            |                   | 0                |                 |        |  |  |  |  |
|                 |                                                                                                                                    | e and interrupt<br>est collision is d                     |              |                   | elecieu          |                 |        |  |  |  |  |
| bit 1           | RQCOL1: DN                                                                                                                         | /IA Channel 1 T                                           | ransfer Requ | est Collision F   | ag bit           |                 |        |  |  |  |  |
|                 | 1 = User force and interrupt-based request collision is detected                                                                   |                                                           |              |                   |                  |                 |        |  |  |  |  |
|                 | 0 = No reque                                                                                                                       | est collision is d                                        | etected      |                   |                  |                 |        |  |  |  |  |
| bit 0           | RQCOLO: DN                                                                                                                         | /IA Channel 0 T                                           | ransfer Requ | est Collision F   | lag bit          |                 |        |  |  |  |  |
|                 | 1 = User force                                                                                                                     | e and interrupt                                           | -based reque | st collision is d | etected          |                 |        |  |  |  |  |

### REGISTER 8-12: DMARQC: DMA REQUEST COLLISION STATUS REGISTER

0 = No request collision is detected

#### 11.7 **Peripheral Pin Select Registers**

#### REGISTER 11-1: RPINR0: PERIPHERAL PIN SELECT INPUT REGISTER 0

| U-0    | R/W-0 | R/W-0 | R/W-0 | R/W-0      | R/W-0 | R/W-0 | R/W-0 |
|--------|-------|-------|-------|------------|-------|-------|-------|
| —      |       |       |       | INT1R<6:0> |       |       |       |
| bit 15 |       |       |       |            |       |       | bit 8 |
|        |       |       |       |            |       |       |       |
| U-0    | U-0   | U-0   | U-0   | U-0        | U-0   | U-0   | U-0   |
| —      | —     | —     | —     | —          | _     | _     | —     |
| bit 7  |       | •     |       | •          |       |       | bit 0 |
|        |       |       |       |            |       |       |       |

| Legend: |
|---------|
|---------|

| Legena:           |                  |                             |                    |
|-------------------|------------------|-----------------------------|--------------------|
| R = Readable bit  | W = Writable bit | U = Unimplemented bit, read | l as '0'           |
| -n = Value at POR | '1' = Bit is set | '0' = Bit is cleared        | x = Bit is unknown |

| bit 15 | Unimplemented: Read as '0' |
|--------|----------------------------|
|--------|----------------------------|

bit 14-8 INT1R<6:0>: Assign External Interrupt 1 (INT1) to the Corresponding RPn Pin bits (see Table 11-2 for input pin selection numbers) 1111001 = Input tied to RPI121 0000001 = Input tied to CMP1 0000000 = Input tied to Vss bit 7-0 Unimplemented: Read as '0'

| U-0       R/W-0       R/W       R/W       R/W </th <th>R/W-0</th> <th>R/W-0</th> <th>R/W-0</th> <th>R/W-0</th> <th>R/W-0</th> <th>R/W-0</th> <th>U-0</th> <th>U-0</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W-0         | R/W-0                                 | R/W-0                                                                                                                                      | R/W-0                            | R/W-0                   | R/W-0            | U-0               | U-0           |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------|------------------|-------------------|---------------|--|--|--|
| U-0       U-0       RW-0       <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PHR           | PHF                                   | PLR                                                                                                                                        | PLF                              | FLTLEBEN                | CLLEBEN          | —                 |               |  |  |  |
| -         BCH <sup>(1)</sup> BCL <sup>(1)</sup> BPH         BPHL         BPLH         BPHH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | bit 15        |                                       |                                                                                                                                            |                                  |                         |                  |                   | bit           |  |  |  |
| bit 7       t         Legend:         R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         in = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       PHR: PWMxH Rising Edge Trigger Enable bit       1 = Rising edge of PWMxH will trigger Leading-Edge Blanking counter       0 = Leading-Edge Blanking ignores rising edge of PWMxH         bit 14       PHF: PWMxH Falling Edge Trigger Enable bit       1 = Falling edge of PWMxH will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxL       1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores rising edge of PWMxL       1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxL       1 = Falling edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking is applied to selected Fault input       1 = Leading-Edge Blanking is applied to selected Fault input         0 = Leading-Edge Blanking is not applied to selected Current-limit input       0 = Leading-Edge Blanking is applied to selected current-limit input         0 = Leading-Edge Blanking is applied to selected current-limit input       0 = Leading-Edge Blanking is applied to selected current-limit input         0 = Leading-Edge Blanking is applied to selected Current-limit input       0 = Leading-Edge Blanking is applied to sel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | U-0           | U-0                                   | R/W-0                                                                                                                                      | R/W-0                            | R/W-0                   | R/W-0            | R/W-0             | R/W-0         |  |  |  |
| Legend:<br>R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'<br>nn = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown<br>bit 15 PHR: PWMxH Rising Edge Trigger Enable bit<br>1 = Rising edge of PWMxH will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores rising edge of PWMxH<br>1 = Falling edge of PWMxH will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores rising edge of PWMxH<br>1 = Falling edge of PWMxH will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores falling edge of PWMxH<br>1 = Rising edge of PWMxH will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores rising edge of PWMxL<br>1 = Rising edge of PWMxL will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores rising edge of PWMxL<br>1 = Falling edge of PWMxL will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores rising edge of PWMxL<br>1 = Falling edge of PWMxL will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores falling edge of PWMxL<br>1 = Falling edge of PWMxL will trigget Leading-Edge Blanking counter<br>0 = Leading-Edge Blanking ignores falling edge of PWMxL<br>1 = Leading-Edge Blanking is applied to selected Fault input<br>0 = Leading-Edge Blanking is applied to selected Fault input<br>1 = Leading-Edge Blanking is applied to selected Current-limit input<br>1 = Leading-Edge Blanking is not applied to selected current-limit input<br>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is high<br>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low<br>0 = No blanking when selected blanking signal Low Enable bit<br>1 = State blanking (of current-limit and/or Fault input signals) when Selected blanking signal is low<br>0 = No blanking when PWMxH dupt is high<br>0 = No blanking when PWMxH dupt signals) when PWMxH output is high<br>0 = No blanking when PWMxH tow Enable bit<br>1 = State blanking (of current-limit and/ | _             | _                                     | BCH <sup>(1)</sup>                                                                                                                         | BCL <sup>(1)</sup>               | BPHH                    | BPHL             | BPLH              | BPLL          |  |  |  |
| R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         in = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       PHR: PWMxH Rising Edge Trigger Enable bit       1 = Rising edge of PWMxH will trigger Leading-Edge Blanking counter       0 = Leading-Edge Blanking ignores rising edge of PWMxH         bit 14       PHF: PWMxH Falling Edge Trigger Enable bit       1 = Falling edge of PWMxH will trigger Leading-Edge Blanking counter       0 = Leading-Edge Blanking ignores falling edge of PWMxH         bit 13       PLR: PWMxL Rising Edge Trigger Enable bit       1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter       0 = Leading-Edge Blanking ignores rising edge of PWMxL         bit 13       PLR: PWMxL Falling Edge Trigger Enable bit       1 = Falling edge of PWMxL will trigger Leading-Edge Blanking counter       0 = Leading-Edge Blanking is not applied to selected Fault input         bit 11       FLTLEBEN: Fault Input Leading-Edge Blanking Enable bit       1 = Leading-Edge Blanking is not applied to selected current-limit input         bit 5       BCH: Blanking is not applied to selected current-limit input       0 = Leading-Edge Blanking is not applied to selected current-limit input         bit 9-6       Unimplemented: Read as '0'       1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is high         bit 4       BCL: Blanking in Selected Blanking signal is high       1 = State blanking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | bit 7         |                                       |                                                                                                                                            |                                  |                         |                  |                   | bit           |  |  |  |
| n = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       PHR: PWMxH Rising Edge Trigger Enable bit       1 = Rising edge of PWMxH will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores rising edge of PWMxH       11 = Falling edge of PWMxH will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxH       11 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxL       1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores fising edge of PWMxL       0 = Leading-Edge Blanking ignores falling edge of PWMxL         bit 12       PLF: PWMxL Falling Edge Trigger Enable bit       1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxL       0 = Leading-Edge Blanking ignores falling edge of PWMxL         bit 11       FLTLEBEN: Fault Input Leading-Edge Blanking Enable bit       1 = Leading-Edge Blanking is not applied to selected Fault input         0 = Leading-Edge Blanking is not applied to selected Fault input       0 = Leading-Edge Blanking is not applied to selected current-limit input         0 = Leading-Edge Blanking is not applied to selected current-limit input       0 = Leading-Edge Blanking signal Figh Enable bit         1 = State blanking in Selected Blanking Singal High Enable bit <sup>(1)</sup> 1 = State blanking in Sel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Legend:       |                                       |                                                                                                                                            |                                  |                         |                  |                   |               |  |  |  |
| <ul> <li>PHR: PWMxH Rising Edge Trigger Enable bit         <ol> <li>Rising edge of PWMxH will trigger Leading-Edge Blanking counter</li></ol></li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R = Readabl   | e bit                                 | W = Writable                                                                                                                               | bit                              | U = Unimpler            | mented bit, read | as '0'            |               |  |  |  |
| <ul> <li>1 = Rising edge of PWMxH will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores rising edge of PWMxH</li> <li>PHF: PWMxH Falling Edge Trigger Enable bit</li> <li>1 = Falling edge of PWMxH will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores falling edge of PWMxH</li> <li>PLR: PVMxL Rising Edge Trigger Enable bit</li> <li>1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores rising edge of PWMxL</li> <li>PLF: PWMxL Falling Edge Trigger Enable bit</li> <li>1 = Falling edge of PWMxL will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores rising edge of PWMxL</li> <li>Det Leading-Edge Blanking ignores ralling edge of PWMxL</li> <li>D = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking Signal High Enable bit</li> <li>1 = Leading-Edge Blanking Signal Liph Enable bit<sup>(1)</sup></li> <li>1 = State blanking (or current-limit and/or Fault input signals) when selected blanking signal is high</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking when PWMxH output is high</li> <li>0 = No blanking when PWMxH output is high</li> <li>0 = No blanking when PWMxH output is high</li> <li>0 = No b</li></ul>                                                                                                                                                                | -n = Value at | POR                                   | '1' = Bit is set                                                                                                                           | :                                | '0' = Bit is cle        | ared             | x = Bit is unkr   | nown          |  |  |  |
| <ul> <li>1 = Falling edge of PWMxH will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores falling edge of PWMxH</li> <li>bit 13 PLR: PWMxL Rising Edge Trigger Enable bit</li> <li>1 = Rising edge of PWMxL. will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores rising edge of PWMxL</li> <li>bit 12 PLF: PWMxL Falling Edge Trigger Enable bit</li> <li>1 = Falling edge of PWMxL. will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores falling edge of PWMxL</li> <li>bit 12 FLTLEBEN: Fault Input Leading-Edge Blanking Counter</li> <li>0 = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when PWMxH output is nigh</li> <li>0 = No bla</li></ul>                                                                                                                                                                 | bit 15        | 1 = Rising ed                         | ge of PWMxH                                                                                                                                | will trigger Le                  | ading-Edge Bla          |                  |                   |               |  |  |  |
| <ul> <li>1 = Rising edge of PWMxL will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores rising edge of PWMxL</li> <li>pLF: PWMxL Falling Edge Trigger Enable bit</li> <li>1 = Falling edge of PWMxL will trigger Leading-Edge Blanking counter</li> <li>0 = Leading-Edge Blanking ignores falling edge of PWMxL</li> <li>bit 11</li> <li>FLTLEBEN: Fault Input Leading-Edge Blanking Enable bit</li> <li>1 = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = No blanking when selected Blanking Signal Low Enable bit<sup>(1)</sup></li> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when PWMxH dutput is high</li> <li>0 = No blanking when PWMxH Low Enable bit</li> <li>1 = State blanking (of</li></ul>                                                                                                                                                         | bit 14        | 1 = Falling ed                        | lge of PWMxH                                                                                                                               | will trigger Le                  | eading-Edge Bla         | 0                |                   |               |  |  |  |
| bit 12       PLF: PWMxL Falling Edge Trigger Enable bit         1 = Falling edge of PWMxL will trigger Leading-Edge Blanking counter         0 = Leading-Edge Blanking ignores falling edge of PWMxL         bit 11       FLTLEBEN: Fault Input Leading-Edge Blanking Enable bit         1 = Leading-Edge Blanking is not applied to selected Fault input         0 = Leading-Edge Blanking is not applied to selected Fault input         0 = Leading-Edge Blanking is applied to selected Fault input         0 = Leading-Edge Blanking is applied to selected current-limit input         0 = Leading-Edge Blanking is not applied to selected current-limit input         0 = Leading-Edge Blanking is not applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = Leading-Edge Blanking is ont applied to selected current-limit input         0 = No blanking when selected Blanking signal Low Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low         0 = No blanking when P                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | bit 13        | 1 = Rising ed                         | ge of PWMxL                                                                                                                                | will trigger Le                  | ading-Edge Bla          |                  |                   |               |  |  |  |
| <ul> <li>1 = Leading-Edge Blanking is applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected Fault input</li> <li>0 = Leading-Edge Blanking is not applied to selected Fault input</li> <li>1 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxL output is low</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxL output is low</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is high</li> <li>0 = No blanking in PWMxL Low Enable bit</li></ul>                                                                                                                                                                 | bit 12        | 1 = Falling ed                        | lge of PWMxL                                                                                                                               | will trigger Le                  | ading-Edge Bla          |                  |                   |               |  |  |  |
| <ul> <li>1 = Leading-Edge Blanking is applied to selected current-limit input</li> <li>0 = Leading-Edge Blanking is not applied to selected current-limit input</li> <li>bit 9-6</li> <li>Unimplemented: Read as '0'</li> <li>bit 5</li> <li>BCH: Blanking in Selected Blanking Signal High Enable bit<sup>(1)</sup></li> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is hig</li> <li>0 = No blanking when selected blanking Signal Low Enable bit<sup>(1)</sup></li> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is hig</li> <li>bit 4</li> <li>BCL: Blanking in Selected Blanking Signal Low Enable bit<sup>(1)</sup></li> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>bit 1</li> <li>BPLH: Blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is low</li> <li>0 = No blanking when PWMxL output is low</li> <li>bit 1</li> <li>BPLH: Blanking in PWMxL Ligh Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is high</li> <li>0 = No blanking in PWMxL Low Enable bit</li> <li>1 = State blanking in PWMxL Low Enable bit</li> <li>1 = State blanking in PWMxL output is high</li> </ul>                                                                                                                                                                                                 | bit 11        | 1 = Leading-E                         | Edge Blanking                                                                                                                              | is applied to                    | selected Fault in       | nput             |                   |               |  |  |  |
| bit 5       BCH: Blanking in Selected Blanking Signal High Enable bit <sup>(1)</sup> 1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is high         bit 4       BCL: Blanking in Selected Blanking Signal Low Enable bit <sup>(1)</sup> 1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low         bit 4       BCL: Blanking in Selected Blanking Signal Low Enable bit <sup>(1)</sup> 1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low         bit 3       BPHH: Blanking in PWMxH High Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is high         0 = No blanking when PWMxH output is high         bit 2       BPHL: Blanking in PWMxH Low Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low         0 = No blanking when PWMxH output is low         bit 1       State blanking in PWMxH Low Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low         0 = No blanking when PWMxL output is low         bit 1       BPLH: Blanking in PWMxL High Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high         0 = No blanking when PWMxL output is high         bit 0       BPLL: Blanking in PWMxL Low Enable bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | bit 10        | 1 = Leading-E                         | Edge Blanking                                                                                                                              | is applied to                    | selected current        | t-limit input    |                   |               |  |  |  |
| <ul> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is hig</li> <li>0 = No blanking when selected blanking signal Low Enable bit<sup>(1)</sup></li> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>0 = No blanking in PWMxH High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking when PWMxH output is high</li> <li>0 = No blanking in PWMxH High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>0 = No blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>bit 1 BPLH: Blanking in PWMxL High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is low</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | bit 9-6       | Unimplemen                            | ted: Read as '                                                                                                                             | 0'                               |                         |                  |                   |               |  |  |  |
| <ul> <li>1 = State blanking (of current-limit and/or Fault input signals) when selected blanking signal is low</li> <li>0 = No blanking when selected blanking signal is low</li> <li>BPHH: Blanking in PWMxH High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking when PWMxH output is high</li> <li>bit 2</li> <li>BPHL: Blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>bit 1</li> <li>BPLH: Blanking in PWMxL High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>bit 1</li> <li>BPLH: Blanking in PWMxL High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>bit 0</li> <li>BPLL: Blanking in PWMxL Low Enable bit</li> <li>1 = State blanking when PWMxL output is high</li> <li>bit 0</li> <li>BPLL: Blanking in PWMxL Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit 5         | 1 = State blar                        | nking (of currer                                                                                                                           | nt-limit and/or                  | Fault input sigr        |                  | cted blanking s   | ignal is high |  |  |  |
| <ul> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is high</li> <li>0 = No blanking when PWMxH output is high</li> <li>bit 2</li> <li>BPHL: Blanking in PWMxH Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low</li> <li>0 = No blanking when PWMxH output is low</li> <li>bit 1</li> <li>BPLH: Blanking in PWMxL High Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>bit 1</li> <li>BPLH: Blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> <li>0 = No blanking when PWMxL output is high</li> <li>bit 0</li> <li>BPLL: Blanking in PWMxL Low Enable bit</li> <li>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | bit 4         | 1 = State blar                        | nking (of currer                                                                                                                           | nt-limit and/or                  | Fault input sigr        |                  | cted blanking s   | ignal is low  |  |  |  |
| 1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low         0 = No blanking when PWMxH output is low         bit 1       BPLH: Blanking in PWMxL High Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high         0 = No blanking when PWMxL output is high         0 = No blanking when PWMxL output is high         bit 0       BPLL: Blanking in PWMxL Low Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | bit 3         | 1 = State blar                        | nking (of currer                                                                                                                           | nt-limit and/or                  | Fault input sigr        | nals) when PWN   | /IxH output is h  | igh           |  |  |  |
| bit 1       BPLH: Blanking in PWMxL High Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is high         0 = No blanking when PWMxL output is high         bit 0       BPLL: Blanking in PWMxL Low Enable bit         1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit 2         | 1 = State blar                        | <b>BPHL:</b> Blanking in PWMxH Low Enable bit<br>1 = State blanking (of current-limit and/or Fault input signals) when PWMxH output is low |                                  |                         |                  |                   |               |  |  |  |
| bit 0 <b>BPLL:</b> Blanking in PWMxL Low Enable bit<br>1 = State blanking (of current-limit and/or Fault input signals) when PWMxL output is low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | bit 1         | <b>BPLH:</b> Blanki<br>1 = State blar | ing in PWMxL<br>hking (of currer                                                                                                           | High Enable I<br>nt-limit and/or | bit<br>Fault input sigr | nals) when PWN   | /IxL output is hi | gh            |  |  |  |
| $\sim$ i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | bit 0         | <b>BPLL:</b> Blanki<br>1 = State blar | ng in PWMxL I<br>hking (of currer                                                                                                          | Low Enable b<br>nt-limit and/or  | it<br>Fault input sigr  | nals) when PWN   | /IxL output is lo | w             |  |  |  |

### REGISTER 16-16: LEBCONX: PWMx LEADING-EDGE BLANKING CONTROL REGISTER

Note 1: The blanking signal is selected via the BLANKSELx bits in the AUXCONx register.

### 17.0 QUADRATURE ENCODER INTERFACE (QEI) MODULE (dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X DEVICES ONLY)

- Note 1: This data sheet summarizes the features of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X families of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Quadrature Encoder Interface (QEI)" (DS70601) in the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip web site (www.microchip.com).
  - 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information.

This chapter describes the Quadrature Encoder Interface (QEI) module and associated operational modes. The QEI module provides the interface to incremental encoders for obtaining mechanical position data.

The operational features of the QEI module include:

- 32-Bit Position Counter
- 32-Bit Index Pulse Counter
- 32-Bit Interval Timer
- 16-Bit Velocity Counter
- 32-Bit Position Initialization/Capture/Compare High register
- 32-Bit Position Compare Low register
- x4 Quadrature Count mode
- External Up/Down Count mode
- External Gated Count mode
- External Gated Timer mode
- Internal Timer mode

Figure 17-1 illustrates the QEI block diagram.

| R/W-0         | R/W-0                                                                                                                                                              | R/W-0                                                                     | R/W-0            | R/W-0             | R/W-0            | R/W-0           | R/W-0 |  |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|------------------|-------------------|------------------|-----------------|-------|--|--|--|--|
| QCAPEN        | FLTREN                                                                                                                                                             | QFDIV2                                                                    | QFDIV1           | QFDIV0            | OUTFNC1          | OUTFNC0         | SWPAB |  |  |  |  |
| bit 15        | ·                                                                                                                                                                  | ·                                                                         |                  |                   |                  |                 | bit 8 |  |  |  |  |
| R/W-0         | R/W-0                                                                                                                                                              | R/W-0                                                                     | R/W-0            | R-x               | R-x              | R-x             | R-x   |  |  |  |  |
| HOMPOL        | IDXPOL                                                                                                                                                             | QEBPOL                                                                    | QEAPOL           | HOME              | INDEX            | QEB             | QEA   |  |  |  |  |
| bit 7         |                                                                                                                                                                    |                                                                           |                  | TIOME             | INDEX            | QLD             | bit ( |  |  |  |  |
| Legend:       |                                                                                                                                                                    |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| R = Readable  | e bit                                                                                                                                                              | W = Writable                                                              | bit              | U = Unimplen      | nented bit, read | d as '0'        |       |  |  |  |  |
| -n = Value at |                                                                                                                                                                    | '1' = Bit is set                                                          |                  | '0' = Bit is cle  |                  | x = Bit is unkn | own   |  |  |  |  |
|               |                                                                                                                                                                    |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 15        | QCAPEN: Q                                                                                                                                                          | EI Position Cou                                                           | nter Input Cap   | ture Enable bit   |                  |                 |       |  |  |  |  |
|               |                                                                                                                                                                    | tch event trigge                                                          |                  |                   |                  |                 |       |  |  |  |  |
|               |                                                                                                                                                                    | tch event does                                                            |                  | -                 |                  |                 |       |  |  |  |  |
| bit 14        |                                                                                                                                                                    | Ax/QEBx/INDX                                                              | •                | tal Filter Enable | e dit            |                 |       |  |  |  |  |
|               |                                                                                                                                                                    | digital filter is e<br>digital filter is d                                |                  | sed)              |                  |                 |       |  |  |  |  |
| bit 13-11     | <ul> <li>Input pin digital filter is disabled (bypassed)</li> <li>QFDIV&lt;2:0&gt;: QEAx/QEBx/INDXx/HOMEx Digital Input Filter Clock Divide Select bits</li> </ul> |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | QFDIV<2:0>: QEAX/QEBX/INDXX/HOMEX Digital Input Filter Clock Divide Select bits<br>111 = 1:128 clock divide                                                        |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 110 = 1.64 clock divide                                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 101 = 1:32 clock divide                                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 100 = 1:16 clock divide                                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 011 = 1:8  clock divide                                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 010 = 1:4 clock divide<br>001 = 1:2 clock divide                                                                                                                   |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 000 = 1:1 clo                                                                                                                                                      |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 10-9      | OUTFNC<1:0>: QEI Module Output Function Mode Select bits                                                                                                           |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               |                                                                                                                                                                    | 11 = The CTNCMPx pin goes high when QEI1LEC $\geq$ POS1CNT $\geq$ QEI1GEC |                  |                   |                  |                 |       |  |  |  |  |
|               | 10 = The CTNCMPx pin goes high when POS1CNT ≤ QEI1LEC                                                                                                              |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 01 = The CTNCMPx pin goes high when POS1CNT ≥ QEI1GEC<br>00 = Output is disabled                                                                                   |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| L:1 0         | •                                                                                                                                                                  |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 8         | <b>SWPAB:</b> Swap QEA and QEB Inputs bit<br>1 = QEAx and QEBx are swapped prior to quadrature decoder logic                                                       |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               |                                                                                                                                                                    | d QEBx are swi<br>d QEBx are not                                          |                  | quadrature dec    | coder logic      |                 |       |  |  |  |  |
| bit 7         | HOMPOL: HOMEx Input Polarity Select bit                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 1 = Input is inverted                                                                                                                                              |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 6         | 0 = Input is not inverted                                                                                                                                          |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | IDXPOL: INDXx Input Polarity Select bit                                                                                                                            |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | <ul> <li>1 = Input is inverted</li> <li>0 = Input is not inverted</li> </ul>                                                                                       |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 5         | QEBPOL: QEBx Input Polarity Select bit                                                                                                                             |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 1 = Input is inverted                                                                                                                                              |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 0 = Input is r                                                                                                                                                     |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| bit 4         | QEAPOL: Q                                                                                                                                                          | EAx Input Polar                                                           | ity Select bit   |                   |                  |                 |       |  |  |  |  |
|               | 1 = Input is i                                                                                                                                                     |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
|               | 0 = Input is r                                                                                                                                                     | not inverted                                                              |                  |                   |                  |                 |       |  |  |  |  |
| bit 3         | HOME: Statu                                                                                                                                                        |                                                                           |                  |                   |                  |                 |       |  |  |  |  |
| DIL 3         | <b>HOME</b> . Statu                                                                                                                                                |                                                                           | out Pin Alter Po | olarity Control   |                  |                 |       |  |  |  |  |
| DIL 3         | 1 = Pin is at<br>0 = Pin is at                                                                                                                                     | logic '1'                                                                 | out Pin Aiter Po | bianty Control    |                  |                 |       |  |  |  |  |

### REGISTER 17-2: QEI1IOC: QEI1 I/O CONTROL REGISTER

### dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| R/W-0                                                                | R/W-0        | R/W-0            | R/W-0 | R/W-0             | R/W-0 | R/W-0           | R/W-0 |  |  |
|----------------------------------------------------------------------|--------------|------------------|-------|-------------------|-------|-----------------|-------|--|--|
|                                                                      |              |                  | INTHL | D<31:24>          |       |                 |       |  |  |
| bit 15                                                               | bit 15 bit 8 |                  |       |                   |       |                 |       |  |  |
|                                                                      |              |                  |       |                   |       |                 |       |  |  |
| R/W-0                                                                | R/W-0        | R/W-0            | R/W-0 | R/W-0             | R/W-0 | R/W-0           | R/W-0 |  |  |
|                                                                      |              |                  | INTHL | D<23:16>          |       |                 |       |  |  |
| bit 7                                                                |              |                  |       |                   |       |                 | bit 0 |  |  |
|                                                                      |              |                  |       |                   |       |                 |       |  |  |
| Legend:                                                              |              |                  |       |                   |       |                 |       |  |  |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' |              |                  |       |                   |       |                 |       |  |  |
| -n = Value at P                                                      | OR           | '1' = Bit is set |       | '0' = Bit is clea | ared  | x = Bit is unkr | nown  |  |  |

bit 15-0 INTHLD<31:16>: Hold Register for Reading and Writing INT1TMRH bits

### REGISTER 17-20: INT1HLDL: INTERVAL 1 TIMER HOLD LOW WORD REGISTER

| R/W-0                                                                      | R/W-0 | R/W-0 | R/W-0 | R/W-0    | R/W-0 | R/W-0 | R/W-0 |
|----------------------------------------------------------------------------|-------|-------|-------|----------|-------|-------|-------|
|                                                                            |       |       | INTHL | .D<15:8> |       |       |       |
| bit 15                                                                     |       |       |       |          |       |       | bit 8 |
|                                                                            |       |       |       |          |       |       |       |
| R/W-0                                                                      | R/W-0 | R/W-0 | R/W-0 | R/W-0    | R/W-0 | R/W-0 | R/W-0 |
|                                                                            |       |       | INTH  | _D<7:0>  |       |       |       |
| bit 7                                                                      |       |       |       |          |       |       | bit 0 |
|                                                                            |       |       |       |          |       |       |       |
| Legend:                                                                    |       |       |       |          |       |       |       |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'       |       |       |       |          |       |       |       |
| -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown |       |       |       |          |       | nown  |       |
|                                                                            |       |       |       |          |       |       |       |

bit 15-0 INTHLD<15:0>: Hold Register for Reading and Writing INT1TMRL bits

| U-0                 | U-0                          | U-0              | R/W-0                                 | R/W-0                | R/W-0                | R/W-0                | R/W-0                |
|---------------------|------------------------------|------------------|---------------------------------------|----------------------|----------------------|----------------------|----------------------|
|                     | —                            | _                | DISSCK                                | DISSDO               | MODE16               | SMP                  | CKE <sup>(1)</sup>   |
| bit 15              |                              | •                |                                       | •                    | •                    | •                    | bit                  |
| R/W-0               | R/W-0                        | R/W-0            | R/W-0                                 | R/W-0                | R/W-0                | R/W-0                | R/W-0                |
| SSEN <sup>(2)</sup> | CKP                          | MSTEN            | SPRE2 <sup>(3)</sup>                  | SPRE1 <sup>(3)</sup> | SPRE0 <sup>(3)</sup> | PPRE1 <sup>(3)</sup> | PPRE0 <sup>(3)</sup> |
| bit 7               | CKF                          | WIGTEN           | SFREZ 7                               | SFREI?               | SFREU 7              | FFREN                | bit                  |
|                     |                              |                  |                                       |                      |                      |                      |                      |
| Legend:             |                              |                  |                                       |                      |                      |                      |                      |
| R = Readabl         | le bit                       | W = Writable     | bit                                   | U = Unimpler         | mented bit, read     | d as '0'             |                      |
| -n = Value at       | t POR                        | '1' = Bit is se  | t                                     | '0' = Bit is cle     | ared                 | x = Bit is unkr      | nown                 |
|                     |                              |                  |                                       |                      |                      |                      |                      |
| bit 15-13           | Unimplemen                   | ted: Read as     | 0'                                    |                      |                      |                      |                      |
| bit 12              |                              |                  | bit (SPIx Mas                         | -                    | ()                   |                      |                      |
|                     |                              | PIx clock is di  | sabled, pin fun                       | ctions as I/O        |                      |                      |                      |
| oit 11              |                              | able SDOx Pir    |                                       |                      |                      |                      |                      |
|                     |                              |                  | / the module; p                       | oin functions as     | s I/O                |                      |                      |
|                     |                              | is controlled b  |                                       |                      |                      |                      |                      |
| bit 10              | MODE16: Wo                   | ord/Byte Comn    | nunication Sele                       | ect bit              |                      |                      |                      |
|                     |                              | ication is word  | · · /                                 |                      |                      |                      |                      |
|                     |                              | ication is byte- | . ,                                   |                      |                      |                      |                      |
| bit 9               |                              | ata Input Sam    | ole Phase bit                         |                      |                      |                      |                      |
|                     | Master mode                  | -                | end of data o                         | utout time           |                      |                      |                      |
|                     |                              |                  | middle of data                        |                      |                      |                      |                      |
|                     | Slave mode:                  |                  |                                       |                      |                      |                      |                      |
|                     |                              |                  | SPIx is used i                        | n Slave mode.        |                      |                      |                      |
| bit 8               |                              | lock Edge Sele   |                                       |                      |                      |                      |                      |
|                     |                              |                  |                                       |                      |                      | lle clock state (r   |                      |
| bit 7               |                              |                  | bit (Slave mo                         |                      |                      | ve clock state (i    |                      |
|                     |                              | sused for Slav   |                                       |                      |                      |                      |                      |
|                     |                              |                  |                                       | is controlled b      | by port function     |                      |                      |
| bit 6               | CKP: Clock F                 | Polarity Select  | bit                                   |                      |                      |                      |                      |
|                     |                              |                  | nigh level; activ<br>ow level; active |                      |                      |                      |                      |
| bit 5               | MSTEN: Mas                   | ter Mode Enat    | ole bit                               |                      |                      |                      |                      |
|                     | 1 = Master m<br>0 = Slave mo |                  |                                       |                      |                      |                      |                      |
| Note 1: T           | he CKE bit is not            | used in Frame    | d SPI modes. I                        | Program this bi      | it to '0' for Fram   | ed SPI modes (       | FRMEN = 1            |
|                     | his bit must be cl           |                  |                                       |                      |                      |                      |                      |
| <b>0</b>            |                              |                  |                                       |                      |                      |                      |                      |

### REGISTER 18-2: SPIXCON1: SPIX CONTROL REGISTER 1

- **3:** Do not set both primary and secondary prescalers to the value of 1:1.

| -             |           |                 |            |                                    |                 |                                         |          |  |
|---------------|-----------|-----------------|------------|------------------------------------|-----------------|-----------------------------------------|----------|--|
| R-0, HSC      | R-0, HSC  | U-0             | U-0        | U-0                                | R/C-0, HS       | R-0, HSC                                | R-0, HSC |  |
| ACKSTAT       | TRSTAT    | —               | —          | —                                  | BCL             | GCSTAT                                  | ADD10    |  |
| bit 15        |           |                 |            |                                    |                 |                                         | bit 8    |  |
|               |           |                 |            |                                    |                 |                                         |          |  |
| R/C-0, HS     | R/C-0, HS | R-0, HSC        | R/C-0, HSC | R/C-0, HSC                         | R-0, HSC        | R-0, HSC                                | R-0, HSC |  |
| IWCOL         | I2COV     | D_A             | Р          | S                                  | R_W             | RBF                                     | TBF      |  |
| bit 7         |           |                 |            |                                    |                 |                                         | bit 0    |  |
|               |           |                 |            |                                    |                 |                                         |          |  |
| Legend:       |           | C = Clearab     | le bit     | HS = Hardwa                        | re Settable bit | t HSC = Hardware Settable/Clearable bit |          |  |
| R = Readab    | le bit    | W = Writable    | e bit      | U = Unimplemented bit, read as '0' |                 |                                         |          |  |
| -n = Value at | t POR     | '1' = Bit is se | et         | '0' = Bit is clea                  | ared            | x = Bit is unknown                      |          |  |

### REGISTER 19-2: I2CxSTAT: I2Cx STATUS REGISTER

| hit 15    | ACKSTAT: Acknowledge Status bit (when operating as I <sup>2</sup> C™ master, applicable to master transmit operation)                          |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 15    | 1 = NACK received from slave                                                                                                                   |
|           | 0 = ACK received from slave                                                                                                                    |
|           | Hardware is set or clear at the end of slave Acknowledge.                                                                                      |
| bit 14    | <b>TRSTAT:</b> Transmit Status bit (when operating as I <sup>2</sup> C master, applicable to master transmit operation)                        |
|           | 1 = Master transmit is in progress (8 bits + ACK)                                                                                              |
|           | 0 = Master transmit is not in progress                                                                                                         |
|           | Hardware is set at the beginning of master transmission. Hardware is clear at the end of slave Acknowledge.                                    |
| bit 13-11 | Unimplemented: Read as '0'                                                                                                                     |
| bit 10    | BCL: Master Bus Collision Detect bit                                                                                                           |
|           | 1 = A bus collision has been detected during a master operation                                                                                |
|           | 0 = No bus collision detected<br>Hardware is set at detection of a bus collision.                                                              |
| bit 9     | GCSTAT: General Call Status bit                                                                                                                |
| DIL 9     | 1 = General call address was received                                                                                                          |
|           | 0 = General call address was not received                                                                                                      |
|           | Hardware is set when address matches general call address. Hardware is clear at Stop detection.                                                |
| bit 8     | ADD10: 10-Bit Address Status bit                                                                                                               |
|           | 1 = 10-bit address was matched                                                                                                                 |
|           | 0 = 10-bit address was not matched                                                                                                             |
|           | Hardware is set at the match of the 2nd byte of the matched 10-bit address. Hardware is clear at Stop detection.                               |
| bit 7     | IWCOL: I2Cx Write Collision Detect bit                                                                                                         |
|           | 1 = An attempt to write to the I2CxTRN register failed because the I <sup>2</sup> C module is busy                                             |
|           | 1 = An attempt to write to the 120x million register laned because the 1-0 module is busy<br>0 = No collision                                  |
|           | Hardware is set at the occurrence of a write to I2CxTRN while busy (cleared by software).                                                      |
| bit 6     | I2COV: I2Cx Receive Overflow Flag bit                                                                                                          |
|           | 1 = A byte was received while the I2CxRCV register was still holding the previous byte                                                         |
|           | 0 = No overflow                                                                                                                                |
|           | Hardware is set at an attempt to transfer I2CxRSR to I2CxRCV (cleared by software).                                                            |
| bit 5     | <b>D_A:</b> Data/Address bit (when operating as I <sup>2</sup> C slave)                                                                        |
|           | <ol> <li>I = Indicates that the last byte received was data</li> <li>I = Indicates that the last byte received was a device address</li> </ol> |
|           | Hardware is clear at a device address match. Hardware is set by reception of a slave byte.                                                     |
| bit 4     | P: Stop bit                                                                                                                                    |
|           | 1 = Indicates that a Stop bit has been detected last                                                                                           |
|           | 0 = Stop bit was not detected last                                                                                                             |
|           | Hardware is set or clear when a Start, Repeated Start or Stop is detected.                                                                     |
|           |                                                                                                                                                |

### REGISTER 23-5: AD1CHS123: ADC1 INPUT CHANNEL 1, 2, 3 SELECT REGISTER (CONTINUED)

bit 0

**CH123SA:** Channel 1, 2, 3 Positive Input Select for Sample MUXA bit In 12-bit mode (AD21B = 1), CH123SA is Unimplemented and is Read as '0':

| Value          | ADC Channel |         |         |  |  |  |  |
|----------------|-------------|---------|---------|--|--|--|--|
| value          | CH1 CH2 CH3 |         |         |  |  |  |  |
| 1 <b>(2)</b>   | OA1/AN3     | OA2/AN0 | OA3/AN6 |  |  |  |  |
| 0 <b>(1,2)</b> | OA2/AN0     | AN1     | AN2     |  |  |  |  |

**Note 1:** AN0 through AN7 are repurposed when comparator and op amp functionality is enabled. See Figure 23-1 to determine how enabling a particular op amp or comparator affects selection choices for Channels 1, 2 and 3.

2: The OAx input is used if the corresponding op amp is selected (OPMODE (CMxCON<10>) = 1); otherwise, the ANx input is used.

## **30.0 ELECTRICAL CHARACTERISTICS**

This section provides an overview of dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/ MC20X electrical characteristics. Additional information will be provided in future revisions of this document as it becomes available.

Absolute maximum ratings for the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X family are listed below. Exposure to these maximum rating conditions for extended periods may affect device reliability. Functional operation of the device at these or any other conditions above the parameters indicated in the operation listings of this specification is not implied.

### Absolute Maximum Ratings<sup>(1)</sup>

| Ambient temperature under bias                                                    | 40°C to +125°C       |
|-----------------------------------------------------------------------------------|----------------------|
| Storage temperature                                                               | 65°C to +150°C       |
| Voltage on VDD with respect to Vss                                                | -0.3V to +4.0V       |
| Voltage on any pin that is not 5V tolerant, with respect to Vss <sup>(3)</sup>    | 0.3V to (VDD + 0.3V) |
| Voltage on any 5V tolerant pin with respect to Vss when $VDD \ge 3.0V^{(3)}$      | 0.3V to +5.5V        |
| Voltage on any 5V tolerant pin with respect to Vss when VDD < 3.0V <sup>(3)</sup> | -0.3V to +3.6V       |
| Maximum current out of Vss pin                                                    |                      |
| Maximum current into Vod pin <sup>(2)</sup>                                       |                      |
| Maximum current sunk/sourced by any 4x I/O pin                                    | 15 mA                |
| Maximum current sunk/sourced by any 8x I/O pin                                    | 25 mA                |
| Maximum current sunk by all ports <sup>(2,4)</sup>                                | 200 mA               |

- **Note 1:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at those or any other conditions above those indicated in the operation listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.
  - 2: Maximum allowable current is a function of device maximum power dissipation (see Table 30-2).
  - 3: See the "Pin Diagrams" section for the 5V tolerant pins.
  - 4: Exceptions are: dsPIC33EPXXXGP502, dsPIC33EPXXXMC202/502 and PIC24EPXXXGP/MC202 devices, which have a maximum sink/source capability of 130 mA.

| DC CHA       | RACTER    | ISTICS                                                              | $\begin{array}{l} \mbox{Standard Operating Conditions (see Note 1): 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array}$ |      |      |       |                 |  |
|--------------|-----------|---------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|-----------------|--|
| Param<br>No. | Symbol    | Characteristic                                                      | Min.                                                                                                                                                                                                                                                                                                 | Тур. | Max. | Units | Conditions      |  |
| Operati      | ng Voltag | e                                                                   |                                                                                                                                                                                                                                                                                                      |      |      |       |                 |  |
| DC10         | Vdd       | Supply Voltage                                                      | 3.0                                                                                                                                                                                                                                                                                                  |      | 3.6  | V     |                 |  |
| DC16         | VPOR      | VDD Start Voltage<br>to Ensure Internal<br>Power-on Reset Signal    | -                                                                                                                                                                                                                                                                                                    | _    | Vss  | V     |                 |  |
| DC17         | Svdd      | <b>VDD Rise Rate</b><br>to Ensure Internal<br>Power-on Reset Signal | 0.03                                                                                                                                                                                                                                                                                                 | _    | —    | V/ms  | 0V-1V in 100 ms |  |

### TABLE 30-4: DC TEMPERATURE AND VOLTAGE SPECIFICATIONS

**Note 1:** Device is functional at VBORMIN < VDD < VDDMIN. Analog modules (ADC, op amp/comparator and comparator voltage reference) may have degraded performance. Device functionality is tested but not characterized. Refer to Parameter BO10 in Table 30-13 for the minimum and maximum BOR values.

### TABLE 30-5: FILTER CAPACITOR (CEFC) SPECIFICATIONS

|              | Standard Operating Conditions (unless otherwise stated):Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for Extended |  |  |  |  |  |  |  |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Param<br>No. | Symbol Characteristics Min Typ Max Units Comments                                                                                                                                        |  |  |  |  |  |  |  |  |
|              | CEFC External Filter Capacitor 4.7 10 — μF Capacitor must have a low series resistance (< 1 Ohm)                                                                                         |  |  |  |  |  |  |  |  |

**Note 1:** Typical VCAP voltage = 1.8 volts when VDD  $\geq$  VDDMIN.

# TABLE 30-46:SPI1 SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 1, SMP = 0)TIMING REQUIREMENTS

| Param. | Symbol                | Characteristic <sup>(1)</sup>                   | Min.         | Тур. <sup>(2)</sup> | Max.                  | Units | Conditions                     |
|--------|-----------------------|-------------------------------------------------|--------------|---------------------|-----------------------|-------|--------------------------------|
| SP70   | FscP                  | Maximum SCK1 Input<br>Frequency                 | _            |                     | Lesser of<br>FP or 11 | MHz   | (Note 3)                       |
| SP72   | TscF                  | SCK1 Input Fall Time                            | _            |                     |                       | ns    | See Parameter DO32<br>(Note 4) |
| SP73   | TscR                  | SCK1 Input Rise Time                            | —            |                     |                       | ns    | See Parameter DO31 (Note 4)    |
| SP30   | TdoF                  | SDO1 Data Output Fall Time                      | —            | _                   |                       | ns    | See Parameter DO32<br>(Note 4) |
| SP31   | TdoR                  | SDO1 Data Output Rise Time                      |              |                     |                       | ns    | See Parameter DO31<br>(Note 4) |
| SP35   | TscH2doV,<br>TscL2doV | SDO1 Data Output Valid after<br>SCK1 Edge       | —            | 6                   | 20                    | ns    |                                |
| SP36   | TdoV2scH,<br>TdoV2scL | SDO1 Data Output Setup to<br>First SCK1 Edge    | 30           | _                   | _                     | ns    |                                |
| SP40   | TdiV2scH,<br>TdiV2scL | Setup Time of SDI1 Data Input to SCK1 Edge      | 30           |                     | —                     | ns    |                                |
| SP41   | TscH2diL,<br>TscL2diL | Hold Time of SDI1 Data Input to SCK1 Edge       | 30           | _                   | _                     | ns    |                                |
| SP50   | TssL2scH,<br>TssL2scL | $\overline{SS1}$ ↓ to SCK1 ↑ or SCK1 ↓<br>Input | 120          | _                   | _                     | ns    |                                |
| SP51   | TssH2doZ              | SS1 ↑ to SDO1 Output<br>High-Impedance          | 10           | _                   | 50                    | ns    | (Note 4)                       |
| SP52   | TscH2ssH,<br>TscL2ssH | SS1 ↑ after SCK1 Edge                           | 1.5 Tcy + 40 | _                   | _                     | ns    | (Note 4)                       |
| SP60   | TssL2doV              | SDO1 Data Output Valid after<br>SS1 Edge        | —            | _                   | 50                    | ns    |                                |

Note 1: These parameters are characterized, but are not tested in manufacturing.

2: Data in "Typical" column is at 3.3V, +25°C unless otherwise stated.

**3:** The minimum clock period for SCK1 is 91 ns. Therefore, the SCK1 clock generated by the master must not violate this specification.

4: Assumes 50 pF load on all SPI1 pins.

| AC CHA       | ARACTER | RISTICS                                                                                                   | $ \begin{array}{l} \mbox{Standard Operating Conditions: 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)}^{(1)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array} $ |         |       |       |                                         |
|--------------|---------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|-------|-----------------------------------------|
| Param<br>No. | Symbol  | Characteristic                                                                                            | Min.                                                                                                                                                                                                                                                                                            | Тур.    | Max.  | Units | Conditions                              |
|              | -       | Cloci                                                                                                     | k Paramet                                                                                                                                                                                                                                                                                       | ters    |       |       |                                         |
| AD50         | TAD     | ADC Clock Period                                                                                          | 117.6                                                                                                                                                                                                                                                                                           | _       | _     | ns    |                                         |
| AD51         | tRC     | ADC Internal RC Oscillator Period <sup>(2)</sup>                                                          |                                                                                                                                                                                                                                                                                                 | 250     | _     | ns    |                                         |
|              |         | Conv                                                                                                      | version R                                                                                                                                                                                                                                                                                       | ate     |       |       |                                         |
| AD55         | tCONV   | Conversion Time                                                                                           | _                                                                                                                                                                                                                                                                                               | 14 Tad  |       | ns    |                                         |
| AD56         | FCNV    | Throughput Rate                                                                                           | _                                                                                                                                                                                                                                                                                               | _       | 500   | ksps  |                                         |
| AD57a        | TSAMP   | Sample Time when Sampling any ANx Input                                                                   | 3 Tad                                                                                                                                                                                                                                                                                           | —       | _     |       |                                         |
| AD57b        | TSAMP   | Sample Time when Sampling the Op<br>Amp Outputs (Configuration A and<br>Configuration B) <sup>(4,5)</sup> | 3 Tad                                                                                                                                                                                                                                                                                           | —       | -     |       |                                         |
|              |         | Timin                                                                                                     | g Parame                                                                                                                                                                                                                                                                                        | ters    |       |       |                                         |
| AD60         | tPCS    | Conversion Start from Sample<br>Trigger <sup>(2,3)</sup>                                                  | 2 Tad                                                                                                                                                                                                                                                                                           | -       | 3 Tad | —     | Auto-convert trigger is<br>not selected |
| AD61         | tPSS    | Sample Start from Setting<br>Sample (SAMP) bit <sup>(2,3)</sup>                                           | 2 Tad                                                                                                                                                                                                                                                                                           | —       | 3 Tad |       |                                         |
| AD62         | tcss    | Conversion Completion to<br>Sample Start (ASAM = 1) <sup>(2,3)</sup>                                      |                                                                                                                                                                                                                                                                                                 | 0.5 Tad | —     |       |                                         |
| AD63         | tdpu    | Time to Stabilize Analog Stage<br>from ADC Off to ADC On <sup>(2,3)</sup>                                 | —                                                                                                                                                                                                                                                                                               | —       | 20    | μS    | (Note 6)                                |

### TABLE 30-60: ADC CONVERSION (12-BIT MODE) TIMING REQUIREMENTS

**Note 1:** Device is functional at VBORMIN < VDD < VDDMIN, but will have degraded performance. Device functionality is tested, but not characterized. Analog modules (ADC, op amp/comparator and comparator voltage reference) may have degraded performance. Refer to Parameter BO10 in Table 30-13 for the minimum and maximum BOR values.

- 2: Parameters are characterized but not tested in manufacturing.
- **3:** Because the sample caps will eventually lose charge, clock rates below 10 kHz may affect linearity performance, especially at elevated temperatures.
- 4: See Figure 25-6 for configuration information.
- 5: See Figure 25-7 for configuration information.
- **6:** The parameter, tDPU, is the time required for the ADC module to stabilize at the appropriate level when the module is turned on (ADON (AD1CON1<15>) = 1). During this time, the ADC result is indeterminate.

NOTES:

### 28-Lead Plastic Shrink Small Outline (SS) – 5.30 mm Body [SSOP]

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



|                          | Units         | MILLIMETERS |          |       |  |
|--------------------------|---------------|-------------|----------|-------|--|
| Dime                     | ension Limits | MIN         | NOM      | MAX   |  |
| Number of Pins           | N             |             | 28       |       |  |
| Pitch                    | е             |             | 0.65 BSC |       |  |
| Overall Height           | A             | -           | -        | 2.00  |  |
| Molded Package Thickness | A2            | 1.65        | 1.75     | 1.85  |  |
| Standoff                 | A1            | 0.05        | -        | -     |  |
| Overall Width            | E             | 7.40        | 7.80     | 8.20  |  |
| Molded Package Width     | E1            | 5.00        | 5.30     | 5.60  |  |
| Overall Length           | D             | 9.90        | 10.20    | 10.50 |  |
| Foot Length              | L             | 0.55        | 0.75     | 0.95  |  |
| Footprint                | L1            | 1.25 REF    |          |       |  |
| Lead Thickness           | С             | 0.09 – 0.25 |          |       |  |
| Foot Angle               | ф             | 0° 4° 8°    |          |       |  |
| Lead Width               | b             | 0.22 – 0.38 |          |       |  |

#### Notes:

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

2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.20 mm per side.

- 3. Dimensioning and tolerancing per ASME Y14.5M.
  - BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-073B

### Revision H (August 2013)

This revision includes minor typographical and formatting changes throughout the text.

Other major changes are referenced by their respective section in Table A-6.

| Section Name                                                         | Update Description                                                                                                                                      |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cover Section                                                        | <ul> <li>Adds Peripheral Pin Select (PPS) to allow Digital Function Remapping and Change<br/>Notification Interrupts to Input/Output section</li> </ul> |
|                                                                      | Adds heading information to 64-Pin TQFP                                                                                                                 |
| Section 4.0 "Memory                                                  | Corrects Reset values for ANSELE, TRISF, TRISC, ANSELC and TRISA                                                                                        |
| Organization"                                                        | <ul> <li>Corrects address range from 0x2FFF to 0x7FFF</li> </ul>                                                                                        |
|                                                                      | Corrects DSRPAG and DSWPAG (now 3 hex digits)                                                                                                           |
|                                                                      | Changes Call Stack Frame from <15:1> to PC<15:0>                                                                                                        |
|                                                                      | Word length in Figure 4-20 is changed to 50 words for clarity                                                                                           |
| Section 5.0 "Flash Program                                           | Corrects descriptions of NVM registers                                                                                                                  |
| Memory"                                                              |                                                                                                                                                         |
| Section 9.0 "Oscillator                                              | Removes resistor from Figure 9-1                                                                                                                        |
| Configuration"                                                       | Adds Fast RC Oscillator with Divide-by-16 (FRCDIV16) row to Table 9-1                                                                                   |
|                                                                      | Removes incorrect information from ROI bit in Register 9-2                                                                                              |
| Section 14.0 "Input Capture"                                         | <ul> <li>Changes 31 user-selectable Trigger/Sync interrupts to 19 user-selectable Trigger/<br/>Sync interrupts</li> </ul>                               |
|                                                                      | <ul> <li>Corrects ICTSEL&lt;12:10&gt; bits (now ICTSEL&lt;2:0&gt;)</li> </ul>                                                                           |
| Section 17.0 "Quadrature<br>Encoder Interface (QEI)                  | Corrects QCAPEN bit description                                                                                                                         |
| Module                                                               |                                                                                                                                                         |
| (dsPIC33EPXXXMC20X/50X<br>and PIC24EPXXXMC20X                        |                                                                                                                                                         |
| Devices Only)"                                                       |                                                                                                                                                         |
| Section 19.0 "Inter-<br>Integrated Circuit™ (I <sup>2</sup> C™)"     | <ul> <li>Adds note to clarify that 100kbit/sec operation of I<sup>2</sup>C is not possible at high processor<br/>speeds</li> </ul>                      |
| Section 22.0 "Charge Time                                            | Clarifies Figure 22-1 to accurately reflect peripheral behavior                                                                                         |
| Measurement Unit (CTMU)"                                             |                                                                                                                                                         |
| Section 23.0 "10-Bit/12-Bit<br>Analog-to-Digital Converter<br>(ADC)" | Correct Figure 23-1 (changes CH123x to CH123Sx)                                                                                                         |
| Section 24.0 "Peripheral<br>Trigger Generator (PTG)<br>Module"       | <ul> <li>Adds footnote to Register 24-1 (In order to operate with CVRSS=1, at least one of the<br/>comparator modules must be enabled.</li> </ul>       |
| Section 25.0 "Op Amp/<br>Comparator Module"                          | <ul> <li>Adds note to Figure 25-3 (In order to operate with CVRSS=1, at least one of the<br/>comparator modules must be enabled)</li> </ul>             |
|                                                                      | <ul> <li>Adds footnote to Register 25-2 (COE is not available when OPMODE<br/>(CMxCON&lt;10&gt;) = 1)</li> </ul>                                        |
| Section 27.0 "Special<br>Features"                                   | Corrects the bit description for FNOSC<2:0>                                                                                                             |
| Section 30.0 "Electrical                                             | Corrects 512K part power-down currents based on test data                                                                                               |
| Characteristics"                                                     | Corrects WDT timing limits based on LPRC oscillator tolerance                                                                                           |
| Section 31.0 "High-<br>Temperature Electrical<br>Characteristics"    | Adds Table 31-5 (DC Characteristics: Idle Current (IIDLE)                                                                                               |
|                                                                      |                                                                                                                                                         |