

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Details                    |                                                                                  |
|----------------------------|----------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                         |
| Core Processor             | dsPIC                                                                            |
| Core Size                  | 16-Bit                                                                           |
| Speed                      | 16 MIPs                                                                          |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART                                  |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                            |
| Number of I/O              | 13                                                                               |
| Program Memory Size        | 32KB (11K x 24)                                                                  |
| Program Memory Type        | FLASH                                                                            |
| EEPROM Size                | - ·                                                                              |
| RAM Size                   | 1K x 16                                                                          |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                        |
| Data Converters            | A/D 6x10b                                                                        |
| Oscillator Type            | Internal                                                                         |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                                |
| Mounting Type              | Surface Mount                                                                    |
| Package / Case             | 18-SOIC (0.295", 7.50mm Width)                                                   |
| Supplier Device Package    | 18-SOIC                                                                          |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic33fj32gp101t-i-so |
|                            |                                                                                  |

Email: info@E-XFL.COM

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

## dsPIC33FJ16(GP/MC)101/102 AND dsPIC33FJ32(GP/MC)101/102/104

#### Pin Diagrams (Continued)



#### Pin Diagrams (Continued)



#### 2.7 Oscillator Value Conditions on Device Start-up

If the PLL of the target device is enabled and configured for the device start-up oscillator, the maximum oscillator source frequency must be limited to 4 MHz < FIN < 8 MHz (for MSPLL mode) or 3 MHz < FIN < 8 MHz (for ECPLL mode) to comply with device PLL start-up conditions. HSPLL mode is not supported. This means that if the external oscillator frequency is outside this range, the application must start-up in the FRC mode first. The fixed PLL settings of 4x after a POR with an oscillator frequency outside this range will violate the device operating speed.

Once the device powers up, the application firmware can enable the PLL and then perform a clock switch to the Oscillator + PLL clock source. Note that clock switching must be enabled in the device Configuration Word.

#### 2.8 Configuration of Analog and Digital Pins During ICSP Operations

If MPLAB ICD 3 or MPLAB REAL ICE in-circuit emulator is selected as a debugger, it automatically initializes all of the Analog-to-Digital input pins (ANx) as "digital" pins, by setting all bits in the AD1PCFGL register.

The bits in the register that correspond to the Analog-to-Digital pins that are initialized by MPLAB ICD 3 or MPLAB REAL ICE in-circuit emulator, must not be cleared by the user application firmware; otherwise, communication errors will result between the debugger and the device.

If your application needs to use certain Analog-to-Digital pins as analog input pins during the debug session, the user application must clear the corresponding bits in the AD1PCFGL register during initialization of the ADC module.

When MPLAB ICD 3 or MPLAB REAL ICE in-circuit emulator is used as a programmer, the user application firmware must correctly configure the AD1PCFGL register. Automatic initialization of this register is only done during debugger operation. Failure to correctly configure the register(s) will result in all Analog-to-Digital pins being recognized as analog input pins, resulting in the port value being read as a logic '0', which may affect user application functionality.

#### 2.9 Unused I/Os

Unused I/O pins should be configured as outputs and driven to a logic-low state.

Alternately, connect a 1k to 10k resistor between Vss and unused pins.

#### REGISTER 3-1: SR: CPU STATUS REGISTER (CONTINUED)

| bit 7-5 | IPL<2:0>: CPU Interrupt Priority Level Status bits <sup>(2,3)</sup>                                                                                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <pre>111 = CPU Interrupt Priority Level is 7 (15), user interrupts are disabled<br/>110 = CPU Interrupt Priority Level is 6 (14)<br/>101 = CPU Interrupt Priority Level is 5 (13)<br/>100 = CPU Interrupt Priority Level is 4 (12)<br/>011 = CPU Interrupt Priority Level is 3 (11)<br/>010 = CPU Interrupt Priority Level is 2 (10)<br/>001 = CPU Interrupt Priority Level is 1 (9)<br/>000 = CPU Interrupt Priority Level is 0 (8)</pre> |
| bit 4   | RA: REPEAT Loop Active bit                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         | 1 = REPEAT loop is in progress<br>0 = REPEAT loop is not in progress                                                                                                                                                                                                                                                                                                                                                                       |
| bit 3   | N: MCU ALU Negative bit                                                                                                                                                                                                                                                                                                                                                                                                                    |
|         | 1 = Result was negative<br>0 = Result was non-negative (zero or positive)                                                                                                                                                                                                                                                                                                                                                                  |
| bit 2   | OV: MCU ALU Overflow bit                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | This bit is used for signed arithmetic (2's complement). It indicates an overflow of a magnitude that causes the sign bit to change state.<br>1 = Overflow occurred for signed arithmetic (in this arithmetic operation)<br>0 = No overflow occurred                                                                                                                                                                                       |
| bit 1   | Z: MCU ALU Zero bit                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         | <ul> <li>1 = An operation that affects the Z bit has set it at some time in the past</li> <li>0 = The most recent operation that affects the Z bit has cleared it (i.e., a non-zero result)</li> </ul>                                                                                                                                                                                                                                     |
| bit 0   | C: MCU ALU Carry/Borrow bit                                                                                                                                                                                                                                                                                                                                                                                                                |
|         | <ul> <li>1 = A carry-out from the Most Significant bit of the result occurred</li> <li>0 = No carry-out from the Most Significant bit of the result occurred</li> </ul>                                                                                                                                                                                                                                                                    |
| 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. 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>).

| U-0             | U-0                            | U-0                                   | R/W-0           | R/W-0               | R-0              | R-0              | R-0   |
|-----------------|--------------------------------|---------------------------------------|-----------------|---------------------|------------------|------------------|-------|
| —               | —                              | _                                     | US              | EDT <sup>(1)</sup>  | DL2              | DL1              | DL0   |
| bit 15          |                                |                                       |                 |                     |                  |                  | bit   |
| R/W-0           | R/W-0                          | R/W-1                                 | R/W-0           | R/C-0               | R/W-0            | R/W-0            | R/W-0 |
| SATA            | SATB                           | SATDW                                 | ACCSAT          | IPL3 <sup>(2)</sup> | PSV              | R/W-0            | IF    |
| bit 7           | SAID                           | SAIDW                                 | ACCOAT          | IF L3. 7            | F3V              | RND              | bit   |
|                 |                                |                                       |                 |                     |                  |                  | Dit   |
| Legend:         |                                | C = Clearable                         | e bit           |                     |                  |                  |       |
| R = Readabl     | e bit                          | W = Writable                          | bit             | -n = Value at       | POR              | '1' = Bit is set |       |
| 0' = Bit is cle | ared                           | 'x = Bit is unk                       | nown            | U = Unimple         | mented bit, read | d as '0'         |       |
| bit 15-13       | Unimplemen                     | ted: Read as '                        | 0'              |                     |                  |                  |       |
| bit 12          | -                              | tiply Unsigned                        |                 | ol bit              |                  |                  |       |
|                 |                                | ne multiplies a                       | •               |                     |                  |                  |       |
|                 | 0 = DSP engi                   | ne multiplies a                       | ire signed      |                     |                  |                  |       |
| bit 11          |                                | Loop Termina                          |                 |                     |                  |                  |       |
|                 | 1 = Terminate<br>0 = No effect | es executing Do                       | o loop at the e | nd of current lo    | oop iteration    |                  |       |
| bit 10-8        | DL<2:0>: DO                    | Loop Nesting                          | Level Status b  | its                 |                  |                  |       |
|                 | 111 <b>= 7</b> DO <b>lo</b>    | ops are active                        |                 |                     |                  |                  |       |
|                 | •                              |                                       |                 |                     |                  |                  |       |
|                 | •<br>001 = 1 DO lo             | on is activo                          |                 |                     |                  |                  |       |
|                 |                                | ops are active                        |                 |                     |                  |                  |       |
| bit 7           | SATA: ACCA                     | Saturation En                         | able bit        |                     |                  |                  |       |
|                 |                                | itor A saturatio                      |                 |                     |                  |                  |       |
|                 |                                | itor A saturatio                      |                 |                     |                  |                  |       |
| bit 6           |                                | Saturation En                         |                 |                     |                  |                  |       |
|                 |                                | tor B saturatio                       |                 |                     |                  |                  |       |
| bit 5           |                                |                                       |                 | ine Saturation      | Enable bit       |                  |       |
|                 |                                | ce write satura                       |                 |                     |                  |                  |       |
|                 |                                | ce write satura                       |                 |                     |                  |                  |       |
| bit 4           | ACCSAT: Acc                    | cumulator Satu                        | uration Mode S  | Select bit          |                  |                  |       |
|                 |                                | ration (super s                       |                 |                     |                  |                  |       |
| L:1 0           |                                | ration (normal                        | ,               | ··· (2)             |                  |                  |       |
| bit 3           |                                | terrupt Priority<br>rrupt Priority Le |                 |                     |                  |                  |       |
|                 |                                | rupt Priority Le                      | •               |                     |                  |                  |       |
| bit 2           |                                |                                       |                 | ace Enable bit      |                  |                  |       |
|                 |                                | space is visible                      |                 |                     |                  |                  |       |
|                 | -                              | space is not vi                       |                 | pace                |                  |                  |       |
| bit 1           |                                | ng Mode Sele                          |                 |                     |                  |                  |       |
|                 |                                | onventional) ro<br>(convergent)       |                 |                     |                  |                  |       |
| bit 0           | IF: Integer or                 | Fractional Mul                        | tiplier Mode S  | elect bit           |                  |                  |       |
|                 | -                              |                                       |                 | iply operations     |                  |                  |       |
|                 | 0 = Fractional                 | l mode is enab                        | led for DSP m   | nultiply operation  | ons              |                  |       |

#### REGISTER 3-2: CORCON: CORE CONTROL REGISTER

2: The IPL3 bit is concatenated with the IPL<2:0> bits (SR<7:5>) to form the CPU Interrupt Priority Level.

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.

#### 4.4.3 MODULO ADDRESSING APPLICABILITY

Modulo Addressing can be applied to the Effective Address (EA) calculation associated with any W register. Address boundaries check for addresses equal to:

- The upper boundary addresses for incrementing buffers
- The lower boundary addresses for decrementing buffers

It is important to realize that the address boundaries check for addresses less than or greater than the upper (for incrementing buffers) and lower (for decrementing buffers) boundary addresses (not just equal to). Address changes can, therefore, jump beyond boundaries and still be adjusted correctly.

Note: The modulo corrected Effective Address is written back to the register only when Pre-Modify or Post-Modify Addressing mode is used to compute the Effective Address. When an address offset (such as [W7 + W2]) is used, Modulo Addressing correction is performed, but the contents of the register remain unchanged.

#### 4.5 Bit-Reversed Addressing

Bit-Reversed Addressing mode is intended to simplify data reordering for radix-2 FFT algorithms. It is supported by the X AGU for data writes only.

The modifier, which can be a constant value or register contents, is regarded as having its bit order reversed. The address source and destination are kept in normal order. Thus, the only operand requiring reversal is the modifier.

# 4.5.1 BIT-REVERSED ADDRESSING IMPLEMENTATION

Bit-Reversed Addressing mode is enabled in any of these situations:

- BWM<3:0> bits (W register selection) in the MODCON register are any value other than '15' (the stack cannot be accessed using Bit-Reversed Addressing)
- The BREN bit is set in the XBREV register
- The addressing mode used is Register Indirect with Pre-Increment or Post-Increment

If the length of a bit-reversed buffer is  $M = 2^N$  bytes, the last 'N' bits of the data buffer start address must be zeros.

XB<14:0> is the bit-reversed address modifier, or 'pivot point,' which is typically a constant. In the case of an FFT computation, its value is equal to half of the FFT data buffer size.

**Note:** All bit-reversed EA calculations assume word-sized data (LSb of every EA is always clear). The XB<14:0> value is scaled accordingly to generate compatible (byte) addresses.

When enabled, Bit-Reversed Addressing is executed only for Register Indirect with Pre-Increment or Post-Increment Addressing and word-sized data writes. It will not function for any other addressing mode or for byte-sized data and normal addresses are generated instead. When Bit-Reversed Addressing is active, the W Address Pointer is always added to the address modifier (XB) and the offset associated with the Register Indirect Addressing mode is ignored. In addition, as word-sized data is a requirement, the LSb of the EA is ignored (and always clear).

Note: Modulo Addressing and Bit-Reversed Addressing should not be enabled together. If an application attempts to do so, Bit-Reversed Addressing will assume priority when active. For the X WAGU and Y AGU, Modulo Addressing will be disabled. However, Modulo Addressing will continue to function in the X RAGU.

If Bit-Reversed Addressing has already been enabled by setting the BREN (XBREV<15>) bit, a write to the XBREV register should not be immediately followed by an indirect read operation using the W register that has been designated as the Bit-Reversed Pointer.

#### 5.0 FLASH PROGRAM MEMORY

- Note 1: This data sheet summarizes the features of the dsPIC33FJ16(GP/MC)101/102 and dsPIC33FJ32(GP/MC)101/102/104 family devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Flash Programming" (DS70191) 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 dsPIC33FJ16(GP/MC)101/102 and dsPIC33FJ32(GP/MC)101/102/104 devices contain internal Flash program memory for storing and executing application code. The memory is readable, writable and erasable during normal operation over the entire VDD range.

Flash memory can be programmed in two ways:

- In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>) programming capability
- Run-Time Self-Programming (RTSP)

ICSP allows a device to be serially programmed while in the end application circuit. This is done with two lines for programming clock and programming data (one of the alternate programming pin pairs: PGECx/PGEDx), and three other lines for power (VDD), ground (VSS) and Master Clear (MCLR). This allows users to manufacture boards with unprogrammed devices and then program the Digital Signal Controller just before shipping the product. This also allows the most recent firmware or a custom firmware to be programmed.

RTSP is accomplished using TBLRD (Table Read) and TBLWT (Table Write) instructions. With RTSP, the user application can write program memory data in a single program memory word and erase program memory in blocks or 'pages' of 512 instructions (1536 bytes).

#### 5.1 Table Instructions and Flash Programming

Regardless of the method used, all programming of Flash memory is done with the Table Read and Table Write instructions. These allow direct read and write access to the program memory space, from the data memory, while the device is in normal operating mode. The 24-bit target address in the program memory is formed using bits<7:0> of the TBLPAG register and the Effective Address (EA) from a W register specified in the table instruction, as shown in Figure 5-1.

The TBLRDL and the TBLWTL instructions are used to read or write to bits<15:0> of program memory. TBLRDL and TBLWTL can access program memory in both Word and Byte modes.

The TBLRDH and TBLWTH instructions are used to read or write to bits<23:16> of program memory. TBLRDH and TBLWTH can also access program memory in Word or Byte mode.

#### FIGURE 5-1:

: ADDRESSING FOR TABLE REGISTERS



#### FIGURE 7-1: dsPIC33FJ16(GP/MC)101/102 AND dsPIC33FJ32(GP/MC)101/102/104 INTERRUPT VECTOR TABLE

| 1                                 |                                            | 7                    |                                                        |
|-----------------------------------|--------------------------------------------|----------------------|--------------------------------------------------------|
|                                   | Reset – GOTO Instruction                   | 0x000000             |                                                        |
|                                   | Reset – GOTO Address                       | 0x000002             |                                                        |
|                                   | Reserved                                   | 0x000004             |                                                        |
|                                   | Oscillator Fail Trap Vector                | _                    |                                                        |
|                                   | Address Error Trap Vector                  | _                    |                                                        |
|                                   | Stack Error Trap Vector                    | _                    |                                                        |
|                                   | Math Error Trap Vector                     | _                    |                                                        |
|                                   | Reserved                                   | -                    |                                                        |
|                                   | Reserved                                   | _                    |                                                        |
|                                   | Reserved<br>Interrupt Vector 0             | 0x000014             |                                                        |
|                                   | Interrupt Vector 1                         | 0,000014             |                                                        |
|                                   |                                            | -                    |                                                        |
|                                   | ~                                          |                      |                                                        |
|                                   | ~                                          | _                    |                                                        |
|                                   | Interrupt Vector 52                        | 0x00007C             | (4)                                                    |
|                                   | Interrupt Vector 53                        | 0x00007E             | Interrupt Vector Table (IVT) <sup>(1)</sup>            |
| ity                               | Interrupt Vector 54                        | 0x000080             |                                                        |
| iori                              | ~                                          |                      |                                                        |
| ā                                 | ~                                          |                      |                                                        |
| der                               | ~                                          |                      |                                                        |
| Decreasing Natural Order Priority | Interrupt Vector 116                       | 0x0000FC             |                                                        |
| ra                                | Interrupt Vector 117                       | 0x0000FE             |                                                        |
| atu                               | Reserved                                   | 0x000100             |                                                        |
| Z                                 | Reserved                                   | 0x000102             |                                                        |
| sing                              | Reserved                                   |                      |                                                        |
| eas                               | Oscillator Fail Trap Vector                |                      |                                                        |
| ecr                               | Address Error Trap Vector                  |                      |                                                        |
| ă                                 | Stack Error Trap Vector                    |                      |                                                        |
|                                   | Math Error Trap Vector                     |                      |                                                        |
|                                   | Reserved                                   |                      |                                                        |
|                                   | Reserved                                   |                      |                                                        |
|                                   | Reserved                                   |                      |                                                        |
|                                   | Interrupt Vector 0                         | 0x000114             |                                                        |
|                                   | Interrupt Vector 1                         | _                    |                                                        |
|                                   | ~                                          | 4                    |                                                        |
|                                   | ~                                          | 4                    |                                                        |
|                                   | ~<br>Interrupt Vector 52                   | 0x000470             | Alternate Interrupt Vector Table (AIVT) <sup>(1)</sup> |
|                                   |                                            | 0x00017C             |                                                        |
|                                   | Interrupt Vector 53<br>Interrupt Vector 54 | 0x00017E<br>0x000180 |                                                        |
|                                   | ~                                          | 0000180              |                                                        |
|                                   | ~                                          | -                    |                                                        |
|                                   | ~ ~                                        | _                    |                                                        |
|                                   | -<br>Interrupt Vector 116                  | -                    |                                                        |
|                                   | Interrupt Vector 117                       | 0x0001FE             |                                                        |
| *                                 | Start of Code                              | 0x000200             | L                                                      |
|                                   |                                            |                      |                                                        |
| Note 1: See                       | e Table 7-1 for the list of impleme        | ented interrupt v    | ectors.                                                |

## dsPIC33FJ16(GP/MC)101/102 AND dsPIC33FJ32(GP/MC)101/102/104

| U-0               | U-0                                                                                 | R/W-0                                                | U-0                                                                | U-0                                      | U-0 | U-0   | U-0                    |  |  |  |
|-------------------|-------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------------|------------------------------------------|-----|-------|------------------------|--|--|--|
| —                 | —                                                                                   | CTMUIF                                               | —                                                                  | —                                        | —   | —     | -                      |  |  |  |
| bit 15            |                                                                                     |                                                      |                                                                    |                                          |     |       | bit 8                  |  |  |  |
|                   |                                                                                     |                                                      |                                                                    |                                          |     |       |                        |  |  |  |
| U-0               | U-0                                                                                 | U-0                                                  | U-0                                                                | U-0                                      | U-0 | R/W-0 | R/W-0                  |  |  |  |
|                   | —                                                                                   | —                                                    | —                                                                  |                                          |     | U1EIF | FLTB1IF <sup>(1)</sup> |  |  |  |
| bit 7             |                                                                                     |                                                      |                                                                    |                                          |     |       | bit 0                  |  |  |  |
| [                 |                                                                                     |                                                      |                                                                    |                                          |     |       |                        |  |  |  |
| Legend:           |                                                                                     |                                                      |                                                                    |                                          |     |       |                        |  |  |  |
| R = Readab        | le bit                                                                              | W = Writable                                         | bit                                                                | U = Unimplemented bit, read as '0'       |     |       |                        |  |  |  |
| -n = Value a      | t POR                                                                               | '1' = Bit is set                                     |                                                                    | 0' = Bit is cleared $x = Bit is unknown$ |     |       |                        |  |  |  |
|                   |                                                                                     |                                                      |                                                                    |                                          |     |       |                        |  |  |  |
| bit 15-14         | Unimplemen                                                                          | ted: Read as '                                       | o'                                                                 |                                          |     |       |                        |  |  |  |
| bit 13            | CTMUIF: CTM                                                                         | MU Interrupt Fla                                     | ag Status bit                                                      |                                          |     |       |                        |  |  |  |
|                   |                                                                                     | equest has occ                                       |                                                                    |                                          |     |       |                        |  |  |  |
|                   | 0 = Interrupt r                                                                     | equest has not                                       | occurred                                                           |                                          |     |       |                        |  |  |  |
|                   |                                                                                     |                                                      |                                                                    |                                          |     |       |                        |  |  |  |
| bit 12-2          | Unimplemen                                                                          | ted: Read as '                                       | כי                                                                 |                                          |     |       |                        |  |  |  |
| bit 12-2<br>bit 1 | -                                                                                   | t <b>ed:</b> Read as '(<br>1 Error Interru           |                                                                    | bit                                      |     |       |                        |  |  |  |
|                   | <b>U1EIF:</b> UART<br>1 = Interrupt r                                               | 1 Error Interrup                                     | ot Flag Status<br>curred                                           | bit                                      |     |       |                        |  |  |  |
|                   | <b>U1EIF:</b> UART<br>1 = Interrupt r<br>0 = Interrupt r                            | 1 Error Interrup<br>equest has occ<br>equest has not | ot Flag Status<br>curred<br>coccurred                              |                                          |     |       |                        |  |  |  |
|                   | <b>U1EIF:</b> UART<br>1 = Interrupt r<br>0 = Interrupt r                            | 1 Error Interrup                                     | ot Flag Status<br>curred<br>coccurred                              |                                          |     |       |                        |  |  |  |
| bit 1             | U1EIF: UART<br>1 = Interrupt r<br>0 = Interrupt r<br>FLTB1IF: PW<br>1 = Interrupt r | 1 Error Interrup<br>equest has occ<br>equest has not | ot Flag Status<br>curred<br>coccurred<br>errupt Flag Sta<br>curred |                                          |     |       |                        |  |  |  |

#### REGISTER 7-9: IFS4: INTERRUPT FLAG STATUS REGISTER 4

Note 1: This bit is available in dsPIC(16/32)MC102/104 devices only.

#### **PMD Control Registers** 9.5

| R/W-0       U-0       R/W-0       U-0       R/W-0       U-0       R/W-0         I2C1MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W-0               | R/W-0               | R/W-0            | R/W-0                  | R/W-0          | U-0            | R/W-0     | U-0                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------------|------------------|------------------------|----------------|----------------|-----------|----------------------|
| R/W-0       U-0       R/W-0       U-0       R/W-0       U-0       R/W-0         I2C1MD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | T5MD <sup>(1)</sup> | T4MD <sup>(1)</sup> | T3MD             | T2MD                   | T1MD           | _              | PWM1MD    | _                    |
| I2C1MD       -       U1MD       -       SPI1MD       -       AD1MDf2         bit 7       bit       -       bit       bit       bit         Legend:       R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'       nn = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       TSMD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled       0 = Timer6 module is disabled       0 = Timer7 module is disabled         bit 14       T4MD: Timer4 Module Disable bit <sup>(1)</sup> 1 = Timer6 module is enabled       0 = Timer7 module is disabled       0 = Timer7 module is disabled         bit 13       T3MD: Timer3 Module Disable bit       1 = Timer7 module is disabled       0 = Timer7 module is enabled         bit 14       T4MD: Timer2 Module Disable bit       1 = Timer2 module is enabled       0 = Timer7 module is disabled         bit 11       Timer2 module is disabled       0 = Timer4 module is disabled       0 = Timer1 module is disabled       0 = Timer1 module is disabled         bit 11       Timer2 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled         bit 11       Timer1 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | bit 15              | •                   |                  | 1                      |                |                |           | bit                  |
| I2C1MD       -       U1MD       -       SPI1MD       -       AD1MDf2         bit 7       bit       -       bit       bit       bit         Legend:       R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'       nn = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       TSMD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled       0 = Timer6 module is disabled       0 = Timer7 module is disabled         bit 14       T4MD: Timer4 Module Disable bit <sup>(1)</sup> 1 = Timer6 module is enabled       0 = Timer7 module is disabled       0 = Timer7 module is disabled         bit 13       T3MD: Timer3 Module Disable bit       1 = Timer7 module is disabled       0 = Timer7 module is enabled         bit 14       T4MD: Timer2 Module Disable bit       1 = Timer2 module is enabled       0 = Timer7 module is disabled         bit 11       Timer2 module is disabled       0 = Timer4 module is disabled       0 = Timer1 module is disabled       0 = Timer1 module is disabled         bit 11       Timer2 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled         bit 11       Timer1 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled       0 = Timer4 module is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     |                     |                  |                        |                |                |           |                      |
| Legend:<br>R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'<br>n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown<br>bit 15 T5MD: Timer5 Module Disable bit <sup>(1)</sup><br>1 = Timer5 module is enabled<br>0 = Timer5 module is enabled<br>0 = Timer4 module is enabled<br>0 = Timer4 module is disabled<br>0 = Timer3 module is enabled<br>0 = Timer3 module is enabled<br>0 = Timer4 module Disable bit<br>1 = Timer2 Module Disable bit<br>1 = Timer2 Module Disable bit<br>1 = Timer2 module is disabled<br>0 = Timer4 module is enabled<br>0 = Timer7 module is enabled<br>0 = Timer7 module is disabled<br>0 = Timer2 module is disabled<br>0 = Timer2 module is disabled<br>0 = Timer1 module is disabled<br>0 = UART1 modul | R/W-0               | U-0                 | R/W-0            | U-0                    | R/W-0          | U-0            | U-0       | R/W-0                |
| Legend:<br>R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'<br>in = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is unknown<br>bit 15 T5MD: Timer5 Module Disable bit <sup>(1)</sup><br>1 = Timer5 module is disabled<br>0 = Timer5 module is disabled<br>0 = Timer4 module is disabled<br>0 = Timer4 module is disabled<br>0 = Timer3 module is disabled<br>0 = Timer3 module is disabled<br>0 = Timer3 module is enabled<br>0 = Timer3 module is disabled<br>0 = Timer3 module is disabled<br>0 = Timer3 module is disabled<br>0 = Timer2 module is disabled<br>0 = Timer2 module is disabled<br>0 = Timer2 module is enabled<br>0 = Timer2 module is enabled<br>0 = Timer1 module is disabled<br>0 = Timer1 module is disabled<br>0 = Timer2 module is disabled<br>0 = Timer2 module is enabled<br>0 = Timer4 module is disabled<br>0 = UXM11 module is disabled<br>0 = UXM11 module is disabled<br>0 = UART1 module is disabled<br>0 = UART4 module i | I2C1MD              |                     | U1MD             |                        | SPI1MD         | _              | —         | AD1MD <sup>(2)</sup> |
| R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         in = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         Dit 15       TSMD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled       0 = Timer6 module is enabled         0 = Timer6 module is enabled       0 = Timer6 module is enabled       0 = Timer6 module is enabled       0 = Timer6 module is enabled         Dit 14       T4MD: Timer6 Module Disable bit <sup>(1)</sup> 1 = Timer6 module is enabled       0 = Timer6 module is enabled         Dit 13       T3MD: Timer3 Module Disable bit       1 = Timer7 module is disabled       0 = Timer7 module is disabled         Dit 12       T2MD: Timer1 Module Disable bit       1 = Timer2 module is disabled       0 = Timer2 module is disabled         Dit 11       T1MD: Timer1 Module Disable bit       1 = Timer1 module is disabled       0 = Timer4 module is disabled         Dit 10       Unimplemented: Read as '0'       0       0       0         Dit 10       Unimplemented: Read as '0'       0       0         Dit 7       I2C1MD: I2C1 Module Disable bit       1 = I2C1 module is disabled       0 = I2C1 module is disabled         Dit 7       I2C1MD: I2C1 Module Disable bit       1 = I2C1 module is disabled       0 = UART1 module Disable bit         Dit 6       Unimplemented: Re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | bit 7               |                     |                  |                        |                |                |           | bit                  |
| R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         in = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         Dit 15       TSMD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled       0 = Timer6 module is enabled         0 = Timer6 module is enabled       0 = Timer6 module is enabled       0 = Timer6 module is enabled       0 = Timer6 module is enabled         Dit 14       T4MD: Timer6 Module Disable bit <sup>(1)</sup> 1 = Timer6 module is enabled       0 = Timer6 module is enabled         Dit 13       T3MD: Timer3 Module Disable bit       1 = Timer7 module is disabled       0 = Timer7 module is disabled         Dit 12       T2MD: Timer1 Module Disable bit       1 = Timer2 module is disabled       0 = Timer2 module is disabled         Dit 11       T1MD: Timer1 Module Disable bit       1 = Timer1 module is disabled       0 = Timer4 module is disabled         Dit 10       Unimplemented: Read as '0'       0       0       0         Dit 10       Unimplemented: Read as '0'       0       0         Dit 7       I2C1MD: I2C1 Module Disable bit       1 = I2C1 module is disabled       0 = I2C1 module is disabled         Dit 7       I2C1MD: I2C1 Module Disable bit       1 = I2C1 module is disabled       0 = UART1 module Disable bit         Dit 6       Unimplemented: Re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Legend:             |                     |                  |                        |                |                |           |                      |
| m = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       TSMD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled       0 = Timer5 module is disabled         bit 14       TAMD: Timer4 Module Disable bit <sup>(1)</sup> 1 = Timer4 module is disabled       0 = Timer4 module is disabled         bit 13       T3MD: Timer3 Module Disable bit       1 = Timer3 module is disabled       0 = Timer3 module is disabled         bit 13       T3MD: Timer3 Module Disable bit       1 = Timer3 module is disabled       0 = Timer3 module is disabled         bit 12       T2MD: Timer2 Module Disable bit       1 = Timer3 module is disabled       0 = Timer3 module is disabled         bit 12       T2MD: Timer1 Module Disable bit       1 = Timer1 module is disabled       0 = Timer1 module is disabled         bit 11       T1MD: Timer1 Module Disable bit       1 = Timer1 module is disabled       0 = Timer1 module is disabled         bit 10       Unimplemented: Read as '0'       0       0       0         bit 8       Unimplemented: Read as '0'       0       1 = I2C1 module is disabled       0 = I2C1 module is disabled         bit 7       I2C1MD: I2C1 Module Disable bit       1 = I2C1 module is disabled       0 = I2C1 module is disabled       0 = I2C1 module is disabled         bit 6       Unimplemented: Read as '0'       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | •                   | le bit              | W = Writable     | bit                    | U = Unimplem   | ented bit, rea | ad as '0' |                      |
| bit 15       T5MD: Timer5 Module Disable bit <sup>(1)</sup> 1 = Timer5 module is disabled         0 = Timer5 module is disabled         1 = Timer4 Module Disable bit <sup>(1)</sup> 1 = Timer4 module is disabled         0 = Timer4 module is disabled         0 = Timer4 module is disabled         0 = Timer3 module is disabled         0 = Timer3 module is disabled         0 = Timer3 module is enabled         0 = Timer3 module is disabled         0 = Timer1 module Disable bit         1 = Timer1 module is disabled         0 = WM1MD: PVM1 Module Disable bit         1 = PWM1 module is disabled         0 = PVWM1 module is disabled         0 = PVW1 module is disabled         0 = VIM1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | -n = Value a        | t POR               | '1' = Bit is set | t                      | •              |                |           | nown                 |
| 1 = Timer5 module is disabled         0 = Timer5 module is enabled         0 = Timer4 Module Disable bit         1 = Timer4 module is enabled         0 = Timer4 module is enabled         0 = Timer3 module is enabled         0 = Timer3 module is disable bit         1 = Timer3 module is disabled         0 = Timer2 module is enabled         0 = Timer2 module is disabled         0 = Timer2 module is disabled         0 = Timer1 module is disabled         0 = PWM1 MD: PWM1 Module Disable bit         1 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PWM1 module is enabled         0 = I2C1 Module Disable bit         1 = I2C1 module is disabled         0 = I2C1 module is enabled         0 = I2C1 module is enabled         0 = I2C1 module Disable bit         1 = UART1 module is disabled         0 = UART1 module is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     |                     |                  |                        |                |                |           |                      |
| 0 = Timer5 module is enabled         bit 14       T4MD: Timer4 Module Disable bit         1 = Timer4 module is disabled         0 = Timer3 Module Disable bit         1 = Timer3 module is enabled         0 = Timer4 module is disabled         0 = Timer3 Module Disable bit         1 = Timer3 module is disabled         0 = Timer2 module is enabled         0 = Timer2 module is disabled         0 = Timer2 module is disabled         0 = Timer2 module is disabled         0 = Timer1 Module Disable bit         1 = Timer1 module is disabled         0 = PWM1 module is disabled         0 = I2C1 Module Disable bit         1 = I2C1 Module Disable bit         1 = I2C1 module is disabled         0 = I2C1 module is disabled         0 = I2C1 module is disabled         0 = I2C1 module is disabled<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | bit 15              | T5MD: Time          | r5 Module Disa   | ble bit <sup>(1)</sup> |                |                |           |                      |
| bit 14       T4MD: Timer4 Module Disable bit <sup>(1)</sup> 1 = Timer4 module is disabled         0 = Timer4 module is disabled         0 = Timer3 module is enabled         bit 12       T2MD: Timer2 Module Disable bit         1 = Timer2 module is disabled         0 = Timer2 module is disabled         0 = Timer1 module is disabled         0 = PWM1 module is disabled         0 = I2C1 module is disabled         0 = UART1 module is disabled         0 = UART1 module is enabled <t< td=""><td></td><td>1 = Timer5 n</td><td>nodule is disabl</td><td>ed</td><td></td><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                     | 1 = Timer5 n        | nodule is disabl | ed                     |                |                |           |                      |
| 1 = Timer4 module is disabled         0 = Timer4 module is enabled         0 = Timer3 Module Disable bit         1 = Timer3 module is disabled         0 = Timer3 module is enabled         0 = Timer3 module is enabled         0 = Timer2 Module Disable bit         1 = Timer2 module is disabled         0 = Timer2 module is disabled         0 = Timer2 module is enabled         0 = Timer1 Module Disable bit         1 = Timer1 module is disabled         0 = PWM1 module Disable bit         1 = PWM1 module is disabled         0 = PWM1 module Disable bit         1 = I2C1 Module Disable bit         1 = I2C1 module is disabled         0 = UART1 module is disabled         0 = UART1 module is enabled         0 = UART1 module is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     | 0 <b>= Timer5 n</b> | nodule is enable | ed                     |                |                |           |                      |
| 0 = Timer4 module is enabled         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 enabled         0 = Timer3 module is enabled         0 = Timer2 module is enabled         0 = Timer2 module is enabled         0 = Timer1 module is disabled         0 = PWM1MD: PVW1 Module Disable bit         1 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PUM1 module is disabled         0 = 12C1 module is disabled         0 = 12C1 module is disabled         0 = 12C1 module is disabled         0 = UART1 module is disabled         0 = UART1 module is disabled         0 = UART1 module is enabled         0 = UART1 module is enabled         0 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | bit 14              |                     |                  |                        |                |                |           |                      |
| bit 13       T3MD: Timer3 Module Disable bit         1 = Timer3 module is disabled       0 = Timer3 module is enabled         0 = Timer3 module is enabled       0 = Timer2 Module Disable bit         1 = Timer2 module is disabled       0 = Timer2 module is enabled         0 = Timer2 module is disabled       0 = Timer2 module is disabled         0 = Timer1 module is disabled       0 = Timer1 module is disabled         0 = Timer1 module is disabled       0 = Timer1 module is disabled         0 = Timer1 module is disabled       0 = Timer1 module is disabled         0 = Timer1 module is disabled       0 = Timer1 module is disabled         0 = Timer1 module is disabled       0 = PWM1 MD: PWM1 Module Disable bit         1 = PWM1 module is disabled       0 = PWM1 module is disabled         0 = PWM1 module is disabled       0 = PWM1 module is enabled         0 = PWM1 module is disabled       0 = PUM1 module is disabled         0 = PWM1 module is disabled       0 = I2C1 module is disabled         0 = I2C1 module is disabled       0 = I2C1 module is enabled         0 = I2C1 module is disabled       0 = I2C1 module is disabled         0 = UART1 module is disabled       0 = UART1 module is disabled         0 = UART1 module is disabled       0 = UART1 module is disabled         0 = UART1 module is disabled       0 = UART1 module is disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                     |                     |                  |                        |                |                |           |                      |
| 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         1 = Timer1 module is disabled         0 = Timer1 module is disabled         0 = Timer1 module is enabled         0 = Timer1 module is disabled         0 = Timer1 module is enabled         0 = Timer1 module is enabled         0 = Timer1 module is disabled         0 = Timer1 module is enabled         0 = Timer1 module is disabled         0 = PWM1MD: PWM1 Module Disable bit         1 = PVWM1 module is enabled         0 = PWM1 module is enabled         0 = PWM1 module is enabled         0 = VATI module is disabled         0 = I2C1 module is enabled         0 = I2C1 module is enabled         0 = I2C1 module is enabled         0 = I2C1 module is disabled         0 = I2C1 module is disabled         0 = UART1 module is disabled         0 = UART1 module is enabled         0 = UART1 module is enabled         0 = UART1 modu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | h:: 40              |                     |                  |                        |                |                |           |                      |
| 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         1 = Timer1 module is disabled         0 = PWM1 MD: PWM1 Module Disable bit         1 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PWM1 module is disabled         0 = PWM1 module Disable bit         1 = I2C1 module is disabled         0 = I2C1 module is enabled         0 = I2C1 module is enabled         0 = I2C1 module is disabled         0 = I2C1 module Disable bit         1 = UART1 Module Disable bit         1 = UART1 module is disabled         0 = UART1 module is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DIT 13              |                     |                  |                        |                |                |           |                      |
| bit 12 <b>T2MD</b> : Timer2 Module Disable bit         1 = Timer2 module is disabled       0 = Timer2 module is enabled         bit 11 <b>T1MD</b> : Timer1 Module Disable bit         1 = Timer1 module is disabled       0 = Timer1 module is disabled         0 = Timer1 module is enabled       0 = Timer1 module is disabled         0 = Timer1 module is enabled       0 = Timer1 module is enabled         bit 10 <b>Unimplemented:</b> Read as '0'         bit 3 <b>PWM1MD</b> : PWM1 Module Disable bit         1 = PWM1 module is enabled       0 = PWM1 module is enabled         bit 4 <b>Unimplemented:</b> Read as '0'         bit 5 <b>Unimplemented:</b> Read as '0'         bit 6 <b>Unimplemented:</b> Read as '0'         bit 7 <b>I2C1MD</b> : I2C1 Module Disable bit         1 = I2C1 module is disabled       0 = I2C1 module is disabled         bit 6 <b>Unimplemented:</b> Read as '0'         bit 5 <b>U1MD</b> : UART1 Module Disable bit         1 = UART1 module is disabled       0 = UART1 module is enabled         bit 4 <b>Unimplemented:</b> Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                     |                     |                  |                        |                |                |           |                      |
| 1 = Timer2 module is disabled         0 = Timer2 module is enabled         bit 11       T1MD: Timer1 Module Disable bit         1 = Timer1 module is disabled         0 = Timer1 module is enabled         bit 10       Unimplemented: Read as '0'         bit 9       PWM1MD: PWM1 Module Disable bit         1 = PWM1 module is disabled       0 = PWM1 module is disabled         0 = PWM1 module is disabled       0 = PWM1 module is enabled         bit 8       Unimplemented: Read as '0'         bit 7       I2C1 Module Disable bit         1 = I2C1 module is disabled       0 = I2C1 module is disabled         0 = I2C1 module is disabled       0 = I2C1 module is disabled         bit 6       Unimplemented: Read as '0'         bit 5       U1MD: UART1 Module Disable bit         1 = UART1 module is disabled       0 = UART1 module is enabled         0 = UART1 module is enabled       0 = UART1 module is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | bit 12              | T2MD: Time          | r2 Module Disa   | ble bit                |                |                |           |                      |
| bit 11 <b>T1MD:</b> Timer1 Module Disable bit<br>$1 = Timer1$ module is disabled<br>$0 = Timer1$ module is enabledbit 10 <b>Unimplemented:</b> Read as '0'bit 9 <b>PWM1MD:</b> PWM1 Module Disable bit<br>$1 = PWM1$ module is disabled<br>$0 = PWM1$ module is enabledbit 8 <b>Unimplemented:</b> Read as '0'bit 7 <b>I2C1MD:</b> I2C1 Module Disable bit<br>$1 = I2C1$ module is disabled<br>$0 = I2C1$ module is enabledbit 6 <b>Unimplemented:</b> Read as '0'bit 5 <b>U1MD:</b> UART1 Module Disable bit<br>$1 = UART1$ module is disabled<br>$0 = UART1$ module is disabled<br>bit 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                     | 1 = Timer2 n        | nodule is disabl | ed                     |                |                |           |                      |
| 1 = Timer1 module is disabled         0 = Timer1 module is enabled         0 = Timer1 module is enabled         0 = Timer1 module is enabled         0 = PWM1MD: PWM1 Module Disable bit         1 = PWM1 module is disabled         0 = PWM1 module is enabled         0 = I2C1 Module Disable bit         1 = I2C1 module is disabled         0 = I2C1 module is enabled         0 = I2C1 module is disabled         0 = I2C1 module is enabled         0 = UART1 Module Disable bit         1 = UART1 module is disabled         0 = UART1 module is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     | 0 = Timer2 n        | nodule is enable | ed                     |                |                |           |                      |
| 0 = Timer1 module is enabled         bit 10       Unimplemented: Read as '0'         bit 9       PWM1MD: PWM1 Module Disable bit         1 = PWM1 module is disabled       0 = PWM1 module is disabled         0 = PWM1 module is enabled       0 = PWM1 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         0 = I2C1 module is enabled       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 11              | T1MD: Time          | r1 Module Disa   | ble bit                |                |                |           |                      |
| bit 10       Unimplemented: Read as '0'         bit 9       PWM1MD: PWM1 Module Disable bit         1 = PWM1 module is disabled       0 = PWM1 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 disabled         0 = I2C1 module is enabled       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 9PWM1MD: PWM1 Module Disable bit1 = PWM1 module is disabled<br>0 = PWM1 module is enabledbit 8Unimplemented: Read as '0'bit 7I2C1MD: I2C1 Module Disable bit<br>1 = I2C1 module is disabled<br>0 = I2C1 module is enabledbit 6Unimplemented: Read as '0'bit 5U1MD: UART1 Module Disable bit<br>1 = UART1 module is disabled<br>0 = UART1 module is enabledbit 4Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                     |                     |                  |                        |                |                |           |                      |
| 1 = PWM1 module is disabled<br>$0 = PWM1$ module is enabledbit 8Unimplemented: Read as '0'bit 7I2C1MD: I2C1 Module Disable bit<br>$1 = I2C1$ module is disabled<br>$0 = I2C1$ module is enabledbit 6Unimplemented: Read as '0'bit 5U1MD: UART1 Module Disable bit<br>$1 = UART1$ module is disabled<br>$0 = UART1$ module is enabledbit 4Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                     | -                   |                  |                        |                |                |           |                      |
| 0 = PWM1  module is enabled bit 8 Unimplemented: Read as '0'<br>bit 7 I2C1MD: I2C1 Module Disable bit<br>1 = I2C1 module is disabled<br>0 = I2C1 module is enabled<br>bit 6 Unimplemented: Read as '0'<br>bit 5 U1MD: UART1 Module Disable bit<br>1 = UART1 module is disabled<br>0 = UART1 module is enabled<br>bit 4 Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit 9               |                     |                  |                        |                |                |           |                      |
| 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         0 = UART1 module is enabled       0         bit 4       Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                     |                     |                  |                        |                |                |           |                      |
| bit 7       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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | hit 8               |                     |                  |                        |                |                |           |                      |
| 1 = 12C1 module is disabled<br>$0 = 12C1$ module is enabled $0 = 12C1$ module is enabled $0 = 12C1$ module is enabled $0 = 12C1$ module is enabled<br>$1 = UART1$ module Disable bit<br>$1 = UART1$ module is enabled<br>$0 = UART1$ module is enabled $0 = UART1$ module is enabled<br>$0 = UART1$ module is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                     | -                   |                  |                        |                |                |           |                      |
| 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                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                     |                     |                  |                        |                |                |           |                      |
| bit 5       U1MD: UART1 Module Disable bit         1 = UART1 module is disabled         0 = UART1 module is enabled         bit 4         Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                     |                     |                  |                        |                |                |           |                      |
| 1 = UART1 module is disabled         0 = UART1 module is enabled         bit 4         Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | bit 6               | Unimpleme           | nted: Read as '  | 0'                     |                |                |           |                      |
| 0 = UART1 module is enabledDit 4Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | bit 5               | U1MD: UAR           | T1 Module Disa   | able bit               |                |                |           |                      |
| bit 4 Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                     | 1 = UART1 r         | module is disabl | led                    |                |                |           |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                     | 0 = UART1 r         | nodule is enabl  | ed                     |                |                |           |                      |
| Note 1: These bits are available in dsPIC33FJ32(GP/MC)10X devices only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | bit 4               | Unimpleme           | nted: Read as '  | 0'                     |                |                |           |                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Note 1: ⊤           | hese bits are av    | vailable in dsPl | C33FJ32(GP/            | MC)10X devices | only.          |           |                      |

#### **REGISTER 9-1:** PMD1: PERIPHERAL MODULE DISABLE CONTROL REGISTER 1

2: 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.



### FIGURE 12-1: TIMER2/3 AND TIMER4/5 (32-BIT) BLOCK DIAGRAM<sup>(1,3,4)</sup>

**4:** Where 'x' or 'y' is present, x = 2 or 4; y = 3 or 5.

#### 13.1 Input Capture Control Register

#### **REGISTER 13-1: ICXCON: INPUT CAPTURE X CONTROL REGISTER**

| U-0            | U-0                                                                                   | R/W-0                                                                                                         | U-0                                                                                           | U-0                           | U-0              | U-0                | U-0   |
|----------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------|------------------|--------------------|-------|
| —              |                                                                                       | ICSIDL                                                                                                        | —                                                                                             |                               |                  |                    | —     |
| it 15          |                                                                                       |                                                                                                               |                                                                                               |                               |                  |                    | bit 8 |
|                |                                                                                       |                                                                                                               |                                                                                               |                               |                  |                    |       |
| R/W-0          | R/W-0                                                                                 | R/W-0                                                                                                         | R-0, HC                                                                                       | R-0, HC                       | R/W-0            | R/W-0              | R/W-0 |
| ICTMR          | ICI1                                                                                  | ICI0                                                                                                          | ICOV                                                                                          | ICBNE                         | ICM2             | ICM1               | ICM0  |
| it 7           |                                                                                       |                                                                                                               |                                                                                               |                               |                  |                    | bit ( |
| egend:         |                                                                                       | HC = Hardwa                                                                                                   | re Clearable I                                                                                | oit                           |                  |                    |       |
| R = Readable   | bit                                                                                   | W = Writable                                                                                                  | bit                                                                                           | U = Unimpler                  | nented bit, read | d as '0'           |       |
| n = Value at I | POR                                                                                   | '1' = Bit is set                                                                                              |                                                                                               | '0' = Bit is cle              | ared             | x = Bit is unkr    | nown  |
|                |                                                                                       |                                                                                                               |                                                                                               |                               |                  |                    |       |
| it 15-14       | Unimplemen                                                                            | ted: Read as '                                                                                                | )'                                                                                            |                               |                  |                    |       |
| it 13          | ICSIDL: Input                                                                         | t Capture x Sto                                                                                               | o in Idle Cont                                                                                | rol bit                       |                  |                    |       |
|                |                                                                                       | ture x module                                                                                                 |                                                                                               |                               |                  |                    |       |
|                |                                                                                       | ture x module                                                                                                 |                                                                                               | o operate in Cl               | PU Idle mode     |                    |       |
| it 12-8        | =                                                                                     | ted: Read as '                                                                                                |                                                                                               |                               |                  |                    |       |
| it 7           | •                                                                                     | Capture x Tim                                                                                                 |                                                                                               |                               |                  |                    |       |
|                |                                                                                       | ntents are capt<br>ntents are capt                                                                            |                                                                                               |                               |                  |                    |       |
| it 6-5         | ICI<1:0>: Sel                                                                         | ect Number of                                                                                                 | Captures per                                                                                  | Interrupt bits                |                  |                    |       |
|                | 10 = Interrupt                                                                        | t on every fourt<br>t on every third                                                                          | capture even                                                                                  | t                             |                  |                    |       |
|                |                                                                                       | t on every seco<br>t on every captu                                                                           |                                                                                               | vent                          |                  |                    |       |
| it 4           | ICOV: Input C                                                                         | Capture x Overf                                                                                               | low Status Fla                                                                                | ag bit (read-onl              | y)               |                    |       |
|                |                                                                                       | ture x overflow<br>Capture x overf                                                                            |                                                                                               |                               |                  |                    |       |
| it 3           | ICBNE: Input                                                                          | Capture x Buff                                                                                                | er Empty Sta                                                                                  | tus bit (read-on              | ly)              |                    |       |
|                |                                                                                       | oture x buffer is<br>oture x buffer is                                                                        |                                                                                               | least one more                | e capture value  | can be read        |       |
| it 2-0         | ICM<2:0>: Inj                                                                         | put Capture x N                                                                                               | Node Select b                                                                                 | oits                          |                  |                    |       |
|                | edge c<br>110 = Unuse<br>101 = Captur<br>100 = Captur<br>011 = Captur<br>010 = Captur | detect only, all d<br>d (module is di<br>re mode, every<br>re mode, every<br>re mode, every<br>re mode, every | other control b<br>sabled)<br>16th rising e<br>4th rising edge<br>rising edge<br>falling edge | bits are not app<br>dge<br>ge | licable)         | s in Sleep or Idle |       |
|                |                                                                                       | s mode)<br>Capture x modu                                                                                     | ile is turned c                                                                               | off                           |                  |                    |       |

# EXAMPLE 15-1: ASSEMBLY CODE FOR WRITE-PROTECTED REGISTER UNLOCK AND FAULT CLEARING SEQUENCE

| ; FLTA1 pin must be pulled high externally in order to clear and disable the Fault<br>; Writing to P1FLTBCON register requires unlock sequence                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>mov #0xabcd,w10 ; Load first unlock key to w10 register<br/>mov #0x4321,w11 ; Load second unlock key to w11 register<br/>mov #0x0000,w0 ; Load desired value of P1FLTACON register in w0<br/>mov w10, PWM1KEY ; Write first unlock key to PWM1KEY register<br/>mov w11, PWM1KEY ; Write second unlock key to PWM1KEY register<br/>mov w0,P1FLTACON ; Write desired value to P1FLTACON register</pre> |
| ; FLTB1 pin must be pulled high externally in order to clear and disable the Fault ; Writing to P1FLTBCON register requires unlock sequence                                                                                                                                                                                                                                                               |
| <pre>mov #0xabcd,w10 ; Load first unlock key to w10 register<br/>mov #0x4321,w11 ; Load second unlock key to w11 register<br/>mov #0x0000,w0 ; Load desired value of P1FLTBCON register in w0<br/>mov w10, PWM1KEY ; Write first unlock key to PWM1KEY register<br/>mov w11, PWM1KEY ; Write second unlock key to PWM1KEY register<br/>mov w0,P1FLTBCON ; Write desired value to P1FLTBCON register</pre> |
| ; Enable all PWMs using PWM1CON1 register<br>; Writing to PWM1CON1 register requires unlock sequence                                                                                                                                                                                                                                                                                                      |
| <pre>mov #0xabcd,w10 ; Load first unlock key to w10 register<br/>mov #0x4321,w11 ; Load second unlock key to w11 register<br/>mov #0x0077,w0 ; Load desired value of PWM1CON1 register in w0<br/>mov w10, PWM1KEY ; Write first unlock key to PWM1KEY register<br/>mov w11, PWM1KEY ; Write second unlock key to PWM1KEY register<br/>mov w0,PWM1CON1 ; Write desired value to PWM1CON1 register</pre>    |

# EXAMPLE 15-2: C CODE FOR WRITE-PROTECTED REGISTER UNLOCK AND FAULT CLEARING SEQUENCE

// FLTAl pin must be pulled high externally in order to clear and disable the Fault // Writing to PIFLTACON register requires unlock sequence // Use builtin function to write 0x0000 to PIFLTACON register \_\_builtin\_write\_PWMSFR(&PIFLTACON, 0x0000, &PWM1KEY); // FLTBl pin must be pulled high externally in order to clear and disable the Fault // Writing to PIFLTBCON register requires unlock sequence // Use builtin function to write 0x0000 to PIFLTBCON register \_\_builtin\_write\_PWMSFR(&PIFLTBCON, 0x0000, &PWM1KEY); // Enable all PWMs using PWM1CON1 register // Writing to PWM1CON1 register requires unlock sequence // Use builtin function to write 0x0077 to PWM1CON1 register \_\_builtin\_write\_PWMSFR(&PWM1CON1, 0x0077, &PWM1KEY);

| REGISTER 2    | 22-2: CTMU                   | JCON2: CTM                     | U CONTROL        | REGISTER                          | 2                |                 |          |
|---------------|------------------------------|--------------------------------|------------------|-----------------------------------|------------------|-----------------|----------|
| R/W-0         | R/W-0                        | R/W-0                          | R/W-0            | R/W-0                             | R/W-0            | R/W-0           | R/W-0    |
| EDG1MOD       | EDG1POL                      | EDG1SEL3                       | EDG1SEL2         | EDG1SEL1                          | EDG1SEL0         | EDG2STAT        | EDG1STAT |
| bit 15        |                              |                                |                  |                                   |                  |                 | bit 8    |
|               |                              |                                |                  |                                   |                  |                 |          |
| R/W-0         | R/W-0                        | R/W-0                          | R/W-0            | R/W-0                             | R/W-0            | U-0             | U-0      |
| EDG2MOD       | EDG2POL                      | EDG2SEL3                       | EDG2SEL2         | EDG2SEL1                          | EDG2SEL0         |                 | —        |
| bit 7         |                              |                                |                  |                                   |                  |                 | bit 0    |
| Legend:       |                              |                                |                  |                                   |                  |                 |          |
| R = Readable  | hit                          | W = Writable                   | hit              | II – Unimplem                     | nented bit, read | las 'N'         |          |
| -n = Value at |                              | 1' = Bit is set                | on               | $0^{\circ} = \text{Bit is clear}$ |                  | x = Bit is unkr |          |
|               |                              | 1 – Dit 13 3et                 |                  |                                   |                  |                 | IOWIT    |
| bit 15        | EDG1MOD: E                   | Edge 1 Edge Sa                 | ampling Selecti  | ion bit                           |                  |                 |          |
|               |                              | edge-sensitive                 |                  |                                   |                  |                 |          |
|               | 0 = Edge 1 is                | level-sensitive                |                  |                                   |                  |                 |          |
| bit 14        |                              | dge 1 Polarity                 |                  |                                   |                  |                 |          |
|               |                              | programmed f                   |                  |                                   |                  |                 |          |
| bit 13-10     | •                            | programmed f                   | •                | •                                 |                  |                 |          |
| DIL 13-10     | 1xxx = Reser                 | :0>: Edge 1 So                 |                  | 5                                 |                  |                 |          |
|               | 01xx = Reser                 |                                |                  |                                   |                  |                 |          |
|               | 0011 = CTED                  |                                |                  |                                   |                  |                 |          |
|               | 0010 = CTED                  | •                              |                  |                                   |                  |                 |          |
|               | 0001 = OC1 r<br>0000 = Timer |                                |                  |                                   |                  |                 |          |
| bit 9         |                              | Edge 2 Status b                | .i+              |                                   |                  |                 |          |
| DIL 9         |                              | -                              |                  | vritten to contro                 | l the edge sou   | rce             |          |
|               | 1 = Edge 2 ha                |                                |                  |                                   | i the edge sou   | 106.            |          |
|               |                              | as not occurred                | ł                |                                   |                  |                 |          |
| bit 8         | EDG1STAT: E                  | Edge 1 Status b                | it               |                                   |                  |                 |          |
|               |                              | •                              | 1 and can be v   | vritten to contro                 | I the edge sou   | rce.            |          |
|               | 1 = Edge 1 has               | as occurred<br>as not occurred | 4                |                                   |                  |                 |          |
| bit 7         | -                            | Edge 2 Edge Sa                 |                  | ion hit                           |                  |                 |          |
|               |                              | edge-sensitive                 |                  |                                   |                  |                 |          |
|               |                              | level-sensitive                |                  |                                   |                  |                 |          |
| bit 6         | EDG2POL: E                   | dge 2 Polarity                 | Select bit       |                                   |                  |                 |          |
|               |                              | programmed f<br>programmed f   |                  |                                   |                  |                 |          |
| bit 5-2       | EDG2SEL<3:                   | <b>0&gt;:</b> Edge 2 So        | urce Select bits | 6                                 |                  |                 |          |
|               | 1xxx = Reser                 |                                |                  |                                   |                  |                 |          |
|               | 01xx = Reser                 |                                |                  |                                   |                  |                 |          |
|               | 0011 = CTED<br>0010 = CTED   |                                |                  |                                   |                  |                 |          |
|               |                              |                                |                  |                                   |                  |                 |          |
|               |                              | arator 2 modul                 | е                |                                   |                  |                 |          |
|               |                              | arator 2 modul                 | e                |                                   |                  |                 |          |

#### REGISTER 22-2: CTMUCON2: CTMU CONTROL REGISTER 2

#### 25.2 MPLAB XC Compilers

The MPLAB XC Compilers are complete ANSI C compilers for all of Microchip's 8, 16, and 32-bit MCU and DSC devices. These compilers provide powerful integration capabilities, superior code optimization and ease of use. MPLAB XC Compilers run on Windows, Linux or MAC OS X.

For easy source level debugging, the compilers provide debug information that is optimized to the MPLAB X IDE.

The free MPLAB XC Compiler editions support all devices and commands, with no time or memory restrictions, and offer sufficient code optimization for most applications.

MPLAB XC Compilers include an assembler, linker and utilities. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. MPLAB XC Compiler uses the assembler to produce its object file. Notable features of the assembler include:

- · Support for the entire device instruction set
- Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- Flexible macro language
- MPLAB X IDE compatibility

#### 25.3 MPASM Assembler

The MPASM Assembler is a full-featured, universal macro assembler for PIC10/12/16/18 MCUs.

The MPASM Assembler generates relocatable object files for the MPLINK Object Linker, Intel<sup>®</sup> standard HEX files, MAP files to detail memory usage and symbol reference, absolute LST files that contain source lines and generated machine code, and COFF files for debugging.

The MPASM Assembler features include:

- Integration into MPLAB X IDE projects
- User-defined macros to streamline
   assembly code
- Conditional assembly for multipurpose source files
- Directives that allow complete control over the assembly process

#### 25.4 MPLINK Object Linker/ MPLIB Object Librarian

The MPLINK Object Linker combines relocatable objects created by the MPASM Assembler. It can link relocatable objects from precompiled libraries, using directives from a linker script.

The MPLIB Object Librarian manages the creation and modification of library files of precompiled code. When a routine from a library is called from a source file, only the modules that contain that routine will be linked in with the application. This allows large libraries to be used efficiently in many different applications.

The object linker/library features include:

- Efficient linking of single libraries instead of many smaller files
- Enhanced code maintainability by grouping related modules together
- Flexible creation of libraries with easy module listing, replacement, deletion and extraction

#### 25.5 MPLAB Assembler, Linker and Librarian for Various Device Families

MPLAB Assembler produces relocatable machine code from symbolic assembly language for PIC24, PIC32 and dsPIC DSC devices. MPLAB XC Compiler uses the assembler to produce its object file. The assembler generates relocatable object files that can then be archived or linked with other relocatable object files and archives to create an executable file. Notable features of the assembler include:

- · Support for the entire device instruction set
- · Support for fixed-point and floating-point data
- Command-line interface
- · Rich directive set
- Flexible macro language
- MPLAB X IDE compatibility

# TABLE 26-33:SPIX SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 0, SMP = 0) TIMING<br/>REQUIREMENTS FOR dsPIC33FJ16(GP/MC)10X

| AC CH        | ARACTERIS             | Standard Op<br>(unless othe<br>Operating ter                 | erwise st    | t <b>ated)</b><br>e -40° | C ≤ TA ≤ | <b>V to 3.6V</b><br>+85°C for Industrial<br>+125°C for Extended |                                      |
|--------------|-----------------------|--------------------------------------------------------------|--------------|--------------------------|----------|-----------------------------------------------------------------|--------------------------------------|
| Param<br>No. | Symbol                | Characteristic <sup>(1)</sup>                                | Min          | Тур <sup>(2)</sup>       | Max      | Units                                                           | Conditions                           |
| SP70         | TscP                  | Maximum SCKx Input Frequency                                 | _            | —                        | 15       | 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                                         | _            | _                        |          | 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<br>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 | $\overline{SSx} \downarrow$ to SCKx $\uparrow$ or SCKx Input | 120          | —                        | _        | ns                                                              |                                      |
| SP51         | TssH2doZ              | SSx ↑ to SDOx Output<br>High-Impedance                       | 10           | _                        | 50       | ns                                                              | See Note 4                           |
| 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 66.7 ns. Therefore, the SCKx clock generated by the master must not violate this specification.

4: Assumes 50 pF load on all SPIx pins.

#### FIGURE 26-20: SPIX MASTER MODE (HALF-DUPLEX, TRANSMIT ONLY, CKE = 1) TIMING CHARACTERISTICS FOR dsPIC33FJ32(GP/MC)10X



# TABLE 26-38:SPIX MASTER MODE (HALF-DUPLEX, TRANSMIT ONLY) TIMING REQUIREMENTS<br/>FOR dsPIC33FJ32(GP/MC)10X

| AC CH        | ARACTERIS             | TICS                                         | $\begin{array}{l} \mbox{Standard Operating Conditions: 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array}$ |                    |     |       |                                      |  |
|--------------|-----------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-------|--------------------------------------|--|
| Param<br>No. | Symbol                | Characteristic <sup>(1)</sup>                | Min                                                                                                                                                                                                                                                                                     | Тур <sup>(2)</sup> | Max | Units | Conditions                           |  |
| SP10         | TscP                  | Maximum SCKx Frequency                       | —                                                                                                                                                                                                                                                                                       | _                  | 15  | MHz   | See Note 3                           |  |
| SP20         | TscF                  | SCKx Output Fall Time                        | _                                                                                                                                                                                                                                                                                       | —                  | _   | ns    | See Parameter DO32 and <b>Note 4</b> |  |
| SP21         | TscR                  | SCKx Output Rise Time                        | _                                                                                                                                                                                                                                                                                       | —                  |     | 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         | TdiV2scH,<br>TdiV2scL | SDOx Data Output Setup to<br>First SCKx Edge | 30                                                                                                                                                                                                                                                                                      | —                  | _   | 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 66.7 ns. Therefore, the clock generated in Master mode must not violate this specification.

4: Assumes 50 pF load on all SPIx pins.

# TABLE 26-41:SPIX SLAVE MODE (FULL-DUPLEX, CKE = 1, CKP = 0, SMP = 0) TIMING<br/>REQUIREMENTS FOR dsPIC33FJ32(GP/MC)10X

| AC CHARACTERISTICS |                       |                                                              | Standard Op<br>(unless othe<br>Operating ter | erwise st          | t <b>ated)</b><br>e -40° | C ≤ TA ≤ | <b>V to 3.6V</b><br>+85°C for Industrial<br>+125°C for Extended |
|--------------------|-----------------------|--------------------------------------------------------------|----------------------------------------------|--------------------|--------------------------|----------|-----------------------------------------------------------------|
| Param<br>No.       | Symbol                | Characteristic <sup>(1)</sup>                                | Min                                          | Typ <sup>(2)</sup> | Max                      | Units    | Conditions                                                      |
| SP70               | TscP                  | Maximum SCKx Input Frequency                                 | —                                            | -                  | 15                       | 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                                         | —                                            | _                  |                          | 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<br>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 | $\overline{SSx} \downarrow$ to SCKx $\uparrow$ or SCKx Input | 120                                          | —                  | _                        | ns       |                                                                 |
| SP51               | TssH2doZ              | SSx ↑ to SDOx Output<br>High-Impedance                       | 10                                           | —                  | 50                       | ns       | See Note 4                                                      |
| 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 66.7 ns. Therefore, the SCKx clock generated by the Master must not violate this specification.

4: Assumes 50 pF load on all SPIx pins.

28-Lead Plastic Shrink Small Outline (SS) - 5.30 mm Body [SSOP]

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



RECOMMENDED LAND PATTERN

|                          | Units |      | MILLIMETERS |      |  |
|--------------------------|-------|------|-------------|------|--|
| Dimension Limits         |       | MIN  | NOM         | MAX  |  |
| Contact Pitch            | E     |      | 0.65 BSC    |      |  |
| Contact Pad Spacing      | С     |      | 7.20        |      |  |
| Contact Pad Width (X28)  | X1    |      |             | 0.45 |  |
| Contact Pad Length (X28) | Y1    |      |             | 1.75 |  |
| 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-2073A