

#### 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

E·XFI

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

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

### dsPIC33FJ12GP201/202 Product Families

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

|                  |      | ory                           |                |                    | Ren              | nappa         | ble Per                    | ipher | als                                |     |                   |                                |                |                              |
|------------------|------|-------------------------------|----------------|--------------------|------------------|---------------|----------------------------|-------|------------------------------------|-----|-------------------|--------------------------------|----------------|------------------------------|
| Device           | Pins | Program Flash Memo<br>(Kbyte) | RAM<br>(Kbyte) | Remappable<br>Pins | 16-bit Timer     | Input Capture | Output Compare<br>Std. PWM | UART  | External Interrupts <sup>(2)</sup> | SPI | 10-Bit/12-Bit ADC | I <sup>2</sup> C <sup>TM</sup> | I/O Pins (Max) | Packages                     |
| dsPIC33FJ12GP201 | 18   | 12                            | 1              | 8                  | 3 <sup>(1)</sup> | 4             | 2                          | 1     | 3                                  | 1   | 1 ADC,<br>6 ch    | 1                              | 13             | PDIP<br>SOIC                 |
| dsPIC33FJ12GP202 | 28   | 12                            | 1              | 16                 | 3 <sup>(1)</sup> | 4             | 2                          | 1     | 3                                  | 1   | 1 ADC,<br>10 ch   | 1                              | 21             | SPDIP<br>SOIC<br>SSOP<br>QFN |

## TABLE 1: dsPIC33FJ12GP201/202 CONTROLLER FAMILIES

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

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

### **Pin Diagrams**



### 3.6.2.4 Data Space Write Saturation

In addition to adder/subtracter saturation, writes to data space can also be saturated, but without affecting the contents of the source accumulator. The data space write saturation logic block accepts a 16-bit, 1.15 fractional value from the round logic block as its input, together with overflow status from the original source (accumulator) and the 16-bit round adder. These inputs are combined and used to select the appropriate 1.15 fractional value as output to write to data space memory.

If the SATDW bit in the CORCON register is set, data (after rounding or truncation) is tested for overflow and adjusted accordingly:

- For input data greater than 0x007FFF, data written to memory is forced to the maximum positive 1.15 value, 0x7FFF
- For input data less than 0xFF8000, data written to memory is forced to the maximum negative 1.15 value, 0x8000

The MSb of the source (bit 39) is used to determine the sign of the operand being tested.

If the SATDW bit in the CORCON register is not set, the input data is always passed through unmodified under all conditions.

## 3.6.3 BARREL SHIFTER

The barrel shifter can perform up to 16-bit arithmetic or logic right shifts, or up to 16-bit left shifts in a single cycle. The source can be either of the two DSP accumulators or the X bus (to support multi-bit shifts of register or memory data).

The shifter requires a signed binary value to determine both the magnitude (number of bits) and direction of the shift operation. A positive value shifts the operand right. A negative value shifts the operand left. A value of '0' does not modify the operand.

The barrel shifter is 40 bits wide, thereby obtaining a 40-bit result for DSP shift operations and a 16-bit result for MCU shift operations. Data from the X bus is presented to the barrel shifter between bit positions 16 and 31 for right shifts, and between bit positions 0 and 16 for left shifts.

NOTES:

#### TABLE 4-16: PORTA REGISTER MAP

| File Name | 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 |
|-----------|------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|--------|--------|--------|--------|--------|---------------|
| TRISA     | 02C0 | -      | -      | -      | -      | -      | —      | _     | -     | —     | -     | _     | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 001F          |
| PORTA     | 02C2 | _      | _      | _      | _      | _      | _      | _     | _     | _     | _     | _     | RA4    | RA3    | RA2    | RA1    | RA0    | xxxx          |
| LATA      | 02C4 | _      | _      | _      | _      | _      | _      | _     | _     | _     | _     | _     | LATA4  | LATA3  | LATA2  | LATA1  | LATA0  | xxxx          |
| ODCA      | 02C6 | _      | _      | _      | -      | —      | —      |       |       |       | _     | —     | ODCA4  | ODCA3  | ODCA2  | ODCA1  | ODCA0  | 0000          |

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

#### TABLE 4-17: PORTB REGISTER MAP FOR dsPIC33FJ12GP202

| File Name | 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 |
|-----------|------|---------|---------|---------|---------|---------|---------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------------|
| TRISB     | 02C8 | TRISB15 | TRISB14 | TRISB13 | TRISB12 | TRISB11 | TRISB10 | TRISB9 | TRISB8 | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | FFFF          |
| PORTB     | 02CA | RB15    | RB14    | RB13    | RB12    | RB11    | RB10    | RB9    | RB8    | RB7    | RB6    | RB5    | RB4    | RB3    | RB2    | RB1    | RB0    | xxxx          |
| LATB      | 02CC | LATB15  | LATB14  | LATB13  | LATB12  | LATB11  | LATB10  | LATB9  | LATB8  | LATB7  | LATB6  | LATB5  | LATB4  | LATB3  | LATB2  | LATB1  | LATB0  | xxxx          |
| ODCB      | 02CE | ODCB15  | ODCB14  | ODCB13  | ODCB12  | ODCB11  | ODCB10  | ODCB9  | ODCB8  | ODCB7  | ODCB6  | ODCB5  | ODCB4  | ODCB3  | ODCB2  | ODCB1  | ODCB0  | 0000          |

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

### TABLE 4-18: PORTB REGISTER MAP FOR dsPIC33FJ12GP201

| File Name | 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 |
|-----------|------|---------|---------|--------|--------|--------|--------|--------|--------|--------|-------|-------|--------|-------|-------|--------|--------|---------------|
| TRISB     | 02C8 | TRISB15 | TRISB14 | _      | —      | —      | —      | TRISB9 | TRISB8 | TRISB7 | —     | —     | TRISB4 | _     | _     | TRISB1 | TRISB0 | C393          |
| PORTB     | 02CA | RB15    | RB14    | _      | _      | _      | _      | RB9    | RB8    | RB7    | _     | _     | RB4    | _     | _     | RB1    | RB0    | xxxx          |
| LATB      | 02CC | LATB15  | LATB14  | _      | _      | _      | _      | LATB9  | LATB8  | LATB7  | _     | _     | LATB4  | _     | _     | LATB1  | LATB0  | xxxx          |
| ODCB      | 02CE | ODCB15  | ODCB14  | _      | _      | _      | _      | ODCB9  | ODCB8  | ODCB7  | _     | _     | ODCB4  | _     | -     | ODCB1  | ODCB0  | 0000          |

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

#### TABLE 4-19: SYSTEM CONTROL REGISTER MAP

| File Name | 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       |
|-----------|------|--------|--------|-----------|--------|--------|-----------------|-----------|-------|---------|----------------------------|--------|-------|-------|----------------|---------|-------|---------------------|
| RCON      | 0740 | TRAPR  | IOPUWR | —         | —      | —      | —               | СМ        | VREGS | EXTR    | SWR                        | SWDTEN | WDTO  | SLEEP | IDLE           | BOR     | POR   | xxxx(1)             |
| OSCCON    | 0742 | _      | (      | COSC<2:0> | >      | _      | 1               | NOSC<2:0  | >     | CLKLOCK | IOLOCK                     | LOCK   | _     | CF    | —              | LPOSCEN | OSWEN | <sub>0300</sub> (2) |
| CLKDIV    | 0744 | ROI    |        | DOZE<2:0> | >      | DOZEN  | F               | RCDIV<2:0 | )>    | PLLPOS  | PLLPOST<1:0> — PLLPRE<4:0> |        |       |       |                |         |       | 3040                |
| PLLFBD    | 0746 | _      | —      | _         | —      | _      | — — PLLDIV<8:0> |           |       |         |                            |        | 0030  |       |                |         |       |                     |
| OSCTUN    | 0748 | _      | _      | _         | _      | _      | _               | _         | _     | _       | _                          |        |       | TUN   | <b>\</b> <5:0> |         |       | 0000                |

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

Note 1: RCON register Reset values dependent on the type of Reset.

2: OSCCON register Reset values dependent on the FOSC Configuration bits and by the type of Reset.

#### 4.6.3 READING DATA FROM PROGRAM MEMORY USING PROGRAM SPACE VISIBILITY

The upper 32 Kbytes of data space may optionally be mapped into any 16K word page of the program space. This option provides transparent access to stored constant data from the data space without the need to use special instructions (such as TBLRDL or TBLRDH).

Program space access through the data space occurs if the MSb of the data space EA is '1' and program space visibility is enabled by setting the PSV bit in the Core Control register (CORCON<2>). The location of the program memory space to be mapped into the data space is determined by the Program Space Visibility Page register (PSVPAG). This 8-bit register defines any one of 256 possible pages of 16K words in program space. In effect, PSVPAG functions as the upper 8 bits of the program memory address, with the 15 bits of the EA functioning as the lower bits. By incrementing the PC by 2 for each program memory word, the lower 15 bits of data space addresses directly map to the lower 15 bits in the corresponding program space addresses.

Data reads to this area add a cycle to the instruction being executed, since two program memory fetches are required.

Although each data space address 0x8000 and higher maps directly into a corresponding program memory address (see Figure 4-9), only the lower 16 bits of the

24-bit program word are used to contain the data. The upper 8 bits of any program space location used as data should be programmed with '1111 1111' or '0000 0000' to force a NOP. This prevents possible issues should the area of code ever be accidentally executed.

## Note: PSV access is temporarily disabled during table reads/writes.

For operations that use PSV and are executed outside a REPEAT loop, the MOV and MOV.D instructions require one instruction cycle in addition to the specified execution time. All other instructions require two instruction cycles in addition to the specified execution time.

For operations that use PSV, and are executed inside a REPEAT loop, these instances require two instruction cycles in addition to the specified execution time of the instruction:

- · Execution in the first iteration
- · Execution in the last iteration
- Execution prior to exiting the loop due to an interrupt
- Execution upon re-entering the loop after an interrupt is serviced

Any other iteration of the REPEAT loop will allow the instruction using PSV to access data to execute in a single cycle.

## FIGURE 4-9: PROGRAM SPACE VISIBILITY OPERATION



NOTES:

## 5.0 FLASH PROGRAM MEMORY

- Note 1: This data sheet summarizes the features of the dsPIC33FJ12GP201/202 family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to Section 5. "Flash Programming" (DS70191) of the "dsPIC33F/PIC24H Family Reference Manual", which is available from the Microchip website (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 dsPIC33FJ12GP201/202 devices contain internal Flash program memory for storing and executing application code. The memory is readable, writable, and erasable during normal operation over the entire VDD range.

Flash memory can be programmed in two ways:

- In-Circuit Serial Programming™ (ICSP™) programming capability
- Run-Time Self-Programming (RTSP)

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

RTSP is accomplished using TBLRD (table read) and TBLWT (table write) instructions. With RTSP, the user application can write program memory data either in blocks or 'rows' of 64 instructions (192 bytes) or a single program memory word, and erase program memory in blocks or 'pages' of 512 instructions (1536 bytes).

## 5.1 Table Instructions and Flash Programming

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

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

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

#### FIGURE 5-1: ADDRESSING FOR TABLE REGISTERS



| TABLE 10-2: OUT | PUT SELECTION FOR REMAPPABLE PIN (RPn) |
|-----------------|----------------------------------------|
|-----------------|----------------------------------------|

| Function | RPnR<4:0> | Output Name                          |
|----------|-----------|--------------------------------------|
| NULL     | 00000     | RPn tied to default port pin         |
| U1TX     | 00011     | RPn tied to UART1 Transmit           |
| U1RTS    | 00100     | RPn tied to UART1 Ready To Send      |
| SDO1     | 00111     | RPn tied to SPI1 Data Output         |
| SCK1OUT  | 01000     | RPn tied to SPI1 Clock Output        |
| SS1OUT   | 01001     | RPn tied to SPI1 Slave Select Output |
| OC1      | 10010     | RPn tied to Output Compare 1         |
| OC2      | 10011     | RPn tied to Output Compare 2         |

## 10.4.3 CONTROLLING CONFIGURATION CHANGES

Because peripheral remapping can be changed during run time, some restrictions on peripheral remapping are needed to prevent accidental configuration changes. dsPIC33FJ12GP201/202 devices include three features to prevent alterations to the peripheral map:

- Control register lock sequence
- · Continuous state monitoring
- Configuration bit pin select lock

### 10.4.3.1 Control Register Lock

Under normal operation, writes to the RPINRx and RPORx registers are not allowed. Attempted writes appear to execute normally, but the contents of the registers remain unchanged. To change these registers, they must be unlocked in hardware. The register lock is controlled by the IOLOCK bit (OSCCON<6>). Setting the IOLOCK bit prevents writes to the control registers; clearing the IOLOCK bit allows writes.

To set or clear the IOLOCK bit, a specific command sequence must be executed:

- 1. Write 0x46 to OSCCON<7:0>.
- 2. Write 0x57 to OSCCON<7:0>.
- 3. Clear (or set) the IOLOCK bit as a single operation.

| Note: | MPLAB <sup>®</sup> C30 provides built-in C                   |
|-------|--------------------------------------------------------------|
|       | language functions for unlocking the<br>OSCCON register:     |
|       | builtin_write_OSCCONL(value)<br>builtin_write_OSCCONH(value) |
|       | See the MPLAB IDE help files for more information.           |

Unlike the similar sequence with the oscillator's LOCK bit, IOLOCK remains in one state until changed. This allows all of the peripheral pin selects to be configured

with a single unlock sequence followed by an update to all control registers, then locked with a second lock sequence.

#### 10.4.3.2 Continuous State Monitoring

In addition to being protected from direct writes, the contents of the RPINRx and RPORx registers are constantly monitored in hardware by shadow registers. If an unexpected change in any of the registers occurs (such as cell disturbances caused by ESD or other external events), a configuration mismatch Reset will be triggered.

#### 10.4.3.3 Configuration Bit Pin Select Lock

As an additional level of safety, the device can be configured to prevent more than one write session to the RPINRx and RPORx registers. The IOL1WAY (FOSC<5>) configuration bit blocks the IOLOCK bit from being cleared after it has been set once.

In the default (unprogrammed) state, the IOL1WAY bit is set, restricting users to one write session. Programming IOL1WAY allows user applications unlimited access (with the proper use of the unlock sequence) to the peripheral pin select registers.

#### **10.5** Peripheral Pin Select Registers

The dsPIC33FJ12GP201/202 devices implement 17 registers for remappable peripheral configuration:

- Input Remappable Peripheral Registers (9)
- Output Remappable Peripheral Registers (8)

Note: Input and Output register values can only be changed if the IOLOCK bit (OSCCON<6>) = 0. See Section 10.4.3.1 "Control Register Lock" for a specific command sequence.

## 14.2 Output Compare Register

## REGISTER 14-1: OCxCON: OUTPUT COMPARE x CONTROL REGISTER

| U-0    | U-0 | R/W-0  | U-0    | U-0    | U-0   | U-0      | U-0   |
|--------|-----|--------|--------|--------|-------|----------|-------|
| —      | _   | OCSIDL | —      | —      | _     | —        | —     |
| bit 15 |     |        |        |        |       |          | bit 8 |
|        |     |        |        |        |       |          |       |
| U-0    | U-0 | U-0    | R-0 HC | R/W-0  | R/W-0 | R/W-0    | R/W-0 |
| —      | —   | —      | OCFLT  | OCTSEL |       | OCM<2:0> |       |
| bit 7  |     |        |        |        |       |          | bit 0 |
|        |     |        |        |        |       |          |       |

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

| bit 15-14 | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 13    | OCSIDL: Stop Output Compare in Idle Mode Control bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|           | <ul> <li>1 = Output Compare x will halt in CPU Idle mode</li> <li>0 = Output Compare x will continue to operate in CPU Idle mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                         |
| bit 12-5  | Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bit 4     | OCFLT: PWM Fault Condition Status bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|           | <ul> <li>1 = PWM Fault condition has occurred (cleared in hardware only)</li> <li>0 = No PWM Fault condition has occurred</li> <li>(This bit is only used when OCM&lt;2:0&gt; = 111.)</li> </ul>                                                                                                                                                                                                                                                                                                                                    |
| bit 3     | OCTSEL: Output Compare Timer Select bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|           | <ul><li>1 = Timer3 is the clock source for Compare x</li><li>0 = Timer2 is the clock source for Compare x</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| bit 2-0   | OCM<2:0>: Output Compare Mode Select bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | <ul> <li>111 = PWM mode on OCx, Fault pin enabled</li> <li>110 = PWM mode on OCx, Fault pin disabled</li> <li>101 = Initialize OCx pin low, generate continuous output pulses on OCx pin</li> <li>100 = Initialize OCx pin low, generate single output pulse on OCx pin</li> <li>011 = Compare event toggles OCx pin</li> <li>010 = Initialize OCx pin high, compare event forces OCx pin low</li> <li>001 = Initialize OCx pin low, compare event forces OCx pin high</li> <li>000 = Output compare channel is disabled</li> </ul> |

## REGISTER 18-6: AD1CSSL: ADC1 INPUT SCAN SELECT REGISTER LOW<sup>(1,2)</sup>

| U-0     | U-0   | U-0   | U-0   | U-0   | U-0   | R/W-0 | R/W-0 |
|---------|-------|-------|-------|-------|-------|-------|-------|
|         |       |       | —     |       |       | CSS9  | CSS8  |
| 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 |
| CSS7    | CSS6  | CSS5  | CSS4  | CSS3  | CSS2  | CSS1  | CSS0  |
| bit 7   |       |       | •     |       |       |       | bit 0 |
|         |       |       |       |       |       |       |       |
| Legend: |       |       |       |       |       |       |       |

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

bit 15-10 Unimplemented: Read as '0'

bit 9-0 CSS<9:0>: ADC Input Scan Selection bits

1 = Select ANx for input scan

0 = Skip ANx for input scan

**2:** CSSx = ANx, where x = 0 through 9.

## REGISTER 18-7: AD1PCFGL: ADC1 PORT CONFIGURATION REGISTER LOW<sup>(1,2,3)</sup>

| U-0     | U-0   | U-0   | U-0   | U-0   | U-0   | R/W-0 | R/W-0 |
|---------|-------|-------|-------|-------|-------|-------|-------|
|         | _     | —     | —     | _     | —     | PCFG9 | PCFG8 |
| 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 |
| PCFG7   | PCFG6 | PCFG5 | PCFG4 | PCFG3 | PCFG2 | PCFG1 | PCFG0 |
| bit 7   |       | •     |       |       |       |       | bit 0 |
|         |       |       |       |       |       |       |       |
| Legend: |       |       |       |       |       |       |       |

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

bit 15-10 Unimplemented: Read as '0'

bit 9-0

PCFG<9:0>: ADC Port Configuration Control bits

1 = Port pin in Digital mode, port read input enabled, ADC input multiplexer connected to AVss 0 = Port pin in Analog mode, port read input disabled, ADC samples pin voltage

#### Note 1: On devices without 10 analog inputs, all PCFG bits are R/W by user. However, PCFG bits are ignored on ports without a corresponding input on device.

- **2:** PCFGx = ANx, where x = 0 through 9.
- 3: PCFGx bits have no effect if the ADC module is disabled by setting the ADxMD bit in the PMDx register. When that bit is set, all port pins that have been multiplexed with ANx will be in Digital mode.

Note 1: On devices without 10 analog inputs, all AD1CSSL bits can be selected by user application. However, inputs selected for scan without a corresponding input on device converts VREFL.

| Base<br>Instr<br># | Assembly<br>Mnemonic |                   | Assembly Syntax                     | Description                                                    | # of<br>Words | # of<br>Cycles | Status Flags<br>Affected |
|--------------------|----------------------|-------------------|-------------------------------------|----------------------------------------------------------------|---------------|----------------|--------------------------|
| 48                 | MPY                  | MPY<br>Wm*Wn,Ac   | cc,Wx,Wxd,Wy,Wyd                    | Multiply Wm by Wn to Accumulator                               | 1             | 1              | OA,OB,OAB,<br>SA,SB,SAB  |
|                    |                      | MPY<br>Wm*Wm,Ac   | cc,Wx,Wxd,Wy,Wyd                    | Square Wm to Accumulator                                       | 1             | 1              | OA,OB,OAB,<br>SA,SB,SAB  |
| 49                 | MPY.N                | MPY.N<br>Wm*Wn,Ac | cc,Wx,Wxd,Wy,Wyd                    | -(Multiply Wm by Wn) to Accumulator                            | 1             | 1              | None                     |
| 50                 | MSC                  | MSC               | Wm*Wm,Acc,Wx,Wxd,Wy,Wyd<br>,<br>AWB | Multiply and Subtract from Accumulator                         | 1             | 1              | OA,OB,OAB,<br>SA,SB,SAB  |
| 51                 | MUL                  | MUL.SS            | Wb,Ws,Wnd                           | {Wnd + 1, Wnd} = signed(Wb) * signed(Ws)                       | 1             | 1              | None                     |
|                    |                      | MUL.SU            | Wb,Ws,Wnd                           | {Wnd + 1, Wnd} = signed(Wb) * unsigned(Ws)                     | 1             | 1              | None                     |
|                    |                      | MUL.US            | Wb,Ws,Wnd                           | {Wnd + 1, Wnd} = unsigned(Wb) * signed(Ws)                     | 1             | 1              | None                     |
|                    |                      | MUL.UU            | Wb,Ws,Wnd                           | {Wnd + 1, Wnd} = unsigned(Wb) *<br>unsigned(Ws)                | 1             | 1              | None                     |
|                    |                      | MUL.SU            | Wb,#lit5,Wnd                        | {Wnd + 1, Wnd} = signed(Wb) * unsigned(lit5)                   | 1             | 1              | None                     |
|                    |                      | MUL.UU            | Wb,#lit5,Wnd                        | {Wnd + 1, Wnd} = unsigned(Wb) *<br>unsigned(lit5)              | 1             | 1              | None                     |
|                    |                      | MUL               | f                                   | W3:W2 = f * WREG                                               | 1             | 1              | None                     |
| 52                 | NEG                  | NEG               | Acc                                 | Negate Accumulator                                             | 1             | 1              | OA,OB,OAB,<br>SA,SB,SAB  |
|                    |                      | NEG               | f                                   | $f = \overline{f} + 1$                                         | 1             | 1              | C,DC,N,OV,Z              |
|                    |                      | NEG               | f,WREG                              | WREG = $\overline{f}$ + 1                                      | 1             | 1              | C,DC,N,OV,Z              |
|                    |                      | NEG               | Ws,Wd                               | $Wd = \overline{Ws} + 1$                                       | 1             | 1              | C,DC,N,OV,Z              |
| 53                 | NOP                  | NOP               |                                     | No Operation                                                   | 1             | 1              | None                     |
|                    |                      | NOPR              |                                     | No Operation                                                   | 1             | 1              | None                     |
| 54                 | POP                  | POP               | f                                   | Pop f from Top-of-Stack (TOS)                                  | 1             | 1              | None                     |
|                    |                      | POP               | Wdo                                 | Pop from Top-of-Stack (TOS) to Wdo                             | 1             | 1              | None                     |
|                    |                      | POP.D             | Wnd                                 | Pop from Top-of-Stack (TOS) to<br>W(nd):W(nd + 1)              | 1             | 2              | None                     |
|                    |                      | POP.S             |                                     | Pop Shadow Registers                                           | 1             | 1              | All                      |
| 55                 | PUSH                 | PUSH              | f                                   | Push f to Top-of-Stack (TOS)                                   | 1             | 1              | None                     |
|                    |                      | PUSH              | Wso                                 | Push Wso to Top-of-Stack (TOS)                                 | 1             | 1              | None                     |
|                    |                      | PUSH.D            | Wns                                 | Push W(ns):W(ns + 1) to Top-of-Stack (TOS)                     | 1             | 2              | None                     |
|                    |                      | PUSH.S            |                                     | Push Shadow Registers                                          | 1             | 1              | None                     |
| 56                 | PWRSAV               | PWRSAV            | #lit1                               | Go into Sleep or Idle mode                                     | 1             | 1              | WDTO,Sleep               |
| 57                 | RCALL                | RCALL             | Expr                                | Relative Call                                                  | 1             | 2              | None                     |
|                    |                      | RCALL             | Wn                                  | Computed Call                                                  | 1             | 2              | None                     |
| 58                 | REPEAT               | REPEAT            | #lit14                              | Repeat Next Instruction lit14 + 1 times                        | 1             | 1              | None                     |
|                    |                      | REPEAT            | Wn                                  | Repeat Next Instruction (Wn) + 1 times                         | 1             | 1              | None                     |
| 59                 | RESET                | RESET             |                                     | Software device Reset                                          | 1             | 1              | None                     |
| 60                 | RETFIE               | RETFIE            |                                     | Return from interrupt                                          | 1             | 3 (2)          | None                     |
| 61                 | RETLW                | RETLW             | #lit10,Wn                           | Return with literal in Wn                                      | 1             | 3 (2)          | None                     |
| 62                 | RETURN               | RETURN            |                                     | Return from Subroutine                                         | 1             | 3 (2)          | None                     |
| 63                 | RLC                  | RLC               | f                                   | f = Rotate Left through Carry f                                | 1             | 1              | C,N,Z                    |
|                    |                      | RLC               | I,WREG                              | Wele Detete Left through Carry f                               | 1             |                | C,N,Z                    |
|                    | DINO                 | RLC               | Ws,Wd                               | Wd = Rotate Left through Carry Ws                              | 1             | 1              | C,N,Z                    |
| 04                 | REINC                | RLNC              | I E                                 | I = Rotate Left (No Carry) T $WPEC = Pototo Loft (No Carry) f$ | 1             | 1              | N,∠                      |
|                    |                      | RLNC              | L, WREG                             | Wid = Rotate Left (No Carry) Wa                                | 1             | 1              | N.Z                      |
| 65                 | RRC                  | RLINC             | ws,wa                               | f = Rotate Right through Corry f                               | 1             | 1              |                          |
| 00                 | 1110                 | RRC               | f WREG                              | WREG = Rotate Right through Carry f                            | 1             | 1              | C N 7                    |
|                    |                      | RRC               | Ws,Wd                               | Wd = Rotate Right through Carry Ws                             | 1             | 1              | C,N,Z                    |

#### TABLE 20-2: INSTRUCTION SET OVERVIEW (CONTINUED)

## 22.1 DC Characteristics

| Charactoristic | VDD Range  | Temp Range      | Max MIPS             |  |  |
|----------------|------------|-----------------|----------------------|--|--|
| Characteristic | (in Volts) | (in °C)         | dsPIC33FJ12GP201/202 |  |  |
|                | 3.0-3.6V   | -40°C to +85°C  | 40                   |  |  |
|                | 3.0-3.6V   | -40°C to +125°C | 40                   |  |  |

#### TABLE 22-1: OPERATING MIPS VS. VOLTAGE

### TABLE 22-2: THERMAL OPERATING CONDITIONS

| Rating                                                                                      | Symbol | Min         | Тур         | Max  | Unit |
|---------------------------------------------------------------------------------------------|--------|-------------|-------------|------|------|
| Industrial Temperature Devices                                                              |        |             |             |      |      |
| Operating Junction Temperature Range                                                        | TJ     | -40         | —           | +125 | °C   |
| Operating Ambient Temperature Range                                                         | TA     | -40         | —           | +85  | °C   |
| Extended Temperature Devices                                                                |        |             |             |      |      |
| Operating Junction Temperature Range                                                        | TJ     | -40         | _           | +140 | °C   |
| Operating Ambient Temperature Range                                                         | TA     | -40         | —           | +125 | °C   |
| Power Dissipation:<br>Internal chip power dissipation:<br>$PINT = VDD x (IDD - \Sigma IOH)$ | PD     | PINT + PI/O |             |      | w    |
| I/O Pin Power Dissipation:<br>I/O = $\Sigma$ ({VDD - VOH} x IOH) + $\Sigma$ (VOL x IOL)     |        |             |             |      |      |
| Maximum Allowed Power Dissipation                                                           | PDMAX  | (           | TJ — TA)/θ. | IA   | W    |

#### TABLE 22-3: THERMAL PACKAGING CHARACTERISTICS

| Characteristic                           | Symbol | Тур | Max | Unit | Notes |
|------------------------------------------|--------|-----|-----|------|-------|
| Package Thermal Resistance, 18-pin PDIP  | θја    | 45  | _   | °C/W | 1     |
| Package Thermal Resistance, 28-pin SPDIP | θја    | 45  | —   | °C/W | 1     |
| Package Thermal Resistance, 18-pin SOIC  | θја    | 60  | _   | °C/W | 1     |
| Package Thermal Resistance, 28-pin SOIC  | θја    | 50  | —   | °C/W | 1     |
| Package Thermal Resistance, 28-pin SSOP  | θја    | 71  | —   | °C/W | 1     |
| Package Thermal Resistance, 28-pin QFN   | θja    | 35  | —   | °C/W | 1     |

**Note 1:** Junction to ambient thermal resistance, Theta-JA ( $\theta$ JA) numbers are achieved by package simulations.





| АС СНА       | ARACTER | ISTICS                        |                           | Standard Operating Conditions: 3.0V to 3.6V         (unless otherwise stated)         Operating temperature       -40°C ≤TA ≤+85°C for Industrial         -40°C ≤TA ≤+125°C for Extended |      |       |                        |  |
|--------------|---------|-------------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|------------------------|--|
| Param<br>No. | Symbol  | Characteristic <sup>(3)</sup> |                           | Min <sup>(1)</sup>                                                                                                                                                                       | Max  | Units | Conditions             |  |
| IM10         | TLO:SCL | Clock Low Time                | 100 kHz mode              | Tcy/2 (BRG + 1)                                                                                                                                                                          | —    | μs    | —                      |  |
|              |         |                               | 400 kHz mode              | Tcy/2 (BRG + 1)                                                                                                                                                                          |      | μs    | _                      |  |
|              |         |                               | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                                                                                                                                          | _    | μs    | —                      |  |
| IM11         | THI:SCL | Clock High Time               | 100 kHz mode              | Tcy/2 (BRG + 1)                                                                                                                                                                          | _    | μs    | —                      |  |
|              |         |                               | 400 kHz mode              | Tcy/2 (BRG + 1)                                                                                                                                                                          | _    | μs    | —                      |  |
|              |         |                               | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 1)                                                                                                                                                                          | —    | μs    | —                      |  |
| IM20         | TF:SCL  | SDAx and SCLx                 | 100 kHz mode              | —                                                                                                                                                                                        | 300  | ns    | CB is specified to be  |  |
|              |         | Fall Time                     | 400 kHz mode              | 20 + 0.1 Св                                                                                                                                                                              | 300  | ns    | from 10 to 400 pF      |  |
|              |         |                               | 1 MHz mode <sup>(2)</sup> | —                                                                                                                                                                                        | 100  | ns    |                        |  |
| IM21         | TR:SCL  | SDAx and SCLx                 | 100 kHz mode              | —                                                                                                                                                                                        | 1000 | ns    | CB is specified to be  |  |
|              |         | Rise Time                     | 400 kHz mode              | 20 + 0.1 Св                                                                                                                                                                              | 300  | ns    | from 10 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         | Pgd     | Pulse Gobbler De              | elay                      | 65                                                                                                                                                                                       | 390  | ns    | See Note 4             |  |

## TABLE 22-36: I<sup>2</sup>Cx BUS DATA TIMING REQUIREMENTS (MASTER MODE)

Note 1: BRG is the value of the I<sup>2</sup>C 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". Refer to the Microchip website (www.microchip.com) for the latest family reference manual sections.

- 2: Maximum pin capacitance = 10 pF for all I2Cx pins (for 1 MHz mode only).
- 3: These parameters are characterized by similarity, but are not tested in manufacturing.
- **4:** Typical value for this parameter is 130 ns.

#### TABLE 22-38: ADC MODULE SPECIFICATIONS

| AC CHA       | RACTER        | ISTICS                                                                | Standard Operating Conditions: 3.0V to 3.6V         (unless otherwise stated)         Operating temperature       -40°C ≤TA ≤+85°C for Industrial         -40°C ≤TA ≤+125°C for Extended |            |                                  |          |                                                                                                  |  |  |  |
|--------------|---------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------|----------|--------------------------------------------------------------------------------------------------|--|--|--|
| Param<br>No. | Symbol        | Characteristic                                                        | Min.                                                                                                                                                                                     | Тур        | Max.                             | Units    | Conditions                                                                                       |  |  |  |
|              | Device Supply |                                                                       |                                                                                                                                                                                          |            |                                  |          |                                                                                                  |  |  |  |
| AD01         | AVdd          | Module VDD Supply <sup>(2)</sup>                                      | Greater of<br>VDD – 0.3<br>or 3.0                                                                                                                                                        | _          | Lesser of<br>VDD + 0.3<br>or 3.6 | V        | _                                                                                                |  |  |  |
| AD02         | AVss          | Module Vss Supply <sup>(2)</sup>                                      | Vss – 0.3                                                                                                                                                                                |            | Vss + 0.3                        | V        | —                                                                                                |  |  |  |
|              |               |                                                                       | Referer                                                                                                                                                                                  | nce Inpu   | Its                              |          |                                                                                                  |  |  |  |
| AD05         | VREFH         | Reference Voltage High                                                | AVss + 2.5                                                                                                                                                                               | _          | AVDD                             | V        | See Note 1                                                                                       |  |  |  |
| AD05a        |               |                                                                       | 3.0                                                                                                                                                                                      | —          | 3.6                              | V        | VREFH = AVDD<br>VREFL = AVSS = 0, see <b>Note 2</b>                                              |  |  |  |
| AD06         | VREFL         | Reference Voltage Low                                                 | AVss                                                                                                                                                                                     |            | AVDD - 2.5                       | V        | See Note 1                                                                                       |  |  |  |
| AD06a        |               |                                                                       | 0                                                                                                                                                                                        | _          | 0                                | V        | VREFH = AVDD<br>VREFL = AVSS = 0, see <b>Note 2</b>                                              |  |  |  |
| AD07         | VREF          | Absolute Reference<br>Voltage <sup>(2)</sup>                          | 2.5                                                                                                                                                                                      | _          | 3.6                              | V        | VREF = VREFH - VREFL                                                                             |  |  |  |
| AD08         | IREF          | Current Drain                                                         |                                                                                                                                                                                          | 250<br>—   | 550<br>10                        | μΑ<br>μΑ | ADC operating, See <b>Note 1</b><br>ADC off, See <b>Note 1</b>                                   |  |  |  |
| AD08a        | IAD           | Operating Current                                                     |                                                                                                                                                                                          | 7.0<br>2.7 | 9.0<br>3.2                       | mA<br>mA | 10-bit ADC mode, See <b>Note 2</b><br>12-bit ADC mode, See <b>Note 2</b>                         |  |  |  |
|              |               |                                                                       | Analo                                                                                                                                                                                    | og Input   |                                  |          |                                                                                                  |  |  |  |
| AD12         | VINH          | Input Voltage Range<br>VINH <sup>(2)</sup>                            | VINL                                                                                                                                                                                     |            | Vrefh                            | V        | This voltage reflects Sample<br>and Hold Channels 0, 1, 2,<br>and 3 (CH0-CH3), positive<br>input |  |  |  |
| AD13         | VINL          | Input Voltage Range<br>VINL <sup>(2)</sup>                            | VREFL                                                                                                                                                                                    | _          | AVss + 1V                        | V        | This voltage reflects Sample<br>and Hold Channels 0, 1, 2,<br>and 3 (CH0-CH3), negative<br>input |  |  |  |
| AD17         | RIN           | Recommended Imped-<br>ance of Analog Voltage<br>Source <sup>(3)</sup> |                                                                                                                                                                                          | _          | 200<br>200                       | Ω<br>Ω   | 10-bit ADC<br>12-bit ADC                                                                         |  |  |  |

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

**2:** These parameters are characterized, but are not tested in manufacturing.

**3:** These parameters are assured by design, but are not characterized or tested in manufacturing.

## 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



|                          | Units    | MILLMETERS |           |      |  |
|--------------------------|----------|------------|-----------|------|--|
| Dimensior                | n Limits | MIN        | NOM       | MAX  |  |
| Number of Pins           | Ν        |            | 18        |      |  |
| Pitch                    | е        |            | 1.27 BSC  |      |  |
| Overall Height           | Α        | —          | -         | 2.65 |  |
| Molded Package Thickness | A2       | 2.05       | -         | -    |  |
| Standoff §               | A1       | 0.10       | -         | 0.30 |  |
| Overall Width            | E        | 10.30 BSC  |           |      |  |
| Molded Package Width     | E1       | 7.50 BSC   |           |      |  |
| Overall Length           | D        |            | 11.55 BSC |      |  |
| Chamfer (optional)       | h        | 0.25       | _         | 0.75 |  |
| Foot Length              | L        | 0.40       | _         | 1.27 |  |
| Footprint                | L1       |            | 1.40 REF  |      |  |
| Foot Angle               | ¢        | 0°         | -         | 8°   |  |
| Lead Thickness           | С        | 0.20       | -         | 0.33 |  |
| Lead Width               | b        | 0.31       | -         | 0.51 |  |
| Mold Draft Angle Top     | α        | 5°         | -         | 15°  |  |
| Mold Draft Angle Bottom  | β        | 5°         | _         | 15°  |  |

Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. § Significant Characteristic.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-051B

## 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



#### Notes:

1. Pin 1 visual index feature may vary, but must be located within the hatched area.

2. § Significant Characteristic.

3. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15 mm per side.

4. Dimensioning and tolerancing per ASME Y14.5M.

BSC: Basic Dimension. Theoretically exact value shown without tolerances.

REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-052B

## APPENDIX A: REVISION HISTORY

## Revision A (January 2007)

Initial release of this document.

## Revision B (May 2007)

This revision includes the following corrections and updates:

- Minor typographical and formatting corrections throughout the data sheet text.
- New content:
  - Addition of bullet item (16-word conversion result buffer) (see Section 18.1 "Key Features")
- Figure update:
  - Oscillator System Diagram (see Figure 8-1)
  - WDT Block Diagram (see Figure 19-2)
- · Equation update:
  - Serial Clock Rate (see Equation 15-1)
- Register updates:
  - Clock Divisor Register (see Register 8-2)
  - PLL Feedback Divisor Register (see Register 8-3)
  - Peripheral Pin Select Input Registers (see Register 10-1 through Register 10-9)
  - ADC1 Input Channel 1, 2, 3 Select Register (see Register 18-4)
  - ADC1 Input Channel 0 Select Register (see Register 18-5)
- Table updates:
  - CNEN2 (see Table 4-2 and Table 4-3)
  - Reset Flag Bit Operation (see Table 5-1)
  - Configuration Bit Values for Clock Operation (see Table 8-1)
- Operation value update:
  - IOLOCK set/clear operation (see Section 10.4.3.1 "Control Register Lock")

- The following tables in Section 22.0 "Electrical Characteristics" have been updated with preliminary values:
  - Updated Max MIPS for -40°C to +125°C Temp Range (see Table 22-1)
  - Added new parameters for +125°C, and updated Typical and Max values for most parameters (see Table 22-5)
  - Added new parameters for +125°C, and updated Typical and Max values for most parameters (see Table 22-6)
  - Added new parameters for +125°C, and updated Typical and Max values for most parameters (see Table 22-7)
  - Added new parameters for +125°C, and updated Typical and Max values for most parameters (see Table 22-8)
  - Updated parameter DI51, added parameter DI51a (see Table 22-9)
  - Added Note 1 (see Table 22-11)
  - Updated parameter OS30 (see Table 22-16)
  - Updated parameter OS52 (see Table 22-17)
  - Updated parameter F20, added Note 2 (see Table 22-18)
  - Updated parameter F21 (see Table 22-19)
  - Updated parameter TA15 (see Table 22-22)
  - Updated parameter TB15 (see Table 22-23)
  - Updated parameter TC15 (see Table 22-24)
  - Updated parameter IC15 (see Table 22-25)
  - Updated parameters AD05, AD06, AD07, AD08, AD10, and AD11; added parameters AD05a and AD06a; added Note 2; modified ADC Accuracy headings to include measurement information (see Table 22-34)
  - Separated the ADC Module Specifications table into three tables (see Table 22-34, Table 22-35, and Table 22-36)
  - Updated parameter AD50 (see Table 22-37)
  - Updated parameters AD50 and AD57 (see Table 22-38)

NOTES: