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 - Microcontrollers</u>" | Details | | |----------------------------|----------------------------------------------------------------------------------| | Product Status | Active | | Core Processor | dsPIC | | Core Size | 16-Bit | | Speed | 60 MIPs | | Connectivity | CANbus, I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, DMA, POR, PWM, WDT | | Number of I/O | 35 | | Program Memory Size | 256KB (85.5K x 24) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 16K 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-TQFP | | Supplier Device Package | 44-TQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/dspic33ep256gp504-e-pt | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong #### Pin Diagrams (Continued) #### **Table of Contents** | 1.0 | Device Overview | 25 | |-------|----------------------------------------------------------------------------------------------------|-----| | 2.0 | Guidelines for Getting Started with 16-bit Digital Signal Controllers and Microcontrollers | 29 | | 3.0 | CPU | 35 | | 4.0 | Memory Organization | 45 | | 5.0 | Flash Program Memory | 119 | | 6.0 | Resets | 123 | | 7.0 | Interrupt Controller | 127 | | 8.0 | Direct Memory Access (DMA) | 139 | | 9.0 | Oscillator Configuration | 153 | | 10.0 | Power-Saving Features | 163 | | 11.0 | I/O Ports | 173 | | 12.0 | Timer1 | 203 | | 13.0 | Timer2/3 and Timer4/5 | 207 | | 14.0 | Input Capture | 213 | | | Output Compare | | | 16.0 | High-Speed PWM Module (dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X Devices Only) | 225 | | 17.0 | Quadrature Encoder Interface (QEI) Module (dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X Devices Only) | 249 | | | Serial Peripheral Interface (SPI) | | | 19.0 | Inter-Integrated Circuit™ (I <sup>2</sup> C™) | 273 | | 20.0 | Universal Asynchronous Receiver Transmitter (UART) | 281 | | 21.0 | Enhanced CAN (ECAN™) Module (dsPIC33EPXXXGP/MC50X Devices Only) | 287 | | 22.0 | Charge Time Measurement Unit (CTMU) | 315 | | 23.0 | 10-Bit/12-Bit Analog-to-Digital Converter (ADC) | 321 | | 24.0 | Peripheral Trigger Generator (PTG) Module | 337 | | | Op Amp/Comparator Module | | | 26.0 | Programmable Cyclic Redundancy Check (CRC) Generator | 373 | | 27.0 | Special Features | 379 | | 28.0 | Instruction Set Summary | 387 | | 29.0 | Development Support | 397 | | 30.0 | Electrical Characteristics | 401 | | 31.0 | High-Temperature Electrical Characteristics | 467 | | 32.0 | DC and AC Device Characteristics Graphs | 475 | | 33.0 | Packaging Information | 479 | | | endix A: Revision History | | | Index | X | 517 | | The I | Microchip Web Site | 525 | | Cust | omer Change Notification Service | 525 | | Cust | omer Support | 525 | | Prod | uct Identification System | 527 | TABLE 4-7: INTERRUPT CONTROLLER REGISTER MAP FOR dsPIC33EPXXXMC50X DEVICES ONLY (CONTINUED) | 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 | |--------------|-------|--------|--------|------------|---------|---------|--------|------------|-------------|----------|---------|-------------|---------|---------|-------------|------------|--------|---------------| | IPC23 | 086E | _ | F | PWM2IP<2:0 | 0> | _ | Р | WM1IP<2: | 0> | _ | - | _ | | _ | _ | _ | _ | 4400 | | IPC24 | 0870 | _ | _ | _ | _ | _ | _ | _ | _ | _ | 1 | _ | - | _ | Р | WM3IP<2:0> | | 0004 | | IPC35 | 0886 | _ | , | JTAGIP<2:0 | )> | _ | | ICDIP<2:0 | > | _ | ı | _ | - | _ | - | - | 1 | 4400 | | IPC36 | 0888 | _ | 1 | PTG0IP<2:0 | )> | _ | PT | GWDTIP< | 2:0> | _ | P | TGSTEPIP<2 | :0> | _ | - | - | 1 | 4440 | | IPC37 | 088A | _ | | _ | _ | _ | F | PTG3IP<2:0 | 0> | _ | | PTG2IP<2:0> | • | _ | PTG1IP<2:0> | | | 0444 | | INTCON1 | 08C0 | NSTDIS | OVAERR | OVBERR | COVAERR | COVBERR | OVATE | OVBTE | COVTE | SFTACERR | DIV0ERR | DMACERR | MATHERR | ADDRERR | STKERR | OSCFAIL | | 0000 | | INTCON2 | 08C2 | GIE | DISI | SWTRAP | _ | _ | | - | _ | _ | 1 | _ | I | _ | INT2EP | INT1EP | INT0EP | 8000 | | INTCON3 | 08C4 | _ | | _ | _ | _ | | - | _ | _ | 1 | DAE | DOOVR | _ | _ | _ | | 0000 | | INTCON4 | 08C6 | _ | _ | _ | _ | _ | _ | _ | _ | _ | | _ | - | _ | _ | _ | SGHT | 0000 | | INTTREG | 08C8 | _ | _ | _ | _ | | ILR< | 3:0> | VECNUM<7:0> | | | | | | 0000 | | | | dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X **Legend:** — = unimplemented, read as '0'. Reset values are shown in hexadecimal. DS/000065/ #### TABLE 4-19: SPI1 AND SPI2 REGISTER MAP | SFR 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 | |----------|-------|-------------------------------------------|--------|---------|-----------------------|--------|--------|------------|-------------|-------------|------------|--------|-------|------------|-------|--------|--------|---------------| | SPI1STAT | 0240 | SPIEN | _ | SPISIDL | 1 | - | 9 | SPIBEC<2:0 | > | SRMPT | SPIROV | SRXMPT | | SISEL<2:0> | | SPITBF | SPIRBF | 0000 | | SPI1CON1 | 0242 | _ | _ | - | DISSCK | DISSDO | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | | SPRE<2:0> | | PPRE | <1:0> | 0000 | | SPI1CON2 | 0244 | FRMEN | SPIFSD | FRMPOL | _ | _ | - | _ | _ | _ | _ | _ | _ | _ | _ | FRMDLY | SPIBEN | 0000 | | SPI1BUF | 0248 | | | | | | | SPI1 Tra | nsmit and R | eceive Buff | er Registe | r | | | | | | 0000 | | SPI2STAT | 0260 | SPIEN | _ | SPISIDL | - | _ | Ş | SPIBEC<2:0 | > | SRMPT | SPIROV | SRXMPT | | SISEL<2:0> | | SPITBF | SPIRBF | 0000 | | SPI2CON1 | 0262 | _ | _ | - | DISSCK | DISSDO | MODE16 | SMP | CKE | SSEN | CKP | MSTEN | | SPRE<2:0> | | PPRE | <1:0> | 0000 | | SPI2CON2 | 0264 | FRMEN | SPIFSD | FRMPOL | MPOL FRMDLY SPIBEN 00 | | | | | | | | | | 0000 | | | | | SPI2BUF | 0268 | SPI2 Transmit and Receive Buffer Register | | | | | | | | | | | 0000 | | | | | | dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X **Legend:** — = 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 | C1OUT | 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 | _ | _ | _ | _ | | SELSRO | 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 | A8A0 | _ | _ | _ | _ | _ | _ | _ | _ | _ | С | FSEL<2:0 | > | CFLTREN | C | CFDIV<2:0 | > | 0000 | | CM2CON | 0A8C | CON | COE | CPOL | _ | _ | OPMODE | CEVT | COUT | EVPOL | _<1:0> | _ | CREF | - | _ | CCH | <1:0> | 0000 | | CM2MSKSRC | 0A8E | _ | _ | _ | _ | | SELSRO | 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 | ı | _ | 1 | | 1 | _ | ı | _ | _ | С | FSEL<2:0 | > | CFLTREN | C | CFDIV<2:0 | > | 0000 | | CM3CON <sup>(1)</sup> | 0A94 | CON | COE | CPOL | | 1 | OPMODE | CEVT | COUT | EVPOL | _<1:0> | 1 | CREF | ı | I | CCH | <1:0> | 0000 | | CM3MSKSRC <sup>(1)</sup> | 0A96 | ı | _ | ı | - | | SELSRO | 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 | _ | _ | _ | _ | _ | _ | _ | _ | _ | С | FSEL<2:0 | > | CFLTREN | C | CFDIV<2:0 | > | 0000 | | CM4CON | 0A9C | CON | COE | CPOL | _ | _ | _ | CEVT | COUT | EVPOL | _<1:0> | _ | CREF | - | _ | CCH | <1:0> | 0000 | | CM4MSKSRC | 0A9E | ı | _ | ı | _ | | SELSRO | 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 | _ | _ | _ | _ | _ | _ | _ | _ | _ | С | FSEL<2:0 | > | CFLTREN | C | CFDIV<2:0 | > | 0000 | **Legend:** — = unimplemented, read as '0'. Reset values are shown in hexadecimal. Note 1: These registers are unavailable on dsPIC33EPXXXGP502/MC502/MC202 and PIC24EP256GP/MC202 (28-pin) devices. #### **TABLE 4-43: CTMU 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 | |-----------|-------|---------|---------|----------|------------|----------|----------|----------|----------|---------|---------|-------|--------|---------|-------|-------|-------|---------------| | CTMUCON1 | 033A | CTMUEN | _ | CTMUSIDL | TGEN | EDGEN | EDGSEQEN | IDISSEN | CTTRIG | _ | _ | _ | _ | _ | _ | _ | _ | 0000 | | CTMUCON2 | 033C | EDG1MOD | EDG1POL | | EDG1 | SEL<3:0> | | EDG2STAT | EDG1STAT | EDG2MOD | EDG2POL | | EDG2SI | EL<3:0> | | _ | _ | 0000 | | CTMUICON | 033E | | | ITRIM<5 | ITRIM<5:0> | | | | <1:0> | ı | _ | I | _ | | | _ | _ | 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> 3 | | | | | | | | | | xxxx | | | JDATAL | 0FF2 | | | | | JDATAL<15:0> | | | | | | | | | | 0000 | | | Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal. #### 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 #### REGISTER 8-1: DMAXCON: DMA CHANNEL x CONTROL REGISTER | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | U-0 | |--------|-------|-------|-------|-------|-----|-----|-------| | CHEN | SIZE | DIR | HALF | NULLW | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | U-0 | R/W-0 | R/W-0 | |-------|-----|--------|--------|-----|-----|-------|-------| | _ | _ | AMODE1 | AMODE0 | _ | _ | MODE1 | MODE0 | | 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 bit 15 CHEN: DMA Channel Enable bit 1 = Channel is enabled0 = Channel is disabled bit 14 SIZE: DMA Data Transfer Size bit 1 = Byte0 = Word bit 13 DIR: DMA Transfer Direction bit (source/destination bus select) 1 = Reads from RAM address, writes to peripheral address 0 = Reads from peripheral address, writes to RAM address bit 12 HALF: DMA Block Transfer Interrupt Select bit 1 = Initiates interrupt when half of the data has been moved 0 = Initiates interrupt when all of the data has been moved bit 11 NULLW: Null Data Peripheral Write Mode Select bit 1 = Null data write to peripheral in addition to RAM write (DIR bit must also be clear) 0 = Normal operation bit 10-6 Unimplemented: Read as '0' bit 5-4 AMODE<1:0>: DMA Channel Addressing Mode Select bits 11 = Reserved 10 = Peripheral Indirect Addressing mode 01 = Register Indirect without Post-Increment mode 00 = Register Indirect with Post-Increment mode bit 3-2 **Unimplemented:** Read as '0' bit 1-0 MODE<1:0>: DMA Channel Operating Mode Select bits 11 = One-Shot, Ping-Pong modes are enabled (one block transfer from/to each DMA buffer) 10 = Continuous, Ping-Pong modes are enabled 01 = One-Shot, Ping-Pong modes are disabled 00 = Continuous, Ping-Pong modes are disabled #### REGISTER 16-13: IOCONx: PWMx I/O CONTROL REGISTER (2) | R/W-1 | R/W-1 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-------|-------|-------|----------------------|----------------------|--------|--------| | PENH | PENL | POLH | POLL | PMOD1 <sup>(1)</sup> | PMOD0 <sup>(1)</sup> | OVRENH | OVRENL | | bit 15 | | | | | | | bit 8 | | R/W-0 |---------|---------|---------|---------|--------|--------|-------|-------| | OVRDAT1 | OVRDAT0 | FLTDAT1 | FLTDAT0 | CLDAT1 | CLDAT0 | SWAP | OSYNC | | bit 7 | | | | | | | bit 0 | Legend: bit 12 R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' '1' = Bit is set '0' = Bit is cleared -n = Value at POR x = Bit is unknown bit 15 PENH: PWMxH Output Pin Ownership bit 1 = PWMx module controls PWMxH pin 0 = GPIO module controls PWMxH pin bit 14 PENL: PWMxL Output Pin Ownership bit 1 = PWMx module controls PWMxL pin 0 = GPIO module controls PWMxL pin bit 13 POLH: PWMxH Output Pin Polarity bit > 1 = PWMxH pin is active-low 0 = PWMxH pin is active-high POLL: PWMxL Output Pin Polarity bit 1 = PWMxL pin is active-low 0 = PWMxL pin is active-high PMOD<1:0>: PWMx # I/O Pin Mode bits(1) bit 11-10 11 = Reserved; do not use 10 = PWMx I/O pin pair is in the Push-Pull Output mode 01 = PWMx I/O pin pair is in the Redundant Output mode 00 = PWMx I/O pin pair is in the Complementary Output mode bit 9 **OVRENH:** Override Enable for PWMxH Pin bit 1 = OVRDAT<1> controls output on PWMxH pin 0 = PWMx generator controls PWMxH pin bit 8 **OVRENL:** Override Enable for PWMxL Pin bit 1 = OVRDAT<0> controls output on PWMxL pin 0 = PWMx generator controls PWMxL pin bit 7-6 OVRDAT<1:0>: Data for PWMxH, PWMxL Pins if Override is Enabled bits If OVERENH = 1, PWMxH is driven to the state specified by OVRDAT<1>. If OVERENL = 1, PWMxL is driven to the state specified by OVRDAT<0>. FLTDAT<1:0>: Data for PWMxH and PWMxL Pins if FLTMOD is Enabled bits bit 5-4 If Fault is active, PWMxH is driven to the state specified by FLTDAT<1>. If Fault is active, PWMxL is driven to the state specified by FLTDAT<0>. bit 3-2 CLDAT<1:0>: Data for PWMxH and PWMxL Pins if CLMOD is Enabled bits If current-limit is active, PWMxH is driven to the state specified by CLDAT<1>. If current-limit is active, PWMxL is driven to the state specified by CLDAT<0>. **Note 1:** These bits should not be changed after the PWMx module is enabled (PTEN = 1). If the PWMLOCK Configuration bit (FOSCSEL<6>) is a '1', the IOCONx register can only be written after the unlock sequence has been executed. #### REGISTER 17-3: QEI1STAT: QEI1 STATUS REGISTER | U-0 | U-0 | HS, R/C-0 | R/W-0 | HS, R/C-0 | R/W-0 | HS, R/C-0 | R/W-0 | |--------|-----|-----------|----------|-----------|----------|-----------|----------| | _ | _ | PCHEQIRQ | PCHEQIEN | PCLEQIRQ | PCLEQIEN | POSOVIRQ | POSOVIEN | | bit 15 | | | | | | | bit 8 | | HS, R/C-0 | R/W-0 | HS, R/C-0 | R/W-0 | HS, R/C-0 | R/W-0 | HS, R/C-0 | R/W-0 | |-----------------------|--------|-----------|----------|-----------|--------|-----------|--------| | PCIIRQ <sup>(1)</sup> | PCIIEN | VELOVIRQ | VELOVIEN | HOMIRQ | HOMIEN | IDXIRQ | IDXIEN | | bit 7 | | | | | | | bit 0 | | <b>Legend:</b> HS = Hardware Settable bit C = Clearable bit | | C = Clearable bit | | | |-------------------------------------------------------------|------------------|------------------------------------|--------------------|--| | 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-14 Unimplemented: Read as '0' bit 13 PCHEQIRQ: Position Counter Greater Than or Equal Compare Status bit 1 = POS1CNT ≥ QEI1GEC 0 = POS1CNT < QEI1GEC bit 12 **PCHEQIEN:** Position Counter Greater Than or Equal Compare Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 11 PCLEQIRQ: Position Counter Less Than or Equal Compare Status bit 1 = POS1CNT ≤ QEI1LEC 0 = POS1CNT > QEI1LEC bit 10 PCLEQIEN: Position Counter Less Than or Equal Compare Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 9 **POSOVIRQ:** Position Counter Overflow Status bit 1 = Overflow has occurred0 = No overflow has occurred bit 8 POSOVIEN: Position Counter Overflow Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 7 PCIIRQ: Position Counter (Homing) Initialization Process Complete Status bit<sup>(1)</sup> 1 = POS1CNT was reinitialized 0 = POS1CNT was not reinitialized bit 6 PCIIEN: Position Counter (Homing) Initialization Process Complete interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 5 **VELOVIRQ:** Velocity Counter Overflow Status bit 1 = Overflow has occurred 0 = No overflow has not occurred bit 4 **VELOVIEN:** Velocity Counter Overflow Interrupt Enable bit 1 = Interrupt is enabled0 = Interrupt is disabled bit 3 **HOMIRQ:** Status Flag for Home Event Status bit 1 = Home event has occurred0 = No Home event has occurred Note 1: This status bit is only applicable to PIMOD<2:0> modes, '011' and '100'. #### REGISTER 18-1: SPIXSTAT: SPIX STATUS AND CONTROL REGISTER (CONTINUED) #### bit 1 SPITBF: SPIx Transmit Buffer Full Status bit 1 = Transmit not yet started, SPIxTXB is full 0 = Transmit started, SPIxTXB is empty #### Standard Buffer mode: Automatically set in hardware when core writes to the SPIxBUF location, loading SPIxTXB. Automatically cleared in hardware when SPIx module transfers data from SPIxTXB to SPIxSR. #### Enhanced Buffer mode: Automatically set in hardware when the CPU writes to the SPIxBUF location, loading the last available buffer location. Automatically cleared in hardware when a buffer location is available for a CPU write operation. #### bit 0 SPIRBF: SPIx Receive Buffer Full Status bit - 1 = Receive is complete, SPIxRXB is full - 0 = Receive is incomplete, SPIxRXB is empty #### Standard Buffer mode: Automatically set in hardware when SPIx transfers data from SPIxSR to SPIxRXB. Automatically cleared in hardware when the core reads the SPIxBUF location, reading SPIxRXB. #### Enhanced Buffer mode: Automatically set in hardware when SPIx transfers data from SPIxSR to the buffer, filling the last unread buffer location. Automatically cleared in hardware when a buffer location is available for a transfer from SPIxSR. ## 20.0 UNIVERSAL ASYNCHRONOUS RECEIVER TRANSMITTER (UART) 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 "UART" (DS70582) 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 family of devices contains two UART modules. The Universal Asynchronous Receiver Transmitter (UART) module is one of the serial I/O modules available in the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X device family. The UART is a full-duplex, asynchronous system that can communicate with peripheral devices, such as personal computers, LIN/J2602, RS-232 and RS-485 interfaces. The module also supports a hardware flow control option with the UxCTS and UxRTS pins, and also includes an IrDA® encoder and decoder. Note: Hardware flow control using UxRTS and UxCTS is not available on all pin count devices. See the "Pin Diagrams" section for availability. The primary features of the UARTx module are: - Full-Duplex, 8 or 9-Bit Data Transmission through the UxTX and UxRX Pins - Even, Odd or No Parity Options (for 8-bit data) - · One or Two Stop bits - Hardware Flow Control Option with UxCTS and UxRTS Pins - Fully Integrated Baud Rate Generator with 16-Bit Prescaler - Baud Rates Ranging from 4.375 Mbps to 67 bps at 16x mode at 70 MIPS - Baud Rates Ranging from 17.5 Mbps to 267 bps at 4x mode at 70 MIPS - 4-Deep First-In First-Out (FIFO) Transmit Data Buffer - · 4-Deep FIFO Receive Data Buffer - Parity, Framing and Buffer Overrun Error Detection - Support for 9-bit mode with Address Detect (9th bit = 1) - · Transmit and Receive Interrupts - A Separate Interrupt for all UARTx Error Conditions - · Loopback mode for Diagnostic Support - · Support for Sync and Break Characters - · Support for Automatic Baud Rate Detection - IrDA<sup>®</sup> Encoder and Decoder Logic - 16x Baud Clock Output for IrDA Support A simplified block diagram of the UARTx module is shown in Figure 20-1. The UARTx module consists of these key hardware elements: - · Baud Rate Generator - · Asynchronous Transmitter - · Asynchronous Receiver ### REGISTER 21-17: CxRXFnEID: ECANx ACCEPTANCE FILTER n EXTENDED IDENTIFIER REGISTER (n = 0-15) | R/W-x |--------|-------|-------|-------|-------|-------|-------|-------| | EID15 | EID14 | EID13 | EID12 | EID11 | EID10 | EID9 | EID8 | | bit 15 | | | | | | | bit 8 | | R/W-x |-------|-------|-------|-------|-------|-------|-------|-------| | EID7 | EID6 | EID5 | EID4 | EID3 | EID2 | EID1 | EID0 | | 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 bit 15-0 **EID<15:0>:** Extended Identifier bits 1 = Message address bit, EIDx, must be '1' to match filter 0 = Message address bit, EIDx, must be '0' to match filter #### REGISTER 21-18: CxFMSKSEL1: ECANx FILTER 7-0 MASK SELECTION REGISTER 1 | R/W-0 |------------|-------|------------|-------|------------|-------|------------|-------| | F7MSK<1:0> | | F6MSK<1:0> | | F5MSK<1:0> | | F4MSK<1:0> | | | bit 15 | | | | • | | • | bit 8 | | R/W-0 |------------|-------|------------|-------|------------|-------|------------|-------| | F3MSK<1:0> | | F2MSK<1:0> | | F1MSK<1:0> | | F0MSK<1:0> | | | bit 7 | | | | | | | bit 0 | Legend: bit 3-2 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-14 F7MSK<1:0>: Mask Source for Filter 7 bits 11 = Reserved 10 = Acceptance Mask 2 registers contain mask 01 = Acceptance Mask 1 registers contain mask 00 = Acceptance Mask 0 registers contain mask bit 13-12 **F6MSK<1:0>:** Mask Source for Filter 6 bits (same values as bits<15:14>) bit 11-10 **F5MSK<1:0>:** Mask Source for Filter 5 bits (same values as bits<15:14>) bit 9-8 **F4MSK<1:0>:** Mask Source for Filter 4 bits (same values as bits<15:14>) bit 7-6 **F3MSK<1:0>:** Mask Source for Filter 3 bits (same values as bits<15:14>) bit 5-4 **F2MSK<1:0>:** Mask Source for Filter 2 bits (same values as bits<15:14>) **F1MSK<1:0>:** Mask Source for Filter 1 bits (same values as bits<15:14>) bit 1-0 **F0MSK<1:0>:** Mask Source for Filter 0 bits (same values as bits<15:14>) ## 22.0 CHARGE TIME MEASUREMENT UNIT (CTMU) - Note 1: This data sheet summarizes the features of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Charge Time Measurement Unit (CTMU)" (DS70661) in the "dsPIC33/PIC24 Family Reference Manual", which is available on 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 Charge Time Measurement Unit is a flexible analog module that provides accurate differential time measurement between pulse sources, as well as asynchronous pulse generation. Its key features include: - · Four Edge Input Trigger Sources - · Polarity Control for Each Edge Source - · Control of Edge Sequence - · Control of Response to Edges - · Precise Time Measurement Resolution of 1 ns - Accurate Current Source Suitable for Capacitive Measurement - On-Chip Temperature Measurement using a Built-in Diode Together with other on-chip analog modules, the CTMU can be used to precisely measure time, measure capacitance, measure relative changes in capacitance or generate output pulses that are independent of the system clock. The CTMU module is ideal for interfacing with capacitive-based sensors. The CTMU is controlled through three registers: CTMUCON1, CTMUCON2 and CTMUICON. CTMUCON1 and CTMUICON2 enable the module and control edge source selection, edge source polarity selection and edge sequencing. The CTMUICON register controls the selection and trim of the current source. #### REGISTER 24-10: PTGADJ: PTG ADJUST REGISTER(1) | R/W-0 | |--------------|-------|-------|-------|-------|-------|-------|-------|--| | PTGADJ<15:8> | | | | | | | | | | bit 15 | | | | | | | | | | R/W-0 | |-------------|-------|-------|-------|-------|-------|-------|-------|--| | PTGADJ<7:0> | | | | | | | | | | bit 7 | | | | | | | | | 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 bit 15-0 **PTGADJ<15:0>:** PTG Adjust Register bits This register holds user-supplied data to be added to the PTGTxLIM, PTGCxLIM, PTGSDLIM or PTGL0 registers with the PTGADD command. **Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1). #### REGISTER 24-11: PTGL0: PTG LITERAL 0 REGISTER<sup>(1)</sup> | R/W-0 | |-------------|-------|-------|-------|-------|-------|-------|-------|--| | PTGL0<15:8> | | | | | | | | | | bit 15 | | | | | | | bit 8 | | | R/W-0 | |------------|-------|-------|-------|-------|-------|-------|-------|--| | PTGL0<7:0> | | | | | | | | | | bit 7 | | | | | | | | | 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 bit 15-0 **PTGL0<15:0>:** PTG Literal 0 Register bits This register holds the 16-bit value to be written to the AD1CHS0 register with the PTGCTRL Step command. **Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1). #### 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 $\geq 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 | 300 mA | | Maximum current into VDD pin <sup>(2)</sup> | 300 mA | | 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. #### 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging **RECOMMENDED LAND PATTERN** | | MILLIMETERS | | | | |----------------------------|-------------|------|------|------| | Dimension | MIN | NOM | MAX | | | Contact Pitch | 0.65 BSC | | | | | Optional Center Pad Width | W2 | | | 6.60 | | Optional Center Pad Length | T2 | | | 6.60 | | Contact Pad Spacing | C1 | | 8.00 | | | Contact Pad Spacing | C2 | | 8.00 | | | Contact Pad Width (X44) | X1 | | | 0.35 | | Contact Pad Length (X44) | Y1 | | | 0.85 | | Distance Between Pads | G | 0.25 | · | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2103B | Remappable Input for U1RX | 176 | Memory Map for PIC24EP256GP/MC20X/50X | | | |---------------------------------------------------|----------|----------------------------------------------|-------|-----| | Reset System | | Devices | | 60 | | Shared Port Structure | | Memory Map for PIC24EP32GP/MC20X/50X | | 00 | | Single-Phase Synchronous Buck Converter | | Devices | | 57 | | | | Memory Map for PIC24EP512GP/MC20X/50X | | 51 | | SPIx ModuleSuggested Oscillator Circuit Placement | | | | 61 | | Type B Timer (Timer2 and Timer4) | | Devices Memory Map for PIC24EP64GP/MC20X/50X | | 0 1 | | | | • | | E0 | | Type B/Type C Timer Pair (32-Bit Timer) | | Devices | | | | Type C Timer (Timer3 and Timer5) | | Near Data Space | | | | UARTx Module | | Organization, Alignment | | | | User-Programmable Blanking Function | | SFR Space | | | | Watchdog Timer (WDT) | | Width | ••••• | 51 | | Brown-out Reset (BOR) | 384 | Data Memory | | | | С | | Arbitration and Bus Master Priority | | 110 | | | | Data Space | | | | C Compilers | 000 | Extended X | | | | MPLAB XC Compilers | 398 | Paged Memory Scheme | | 105 | | Charge Time Measurement Unit. See CTMU. | | DC and AC Characteristics | | | | Code Examples | | Graphs | | 475 | | IC1 Connection to QEI1 Input on | | DC Characteristics | | | | Pin 43 of dsPIC33EPXXXMC206 | | BOR | | | | Port Write/Read | 174 | CTMU Current Source Requirements | | | | PWMx Write-Protected Register | | Doze Current (IDOZE) | 407, | 469 | | Unlock Sequence | | High Temperature | | 468 | | PWRSAV Instruction Syntax | | I/O Pin Input Specifications | | 408 | | Code Protection | 379, 386 | I/O Pin Output Specifications | 411, | 470 | | CodeGuard Security | 379, 386 | Idle Current (IIDLE) | 405, | 469 | | Configuration Bits | 379 | Op Amp/Comparator Requirements | | 455 | | Description | 381 | Op Amp/Comparator Voltage Reference | | | | Configuration Byte Register Map | 380 | Requirements | | 457 | | Configuring Analog and Digital Port Pins | 174 | Operating Current (IDD) | | | | CPU | | Operating MIPS vs. Voltage | | | | Addressing Modes | 35 | Power-Down Current (IPD) | | | | Clocking System Options | | Program Memory | | | | Fast RC (FRC) Oscillator | | Temperature and Voltage | | | | FRC Oscillator with PLL | | Temperature and Voltage Specifications | | | | FRC Oscillator with Postscaler | | Thermal Operating Conditions | | | | Low-Power RC (LPRC) Oscillator | | Watchdog Timer Delta Current | | | | Primary (XT, HS, EC) Oscillator | | Demo/Development Boards, Evaluation and | | 401 | | Primary Oscillator with PLL | | Starter Kits | | 400 | | Control Registers | | | | | | Data Space Addressing | | Development Support | | | | • | | Third-Party Tools | | 400 | | Instruction Set<br>Resources | | DMA Controller | | 440 | | | 39 | Channel to Peripheral Associations | | | | CTMU | 047 | Control Registers | | | | Control Registers | | DMAxCNT | | | | Resources | | DMAxCON | | | | Customer Change Notification Service | | DMAxPAD | | | | Customer Notification Service | | DMAxREQ | | | | Customer Support | 524 | DMAxSTA | | | | D | | DMAxSTB | | 141 | | | | Resources | | 141 | | Data Address Space | | Supported Peripherals | | 139 | | Memory Map for dsPIC33EP128MC20X/50X, | | Doze Mode | | 165 | | dsPIC33EP128GP50X Devices | | DSP Engine | | 44 | | Memory Map for dsPIC33EP256MC20X/50X, | | _ | | | | dsPIC33EP256GP50X Devices | 55 | E | | | | Memory Map for dsPIC33EP32MC20X/50X, | | ECAN Message Buffers | | | | dsPIC33EP32GP50X Devices | 52 | Word 0 | | 310 | | Memory Map for dsPIC33EP512MC20X/50X, | | Word 1 | | | | dsPIC33EP512GP50X Devices | | Word 2 | | | | Memory Map for dsPIC33EP64MC20X/50X, | | Word 3 | | | | dsPIC33EP64GP50X Devices | 53 | Word 4 | | | | Memory Map for PIC24EP128GP/MC20X/50X | | Word 5 | | | | Devices | | Word 6 | | | | DOVIDOS | | Word 7 | | 313 | | | | | | | | DSPIC33EPXXXGP50X, DSPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X | | | | | |-----------------------------------------------------------------|--|--|--|--| | NOTES: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### Note the following details of the code protection feature on Microchip devices: - Microchip products meet the specification contained in their particular Microchip Data Sheet. - Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions. - There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property. - Microchip is willing to work with the customer who is concerned about the integrity of their code. - Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable." Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act. Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights. # QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV == ISO/TS 16949 == #### **Trademarks** The Microchip name and logo, the Microchip logo, dsPIC, FlashFlex, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MTP, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries. Analog-for-the-Digital Age, Application Maestro, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, SQI, Serial Quad I/O, Total Endurance, TSHARC, UniWinDriver, WiperLock, ZENA and Z-Scale are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. SQTP is a service mark of Microchip Technology Incorporated in the U.S.A. GestIC and ULPP are registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries. All other trademarks mentioned herein are property of their respective companies. © 2011-2013, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved. Printed on recycled paper. ISBN: 9781620773949 Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.