



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

| Details                    |                                                                                  |
|----------------------------|----------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                         |
| Core Processor             | dsPIC                                                                            |
| Core Size                  | 16-Bit                                                                           |
| Speed                      | 60 MIPs                                                                          |
| Connectivity               | CANbus, 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              | 21                                                                               |
| Program Memory Size        | 64KB (22K x 24)                                                                  |
| Program Memory Type        | FLASH                                                                            |
| EEPROM Size                | -                                                                                |
| RAM Size                   | 4K x 16                                                                          |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                        |
| Data Converters            | A/D 6x10b/12b                                                                    |
| Oscillator Type            | Internal                                                                         |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                               |
| Mounting Type              | Surface Mount                                                                    |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                                   |
| Supplier Device Package    | 28-SOIC                                                                          |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic33ep64mc502t-e-so |
|                            |                                                                                  |

Email: info@E-XFL.COM

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





| TABLE        | 4-2:  | CPU CORE REGISTER MAP FOR PIC24EPXXXGP/MC20X DEVICES ONLY |                   |        |        |        |        |       |          |          |        |       |           |          |       |       |       |               |
|--------------|-------|-----------------------------------------------------------|-------------------|--------|--------|--------|--------|-------|----------|----------|--------|-------|-----------|----------|-------|-------|-------|---------------|
| File<br>Name | Addr. | Bit 15                                                    | Bit 14            | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8    | Bit 7    | Bit 6  | Bit 5 | Bit 4     | Bit 3    | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
| W0           | 0000  |                                                           |                   |        |        |        |        |       | W0 (WR   | EG)      |        |       |           |          |       |       |       | xxxx          |
| W1           | 0002  |                                                           |                   |        |        |        |        |       | W1       |          |        |       |           |          |       |       |       | xxxx          |
| W2           | 0004  |                                                           |                   |        |        |        |        |       | W2       |          |        |       |           |          |       |       |       | xxxx          |
| W3           | 0006  |                                                           |                   |        |        |        |        |       | W3       |          |        |       |           |          |       |       |       | xxxx          |
| W4           | 0008  |                                                           |                   |        |        |        |        |       | W4       |          |        |       |           |          |       |       |       | xxxx          |
| W5           | 000A  |                                                           |                   |        |        |        |        |       | W5       |          |        |       |           |          |       |       |       | xxxx          |
| W6           | 000C  |                                                           |                   |        |        |        |        |       | W6       |          |        |       |           |          |       |       |       | xxxx          |
| W7           | 000E  |                                                           |                   |        |        |        |        |       | W7       |          |        |       |           |          |       |       |       | xxxx          |
| W8           | 0010  |                                                           |                   |        |        |        |        |       | W8       |          |        |       |           |          |       |       |       | xxxx          |
| W9           | 0012  |                                                           |                   |        |        |        |        |       | W9       |          |        |       |           |          |       |       |       | xxxx          |
| W10          | 0014  |                                                           |                   |        |        |        |        |       | W10      |          |        |       |           |          |       |       |       | xxxx          |
| W11          | 0016  |                                                           | W11 x             |        |        |        |        |       |          |          | xxxx   |       |           |          |       |       |       |               |
| W12          | 0018  |                                                           |                   |        |        |        |        |       | W12      |          |        |       |           |          |       |       |       | xxxx          |
| W13          | 001A  |                                                           |                   |        |        |        |        |       | W13      |          |        |       |           |          |       |       |       | xxxx          |
| W14          | 001C  |                                                           |                   |        |        |        |        |       | W14      |          |        |       |           |          |       |       |       | xxxx          |
| W15          | 001E  |                                                           |                   |        |        |        |        |       | W15      |          |        |       |           |          |       |       |       | xxxx          |
| SPLIM        | 0020  |                                                           |                   |        |        |        |        |       | SPLIM<1  | 5:0>     |        |       |           |          |       |       |       | 0000          |
| PCL          | 002E  |                                                           |                   |        |        |        |        | P     | CL<15:1> |          |        |       |           |          |       |       | —     | 0000          |
| PCH          | 0030  | —                                                         | -                 | _      | _      | —      | —      | —     | —        | _        |        |       |           | PCH<6:0> |       |       |       | 0000          |
| DSRPAG       | 0032  | —                                                         | -                 | _      | _      | —      | —      |       |          |          |        | DSRPA | G<9:0>    |          |       |       |       | 0001          |
| DSWPAG       | 0034  | _                                                         |                   |        |        | _      |        | _     |          |          |        | DS    | SWPAG<8:0 | >        |       |       |       | 0001          |
| RCOUNT       | 0036  |                                                           | RCOUNT<15:0> 00/  |        |        |        |        |       |          |          |        | 0000  |           |          |       |       |       |               |
| SR           | 0042  | _                                                         |                   |        |        | —      |        | —     | DC       | IPL2     | IPL1   | IPL0  | RA        | N        | OV    | Z     | С     | 0000          |
| CORCON       | 0044  | VAR                                                       | _                 | -      | -      | —      |        | —     | _        | -        | _      | —     | -         | IPL3     | SFA   | —     | _     | 0020          |
| DISICNT      | 0052  | _                                                         | _                 |        |        |        |        |       |          | DISICNT< | :13:0> |       |           |          |       |       |       | 0000          |
| TBLPAG       | 0054  | _                                                         | _                 | -      | -      | —      |        | —     | _        |          |        |       | TBLPA     | G<7:0>   |       |       |       | 0000          |
| MSTRPR       | 0058  |                                                           | MSTRPR<15:0> 0000 |        |        |        |        |       |          |          |        | 0000  |           |          |       |       |       |               |

#### **D**1 -4.0 - -

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

### TABLE 4-42: OP AMP/COMPARATOR REGISTER MAP

| File Name                | Addr. | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10  | Bit 9   | Bit 8 | Bit 7 | Bit 6  | Bit 5    | Bit 4 | Bit 3   | Bit 2  | Bit 1     | Bit 0 | All<br>Resets |
|--------------------------|-------|--------|--------|--------|--------|--------|---------|---------|-------|-------|--------|----------|-------|---------|--------|-----------|-------|---------------|
| CMSTAT                   | 0A80  | PSIDL  | _      | -      | —      | C4EVT  | C3EVT   | C2EVT   | C1EVT | _     | -      | —        | —     | C4OUT   | C3OUT  | C2OUT     | C10UT | 0000          |
| CVRCON                   | 0A82  |        | CVR2OE | _      | _      | _      | VREFSEL | _       | _     | CVREN | CVR10E | CVRR     | CVRSS |         | CVR<   | 3:0>      |       | 0000          |
| CM1CON                   | 0A84  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | _       | _      | CCH       | <1:0> | 0000          |
| CM1MSKSRC                | 0A86  |        | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM1MSKCON                | 0A88  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM1FLTR                  | 0A8A  |        | _      | _      | _      | _      | _       | _       | _     | _     | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM2CON                   | 0A8C  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | —       | _      | CCH       | <1:0> | 0000          |
| CM2MSKSRC                | 0A8E  |        | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM2MSKCON                | 0A90  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM2FLTR                  | 0A92  | _      | _      | _      | _      | _      | _       | _       | _     |       | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM3CON <sup>(1)</sup>    | 0A94  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | —       | _      | CCH       | <1:0> | 0000          |
| CM3MSKSRC(1)             | 0A96  | _      | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM3MSKCON <sup>(1)</sup> | 0A98  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM3FLTR <sup>(1)</sup>   | 0A9A  | _      | _      | _      | _      | _      | _       | _       | _     |       | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM4CON                   | 0A9C  | CON    | COE    | CPOL   | _      | _      | _       | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | —       | _      | CCH       | <1:0> | 0000          |
| CM4MSKSRC                | 0A9E  | _      | _      |        |        |        | SELSR   | CC<3:0> | -     |       | SELSRC | B<3:0>   | •     |         | SELSRC | A<3:0>    |       | 0000          |
| CM4MSKCON                | 0AA0  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM4FLTR                  | 0AA2  | _      | _      |        | _      | _      | _       | _       | _     | —     | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |

Legend: - = unimplemented, read as '0'. Reset values are shown in hexadecimal.

Note 1: These registers are unavailable on dsPIC33EPXXXGP502/MC502/MC502/MC202 and PIC24EP256GP/MC202 (28-pin) devices.

#### TABLE 4-43: CTMU REGISTER MAP

| File N | lame | Addr. | Bit 15  | Bit 14  | Bit 13   | Bit 12 | Bit 11   | Bit 10   | Bit 9    | Bit 8    | Bit 7   | Bit 6   | Bit 5 | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
|--------|------|-------|---------|---------|----------|--------|----------|----------|----------|----------|---------|---------|-------|-------|---------|-------|-------|-------|---------------|
| CTMUC  | CON1 | 033A  | CTMUEN  | —       | CTMUSIDL | TGEN   | EDGEN    | EDGSEQEN | IDISSEN  | CTTRIG   | _       | _       | _     | _     | _       | _     | _     | _     | 0000          |
| CTMUC  | CON2 | 033C  | EDG1MOD | EDG1POL |          | EDG1   | SEL<3:0> |          | EDG2STAT | EDG1STAT | EDG2MOD | EDG2POL |       | EDG2S | EL<3:0> |       | _     | -     | 0000          |
| CTMU   | ICON | 033E  |         |         | ITRIM<5  | 5:0>   |          |          | IRNG     | <1:0>    |         | _       | _     | _     | _       | _     | -     | _     | 0000          |

dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

Legend: - = unimplemented, read as '0'. Reset values are shown in hexadecimal.

### TABLE 4-44: JTAG INTERFACE REGISTER MAP

| File Name | Addr | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10        | Bit 9 | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
|-----------|------|--------|--------|--------|--------|--------|---------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|---------------|
| JDATAH    | 0FF0 | _      | —      | _      | _      |        | JDATAH<27:16> |       |       |       |       |       |       | xxxx  |       |       |       |               |
| JDATAL    | 0FF2 |        |        |        |        |        | JDATAL<15:0>  |       |       |       |       |       |       | 0000  |       |       |       |               |

Legend: x = unknown value on Reset, - = unimplemented, read as '0'. Reset values are shown in hexadecimal.

DS70000657H-page 97

Allocating different Page registers for read and write access allows the architecture to support data movement between different pages in data memory. This is accomplished by setting the DSRPAG register value to the page from which you want to read, and configuring the DSWPAG register to the page to which it needs to be written. Data can also be moved from different PSV to EDS pages, by configuring the DSRPAG and DSWPAG registers to address PSV and EDS space, respectively. The data can be moved between pages by a single instruction.

When an EDS or PSV page overflow or underflow occurs, EA<15> is cleared as a result of the register indirect EA calculation. An overflow or underflow of the EA in the EDS or PSV pages can occur at the page boundaries when:

- The initial address prior to modification addresses an EDS or PSV page
- The EA calculation uses Pre-Modified or Post-Modified Register Indirect Addressing; however, this does not include Register Offset Addressing

In general, when an overflow is detected, the DSxPAG register is incremented and the EA<15> bit is set to keep the base address within the EDS or PSV window. When an underflow is detected, the DSxPAG register is decremented and the EA<15> bit is set to keep the base address within the EDS or PSV window. This creates a linear EDS and PSV address space, but only when using Register Indirect Addressing modes.

Exceptions to the operation described above arise when entering and exiting the boundaries of Page 0, EDS and PSV spaces. Table 4-61 lists the effects of overflow and underflow scenarios at different boundaries.

In the following cases, when overflow or underflow occurs, the EA<15> bit is set and the DSxPAG is not modified; therefore, the EA will wrap to the beginning of the current page:

- · Register Indirect with Register Offset Addressing
- Modulo Addressing
- · Bit-Reversed Addressing

|             | -                   | SV SI ACE BOON |              |                        |                |              |                        |
|-------------|---------------------|----------------|--------------|------------------------|----------------|--------------|------------------------|
| 0/11        |                     |                | Before       |                        |                | After        |                        |
| O/U,<br>R/W | Operation           | DSxPAG         | DS<br>EA<15> | Page<br>Description    | DSxPAG         | DS<br>EA<15> | Page<br>Description    |
| O,<br>Read  |                     | DSRPAG = 0x1FF | 1            | EDS: Last page         | DSRPAG = 0x1FF | 0            | See Note 1             |
| O,<br>Read  | [++Wn]              | DSRPAG = 0x2FF | 1            | PSV: Last lsw<br>page  | DSRPAG = 0x300 | 1            | PSV: First MSB<br>page |
| O,<br>Read  | <b>Or</b><br>[Wn++] | DSRPAG = 0x3FF | 1            | PSV: Last MSB<br>page  | DSRPAG = 0x3FF | 0            | See Note 1             |
| O,<br>Write |                     | DSWPAG = 0x1FF | 1            | EDS: Last page         | DSWPAG = 0x1FF | 0            | See Note 1             |
| U,<br>Read  |                     | DSRPAG = 0x001 | 1            | PSV page               | DSRPAG = 0x001 | 0            | See Note 1             |
| U,<br>Read  | [Wn]<br>Or<br>[Wn]  | DSRPAG = 0x200 | 1            | PSV: First Isw<br>page | DSRPAG = 0x200 | 0            | See Note 1             |
| U,<br>Read  | [ //11 - ]          | DSRPAG = 0x300 | 1            | PSV: First MSB<br>page | DSRPAG = 0x2FF | 1            | PSV: Last Isw<br>page  |

# TABLE 4-61: OVERFLOW AND UNDERFLOW SCENARIOS AT PAGE 0, EDS and PSV SPACE BOUNDARIES<sup>(2,3,4)</sup>

Legend: O = Overflow, U = Underflow, R = Read, W = Write

Note 1: The Register Indirect Addressing now addresses a location in the base Data Space (0x0000-0x8000).

2: An EDS access with DSxPAG = 0x000 will generate an address error trap.

- **3:** Only reads from PS are supported using DSRPAG. An attempt to write to PS using DSWPAG will generate an address error trap.
- 4: Pseudo-Linear Addressing is not supported for large offsets.

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

### REGISTER 8-9: DSADRH: DMA MOST RECENT RAM HIGH ADDRESS REGISTER

| U-0            | U-0 | U-0             | U-0   | U-0          | U-0              | U-0    | U-0   |
|----------------|-----|-----------------|-------|--------------|------------------|--------|-------|
| —              | —   | —               | —     | —            | —                | -      | —     |
| bit 15         |     |                 |       |              |                  |        | bit 8 |
|                |     |                 |       |              |                  |        |       |
| R-0            | R-0 | R-0             | R-0   | R-0          | R-0              | R-0    | R-0   |
|                |     |                 | DSADR | <23:16>      |                  |        |       |
| bit 7          |     |                 |       |              |                  |        | bit 0 |
|                |     |                 |       |              |                  |        |       |
| Legend:        |     |                 |       |              |                  |        |       |
| R = Readable b | it  | W = Writable bi | t     | U = Unimpler | nented bit, read | as '0' |       |

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

#### bit 15-8 Unimplemented: Read as '0'

bit 7-0 DSADR<23:16>: Most Recent DMA Address Accessed by DMA bits

#### REGISTER 8-10: DSADRL: DMA MOST RECENT RAM LOW ADDRESS REGISTER

| R-0              | R-0 | R-0              | R-0  | R-0                  | R-0         | R-0             | R-0   |
|------------------|-----|------------------|------|----------------------|-------------|-----------------|-------|
|                  |     |                  | DSAD | DR<15:8>             |             |                 |       |
| bit 15           |     |                  |      |                      |             |                 | bit 8 |
|                  |     |                  |      |                      |             |                 |       |
| R-0              | R-0 | R-0              | R-0  | R-0                  | R-0         | R-0             | R-0   |
|                  |     |                  | DSA  | DR<7:0>              |             |                 |       |
| bit 7            |     |                  |      |                      |             |                 | bit 0 |
|                  |     |                  |      |                      |             |                 |       |
| Legend:          |     |                  |      |                      |             |                 |       |
| R = Readable b   | it  | W = Writable bit |      | U = Unimplemen       | ted bit, re | ad as '0'       |       |
| -n = Value at PC | OR  | '1' = Bit is set |      | '0' = Bit is cleared | d           | x = Bit is unkn | own   |

bit 15-0 DSADR<15:0>: Most Recent DMA Address Accessed by DMA bits

| 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-1              | R-1              | R-1             | R-1   |
| _            | _                           | _                                            | _              |                  | LSTC             | H<3:0>          |       |
| bit 7        |                             |                                              |                |                  |                  |                 | bit 0 |
| Legend:      |                             |                                              |                |                  |                  |                 |       |
| R = Readat   | ole bit                     | W = Writable                                 | bit            | U = Unimpler     | mented bit, read | 1 as '0'        |       |
| -n = Value a | at POR                      | '1' = Bit is set                             |                | '0' = Bit is cle | ared             | x = Bit is unkr | nown  |
|              |                             |                                              |                |                  |                  |                 |       |
| bit 15-4     | Unimplemen                  | ted: Read as '                               | 0'             |                  |                  |                 |       |
| bit 3-0      | LSTCH<3:0>                  | : Last DMAC C                                | hannel Active  | e Status bits    |                  |                 |       |
|              | 1111 = No DI<br>1110 = Rese | MA transfer has<br>rved                      | s occurred sir | nce system Res   | set              |                 |       |
|              | •                           |                                              |                |                  |                  |                 |       |
|              | •                           |                                              |                |                  |                  |                 |       |
|              | •                           |                                              |                |                  |                  |                 |       |
|              |                             | rved<br>data transfer wa<br>data transfer wa |                |                  |                  |                 |       |
|              |                             | data transfer wa                             |                |                  |                  |                 |       |

### REGISTER 8-13: DMALCA: DMA LAST CHANNEL ACTIVE STATUS REGISTER

0000 = Last data transfer was handled by Channel 0 0000 = Last data transfer was handled by Channel 0

### 9.0 OSCILLATOR CONFIGURATION

- 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 "Oscillator" (DS70580) 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.

The dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/ 50X and PIC24EPXXXGP/MC20X oscillator system provides:

- On-chip Phase-Locked Loop (PLL) to boost internal operating frequency on select internal and external oscillator sources
- On-the-fly clock switching between various clock sources
- · Doze mode for system power savings
- Fail-Safe Clock Monitor (FSCM) that detects clock failure and permits safe application recovery or shutdown
- Configuration bits for clock source selection
- A simplified diagram of the oscillator system is shown in Figure 9-1.

### FIGURE 9-1: OSCILLATOR SYSTEM DIAGRAM



2: The term, FP, refers to the clock source for all peripherals, while FCY refers to the clock source for the CPU. Throughout this document, FCY and FP are used interchangeably, except in the case of Doze mode. FP and FCY will be different when Doze mode is used with a doze ratio of 1:2 or lower.

| Oscillator Mode                                            | Oscillator Source | POSCMD<1:0> | FNOSC<2:0> | See<br>Notes |
|------------------------------------------------------------|-------------------|-------------|------------|--------------|
| Fast RC Oscillator with Divide-by-N (FRCDIVN)              | Internal          | xx          | 111        | 1, 2         |
| Fast RC Oscillator with Divide-by-16 (FRCDIV16)            | Internal          | xx          | 110        | 1            |
| Low-Power RC Oscillator (LPRC)                             | Internal          | xx          | 101        | 1            |
| Primary Oscillator (HS) with PLL (HSPLL)                   | Primary           | 10          | 011        |              |
| Primary Oscillator (XT) with PLL (XTPLL)                   | Primary           | 01          | 011        |              |
| Primary Oscillator (EC) with PLL (ECPLL)                   | Primary           | 0.0         | 011        | 1            |
| Primary Oscillator (HS)                                    | Primary           | 10          | 010        |              |
| Primary Oscillator (XT)                                    | Primary           | 01          | 010        |              |
| Primary Oscillator (EC)                                    | Primary           | 00          | 010        | 1            |
| Fast RC Oscillator (FRC) with Divide-by-N and PLL (FRCPLL) | Internal          | xx          | 001        | 1            |
| Fast RC Oscillator (FRC)                                   | Internal          | xx          | 000        | 1            |

### TABLE 9-1: CONFIGURATION BIT VALUES FOR CLOCK SELECTION

Note 1: OSC2 pin function is determined by the OSCIOFNC Configuration bit.

2: This is the default oscillator mode for an unprogrammed (erased) device.

### 9.2 Oscillator 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 brouger. |
|-------|----------------------------------------------------------------------------------------------------------------|
|       | this URL in your browser:<br>http://www.microchip.com/wwwproducts/<br>Devices.aspx?dDocName=en555464           |

### 9.2.1 KEY RESOURCES

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



#### FIGURE 18-1: SPIX MODULE BLOCK DIAGRAM

### REGISTER 18-2: SPIXCON1: SPIX CONTROL REGISTER 1 (CONTINUED)

- SPRE<2:0>: Secondary Prescale bits (Master mode)<sup>(3)</sup> bit 4-2 111 = Secondary prescale 1:1 110 = Secondary prescale 2:1 000 = Secondary prescale 8:1 bit 1-0 PPRE<1:0>: Primary Prescale bits (Master mode)<sup>(3)</sup> 11 = Primary prescale 1:1
  - 10 = Primary prescale 4:1
    - 01 = Primary prescale 16:1
    - 00 = Primary prescale 64:1
- Note 1: The CKE bit is not used in Framed SPI modes. Program this bit to '0' for Framed SPI modes (FRMEN = 1).
  - 2: This bit must be cleared when FRMEN = 1.
  - 3: Do not set both primary and secondary prescalers to the value of 1:1.

## 19.1 I<sup>2</sup>C 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 UDL increases |
|-------|---------------------------------------------------------------------------------------------------------|
|       | this URL in your browser:                                                                               |
|       | http://www.microchip.com/wwwproducts/                                                                   |
|       | Devices.aspx?dDocName=en555464                                                                          |

### 19.1.1 KEY RESOURCES

- "Inter-Integrated Circuit (I<sup>2</sup>C)" (DS70330) in the "dsPIC33/PIC24 Family Reference Manual"
- Code Samples
- Application Notes
- · Software Libraries
- Webinars
- All Related "dsPIC33/PIC24 Family Reference Manual" Sections
- Development Tools

| U-0    | U-0   | U-0   | U-0   | U-0   | U-0   | R/W-0 | R/W-0 |
|--------|-------|-------|-------|-------|-------|-------|-------|
| —      | —     | —     | —     | —     | —     | AMSK9 | AMSK8 |
| 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 |
| AMSK7  | AMSK6 | AMSK5 | AMSK4 | AMSK3 | AMSK2 | AMSK1 | AMSK0 |
| bit 7  |       |       |       |       |       |       | bit 0 |

### REGISTER 19-3: I2CxMSK: I2Cx SLAVE MODE ADDRESS MASK REGISTER

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

bit 15-10 Unimplemented: Read as '0'

bit 9-0

AMSK<9:0>: Address Mask Select bits

For 10-Bit Address:

1 = Enables masking for bit Ax of incoming message address; bit match is not required in this position

0 = Disables masking for bit Ax; bit match is required in this position

For 7-Bit Address (I2CxMSK<6:0> only):

1 = Enables masking for bit Ax + 1 of incoming message address; bit match is not required in this position

0 = Disables masking for bit Ax + 1; bit match is required in this position

### BUFFER 21-5: ECAN™ MESSAGE BUFFER WORD 4

| R/W-x                                                              | R/W-x | R/W-x            | R/W-x | R/W-x             | R/W-x | R/W-x           | R/W-x |
|--------------------------------------------------------------------|-------|------------------|-------|-------------------|-------|-----------------|-------|
|                                                                    |       |                  | Ву    | /te 3             |       |                 |       |
| bit 15                                                             |       |                  |       |                   |       |                 | bit 8 |
|                                                                    |       |                  |       |                   |       |                 |       |
| R/W-x                                                              | R/W-x | R/W-x            | R/W-x | R/W-x             | R/W-x | R/W-x           | R/W-x |
|                                                                    |       |                  | Ву    | /te 2             |       |                 |       |
| bit 7                                                              |       |                  |       |                   |       |                 | bit 0 |
| Legend:                                                            |       |                  |       |                   |       |                 |       |
| R = Readable bitW = Writable bitU = 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-8 Byte 3<15:8>: ECAN Message Byte 3 bits

bit 7-0 Byte 2<7:0>: ECAN Message Byte 2 bits

### BUFFER 21-6: ECAN™ MESSAGE BUFFER WORD 5

| R/W-x                             | R/W-x                                                            | R/W-x | R/W-x | R/W-x                              | R/W-x | R/W-x | R/W-x |
|-----------------------------------|------------------------------------------------------------------|-------|-------|------------------------------------|-------|-------|-------|
|                                   |                                                                  |       | B     | yte 5                              |       |       |       |
| bit 15                            |                                                                  |       |       |                                    |       |       | bit 8 |
| R/W-x                             | R/W-x                                                            | R/W-x | R/W-x | R/W-x                              | R/W-x | R/W-x | R/W-x |
|                                   |                                                                  |       |       | yte 4                              |       |       |       |
| bit 7                             |                                                                  |       |       |                                    |       |       | bit 0 |
|                                   |                                                                  |       |       |                                    |       |       |       |
| Legend:                           |                                                                  |       |       |                                    |       |       |       |
| R = Readable bit W = Writable bit |                                                                  |       | bit   | U = Unimplemented bit, read as '0' |       |       |       |
| -n = Value at P                   | e at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknow |       | nown  |                                    |       |       |       |

bit 15-8 Byte 5<15:8>: ECAN Message Byte 5 bits

bit 7-0 Byte 4<7:0>: ECAN Message Byte 4 bits

| REGISTER 24-6: | PTGSDLIM: PTG STEP DELAY LIMIT REGISTER <sup>(1,2)</sup> |
|----------------|----------------------------------------------------------|
|                |                                                          |

| R/W-0                                                                     | R/W-0                                                                | R/W-0 | R/W-0 | R/W-0     | R/W-0 | R/W-0 | R/W-0 |
|---------------------------------------------------------------------------|----------------------------------------------------------------------|-------|-------|-----------|-------|-------|-------|
|                                                                           |                                                                      |       | PTGSD | LIM<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 |
|                                                                           |                                                                      |       | PTGSE | )LIM<7:0> |       |       |       |
| bit 7                                                                     |                                                                      |       |       |           |       |       | bit 0 |
|                                                                           |                                                                      |       |       |           |       |       |       |
| Legend:                                                                   |                                                                      |       |       |           |       |       |       |
| R = Readable                                                              | 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 unknow |                                                                      |       | nown  |           |       |       |       |

bit 15-0 **PTGSDLIM<15:0>:** PTG Step Delay Limit Register bits Holds a PTG Step delay value representing the number of additional PTG clocks between the start of a Step command and the completion of a Step command.

**Note 1:** A base Step delay of one PTG clock is added to any value written to the PTGSDLIM register (Step Delay = (PTGSDLIM) + 1).

2: This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1).

### REGISTER 24-7: PTGC0LIM: PTG COUNTER 0 LIMIT REGISTER<sup>(1)</sup>

| R/W-0                             | R/W-0 | R/W-0            | R/W-0 | R/W-0             | R/W-0           | R/W-0           | R/W-0 |
|-----------------------------------|-------|------------------|-------|-------------------|-----------------|-----------------|-------|
|                                   |       |                  | PTGC0 | LIM<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 |
|                                   |       |                  | PTGC  | )LIM<7:0>         |                 |                 |       |
| bit 7                             |       |                  |       |                   |                 |                 | bit 0 |
|                                   |       |                  |       |                   |                 |                 |       |
| Legend:                           |       |                  |       |                   |                 |                 |       |
| R = Readable bit W = Writable bit |       |                  | it    | U = Unimplem      | nented bit, rea | ad as '0'       |       |
| -n = Value at POR '1' :           |       | '1' = Bit is set |       | '0' = Bit is clea | ared            | x = Bit is unki | nown  |

bit 15-0 **PTGC0LIM<15:0>:** PTG Counter 0 Limit Register bits May be used to specify the loop count for the PTGJMPC0 Step command or as a limit register for the General Purpose Counter 0.

**Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1).

NOTES:

### 27.5 Watchdog Timer (WDT)

For dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/ 50X and PIC24EPXXXGP/MC20X devices, the WDT is driven by the LPRC oscillator. When the WDT is enabled, the clock source is also enabled.

### 27.5.1 PRESCALER/POSTSCALER

The nominal WDT clock source from LPRC is 32 kHz. This feeds a prescaler that can be configured for either 5-bit (divide-by-32) or 7-bit (divide-by-128) operation. The prescaler is set by the WDTPRE Configuration bit. With a 32 kHz input, the prescaler yields a WDT Timeout period (TWDT), as shown in Parameter SY12 in Table 30-22.

A variable postscaler divides down the WDT prescaler output and allows for a wide range of time-out periods. The postscaler is controlled by the WDTPOST<3:0> Configuration bits (FWDT<3:0>), which allow the selection of 16 settings, from 1:1 to 1:32,768. Using the prescaler and postscaler, time-out periods ranging from 1 ms to 131 seconds can be achieved.

The WDT, prescaler and postscaler are reset:

- · On any device Reset
- On the completion of a clock switch, whether invoked by software (i.e., setting the OSWEN bit after changing the NOSCx bits) or by hardware (i.e., Fail-Safe Clock Monitor)
- When a PWRSAV instruction is executed (i.e., Sleep or Idle mode is entered)
- When the device exits Sleep or Idle mode to resume normal operation
- By a CLRWDT instruction during normal execution
- Note: The CLRWDT and PWRSAV instructions clear the prescaler and postscaler counts when executed.



### FIGURE 27-2: WDT BLOCK DIAGRAM

### 27.5.2 SLEEP AND IDLE MODES

If the WDT is enabled, it continues to run during Sleep or Idle modes. When the WDT time-out occurs, the device wakes the device and code execution continues from where the PWRSAV instruction was executed. The corresponding SLEEP or IDLE bit (RCON<3,2>) needs to be cleared in software after the device wakes up.

### 27.5.3 ENABLING WDT

The WDT is enabled or disabled by the FWDTEN Configuration bit in the FWDT Configuration register. When the FWDTEN Configuration bit is set, the WDT is always enabled.

The WDT can be optionally controlled in software when the FWDTEN Configuration bit has been programmed to '0'. The WDT is enabled in software by setting the SWDTEN control bit (RCON<5>). The SWDTEN control bit is cleared on any device Reset. The software WDT option allows the user application to enable the WDT for critical code segments and disable the WDT during non-critical segments for maximum power savings.

The WDT flag bit, WDTO (RCON<4>), is not automatically cleared following a WDT time-out. To detect subsequent WDT events, the flag must be cleared in software.

### 27.5.4 WDT WINDOW

The Watchdog Timer has an optional Windowed mode, enabled by programming the WINDIS bit in the WDT Configuration register (FWDT<6>). In the Windowed mode (WINDIS = 0), the WDT should be cleared based on the settings in the programmable Watchdog Timer Window select bits (WDTWIN<1:0>).



### FIGURE 30-27: SPI1 SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 1, SMP = 0) TIMING CHARACTERISTICS

### 31.0 HIGH-TEMPERATURE ELECTRICAL CHARACTERISTICS

This section provides an overview of dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/ MC20X electrical characteristics for devices operating in an ambient temperature range of -40°C to +150°C.

The specifications between  $-40^{\circ}$ C to  $+150^{\circ}$ C are identical to those shown in **Section 30.0** "**Electrical Characteristics**" for operation between  $-40^{\circ}$ C to  $+125^{\circ}$ C, with the exception of the parameters listed in this section.

Parameters in this section begin with an H, which denotes High temperature. For example, Parameter DC10 in **Section 30.0 "Electrical Characteristics"** is the Industrial and Extended temperature equivalent of HDC10.

Absolute maximum ratings for the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X high-temperature devices are listed below. Exposure to these maximum rating conditions for extended periods can 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 <sup>(2)</sup>                                     | 40°C to +150°C       |
|-----------------------------------------------------------------------------------|----------------------|
| Storage temperature                                                               | 65°C to +160°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 < 3.0V <sup>(3)</sup> | 0.3V to 3.6V         |
| Voltage on any 5V tolerant pin with respect to Vss when $VDD \ge 3.0V^{(3)}$      | 0.3V to 5.5V         |
| Maximum current out of Vss pin                                                    | 60 mA                |
| Maximum current into Vod pin <sup>(4)</sup>                                       | 60 mA                |
| Maximum junction temperature                                                      | +155°C               |
| Maximum current sourced/sunk by any 4x I/O pin                                    | 10 mA                |
| Maximum current sourced/sunk by any 8x I/O pin                                    | 15 mA                |
| Maximum current sunk by all ports combined                                        | 70 mA                |
| Maximum current sourced by all ports combined <sup>(4)</sup>                      | 70 mA                |

- **Note 1:** Stresses above those listed under "Absolute Maximum Ratings" can 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 can affect device reliability.
  - 2: AEC-Q100 reliability testing for devices intended to operate at +150°C is 1,000 hours. Any design in which the total operating time from +125°C to +150°C will be greater than 1,000 hours is not warranted without prior written approval from Microchip Technology Inc.
  - 3: Refer to the "Pin Diagrams" section for 5V tolerant pins.
  - 4: Maximum allowable current is a function of device maximum power dissipation (see Table 31-2).



### 48-Lead Plastic Ultra Thin Quad Flat, No Lead Package (MV) – 6x6x0.5 mm Body [UQFN]

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

Microchip Technology Drawing C04-153A Sheet 1 of 2

### Revision E (April 2012)

This revision includes typographical and formatting changes throughout the data sheet text.

All other major changes are referenced by their respective section in Table A-3.

| TABLE A-4: | MAJOR SECTION UPDATES |
|------------|-----------------------|
|------------|-----------------------|

| Section Name                                   | Update Description                                                                              |
|------------------------------------------------|-------------------------------------------------------------------------------------------------|
| "16-bit Microcontrollers<br>and Digital Signal | The following 512-Kbyte devices were added to the General Purpose Families table (see Table 1): |
| Controllers (up to                             | <ul> <li>PIC24EP512GP202</li> </ul>                                                             |
| 512-Kbyte Flash and                            | • PIC24EP512GP204                                                                               |
| 48-Kbyte SRAM) with High-                      | • PIC24EP512GP206                                                                               |
| Speed PWM, Op amps, and Advanced Analog"       | • dsPIC33EP512GP502                                                                             |
| Advanced Analog                                | • dsPIC33EP512GP504                                                                             |
|                                                | • dsPIC33EP512GP506                                                                             |
|                                                | The following 512-Kbyte devices were added to the Motor Control Families table (see Table 2):   |
|                                                | • PIC24EP512MC202                                                                               |
|                                                | • PIC24EP512MC204                                                                               |
|                                                | • PIC24EP512MC206                                                                               |
|                                                | • dsPIC33EP512MC202                                                                             |
|                                                | • dsPIC33EP512MC204                                                                             |
|                                                | • dsPIC33EP512MC206                                                                             |
|                                                | • dsPIC33EP512MC502                                                                             |
|                                                | • dsPIC33EP512MC504                                                                             |
|                                                | • dsPIC33EP512MC506                                                                             |
|                                                | Certain Pin Diagrams were updated to include the new 512-Kbyte devices.                         |
| Section 4.0 "Memory                            | Added a Program Memory Map for the new 512-Kbyte devices (see Figure 4-4).                      |
| Organization"                                  | Added a Data Memory Map for the new dsPIC 512-Kbyte devices (see Figure 4-11).                  |
|                                                | Added a Data Memory Map for the new PIC24 512-Kbyte devices (see Figure 4-16).                  |
| Section 7.0 "Interrupt<br>Controller"          | Updated the VECNUM bits in the INTTREG register (see Register 7-7).                             |
| Section 11.0 "I/O Ports"                       | Added tip 6 to Section 11.5 "I/O Helpful Tips".                                                 |
| Section 27.0 "Special<br>Features"             | The following modifications were made to the Configuration Byte Register Map (see Table 27-1):  |
|                                                | <ul> <li>Added the column Device Memory Size (Kbytes)</li> </ul>                                |
|                                                | Removed Notes 1 through 4                                                                       |
|                                                | Added addresses for the new 512-Kbyte devices                                                   |
| Section 30.0 "Electrical                       | Updated the Minimum value for Parameter DC10 (see Table 30-4).                                  |
| Characteristics"                               | Added Power-Down Current (Ipd) parameters for the new 512-Kbyte devices (see Table 30-8).       |
|                                                | Updated the Minimum value for Parameter CM34 (see Table 30-53).                                 |
|                                                | Updated the Minimum and Maximum values and the Conditions for paramteer SY12 (see Table 30-22). |