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 | 40 MIPs | | Connectivity | I <sup>2</sup> C, IrDA, SPI, UART/USART | | Peripherals | Brown-out Detect/Reset, Motor Control PWM, QEI, POR, PWM, WDT | | Number of I/O | 15 | | Program Memory Size | 12KB (12K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 1K x 8 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V | | Data Converters | A/D 4x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | 20-SSOP | | Purchase URL | https://www.e-xfl.com/product-detail/microchip-technology/dspic33fj12mc201t-i-ss | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong #### 3.6.1 MULTIPLIER The 17-bit x 17-bit multiplier is capable of signed or unsigned operation and can multiplex its output using a scaler to support either 1.31 fractional (Q31) or 32-bit integer results. Unsigned operands are zero-extended into the 17th bit of the multiplier input value. Signed operands are sign-extended into the 17th bit of the multiplier input value. The output of the 17-bit x 17-bit multiplier/scaler is a 33-bit value that is sign-extended to 40 bits. Integer data is inherently represented as a signed 2's complement value, where the Most Significant bit (MSb) is defined as a sign bit. The range of an N-bit 2's complement integer is $-2^{N-1}$ to $2^{N-1}-1$ . - For a 16-bit integer, the data range is -32768 (0x8000) to 32767 (0x7FFF) including 0. - For a 32-bit integer, the data range is -2,147,483,648 (0x8000 0000) to 2,147,483,647 (0x7FFF FFFF). When the multiplier is configured for fractional multiplication, the data is represented as a 2's complement fraction, where the MSb is defined as a sign bit and the radix point is implied to lie just after the sign bit (QX format). The range of an N-bit 2's complement fraction with this implied radix point is -1.0 to $(1-2^{1-N})$ . For a 16-bit fraction, the Q15 data range is -1.0 (0x8000) to 0.999969482 (0x7FFF) including 0 and has a precision of 3.01518x10<sup>-5</sup>. In Fractional mode, the 16 x 16 multiply operation generates a 1.31 product that has a precision of 4.65661 x $10^{-10}$ . The same multiplier is used to support the MCU multiply instructions, which include integer 16-bit signed, unsigned and mixed sign multiply operations. The MUL instruction can be directed to use byte- or word-sized operands. Byte operands will direct a 16-bit result, and word operands will direct a 32-bit result to the specified register(s) in the W array. ## 3.6.2 DATA ACCUMULATORS AND ADDER/SUBTRACTER The data accumulator consists of a 40-bit adder/subtracter with automatic sign extension logic. It can select one of two accumulators (A or B) as its preaccumulation source and post-accumulation destination. For the ADD and LAC instructions, the data to be accumulated or loaded can be optionally scaled using the barrel shifter prior to accumulation. ## 3.6.2.1 Adder/Subtracter, Overflow and Saturation The adder/subtracter is a 40-bit adder with an optional zero input into one side, and either true or complement data into the other input. - In the case of addition, the Carry/Borrow input is active-high and the other input is true data (not complemented). - In the case of subtraction, the Carry/Borrow input is active-low and the other input is complemented. The adder/subtracter generates Overflow Status bits, SA/SB and OA/OB, which are latched and reflected in the STATUS register: - Overflow from bit 39: this is a catastrophic overflow in which the sign of the accumulator is destroyed. - Overflow into guard bits 32 through 39: this is a recoverable overflow. This bit is set whenever all the guard bits are not identical to each other. The adder has an additional saturation block that controls accumulator data saturation, if selected. It uses the result of the adder, the Overflow Status bits described previously and the SAT<A:B> (CORCON<7:6>) and ACCSAT (CORCON<4>) mode control bits to determine when and to what value, to saturate. Six STATUS register bits support saturation and overflow: - · OA: ACCA overflowed into guard bits - · OB: ACCB overflowed into guard bits - SA: ACCA saturated (bit 31 overflow and saturation) or ACCA overflowed into guard bits and saturated (bit 39 overflow and saturation) SB: ACCB saturated (bit 31 overflow and saturation) or ACCB overflowed into guard bits and saturated (bit 39 overflow and saturation) - · OAB: Logical OR of OA and OB - · SAB: Logical OR of SA and SB The OA and OB bits are modified each time data passes through the adder/subtracter. When set, they indicate that the most recent operation has overflowed into the accumulator guard bits (bits 32 through 39). The OA and OB bits can also optionally generate an arithmetic warning trap when OA and OB are set and the corresponding Overflow Trap Flag Enable bits (OVATE, OVBTE) in the INTCON1 register are set (refer to **Section 7.0 "Interrupt Controller"**). This allows the user application to take immediate action; for example, to correct system gain. #### 3.6.3.1 Round Logic The round logic is a combinational block that performs a conventional (biased) or convergent (unbiased) round function during an accumulator write (store). The Round mode is determined by the state of the RND bit in the CORCON register. It generates a 16-bit, 1.15 data value that is passed to the data space write saturation logic. If rounding is not indicated by the instruction, a truncated 1.15 data value is stored and the least significant word (lsw) is simply discarded. Conventional rounding will zero-extend bit 15 of the accumulator and will add it to the ACCxH word (bits 16 through 31 of the accumulator). - If the ACCxL word (bits 0 through 15 of the accumulator) is between 0x8000 and 0xFFFF (0x8000 included), ACCxH is incremented. - If ACCxL is between 0x0000 and 0x7FFF, ACCxH is left unchanged. A consequence of this algorithm is that over a succession of random rounding operations, the value tends to be biased slightly positive. Convergent (or unbiased) rounding operates in the same manner as conventional rounding, except when ACCxL equals 0x8000. In this case, the Least Significant bit (LSb), bit 16 of the accumulator, of ACCxH is examined: - · If it is '1', ACCxH is incremented. - · If it is '0', ACCxH is not modified. Assuming that bit 16 is effectively random in nature, this scheme removes any rounding bias that may accumulate. The SAC and SAC.R instructions store either a truncated (SAC), or rounded (SAC.R) version of the contents of the target accumulator to data memory via the X bus, subject to data saturation (see **Section 3.6.3.2 "Data Space Write Saturation"**). For the MAC class of instructions, the accumulator writeback operation functions in the same manner, addressing combined MCU (X and Y) data space though the X bus. For this class of instructions, the data is always subject to rounding. #### 3.6.3.2 Data Space Write Saturation In addition to adder/subtracter saturation, writes to data space can also be saturated, but without affecting the contents of the source accumulator. The data space write saturation logic block accepts a 16-bit, 1.15 fractional value from the round logic block as its input, together with overflow status from the original source (accumulator) and the 16-bit round adder. These inputs are combined and used to select the appropriate 1.15 fractional value as output to write to data space memory. If the SATDW bit in the CORCON register is set, data (after rounding or truncation) is tested for overflow and adjusted accordingly: - For input data greater than 0x007FFF, data written to memory is forced to the maximum positive 1.15 value, 0x7FFF. - For input data less than 0xFF8000, data written to memory is forced to the maximum negative 1.15 value, 0x8000. The MSb of the source (bit 39) is used to determine the sign of the operand being tested. If the SATDW bit in the CORCON register is not set, the input data is always passed through unmodified under all conditions. #### 3.6.4 BARREL SHIFTER The barrel shifter can perform up to 16-bit arithmetic or logic right shifts, or up to 16-bit left shifts, in a single cycle. The source can be either of the two DSP accumulators or the X bus (to support multi-bit shifts of register or memory data). The shifter requires a signed binary value to determine both the magnitude (number of bits) and direction of the shift operation. A positive value shifts the operand right. A negative value shifts the operand left. A value of '0' does not modify the operand. The barrel shifter is 40 bits wide, thereby obtaining a 40-bit result for DSP shift operations and a 16-bit result for MCU shift operations. Data from the X bus is presented to the barrel shifter between bit positions 16 and 31 for right shifts, and between bit positions 0 and 16 for left shifts. ### REGISTER 7-9: IEC0: INTERRUPT ENABLE CONTROL REGISTER 0 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |--------|-----|-------|--------|--------|--------|---------|-------| | _ | _ | AD1IE | U1TXIE | U1RXIE | SPI1IE | SPI1EIE | T3IE | | bit 15 | | | | | | | bit 8 | | R/W-0 | R/W-0 | R/W-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | |-------|-------|-------|-----|-------|-------|-------|--------| | T2IE | OC2IE | IC2IE | _ | T1IE | OC1IE | IC1IE | INT0IE | | bit 7 | | | | | | | bit 0 | Legend: bit 7 bit 6 bit 4 bit 3 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 AD1IE: ADC1 Conversion Complete Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 12 **U1TXIE:** UART1 Transmitter Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 11 **U1RXIE:** UART1 Receiver Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 10 SPI1IE: SPI1 Event Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 9 SPI1EIE: SPI1 Event Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabledT3IE: Timer3 Interrupt Enable bit bit 8 **T3IE:** Timer3 Interrupt Enable bit 1 = Interrupt request enabled 0 = Interrupt request not enabledT2IE: Timer2 Interrupt Enable bit1 = Interrupt request enabled 0 = Interrupt request not enabledOC2IE: Output Compare Channel 2 Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 5 IC2IE: Input Capture Channel 2 Interrupt Enable bit 1 = Interrupt request enabled 0 = Interrupt request not enabled Unimplemented: Read as '0' T1IE: Timer1 Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 2 OC1IE: Output Compare Channel 1 Interrupt Enable bit 1 = Interrupt request enabled 0 = Interrupt request not enabled ### REGISTER 7-11: IEC3: INTERRUPT ENABLE CONTROL REGISTER 3 | R/W-0 | U-0 | U-0 | U-0 | U-0 | R/W-0 | R/W-0 | U-0 | |---------|-----|-----|-----|-----|-------|--------|-------| | FLTA1IE | _ | _ | _ | _ | QEIIE | PWM1IE | _ | | bit 15 | | | | | | | bit 8 | | U-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 FLTA1IE: PWM1 Fault A Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 14-11 **Unimplemented:** Read as '0' bit 10 QEIIE: QEI Event Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 9 **PWM1IE:** PWM1 Error Interrupt Enable bit 1 = Interrupt request enabled0 = Interrupt request not enabled bit 8-0 **Unimplemented:** Read as '0' #### **REGISTER 7-18: IPC5: INTERRUPT PRIORITY CONTROL REGISTER 5** | U-0 | R/W-1 | R/W-0 | R/W-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |--------|-------|------------|-------|-----|-------|------------|-------| | _ | | IC8IP<2:0> | | _ | | IC7IP<2:0> | | | bit 15 | | | | | | | bit 8 | | U-0 | U-1 | U-0 | U-0 | U-0 | R/W-1 | R/W-0 | R/W-0 | |-------|-----|-----|-----|-----|-------|-------------|-------| | _ | _ | _ | _ | _ | | INT1IP<2: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 Unimplemented: Read as '0' bit 14-12 IC8IP<2:0>: Input Capture Channel 8 Interrupt Priority bits 111 = Interrupt is priority 7 (highest priority interrupt) 001 = Interrupt is priority 1 000 = Interrupt source is disabled bit 11 Unimplemented: Read as '0' bit 10-8 IC7IP<2:0>: Input Capture Channel 7 Interrupt Priority bits 111 = Interrupt is priority 7 (highest priority interrupt) 001 = Interrupt is priority 1 000 = Interrupt source is disabled bit 7-3 Unimplemented: Read as '0' bit 2-0 INT1IP<2:0>: External Interrupt 1 Priority bits 111 = Interrupt is priority 7 (highest priority interrupt) 001 = Interrupt is priority 1 000 = Interrupt source is disabled NOTES: ## REGISTER 8-1: OSCCON: OSCILLATOR CONTROL REGISTER<sup>(1,3)</sup> (CONTINUED) bit 3 **CF:** Clock Fail Detect bit (read/clear by application) 1 = FSCM has detected clock failure0 = FSCM has not detected clock failure bit 2 Unimplemented: Read as '0' bit 0 bit 1 LPOSCEN: Secondary (LP) Oscillator Enable bit 1 = Enable secondary oscillator 0 = Disable secondary oscillator OSWEN: Oscillator Switch Enable bit 1 = Request oscillator switch to selection specified by NOSC<2:0> bits 0 = Oscillator switch is complete **Note 1:** Writes to this register require an unlock sequence. Refer to **Section 7. "Oscillator"** (DS70186) in the "dsPIC33F/PIC24H Family Reference Manual" (available from the Microchip web site) for details. - 2: Direct clock switches between any primary oscillator mode with PLL and FRCPLL mode are not permitted. This applies to clock switches in either direction. In these instances, the application must switch to FRC mode as a transition clock source between the two PLL modes. - 3: This register is reset only on a Power-on Reset (POR). ## REGISTER 9-1: PMD1: PERIPHERAL MODULE DISABLE CONTROL REGISTER 1 | U-0 | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | U-0 | |--------|-----|-------|-------|-------|-------|--------|-------| | _ | _ | T3MD | T2MD | T1MD | QEIMD | PWM1MD | _ | | 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 | _ | _ | AD1MD <sup>(1)</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 = F | 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 | | bit 11 | T1MD: Timer1 Module Disable bit | | | <ul><li>1 = Timer1 module is disabled</li><li>0 = Timer1 module is enabled</li></ul> | | bit 10 | <b>QEIMD:</b> QEI Module Disable bit | | | 1 = QEI module is disabled | | | 0 = QEI module is enabled | | bit 9 | PWM1MD: PWM1 Module Disable bit | | | 1 = PWM1 module is disabled | | | 0 = PWM1 module is enabled | | bit 18 | Unimplemented: Dood on '0' | | | Unimplemented: Read as '0' | | bit 7 | <b>I2C1MD:</b> I <sup>2</sup> C1 Module Disable bit | | | <b>I2C1MD:</b> $I^2C1$ Module Disable bit $1 = I^2C1$ module is disabled | | bit 7 | <b>I2C1MD:</b> $I^2C1$ Module Disable bit $1 = I^2C1$ module is disabled $0 = I^2C1$ module is enabled | | bit 7 | <b>I2C1MD:</b> $I^2C1$ Module Disable bit $1 = I^2C1$ module is disabled $0 = I^2C1$ module is enabled <b>Unimplemented:</b> Read as '0' | | bit 7 | I2C1MD: I <sup>2</sup> C1 Module Disable bit<br>1 = I <sup>2</sup> C1 module is disabled<br>0 = I <sup>2</sup> C1 module is enabled<br>Unimplemented: Read as '0'<br>U1MD: UART1 Module Disable bit | | bit 7 | I2C1MD: I <sup>2</sup> C1 Module Disable bit<br>1 = I <sup>2</sup> C1 module is disabled<br>0 = I <sup>2</sup> C1 module is enabled<br>Unimplemented: Read as '0'<br>U1MD: UART1 Module Disable bit<br>1 = UART1 module is disabled | | bit 7 bit 6 bit 5 | I2C1MD: $I^2$ C1 Module Disable bit<br>$1 = I^2$ C1 module is disabled<br>$0 = I^2$ C1 module is enabled<br>Unimplemented: Read as '0'<br>U1MD: UART1 Module Disable bit<br>1 = UART1 module is disabled<br>0 = UART1 module is enabled | | bit 7 bit 6 bit 5 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' | | bit 7 bit 6 bit 5 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit | | bit 7 bit 6 bit 5 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled | | bit 7 bit 6 bit 5 bit 4 bit 3 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled 0 = SPI1 module is enabled | | bit 7 bit 6 bit 5 bit 4 bit 3 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled 0 = SPI1 module is enabled Unimplemented: Read as '0' | | bit 7 bit 6 bit 5 bit 4 bit 3 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled 0 = SPI1 module is enabled Unimplemented: Read as '0' AD1MD: ADC1 Module Disable bit (1) | | bit 7 bit 6 bit 5 bit 4 bit 3 | I2C1MD: I <sup>2</sup> C1 Module Disable bit 1 = I <sup>2</sup> C1 module is disabled 0 = I <sup>2</sup> C1 module is enabled Unimplemented: Read as '0' U1MD: UART1 Module Disable bit 1 = UART1 module is disabled 0 = UART1 module is enabled Unimplemented: Read as '0' SPI1MD: SPI1 Module Disable bit 1 = SPI1 module is disabled 0 = SPI1 module is enabled Unimplemented: Read as '0' | **Note 1:** PCFGx bits have no effect if the ADC module is disabled by setting this bit. When the bit is set, all port pins that have been multiplexed with ANx will be in Digital mode. ### 10.4 Peripheral Pin Select Peripheral pin select configuration enables peripheral set selection and placement on a wide range of I/O pins. By increasing the pinout options available on a particular device, programmers can better tailor the microcontroller to their entire application, rather than trimming the application to fit the device. The peripheral pin select configuration feature operates over a fixed subset of digital I/O pins. Programmers can independently map the input and/or output of most digital peripherals to any one of these I/O pins. Peripheral pin select is performed in software, and generally does not require the device to be reprogrammed. Hardware safeguards are included that prevent accidental or spurious changes to the peripheral mapping, once it has been established. #### 10.4.1 AVAILABLE PINS The peripheral pin select feature is used with a range of up to 16 pins. The number of available pins depends on the particular device and its pin count. Pins that support the peripheral pin select feature include the designation "RPn" in their full pin designation, where "RP" designates a remappable peripheral and "n" is the remappable pin number. ## 10.4.2 CONTROLLING PERIPHERAL PIN SELECT Peripheral pin select features are controlled through two sets of special function registers: one to map peripheral inputs, and one to map outputs. Because they are separately controlled, a particular peripheral's input and output (if the peripheral has both) can be placed on any selectable function pin without constraint. The association of a peripheral to a peripheral selectable pin is handled in two different ways, depending on whether an input or output is being mapped. #### 10.4.2.1 Input Mapping Note: The inputs of the peripheral pin select options are mapped on the basis of the peripheral. A control register associated with a peripheral dictates the pin it will be mapped to. The RPINRx registers are used to configure peripheral input mapping (see Register 10-1 through Register 10-13). Each register contains sets of 5-bit fields, with each set associated with one of the remappable peripherals. Programming a given peripheral's bit field with an appropriate 5-bit value maps the RPn pin with that value to that peripheral. For any given device, the valid range of values for any bit field corresponds to the maximum number of peripheral pin selections supported by the device. Figure 10-2 Illustrates remappable pin selection for U1RX input. For input mapping only, the Peripheral Pin Select (PPS) functionality does not have priority over the TRISx settings. Therefore, when configuring the RPx pin for input, the corresponding bit in the TRISx register must also be configured for input (i.e., set to '1'). FIGURE 10-2: REMAPPABLE MUX INPUT FOR U1RX ### REGISTER 10-6: RPINR11: PERIPHERAL PIN SELECT INPUT REGISTER 11 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | _ | _ | | _ | | _ | bit 8 | | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-----|-------|-------|------------|-------|-------| | _ | _ | _ | | | OCFAR<4: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-5 **Unimplemented:** Read as '0' bit 4-0 OCFAR<4:0>: Assign Output Capture A (OCFA) to the corresponding RPn pin 11111 = Input tied Vss 01111 = Input tied to RP15 : 00001 = Input tied to RP1 00000 = Input tied to RP0 ### REGISTER 10-7: RPINR12: PERIPHERAL PIN SELECT INPUT REGISTER 12 | U-0 |--------|-----|-----|-----|-----|-----|-----|-------| | _ | _ | _ | _ | _ | _ | _ | _ | | bit 15 | | | | | | | bit 8 | | U-0 | U-0 | U-0 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | R/W-1 | |-------|-----|-----|-------|-------|-------------|-------|-------| | _ | _ | _ | | | FLTA1R<4: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-5 **Unimplemented:** Read as '0' bit 4-0 **FLTA1R<4:0>:** Assign PWM1 Fault (FLTA1) to the corresponding RPn pin 11111 = Input tied Vss 01111 = Input tied to RP15 ٠ © 2007-2011 Microchip Technology Inc. 00001 = Input tied to RP1 00000 = Input tied to RP0 ### REGISTER 15-4: PXSECMP: SPECIAL EVENT COMPARE REGISTER | R/W-0 |------------------------|-------|-------|-------|-------------|-------|-------|-------| | SEVTDIR <sup>(1)</sup> | | | SI | EVTCMP<14:8 | 3>(2) | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|--------|-----------------------|-------|-------|-------| | | | | SEVTCM | P<7:0> <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 **SEVTDIR:** Special Event Trigger Time Base Direction bit<sup>(1)</sup> 1 = A Special Event Trigger will occur when the PWM time base is counting down 0 = A Special Event Trigger will occur when the PWM time base is counting up bit 14-0 SEVTCMP<14:0>: Special Event Compare Value bits<sup>(2)</sup> Note 1: SEVTDIR is compared with PTDIR (PxTMR<15>) to generate the Special Event Trigger. 2: PxSECMP<14:0> is compared with PxTMR<14:0> to generate the Special Event Trigger. ### REGISTER 15-11: PxDC1: PWM DUTY CYCLE REGISTER 1 | R/W-0 |--------|-------|-------|-------|--------|-------|-------|-------| | | | | PDC1 | <15:8> | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | | | | PDC1 | <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 PDC1<15:0>: PWM Duty Cycle 1 Value bits #### REGISTER 15-12: P1DC2: PWM DUTY CYCLE REGISTER 2 | R/W-0 |--------|-------|-------|-------|--------|-------|-------|-------| | | | | PDC2 | <15:8> | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|--------|-------|-------|-------| | | | | PDC2 | !<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 PDC2<15:0>: PWM Duty Cycle 2 Value bits ### REGISTER 15-13: P1DC3: PWM DUTY CYCLE REGISTER 3 | R/W-0 |--------|-------|-------|-------|--------|-------|-------|-------| | | | | PDC3 | <15:8> | | | | | bit 15 | | | | | | | bit 8 | | R/W-0 |-------|-------|-------|-------|-------|-------|-------|-------| | | | | PDC3 | <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 PDC3<15:0>: PWM Duty Cycle 3 Value bits TABLE 21-2: dsPIC33F CONFIGURATION BITS DESCRIPTION (CONTINUED) | TABLE 21-2: | usricssi | CON IGO | IFIGURATION BITS DESCRIPTION (CONTINUED) | | | |--------------|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit Field | Register | RTSP<br>Effect | Description | | | | FWDTEN | FWDT | Immediate | Watchdog Timer Enable bit 1 = Watchdog Timer always enabled (LPRC oscillator cannot be disabled. Clearing the SWDTEN bit in the RCON register will have no effect.) 0 = Watchdog Timer enabled/disabled by user software (LPRC can be disabled by clearing the SWDTEN bit in the RCON register) | | | | WINDIS | FWDT | Immediate | Watchdog Timer Window Enable bit 1 = Watchdog Timer in Non-Window mode 0 = Watchdog Timer in Window mode | | | | WDTPRE | FWDT | Immediate | Watchdog Timer Prescaler bit<br>1 = 1:128<br>0 = 1:32 | | | | WDTPOST<3:0> | FWDT | Immediate | Watchdog Timer Postscaler bits 1111 = 1:32,768 1110 = 1:16,384 | | | | PWMPIN | FPOR | Immediate | Motor Control PWM Module Pin Mode bit 1 = PWM module pins controlled by PORT register at device Reset (tri-stated) 0 = PWM module pins controlled by PWM module at device Reset (configured as output pins) | | | | HPOL | FPOR | Immediate | Motor Control PWM High Side Polarity bit 1 = PWM module high side output pins have active-high output polarity 0 = PWM module high side output pins have active-low output polarity | | | | LPOL | FPOR | Immediate | Motor Control PWM Low Side Polarity bit 1 = PWM module low side output pins have active-high output polarity 0 = PWM module low side output pins have active-low output polarity | | | | FPWRT<2:0> | FPOR | Immediate | Power-on Reset Timer Value Select bits 111 = PWRT = 128 ms 110 = PWRT = 64 ms 101 = PWRT = 32 ms 100 = PWRT = 16 ms 011 = PWRT = 8 ms 010 = PWRT = 4 ms 001 = PWRT = 2 ms 000 = PWRT = Disabled | | | | ALTI2C | FPOR | Immediate | Alternate I <sup>2</sup> C pins<br>1 = I <sup>2</sup> C mapped to SDA1/SCL1 pins<br>0 = I <sup>2</sup> C mapped to ASDA1/ASCL1 pins | | | | JTAGEN | FICD | Immediate | JTAG Enable bit 1 = JTAG enabled 0 = JTAG disabled | | | | ICS<1:0> | FICD | Immediate | ICD Communication Channel Select bits 11 = Communicate on PGEC1 and PGED1 10 = Communicate on PGEC2 and PGED2 01 = Communicate on PGEC3 and PGED3 00 = Reserved, do not use | | | TABLE 24-9: DC CHARACTERISTICS: I/O PIN INPUT SPECIFICATIONS (CONTINUED) | DC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤TA ≤+85°C for Industrial -40°C ≤TA ≤+125°C for Extended | | | | | | |--------------------|--------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------|-------|--------------------------------------------------------------------|--| | Param<br>No. | Symbol | Characteristic | Min | Typ <sup>(1)</sup> | Max | Units | Conditions | | | | IIL | Input Leakage Current(2,3) | | | | | | | | DI50 | | I/O Pins 5V Tolerant <sup>(4)</sup> | _ | | ±2 | μА | Vss ≤VPIN ≤VDD,<br>Pin at high-impedance | | | DI51 | | I/O Pins Not 5V Tolerant <sup>(4)</sup> | _ | _ | ±1 | μА | Vss ≤VPIN ≤VDD,<br>Pin at high-impedance,<br>-40°C ≤TA ≤+85°C | | | DI51a | | I/O Pins Not 5V Tolerant <sup>(4)</sup> | _ | _ | ±2 | μΑ | Shared with external reference pins, -40°C ≤TA ≤+85°C | | | DI51b | | I/O Pins Not 5V Tolerant <sup>(4)</sup> | _ | _ | ±3.5 | μА | Vss ≤VPIN ≤VDD, Pin at high-impedance, -40°C ≤TA ≤+125°C | | | DI51c | | I/O Pins Not 5V Tolerant <sup>(4)</sup> | _ | _ | ±8 | μА | Analog pins shared with external reference pins, -40°C ≤TA ≤+125°C | | | DI55 | | MCLR | _ | _ | ±2 | μΑ | Vss ⊴Vpin ⊴Vdd | | | DI56 | | OSC1 | _ | _ | ±2 | μА | Vss ≤VPIN ≤VDD,<br>XT and HS modes | | - Note 1: Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. - 2: The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current may be measured at different input voltages. - 3: Negative current is defined as current sourced by the pin. - 4: See "Pin Diagrams" for a list of 5V tolerant pins. - 5: VIL source < (Vss 0.3). Characterized but not tested. - **6:** Non-5V tolerant pins VIH source > (VDD + 0.3), 5V tolerant pins VIH source > 5.5V. Characterized but not tested. - 7: Digital 5V tolerant pins cannot tolerate any "positive" input injection current from input sources > 5.5V. - 8: Injection currents > | 0 | can affect the ADC results by approximately 4-6 counts. - **9:** Any number and/or combination of I/O pins not excluded under IICL or IICH conditions are permitted provided the mathematical "absolute instantaneous" sum of the input injection currents from all pins do not exceed the specified limit. Characterized but not tested. - 10: These parameters are characterized, but not tested. TABLE 24-12: DC CHARACTERISTICS: PROGRAM MEMORY | DC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) | | | | | | | |--------------------|--------|--------------------------------------|-----------------------------------------------------------------------|------------------------------|------|-------------------------------------------------------------------|------------------------------------------------------------|--|--| | | | | Operating temperature | | | -40°C ≤TA ≤+85°C for Industrial<br>-40°C ≤TA ≤+125°C for Extended | | | | | Param<br>No. | Symbol | Characteristic <sup>(3)</sup> | Min | Min Typ <sup>(1)</sup> Max U | | Units | Conditions | | | | | | Program Flash Memory | | | | | | | | | D130a | EP | Cell Endurance | 10,000 | _ | _ | E/W | -40° C to +125° C | | | | D131 | VPR | VDD for Read | VMIN | _ | 3.6 | V | VMIN = Minimum operating voltage | | | | D132B | VPEW | VDD for Self-Timed Write | VMIN | _ | 3.6 | V | VMIN = Minimum operating voltage | | | | D134 | TRETD | Characteristic Retention | 20 | _ | _ | Year | Provided no other specifications are violated | | | | D135 | IDDP | Supply Current during<br>Programming | _ | 10 | _ | mA | | | | | D136a | Trw | Row Write Time | 1.32 | _ | 1.74 | ms | TRW = 11064 FRC cycles,<br>TA = +85°C, See <b>Note 2</b> | | | | D136b | TRW | Row Write Time | 1.28 | _ | 1.79 | ms | TRW = 11064 FRC cycles,<br>TA = +125°C, See <b>Note 2</b> | | | | D137a | TPE | Page Erase Time | 20.1 | _ | 26.5 | ms | TPE = 168517 FRC cycles,<br>TA = +85°C, See <b>Note 2</b> | | | | D137b | TPE | Page Erase Time | 19.5 | _ | 27.3 | ms | TPE = 168517 FRC cycles,<br>TA = +125°C, See <b>Note 2</b> | | | | D138a | Tww | Word Write Cycle Time | 42.3 | _ | 55.9 | μs | Tww = 355 FRC cycles,<br>TA = +85°C, See <b>Note 2</b> | | | | D138b | Tww | Word Write Cycle Time | 41.1 | _ | 57.6 | μs | Tww = 355 FRC cycles,<br>TA = +125°C, See <b>Note 2</b> | | | - **Note 1:** Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. - 2: Other conditions: FRC = 7.37 MHz, TUN<5:0> = b'011111 (for Min), TUN<5:0> = b'100000 (for Max). This parameter depends on the FRC accuracy (see Table 24-18) and the value of the FRC Oscillator Tuning register (see Register 8-4). For complete details on calculating the Minimum and Maximum time see Section 5.3 "Programming Operations". - 3: These parameters are ensured by design, but are not characterized or tested in manufacturing. **TABLE 24-13: INTERNAL VOLTAGE REGULATOR SPECIFICATIONS** | DC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤TA ≤+85°C for Industrial -40°C ≤TA ≤+125°C for Extended | | | | | |--------------------|--------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|----|----------------------------------------------------| | Param<br>No. | Symbol | Characteristics | Min Typ Max Units Comments | | | | Comments | | | CEFC | External Filter Capacitor Value <sup>(1)</sup> | 4.7 | 10 | | μF | Capacitor must be low series resistance (< 5 ohms) | **Note 1:** Typical VCAP pin voltage = 2.5V when VDD ≥ VDDMIN. TABLE 24-29: MOTOR CONTROL PWM MODULE TIMING REQUIREMENTS | AC CHARACTERISTICS | | | Standard Operating Conditions: 3.0V to 3.6V (unless otherwise stated) Operating temperature -40°C ≤TA ≤+85°C for Industrial -40°C ≤TA ≤+125°C for Extended | | | | | |--------------------|--------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|----|--------------------| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min Typ Max Units Conditions | | | | | | MP10 | TFPWM | PWM Output Fall Time | _ | _ | _ | ns | See parameter D032 | | MP11 | TRPWM | PWM Output Rise Time | _ | _ | _ | ns | See parameter D031 | | MP20 | TFD | Fault Input ↓to PWM<br>I/O Change | _ | _ | 50 | ns | _ | | MP30 | TFH | Minimum Pulse Width | 50 | _ | _ | ns | _ | Note 1: These parameters are characterized by similarity, but are not tested in manufacturing. ## FIGURE 24-12: QEA/QEB INPUT CHARACTERISTICS TABLE 24-37: SPIX 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°C ≤TA ≤+85°C for Industrial -40°C ≤TA ≤+125°C for Extended | | | | | | |--------------------|-----------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|--------------------------------------|--| | Param<br>No. | Symbol | Characteristic <sup>(1)</sup> | Min | Typ <sup>(2)</sup> | Max | Units | Conditions | | | SP70 | TscP | Maximum SCK Input Frequency | _ | _ | 11 | MHz | See Note 3 | | | SP72 | TscF | SCKx Input Fall Time | _ | | _ | ns | See parameter DO32 and <b>Note 4</b> | | | SP73 | TscR | SCKx Input Rise Time | _ | | 1 | ns | See parameter DO31 and <b>Note 4</b> | | | SP30 | TdoF | SDOx Data Output Fall Time | _ | | _ | ns | See parameter DO32 and <b>Note 4</b> | | | SP31 | TdoR | SDOx Data Output Rise Time | _ | | _ | ns | See parameter DO31 and <b>Note 4</b> | | | SP35 | TscH2doV,<br>TscL2doV | SDOx Data Output Valid after<br>SCKx Edge | _ | 6 | 20 | ns | _ | | | SP36 | TdoV2scH,<br>TdoV2scL | SDOx Data Output Setup to First SCKx Edge | 30 | | _ | ns | _ | | | SP40 | TdiV2scH,<br>TdiV2scL | Setup Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | _ | | | SP41 | TscH2diL,<br>TscL2diL | Hold Time of SDIx Data Input to SCKx Edge | 30 | | _ | ns | _ | | | SP50 | TssL2scH,<br>TssL2scL | SSx ↓to SCKx ↑ or SCKx Input | 120 | 1 | | ns | _ | | | SP51 | TssH2doZ | SSx ↑ to SDOx Output<br>High-Impedance <sup>(4)</sup> | 10 | | 50 | ns | _ | | | SP52 | TscH2ssH<br>TscL2ssH | SSx after SCKx Edge | 1.5 Tcy + 40 | _ | _ | ns | See Note 4 | | | SP60 | TssL2doV | SDOx Data Output Valid after<br>SSx Edge | _ | | 50 | ns | _ | | - Note 1: These parameters are characterized, but are not tested in manufacturing. - **2:** Data in "Typ" column is at 3.3V, 25°C unless otherwise stated. - **3:** The minimum clock period for SCKx is 91 ns. Therefore, the SCK clock generated by the Master must not violate this specification. - 4: Assumes 50 pF load on all SPIx pins. ## **TABLE 25-1: MAJOR SECTION UPDATES** | Section Name | Update Description | |----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Section 23.0 "Electrical<br>Characteristics" | Updated Max MIPS value for -40°C to +125°C temperature range in Operating MIPS vs. Voltage (see Table 23-1). | | | Added 20-pin SOIC and 28-pin SSOP package information to Thermal Packaging Characteristics and updated Typical values for all devices (see Table 23-3). | | | Removed Typ value for parameter DC12 (see Table 23-4). | | | Updated Note 2 in Table 23-7: DC Characteristics: Power-Down Current (IPD). | | | Updated MIPS conditions for parameters DC24c, DC44c, DC72a, DC72f, and DC72g (see Table 23-5, Table 23-6, and Table 23-8). | | | Added Note 4 (reference to new table containing digital-only and analog pin information to I/O Pin Input Specifications (see Table 23-9). | | | Updated Program Memory parameters (D136a, D136b, D137a, D137b, D138a and D138b) and added Note 2 (see Table 23-12). | | | Updated Max value for Internal RC Accuracy parameter F21 for -40°C $\leq$ TA $\leq$ +125°C condition and added Note 2 (see Table 23-19). | | | Removed all values for Reset, Watchdog Timer, Oscillator Start-up Timer, and Power-up Timer parameter SY20 and updated conditions, which now refers to <b>Section 20.4 "Watchdog Timer (WDT)"</b> and LPRC parameter F21 (Table 23-21). | | | Updated Min value for Input Capture Timing Requirements parameter IC15 (see Table 23-26). | | | The following changes were made to the ADC Module Specifications (Table 23-38): | | | Updated Min value for ADC Module Specification parameter AD07. | | | Updated Typ value for parameter AD08 Added or formation AD40 and AD40 | | | <ul> <li>Added references to Note 1 for parameters AD12 and AD13</li> <li>Removed Note 2.</li> </ul> | | | The following changes were made to the ADC Module Specifications (12-bit Mode) (Table 23-39): | | | <ul> <li>Updated Min and Max values for both AD21a parameters (measurements<br/>with internal and external VREF+/VREF-).</li> </ul> | | | <ul><li>Updated Min, Typ, and Max values for parameter AD24a.</li><li>Updated Max value for parameter AD32a.</li></ul> | | | Removed Note 1. | | | <ul> <li>Removed VREFL from Conditions for parameters AD21a, AD22a, AD23a,<br/>and AD24a (measurements with internal VREF+/VREF-).</li> </ul> | | | The following changes were made to the ADC Module Specifications (10-bit Mode) (Table 23-40): | | | <ul> <li>Updated Min and Max values for parameter AD21b (measurements with<br/>external VREF+/VREF-).</li> </ul> | | | <ul> <li>Removed ± symbol from Min, Typ, and Max values for parameters AD23b<br/>and AD24b (measurements with internal VREF+/VREF-).</li> </ul> | | | <ul> <li>Updated Typ and Max values for parameter AD32b.</li> <li>Removed Note 1.</li> </ul> | | | <ul> <li>Removed Note 1.</li> <li>Removed VREFL from Conditions for parameters AD21a, AD22a, AD23a, and AD24a (measurements with <i>internal</i> VREF+/VREF-).</li> </ul> | | | Updated Min and Typ values for parameters AD60, AD61, AD62, and AD63 an removed Note 3 (see Table 23-41 and Table 23-42). | ## THE MICROCHIP WEB SITE Microchip provides online support via our WWW site at www.microchip.com. This web site is used as a means to make files and information easily available to customers. Accessible by using your favorite Internet browser, the web site contains the following information: - Product Support Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software - General Technical Support Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip consultant program member listing - Business of Microchip Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives # CUSTOMER CHANGE NOTIFICATION SERVICE Microchip's customer notification service helps keep customers current on Microchip products. Subscribers will receive e-mail notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest. To register, access the Microchip web site at www.microchip.com. Under "Support", click on "Customer Change Notification" and follow the registration instructions. #### **CUSTOMER SUPPORT** Users of Microchip products can receive assistance through several channels: - · Distributor or Representative - · Local Sales Office - Field Application Engineer (FAE) - · Technical Support - · Development Systems Information Line Customers should contact their distributor, representative or field application engineer (FAE) for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in the back of this document. Technical support is available through the web site at: http://microchip.com/support