

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China









# 16-Bit Digital Signal Controllers with Advanced Analog

### **Operating Conditions**

- 3.0V to 3.6V, -40°C to +150°C, DC to 20 MIPS
- 3.0V to 3.6V, -40°C to +125°C, DC to 40 MIPS

#### Core: 16-Bit dsPIC33F CPU

- · Code-efficient (C and Assembly) architecture
- · Two 40-bit wide accumulators
- · Single-cycle (MAC/MPY) with dual data fetch
- Single-cycle, mixed-sign MUL plus hardware divide

### **Clock Management**

- · ±2% internal oscillator
- · Programmable PLLs and oscillator clock sources
- · Fail-Safe Clock Monitor (FSCM)
- · Independent Watchdog Timer (WDT)
- · Fast wake-up and start-up

### **Power Management**

- Low-power management modes (Sleep, Idle, Doze)
- · Integrated Power-on Reset and Brown-out Reset
- 1.35 mA/MHz dynamic current (typical)
- 55 µA IPD current (typical)

### **Advanced Analog Features**

- · ADC module:
  - Configurable as 10-bit, 1.1 Msps with four S/H (Sample-and-Hold) or 12-bit, 500 ksps with one S/H
  - Ten analog inputs on 28-pin devices and up to 13 analog inputs on 44-pin devices
- · Flexible and independent ADC trigger sources

### Timers/Output Compare/Input Capture

- Three 16-bit timers/counters; can pair up two to make one 32-bit
- · Two OC modules, configurable as timers/counters
- · Four IC modules
- Peripheral Pin Select (PPS) to allow function remap

### **Communication Interfaces**

- One UART module (10 Mbps)
  - With support for LIN/J2602 protocols and IrDA®
- One 4-wire SPI module (15 Mbps)
- One I<sup>2</sup>C<sup>™</sup> module (up to 1 Mbaud) with SMBus support
- · PPS to allow function remap

### Input/Output

- Sink/Source up to 10 mA (pin-specific) for standard VoH/VoL, up to 16 mA (pin-specific) for non-standard VoH1
- · 5V tolerant pins
- · Selectable open-drain, pull-ups, and pull-downs
- · Up to 5 mA overvoltage clamp current
- · External interrupts on all I/O pins

### **Qualification and Class B Support**

- AEC-Q100 REVG (Grade 1 -40°C to +125°C)
- AEC-Q100 REVG (Grade 0 -40°C to +150°C)
- · Class B Safety Library, IEC 60730

### **Debugger Development Support**

- · In-circuit and in-application programming
- · Two program and two complex data breakpoints
- IEEE 1149.2-compatible (JTAG) boundary scan
- · Trace and run-time watch

# dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 Product Families

The device names, pin counts, memory sizes and peripheral availability of each family are listed below, followed by their pinout diagrams.

TABLE 1: dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 CONTROLLER FAMILIES

|                  |      | tes)                          |              |                    | Re               | mappa         | ble Pe                     | ripher | als                                |     |                   |                                |                |                                |
|------------------|------|-------------------------------|--------------|--------------------|------------------|---------------|----------------------------|--------|------------------------------------|-----|-------------------|--------------------------------|----------------|--------------------------------|
| Device           | Pins | Program Flash Memory (Kbytes) | RAM (Kbytes) | Remappable<br>Pins | 16-Bit Timer     | Input Capture | Output Compare<br>Std. PWM | UART   | External Interrupts <sup>(2)</sup> | IdS | 10-Bit/12-Bit ADC | I <sup>2</sup> C <sup>TM</sup> | I/O Pins (Max) | Packages                       |
| dsPIC33FJ32GP202 | 28   | 32                            | 2            | 16                 | 3 <sup>(1)</sup> | 4             | 2                          | 1      | 3                                  | 1   | 1 ADC,<br>10 ch   | 1                              | 21             | SPDIP<br>SOIC<br>SSOP<br>QFN-S |
| dsPIC33FJ32GP204 | 44   | 32                            | 2            | 26                 | 3(1)             | 4             | 2                          | 1      | 3                                  | 1   | 1 ADC,<br>13 ch   | 1                              | 35             | QFN<br>TQFP                    |
| dsPIC33FJ16GP304 | 44   | 16                            | 2            | 26                 | 3(1)             | 4             | 2                          | 1      | 3                                  | 1   | 1 ADC,<br>13 ch   | 1                              | 35             | QFN<br>TQFP                    |

**Note 1:** Only two out of three timers are remappable.

**2:** Only two out of three interrupts are remappable.

### **Pin Diagrams**



### Pin Diagrams (Continued)



2: The metal plane at the bottom of the device is not connected to any pins and is recommended to be connected to Vss externally.

### Pin Diagrams (Continued)



### **Table of Contents**

| 1.0   | Device Overview                                                       | 9   |
|-------|-----------------------------------------------------------------------|-----|
| 2.0   | Guidelines for Getting Started with 16-bit Digital Signal Controllers | 13  |
| 3.0   | CPU                                                                   |     |
| 4.0   | Memory Organization                                                   | 29  |
| 5.0   | Flash Program Memory                                                  | 55  |
| 6.0   | Resets                                                                | 61  |
| 7.0   | Interrupt Controller                                                  | 71  |
| 8.0   | Oscillator Configuration                                              | 97  |
| 9.0   | Power-Saving Features                                                 | 109 |
| 10.0  | I/O Ports                                                             | 115 |
| 11.0  | Timer1                                                                | 137 |
| 12.0  | Timer2/3 Feature                                                      | 141 |
| 13.0  | Input Capture                                                         | 147 |
| 14.0  | Output Compare                                                        | 151 |
| 15.0  | Serial Peripheral Interface (SPI)                                     |     |
| 16.0  | Inter-Integrated Circuit™ (I <sup>2</sup> C™)                         | 161 |
| 17.0  | Universal Asynchronous Receiver Transmitter (UART)                    | 169 |
| 18.0  | 10-bit/12-bit Analog-to-Digital Converter (ADC)                       | 175 |
| 19.0  | Special Features                                                      | 189 |
| 20.0  | Instruction Set Summary                                               | 197 |
| 21.0  | Development Support                                                   | 205 |
| 22.0  | Electrical Characteristics                                            | 209 |
| 23.0  | High Temperature Electrical Characteristics                           | 253 |
| 24.0  | DC and AC Device Characteristics Graphs                               | 263 |
| 25.0  | Packaging Information                                                 | 267 |
| Appe  | endix A: Revision History                                             | 281 |
| Index | x                                                                     | 291 |
| The I | Microchip Web Site                                                    | 295 |
| Custo | omer Change Notification Service                                      | 295 |
| Custo | omer Support                                                          | 295 |
| Read  | der Response                                                          | 296 |
| Prod  | uct Identification System                                             | 297 |

### TO OUR VALUED CUSTOMERS

It is our intention to provide our valued customers with the best documentation possible to ensure successful use of your Microchip products. To this end, we will continue to improve our publications to better suit your needs. Our publications will be refined and enhanced as new volumes and updates are introduced.

If you have any questions or comments regarding this publication, please contact the Marketing Communications Department via E-mail at **docerrors@microchip.com** or fax the **Reader Response Form** in the back of this data sheet to (480) 792-4150. We welcome your feedback.

#### **Most Current Data Sheet**

To obtain the most up-to-date version of this data sheet, please register at our Worldwide Web site at:

#### http://www.microchip.com

You can determine the version of a data sheet by examining its literature number found on the bottom outside corner of any page. The last character of the literature number is the version number, (e.g., DS30000A is version A of document DS30000).

#### **Errata**

An errata sheet, describing minor operational differences from the data sheet and recommended workarounds, may exist for current devices. As device/documentation issues become known to us, we will publish an errata sheet. The errata will specify the revision of silicon and revision of document to which it applies.

To determine if an errata sheet exists for a particular device, please check with one of the following:

- · Microchip's Worldwide Web site; http://www.microchip.com
- Your local Microchip sales office (see last page)

When contacting a sales office, please specify which device, revision of silicon and data sheet (include literature number) you are using.

### **Customer Notification System**

Register on our web site at www.microchip.com to receive the most current information on all of our products.

### **Referenced Sources**

This device data sheet is based on the following individual chapters of the "dsPIC33F/PIC24H Family Reference Manual". These documents should be considered as the general reference for the operation of a particular module or device feature.

Note 1: To access the documents listed below, browse to the documentation section of the dsPIC33FJ32GP204 product page of the Microchip web site (www.microchip.com).

In addition to parameters, features, and other documentation, the resulting page provides links to the related family reference manual sections.

- Section 1. "Introduction" (DS70197)
- Section 2. "CPU" (DS70204)
- Section 3. "Data Memory" (DS70202)
- Section 4. "Program Memory" (DS70202)
- Section 5. "Flash Programming" (DS70191)
- Section 6. "Interrupts (DS70184)
- Section 7. "Oscillator" (DS70186)
- Section 8. "Reset" (DS70192)
- Section 9. "Watchdog Timer and Power-Saving Modes" (DS70196)
- Section 10. "I/O Ports" (DS70193)
- Section 11. "Timers" (DS70205)
- Section 12. "Input Capture" (DS70198)
- Section 13. "Output Compare" (DS70209)
- Section 16. "Analog-to-Digital Converter (ADC)" (DS70183)
- Section 17. "UART" (DS70188)
- Section 18. "Serial Peripheral Interface (SPI)" (DS70206)
- Section 19. "Inter-Integrated Circuit™ (I<sup>2</sup>C™)" (DS70195)
- Section 23. "CodeGuard™ Security" (DS70199)
- Section 25. "Device Configuration" (DS70194)

### 1.0 DEVICE OVERVIEW

Note 1: This data sheet summarizes the features of the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the "dsPIC33F/PIC24H Family Reference Manual". Please see the Microchip web site (www.microchip.com) for the latest dsPIC33F/PIC24H Family Reference Manual sections.

2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information.

This document contains device-specific information for the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 Digital Signal Controller (DSC) devices. The dsPIC33F devices contain extensive Digital Signal Processor (DSP) functionality with a high performance 16-bit microcontroller (MCU) architecture.

Figure 1-1 shows a general block diagram of the core and peripheral modules in the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 family of devices. Table 1-1 lists the functions of the various pins shown in the pinout diagrams.



**TABLE 1-1: PINOUT I/O DESCRIPTIONS** 

| IABLE 1-1:          | -1: PINOUT I/O DESCRIPTIONS |                |            |                                                                                                                                                                                                                                                           |  |  |
|---------------------|-----------------------------|----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Pin Name            | Pin<br>Type                 | Buffer<br>Type | PPS        | Description                                                                                                                                                                                                                                               |  |  |
| AN0-AN12            | I                           | Analog         | No         | Analog input channels.                                                                                                                                                                                                                                    |  |  |
| CLKI<br>CLKO        | 0                           | ST/CMOS        | No<br>No   | External clock source input. Always associated with OSC1 pin function. Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes. Always associated with OSC2 pin function. |  |  |
| OSC1                | I                           | ST/CMOS        | No         | Oscillator crystal input. ST buffer when configured in RC mode; CMOS otherwise.                                                                                                                                                                           |  |  |
| OSC2                | I/O                         | _              | No         | Oscillator crystal output. Connects to crystal or resonator in Crystal Oscillator mode. Optionally functions as CLKO in RC and EC modes.                                                                                                                  |  |  |
| SOSCI<br>SOSCO      | I<br>О                      | ST/CMOS        | No<br>No   | 32.768 kHz low-power oscillator crystal input; CMOS otherwise. 32.768 kHz low-power oscillator crystal output.                                                                                                                                            |  |  |
| CN0-CN30            | I                           | ST             | No         | Change notification inputs. Can be software programmed for internal weak pull-ups on all inputs.                                                                                                                                                          |  |  |
| IC1-IC2<br>IC7-IC8  | I                           | ST             | Yes<br>Yes | Capture inputs 1/2. Capture inputs 7/8.                                                                                                                                                                                                                   |  |  |
| OCFA<br>OC1-OC2     | I<br>О                      | ST<br>—        | Yes<br>Yes | Compare Fault A input (for Compare Channels 1 and 2). Compare outputs 1 through 2.                                                                                                                                                                        |  |  |
| INT0                | I                           | ST             | No         | External interrupt 0.                                                                                                                                                                                                                                     |  |  |
| INT1                | I                           | ST             | Yes        | External interrupt 1.                                                                                                                                                                                                                                     |  |  |
| INT2                | l                           | ST             | Yes        | External interrupt 2.                                                                                                                                                                                                                                     |  |  |
| RA0-RA4<br>RA7-RA10 | I/O                         | ST             | No<br>No   | PORTA is a bidirectional I/O port.                                                                                                                                                                                                                        |  |  |
| RB0-RB15            | I/O                         | ST             | No         | PORTB is a bidirectional I/O port.                                                                                                                                                                                                                        |  |  |
| RC0-RC9             | I/O                         | ST             | No         | PORTC is a bidirectional I/O port.                                                                                                                                                                                                                        |  |  |
| T1CK                | I                           | ST             | No         | Timer1 external clock input.                                                                                                                                                                                                                              |  |  |
| T2CK                | 1                           | ST             | Yes        | Timer2 external clock input.                                                                                                                                                                                                                              |  |  |
| T3CK                |                             | ST             | Yes        | Timer3 external clock input.                                                                                                                                                                                                                              |  |  |
| U1CTS               |                             | ST             | Yes        | UART1 clear to send.                                                                                                                                                                                                                                      |  |  |
| U1RTS               | 0                           | ST             | Yes<br>Yes | UART1 ready to send. UART1 receive.                                                                                                                                                                                                                       |  |  |
| U1RX<br>U1TX        | 0                           | - SI           | Yes        | UART1 transmit.                                                                                                                                                                                                                                           |  |  |
| SCK1                | I/O                         | ST             | Yes        | Synchronous serial clock input/output for SPI1.                                                                                                                                                                                                           |  |  |
| SDI1                | 1/0                         | ST             | Yes        | SPI1 data in.                                                                                                                                                                                                                                             |  |  |
| SDO1                | Ö                           | _              | Yes        | SPI1 data out.                                                                                                                                                                                                                                            |  |  |
| SS1                 | I/O                         | ST             | Yes        | SPI1 slave synchronization or frame pulse I/O.                                                                                                                                                                                                            |  |  |
| SCL1                | I/O                         | ST             | No         | Synchronous serial clock input/output for I2C1.                                                                                                                                                                                                           |  |  |
| SDA1                | I/O                         | ST             | No         | Synchronous serial data input/output for I2C1.                                                                                                                                                                                                            |  |  |
| ASCL1               | I/O                         | ST             | No         | Alternate synchronous serial clock input/output for I2C1.                                                                                                                                                                                                 |  |  |
| ASDA1               | I/O                         | ST             | No         | Alternate synchronous serial data input/output for I2C1.                                                                                                                                                                                                  |  |  |
| TMS                 | l                           | ST             | No<br>No   | JTAG Test mode select pin.                                                                                                                                                                                                                                |  |  |
| TCK<br>TDI          | l<br>I                      | ST<br>ST       | No<br>No   | JTAG test clock input pin. JTAG test data input pin.                                                                                                                                                                                                      |  |  |
| TDO                 | 0                           | _              | No         | JTAG test data output pin.                                                                                                                                                                                                                                |  |  |
| PGED1               | I/O                         | ST             | No         | Data I/O pin for programming/debugging communication channel 1.                                                                                                                                                                                           |  |  |
| PGEC1               | I                           | ST             | No         | Clock input pin for programming/debugging communication channel 1.                                                                                                                                                                                        |  |  |
| PGED2               | I/O                         | ST             | No         | Data I/O pin for programming/debugging communication channel 2.                                                                                                                                                                                           |  |  |
| PGEC2               |                             | ST             | No         | Clock input pin for programming/debugging communication channel 2.                                                                                                                                                                                        |  |  |
| PGED3<br>PGEC3      | I/O<br>I                    | ST<br>ST       | No<br>No   | Data I/O pin for programming/debugging communication channel 3. Clock input pin for programming/debugging communication channel 3.                                                                                                                        |  |  |

**Legend:** CMOS = CMOS compatible input or output;

ST = Schmitt Trigger input with CMOS levels;

PPS = Peripheral Pin Select

Analog = Analog input;

O = Output;

P = Power I = Input

TABLE 1-1: PINOUT I/O DESCRIPTIONS (CONTINUED)

| Pin Name | Pin<br>Type | Buffer<br>Type | PPS | Description                                                                  |  |
|----------|-------------|----------------|-----|------------------------------------------------------------------------------|--|
| VCAP     | Р           | _              | No  | CPU logic filter capacitor connection.                                       |  |
| Vss      | Р           | _              | No  | Ground reference for logic and I/O pins.                                     |  |
| VREF+    | - 1         | Analog         | No  | Analog voltage reference (high) input.                                       |  |
| VREF-    | I           | Analog         | No  | Analog voltage reference (low) input.                                        |  |
| AVDD     | Р           | Р              | No  | Positive supply for analog modules. This pin must be connected at all times. |  |
| MCLR     | I/P         | ST             | No  | Master Clear (Reset) input. This pin is an active-low Reset to the device.   |  |
| Avss     | Р           | Р              | No  | Ground reference for analog modules.                                         |  |
| VDD      | Р           | _              | No  | Positive supply for peripheral logic and I/O pins.                           |  |

**Legend:** CMOS = CMOS compatible input or output;

Analog = Analog input;

P = Power

ST = Schmitt Trigger input with CMOS levels; PPS = Peripheral Pin Select O = Output;

I = Input

# 2.0 GUIDELINES FOR GETTING STARTED WITH 16-BIT DIGITAL SIGNAL CONTROLLERS

- Note 1: This data sheet summarizes the features of the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to the "dsPIC33F/PIC24H Family Reference Manual". Please see the Microchip web site (www.microchip.com) for the latest dsPIC33F/PIC24H Family Reference Manual sections.
  - 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.

### 2.1 Basic Connection Requirements

Getting started with the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 family of 16-bit Digital Signal Controllers (DSCs) requires attention to a minimal set of device pin connections before proceeding with development. The following is a list of pin names, which must always be connected:

- All VDD and Vss pins (see Section 2.2 "Decoupling Capacitors")
- All AVDD and AVSS pins (even if ADC module is not used)

(see Section 2.2 "Decoupling Capacitors")

- VCAP (see Section 2.3 "CPU Logic Filter Capacitor Connection (VCAP)")
- MCLR pin (see Section 2.4 "Master Clear (MCLR) Pin")
- PGECx/PGEDx pins used for In-Circuit Serial Programming™ (ICSP™) and debugging purposes (see Section 2.5 "ICSP Pins")
- OSC1 and OSC2 pins when external oscillator source is used (see Section 2.6 "External Oscillator Pins")

Additionally, the following pins may be required:

 VREF+/VREF- pins used when external voltage reference for ADC module is implemented

**Note:** The AVDD and AVSS pins must be connected independent of the ADC voltage reference source.

### 2.2 Decoupling Capacitors

The use of decoupling capacitors on every pair of power supply pins, such as VDD, VSS, AVDD and AVSS is required.

Consider the following criteria when using decoupling capacitors:

- Value and type of capacitor: Recommendation of 0.1 μF (100 nF), 10-20V. This capacitor should be a low-ESR and have resonance frequency in the range of 20 MHz and higher. It is recommended that ceramic capacitors be used.
- Placement on the printed circuit board: The
  decoupling capacitors should be placed as close
  to the pins as possible. It is recommended to
  place the capacitors on the same side of the
  board as the device. If space is constricted, the
  capacitor can be placed on another layer on the
  PCB using a via; however, ensure that the trace
  length from the pin to the capacitor is within
  one-quarter inch (6 mm) in length.
- Handling high frequency noise: If the board is experiencing high frequency noise, upward of tens of MHz, add a second ceramic-type capacitor in parallel to the above described decoupling capacitor. The value of the second capacitor can be in the range of 0.01 µF to 0.001 µF. Place this second capacitor next to the primary decoupling capacitor. In high-speed circuit designs, consider implementing a decade pair of capacitances as close to the power and ground pins as possible. For example, 0.1 µF in parallel with 0.001 µF.
- Maximizing performance: On the board layout from the power supply circuit, run the power and return traces to the decoupling capacitors first, and then to the device pins. This ensures that the decoupling capacitors are first in the power chain. Equally important is to keep the trace length between the capacitor and the power pins to a minimum thereby reducing PCB track inductance.

# FIGURE 2-1: RECOMMENDED MINIMUM CONNECTION



Note 1: As an option, instead of a hard-wired connection, an inductor (L1) can be substituted between VDD and AVDD to improve ADC noise rejection. The inductor impedance should be less than 1Ω and the inductor capacity greater than 10 mA.

Where

$$f = \frac{FCNV}{2} \qquad \text{(i.e., ADC conversion rate/2)}$$
 
$$f = \frac{1}{(2\pi\sqrt{LC})}$$
 
$$L = \left(\frac{1}{(2\pi f\sqrt{C})}\right)^2$$

### 2.2.1 TANK CAPACITORS

On boards with power traces running longer than six inches in length, it is suggested to use a tank capacitor for integrated circuits including DSCs to supply a local power source. The value of the tank capacitor should be determined based on the trace resistance that connects the power supply source to the device, and the maximum current drawn by the device in the application. In other words, select the tank capacitor so that it meets the acceptable voltage sag at the device. Typical values range from 4.7  $\mu$ F to 47  $\mu$ F.

# 2.3 CPU Logic Filter Capacitor Connection (VCAP)

A low-ESR (< 5 Ohms) capacitor is required on the VCAP pin, which is used to stabilize the voltage regulator output voltage. The VCAP pin must not be connected to VDD, and must have a capacitor between 4.7  $\mu$ F and 10  $\mu$ F, 16V connected to ground. The type can be ceramic or tantalum. Refer to Section 22.0 "Electrical Characteristics" for additional information.

The placement of this capacitor should be close to the VCAP. It is recommended that the trace length not exceed one-quarter inch (6 mm). Refer to Section 19.2 "On-Chip Voltage Regulator" for details.

### 2.4 Master Clear (MCLR) Pin

The  $\overline{\text{MCLR}}$  pin provides for two specific device functions:

- · Device Reset
- · Device programming and debugging

During device programming and debugging, the resistance and capacitance that can be added to the pin must be considered. Device programmers and debuggers drive the  $\overline{\text{MCLR}}$  pin. Consequently, specific voltage levels (VIH and VIL) and fast signal transitions must not be adversely affected. Therefore, specific values of R and C will need to be adjusted based on the application and PCB requirements.

For example, as shown in Figure 2-2, it is recommended that capacitor C is isolated from the MCLR pin during programming and debugging operations.

Place the components shown in Figure 2-2 within one-quarter inch (6 mm) from the MCLR pin.

# FIGURE 2-2: EXAMPLE OF MCLR PIN CONNECTIONS



- Note 1:  $R \le 10 \text{ k}\Omega$  is recommended. A suggested starting value is  $10 \text{ k}\Omega$  Ensure that the MCLR pin VIH and VIL specifications are met.
  - 2:  $R1 \le 470\Omega$  will limit any current flowing into MCLR from the external capacitor C, in the event of MCLR pin breakdown, due to Electrostatic Discharge (ESD) or Electrical Overstress (EOS). Ensure that the MCLR pin VIH and VIL specifications are met.

### 2.5 ICSP Pins

The PGECx and PGEDx pins are used for In-Circuit Serial Programming (ICSP) and debugging purposes. It is recommended to keep the trace length between the ICSP connector and the ICSP pins on the device as short as possible. If the ICSP connector is expected to experience an ESD event, a series resistor is recommended, with the value in the range of a few tens of Ohms, not to exceed 100 Ohms.

Pull-up resistors, series diodes and capacitors on the PGECx and PGEDx pins are not recommended as they will interfere with the programmer/debugger communications to the device. If such discrete components are an application requirement, they should be removed from the circuit during programming and debugging. Alternatively, refer to the AC/DC characteristics and timing requirements information in the respective device Flash programming specification for information on capacitive loading limits and pin input voltage high (VIH) and input low (VIL) requirements.

Ensure that the "Communication Channel Select" (i.e., PGECx/PGEDx pins) programmed into the device matches the physical connections for the ICSP to MPLAB® ICD 3 or MPLAB REAL ICE™ in-circuit emulator.

For more information on MPLAB ICD 3 or MPLAB REAL ICE™ in-circuit emulator connection requirements, refer to the following documents that are available on the Microchip web site.

- "Using MPLAB® ICD 3" (poster) DS51765
- "MPLAB® ICD 3 Design Advisory" DS51764
- "MPLAB<sup>®</sup> REAL ICE™ In-Circuit Emulator User's Guide" DS51616
- "Using MPLAB® REAL ICE™" (poster) DS51749

### 2.6 External Oscillator Pins

Many DSCs have options for at least two oscillators: a high-frequency primary oscillator and a low-frequency secondary oscillator (refer to **Section 8.0 "Oscillator Configuration"** for details).

The oscillator circuit should be placed on the same side of the board as the device. Also, place the oscillator circuit close to the respective oscillator pins, not exceeding one-half inch (12 mm) distance between them. The load capacitors should be placed next to the oscillator itself, on the same side of the board. Use a grounded copper pour around the oscillator circuit to isolate them from surrounding circuits. The grounded copper pour should be routed directly to the MCU ground. Do not run any signal traces or power traces inside the ground pour. Also, if using a two-sided board, avoid any traces on the other side of the board where the crystal is placed. A suggested layout is shown in Figure 2-3.

FIGURE 2-3: SUGGESTED PLACEMENT OF THE OSCILLATOR CIRCUIT



# 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 ≤8 MHz for start-up with PLL enabled to comply with device PLL start-up conditions. This means that if the external oscillator frequency is outside this range, the application must start-up in FRC mode first. The default PLL settings 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 initialize the PLL SFRs, CLKDIV and PLLDBF to a suitable value, 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 2, MPLAB ICD 3, or MPLAB REAL ICE in-circuit emulator is selected as a debugger, it automatically initializes all of the A/D input pins (ANx) as "digital" pins, by setting all bits in the AD1PCFGL register.

The bits in the registers that correspond to the A/D 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 A/D 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 A/D 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.

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

### 3.0 CPU

Note 1: This data sheet summarizes the features of the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 2. "CPU" (DS70204) of the "dsPIC33F/PIC24H 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 dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 CPU module has a 16-bit (data) modified Harvard architecture with an enhanced instruction set, including significant support for DSP. The CPU has a 24-bit instruction word with a variable length opcode field. The Program Counter (PC) is 23 bits wide and addresses up to 4M x 24 bits of user program memory space. The actual amount of program memory implemented varies by device. A single-cycle instruction prefetch mechanism is used to help maintain throughput and provides predictable execution. All instructions execute in a single cycle, with the exception of instructions that change the program flow, the double word move (MOV.D) instruction and the table instructions. Overhead-free program loop constructs are supported using the DO and REPEAT instructions, both of which are interruptible at any point.

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 devices have sixteen, 16-bit working registers in the programmer's model. Each of the working registers can serve as a data, address or address offset register. The 16th working register (W15) operates as a software Stack Pointer (SP) for interrupts and calls.

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 instruction set has two classes of instructions: MCU and DSP. These two instruction classes are seamlessly integrated into a single CPU. The instruction set includes many addressing modes and is designed for optimum C compiler efficiency. For most instructions, the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 is capable of executing a data (or program data) memory read, a working register (data) read, a data memory write and a program (instruction) memory read per instruction cycle. As a result, three parameter instructions can be supported, allowing A + B = C operations to be executed in a single cycle.

A block diagram of the CPU is shown in Figure 3-1. The programmer's model for the dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 is shown in Figure 3-2.

### 3.1 Data Addressing Overview

The data space can be addressed as 32K words or 64 Kbytes and is split into two blocks, referred to as X and Y data memory. Each memory block has its own independent Address Generation Unit (AGU). The MCU class of instructions operates solely through the X memory AGU, which accesses the entire memory map as one linear data space. Certain DSP instructions operate through the X and Y AGUs to support dual operand reads, which splits the data address space into two parts. The X and Y data space boundary is device-specific.

Overhead-free circular buffers (Modulo Addressing mode) are supported in both X and Y address spaces. The Modulo Addressing removes the software boundary checking overhead for DSP algorithms. Furthermore, the X AGU circular addressing can be used with any of the MCU class of instructions. The X AGU also supports Bit-Reversed Addressing to greatly simplify input or output data reordering for radix-2 FFT algorithms.

The upper 32 Kbytes of the data space memory map can optionally be mapped into program space at any 16K program word boundary defined by the 8-bit Program Space Visibility Page (PSVPAG) register. The program to data space mapping feature lets any instruction access program space as if it were data space.

### 3.2 DSP Engine Overview

The DSP engine features a high-speed 17-bit by 17-bit multiplier, a 40-bit ALU, two 40-bit saturating accumulators and a 40-bit bidirectional barrel shifter. The barrel shifter is capable of shifting a 40-bit value up to 16 bits right or left, in a single cycle. The DSP instructions operate seamlessly with all other instructions and have been designed for optimal real-time performance. The MAC instruction and other associated instructions can concurrently fetch two data operands from memory while multiplying two W registers and accumulating and optionally saturating the result in the same cycle. This instruction functionality requires that the RAM data space be split for these instructions and linear for all others. Data space partitioning is achieved in a transparent and flexible manner through dedicating certain working registers to each address space.

### 3.3 Special MCU Features

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 features a 17-bit by 17-bit single-cycle multiplier that is shared by both the MCU ALU and DSP engine. The multiplier can perform signed, unsigned and mixed-sign multiplication. Using a 17-bit by 17-bit multiplier for 16-bit by 16-bit multiplication not only allows you to perform mixed-sign multiplication, it also achieves accurate results for special operations, such as (-1.0) x (-1.0).

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 supports 16/16 and 32/16 divide operations, both fractional and integer. All divide instructions are iterative operations. They must be executed within a REPEAT loop, resulting in a total execution time of 19 instruction cycles. The divide operation can be interrupted during any of those 19 cycles without loss of data.

A 40-bit barrel shifter is used to perform up to a 16-bit left or right shift in a single cycle. The barrel shifter can be used by both MCU and DSP instructions.

FIGURE 3-1: dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 CPU CORE BLOCK DIAGRAM





### 3.4 CPU Resources

Many useful resources are provided on the main product page of the Microchip web site for the devices listed in this data sheet. This product page, which can be accessed using this link, contains the latest updates and additional information.

Note:

In the event you are not able to access the product page using the link above, enter this URL in your browser: http://www.microchip.com/wwwproducts/Devices.aspx?dDocName=en530331

### 3.4.1 KEY RESOURCES

- Section 2. "CPU" (DS70204)
- · Code Samples
- · Application Notes
- · Software Libraries
- · Webinars
- All related dsPIC33F/PIC24H Family Reference Manuals Sections
- · Development Tools

### 3.5 CPU Control Registers

### **REGISTER 3-1:** SR: CPU STATUS REGISTER

| R-0    | R-0 | R/C-0             | R/C-0             | R-0 | R/C-0 | R -0 | R/W-0 |
|--------|-----|-------------------|-------------------|-----|-------|------|-------|
| OA     | ОВ  | SA <sup>(1)</sup> | SB <sup>(1)</sup> | OAB | SAB   | DA   | DC    |
| bit 15 |     |                   |                   |     |       |      | bit 8 |

| R/W-0 <sup>(2)</sup> | R/W-0 <sup>(3)</sup>    | R/W-0 <sup>(3)</sup> | R-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
|----------------------|-------------------------|----------------------|-----|-------|-------|-------|-------|
|                      | IPL<2:0> <sup>(2)</sup> |                      | RA  | N     | OV    | Z     | С     |
| bit 7                |                         |                      |     |       |       |       | bit 0 |

| Legend:            |                      |                                    |
|--------------------|----------------------|------------------------------------|
| C = Clear only bit | R = Readable bit     | U = Unimplemented bit, read as '0' |
| S = Set only bit   | W = Writable bit     | -n = Value at POR                  |
| '1' = Bit is set   | '0' = Bit is cleared | x = Bit is unknown                 |

bit 15 OA: Accumulator A Overflow Status bit

1 = Accumulator A overflowed

0 = Accumulator A has not overflowed

bit 14 **OB:** Accumulator B Overflow Status bit

1 = Accumulator B overflowed

0 = Accumulator B has not overflowed

bit 13 **SA:** Accumulator A Saturation 'Sticky' Status bit (1)

1 = Accumulator A is saturated or has been saturated at some time

0 = Accumulator A is not saturated

bit 12 SB: Accumulator B Saturation 'Sticky' Status bit (1)

1 = Accumulator B is saturated or has been saturated at some time

0 = Accumulator B is not saturated

bit 11 OAB: OA || OB Combined Accumulator Overflow Status bit

1 = Accumulators A or B have overflowed

0 = Neither Accumulators A or B have overflowed

bit 10 SAB: SA | SB Combined Accumulator 'Sticky' Status bit

1 = Accumulators A or B are saturated or have been saturated at some time in the past

0 = Neither Accumulator A or B are saturated

Note: This bit can be read or cleared (not set). Clearing this bit will clear SA and SB.

bit 9 DA: DO Loop Active bit

1 = DO loop in progress

0 = DO loop not in progress

bit 8 DC: MCU ALU Half Carry/Borrow bit

1 = A carry-out from the 4th low-order bit (for byte sized data) or 8th low-order bit (for word sized data) of the result occurred

0 = No carry-out from the 4th low-order bit (for byte sized data) or 8th low-order bit (for word sized data) of the result occurred

Note 1: This bit can be read or cleared (not set).

2: The IPL<2:0> bits are concatenated with the IPL<3> bit (CORCON<3>) to form the CPU Interrupt Priority Level (IPL). The value in parentheses indicates the IPL if IPL<3> = 1. User interrupts are disabled when IPI <3> = 1.

3: The IPL<2:0> Status bits are read only when NSTDIS = 1 (INTCON1<15>).

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

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

- Note 1: This bit can be read or cleared (not set).
  - 2: The IPL<2:0> bits are concatenated with the IPL<3> bit (CORCON<3>) to form the CPU Interrupt Priority Level (IPL). The value in parentheses indicates the IPL if IPL<3> = 1. User interrupts are disabled when IPL<3> = 1.
  - 3: The IPL<2:0> Status bits are read only when NSTDIS = 1 (INTCON1<15>).

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

| U-0    | U-0 | U-0 | R/W-0 | R/W-0              | R-0 | R-0     | R-0   |
|--------|-----|-----|-------|--------------------|-----|---------|-------|
| _      | _   | _   | US    | EDT <sup>(1)</sup> |     | DL<2:0> |       |
| bit 15 |     |     |       |                    |     |         | bit 8 |

| 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   | RND   | IF    |
| bit 7 |       |       |        |                     |       |       | bit 0 |

| Legend:             | C = Clear only bit  |                                                       |                  |  |  |
|---------------------|---------------------|-------------------------------------------------------|------------------|--|--|
| R = Readable bit    | W = Writable bit    | -n = Value at POR                                     | '1' = Bit is set |  |  |
| 0' = Bit is cleared | 'x = Bit is unknown | x = Bit is unknown U = Unimplemented bit, read as '0' |                  |  |  |

bit 15-13 **Unimplemented:** Read as '0'

bit 12 US: DSP Multiply Unsigned/Signed Control bit

1 = DSP engine multiplies are unsigned0 = DSP engine multiplies are signed

bit 11 EDT: Early DO Loop Termination Control bit<sup>(1)</sup>

1 = Terminate executing DO loop at end of current loop iteration

0 = No effect

bit 10-8 **DL<2:0>:** DO Loop Nesting Level Status bits

111 **= 7** DO **loops** active

•

bit 5

001 = 1 DO loop active 000 = 0 DO loops active

bit 7 SATA: AccA Saturation Enable bit

1 = Accumulator A saturation enabled 0 = Accumulator A saturation disabled

bit 6 SATB: AccB Saturation Enable bit

1 = Accumulator B saturation enabled0 = Accumulator B saturation disabled

SATDW: Data Space Write from DSP Engine Saturation Enable bit

1 = Data space write saturation enabled0 = Data space write saturation disabled

bit 4 ACCSAT: Accumulator Saturation Mode Select bit

1 = 9.31 saturation (super saturation)0 = 1.31 saturation (normal saturation)

bit 3 IPL3: CPU Interrupt Priority Level Status bit 3<sup>(2)</sup>

1 = CPU Interrupt Priority Level is greater than 70 = CPU Interrupt Priority Level is 7 or less

bit 2 PSV: Program Space Visibility in Data Space Enable bit

1 = Program space visible in data space0 = Program space not visible in data space

bit 1 RND: Rounding Mode Select bit

1 = Biased (conventional) rounding enabled0 = Unbiased (convergent) rounding enabled

bit 0 **IF:** Integer or Fractional Multiplier Mode Select bit

1 = Integer mode enabled for DSP multiply ops0 = Fractional mode enabled for DSP multiply ops

Note 1: This bit will always read as '0'.

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

### 3.6 Arithmetic Logic Unit (ALU)

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 ALU is 16 bits wide and is capable of addition, subtraction, bit shifts and logic operations. Unless otherwise mentioned, arithmetic operations are 2's complement in nature. Depending on the operation, the ALU can affect the values of the Carry (C), Zero (Z), Negative (N), Overflow (OV) and Digit Carry (DC) Status bits in the SR register. The C and DC Status bits operate as Borrow and Digit Borrow bits, respectively, for subtraction operations.

The ALU can perform 8-bit or 16-bit operations, depending on the mode of the instruction that is used. Data for the ALU operation can come from the W register array or data memory, depending on the addressing mode of the instruction. Likewise, output data from the ALU can be written to the W register array or a data memory location.

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 CPU incorporates hardware support for both multiplication and division. This includes a dedicated hardware multiplier and support hardware for 16-bit-divisor division.

Refer to the "dsPIC30F/33F Programmer's Reference Manual" (DS70157) for information on the SR bits affected by each instruction.

#### 3.6.1 MULTIPLIER

Using the high-speed 17-bit x 17-bit multiplier of the DSP engine, the ALU supports unsigned, signed or mixed-sign operation in several MCU multiplication modes:

- 16-bit x 16-bit signed
- · 16-bit x 16-bit unsigned
- 16-bit signed x 5-bit (literal) unsigned
- 16-bit unsigned x 16-bit unsigned
- 16-bit unsigned x 5-bit (literal) unsigned
- 16-bit unsigned x 16-bit signed
- · 8-bit unsigned x 8-bit unsigned

#### 3.6.2 DIVIDER

The divide block supports 32-bit/16-bit and 16-bit/16-bit signed and unsigned integer divide operations with the following data sizes:

- · 32-bit signed/16-bit signed divide
- · 32-bit unsigned/16-bit unsigned divide
- · 16-bit signed/16-bit signed divide
- 16-bit unsigned/16-bit unsigned divide

The quotient for all divide instructions ends up in W0 and the remainder in W1. 16-bit signed and unsigned DIV instructions can specify any W register for both the 16-bit divisor (Wn) and any W register (aligned) pair (W(m+1):Wm) for the 32-bit dividend. The divide algorithm takes one cycle per bit of divisor, so both 32-bit/16-bit and 16-bit/16-bit instructions take the same number of cycles to execute.

### 3.7 DSP Engine

The DSP engine consists of a high-speed 17-bit x 17-bit multiplier, a barrel shifter and a 40-bit adder/subtracter (with two target accumulators, round and saturation logic).

The dsPIC33FJ32GP202/204 and dsPIC33FJ16GP304 is a single-cycle instruction flow architecture; therefore, concurrent operation of the DSP engine with MCU instruction flow is not possible. However, some MCU ALU and DSP engine resources can be used concurrently by the same instruction (e.g., ED, EDAC).

The DSP engine can also perform accumulator-to-accumulator operations that require no additional data. These instructions are ADD, SUB and NEG.

The DSP engine has options selected through bits in the CPU Core Control register (CORCON), as listed below:

- Fractional or integer DSP multiply (IF)
- · Signed or unsigned DSP multiply (US)
- · Conventional or convergent rounding (RND)
- Automatic saturation on/off for AccA (SATA), AccB (SATB) and writes to data memory (SATDW)
- Accumulator Saturation mode selection (ACC-SAT)

A block diagram of the DSP engine is shown in Figure 3-3.

TABLE 3-1: DSP INSTRUCTIONS SUMMARY

| Instruction | Algebraic<br>Operation | ACC Write<br>Back |
|-------------|------------------------|-------------------|
| CLR         | A = 0                  | Yes               |
| ED          | $A = (x - y)^2$        | No                |
| EDAC        | $A = A + (x - y)^2$    | No                |
| MAC         | A = A + (x * y)        | Yes               |
| MAC         | $A = A + x^2$          | No                |
| MOVSAC      | No change in A         | Yes               |
| MPY         | $A = x \cdot y$        | No                |
| MPY         | $A = x^2$              | No                |
| MPY.N       | $A = -x \bullet y$     | No                |
| MSC         | $A = A - x \bullet y$  | Yes               |

