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 | 50 MIPs | | Connectivity | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, POR, PWM, WDT | | Number of I/O | 21 | | Program Memory Size | 16KB (16K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 2K x 8 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V | | Data Converters | A/D 8x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 28-VQFN Exposed Pad | | Supplier Device Package | 28-QFN-S (6x6) | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/dspic33fj16gs402-50i-mm | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong ### Pin Diagrams (Continued) FIGURE 2-9: **INTERLEAVED PFC** ── Vout+ |VAC| $k_3$ $k_1$ $k_2$ Vout-FET FET Driver Driver ADC Channel ADC Channel ADC Channel PWM ADC PWM Channel dsPIC33FJ06GS202 **ADC Channel** ### 3.4 CPU Control Registers #### REGISTER 3-1: SR: CPU STATUS REGISTER | R-0 | R-0 | R/C-0 | R/C-0 | R-0 | R/C-0 | R-0 | R/W-0 | |--------|-----|-------------------|-------------------|-----|----------------------|-----|-------| | OA | ОВ | SA <sup>(1)</sup> | SB <sup>(1)</sup> | OAB | SAB <sup>(1,4)</sup> | DA | DC | | bit 15 | | | | | | | bit 8 | | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | R/W-0 <sup>(3)</sup> | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |----------------------|----------------------|----------------------|-----|-------|-------|-------|-------| | IPL2 <sup>(2)</sup> | IPL1 <sup>(2)</sup> | IPL0 <sup>(2)</sup> | RA | N | OV | Z | С | | bit 7 | | | | | | | bit 0 | | Legend: | C = Clearable bit | | | |---------------------|---------------------|-----------------------------|------------------| | R = Readable bit | W = Writable bit | -n = Value at POR | '1' = Bit is set | | 0' = Bit is cleared | 'x = Bit is unknown | U = Unimplemented bit, read | d as '0' | bit 15 OA: Accumulator A Overflow Status bit 1 = Accumulator A has overflowed 0 = Accumulator A has not overflowed bit 14 OB: Accumulator B Overflow Status bit 1 = Accumulator B has overflowed 0 = Accumulator B has not overflowed bit 13 SA: Accumulator A Saturation 'Sticky' Status bit<sup>(1)</sup> 1 = Accumulator A is saturated or has been saturated at some time 0 = Accumulator A is not saturated bit 12 **SB:** Accumulator B Saturation 'Sticky' Status bit<sup>(1)</sup> 1 = Accumulator B is saturated or has been saturated at some time 0 = Accumulator B is not saturated bit 11 OAB: OA || OB Combined Accumulator Overflow Status bit 1 = Accumulator A or B has overflowed 0 = Neither Accumulator A or B has overflowed bit 10 SAB: SA | SB Combined Accumulator 'Sticky' Status bit (1,4) 1 = Accumulator A or B is saturated or has been saturated at some time in the past 0 = Neither Accumulator A or B is saturated bit 9 DA: DO Loop Active bit 1 = DO loop in progress 0 = DO loop not in progress bit 8 **DC:** MCU ALU Half Carry/Borrow bit 1 = A carry-out from the 4th low-order bit (for byte-sized data) or 8th low-order bit (for word-sized data) of the result occurred 0 = No carry-out from the 4th low-order bit (for byte-sized data) or 8th low-order bit (for word-sized data) of the result occurred Note 1: This bit can be read or cleared (not set). 2: The IPL<2:0> bits are concatenated with the IPL<3> bit (CORCON<3>) to form the CPU Interrupt Priority Level (IPL). The value in parentheses indicates the IPL if IPL<3> = 1. User interrupts are disabled when IPL<3> = 1. 3: The IPL<2:0> Status bits are read-only when NSTDIS = 1 (INTCON1<15>). 4: Clearing this bit will clear SA and SB. ### REGISTER 3-2: CORCON: CORE CONTROL REGISTER (CONTINUED) bit 1 RND: Rounding Mode Select bit 1 = Biased (conventional) rounding is enabled 0 = Unbiased (convergent) rounding is enabled IF: Integer or Fractional Multiplier Mode Select bit 1 = Integer mode is enabled for DSP multiply ops0 = Fractional mode is enabled for DSP multiply ops Note 1: This bit will always read as '0'. bit 0 2: The IPL3 bit is concatenated with the IPL<2:0> bits (SR<7:5>) to form the CPU Interrupt Priority Level. # 7.3 Interrupt Control and Status Registers The dsPIC33FJ06GS101/X02 and dsPIC33FJ16GSX02/X04 devices implement 27 registers for the interrupt controller: - INTCON1 - INTCON2 - IFSx - IECx - IPCx - INTTREG #### 7.3.1 INTCON1 AND INTCON2 Global interrupt control functions are controlled from INTCON1 and INTCON2. INTCON1 contains the Interrupt Nesting Disable (NSTDIS) bit as well as the control and status flags for the processor trap sources. The INTCON2 register controls the external interrupt request signal behavior and the use of the Alternate Interrupt Vector Table. #### 7.3.2 IFSx The IFSx registers maintain all of the interrupt request flags. Each source of interrupt has a status bit, which is set by the respective peripherals or external signal and is cleared via software. #### 7.3.3 IECx The IECx registers maintain all of the interrupt enable bits. These control bits are used to individually enable interrupts from the peripherals or external signals. #### 7.3.4 IPCx The IPCx registers are used to set the Interrupt Priority Level for each source of interrupt. Each user interrupt source can be assigned to one of eight priority levels. #### 7.3.5 INTTREG The INTTREG register contains the associated interrupt vector number and the new CPU Interrupt Priority Level, which are latched into the Vector Number (VECNUM<6:0>) and Interrupt Level (ILR<3:0>) bit fields in the INTTREG register. The new Interrupt Priority Level is the priority of the pending interrupt. The interrupt sources are assigned to the IFSx, IECx and IPCx registers in the same sequence that they are listed in Table 7-1. For example, the INT0 (External Interrupt 0) is shown as having Vector Number 8 and a natural order priority of 0. Thus, the INT0IF bit is found in IFS0<0>, the INT0IE bit is found in IEC0<0> and the INT0IP bits are found in the first position of IPC0 (IPC0<2:0>). #### 7.3.6 STATUS/CONTROL REGISTERS Although they are not specifically part of the interrupt control hardware, two of the CPU Control registers contain bits that control interrupt functionality. - The CPU STATUS Register, SR, contains the IPL<2:0> bits (SR<7:5>). These bits indicate the current CPU Interrupt Priority Level. The user can change the current CPU priority level by writing to the IPL bits. - The CORCON register contains the IPL3 bit, which together with IPL<2:0>, indicates the current CPU priority level. IPL3 is a read-only bit so that trap events cannot be masked by the user software All Interrupt registers are described in Register 7-1 through Register 7-35 in the following pages. #### REGISTER 7-6: IFS1: INTERRUPT FLAG STATUS REGISTER 1 | U-0 | U-0 | R/W-0 | U-0 | U-0 | U-0 | U-0 | U-0 | |--------|-----|--------|-----|-----|-----|-----|-------| | _ | _ | INT2IF | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-----|-----|--------|-------|-------|---------|---------| | _ | _ | _ | INT1IF | CNIF | AC1IF | MI2C1IF | SI2C1IF | | 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-14 Unimplemented: Read as '0' bit 13 INT2IF: External Interrupt 2 Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 12-5 Unimplemented: Read as '0' bit 4 INT1IF: External Interrupt 1 Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 3 CNIF: Input Change Notification Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 2 AC1IF: Analog Comparator 1 Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 1 MI2C1IF: I2C1 Master Events Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred bit 0 SI2C1IF: I2C1 Slave Events Interrupt Flag Status bit 1 = Interrupt request has occurred0 = Interrupt request has not occurred #### 9.2.2 IDLE MODE The following occur in Idle mode: - The CPU stops executing instructions - · The WDT is automatically cleared - The system clock source remains active. By default, all peripheral modules continue to operate normally from the system clock source, but can also be selectively disabled (see Section 9.4 "Peripheral Module Disable"). - If the WDT or FSCM is enabled, the LPRC also remains active The device will wake-up from Idle mode on any of these events: - · Any interrupt that is individually enabled - Any device Reset - A WDT time-out On wake-up from Idle mode, the clock is reapplied to the CPU and instruction execution will begin (2-4 clock cycles later), starting with the instruction following the PWRSAV instruction, or the first instruction in the ISR. # 9.2.3 INTERRUPTS COINCIDENT WITH POWER SAVE INSTRUCTIONS Any interrupt that coincides with the execution of a PWRSAV instruction is held off until entry into Sleep or Idle mode has completed. The device then wakes up from Sleep or Idle mode. #### 9.3 Doze Mode The preferred strategies for reducing power consumption are changing clock speed and invoking one of the power-saving modes. In some circumstances, this may not be practical. For example, it may be necessary for an application to maintain uninterrupted synchronous communication, even while it is doing nothing else. Reducing system clock speed can introduce communication errors, while using a power-saving mode can stop communications completely. Doze mode is a simple and effective alternative method to reduce power consumption while the device is still executing code. In this mode, the system clock continues to operate from the same source and at the same speed. Peripheral modules continue to be clocked at the same speed, while the CPU clock speed is reduced. Synchronization between the two clock domains is maintained, allowing the peripherals to access the SFRs while the CPU executes code at a slower rate. Doze mode is enabled by setting the DOZEN bit (CLKDIV<11>). The ratio between peripheral and core clock speed is determined by the DOZE<2:0> bits (CLKDIV<14:12>). There are eight possible configurations, from 1:1 to 1:128, with 1:1 being the default setting. Programs can use Doze mode to selectively reduce power consumption in event-driven applications. This allows clock-sensitive functions, such as synchronous communications, to continue without interruption while the CPU idles, waiting for something to invoke an interrupt routine. An automatic return to full-speed CPU operation on interrupts can be enabled by setting the ROI bit (CLKDIV<15>). By default, interrupt events have no effect on Doze mode operation. For example, suppose the device is operating at 20 MIPS and the CAN module has been configured for 500 kbps based on this device operating speed. If the device is placed in Doze mode with a clock frequency ratio of 1:4, the CAN module continues to communicate at the required bit rate of 500 kbps, but the CPU now starts executing instructions at a frequency of 5 MIPS. ### 9.4 Peripheral Module Disable The Peripheral Module Disable (PMD) registers provide a method to disable a peripheral module by stopping all clock sources supplied to that module. When a peripheral is disabled using the appropriate PMD control bit, the peripheral is in a minimum power consumption state. The control and status registers associated with the peripheral are also disabled, so writes to those registers will have no effect and read values will be invalid. A peripheral module is enabled only if both the associated bit in the PMD register is cleared and the peripheral is supported by the specific dsPIC<sup>®</sup> DSC variant. If the peripheral is present in the device, it is enabled in the PMD register by default. Note If a PMD bit is set, the corresponding module is disabled after a delay of one instruction cycle. Similarly, if a PMD bit is cleared, the corresponding module is enabled after a delay of one instruction cycle (assuming the module control registers are already configured to enable module operation). #### REGISTER 9-1: PMD1: PERIPHERAL MODULE DISABLE CONTROL REGISTER 1 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | U-0 | |--------|-----|-------|-------|-------|-----|----------------------|-------| | _ | _ | T3MD | T2MD | T1MD | _ | PWMMD <sup>(1)</sup> | _ | | bit 15 | | | | | | | bit 8 | | R/W-0 | U-0 | R/W-0 | U-0 | R/W-0 | U-0 | U-0 | R/W-0 | |--------|-----|-------|-----|--------|-----|-----|-------| | I2C1MD | _ | U1MD | _ | SPI1MD | _ | _ | ADCMD | | 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-14 Unimplemented: Read as '0' bit 13 T3MD: Timer3 Module Disable bit 1 = Timer3 module is disabled 0 = Timer3 module is enabled bit 12 T2MD: Timer2 Module Disable bit 1 = Timer2 module is disabled 0 = Timer2 module is enabled T1MD: Timer1 Module Disable bit bit 11 1 = Timer1 module is disabled 0 = Timer1 module is enabled bit 10 Unimplemented: Read as '0' bit 9 **PWMMD**: PWM Module Disable bit<sup>(1)</sup> 1 = PWM module is disabled 0 = PWM module is enabled bit 8 Unimplemented: Read as '0' bit 7 I2C1MD: I2C1 Module Disable bit 1 = I2C1 module is disabled 0 = I2C1 module is enabled bit 6 Unimplemented: Read as '0' bit 5 U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled bit 4 Unimplemented: Read as '0' bit 3 SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled 0 = SPI1 module is enabled Unimplemented: Read as '0' bit 2-1 bit 0 ADCMD: ADC Module Disable bit 1 = ADC module is disabled 0 = ADC module is enabled Note 1: Once the PWM module is re-enabled (PWMMD is set to '1' and then set to '0'), all PWM registers must be reinitialized. ### REGISTER 10-2: RPINR1: PERIPHERAL PIN SELECT INPUT REGISTER 1 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|--------|--------|--------|--------|--------|--------| | _ | _ | INT2R5 | INT2R4 | INT2R3 | INT2R2 | INT2R1 | INT2R0 | | 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-6 Unimplemented: Read as '0' bit 5-0 INT2R<5:0>: Assign External Interrupt 2 (INTR2) to the Corresponding RPn Pin bits 111111 = Input tied to Vss 100011 = Input tied to RP35 100010 = Input tied to RP34 100001 = Input tied to RP33 100000 = Input tied to RP32 • • • 00000 = Input tied to RP0 #### 15.2 Feature Description The PWM module is designed for applications that require: - High-resolution at high PWM frequencies - The ability to drive Standard, Edge-Aligned, Center-Aligned Complementary mode, and Push-Pull mode outputs - The ability to create multiphase PWM outputs For Center-Aligned mode, the duty cycle, period phase and dead-time resolutions will be 8.32 ns. Two common, medium power converter topologies are push-pull and half-bridge. These designs require the PWM output signal to be switched between alternate pins, as provided by the Push-Pull PWM mode. Phase-shifted PWM describes the situation where each PWM generator provides outputs, but the phase relationship between the generator outputs is specifiable and changeable. Multiphase PWM is often used to improve DC/DC Converter load transient response, and reduce the size of output filter capacitors and inductors. Multiple DC/DC Converters are often operated in parallel, but phase-shifted in time. A single PWM output operating at 250 kHz has a period of 4 $\mu s$ , but an array of four PWM channels, staggered by 1 $\mu s$ each, yields an effective switching frequency of 1 MHz. Multiphase PWM applications typically use a fixed-phase relationship. Variable phase PWM is useful in Zero Voltage Transition (ZVT) power converters. Here, the PWM duty cycle is always 50%, and the power flow is controlled by varying the relative phase shift between the two PWM generators. ### REGISTER 15-15: FCLCONx: PWMx FAULT CURRENT-LIMIT CONTROL REGISTER (CONTINUED) ``` FLTSRC<4:0>: Fault Control Signal Source Select for PWM Generator # bits(2,3) bit 7-3 11111 = Reserved 01000 = Reserved 00111 = Fault 8 00110 = Fault 7 00101 = Fault 6 00100 = Fault 5 00011 = Fault 4 00010 = Fault 3 00001 = Fault 2 00000 = Fault 1 FLTPOL: Fault Polarity for PWM Generator # bit(1) bit 2 1 = The selected Fault source is active-low 0 = The selected Fault source is active-high bit 1-0 FLTMOD<1:0>: Fault Mode for PWM Generator # bits 11 = Fault input is disabled 10 = Reserved 01 = The selected Fault source forces the PWMxH and PWMxL pins to FLTDAT values (cycle) 00 = The selected Fault source forces the PWMxH and PWMxL pins to FLTDAT values (latched condition) ``` - **Note 1:** These bits should be changed only when PTEN = 0. Changing the clock selection during operation will yield unpredictable results. - 2: When Independent Fault mode is enabled (IFLTMOD = 1), and Fault 1 is used for Current-Limit mode (CLSRC<4:0> = b0000), the Fault Control Source Select bits (FLTSRC<4:0>) should be set to an unused Fault source to prevent Fault 1 from disabling both the PWMxL and PWMxH outputs. - 3: When Independent Fault mode is enabled (IFLTMOD = 1) and Fault 1 is used for Fault mode (FLTSRC<4:0> = b0000), the Current-Limit Control Source Select bits (CLSRC<4:0>) should be set to an unused current-limit source to prevent the current-limit source from disabling both the PWMxH and PWMxL outputs. #### REGISTER 16-2: SPIXCON1: SPIX CONTROL REGISTER 1 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|-----|--------|--------|--------|-------|--------------------| | _ | _ | _ | DISSCK | DISSDO | MODE16 | SMP | CKE <sup>(1)</sup> | | bit 15 | | | | | | | bit 8 | | R/W-0 |---------------------|-------|-------|----------------------|----------------------|----------------------|----------------------|----------------------| | SSEN <sup>(3)</sup> | CKP | MSTEN | SPRE2 <sup>(2)</sup> | SPRE1 <sup>(2)</sup> | SPRE0 <sup>(2)</sup> | PPRE1 <sup>(2)</sup> | PPRE0 <sup>(2)</sup> | | 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-13 Unimplemented: Read as '0' bit 12 **DISSCK:** Disable SCKx Pin bit (SPI Master modes only) 1 = Internal SPI clock is disabled; pin functions as I/O 0 = Internal SPI clock is enabled bit 11 DISSDO: Disable SDOx Pin bit 1 = SDOx pin is not used by module; pin functions as I/O 0 = SDOx pin is controlled by the module bit 10 MODE16: Word/Byte Communication Select bit 1 = Communication is word-wide (16 bits) 0 = Communication is byte-wide (8 bits) bit 9 SMP: SPIx Data Input Sample Phase bit Master mode: 1 = Input data sampled at end of data output time 0 = Input data sampled at middle of data output time Slave mode: SMP must be cleared when SPIx is used in Slave mode. bit 8 **CKE:** SPIx Clock Edge Select bit<sup>(1)</sup> 1 = Serial output data changes on transition from active clock state to Idle clock state (see bit 6) 0 = Serial output data changes on transition from Idle clock state to active clock state (see bit 6) bit 7 SSEN: Slave Select Enable bit (Slave mode)<sup>(3)</sup> $1 = \overline{SSx}$ pin is used for Slave mode 0 = SSx pin is not used by module; pin controlled by port function bit 6 CKP: Clock Polarity Select bit 1 = Idle state for clock is a high level; active state is a low level 0 = Idle state for clock is a low level; active state is a high level bit 5 MSTEN: Master Mode Enable bit 1 = Master mode 0 = Slave mode **Note 1:** The CKE bit is not used in the Framed SPI modes. Program this bit to '0' for the Framed SPI modes (FRMEN = 1). 2: Do not set both primary and secondary prescalers to a value of 1:1. 3: This bit must be cleared when FRMEN = 1. ### REGISTER 18-1: UXMODE: UARTX MODE REGISTER (CONTINUED) bit 4 URXINV: UARTx Receive Polarity Inversion bit 1 = UxRX Idle state is '0' 0 = UxRX Idle state is '1' bit 3 BRGH: High Baud Rate Enable bit 1 = BRG generates 4 clocks per bit period (4x baud clock, High-Speed mode) 0 = BRG generates 16 clocks per bit period (16x baud clock, Standard mode) bit 2-1 PDSEL<1:0>: Parity and Data Selection bits 11 = 9-bit data, no parity 10 = 8-bit data, odd parity 01 = 8-bit data, even parity 00 = 8-bit data, no parity bit 0 STSEL: Stop Bit Selection bit 1 = Two Stop bits 0 = One Stop bit **Note 1:** Refer to "UART" (DS70188) in the "dsPIC33F/PIC24H Family Reference Manual" for information on enabling the UART module for receive or transmit operation. 2: This feature is only available for the $16x BRG \mod (BRGH = 0)$ . ### REGISTER 18-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 enable; 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 = \text{Receive buffer has not overflowed; clearing a previously set OERR bit } (1 \rightarrow 0 \text{ transition}) \text{ will reset}$ 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 "UART" (DS70188) in the "dsPIC33F/PIC24H Family Reference Manual" for information on enabling the UART module for transmit operation. ### 19.0 HIGH-SPEED 10-BIT ANALOG-TO-DIGITAL CONVERTER (ADC) Note 1: This data sheet summarizes the features of the dsPIC33FJ06GS101/X02 and dsPIC33FJ16GSX02/X04 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 10-Bit Analog-to-Digital Converter (ADC)" (DS70000321) 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. dsPIC33FJ06GS101/X02 and dsPIC33FJ16GSX02/X04 devices provide high-speed, successive approximation Analog-to-Digital conversions to support applications, such as AC/DC and DC/DC power converters. #### 19.1 Features Overview The ADC module comprises the following features: - 10-bit resolution - · Unipolar inputs - Up to two Successive Approximation Registers (SARs) - Up to 12 external input channels - · Up to two internal analog inputs - · Dedicated result register for each analog input - ±1 LSB accuracy at 3.3V - · Single supply operation - 4 Msps conversion rate at 3.3V (devices with two SARs) - 2 Msps conversion rate at 3.3V (devices with one SAR) - Low-power CMOS technology #### 19.2 Module Description This ADC module is designed for applications that require low latency between the request for conversion and the resultant output data. Typical applications include: - · AC/DC power supplies - DC/DC Converters - Power Factor Correction (PFC) This ADC works with the high-speed PWM module in power control applications that require high-frequency control loops. This module can sample and convert two analog inputs in a 0.5 microsecond when two SARs are used. This small conversion delay reduces the "phase lag" between measurement and control system response. Up to five inputs may be sampled at a time (four inputs from the dedicated Sample-and-Hold circuits and one from the shared Sample-and-Hold circuit). If multiple inputs request conversion, the ADC will convert them in a sequential manner, starting with the lowest order input. This ADC design provides each pair of analog inputs (AN1, AN0), (AN3, AN2),..., the ability to specify its own trigger source out of a maximum of sixteen different trigger sources. This capability allows this ADC to sample and convert analog inputs that are associated with PWM generators operating on Independent Time Bases (ITBs). The user application typically requires synchronization between analog data sampling and PWM output to the application circuit. The very high-speed operation of this ADC module allows "data on demand". In addition, several hardware features have been added to the peripheral interface to improve real-time performance in a typical DSP-based application. - · Result alignment options - · Automated sampling - External conversion start control - Two internal inputs to monitor the INTREF internal reference and the EXTREF input signal #### 19.3 Module Functionality The high-speed, 10-bit ADC module is designed to support power conversion applications when used with the high-speed PWM module. The ADC may have one or two SAR modules, depending on the device variant. If two SARs are present on a device, two conversions can be processed at a time, yielding 4 Msps conversion rate. If only one SAR is present on a device, only one conversion can be processed at a time, yielding 2 Msps conversion rate. The high-speed 10-bit ADC produces two 10-bit conversion results in a 0.5 microsecond. The ADC module supports up to 12 external analog inputs and two internal analog inputs. To monitor reference voltage, two internal inputs, AN12 and AN13, are connected to the EXTREF and INTREF voltages, respectively. The analog reference voltage is defined as the device supply voltage (AVDD/AVSS). Block diagrams of the ADC module are shown in Figure 19-1 through Figure 19-6. FIGURE 24-8: OCx/PWMx MODULE TIMING CHARACTERISTICS TABLE 24-28: SIMPLE OCx/PWMx MODE 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<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min | Тур | Max | Units | Conditions | | | OC15 | TFD | Fault Input to PWMx I/O Change | _ | _ | Tcy + 20 | ns | | | | OC20 | TFLT | Fault Input Pulse Width | Tcy + 20 | _ | _ | ns | | | Note 1: These parameters are characterized but not tested in manufacturing. TABLE 24-38: I2Cx BUS DATA TIMING REQUIREMENTS (MASTER MODE) | 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<br>No. | Symbol | Characteristic | | Min <sup>(1)</sup> Max | | Units | Conditions | | | | IM10 | TLO:SCL | Clock Low Time | 100 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 400 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | μS | | | | | IM11 | THI:SCL | Clock High Time | 100 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 400 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | μS | | | | | IM20 | TF:SCL | SDAx and SCLx | 100 kHz mode | _ | 300 | ns | CB is specified to be | | | | | | Fall Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | from 10 pF to 400 pF | | | | | | | 1 MHz mode <sup>(2)</sup> | _ | 100 | ns | | | | | IM21 | TR:SCL | SDAx and SCLx | 100 kHz mode | _ | 1000 | ns | CB is specified to be | | | | | | Rise Time | 400 kHz mode | 20 + 0.1 CB | 300 | ns | from 10 pF to 400 pF | | | | | | | 1 MHz mode <sup>(2)</sup> | _ | 300 | ns | | | | | IM25 | TSU:DAT | Data Input<br>Setup Time | 100 kHz mode | 250 | _ | ns | | | | | | | | 400 kHz mode | 100 | _ | ns | | | | | | | | 1 MHz mode <sup>(2)</sup> | 40 | _ | ns | | | | | IM26 | THD:DAT | Data Input<br>Hold Time | 100 kHz mode | 0 | _ | μS | | | | | | | | 400 kHz mode | 0 | 0.9 | μS | | | | | | | | 1 MHz mode <sup>(2)</sup> | 0.2 | _ | μS | | | | | IM30 | Tsu:sta | Start Condition<br>Setup Time | 100 kHz mode | Tcy/2 (BRG + 1) | _ | μS | Only relevant for | | | | | | | 400 kHz mode | Tcy/2 (BRG + 1) | _ | μS | Repeated Start | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | μS | condition | | | | IM31 THD: | THD:STA | Start Condition<br>Hold Time | 100 kHz mode | Tcy/2 (BRG + 1) | _ | μS | After this period the | | | | | | | 400 kHz mode | Tcy/2 (BRG + 1) | _ | μS | first clock pulse is | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | μS | generated | | | | IM33 | Tsu:sto | Stop Condition<br>Setup Time | 100 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 400 kHz mode | Tcy/2 (BRG + 1) | _ | μS | | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | μS | | | | | IM34 | THD:STO | Stop Condition | 100 kHz mode | Tcy/2 (BRG + 1) | _ | ns | | | | | | | Hold Time | 400 kHz mode | Tcy/2 (BRG + 1) | _ | ns | | | | | | | | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1) | _ | ns | | | | | IM40 | TAA:SCL | Output Valid<br>From Clock | 100 kHz mode | _ | 3500 | ns | | | | | | | | 400 kHz mode | _ | 1000 | ns | | | | | | | | 1 MHz mode <sup>(2)</sup> | _ | 400 | ns | | | | | IM45 | TBF:SDA | Bus Free Time | 100 kHz mode | 4.7 | _ | μS | Time the bus must be | | | | | | | 400 kHz mode | 1.3 | _ | μS | free before a new | | | | | | | 1 MHz mode <sup>(2)</sup> | 0.5 | _ | μS | transmission can start | | | | IM50 | Св | Bus Capacitive Loading | | _ | 400 | pF | | | | | IM51 | TPGD Pulse Gobbler Delay | | | 65 | 390 | ns | See Note 3 | | | Note 1: BRG is the value of the I<sup>2</sup>C™ Baud Rate Generator. Refer to "Inter-Integrated Circuit (I<sup>2</sup>C™)" (DS70000195) in the "dsPIC33/PIC24 Family Reference Manual". <sup>2:</sup> Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only). **<sup>3:</sup>** Typical value for this parameter is 130 ns. #### TABLE 25-4: DC CHARACTERISTICS: POWER-DOWN CURRENT (IPD) | TABLE 20 4. DO STATE OF THE TOTAL CONTROL (11 D) | | | | | | | | | | |--------------------------------------------------|------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|--|--|--|--|--| | DC CHARACT | ERISTICS | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature $-40^{\circ}\text{C} \le \text{TA} \le +150^{\circ}\text{C}$ for High Temperature | | | | | | | | Parameter<br>No. | Typical <sup>(1)</sup> | Max | Units | Conditions | | | | | | | Power-Down Current (IPD) <sup>(2,4)</sup> | | | | | | | | | | | HDC60e | 1000 | 2000 | μΑ | +150°C 3.3V Base Power-Down Current | | | | | | | HDC61c | 100 | 110 | μΑ | +150°C 3.3V Watchdog Timer Current: ΔIWDT <sup>(3)</sup> | | | | | | - Note 1: Data in the Typical column is at 3.3V, +25°C unless otherwise stated. - 2: IPD (Sleep) current is measured as follows: - CPU core is off, oscillator is configured in EC mode and external clock active, OSC1 is driven with external square wave from rail-to-rail (EC clock overshoot/undershoot < 250 mV required)</li> - CLKO is configured as an I/O input pin in the Configuration Word - All I/O pins are configured as inputs and pulled to Vss - MCLR = VDD, WDT and FSCM are disabled - All peripheral modules are disabled (PMDx bits are all ones) - The VREGS bit (RCON<8>) = 0 (i.e., core regulator is set to stand-by while the device is in Sleep mode) - JTAG disabled - **3:** The Δ current is the additional current consumed when the WDT module is enabled. This current should be added to the base IPD current. - 4: These currents are measured on the device containing the most memory in this family. ### 26.2 AC Characteristics and Timing Parameters This section defines the dsPIC33FJ06GS101/X02 and dsPIC33FJ16GSX02/X04 AC characteristics and timing parameters for 50 MIPS devices. TABLE 26-5: EXTERNAL CLOCK TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ TA ≤ +85°C for Industrial | | | | | | | |--------------------|------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|------------|--|--| | Param<br>No. | Symb | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | | MOS10 Fin | | External CLKI Frequency<br>(External clocks allowed only<br>in EC and ECPLL modes) | DC | | 50 | MHz | EC | | | | | | Oscillator Crystal Frequency | 3.5 | _ | 10 | MHz | XT | | | | | | | 10 | _ | 50 | MHz | HS | | | | MOS20 | Tosc | Tosc = 1/Fosc | 10 | _ | DC | ns | | | | | MOS25 | Tcy | Instruction Cycle Time <sup>(2)</sup> | 20 | _ | DC | ns | | | | Note 1: Data in "Typ" column is at 3.3V, +25°C unless otherwise stated. TABLE 26-6: SIMPLE OCX/PWMx MODE TIMING REQUIREMENTS | AC CHAI | RACTERIS | rics | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤ TA ≤ +85°C for Industrial | | | | | | |--------------|----------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|----------|-------|------------|--| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min | Тур | Max | Units | Conditions | | | MOC15 | TFD | Fault Input to PWMx I/O Change | | _ | Tcy + 10 | ns | | | | MOC20 | TFLT | Fault Input Pulse Width | Tcy + 10 | _ | _ | ns | | | Note 1: These parameters are characterized but not tested in manufacturing. <sup>2:</sup> Instruction cycle period (TcY) equals two times the input oscillator time base period. All specified values are based on characterization data for that particular oscillator type, under standard operating conditions, with the device executing code. Exceeding these specified limits may result in an unstable oscillator operation and/or higher than expected current consumption. All devices are tested to operate at "Min." values with an external clock applied to the OSC1/CLKI pin. When an external clock input is used, the "Max." cycle time limit is "DC" (no clock) for all devices.