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 | 70 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 | 53 | | Program Memory Size | 64KB (22K x 24) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 4K x 16 | | /oltage - Supply (Vcc/Vdd) | 3V ~ 3.6V | | Data Converters | A/D 16x10b/12b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 64-TQFP | | Supplier Device Package | 64-TQFP (10x10) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/dspic33ep64mc506t-i-pt | TABLE 2: dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X MOTOR CONTROL FAMILIES (CONTINUED) | | | - | ` | | | | | | | | | | | | | | | | | | | |-------------------|--------------------------------|-------------------------------|--------------|----------------------|---------------|----------------|------------------------------------------------|------------------------------|--------|---------------------|------------------|------------------------------------|-----|---------------|------------------------------|---------------------|------|-----|----------|-----------|-----------------------| | | <u>~</u> | (SE | | | | Rei | nappa | ble P | eriphe | erals | | | | | | | | | | | | | Device | Page Erase Size (Instructions) | Program Flash Memory (Kbytes) | RAM (Kbytes) | 16-Bit/32-Bit Timers | Input Capture | Output Compare | Motor Control PWM <sup>(4)</sup><br>(Channels) | Quadrature Encoder Interface | UART | ( <sub>2</sub> )IdS | ECAN™ Technology | External Interrupts <sup>(3)</sup> | РС™ | CRC Generator | 10-Bit/12-Bit ADC (Channels) | Op Amps/Comparators | СТМО | PTG | I/O Pins | Pins | Packages | | dsPIC33EP32MC504 | 512 | 32 | 4 | | | | | | | | | | | | | | | | | | | | dsPIC33EP64MC504 | 1024 | 64 | 8 | | | | | | | | | | | | | | | | | | VTLA <sup>(5)</sup> , | | dsPIC33EP128MC504 | 1024 | 128 | 16 | 5 | 4 | 4 | 6 | 1 | 2 | 2 | 1 | 3 | 2 | 1 | 9 | 3/4 | Yes | Yes | 35 | 44/<br>48 | TQFP,<br>QFN, | | dsPIC33EP256MC504 | 1024 | 256 | 32 | | | | | | | | | | | | | | | | | 10 | UQFN | | dsPIC33EP512MC504 | 1024 | 512 | 48 | | | | | | | | | | | | | | | | | | | | dsPIC33EP64MC506 | 1024 | 64 | 8 | | | | | | | | | | | | | | | | | | | | dsPIC33EP128MC506 | 1024 | 128 | 16 | 5 | 4 | 4 | 6 | 1 | 2 | 2 | 1 | 3 | 2 | 1 | 16 | 3/4 | Yes | Yes | 53 | 64 | TQFP, | | dsPIC33EP256MC506 | 1024 | 256 | 32 | 3 | 4 | 4 | O | 1 | | | 1 | 3 | | ı | 10 | 3/4 | res | res | 55 | 04 | QFN | | dsPIC33EP512MC506 | 1024 | 512 | 48 | | | | | | | | | | | | | | | | | | | Note 1: On 28-pin devices, Comparator 4 does not have external connections. Refer to Section 25.0 "Op Amp/Comparator Module" for details. - 2: Only SPI2 is remappable. - **3:** INT0 is not remappable. - 4: Only the PWM Faults are remappable. - 5: The SSOP and VTLA packages are not available for devices with 512 Kbytes of memory. #### 1.0 DEVICE OVERVIEW 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 resource. To complement the information in this data sheet, refer to the related section of the "dsPIC33/ PIC24 Family Reference Manual", which is available from the Microchip web site (www.microchip.com) 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information. This document contains device-specific information for the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/ 50X and PIC24EPXXXGP/MC20X Digital Signal Controller (DSC) and Microcontroller (MCU) devices. dsPIC33EPXXXMC20X/50X and dsPIC33EPXXXGP50X devices contain extensive Digital Signal Processor (DSP) functionality with a high-performance, 16-bit MCU architecture. Figure 1-1 shows a general block diagram of the core and peripheral modules. Table 1-1 lists the functions of the various pins shown in the pinout diagrams. FIGURE 1-1: dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X BLOCK DIAGRAM TABLE 1-1: PINOUT I/O DESCRIPTIONS (CONTINUED) | Pin Name <sup>(4)</sup> | Pin<br>Type | Buffer<br>Type | PPS | Description | |-------------------------|-------------|----------------|-----|-------------------------------------------------------------------------------| | C1IN1- | I | Analog | No | Op Amp/Comparator 1 Negative Input 1. | | C1IN2- | ı | Analog | No | Comparator 1 Negative Input 2. | | C1IN1+ | ı | Analog | No | Op Amp/Comparator 1 Positive Input 1. | | OA1OUT | 0 | Analog | No | Op Amp 1 output. | | C1OUT | 0 | | Yes | Comparator 1 output. | | C2IN1- | I | Analog | No | Op Amp/Comparator 2 Negative Input 1. | | C2IN2- | I | Analog | No | Comparator 2 Negative Input 2. | | C2IN1+ | I | Analog | No | Op Amp/Comparator 2 Positive Input 1. | | OA2OUT | О | Analog | No | Op Amp 2 output. | | C2OUT | 0 | _ | Yes | Comparator 2 output. | | C3IN1- | I | Analog | No | Op Amp/Comparator 3 Negative Input 1. | | C3IN2- | I | Analog | No | Comparator 3 Negative Input 2. | | C3IN1+ | I | Analog | No | Op Amp/Comparator 3 Positive Input 1. | | OA3OUT | О | Analog | No | Op Amp 3 output. | | C3OUT | 0 | _ | Yes | Comparator 3 output. | | C4IN1- | I | Analog | No | Comparator 4 Negative Input 1. | | C4IN1+ | 1 | Analog | No | Comparator 4 Positive Input 1. | | C4OUT | 0 | _ | Yes | Comparator 4 output. | | CVREF10 | 0 | Analog | No | Op amp/comparator voltage reference output. | | CVREF20 | 0 | Analog | No | Op amp/comparator voltage reference divided by 2 output. | | PGED1 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 1. | | PGEC1 | ı | ST | No | Clock input pin for Programming/Debugging Communication Channel 1. | | PGED2 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 2. | | PGEC2 | ı | ST | No | Clock input pin for Programming/Debugging Communication Channel 2. | | PGED3 | I/O | ST | No | Data I/O pin for Programming/Debugging Communication Channel 3. | | PGEC3 | l | ST | No | Clock input pin for Programming/Debugging Communication Channel 3. | | MCLR | I/P | ST | No | Master Clear (Reset) input. This pin is an active-low Reset to the device. | | AVDD | Р | Р | No | Positive supply for analog modules. This pin must be connected at all times. | | AVss | Р | Р | No | Ground reference for analog modules. This pin must be connected at all times. | | VDD | Р | _ | No | Positive supply for peripheral logic and I/O pins. | | VCAP | Р | _ | No | CPU logic filter capacitor connection. | | Vss | Р | _ | No | Ground reference for logic and I/O pins. | | VREF+ | I | Analog | No | Analog voltage reference (high) input. | | VREF- | I | Analog | No | Analog voltage reference (low) input. | Legend:CMOS = CMOS compatible input or outputAnalog = Analog inputP = PowerST = Schmitt Trigger input with CMOS levelsO = OutputI = InputPPS = Peripheral Pin SelectTTL = TTL input buffer Note 1: This pin is available on dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices only. - 2: This pin is available on dsPIC33EPXXXGP/MC50X devices only. - 3: This is the default Fault on Reset for dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices. See Section 16.0 "High-Speed PWM Module (dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X Devices Only)" for more information. - 4: Not all pins are available in all packages variants. See the "Pin Diagrams" section for pin availability. - 5: There is an internal pull-up resistor connected to the TMS pin when the JTAG interface is active. See the JTAGEN bit field in Table 27-2. FIGURE 3-1: dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X CPU BLOCK DIAGRAM # REGISTER 7-3: INTCON1: INTERRUPT CONTROL REGISTER 1 (CONTINUED) | bit 4 | MATHERR: Math Error Status bit | |-------|-------------------------------------------------------------------------------------------------------| | | 1 = Math error trap has occurred | | | 0 = Math error trap has not occurred | | bit 3 | ADDRERR: Address Error Trap Status bit | | | <ul><li>1 = Address error trap has occurred</li><li>0 = Address error trap has not occurred</li></ul> | | bit 2 | STKERR: Stack Error Trap Status bit | | | 1 = Stack error trap has occurred | | | 0 = Stack error trap has not occurred | | bit 1 | <b>OSCFAIL:</b> Oscillator Failure Trap Status bit | | | 1 = Oscillator failure trap has occurred | | | 0 = Oscillator failure trap has not occurred | | bit 0 | Unimplemented: Read as '0' | Note 1: These bits are available on dsPIC33EPXXXMC20X/50X and dsPIC33EPXXXGP50X devices only. # 11.4.4.2 Output Mapping In contrast to inputs, the outputs of the Peripheral Pin Select options are mapped on the basis of the pin. In this case, a control register associated with a particular pin dictates the peripheral output to be mapped. The RPORx registers are used to control output mapping. Like the RPINRx registers, each register contains sets of 6-bit fields, with each set associated with one RPn pin (see Register 11-18 through Register 11-27). The value of the bit field corresponds to one of the peripherals and that peripheral's output is mapped to the pin (see Table 11-3 and Figure 11-3). A null output is associated with the output register Reset value of '0'. This is done to ensure that remappable outputs remain disconnected from all output pins by default. FIGURE 11-3: MULTIPLEXING REMAPPABLE OUTPUT FOR RPn # 11.4.4.3 Mapping Limitations The control schema of the peripheral select pins is not limited to a small range of fixed peripheral configurations. There are no mutual or hardware-enforced lockouts between any of the peripheral mapping SFRs. Literally any combination of peripheral mappings across any or all of the RPn pins is possible. This includes both many-to-one and one-to-many mappings of peripheral inputs and outputs to pins. While such mappings may be technically possible from a configuration point of view, they may not be supportable from an electrical point of view. TABLE 11-3: OUTPUT SELECTION FOR REMAPPABLE PINS (RPn) | Function | RPxR<5:0> | Output Name | |-------------------------|-----------|-----------------------------------------------| | Default PORT | 000000 | RPn tied to Default Pin | | U1TX | 000001 | RPn tied to UART1 Transmit | | U2TX | 000011 | RPn tied to UART2 Transmit | | SDO2 | 001000 | RPn tied to SPI2 Data Output | | SCK2 | 001001 | RPn tied to SPI2 Clock Output | | SS2 | 001010 | RPn tied to SPI2 Slave Select | | C1TX <sup>(2)</sup> | 001110 | RPn tied to CAN1 Transmit | | OC1 | 010000 | RPn tied to Output Compare 1 Output | | OC2 | 010001 | RPn tied to Output Compare 2 Output | | OC3 | 010010 | RPn tied to Output Compare 3 Output | | OC4 | 010011 | RPn tied to Output Compare 4 Output | | C1OUT | 011000 | RPn tied to Comparator Output 1 | | C2OUT | 011001 | RPn tied to Comparator Output 2 | | C3OUT | 011010 | RPn tied to Comparator Output 3 | | SYNCO1 <sup>(1)</sup> | 101101 | RPn tied to PWM Primary Time Base Sync Output | | QEI1CCMP <sup>(1)</sup> | 101111 | RPn tied to QEI 1 Counter Comparator Output | | REFCLKO | 110001 | RPn tied to Reference Clock Output | | C4OUT | 110010 | RPn tied to Comparator Output 4 | Note 1: This function is available in dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices only. 2: This function is available in dsPIC33EPXXXGP/MC50X devices only. # 13.2 Timer Control Registers # REGISTER 13-1: TxCON: (TIMER2 AND TIMER4) CONTROL REGISTER | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|-----|-------|-----|-----|-----|-----|-------| | TON | _ | TSIDL | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | |-------|-------|--------|--------|-------|-----|-------|-------| | _ | TGATE | TCKPS1 | TCKPS0 | T32 | _ | TCS | _ | | 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 **TON:** Timerx On bit When T32 = 1: 1 = Starts 32-bit Timerx/y 0 = Stops 32-bit Timerx/y When T32 = 0: 1 = Starts 16-bit Timerx 0 = Stops 16-bit Timerx bit 14 Unimplemented: Read as '0' bit 13 TSIDL: Timerx Stop in Idle Mode bit 1 = Discontinues module operation when device enters Idle mode 0 = Continues module operation in Idle mode bit 12-7 Unimplemented: Read as '0' bit 6 TGATE: Timerx Gated Time Accumulation Enable bit When TCS = 1: This bit is ignored. When TCS = 0: 1 = Gated time accumulation is enabled 0 = Gated time accumulation is disabled bit 5-4 TCKPS<1:0>: Timerx Input Clock Prescale Select bits 11 = 1:256 10 = 1:64 01 = 1:8 00 = 1:1 bit 3 T32: 32-Bit Timer Mode Select bit 1 = Timerx and Timery form a single 32-bit timer 0 = Timerx and Timery act as two 16-bit timers bit 2 Unimplemented: Read as '0' bit 1 TCS: Timerx Clock Source Select bit 1 = External clock is from pin, TxCK (on the rising edge) 0 = Internal clock (FP) bit 0 Unimplemented: Read as '0' # 16.0 HIGH-SPEED PWM MODULE (dsPIC33EPXXXMC20X/50X AND PIC24EPXXXMC20X DEVICES ONLY) Note 1: This data sheet summarizes the features of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X families of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "High-Speed PWM" (DS70645) 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 dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices support a dedicated Pulse-Width Modulation (PWM) module with up to 6 outputs. The high-speed PWMx module consists of the following major features: - · Three PWM generators - · Two PWM outputs per PWM generator - · Individual period and duty cycle for each PWM pair - Duty cycle, dead time, phase shift and frequency resolution of Tcy/2 (7.14 ns at Fcy = 70MHz) - Independent Fault and current-limit inputs for six PWM outputs - · Redundant output - · Center-Aligned PWM mode - · Output override control - Chop mode (also known as Gated mode) - · Special Event Trigger - · Prescaler for input clock - · PWMxL and PWMxH output pin swapping - Independent PWM frequency, duty cycle and phase-shift changes for each PWM generator - · Dead-time compensation - Enhanced Leading-Edge Blanking (LEB) functionality - · Frequency resolution enhancement - PWM capture functionality Note: In Edge-Aligned PWM mode, the duty cycle, dead time, phase shift and frequency resolution are 8.32 ns. The high-speed PWMx module contains up to three PWM generators. Each PWM generator provides two PWM outputs: PWMxH and PWMxL. The master time base generator provides a synchronous signal as a common time base to synchronize the various PWM outputs. The individual PWM outputs are available on the output pins of the device. The input Fault signals and current-limit signals, when enabled, can monitor and protect the system by placing the PWM outputs into a known "safe" state. Each PWMx can generate a trigger to the ADC module to sample the analog signal at a specific instance during the PWM period. In addition, the high-speed PWMx module also generates a Special Event Trigger to the ADC module based on either of the two master time bases. The high-speed PWMx module can synchronize itself with an external signal or can act as a synchronizing source to any external device. The SYNCI1 input pin that utilizes PPS, can synchronize the high-speed PWMx module with an external signal. The SYNCO1 pin is an output pin that provides a synchronous signal to an external device. Figure 16-1 illustrates an architectural overview of the high-speed PWMx module and its interconnection with the CPU and other peripherals. #### 16.1 PWM Faults The PWMx module incorporates multiple external Fault inputs to include FLT1 and FLT2 which are remappable using the PPS feature, FLT3 and FLT4 which are available only on the larger 44-pin and 64-pin packages, and FLT32 which has been implemented with Class B safety features, and is available on a fixed pin on all dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices. These Faults provide a safe and reliable way to safely shut down the PWM outputs when the Fault input is asserted. #### 16.1.1 PWM FAULTS AT RESET During any Reset event, the PWMx module maintains ownership of the Class B Fault, FLT32. At Reset, this Fault is enabled in Latched mode to ensure the fail-safe power-up of the application. The application software must clear the PWM Fault before enabling the high-speed motor control PWMx module. To clear the Fault condition, the FLT32 pin must first be pulled low externally or the internal pull-down resistor in the CNPDx register can be enabled. **Note:** The Fault mode may be changed using the FLTMOD<1:0> bits (FCLCON<1:0>), regardless of the state of FLT32. # REGISTER 16-16: LEBCONX: PWMx LEADING-EDGE BLANKING CONTROL REGISTER | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | U-0 | |--------|-------|-------|-------|----------|---------|-----|-------| | PHR | PHF | PLR | PLF | FLTLEBEN | CLLEBEN | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|--------------------|--------------------|-------|-------|-------|-------| | _ | _ | BCH <sup>(1)</sup> | BCL <sup>(1)</sup> | BPHH | BPHL | BPLH | BPLL | | bit 7 | | | | | | | bit 0 | | R = Readab | le hit | W = Writable bit | U = Unimplemented bit, | read as '0' | |---------------|-------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------| | -n = Value a | | '1' = Bit is set | '0' = Bit is cleared | x = Bit is unknown | | -II – Value a | IT OIL | i - Dit is set | 0 - Dit is cleared | X - Bit is utiknown | | bit 15 | 1 = Rising | MxH Rising Edge Trigger E<br>I edge of PWMxH will trigge<br>ng-Edge Blanking ignores ri | er Leading-Edge Blanking cour | nter | | bit 14 | 1 = Falling | MxH Falling Edge Trigger E<br>g edge of PWMxH will triggen<br>ng-Edge Blanking ignores fa | er Leading-Edge Blanking cou | nter | | bit 13 | 1 = Rising | MxL Rising Edge Trigger Er<br>ı edge of PWMxL will trigge<br>ng-Edge Blanking ignores ri | r Leading-Edge Blanking coun | iter | | bit 12 | 1 = Falling | MxL Falling Edge Trigger Er<br>g edge of PWMxL will trigge<br>ng-Edge Blanking ignores fa | er Leading-Edge Blanking cour | nter | | bit 11 | 1 = Leadii | <b>N:</b> Fault Input Leading-Edg<br>ng-Edge Blanking is applied<br>ng-Edge Blanking is not app | • | | | bit 10 | 1 = Leadii | | lge Blanking Enable bit<br>I to selected current-limit input<br>blied to selected current-limit ir | | | bit 9-6 | Unimplen | nented: Read as '0' | | | | bit 5 | 1 = State | nking in Selected Blanking s<br>blanking (of current-limit an<br>anking when selected blank | d/or Fault input signals) when | selected blanking signal is high | | bit 4 | 1 = State | nking in Selected Blanking S<br>blanking (of current-limit an<br>anking when selected blank | d/or Fault input signals) when | selected blanking signal is low | | bit 3 | 1 = State | anking in PWMxH High Ena<br>blanking (of current-limit an<br>anking when PWMxH outpu | d/or Fault input signals) when | PWMxH output is high | | bit 2 | 1 = State | anking in PWMxH Low Ena<br>blanking (of current-limit an<br>anking when PWMxH outpu | d/or Fault input signals) when | PWMxH output is low | | bit 1 | 1 = State | anking in PWMxL High Ena<br>blanking (of current-limit an<br>anking when PWMxL output | d/or Fault input signals) when | PWMxL output is high | | bit 0 | 1 = State | anking in PWMxL Low Enab<br>blanking (of current-limit an<br>anking when PWMxL output | d/or Fault input signals) when | PWMxL output is low | Note 1: The blanking signal is selected via the BLANKSELx bits in the AUXCONx register. Legend: # REGISTER 20-2: UxSTA: UARTx STATUS AND CONTROL REGISTER (CONTINUED) - bit 5 **ADDEN:** Address Character Detect bit (bit 8 of received data = 1) - 1 = Address Detect mode is enabled; if 9-bit mode is not selected, this does not take effect - 0 = Address Detect mode is disabled - bit 4 RIDLE: Receiver Idle bit (read-only) - 1 = Receiver is Idle - 0 = Receiver is active - bit 3 **PERR:** Parity Error Status bit (read-only) - 1 = Parity error has been detected for the current character (character at the top of the receive FIFO) - 0 = Parity error has not been detected - bit 2 **FERR:** Framing Error Status bit (read-only) - 1 = Framing error has been detected for the current character (character at the top of the receive FIFO) - 0 = Framing error has not been detected - bit 1 OERR: Receive Buffer Overrun Error Status bit (clear/read-only) - 1 = Receive buffer has overflowed - 0 = Receive buffer has not overflowed; clearing a previously set OERR bit (1 $\rightarrow$ 0 transition) resets the receiver buffer and the UxRSR to the empty state - bit 0 URXDA: UARTx Receive Buffer Data Available bit (read-only) - 1 = Receive buffer has data, at least one more character can be read - 0 = Receive buffer is empty - **Note 1:** Refer to the "**UART**" (DS70582) section in the "dsPIC33/PIC24 Family Reference Manual" for information on enabling the UARTx module for transmit operation. #### REGISTER 23-1: AD1CON1: ADC1 CONTROL REGISTER 1 (CONTINUED) #### bit 7-5 SSRC<2:0>: Sample Trigger Source Select bits #### If SSRCG = 1: - 111 = Reserved - 110 = PTGO15 primary trigger compare ends sampling and starts conversion<sup>(1)</sup> - 101 = PTGO14 primary trigger compare ends sampling and starts conversion<sup>(1)</sup> - 100 = PTGO13 primary trigger compare ends sampling and starts conversion (1) - 011 = PTGO12 primary trigger compare ends sampling and starts conversion<sup>(1)</sup> - 010 = PWM Generator 3 primary trigger compare ends sampling and starts conversion<sup>(2)</sup> - 001 = PWM Generator 2 primary trigger compare ends sampling and starts conversion<sup>(2)</sup> - 000 = PWM Generator 1 primary trigger compare ends sampling and starts conversion<sup>(2)</sup> #### If SSRCG = 0: - 111 = Internal counter ends sampling and starts conversion (auto-convert) - 110 = CTMU ends sampling and starts conversion - 101 = Reserved - 100 = Timer5 compare ends sampling and starts conversion - 011 = PWM primary Special Event Trigger ends sampling and starts conversion(2) - 010 = Timer3 compare ends sampling and starts conversion - 001 = Active transition on the INT0 pin ends sampling and starts conversion - 000 = Clearing the Sample bit (SAMP) ends sampling and starts conversion (Manual mode) - bit 4 SSRCG: Sample Trigger Source Group bit See SSRC<2:0> for details. bit 3 SIMSAM: Simultaneous Sample Select bit (only applicable when CHPS<1:0> = 01 or 1x) In 12-bit mode (AD21B = 1), SIMSAM is Unimplemented and is Read as '0': - 1 = Samples CH0, CH1, CH2, CH3 simultaneously (when CHPS<1:0> = 1x); or samples CH0 and CH1 simultaneously (when CHPS<1:0> = 01) - 0 = Samples multiple channels individually in sequence - bit 2 ASAM: ADC1 Sample Auto-Start bit - 1 = Sampling begins immediately after the last conversion; SAMP bit is auto-set - 0 = Sampling begins when the SAMP bit is set - bit 1 SAMP: ADC1 Sample Enable bit - 1 = ADC Sample-and-Hold amplifiers are sampling - 0 = ADC Sample-and-Hold amplifiers are holding If ASAM = 0, software can write '1' to begin sampling. Automatically set by hardware if ASAM = 1. If SSRC<2:0> = 000, software can write '0' to end sampling and start conversion. If SSRC<2:0> $\neq$ 000, automatically cleared by hardware to end sampling and start conversion. - bit 0 **DONE:** ADC1 Conversion Status bit<sup>(3)</sup> - 1 = ADC conversion cycle has completed - 0 = ADC conversion has not started or is in progress Automatically set by hardware when the ADC conversion is complete. Software can write '0' to clear the DONE status bit (software is not allowed to write '1'). Clearing this bit does NOT affect any operation in progress. Automatically cleared by hardware at the start of a new conversion. - Note 1: See Section 24.0 "Peripheral Trigger Generator (PTG) Module" for information on this selection. - 2: This setting is available in dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices only. - 3: Do not clear the DONE bit in software if Auto-Sample is enabled (ASAM = 1). ### REGISTER 23-6: AD1CHS0: ADC1 INPUT CHANNEL 0 SELECT REGISTER (CONTINUED) ``` CH0SA<4:0>: Channel 0 Positive Input Select for Sample MUXA bits(1) bit 4-0 11111 = Open; use this selection with CTMU capacitive and time measurement 11110 = Channel 0 positive input is connected to the CTMU temperature measurement diode (CTMU TEMP) 11101 = Reserved 11100 = Reserved 11011 = Reserved 11010 = Channel 0 positive input is the output of OA3/AN6<sup>(2,3)</sup> 11001 = Channel 0 positive input is the output of OA2/AN0<sup>(2)</sup> 11000 = Channel 0 positive input is the output of OA1/AN3<sup>(2)</sup> 10110 = Reserved 10000 = Reserved 01111 = Channel 0 positive input is AN15<sup>(1,3)</sup> 01110 = Channel 0 positive input is AN14<sup>(1,3)</sup> 01101 = Channel 0 positive input is AN13<sup>(1,3)</sup> 00010 = Channel 0 positive input is AN2(1,3) 00001 = Channel 0 positive input is AN1<sup>(1,3)</sup> 00000 = Channel 0 positive input is AN0^{(1,3)} ``` - Note 1: AN0 through AN7 are repurposed when comparator and op amp functionality is enabled. See Figure 23-1 to determine how enabling a particular op amp or comparator affects selection choices for Channels 1, 2 and 3. - 2: The OAx input is used if the corresponding op amp is selected (OPMODE (CMxCON<10>) = 1); otherwise, the ANx input is used. - **3:** See the "Pin Diagrams" section for the available analog channels for each device. # REGISTER 24-8: PTGC1LIM: PTG COUNTER 1 LIMIT REGISTER<sup>(1)</sup> | R/W-0 | | | |--------|----------------|-------|-------|-------|-------|-------|-------|--|--|--| | | PTGC1LIM<15:8> | | | | | | | | | | | bit 15 | | | | | | | bit 8 | | | | | R/W-0 | | | |-------|---------------|-------|-------|-------|-------|-------|-------|--|--|--| | | PTGC1LIM<7:0> | | | | | | | | | | | bit 7 | | | | | | | bit 0 | | | | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-0 **PTGC1LIM<15:0>:** PTG Counter 1 Limit Register bits May be used to specify the loop count for the PTGJMPC1 Step command or as a limit register for the General Purpose Counter 1. **Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1). # REGISTER 24-9: PTGHOLD: PTG HOLD REGISTER(1) | R/W-0 |---------------|-------|-------|-------|-------|-------|-------|-------| | PTGHOLD<15:8> | | | | | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|---------|-------|-------|-------| | | | | PTGHO | LD<7:0> | | | | | bit 7 | | | | | | | bit 0 | Legend: R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown bit 15-0 PTGHOLD<15:0>: PTG General Purpose Hold Register bits Holds user-supplied data to be copied to the PTGTxLIM, PTGCxLIM, PTGSDLIM or PTGL0 registers with the PTGCOPY command. **Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1). | OTES: | | | | |--------|--|--|--| | /I E3. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 29.6 MPLAB X SIM Software Simulator The MPLAB X SIM Software Simulator allows code development in a PC-hosted environment by simulating the PIC MCUs and dsPIC DSCs on an instruction level. On any given instruction, the data areas can be examined or modified and stimuli can be applied from a comprehensive stimulus controller. Registers can be logged to files for further run-time analysis. The trace buffer and logic analyzer display extend the power of the simulator to record and track program execution, actions on I/O, most peripherals and internal registers. The MPLAB X SIM Software Simulator fully supports symbolic debugging using the MPLAB XC Compilers, and the MPASM and MPLAB Assemblers. The software simulator offers the flexibility to develop and debug code outside of the hardware laboratory environment, making it an excellent, economical software development tool. # 29.7 MPLAB REAL ICE In-Circuit Emulator System The MPLAB REAL ICE In-Circuit Emulator System is Microchip's next generation high-speed emulator for Microchip Flash DSC and MCU devices. It debugs and programs all 8, 16 and 32-bit MCU, and DSC devices with the easy-to-use, powerful graphical user interface of the MPLAB X IDE. The emulator is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with either a connector compatible with in-circuit debugger systems (RJ-11) or with the new high-speed, noise tolerant, Low-Voltage Differential Signal (LVDS) interconnection (CAT5). The emulator is field upgradable through future firmware downloads in MPLAB X IDE. MPLAB REAL ICE offers significant advantages over competitive emulators including full-speed emulation, run-time variable watches, trace analysis, complex breakpoints, logic probes, a ruggedized probe interface and long (up to three meters) interconnection cables. # 29.8 MPLAB ICD 3 In-Circuit Debugger System The MPLAB ICD 3 In-Circuit Debugger System is Microchip's most cost-effective, high-speed hardware debugger/programmer for Microchip Flash DSC and MCU devices. It debugs and programs PIC Flash microcontrollers and dsPIC DSCs with the powerful, yet easy-to-use graphical user interface of the MPLAB IDE. The MPLAB ICD 3 In-Circuit Debugger probe is connected to the design engineer's PC using a high-speed USB 2.0 interface and is connected to the target with a connector compatible with the MPLAB ICD 2 or MPLAB REAL ICE systems (RJ-11). MPLAB ICD 3 supports all MPLAB ICD 2 headers. # 29.9 PICkit 3 In-Circuit Debugger/ Programmer The MPLAB PICkit 3 allows debugging and programming of PIC and dsPIC Flash microcontrollers at a most affordable price point using the powerful graphical user interface of the MPLAB IDE. The MPLAB PICkit 3 is connected to the design engineer's PC using a full-speed USB interface and can be connected to the target via a Microchip debug (RJ-11) connector (compatible with MPLAB ICD 3 and MPLAB REAL ICE). The connector uses two device I/O pins and the Reset line to implement in-circuit debugging and In-Circuit Serial Programming™ (ICSP™). # 29.10 MPLAB PM3 Device Programmer The MPLAB PM3 Device Programmer is a universal, CE compliant device programmer with programmable voltage verification at VDDMIN and VDDMAX for maximum reliability. It features a large LCD display (128 x 64) for menus and error messages, and a modular, detachable socket assembly to support various package types. The ICSP cable assembly is included as a standard item. In Stand-Alone mode, the MPLAB PM3 Device Programmer can read, verify and program PIC devices without a PC connection. It can also set code protection in this mode. The MPLAB PM3 connects to the host PC via an RS-232 or USB cable. The MPLAB PM3 has high-speed communications and optimized algorithms for quick programming of large memory devices, and incorporates an MMC card for file storage and data applications. FIGURE 30-17: SPI2 MASTER MODE (FULL-DUPLEX, CKE = 0, CKP = x, SMP = 1) TIMING CHARACTERISTICS TABLE 30-36: SPI2 MASTER MODE (FULL-DUPLEX, CKE = 0, CKP = x, SMP = 1) TIMING REQUIREMENTS | | THINKS INCAGENCIATO | | | | | | | |--------------------|-----------------------|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|-------|-----------------------------| | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{TA} \le +125^{\circ}\text{C}$ for Extended | | | | | | Param. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | SP10 | FscP | Maximum SCK2 Frequency | _ | | 9 | MHz | -40°C to +125°C<br>(Note 3) | | SP20 | TscF | SCK2 Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 4) | | SP21 | TscR | SCK2 Output Rise Time | _ | _ | _ | ns | See Parameter DO31 (Note 4) | | SP30 | TdoF | SDO2 Data Output Fall Time | _ | _ | _ | ns | See Parameter DO32 (Note 4) | | SP31 | TdoR | SDO2 Data Output Rise Time | _ | _ | _ | ns | See Parameter DO31 (Note 4) | | SP35 | TscH2doV,<br>TscL2doV | SDO2 Data Output Valid after SCK2 Edge | _ | 6 | 20 | ns | | | SP36 | TdoV2scH,<br>TdoV2scL | SDO2 Data Output Setup to First SCK2 Edge | 30 | _ | _ | ns | | | SP40 | TdiV2scH,<br>TdiV2scL | Setup Time of SDI2 Data<br>Input to SCK2 Edge | 30 | _ | _ | ns | | | SP41 | TscH2diL,<br>TscL2diL | Hold Time of SDI2 Data Input to SCK2 Edge | 30 | _ | _ | ns | | - **Note 1:** These parameters are characterized, but are not tested in manufacturing. - 2: Data in "Typical" column is at 3.3V, +25°C unless otherwise stated. - 3: The minimum clock period for SCK2 is 111 ns. The clock generated in Master mode must not violate this specification. - 4: Assumes 50 pF load on all SPI2 pins. TABLE 30-46: SPI1 SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 1, SMP = 0) TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{Ta} \le +85^{\circ}\text{C}$ for Industrial $-40^{\circ}\text{C} \le \text{Ta} \le +125^{\circ}\text{C}$ for Extended | | | | | |--------------------|-----------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|--------------------|-------|-----------------------------| | Param. | Symbol | Characteristic <sup>(1)</sup> | Min. | Typ. <sup>(2)</sup> | Max. | Units | Conditions | | SP70 | FscP | Maximum SCK1 Input Frequency | _ | l | Lesser of FP or 11 | MHz | (Note 3) | | SP72 | TscF | SCK1 Input Fall Time | _ | 1 | ı | ns | See Parameter DO32 (Note 4) | | SP73 | TscR | SCK1 Input Rise Time | _ | 1 | ı | ns | See Parameter DO31 (Note 4) | | SP30 | TdoF | SDO1 Data Output Fall Time | _ | | ı | ns | See Parameter DO32 (Note 4) | | SP31 | TdoR | SDO1 Data Output Rise Time | _ | | | ns | See Parameter DO31 (Note 4) | | SP35 | TscH2doV,<br>TscL2doV | SDO1 Data Output Valid after SCK1 Edge | _ | 6 | 20 | ns | | | SP36 | TdoV2scH,<br>TdoV2scL | SDO1 Data Output Setup to First SCK1 Edge | 30 | l | ı | ns | | | SP40 | TdiV2scH,<br>TdiV2scL | Setup Time of SDI1 Data Input to SCK1 Edge | 30 | l | ı | ns | | | SP41 | TscH2diL,<br>TscL2diL | Hold Time of SDI1 Data Input to SCK1 Edge | 30 | | | ns | | | SP50 | TssL2scH,<br>TssL2scL | SS1 ↓ to SCK1 ↑ or SCK1 ↓ Input | 120 | - | | ns | | | SP51 | TssH2doZ | SS1 ↑ to SDO1 Output<br>High-Impedance | 10 | _ | 50 | ns | (Note 4) | | SP52 | TscH2ssH,<br>TscL2ssH | SS1 ↑ after SCK1 Edge | 1.5 Tcy + 40 | _ | _ | ns | (Note 4) | | SP60 | TssL2doV | SDO1 Data Output Valid after SS1 Edge | _ | _ | 50 | ns | | Note 1: These parameters are characterized, but are not tested in manufacturing. **<sup>2:</sup>** Data in "Typical" column is at 3.3V, +25°C unless otherwise stated. **<sup>3:</sup>** The minimum clock period for SCK1 is 91 ns. Therefore, the SCK1 clock generated by the master must not violate this specification. <sup>4:</sup> Assumes 50 pF load on all SPI1 pins. # 64-Lead Plastic Thin Quad Flatpack (PT) 10x10x1 mm Body, 2.00 mm Footprint [TQFP] **Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging RECOMMENDED LAND PATTERN | | N | <b>ILLIMETER</b> | S | | |--------------------------|-----|------------------|----------|------| | Dimension | MIN | NOM | MAX | | | Contact Pitch | Е | | 0.50 BSC | | | Contact Pad Spacing | C1 | | 11.40 | | | Contact Pad Spacing | C2 | | 11.40 | | | Contact Pad Width (X64) | X1 | | | 0.30 | | Contact Pad Length (X64) | Y1 | | | 1.50 | | Distance Between Pads | G | 0.20 | | | #### Notes: 1. Dimensioning and tolerancing per ASME Y14.5M BSC: Basic Dimension. Theoretically exact value shown without tolerances. Microchip Technology Drawing No. C04-2085B TABLE A-2: MAJOR SECTION UPDATES (CONTINUED) | Section Name | Update Description | |-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Section 16.0 "High-Speed<br>PWM Module<br>(dsPIC33EPXXXMC20X/50X<br>and PIC24EPXXXMC20X<br>Devices Only)" | Updated the High-Speed PWM Module Register Interconnection Diagram (see Figure 16-2). Added the TRGCONx and TRIGx registers (see Register 16-12 and Register 16-14, respectively). | | Section 21.0 "Enhanced<br>CAN (ECAN™) Module<br>(dsPIC33EPXXXGP/MC50X<br>Devices Only)" | Updated the CANCKS bit value definitions in CiCTRL1: ECAN Control Register 1 (see Register 21-1). | | Section 22.0 "Charge Time Measurement Unit (CTMU)" | Updated the IRNG<1:0> bit value definitions and added Note 2 in the CTMU Current Control Register (see Register 22-3). | | Section 25.0 "Op amp/<br>Comparator Module" | Updated the Op amp/Comparator I/O Operating Modes Diagram (see Figure 25-1). Updated the User-programmable Blanking Function Block Diagram (see Figure 25-3). Updated the Digital Filter Interconnect Block Diagram (see Figure 25-4). Added Section 25.1 "Op amp Application Considerations". Added Note 2 to the Comparator Control Register (see Register 25-2). Updated the bit definitions in the Comparator Mask Gating Control Register (see Register 25-5). | | Section 27.0 "Special Features" | Updated the FICD Configuration Register, updated Note 1, and added Note 3 in the Configuration Byte Register Map (see Table 27-1). Added Section 27.2 "User ID Words". | | Section 30.0 "Electrical Characteristics" | Updated the following Absolute Maximum Ratings: • Maximum current out of Vss pin • Maximum current into VDD pin Added Note 1 to the Operating MIPS vs. Voltage (see Table 30-1). | | | Updated all Idle Current (IIDLE) Typical and Maximum DC Characteristics values (see Table 30-7). | | | Updated all Doze Current (IDOZE) Typical and Maximum DC Characteristics values (see Table 30-9). | | | Added Note 2, removed Parameter CM24, updated the Typical values Parameters CM10, CM20, CM21, CM32, CM41, CM44, and CM45, and updated the Minimum values for CM40 and CM41, and the Maximum value for CM40 in the AC/DC Characteristics: Op amp/Comparator (see Table 30-14). | | | Updated Note 2 and the Typical value for Parameter VR310 in the Op amp/<br>Comparator Reference Voltage Settling Time Specifications (see Table 30-15). | | | Added Note 1, removed Parameter VRD312, and added Parameter VRD314 to the Op amp/Comparator Voltage Reference DC Specifications (see Table 30-16). | | | Updated the Minimum, Typical, and Maximum values for Internal LPRC Accuracy (see Table 30-22). | | | Updated the Minimum, Typical, and Maximum values for Parameter SY37 in the Reset, Watchdog Timer, Oscillator Start-up Timer, Power-up Timer Timing Requirements (see Table 30-24). | | | The Maximum Data Rate values were updated for the SPI2 Maximum Data/Clock Rate Summary (see Table 30-35) |