

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

╳≻

| Product Status             | Active                                                                         |
|----------------------------|--------------------------------------------------------------------------------|
| Core Processor             | dsPIC                                                                          |
| Core Size                  | 16-Bit                                                                         |
| Speed                      | 40 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        | 6KB (2K x 24)                                                                  |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | -                                                                              |
| RAM Size                   | 256 x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                      |
| Data Converters            | A/D 6x10b                                                                      |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                             |
| Mounting Type              | Through Hole                                                                   |
| Package / Case             | 18-DIP (0.300", 7.62mm)                                                        |
| Supplier Device Package    | 18-PDIP                                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic33fj06gs001-e-p |

Email: info@E-XFL.COM

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

#### 4.1.1 PROGRAM MEMORY ORGANIZATION

The program memory space is organized in wordaddressable blocks. Although it is treated as 24 bits wide, it is more appropriate to think of each address of the program memory as a lower and upper word, with the upper byte of the upper word being unimplemented. The lower word always has an even address, while the upper word has an odd address (see Figure 4-2).

Program memory addresses are always word-aligned on the lower word, and addresses are incremented or decremented by two during the code execution. This arrangement provides compatibility with data memory space addressing and makes data in the program memory space accessible.

#### 4.1.2 INTERRUPT AND TRAP VECTORS

All devices reserve the addresses between 0x00000 and 0x000200 for hard-coded program execution vectors. A hardware Reset vector is provided to redirect code execution from the default value of the PC on device Reset to the actual start of code. A GOTO instruction is programmed by the user application at 0x000000, with the actual address for the start of code at 0x000002.

The devices also have two interrupt vector tables, located from 0x000004 to 0x0000FF and 0x000100 to 0x0001FF. These vector tables allow each of the device interrupt sources to be handled by separate Interrupt Service Routines (ISRs). A more detailed discussion of the interrupt vector tables is provided in **Section 7.1** "Interrupt Vector Table".



#### FIGURE 4-2: PROGRAM MEMORY ORGANIZATION

#### TABLE 4-1: CPU CORE REGISTER MAP (CONTINUED)

| SFR Name | SFR<br>Addr | Bit 15                                    | Bit 14 | Bit 13 | Bit 12                     | Bit 11 | Bit 10 | Bit 9   | Bit 8 | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3 | Bit 2 | Bit 1 | Bit 0 | All<br>Resets |
|----------|-------------|-------------------------------------------|--------|--------|----------------------------|--------|--------|---------|-------|-------|-------|-------|--------|-------|-------|-------|-------|---------------|
| CORCON   | 0044        | _                                         | _      | _      | US                         | EDT    |        | DL<2:0> |       | SATA  | SATB  | SATDW | ACCSAT | IPL3  | PSV   | RND   | IF    | 0020          |
| MODCON   | 0046        | XMODEN                                    | YMODEN |        | BWM<3:0> YWM<3:0> XWM<3:0> |        |        |         |       |       |       | 0000  |        |       |       |       |       |               |
| XMODSRT  | 0048        | XS<15:1>                                  |        |        |                            |        |        |         |       | 0     | XXXX  |       |        |       |       |       |       |               |
| XMODEND  | 004A        | XE<15:1>                                  |        |        |                            |        |        |         | 1     | XXXX  |       |       |        |       |       |       |       |               |
| YMODSRT  | 004C        |                                           |        |        |                            |        | Y      | S<15:1> |       |       |       |       |        |       |       |       | 0     | XXXX          |
| YMODEND  | 004E        | YE<15:1>                                  |        |        |                            |        |        |         | 1     | XXXX  |       |       |        |       |       |       |       |               |
| XBREV    | 0050        | BREN XB<14:0>                             |        |        |                            |        |        |         | XXXX  |       |       |       |        |       |       |       |       |               |
| DISICNT  | 0052        | — — Disable Interrupts Counter Register 2 |        |        |                            |        |        |         |       | XXXX  |       |       |        |       |       |       |       |               |

Legend:

x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

|           |                | USFICJ  | 323036           | 53302            |                                    |                                 |        |          |          |        |         |       |        |         |          |         |         |               |
|-----------|----------------|---------|------------------|------------------|------------------------------------|---------------------------------|--------|----------|----------|--------|---------|-------|--------|---------|----------|---------|---------|---------------|
| File Name | Addr<br>Offset | Bit 15  | Bit 14           | Bit 13           | Bit 12                             | Bit 11                          | Bit 10 | Bit 9    | Bit 8    | Bit 7  | Bit 6   | Bit 5 | Bit 4  | Bit 3   | Bit 2    | Bit 1   | Bit 0   | All<br>Resets |
| PWMCON4   | 0480           | FLTSTAT | CLSTAT           | TRGSTAT          | FLTIEN                             | CLIEN                           | TRGIEN | ITB      | MDCS     | DTC    | <1:0>   | —     | —      | —       | CAM      | XPRES   | IUE     | 0000          |
| IOCON4    | 0482           | PENH    | PENL             | POLH             | POLL                               | PMOD                            | )<1:0> | OVRENH   | OVRENL   | OVRDA  | \T<1:0> | FLTDA | T<1:0> | CLDA    | T<1:0>   | SWAP    | OSYNC   | 0000          |
| FCLCON4   | 0484           | IFLTMOD |                  |                  | CLSRC<4:0> CLPOL CLMOD FLTSRC<4:0> |                                 |        | FLTPOL   | FLTMO    | D<1:0> | 0000    |       |        |         |          |         |         |               |
| PDC4      | 0486           |         | PDC4<15:0> 0000  |                  |                                    |                                 |        |          |          | 0000   |         |       |        |         |          |         |         |               |
| PHASE4    | 0488           |         | PHASE4<15:0> 000 |                  |                                    |                                 |        |          |          | 0000   |         |       |        |         |          |         |         |               |
| DTR4      | 048A           | _       | —                |                  | DTR4<13:0> 00                      |                                 |        |          |          |        | 0000    |       |        |         |          |         |         |               |
| ALTDTR4   | 048C           | _       | —                | ALTDTR4<13:0> 00 |                                    |                                 |        |          |          |        | 0000    |       |        |         |          |         |         |               |
| SDC4      | 048E           |         | SDC4<15:0> 00    |                  |                                    |                                 |        |          |          |        | 0000    |       |        |         |          |         |         |               |
| SPHASE4   | 0490           |         |                  |                  |                                    |                                 |        | 5        | SPHASE4< | 15:0>  |         |       |        |         |          |         |         | 0000          |
| TRIG4     | 0492           |         |                  |                  |                                    |                                 | TRGC   | MP<15:3> |          |        |         |       |        |         | —        | _       | —       | 0000          |
| TRGCON4   | 0494           |         | TRGD             | IV<3:0>          |                                    | _                               | _      | _        | —        | DTM    | _       |       |        | TRG     | STRT<5:0 | >       |         | 0000          |
| STRIG4    | 0496           |         |                  |                  |                                    |                                 | STRGC  | MP<15:3> |          |        |         |       |        |         | —        | _       | —       | 0000          |
| PWMCAP4   | 0498           |         |                  |                  | PWMCAP4<15:3>                      |                                 |        |          |          | 0000   |         |       |        |         |          |         |         |               |
| LEBCON4   | 049A           | PHR     | PHF              | PLR              | PLF                                | FLTLEBEN CLLEBEN LEB<6:0> — — — |        |          |          | _      | 0000    |       |        |         |          |         |         |               |
| AUXCON4   | 049E           | HRPDIS  | HRDDIS           | _                | _                                  | _                               | _      | _        | _        | _      | _       |       | CHOPS  | EL<3:0> |          | CHOPHEN | CHOPLEN | 0000          |
| 1         |                |         | - ·              |                  |                                    |                                 |        |          |          |        |         |       |        |         |          |         |         |               |

dsPIC33FJ06GS001/101A/102A/202A and dsPIC33FJ09GS302

# TABLE 4-15: HIGH-SPEED PWM GENERATOR 4 REGISTER MAP FOR dsPIC33FJ06GS001, dsPIC33FJ06GS101A AND dsPIC33FJ09GS302

Legend: x = unknown value on Reset, — = unimplemented, read as '0'. Reset values are shown in hexadecimal.

#### 4.5 Modulo Addressing

Modulo Addressing mode is a method used to provide an automated means to support circular data buffers using hardware. The objective is to remove the need for software to perform data address boundary checks when executing tightly looped code, as is typical in many DSP algorithms.

Modulo Addressing can operate in either data or program space (since the data pointer mechanism is essentially the same for both). One circular buffer can be supported in each of the X (which also provides the pointers into program space) and Y data spaces. Modulo Addressing can operate on any W register pointer. However, it is not advisable to use W14 or W15 for Modulo Addressing since these two registers are used as the Stack Frame Pointer and Stack Pointer, respectively.

In general, any particular circular buffer can be configured to operate in only one direction as there are certain restrictions on the buffer start address (for incrementing buffers), or end address (for decrementing buffers), based upon the direction of the buffer.

The only exception to the usage restrictions is for buffers that have a power-of-two length. As these buffers satisfy the start and end address criteria, they can operate in a bidirectional mode (that is, address boundary checks are performed on both the lower and upper address boundaries).

#### 4.5.1 START AND END ADDRESS

The Modulo Addressing scheme requires that a starting and ending address be specified and loaded into the 16-bit Modulo Buffer Address registers: XMODSRT, XMODEND, YMODSRT and YMODEND (see Table 4-1).

| Note: | Y                                  | space | Modulo | Addressing | EA   |  |  |
|-------|------------------------------------|-------|--------|------------|------|--|--|
|       | calculations                       |       | assume | word-sized | data |  |  |
|       | (LSb of every EA is always clear). |       |        |            |      |  |  |

The length of a circular buffer is not directly specified. It is determined by the difference between the corresponding start and end addresses. The maximum possible length of the circular buffer is 32K words (64 Kbytes).

#### 4.5.2 W ADDRESS REGISTER SELECTION

The Modulo and Bit-Reversed Addressing Control register, MODCON<15:0>, contains enable flags as well as a W register field to specify the W Address registers. The XWM and YWM fields select the registers that will operate with Modulo Addressing:

- If XWM = 15, X RAGU and X WAGU Modulo Addressing is disabled
- If YWM = 15, Y AGU Modulo Addressing is disabled

The X Address Space Pointer W register (XWM), to which Modulo Addressing is to be applied, is stored in MODCON<3:0> (see Table 4-1). Modulo Addressing is enabled for X data space when XWM is set to any value other than '15' and the XMODEN bit is set at MODCON<15>.

The Y Address Space Pointer W register (YWM) to which Modulo Addressing is to be applied is stored in MODCON<7:4>. Modulo Addressing is enabled for Y data space when YWM is set to any value other than '15' and the YMODEN bit is set at MODCON<14>.

#### FIGURE 4-6: MODULO ADDRESSING OPERATION EXAMPLE



### 6.1 Reset Control Register

| REGISIE    | ROUN                                                          | RESET CO                               | VIRUL REC                      |                                 |                   |                  |               |
|------------|---------------------------------------------------------------|----------------------------------------|--------------------------------|---------------------------------|-------------------|------------------|---------------|
| R/W-0      | R/W-0                                                         | U-0                                    | U-0                            | U-0                             | U-0               | R/W-0            | R/W-0         |
| TRAP       | R IOPUWR                                                      | _                                      | _                              | _                               | _                 | СМ               | VREGS         |
| bit 15     |                                                               |                                        |                                |                                 |                   |                  | bit 8         |
| [          |                                                               |                                        |                                |                                 |                   |                  |               |
| R/W-0      | R/W-0                                                         | R/W-0                                  | R/W-0                          | R/W-0                           | R/W-0             | R/W-1            | R/W-1         |
| EXTR       | SWR                                                           | SWDTEN <sup>(2)</sup>                  | WDTO                           | SLEEP                           | IDLE              | BOR              | POR           |
| bit 7      |                                                               |                                        |                                |                                 |                   |                  | bit 0         |
| Logondi    |                                                               |                                        |                                |                                 |                   |                  |               |
| R = Read   | ahla hit                                                      | W = Writable                           | hit                            | =   Inimplei                    | mented hit read   | 1 as '0'         |               |
| -n = Value | at POR                                                        | $(1)^{2} = \text{Rit is set}$          | on                             | $0^{\circ} = \text{Bit is cle}$ | ared              | x = Ritis unki   | nown          |
|            |                                                               |                                        |                                |                                 |                   |                  | IOWIT         |
| bit 15     | TRAPR: Trap                                                   | Reset Flag bit                         |                                |                                 |                   |                  |               |
|            | 1 = A Trap C                                                  | onflict Reset ha                       | s occurred                     |                                 |                   |                  |               |
|            | 0 = A Trap Co                                                 | onflict Reset ha                       | s not occurre                  | d                               |                   |                  |               |
| bit 14     | IOPUWR: Ille                                                  | egal Opcode or                         | Uninitialized \                | N Access Res                    | et Flag bit       |                  |               |
|            | 1 = An illega                                                 | al opcode deter                        | ction, an illeg                | al address m                    | ode or uninitial  | ized W registe   | er used as an |
|            | 0 = An illega                                                 | l opcode or unit                       | nitialized W R                 | eset has not o                  | ccurred           |                  |               |
| bit 13-10  | Unimplemen                                                    | nted: Read as '                        | )'                             |                                 |                   |                  |               |
| bit 9      | CM: Configur                                                  | ration Mismatch                        | Flag bit                       |                                 |                   |                  |               |
|            | 1 = A Configu                                                 | uration Mismatc                        | h Reset has o                  | occurred                        |                   |                  |               |
|            | 0 = A Configu                                                 | uration Mismato                        | h Reset has I                  | NOT occurred                    |                   |                  |               |
| bit 8      | VREGS: Volt                                                   | age Regulator S                        | Standby Durin                  | ig Sleep bit                    |                   |                  |               |
|            | 1 = Voltage re 0 = Voltage re                                 | egulator is activ<br>equilator does ir | e during Siee<br>ito Standby m | p<br>Iode during Sle            | en                |                  |               |
| bit 7      | EXTR: Extern                                                  | nal Reset Pin (N                       | $\overline{ACLR}$ ) bit        |                                 | 500               |                  |               |
|            | 1 = A Master                                                  | Clear (pin) Res                        | set has occurr                 | ed                              |                   |                  |               |
|            | 0 = A Master                                                  | Clear (pin) Res                        | et has not oc                  | curred                          |                   |                  |               |
| bit 6      | SWR: Softwa                                                   | are Reset Flag (                       | Instruction) bi                | it                              |                   |                  |               |
|            | $1 = \mathbf{A} \text{ RESET}$ $0 = \mathbf{A} \text{ RESET}$ | instruction has                        | been execute                   | ed<br>cuted                     |                   |                  |               |
| bit 5      | SWDTEN: S                                                     | offware Enable/                        | Disable of WI                  | DT bit <sup>(2)</sup>           |                   |                  |               |
|            | 1 = WDT is e                                                  | nabled                                 |                                |                                 |                   |                  |               |
|            | 0 = WDT is d                                                  | lisabled                               |                                |                                 |                   |                  |               |
| bit 4      | WDTO: Watc                                                    | hdog Timer Tim                         | ne-out Flag bi                 | t                               |                   |                  |               |
|            | 1 = WDT time                                                  | e-out has occur                        | red                            |                                 |                   |                  |               |
| bit 3      |                                                               |                                        | curreu                         |                                 |                   |                  |               |
| DIL 3      | 1 = Device h                                                  | as been in Slee                        | n mode                         |                                 |                   |                  |               |
|            | 0 = Device ha                                                 | as not been in S                       | Bleep mode                     |                                 |                   |                  |               |
| bit 2      | IDLE: Wake-                                                   | up from Idle Fla                       | g bit                          |                                 |                   |                  |               |
|            | 1 = Device w                                                  | as in Idle mode                        |                                |                                 |                   |                  |               |
|            | 0 = Device w                                                  | as not in Idle m                       | ode                            |                                 |                   |                  |               |
| NOTE 1:    | All of the Reset sta                                          | atus bits can be<br>eset.              | set or cleared                 | a in soπware. S                 | betting one of th | ese bits in soft | ware does not |
| 2:         | If the FWDTEN Co                                              | onfiguration bit i                     | s '1' (unprogr                 | ammed), the V                   | VDT is always e   | enabled, regard  | lless of the  |
|            | SWDTEN bit settir                                             | ng.                                    | ( F - 3.                       | ,,                              |                   |                  |               |

#### 

#### 6.2 System Reset

There are two types of Reset:

- Cold Reset
- Warm Reset

A cold Reset is the result of a Power-on Reset (POR) or a Brown-out Reset (BOR). On a cold Reset, the FNOSC Configuration bits in the FOSC Configuration register select the device clock source.

A warm Reset is the result of all the other Reset sources, including the RESET instruction. On warm Reset, the device will continue to operate from the current clock source, as indicated by the Current Oscillator Selection bits (COSC<2:0>) in the Oscillator Control register (OSCCON<14:12>).

The device is kept in a Reset state until the system power supplies have stabilized at appropriate levels and the oscillator clock is ready. The sequence in which this occurs is provided in Figure 6-2.

| Oscillator Mode        | Oscillator<br>Start-up Delay | Oscillator<br>Start-up Timer | PLL Lock Time        | Total Delay                             |
|------------------------|------------------------------|------------------------------|----------------------|-----------------------------------------|
| FRC, FRCDIV16, FRCDIVN | Toscd <sup>(1)</sup>         | _                            | _                    | Toscd <sup>(1)</sup>                    |
| FRCPLL                 | Toscd <sup>(1)</sup>         | —                            | ТLОСК <sup>(3)</sup> | Toscd + Tlock <sup>(1,3)</sup>          |
| ХТ                     | Toscd <sup>(1)</sup>         | Tost <sup>(2)</sup>          | —                    | Toscd + Tost <sup>(1,2)</sup>           |
| HS                     | Toscd <sup>(1)</sup>         | Tost <sup>(2)</sup>          | —                    | Toscd + Tost <sup>(1,2)</sup>           |
| EC                     | _                            | —                            | —                    | —                                       |
| XTPLL                  | Toscd <sup>(1)</sup>         | Tost <sup>(2)</sup>          | ТLОСК <sup>(3)</sup> | TOSCD + TOST + TLOCK <sup>(1,2,3)</sup> |
| HSPLL                  | Toscd <sup>(1)</sup>         | Tost <sup>(2)</sup>          | ТLОСК <sup>(3)</sup> | TOSCD + TOST + TLOCK <sup>(1,2,3)</sup> |
| ECPLL                  | _                            | —                            | ТLОСК <sup>(3)</sup> | ТLОСК <sup>(3)</sup>                    |
| LPRC                   | Toscd <sup>(1)</sup>         | —                            | —                    | Toscd <sup>(1)</sup>                    |

**Note 1:** TOSCD = Oscillator start-up delay (1.1 μs max. for FRC, 70 μs max. for LPRC). Crystal oscillator start-up times vary with crystal characteristics, load capacitance, etc.

**2:** TOST = Oscillator Start-up Timer (OST) delay (1024 oscillator clock period). For example, TOST = 102.4 μs for a 10 MHz crystal and TOST = 32 ms for a 32 kHz crystal.

**3:** TLOCK = PLL lock time (1.5 ms nominal) if PLL is enabled.

TABLE 6-1: OSCILLATOR DELAY

#### 10.0 I/O PORTS

- Note 1: This data sheet summarizes the features of the dsPIC33FJ06GS001/101A/102A/ 202A and dsPIC33FJ09GS302 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 10. "I/O Ports" (DS70193) in the "dsPIC33F/PIC24H Family Reference Manual", which is available on the Microchip web site (www.microchip.com).
  - 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.

All of the device pins (except VDD, VSS, MCLR and OSC1/CLKI) are shared among the peripherals and the parallel I/O ports. All I/O input ports feature Schmitt Trigger inputs for improved noise immunity.

### 10.1 Parallel I/O (PIO) Ports

Generally a parallel I/O port that shares a pin with a peripheral is subservient to the peripheral. The peripheral's output buffer data and control signals are provided to a pair of multiplexers. The multiplexers select whether the peripheral or the associated port has ownership of the output data and control signals of the I/O pin. The logic also prevents "loop through", in which a port's digital output can drive the input of a peripheral that shares the same pin. Figure 10-1 shows how ports are shared with other peripherals and the associated I/O pin to which they are connected.

When a peripheral is enabled and the peripheral is actively driving an associated pin, the use of the pin as a general purpose output pin is disabled. The I/O pin can be read, but the output driver for the parallel port bit is disabled. If a peripheral is enabled, but the peripheral is not actively driving a pin, that pin can be driven by a port.

All port pins have three registers directly associated with their operation as digital I/O. The Data Direction register (TRISx) determines whether the pin is an input or an output. If the data direction bit is '1', then the pin is an input. All port pins are defined as inputs after a Reset. Reads from the latch (LATx) read the latch. Writes to the latch write the latch. Reads from the port (PORTx) read the port pins, while writes to the port pins write the latch.

Any bit and its associated data and control registers that are not valid for a particular device will be disabled. That means the corresponding LATx and TRISx registers and the port pin will read as zeros.

When a pin is shared with another peripheral or function that is defined as an input only, it is nevertheless regarded as a dedicated port because there is no other competing source of outputs.

#### 10.2 Open-Drain Configuration

In addition to the PORT, LAT and TRIS registers for data control, some digital only port pins can also be individually configured for either digital or open-drain output. This is controlled by the Open-Drain Control register, ODCx, associated with each port. Setting any of the bits configures the corresponding pin to act as an open-drain output.

The open-drain feature allows the generation of outputs higher than VDD (for example, 5V), on any desired 5V tolerant pins, by using external pull-up resistors. The maximum open-drain voltage allowed is the same as the maximum VIH specification.

Refer to the **"Pin Diagrams"** section for the available pins and their functionality.

#### 10.3 Configuring Analog Port Pins

The ADPCFG and TRIS registers control the operation of the Analog-to-Digital port pins. The port pins that are to function as analog inputs must have their corresponding TRIS bit set (input). If the TRIS bit is cleared (output), the digital output level (VOH or VOL) will be converted.

The ADPCFG register has a default value of 0x0000; therefore, all pins that share ANx functions are analog (not digital) by default.

When the PORT register is read, all pins configured as analog input channels will read as cleared (a low level).

Pins configured as digital inputs will not convert an analog input. Analog levels on any pin, defined as a digital input (including the ANx pins), can cause the input buffer to consume current that exceeds the device specifications.

#### 10.4 I/O Port Write/Read Timing

One instruction cycle is required between a port direction change or port write operation and a read operation of the same port. Typically, this instruction would be a NOP. An example is shown in Example 10-1.

#### 10.5 Input Change Notification

The Input Change Notification function of the I/O ports allows devices to generate interrupt requests to the processor in response to a Change-of-State (COS) on selected input pins. This feature can detect input Change-of-States (COS), even in Sleep mode when the clocks are disabled. Depending on the device pin count, up to 16 external signals (CNx pin) can be selected (enabled) for generating an interrupt request on a Change-of-State.

Four control registers are associated with the CN module. The CNEN1 register contains the interrupt enable control bits for each of the CN input pins. Setting any of these bits enables a CN interrupt for the corresponding pin.

Each CN pin also has a weak pull-up connected to it. The pull-ups act as a current source connected to the pin and eliminate the need for external resistors when the push button or keypad devices are connected. The pull-ups are enabled separately, using the CNPU1 register, which contains the control bits for each of the CN pins. Setting any of the control bits enables the weak pull-ups for the corresponding pins.

**Note:** Pull-ups on change notification pins should always be disabled when the port pin is configured as a digital output.

| MOV | 0xFF00, W0   | ; Configure PORTB<15:8> as inputs |
|-----|--------------|-----------------------------------|
| MOV | WO, TRISBB   | ; and PORTB<7:0> as outputs       |
| NOF | •            | ; Delay 1 cycle                   |
| BTS | S PORTB, #13 | ; Next Instruction                |

EXAMPLE 10-1: PORT WRITE/READ EXAMPLE

| Input Name                                              | Function Name | Register | Configuration<br>Bits |
|---------------------------------------------------------|---------------|----------|-----------------------|
| External Interrupt 1                                    | INT1          | RPINR0   | INT1R<5:0>            |
| External Interrupt 2                                    | INT2          | RPINR1   | INT2R<5:0>            |
| Timer1 External Clock                                   | T1CK          | RPINR2   | T1CKR<5:0>            |
| Timer2 External Clock                                   | T2CK          | RPINR3   | T2CKR<5:0>            |
| Input Capture 1                                         | IC1           | RPINR7   | IC1R<5:0>             |
| Output Compare Fault A                                  | OCFA          | RPINR11  | OCFAR<5:0>            |
| UART1 Receive                                           | U1RX          | RPINR18  | U1RXR<5:0>            |
| UART1 Clear-to-Send                                     | U1CTS         | RPINR18  | U1CTSR<5:0>           |
| SPI Data Input 1                                        | SDI1          | RPINR20  | SDI1R<5:0>            |
| SPI Clock Input 1                                       | SCK1          | RPINR20  | SCK1R<5:0>            |
| SPI Slave Select Input 1                                | SS1           | RPINR21  | SS1R<5:0>             |
| PWM Fault Input                                         | FLT1          | RPINR29  | FLT1R<5:0>            |
| PWM Fault Input                                         | FLT2          | RPINR30  | FLT2R<5:0>            |
| PWM Fault Input                                         | FLT3          | RPINR30  | FLT3R<5:0>            |
| PWM Fault Input                                         | FLT4          | RPINR31  | FLT4R<5:0>            |
| PWM Fault Input                                         | FLT5          | RPINR31  | FLT5R<5:0>            |
| PWM Fault Input                                         | FLT6          | RPINR32  | FLT6R<5:0>            |
| PWM Fault Input                                         | FLT7          | RPINR32  | FLT7R<5:0>            |
| PWM Fault Input                                         | FLT8          | RPINR33  | FLT8R<5:0>            |
| External Synchronization Signal to PWM Master Time Base | SYNCI1        | RPINR33  | SYNCI1R<5:0>          |
| External Synchronization Signal to PWM Master Time Base | SYNCI2        | RPINR34  | SYNCI2R<5:0>          |

#### TABLE 10-1: SELECTABLE INPUT SOURCES (MAPS INPUT TO FUNCTION)

### dsPIC33FJ06GS001/101A/102A/202A and dsPIC33FJ09GS302

| U-0                                                                      | U-0 | R/W-0 | R/W-0                              | R/W-0 | R/W-0                | R/W-0 | R/W-0 |  |
|--------------------------------------------------------------------------|-----|-------|------------------------------------|-------|----------------------|-------|-------|--|
| _                                                                        | _   |       |                                    | RP9R  | <5:0>(1)             |       |       |  |
| bit 15                                                                   |     |       |                                    |       |                      |       | bit 8 |  |
|                                                                          |     |       |                                    |       |                      |       |       |  |
| U-0                                                                      | U-0 | R/W-0 | R/W-0                              | R/W-0 | R/W-0                | R/W-0 | R/W-0 |  |
|                                                                          | _   |       |                                    | RP8R  | <5:0> <sup>(1)</sup> |       |       |  |
| bit 7                                                                    |     |       |                                    |       |                      |       | bit 0 |  |
|                                                                          |     |       |                                    |       |                      |       |       |  |
| Legend:                                                                  |     |       |                                    |       |                      |       |       |  |
| R = Readable bit W = Writable bit                                        |     |       | U = Unimplemented bit, read as '0' |       |                      |       |       |  |
| -n = Value at POR (1' = Bit is set (0' = Bit is cleared x = Bit is unkn) |     |       |                                    |       |                      | nown  |       |  |

#### **REGISTER 10-20: RPOR4: PERIPHERAL PIN SELECT OUTPUT REGISTER 4**

| bit 15-14 | Unimplemented: Read as '0'                                                                           |
|-----------|------------------------------------------------------------------------------------------------------|
| bit 13-8  | <b>RP9R&lt;5:0&gt;:</b> Peripheral Output Function is Assigned to RP9 Output Pin bits <sup>(1)</sup> |
|           | (see Table 10-2 for peripheral function numbers)                                                     |
| bit 7-6   | Unimplemented: Read as '0'                                                                           |
| bit 5-0   | <b>RP8R&lt;5:0&gt;:</b> Peripheral Output Function is Assigned to RP8 Output Pin bits <sup>(1)</sup> |
|           | (see Table 10-2 for peripheral function numbers)                                                     |

Note 1: These bits are not implemented in dsPIC33FJ06GS001/101A devices.

#### **REGISTER 10-21: RPOR5: PERIPHERAL PIN SELECT OUTPUT REGISTER 5**

| U-0    | U-0 | R/W-0                     | R/W-0 | R/W-0 | R/W-0                | R/W-0 | R/W-0 |  |  |
|--------|-----|---------------------------|-------|-------|----------------------|-------|-------|--|--|
| —      | —   |                           |       | RP11F | <5:0> <sup>(1)</sup> |       |       |  |  |
| bit 15 |     |                           |       |       |                      |       | bit 8 |  |  |
|        |     |                           |       |       |                      |       |       |  |  |
| U-0    | U-0 | R/W-0                     | R/W-0 | R/W-0 | R/W-0                | R/W-0 | R/W-0 |  |  |
| —      | —   | RP10R<5:0> <sup>(1)</sup> |       |       |                      |       |       |  |  |
| bit 7  |     |                           |       |       |                      |       | bit 0 |  |  |
|        |     |                           |       |       |                      |       |       |  |  |

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

bit 15-14 Unimplemented: Read as '0'

- RP11R<5:0>: Peripheral Output Function is Assigned to RP11 Output Pin bits<sup>(1)</sup> bit 13-8 (see Table 10-2 for peripheral function numbers) bit 7-6 Unimplemented: Read as '0'
- RP10R<5:0>: Peripheral Output Function is Assigned to RP10 Output Pin bits<sup>(1)</sup> bit 5-0 (see Table 10-2 for peripheral function numbers)

Note 1: These bits are not implemented in dsPIC33FJ06GS001/101A devices.

#### 15.0 HIGH-SPEED PWM

- Note 1: This data sheet summarizes the features of the dsPIC33FJ06GS001/101A/102A/ 202A and dsPIC33FJ09GS302 families of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 43. "High-Speed PWM" (DS70323) in the "dsPIC33F/ PIC24H Family Reference Manual", which is available on the Microchip web site (www.microchip.com).
  - 2: Some registers and associated bits described in this section may not be available on all devices. Refer to Section 4.0 "Memory Organization" in this data sheet for device-specific register and bit information.

The high-speed PWM module supports a wide variety of PWM modes and output formats. This PWM module is ideal for power conversion applications, such as:

- AC/DC Converters
- DC/DC Converters
- Power Factor Correction (PFC)
- Uninterruptible Power Supply (UPS)
- Inverters
- · Battery Chargers
- · Digital Lighting

#### 15.1 Features Overview

The high-speed PWM module incorporates the following features:

- Two to three PWM generators with four to six outputs
- Individual time base and duty cycle for each of the six PWM outputs
- · Dead time for rising and falling edges:
- Duty cycle resolution of 1.04 ns<sup>(1,2)</sup>
- Dead-time resolution of 1.04 ns<sup>(1,2)</sup>
- Phase-shift resolution of 1.04 ns<sup>(1,2)</sup>
- Frequency resolution of 1.04 ns<sup>(1,2)</sup>

Note 1: Resolution is 8.32 ns in Center-Aligned PWM mode.

2: Resolution is 8.32 ns for dsPIC33FJ06GS001 devices.

- Supported PWM modes:
  - Standard Edge-Aligned
  - True Independent Output
  - Complementary
  - Center-Aligned
  - Push-Pull
  - Multiphase
  - Variable Phase
  - Fixed Off Time
  - Current Reset
  - Current Limit
- Independent Fault/Current-Limit inputs for each of the six PWM outputs
- Output override control
- Special Event Trigger
- · PWM capture feature
- Prescaler for input clock
- Dual trigger from PWM to ADC
- PWMxH, PWMxL output pin swapping
- Remappable PWM4H, PWM4L pins
- On-the-fly PWM frequency, duty cycle and phase-shift changes
- Disabling of individual PWM generators to reduce power consumption
- Leading-Edge Blanking (LEB) functionality
- PWM output chopping (see Note 1)
  - **Note 1:** The chopping function performs a logical AND of the PWM outputs with a very high-frequency clock signal. The chopping frequency is typically hundreds or thousands of time higher in frequency, as compared to the PWM frequency. Chopping a PWM signal constrains the use of a pulse transformer to cross the isolation barrier.

Figure 15-1 conceptualizes the PWM module in a simplified block diagram. Figure 15-2 illustrates how the module hardware is partitioned for each PWM output pair for the Complementary PWM mode. Each functional unit of the PWM module is discussed in subsequent sections.

The PWM module contains three PWM generators. The module has up to six PWM output pins: PWM1H, PWM1L, PWM2H, PWM2L, PWM4H and PWM4L. For complementary outputs, these six I/O pins are grouped into H/L pairs.

| REGISTER 15-2: | PTCON2: PWM CLOCK DIVIDER SELECT REGISTER 2 |
|----------------|---------------------------------------------|
|----------------|---------------------------------------------|

| U-0             | U-0 | U-0              | U-0 | U-0                                | U-0                                    | U-0                       | U-0   |
|-----------------|-----|------------------|-----|------------------------------------|----------------------------------------|---------------------------|-------|
| —               | _   | _                |     | —                                  | _                                      |                           | _     |
| bit 15          |     |                  |     |                                    |                                        |                           | bit 8 |
|                 |     |                  |     |                                    |                                        |                           |       |
| U-0             | U-0 | U-0              | U-0 | U-0                                | R/W-0                                  | R/W-0                     | R/W-0 |
| —               | —   | —                | —   | —                                  | P                                      | CLKDIV<2:0> <sup>(1</sup> | )     |
| bit 7           |     |                  |     |                                    |                                        |                           | bit 0 |
|                 |     |                  |     |                                    |                                        |                           |       |
| Legend:         |     |                  |     |                                    |                                        |                           |       |
| R = Readable b  | oit | W = Writable I   | oit | U = Unimplemented bit, read as '0' |                                        |                           |       |
| -n = Value at P | OR  | '1' = Bit is set |     | '0' = Bit is cle                   | )' = Bit is cleared x = Bit is unknown |                           |       |

bit 15-3 Unimplemented: Read as '0'

- bit 2-0 PCLKDIV<2:0>: PWM Input Clock Prescaler (Divider) Select bits<sup>(1)</sup>
  - 111 = Reserved
  - 110 = Divide-by-64, maximum PWM timing resolution
  - 101 = Divide-by-32, maximum PWM timing resolution
  - 100 = Divide-by-16, maximum PWM timing resolution
  - 011 = Divide-by-8, maximum PWM timing resolution
  - 010 = Divide-by-4, maximum PWM timing resolution
  - 001 = Divide-by-2, maximum PWM timing resolution
  - 000 = Divide-by-1, maximum PWM timing resolution (power-on default)
- **Note 1:** These bits should be changed only when PTEN = 0. Changing the clock selection during operation will yield unpredictable results.

#### REGISTER 15-3: PTPER: PWM MASTER TIME BASE REGISTER<sup>(1)</sup>

| R/W-1           | R/W-1 | R/W-1            | R/W-1 | R/W-1            | R/W-1           | R/W-1           | R/W-1 |
|-----------------|-------|------------------|-------|------------------|-----------------|-----------------|-------|
|                 |       |                  | PTPEF | R <15:8>         |                 |                 |       |
| bit 15          |       |                  |       |                  |                 |                 | bit 8 |
|                 |       |                  |       |                  |                 |                 |       |
| R/W-1           | R/W-1 | R/W-1            | R/W-1 | R/W-1            | R/W-0           | R/W-0           | R/W-0 |
|                 |       |                  | PTPE  | R <7:0>          |                 |                 |       |
| bit 7           |       |                  |       |                  |                 |                 | bit 0 |
|                 |       |                  |       |                  |                 |                 |       |
| Legend:         |       |                  |       |                  |                 |                 |       |
| R = Readable    | bit   | W = Writable     | bit   | U = Unimpler     | nented bit, rea | d as '0'        |       |
| -n = Value at P | POR   | '1' = Bit is set |       | '0' = Bit is cle | ared            | x = Bit is unkr | nown  |

bit 15-0 PTPER<15:0>: PWM Master Time Base (PMTMR) Period Value bits

Note 1: The minimum value that can be loaded into the PTPER register is 0x0010 and the maximum value is 0xFFF8.

## dsPIC33FJ06GS001/101A/102A/202A and dsPIC33FJ09GS302

#### REGISTER 15-4: SEVTCMP: PWM SPECIAL EVENT COMPARE REGISTER

| R/W-0       | R/W-0 | R/W-0        | R/W-0  | R/W-0     | R/W-0 R/W-0 |     | R/W-0 |
|-------------|-------|--------------|--------|-----------|-------------|-----|-------|
|             |       |              | SEVTCN | IP <15:8> |             |     |       |
| bit 15      |       |              |        |           |             |     | bit 8 |
|             |       |              |        |           |             |     |       |
| R/W-0       | R/W-0 | R/W-0        | R/W-0  | R/W-0     | U-0         | U-0 | U-0   |
|             | SE    | EVTCMP <7:3> | >      |           | —           | —   | —     |
| bit 7       |       |              |        |           |             |     | bit 0 |
|             |       |              |        |           |             |     |       |
| I a manual. |       |              |        |           |             |     |       |

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

bit 15-3 SEVTCMP<15:3>: Special Event Compare Count Value bits bit 2-0 Unimplemented: Read as '0'

#### REGISTER 15-5: MDC: PWM MASTER DUTY CYCLE REGISTER

| R/W-0           | R/W-0 | R/W-0            | R/W-0 | R/W-0                  | R/W-0           | R/W-0           | R/W-0 |
|-----------------|-------|------------------|-------|------------------------|-----------------|-----------------|-------|
|                 |       |                  | MDC<  | 15:8> <sup>(1,2)</sup> |                 |                 |       |
| bit 15          |       |                  |       |                        |                 |                 | bit 8 |
|                 |       |                  |       |                        |                 |                 |       |
| R/W-0           | R/W-0 | R/W-0            | R/W-0 | R/W-0                  | R/W-0           | R/W-0           | R/W-0 |
|                 |       |                  | MDC   | <7:0> <sup>(1,2)</sup> |                 |                 |       |
| bit 7           |       |                  |       |                        |                 |                 | bit 0 |
|                 |       |                  |       |                        |                 |                 |       |
| Legend:         |       |                  |       |                        |                 |                 |       |
| R = Readable    | bit   | W = Writable b   | oit   | U = Unimpler           | mented bit, rea | id as '0'       |       |
| -n = Value at P | OR    | '1' = Bit is set |       | '0' = Bit is cle       | ared            | x = Bit is unkr | nown  |

bit 15-0 MDC<15:0>: Master PWM Duty Cycle Value bits<sup>(1,2)</sup>

**Note 1:** The smallest pulse width that can be generated on the PWM output corresponds to a value of 0x0009, while the maximum pulse width generated corresponds to a value of Period – 0x0008.

2: As the duty cycle gets closer to 0% or 100% of the PWM period (0 ns-40 ns, depending on the mode of operation), the PWM duty cycle resolution will degrade from 1 LSb to 3 LSbs.

## dsPIC33FJ06GS001/101A/102A/202A and dsPIC33FJ09GS302

#### REGISTER 15-16: TRIGX: PWMx PRIMARY TRIGGER COMPARE VALUE REGISTER

| R/W-0           | R/W-0 | R/W-0            | R/W-0 | R/W-0            | R/W-0            | R/W-0           | R/W-0 |
|-----------------|-------|------------------|-------|------------------|------------------|-----------------|-------|
|                 |       |                  | TRGCI | MP<15:8>         |                  |                 |       |
| bit 15          |       |                  |       |                  |                  |                 | bit 8 |
|                 |       |                  |       |                  |                  |                 |       |
| R/W-0           | R/W-0 | R/W-0            | R/W-0 | R/W-0            | U-0              | U-0             | U-0   |
|                 | Т     | RGCMP<7:3>       |       |                  | _                | —               | —     |
| bit 7           |       |                  |       |                  |                  |                 | bit 0 |
|                 |       |                  |       |                  |                  |                 |       |
| Legend:         |       |                  |       |                  |                  |                 |       |
| R = Readable    | bit   | W = Writable     | bit   | U = Unimpler     | mented bit, read | 1 as '0'        |       |
| -n = Value at P | OR    | '1' = Bit is set |       | '0' = Bit is cle | eared            | x = Bit is unki | nown  |

| bit 15-3 | TRGCMP<15:3>: Trigger Control Value bits                                                          |
|----------|---------------------------------------------------------------------------------------------------|
|          | When primary PWM functions in local time base, this register contains the compare values that can |
|          | trigger the ADC module.                                                                           |
| bit 2-0  | Unimplemented: Read as '0'                                                                        |

#### REGISTER 15-17: STRIGX: PWMx SECONDARY TRIGGER COMPARE VALUE REGISTER

| R/W-0            | R/W-0 | R/W-0          | R/W-0 | R/W-0         | R/W-0           | R/W-0    | R/W-0 |
|------------------|-------|----------------|-------|---------------|-----------------|----------|-------|
|                  |       |                | STRGC | CMP<15:8>     |                 |          |       |
| bit 15           |       |                |       |               |                 |          | bit 8 |
|                  |       |                |       |               |                 |          |       |
| R/W-0            | R/W-0 | R/W-0          | R/W-0 | R/W-0         | U-0             | U-0      | U-0   |
|                  | ST    | FRGCMP<7:3>    |       |               | —               | —        | —     |
| bit 7            |       |                |       |               |                 |          | bit 0 |
|                  |       |                |       |               |                 |          |       |
| Legend:          |       |                |       |               |                 |          |       |
| R = Readable bit |       | W = Writable k | nit   | LL = LInimple | mented hit read | l as '0' |       |

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

 bit 15-3
 STRGCMP<15:3>: Secondary Trigger Control Value bits

 When secondary PWM functions in local time base, this register contains the compare values that can trigger the ADC module.

 bit 2-0
 Unimplemented: Read as '0'

#### 22.5 JTAG Interface

A JTAG interface is implemented, which supports boundary scan device testing, as well as in-circuit programming. Detailed information on this interface will be provided in future revisions of this document.

#### 22.6 In-Circuit Serial Programming

dsPIC33FJ06GS001/101A/102A/202A The and dsPIC33FJ09GS302 family of digital signal controllers can be serially programmed while in the end application circuit. This is done with two lines for clock and data, and three other lines for power, ground and the programming sequence. Serial programming allows customers to manufacture boards with unprogrammed devices and then program the digital signal controller just before shipping the product. Serial programming also allows the most recent firmware or a custom firmware to be programmed. Refer to the "dsPIC33F/PIC24H Flash Programming Specification" (DS70152) for details about In-Circuit Serial Programming (ICSP<sup>™</sup>).

Any of the three pairs of programming clock/data pins can be used:

- PGEC1 and PGED1
- PGEC2 and PGED2
- · PGEC3 and PGED3

#### 22.7 In-Circuit Debugger

The dsPIC33FJ06GS001/101A/102A/202A and dsPIC33FJ09GS302 devices provide simple debugging functionality through the PGECx (Emulation/ Debug Clock) and PGEDx (Emulation/Debug Data) pin functions.

Any of the three pairs of debugging clock/data pins can be used:

- PGEC1 and PGED1
- PGEC2 and PGED2
- · PGEC3 and PGED3

To use the in-circuit debugger function of the device, the design must implement ICSP connections to  $\overline{MCLR}$ , VDD, Vss and the PGECx/PGEDx pin pair. In addition, when the feature is enabled, some of the resources are not available for general use. These resources include the first 80 bytes of data RAM and two I/O pins.

| АС СНА | RACTER  | ISTICS           |                           | Standard Operation<br>(unless otherwise<br>Operating temperation | ng Condi<br>e stated)<br>ature -40<br>-40 | itions: 3.0<br>)°C ≤ Ta ≤<br>)°C ≤ Ta ≤ | <b>IV to 3.6V</b><br>+85°C for Industrial<br>+125°C for Extended |
|--------|---------|------------------|---------------------------|------------------------------------------------------------------|-------------------------------------------|-----------------------------------------|------------------------------------------------------------------|
| Param. | Symbol  | Charac           | teristic                  | Min. <sup>(1)</sup>                                              | Max.                                      | Units                                   | Conditions                                                       |
| IM10   | TLO:SCL | Clock Low Time   | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | μs                                      |                                                                  |
|        |         |                  | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | —                                         | μS                                      |                                                                  |
| IM11   | THI:SCL | Clock High Time  | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | μS                                      |                                                                  |
|        |         |                  | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | μS                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | —                                         | μs                                      |                                                                  |
| IM20   | TF:SCL  | SDA1 and SCL1    | 100 kHz mode              | —                                                                | 300                                       | ns                                      | CB is specified to be                                            |
|        |         | Fall Time        | 400 kHz mode              | 20 + 0.1 Св                                                      | 300                                       | ns                                      | from 10 pF to 400 pF                                             |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | _                                                                | 100                                       | ns                                      |                                                                  |
| IM21   | TR:SCL  | SDA1 and SCL1    | 100 kHz mode              | _                                                                | 1000                                      | ns                                      | CB is specified to be                                            |
|        |         | Rise Time        | 400 kHz mode              | 20 + 0.1 Св                                                      | 300                                       | ns                                      | from 10 pF to 400 pF                                             |
|        |         |                  | 1 MHz mode <sup>(2)</sup> |                                                                  | 300                                       | ns                                      |                                                                  |
| IM25   | TSU:DAT | Data Input       | 100 kHz mode              | 250                                                              | _                                         | ns                                      |                                                                  |
|        |         | Setup Time       | 400 kHz mode              | 100                                                              | _                                         | ns                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | 40                                                               | _                                         | ns                                      |                                                                  |
| IM26   | THD:DAT | Data Input       | 100 kHz mode              | 0                                                                | _                                         | μs                                      |                                                                  |
|        |         | Hold Time        | 400 kHz mode              | 0                                                                | 0.9                                       | μS                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | 0.2                                                              | _                                         | μS                                      |                                                                  |
| IM30   | TSU:STA | Start Condition  | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      | Only relevant for                                                |
|        |         | Setup Time       | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | μS                                      | Repeated Start                                                   |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | —                                         | μS                                      | condition                                                        |
| IM31   | THD:STA | Start Condition  | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      | After this period the                                            |
|        |         | Hold Time        | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      | first clock pulse is                                             |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      | generated                                                        |
| IM33   | Tsu:sto | Stop Condition   | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | μs                                      |                                                                  |
|        |         | Setup Time       | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | _                                         | μS                                      |                                                                  |
| IM34   | THD:STO | Stop Condition   | 100 kHz mode              | Tcy/2 (BRG + 1)                                                  | —                                         | ns                                      |                                                                  |
|        |         | Hold Time        | 400 kHz mode              | Tcy/2 (BRG + 1)                                                  | _                                         | ns                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                  | _                                         | ns                                      |                                                                  |
| IM40   | TAA:SCL | Output Valid     | 100 kHz mode              |                                                                  | 3500                                      | ns                                      |                                                                  |
|        |         | From Clock       | 400 kHz mode              | _                                                                | 1000                                      | ns                                      |                                                                  |
|        |         |                  | 1 MHz mode <sup>(2)</sup> |                                                                  | 400                                       | ns                                      |                                                                  |
| IM45   | TBF:SDA | Bus Free Time    | 100 kHz mode              | 4.7                                                              | —                                         | μS                                      | Time the bus must be                                             |
|        |         |                  | 400 kHz mode              | 1.3                                                              | _                                         | μS                                      | free before a new                                                |
|        |         |                  | 1 MHz mode <sup>(2)</sup> | 0.5                                                              | _                                         | μS                                      | transmission can start                                           |
| IM50   | Св      | Bus Capacitive L | oading                    | —                                                                | 400                                       | pF                                      |                                                                  |
| IM51   | TPGD    | Pulse Gobbler De | elay                      | 65                                                               | 390                                       | ns                                      | See Note 3                                                       |

#### TABLE 25-37: I2C1 BUS DATA TIMING REQUIREMENTS (MASTER MODE)

Note 1: BRG is the value of the I<sup>2</sup>C<sup>™</sup> Baud Rate Generator. Refer to Section 19. "Inter-Integrated Circuit (I<sup>2</sup>C<sup>™</sup>)" (DS70195) in the "dsPIC33F/PIC24H Family Reference Manual".

2: Maximum pin capacitance = 10 pF for all I2C1 pins (for 1 MHz mode only).

**3:** Typical value for this parameter is 130 ns.

| AC CHARACTERISTICS <sup>(2)</sup> |                                               |                                | Standard<br>(unless<br>Operatin | d Operatin<br>otherwise<br>g temperat | <b>ig Condit</b><br>stated)<br>ture -4<br>-4 | ions: 3.0<br>0°C ≤ TA<br>0°C ≤ TA | <b>0V and 3.6V</b><br>≤ +85°C for Industrial<br>≤ +125°C for Extended |
|-----------------------------------|-----------------------------------------------|--------------------------------|---------------------------------|---------------------------------------|----------------------------------------------|-----------------------------------|-----------------------------------------------------------------------|
| Param.                            | Param. Symbol Characteristic Min. Typ. Max. U |                                |                                 |                                       |                                              |                                   | Conditions                                                            |
|                                   |                                               | Dyr                            | namic Per                       | formance                              |                                              |                                   |                                                                       |
| AD30                              | THD                                           | Total Harmonic Distortion      | —                               | -73                                   |                                              | dB                                |                                                                       |
| AD31                              | SINAD                                         | Signal to Noise and Distortion | —                               | 58                                    |                                              | dB                                |                                                                       |
| AD32                              | SFDR                                          | Spurious Free Dynamic Range    | —                               | -73                                   |                                              | dB                                |                                                                       |
| AD33                              | Fnyq                                          | Input Signal Bandwidth         | —                               | —                                     | 1                                            | MHz                               |                                                                       |
| AD34                              | ENOB                                          | Effective Number of Bits       | _                               | 9.4                                   | _                                            | bits                              |                                                                       |

#### TABLE 25-39: 10-BIT HIGH-SPEED ADC MODULE SPECIFICATIONS (CONTINUED)

Note 1: The Analog-to-Digital conversion result never decreases with an increase in input voltage and has no missing codes.

2: Overall functional device operation at VBORMIN < VDD < VDDMIN is tested but not characterized. All device analog modules, such as the ADC, etc., will function, but with degraded performance below VDDMIN. Refer to Parameter BO10 in Table 25-11 for BOR values.

3: These parameters are characterized by similarity, but are not tested in manufacturing.

#### TABLE 25-40: 10-BIT HIGH-SPEED ADC MODULE TIMING REQUIREMENTS

|                   |        |                                                          | $\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.            | Symbol | Characteristic                                           | Min.                                                                                                                                                                                                                                                                                  | Typ. <sup>(1)</sup> | Max. | Units | Conditions |
| Clock Parameters  |        |                                                          |                                                                                                                                                                                                                                                                                       |                     |      |       |            |
| AD50b             | TAD    | ADC Clock Period                                         | 35.8                                                                                                                                                                                                                                                                                  | —                   | _    | ns    |            |
| Conversion Rate   |        |                                                          |                                                                                                                                                                                                                                                                                       |                     |      |       |            |
| AD55b             | tconv  | Conversion Time                                          | —                                                                                                                                                                                                                                                                                     | 14 Tad              | —    | —     |            |
| AD56b             | FCNV   | Throughput Rate                                          |                                                                                                                                                                                                                                                                                       |                     |      |       |            |
|                   |        | Devices with Single SAR                                  | _                                                                                                                                                                                                                                                                                     | —                   | 2.0  | Msps  |            |
| Timing Parameters |        |                                                          |                                                                                                                                                                                                                                                                                       |                     |      |       |            |
| AD63b             | tdpu   | Time to Stabilize Analog Stage<br>from ADC Off to ADC On | 1.0                                                                                                                                                                                                                                                                                   |                     | 10   | μS    |            |

Note 1: These parameters are characterized but not tested in manufacturing.

#### FIGURE 25-23: ANALOG-TO-DIGITAL CONVERSION TIMING PER INPUT



#### 18-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

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



Microchip Technology Drawing C04-051C Sheet 1 of 2

#### 28-Lead Plastic Small Outline (SO) - Wide, 7.50 mm Body [SOIC]

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







Microchip Technology Drawing C04-052C Sheet 1 of 2

# 28-Lead Plastic Quad Flat, No Lead Package (MM) - 6x6x0.9mm Body [QFN-S] With 0.40 mm Terminal Length

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



Microchip Technology Drawing C04-124C Sheet 1 of 2