

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                      | 70 MIPs                                                                         |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, QEI, SPI, UART/USART                            |
| Peripherals                | Brown-out Detect/Reset, DMA, Motor Control PWM, POR, PWM, WDT                   |
| Number of I/O              | 53                                                                              |
| Program Memory Size        | 64KB (22K x 24)                                                                 |
| Program Memory Type        | FLASH                                                                           |
| EEPROM Size                | -                                                                               |
| RAM Size                   | 4K x 16                                                                         |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                       |
| Data Converters            | A/D 16x10b/12b                                                                  |
| Oscillator Type            | Internal                                                                        |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                               |
| Mounting Type              | Surface Mount                                                                   |
| Package / Case             | 64-VFQFN Exposed Pad                                                            |
| Supplier Device Package    | 64-VQFN (9x9)                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic33ep64mc206-i-mr |

Email: info@E-XFL.COM

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



#### 2.2.1 TANK CAPACITORS

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

### 2.3 CPU Logic Filter Capacitor Connection (VCAP)

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

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

# 2.4 Master Clear (MCLR) Pin

The MCLR pin provides two specific device functions:

- Device Reset
- Device Programming and Debugging.

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

For example, as shown in Figure 2-2, it is recommended that the capacitor, C, be isolated from the  $\overline{\text{MCLR}}$  pin during programming and debugging operations.

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





#### 3.7 CPU Control Registers

| R/W-0               | ) R/W-0                                | R/W-0                  | R/W-0                       | R/C-0                    | R/C-0              | R-0               | R/W-0           |
|---------------------|----------------------------------------|------------------------|-----------------------------|--------------------------|--------------------|-------------------|-----------------|
| 0A <sup>(1)</sup>   | OB <sup>(1)</sup>                      | SA <sup>(1,4)</sup>    | SB <sup>(1,4)</sup>         | OAB <sup>(1)</sup>       | SAB <sup>(1)</sup> | DA <sup>(1)</sup> | DC              |
| bit 15              |                                        |                        |                             |                          |                    |                   | bit 8           |
|                     |                                        |                        |                             |                          |                    |                   |                 |
| R/W-0 <sup>(2</sup> | R/W-0 <sup>(2,3)</sup>                 | R/W-0 <sup>(2,3)</sup> | R-0                         | R/W-0                    | R/W-0              | R/W-0             | R/W-0           |
| IPL2                | IPL1                                   | IPL0                   | RA                          | N                        | OV                 | Z                 | С               |
| bit 7               |                                        |                        |                             |                          |                    |                   | bit 0           |
|                     |                                        |                        |                             |                          |                    |                   |                 |
| Legend:             |                                        | C = Clearable          | bit                         |                          |                    |                   |                 |
| R = Reada           | able bit                               | W = Writable           | bit                         | U = Unimpler             | mented bit, read   | l as '0'          |                 |
| -n = Value          | e at POR                               | '1'= Bit is set        |                             | '0' = Bit is cle         | ared               | x = Bit is unkr   | nown            |
|                     |                                        |                        |                             |                          |                    |                   |                 |
| bit 15              | OA: Accumu                             | lator A Overflow       | v Status bit <sup>(1)</sup> |                          |                    |                   |                 |
|                     | 1 = Accumula                           | ator A has over        | flowed                      |                          |                    |                   |                 |
|                     | 0 = Accumula                           | ator A has not c       | verflowed                   |                          |                    |                   |                 |
| bit 14              | OB: Accumu                             | lator B Overflov       | v Status bit <sup>(1)</sup> |                          |                    |                   |                 |
|                     | 1 = Accumula                           | ator B has over        | flowed                      |                          |                    |                   |                 |
| hit 13              |                                        | lator A Saturatio      | n 'Sticky' Sta              | tue hit(1,4)             |                    |                   |                 |
| DIL 15              | $1 = \Delta c cumula$                  | ator A is saturat      | ed or has her               | n saturated at           | some time          |                   |                 |
|                     | 0 = Accumula                           | ator A is not sat      | urated                      |                          | Some time          |                   |                 |
| bit 12              | SB: Accumu                             | lator B Saturatio      | on 'Sticky' Sta             | tus bit <sup>(1,4)</sup> |                    |                   |                 |
|                     | 1 = Accumula                           | ator B is satura       | ed or has bee               | en saturated at          | some time          |                   |                 |
|                     | 0 = Accumula                           | ator B is not sat      | urated                      |                          |                    |                   |                 |
| bit 11              | <b>OAB:</b> OA    (                    | OB Combined A          | ccumulator O                | verflow Status           | bit <sup>(1)</sup> |                   |                 |
|                     | 1 = Accumula                           | ators A or B have      | ve overflowed               |                          |                    |                   |                 |
|                     | 0 = Neither A                          | Accumulators A         | or B have ove               | erflowed                 | (1)                |                   |                 |
| bit 10              | SAB: SA    S                           | B Combined A           | cumulator 'Si               | icky Status bit          |                    | <b>1</b>          |                 |
|                     | 1 = Accumula  0 = Neither A            | ators A or B are       | or B are satur              | nave been sat            | urated at some     | time              |                 |
| hit 9               |                                        | Active hit(1)          |                             | alou                     |                    |                   |                 |
| bit 0               | 1 = DO loop is                         | s in progress          |                             |                          |                    |                   |                 |
|                     | 0 = DO loop is                         | s not in progres       | S                           |                          |                    |                   |                 |
| bit 8               | DC: MCU AL                             | U Half Carry/Bo        | orrow bit                   |                          |                    |                   |                 |
|                     | 1 = A carry-o                          | out from the 4th       | low-order bit (             | for byte-sized o         | data) or 8th low-  | order bit (for wo | ord-sized data) |
|                     | of the re                              | sult occurred          |                             |                          |                    |                   |                 |
|                     | 0 = No carry                           | -out from the 4        | th low-order t              | bit (for byte-siz        | ed data) or 8th    | low-order bit (1  | for word-sized  |
|                     | uala) U                                |                        |                             |                          |                    |                   |                 |
| Note 1:             | This bit is availabl                   | e on dsPIC33E          | PXXXMC20X                   | /50X and dsPl            | C33EPXXXGP         | 50X devices on    | ly.             |
| 2:                  | The IPL<2:0> bits                      | are concatenat         | ed with the IF              | PL<3> bit (COR           | RCON<3>) to fo     | rm the CPU Inte   | errupt Priority |
|                     | Level. The value I<br>IPL< $3 > = 1$ . | n parentheses i        | naicates the I              | PL, IT IPL<3> =          | = ⊥. User interru  | ipts are disable  | a wnen          |

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

- 3: The IPL<2:0> Status bits are read-only when the NSTDIS bit (INTCON1<15>) = 1.
- **4:** A data write to the SR register can modify the SA and SB bits by either a data write to SA and SB or by clearing the SAB bit. To avoid a possible SA or SB bit write race condition, the SA and SB bits should not be modified using bit operations.

#### FIGURE 4-2: PROGRAM MEMORY MAP FOR dsPIC33EP64GP50X, dsPIC33EP64MC20X/50X AND PIC24EP64GP/MC20X DEVICES



Note: Memory areas are not shown to scale.

# TABLE 4-27: PERIPHERAL PIN SELECT OUTPUT REGISTER MAP FOR dsPIC33EPXXXGP/MC204/504 AND PIC24EPXXXGP/MC204 DEVICES ONLY DEVICES ONLY

| File<br>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 |
|--------------|-------|--------|--------|---------------------------|---------------------------------------------------|--------|--------|-------|-------|-------|-------|--------------|--------|-------|-------|-------|-------|---------------|
| RPOR0        | 0680  |        |        |                           | RP35R<5:0> — — RP20R<5:0>                         |        |        |       |       |       |       | 0000         |        |       |       |       |       |               |
| RPOR1        | 0682  | —      | —      |                           | RP37R<5:0>         —         —         RP36R<5:0> |        |        |       |       |       |       | 0000         |        |       |       |       |       |               |
| RPOR2        | 0684  | —      | —      | RP39R<5:0> — — RP38R<5:0> |                                                   |        |        |       |       |       |       | 0000         |        |       |       |       |       |               |
| RPOR3        | 0686  | _      | _      |                           |                                                   | RP41   | R<5:0> |       |       | —     | _     | RP40R<5:0>   |        |       |       |       |       | 0000          |
| RPOR4        | 0688  | _      | _      |                           |                                                   | RP43   | R<5:0> |       |       | —     | _     | RP42R<5:0>   |        |       |       |       | 0000  |               |
| RPOR5        | 068A  | _      | _      | RP55R<5:0> — —            |                                                   |        |        |       |       |       |       | RP54         | R<5:0> |       |       | 0000  |       |               |
| RPOR6        | 068C  | _      | _      |                           |                                                   | RP57   | R<5:0> |       |       | _     | —     | - RP56R<5:0> |        |       |       | 0000  |       |               |

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

# TABLE 4-28: PERIPHERAL PIN SELECT OUTPUT REGISTER MAP FOR dsPIC33EPXXXGP/MC206/506 AND PIC24EPXXXGP/MC206 DEVICES ONLY DEVICES ONLY

| File<br>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 |
|--------------|-------|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|--------|-------|-------|---------------|
| RPOR0        | 0680  | —      | —      |        |        | RP35   | R<5:0> |       |       | _     | _     |       |       | RP20I | R<5:0> |       |       | 0000          |
| RPOR1        | 0682  | _      | _      |        |        | RP37   | R<5:0> |       |       | _     | _     |       |       | RP36  | R<5:0> |       |       | 0000          |
| RPOR2        | 0684  | _      | _      |        |        | RP39   | R<5:0> |       |       | —     | —     |       |       | RP38  | R<5:0> |       |       | 0000          |
| RPOR3        | 0686  | _      | _      |        |        | RP41   | R<5:0> |       |       | —     | —     |       |       | RP40  | R<5:0> |       |       | 0000          |
| RPOR4        | 0688  | _      | _      |        |        | RP43   | R<5:0> |       |       | —     | —     |       |       | RP42I | R<5:0> |       |       | 0000          |
| RPOR5        | 068A  | _      | _      |        |        | RP55I  | R<5:0> |       |       | —     | —     |       |       | RP54I | R<5:0> |       |       | 0000          |
| RPOR6        | 068C  | _      | _      |        |        | RP57I  | R<5:0> |       |       | —     | —     |       |       | RP56I | R<5:0> |       |       | 0000          |
| RPOR7        | 068E  | _      | _      |        |        | RP97   | R<5:0> |       |       | —     | —     | _     | _     | _     | _      | _     | _     | 0000          |
| RPOR8        | 0690  | _      | _      |        |        | RP118  | R<5:0> |       |       | —     | —     | _     | _     | _     | _      | _     | _     | 0000          |
| RPOR9        | 0692  | _      | _      | _      | _      | _      | _      | _     | _     | _     | _     |       |       | RP120 | R<5:0> |       |       | 0000          |

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

#### TABLE 4-56: PORTA REGISTER MAP FOR PIC24EPXXXGP/MC203 AND dsPIC33EPXXXGP/MC203/503 DEVICES ONLY

| File<br>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        | 0E00  |        |        | —      |        |        | —      |       | TRISA8 |       |       |       | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 011F          |
| PORTA        | 0E02  |        | -      | —      | -      | -      | —      | -     | RA8    | _     | _     | -     | RA4    | RA3    | RA2    | RA1    | RA0    | 0000          |
| LATA         | 0E04  | _      | _      | _      | _      | _      | _      | _     | LATA8  | _     | _     | _     | LATA4  | LATA3  | LATA2  | LA1TA1 | LA0TA0 | 0000          |
| ODCA         | 0E06  | _      | _      | _      | _      | _      | _      | _     | ODCA8  | _     | _     | _     | ODCA4  | ODCA3  | ODCA2  | ODCA1  | ODCA0  | 0000          |
| CNENA        | 0E08  | _      | _      | _      | _      | _      | _      | _     | CNIEA8 | _     | _     | _     | CNIEA4 | CNIEA3 | CNIEA2 | CNIEA1 | CNIEA0 | 0000          |
| CNPUA        | 0E0A  | _      | _      | _      | _      | _      | _      | _     | CNPUA8 | _     | _     | _     | CNPUA4 | CNPUA3 | CNPUA2 | CNPUA1 | CNPUA0 | 0000          |
| CNPDA        | 0E0C  | _      | _      | _      | _      | _      | _      | _     | CNPDA8 | _     | _     | _     | CNPDA4 | CNPDA3 | CNPDA2 | CNPDA1 | CNPDA0 | 0000          |
| ANSELA       | 0E0E  |        |        | —      |        |        | —      |       | _      | _     |       |       | ANSA4  |        | -      | ANSA1  | ANSA0  | 0013          |

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

#### TABLE 4-57: PORTB REGISTER MAP FOR PIC24EPXXXGP/MC203 AND dsPIC33EPXXXGP/MC203/503 DEVICES ONLY

| File<br>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        | 0E10  | TRISB15 | TRISB14 | TRISB13 | TRISB12 | TRISB11 | TRISB10 | TRISB9 | TRISB8 | TRISB7 | TRISB6 | TRISB5 | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | FFFF          |
| PORTB        | 0E12  | RB15    | RB14    | RB13    | RB12    | RB11    | RB10    | RB9    | RB8    | RB7    | RB6    | RB5    | RB4    | RB3    | RB2    | RB1    | RB0    | xxxx          |
| LATB         | 0E14  | LATB15  | LATB14  | LATB13  | LATB12  | LATB11  | LATB10  | LATB9  | LATB8  | LATB7  | LATB6  | LATB5  | LATB4  | LATB3  | LATB2  | LATB1  | LATB0  | xxxx          |
| ODCB         | 0E16  | ODCB15  | ODCB14  | ODCB13  | ODCB12  | ODCB11  | ODCB10  | ODCB9  | ODCB8  | ODCB7  | ODCB6  | ODCB5  | ODCB4  | ODCB3  | ODCB2  | ODCB1  | ODCB0  | 0000          |
| CNENB        | 0E18  | CNIEB15 | CNIEB14 | CNIEB13 | CNIEB12 | CNIEB11 | CNIEB10 | CNIEB9 | CNIEB8 | CNIEB7 | CNIEB6 | CNIEB5 | CNIEB4 | CNIEB3 | CNIEB2 | CNIEB1 | CNIEB0 | 0000          |
| CNPUB        | 0E1A  | CNPUB15 | CNPUB14 | CNPUB13 | CNPUB12 | CNPUB11 | CNPUB10 | CNPUB9 | CNPUB8 | CNPUB7 | CNPUB6 | CNPUB5 | CNPUB4 | CNPUB3 | CNPUB2 | CNPUB1 | CNPUB0 | 0000          |
| CNPDB        | 0E1C  | CNPDB15 | CNPDB14 | CNPDB13 | CNPDB12 | CNPDB11 | CNPDB10 | CNPDB9 | CNPDB8 | CNPDB7 | CNPDB6 | CNPDB5 | CNPDB4 | CNPDB3 | CNPDB2 | CNPDB1 | CNPDB0 | 0000          |
| ANSELB       | 0E1E  | _       | _       | _       | _       | _       | _       | _      | ANSB8  | _      | _      | _      | _      | ANSB3  | ANSB2  | ANSB1  | ANSB0  | 010F          |

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

#### TABLE 4-58: PORTC REGISTER MAP FOR PIC24EPXXXGP/MC203 AND dsPIC33EPXXXGP/MC203/503 DEVICES ONLY

| File<br>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 |
|--------------|-------|--------|--------|--------|--------|--------|--------|-------|--------|-------|-------|-------|-------|-------|-------|--------|--------|---------------|
| TRISC        | 0E20  | —      | _      | —      | _      | —      | —      | —     | TRISC8 | _     | —     | —     | —     | —     | —     | TRISC1 | TRISC0 | 0103          |
| PORTC        | 0E22  | —      | _      | —      | _      | _      | _      | _     | RC8    |       | —     | _     | _     | _     | _     | RC1    | RC0    | xxxx          |
| LATC         | 0E24  | —      | _      | —      | _      | —      | —      | —     | LATC8  |       | _     | —     | —     | —     | _     | LATC1  | LATC0  | xxxx          |
| ODCC         | 0E26  | —      | _      | —      | _      | —      | —      | —     | ODCC8  |       | _     | —     | —     | —     | _     | ODCC1  | ODCC0  | 0000          |
| CNENC        | 0E28  | —      | _      | —      | _      | —      | —      | —     | CNIEC8 |       | _     | —     | —     | —     | _     | CNIEC1 | CNIEC0 | 0000          |
| CNPUC        | 0E2A  | —      | _      | —      | _      | —      | —      | —     | CNPUC8 |       | _     | —     | —     | —     | _     | CNPUC1 | CNPUC0 | 0000          |
| CNPDC        | 0E2C  | —      | _      | —      | _      | —      | —      | —     | CNPDC8 |       | _     | —     | —     | —     | _     | CNPDC1 | CNPDC0 | 0000          |
| ANSELC       | 0E2E  | _      | _      | _      | _      | _      | _      | _     | _      | _     | _     | _     | _     | _     |       | ANSC1  | ANSC0  | 0003          |

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

#### 4.4.2 EXTENDED X DATA SPACE

The lower portion of the base address space range, between 0x0000 and 0x7FFF, is always accessible regardless of the contents of the Data Space Page registers. It is indirectly addressable through the register indirect instructions. It can be regarded as being located in the default EDS Page 0 (i.e., EDS address range of 0x000000 to 0x007FFF with the base address bit, EA<15> = 0, for this address range). However, Page 0 cannot be accessed through the upper 32 Kbytes, 0x8000 to 0xFFFF, of base Data Space, in combination with DSRPAG = 0x000 or DSWPAG = 0x000. Consequently, DSRPAG and DSWPAG are initialized to 0x001 at Reset.

- Note 1: DSxPAG should not be used to access Page 0. An EDS access with DSxPAG set to 0x000 will generate an address error trap.
  - 2: Clearing the DSxPAG in software has no effect.

The remaining pages, including both EDS and PSV pages, are only accessible using the DSRPAG or DSWPAG registers in combination with the upper 32 Kbytes, 0x8000 to 0xFFFF, of the base address, where base address bit, EA<15> = 1.

For example, when DSRPAG = 0x001 or DSWPAG = 0x001, accesses to the upper 32 Kbytes, 0x8000 to 0xFFFF, of the Data Space will map to the EDS address range of 0x008000 to 0x00FFFF. When DSRPAG = 0x002 or DSWPAG = 0x002, accesses to the upper 32 Kbytes of the Data Space will map to the EDS address range of 0x010000 to 0x017FFF and so on, as shown in the EDS memory map in Figure 4-17.

For more information on the PSV page access using Data Space Page registers, refer to the "**Program Space Visibility from Data Space**" section in "**Program Memory**" (DS70613) of the "*dsPIC33/ PIC24 Family Reference Manual*".



#### FIGURE 4-17: EDS MEMORY MAP

### 4.8 Interfacing Program and Data Memory Spaces

The dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/ 50X and PIC24EPXXXGP/MC20X architecture uses a 24-bit-wide Program Space (PS) and a 16-bit-wide Data Space (DS). The architecture is also a modified Harvard scheme, meaning that data can also be present in the Program Space. To use this data successfully, it must be accessed in a way that preserves the alignment of information in both spaces.

Aside from normal execution, the architecture of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X devices provides two methods by which Program Space can be accessed during operation:

- Using table instructions to access individual bytes or words anywhere in the Program Space
- Remapping a portion of the Program Space into the Data Space (Program Space Visibility)

Table instructions allow an application to read or write to small areas of the program memory. This capability makes the method ideal for accessing data tables that need to be updated periodically. It also allows access to all bytes of the program word. The remapping method allows an application to access a large block of data on a read-only basis, which is ideal for look-ups from a large table of static data. The application can only access the least significant word of the program word.

#### TABLE 4-65: PROGRAM SPACE ADDRESS CONSTRUCTION

|                        | Access        |                           | Progra      | m Space A | ddress        |     |  |
|------------------------|---------------|---------------------------|-------------|-----------|---------------|-----|--|
| Access Type            | Space         | <23>                      | <22:16>     | <15>      | <14:1>        | <0> |  |
| Instruction Access     | User          | 0                         |             | PC<22:1>  |               | 0   |  |
| (Code Execution)       |               |                           | 0xx xxxx xx | xx xxxx   | xxxx xxx0     |     |  |
| TBLRD/TBLWT            | User          | TBLPAG<7:0> Data EA<15:0> |             |           |               |     |  |
| (Byte/Word Read/Write) |               | 0                         | xxx xxxx    | xxxx xxx  | x xxxx xxxx   |     |  |
|                        | Configuration | TBLPAG<7:0>               |             |           | Data EA<15:0> |     |  |
|                        |               | 1                         | XXX XXXX    | XXXX XX   | xx xxxx xxxx  |     |  |

#### FIGURE 4-22: DATA ACCESS FROM PROGRAM SPACE ADDRESS GENERATION



#### 7.3 Interrupt Resources

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

| Note: | In the event you are not able to access the product page using the link above, enter |
|-------|--------------------------------------------------------------------------------------|
|       | this ORL in your prowser.                                                            |
|       | http://www.microchip.com/wwwproducts/                                                |
|       | Devices.aspx?dDocName=en555464                                                       |

#### 7.3.1 KEY RESOURCES

- "Interrupts" (DS70600) in the "dsPIC33/PIC24 Family Reference Manual"
- Code Samples
- Application Notes
- Software Libraries
- Webinars
- All Related "dsPIC33/PIC24 Family Reference Manual" Sections
- Development Tools

#### 7.4 Interrupt Control and Status Registers

dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X devices implement the following registers for the interrupt controller:

- INTCON1
- INTCON2
- INTCON3
- INTCON4
- INTTREG

#### 7.4.1 INTCON1 THROUGH INTCON4

Global interrupt control functions are controlled from INTCON1, INTCON2, INTCON3 and INTCON4.

INTCON1 contains the Interrupt Nesting Disable bit (NSTDIS), as well as the control and status flags for the processor trap sources.

The INTCON2 register controls external interrupt request signal behavior and also contains the Global Interrupt Enable bit (GIE).

INTCON3 contains the status flags for the DMA and DO stack overflow status trap sources.

The INTCON4 register contains the software generated hard trap status bit (SGHT).

### 7.4.2 IFSx

The IFSx registers maintain all of the interrupt request flags. Each source of interrupt has a status bit, which is set by the respective peripherals or external signal and is cleared via software.

#### 7.4.3 IECx

The IECx registers maintain all of the interrupt enable bits. These control bits are used to individually enable interrupts from the peripherals or external signals.

#### 7.4.4 IPCx

The IPCx registers are used to set the Interrupt Priority Level (IPL) for each source of interrupt. Each user interrupt source can be assigned to one of eight priority levels.

#### 7.4.5 INTTREG

The INTTREG register contains the associated interrupt vector number and the new CPU Interrupt Priority Level, which are latched into the Vector Number bits (VECNUM<7:0>) and Interrupt Priority Level bits (ILR<3:0>) fields in the INTTREG register. The new Interrupt Priority Level is the priority of the pending interrupt.

The interrupt sources are assigned to the IFSx, IECx and IPCx registers in the same sequence as they are listed in Table 7-1. For example, the INT0 (External Interrupt 0) is shown as having Vector Number 8 and a natural order priority of 0. Thus, the INT0IF bit is found in IFS0<0>, the INT0IE bit in IEC0<0> and the INT0IP bits in the first position of IPC0 (IPC0<2:0>).

#### 7.4.6 STATUS/CONTROL REGISTERS

Although these registers are not specifically part of the interrupt control hardware, two of the CPU Control registers contain bits that control interrupt functionality. For more information on these registers refer to "**CPU**" (DS70359) in the "dsPIC33/PIC24 Family Reference Manual".

- The CPU STATUS Register, SR, contains the IPL<2:0> bits (SR<7:5>). These bits indicate the current CPU Interrupt Priority Level. The user software can change the current CPU Interrupt Priority Level by writing to the IPLx bits.
- The CORCON register contains the IPL3 bit which, together with IPL<2:0>, also indicates the current CPU priority level. IPL3 is a read-only bit so that trap events cannot be masked by the user software.

All Interrupt registers are described in Register 7-3 through Register 7-7 in the following pages.

# 12.2 Timer1 Control Register

| R/W-0              | U-0                                      | R/W-0                               | U-0                         | U-0                              | U-0                       | U-0                | U-0         |
|--------------------|------------------------------------------|-------------------------------------|-----------------------------|----------------------------------|---------------------------|--------------------|-------------|
| TON <sup>(1)</sup> | —                                        | TSIDL                               | —                           | _                                | —                         | —                  | —           |
| bit 15             |                                          |                                     |                             |                                  |                           |                    | bit 8       |
|                    |                                          |                                     |                             |                                  |                           |                    |             |
| U-0                | R/W-0                                    | R/W-0                               | R/W-0                       | U-0                              | R/W-0                     | R/W-0              | U-0         |
|                    | TGATE                                    | TCKPS1                              | TCKPS0                      | _                                | TSYNC <sup>(1)</sup>      | TCS <sup>(1)</sup> | —           |
| bit 7              |                                          |                                     |                             |                                  |                           |                    | bit 0       |
|                    |                                          |                                     |                             |                                  |                           |                    |             |
| Legend:            |                                          |                                     |                             |                                  |                           |                    |             |
| R = Readab         | ole bit                                  | W = Writable                        | bit                         | U = Unimpler                     | mented bit, read          | as '0'             |             |
| -n = Value a       | at POR                                   | '1' = Bit is set                    |                             | '0' = Bit is cle                 | ared                      | x = Bit is unkn    | own         |
|                    |                                          | (1)                                 |                             |                                  |                           |                    |             |
| bit 15             | TON: Timer1                              | On bit <sup>(1)</sup>               |                             |                                  |                           |                    |             |
|                    | 1 = Starts 16-                           | bit Limer1<br>bit Timer1            |                             |                                  |                           |                    |             |
| bit 1/             | Unimplement                              | ted: Pead as '                      | ı'                          |                                  |                           |                    |             |
| bit 13             |                                          | 1 Stop in Idle N                    | /ode hit                    |                                  |                           |                    |             |
| DIC 15             | 1 = Discontinu                           | i stop in lae k                     | eration when a              | device enters l                  | dle mode                  |                    |             |
|                    | 0 = Continues                            | module opera                        | tion in Idle mo             | ode                              |                           |                    |             |
| bit 12-7           | Unimplement                              | ted: Read as '                      | )'                          |                                  |                           |                    |             |
| bit 6              | TGATE: Time                              | r1 Gated Time                       | Accumulation                | Enable bit                       |                           |                    |             |
|                    | When TCS =                               | <u>1:</u><br>prod                   |                             |                                  |                           |                    |             |
|                    | When TCS =                               | 0.<br>0.                            |                             |                                  |                           |                    |             |
|                    | 1 = Gated tim                            | <u>e</u> accumulatior               | n is enabled                |                                  |                           |                    |             |
|                    | 0 = Gated tim                            | e accumulatior                      | n is disabled               |                                  |                           |                    |             |
| bit 5-4            | TCKPS<1:0>                               | : Timer1 Input                      | Clock Prescal               | e Select bits                    |                           |                    |             |
|                    | 11 = 1:256                               |                                     |                             |                                  |                           |                    |             |
|                    | 10 = 1:64<br>01 = 1:8                    |                                     |                             |                                  |                           |                    |             |
|                    | 01 = 1.0<br>00 = 1.1                     |                                     |                             |                                  |                           |                    |             |
| bit 3              | Unimplement                              | ted: Read as '                      | )'                          |                                  |                           |                    |             |
| bit 2              | TSYNC: Time                              | er1 External Clo                    | ock Input Sync              | chronization Se                  | elect bit <sup>(1)</sup>  |                    |             |
|                    | When TCS =                               | 1:                                  |                             |                                  |                           |                    |             |
|                    | 1 = Synchroni                            | izes external cl                    | ock input                   |                                  |                           |                    |             |
|                    | 0 = Does not                             | synchronize ex                      | ternal clock in             | nput                             |                           |                    |             |
|                    | This bit is jand                         | <u>ored</u> .                       |                             |                                  |                           |                    |             |
| bit 1              | TCS: Timer1 (                            | Clock Source S                      | Select bit <sup>(1)</sup>   |                                  |                           |                    |             |
|                    | 1 = External c                           | lock is from pir                    | n, T1CK (on th              | ne rising edge)                  |                           |                    |             |
|                    | 0 = Internal cl                          | ock (FP)                            |                             | 5 5-7                            |                           |                    |             |
| bit 0              | Unimplement                              | ted: Read as '                      | )'                          |                                  |                           |                    |             |
| Note 1: \          | When Timer1 is en<br>attempts by user so | abled in Exterr<br>oftware to write | al Synchrono<br>to the TMR1 | us Counter mo<br>register are ig | ode (TCS = 1, T<br>nored. | SYNC = 1, TO       | N = 1), any |

#### REGISTER 12-1: T1CON: TIMER1 CONTROL REGISTER

© 2011-2013 Microchip Technology Inc.

# dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| U-0             | U-0   | U-0              | U-0   | R/W-0            | R/W-0           | R/W-0           | R/W-0 |
|-----------------|-------|------------------|-------|------------------|-----------------|-----------------|-------|
| —               | —     | —                | _     |                  | LEB             | <11:8>          |       |
| 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 |
|                 |       |                  | LEE   | 3<7:0>           |                 |                 |       |
| bit 7           |       |                  |       |                  |                 |                 | bit 0 |
|                 |       |                  |       |                  |                 |                 |       |
| Legend:         |       |                  |       |                  |                 |                 |       |
| R = Readable    | bit   | W = Writable     | bit   | U = Unimpler     | nented bit, rea | d as '0'        |       |
| -n = Value at F | POR   | '1' = Bit is set |       | '0' = Bit is cle | ared            | x = Bit is unkr | nown  |
|                 |       |                  |       |                  |                 |                 |       |
|                 |       |                  |       |                  |                 |                 |       |

### REGISTER 16-17: LEBDLYx: PWMx LEADING-EDGE BLANKING DELAY REGISTER

bit 15-12 Unimplemented: Read as '0'

bit 11-0 LEB<11:0>: Leading-Edge Blanking Delay for Current-Limit and Fault Inputs bits

| R/W-0        | R/W-0                                   | R/W-0                                      | R/W-0                    | R/W-0             | R/W-0             | R/W-0          | R/W-0 |
|--------------|-----------------------------------------|--------------------------------------------|--------------------------|-------------------|-------------------|----------------|-------|
| QCAPEN       | FLTREN                                  | QFDIV2                                     | QFDIV1                   | QFDIV0            | OUTFNC1           | OUTFNC0        | SWPAB |
| bit 15       |                                         |                                            |                          |                   | •<br>•            |                | bit 8 |
|              |                                         |                                            |                          |                   |                   |                |       |
| R/W-0        | R/W-0                                   | R/W-0                                      | R/W-0                    | R-x               | R-x               | R-x            | R-x   |
| HOMPOL       | IDXPOL                                  | QEBPOL                                     | QEAPOL                   | HOME              | INDEX             | QEB            | QEA   |
| bit 7        |                                         |                                            |                          |                   |                   |                | bit 0 |
|              |                                         |                                            |                          |                   |                   |                |       |
| Legend:      | a hit                                   | \// - \//ritabla                           | h it                     | II – Unimploy     | monted bit read   | 4 a.a. (0)     |       |
| n - Value at |                                         | vv = vvii(able                             | DIL                      | $0^{\circ} = 0$   | nented bit, read  | v – Ritic unkn |       |
|              |                                         | 1 - Dit 13 36t                             |                          |                   | areu              |                |       |
| bit 15       | OCAPEN: OF                              | -I Position Cou                            | nter Input Cap           | ture Enable bit   |                   |                |       |
|              | 1 = Index ma                            | tch event trigge                           | ers a position c         | apture event      |                   |                |       |
|              | 0 = Index ma                            | tch event does                             | not trigger a p          | osition capture   | event             |                |       |
| bit 14       | FLTREN: QE                              | Ax/QEBx/INDX                               | x/HOMEx Digi             | ital Filter Enabl | e bit             |                |       |
|              | 1 = Input pin                           | digital filter is e<br>digital filter is d | nabled<br>isabled (bypas | eed)              |                   |                |       |
| hit 13_11    |                                         |                                            | NDXv/HOMEv               | Digital Input Fi  | ilter Clock Divid | a Salact hits  |       |
| 511 15-11    | 111 = 1:128 (                           | clock divide                               |                          | Digital Input I   |                   |                |       |
|              | 110 <b>= 1:64 cl</b>                    | ock divide                                 |                          |                   |                   |                |       |
|              | 101 = 1:32 cl                           | ock divide                                 |                          |                   |                   |                |       |
|              | 100 = 1.16  cm<br>011 = 1:8  clo        | ck divide                                  |                          |                   |                   |                |       |
|              | 010 = 1:4 clo                           | ck divide                                  |                          |                   |                   |                |       |
|              | 001 = 1:2 clo                           | ck divide<br>ck divide                     |                          |                   |                   |                |       |
| hit 10-9     |                                         |                                            | Output Functi            | ion Mode Sele     | rt hits           |                |       |
| bit 10 5     | 11 = The CTN                            | VCMPx pin ace                              | s high when C            | $EI1LEC \ge POS$  | $S1CNT \ge QEI10$ | GEC            |       |
|              | 10 = The CTM                            | NCMPx pin goe                              | s high when P            | $OS1CNT \leq QE$  | EIILEC            |                |       |
|              | 01 = The CT                             | NCMPx pin goe                              | s high when P            | $OS1CNT \ge QE$   | EI1GEC            |                |       |
| hit 8        | SWPAB: Swa                              | OFA and OFA                                | B Innuts hit             |                   |                   |                |       |
| bit 0        | 1 = QEAx and                            | d QEBx are swa                             | apped prior to           | quadrature de     | coder logic       |                |       |
|              | 0 = QEAx and                            | d QEBx are not                             | swapped                  | 1                 |                   |                |       |
| bit 7        | HOMPOL: HO                              | OMEx Input Po                              | larity Select bit        | t                 |                   |                |       |
|              | 1 = Input is in                         | iverted                                    |                          |                   |                   |                |       |
| hit 6        |                                         | ot inverted<br>Vy Input Dolori             | ty Soloot bit            |                   |                   |                |       |
| DILO         | 1 = Input is in                         | verted                                     | ly Select bit            |                   |                   |                |       |
|              | 0 = Input is no                         | ot inverted                                |                          |                   |                   |                |       |
| bit 5        | QEBPOL: QE                              | EBx Input Polar                            | ity Select bit           |                   |                   |                |       |
|              | 1 = Input is ir                         | nverted                                    |                          |                   |                   |                |       |
| L:1 4        |                                         | ot inverted                                | :                        |                   |                   |                |       |
| DIT 4        |                                         | EAX Input Polar                            | ity Select bit           |                   |                   |                |       |
|              | 1 = 10000000000000000000000000000000000 | not inverted                               |                          |                   |                   |                |       |
| bit 3        | HOME: Statu                             | s of HOMEx In                              | out Pin After P          | olarity Control   |                   |                |       |
|              | 1 = Pin is at I                         | logic '1'                                  |                          | -                 |                   |                |       |
|              | 0 = Pin is at                           | logic '0'                                  |                          |                   |                   |                |       |

# REGISTER 17-2: QEI1IOC: QEI1 I/O CONTROL REGISTER



dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

# dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| R/W-0         | R/W                                                                                                                                                                                      | -0                                                                                            | R/W-0          | U-0          | U-0        | R/W-0             | R/W-0          | R/W-0 |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------|--------------|------------|-------------------|----------------|-------|--|--|--|
| VCFG2         | VCFC                                                                                                                                                                                     | G1                                                                                            | VCFG0          |              | —          | CSCNA             | CHPS1          | CHPS0 |  |  |  |
| bit 15        | •                                                                                                                                                                                        |                                                                                               |                |              |            | ·                 |                | bit 8 |  |  |  |
|               |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                |       |  |  |  |
| R-0           | R/W                                                                                                                                                                                      | -0                                                                                            | R/W-0          | R/W-0        | R/W-0      | R/W-0             | R/W-0          | R/W-0 |  |  |  |
| BUFS          | SMP                                                                                                                                                                                      | 14                                                                                            | SMPI3          | SMPI2        | SMPI1      | SMPI0             | BUFM           | ALTS  |  |  |  |
| bit 7         |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                | bit 0 |  |  |  |
|               |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                |       |  |  |  |
| Legend:       |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                |       |  |  |  |
| R = Readable  | e bit                                                                                                                                                                                    |                                                                                               | W = Writable   | bit          | U = Unimpl | emented bit, read | d as '0'       |       |  |  |  |
| -n = Value at | POR                                                                                                                                                                                      | PR '1' = Bit is set                                                                           |                |              |            | leared            | x = Bit is unk | nown  |  |  |  |
|               |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                |       |  |  |  |
| bit 15-13     | VCFG<                                                                                                                                                                                    | VCFG<2:0>: Converter Voltage Reference Configuration bits                                     |                |              |            |                   |                |       |  |  |  |
|               | Value                                                                                                                                                                                    |                                                                                               | VREFH          | VREFL        |            |                   |                |       |  |  |  |
|               | 000                                                                                                                                                                                      |                                                                                               | Avdd           | Avss         |            |                   |                |       |  |  |  |
|               | 001                                                                                                                                                                                      | Ext                                                                                           | ernal VREF+    | Avss         |            |                   |                |       |  |  |  |
|               | 010                                                                                                                                                                                      |                                                                                               | Avdd           | External VRE | F-         |                   |                |       |  |  |  |
|               | 011                                                                                                                                                                                      | Ext                                                                                           | ernal VREF+    | External VRE | F-         |                   |                |       |  |  |  |
|               | 1xx                                                                                                                                                                                      |                                                                                               | Avdd           | Avss         |            |                   |                |       |  |  |  |
| bit 12-11     | Unimple                                                                                                                                                                                  | emen                                                                                          | ted: Read as ' | 0'           |            |                   |                |       |  |  |  |
| bit 10        | CSCNA                                                                                                                                                                                    | CSCNA: Input Scan Select bit                                                                  |                |              |            |                   |                |       |  |  |  |
|               | 1 <b>= Sca</b>                                                                                                                                                                           | 1 = Scans inputs for CH0+ during Sample MUXA                                                  |                |              |            |                   |                |       |  |  |  |
|               | 0 = Does not scan inputs                                                                                                                                                                 |                                                                                               |                |              |            |                   |                |       |  |  |  |
| bit 9-8       | CHPS<                                                                                                                                                                                    | CHPS<1:0>: Channel Select bits                                                                |                |              |            |                   |                |       |  |  |  |
|               | <u>In 12-bit</u>                                                                                                                                                                         | In 12-bit mode (AD21B = 1), the CHPS<1:0> bits are Unimplemented and are Read as '0':         |                |              |            |                   |                |       |  |  |  |
|               | 1x = Co                                                                                                                                                                                  | 1x = Converts CH0, CH1, CH2 and CH3                                                           |                |              |            |                   |                |       |  |  |  |
|               | 01 = Converts CH0 and CH1<br>00 = Converts CH0                                                                                                                                           |                                                                                               |                |              |            |                   |                |       |  |  |  |
| bit 7         | <b>BUFS:</b> Buffer Fill Status bit (only valid when BUFM = 1)                                                                                                                           |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | 1 = ADC is currently filling the second half of the buffer; the user application should access data in the                                                                               |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | first                                                                                                                                                                                    | first half of the buffer                                                                      |                |              |            |                   |                |       |  |  |  |
|               | 0 = ADC is currently filling the first half of the buffer; the user application should access data in the                                                                                |                                                                                               |                |              |            |                   |                |       |  |  |  |
| hit 6 0       | second nait of the buffer                                                                                                                                                                |                                                                                               |                |              |            |                   |                |       |  |  |  |
| DIL 0-2       |                                                                                                                                                                                          | SMPI<4:0>: Increment Rate bits                                                                |                |              |            |                   |                |       |  |  |  |
|               | <u><b>WINER ADDIMAEN = 0:</b></u><br>x1111 = Generates interrupt after completion of every 16th sample/conversion operation                                                              |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | x1110 =                                                                                                                                                                                  | x1110 = Generates interrupt after completion of every 15th sample/conversion operation        |                |              |            |                   |                |       |  |  |  |
|               | •                                                                                                                                                                                        | •                                                                                             |                |              |            |                   |                |       |  |  |  |
|               |                                                                                                                                                                                          |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | •<br>x0001=                                                                                                                                                                              | • x0001 = Generates interrupt after completion of every 2nd sample/conversion operation       |                |              |            |                   |                |       |  |  |  |
|               | $x_{0000}$ = Generates interrupt after completion of every sample/conversion operation                                                                                                   |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | When ADDMAEN = 1:                                                                                                                                                                        |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | 11111 =                                                                                                                                                                                  | 11111 = Increments the DMA address after completion of every 32nd sample/conversion operation |                |              |            |                   |                |       |  |  |  |
|               | 11110 = Increments the DMA address after completion of every 31st sample/conversion operation                                                                                            |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | •                                                                                                                                                                                        |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | •                                                                                                                                                                                        |                                                                                               |                |              |            |                   |                |       |  |  |  |
|               | 00001 = Increments the DMA address after completion of every 2nd sample/conversion operation<br>00000 = Increments the DMA address after completion of every sample/conversion operation |                                                                                               |                |              |            |                   |                |       |  |  |  |

#### . . ACOND. ADCA CONTROL DECISTED 2

### 26.0 PROGRAMMABLE CYCLIC REDUNDANCY CHECK (CRC) GENERATOR

- Note 1: This data sheet summarizes the features of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X families of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Programmable Cyclic Redundancy Check (CRC)" (DS70346) of the "dsPIC33/PIC24 Family Reference Manual", which is available from 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.

The programmable CRC generator offers the following features:

- User-programmable (up to 32nd order) polynomial CRC equation
- Interrupt output
- Data FIFO

The programmable CRC generator provides a hardware implemented method of quickly generating checksums for various networking and security applications. It offers the following features:

- User-programmable CRC polynomial equation, up to 32 bits
- Programmable shift direction (little or big-endian)
- · Independent data and polynomial lengths
- Configurable interrupt output
- Data FIFO

A simplified block diagram of the CRC generator is shown in Figure 26-1. A simple version of the CRC shift engine is shown in Figure 26-2.



#### FIGURE 26-1: CRC BLOCK DIAGRAM

| DC CHARACTERISTICS |        |                                                                       | Standard Operating Conditions: 3.0V to 3.6V(unless otherwise stated)Operating temperature $-40^{\circ}C \le TA \le +85^{\circ}C$ for Industrial $-40^{\circ}C \le TA \le +125^{\circ}C$ for Extended |      |                       |       |                                                                                                                                      |  |
|--------------------|--------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------|--|
| Param<br>No.       | Symbol | Characteristic                                                        | Min.                                                                                                                                                                                                 | Тур. | Max.                  | Units | Conditions                                                                                                                           |  |
| DI60a              | licl   | Input Low Injection Current                                           | 0                                                                                                                                                                                                    | _    | <sub>-5</sub> (4,7)   | mA    | All pins except VDD, VSS,<br>AVDD, AVSS, MCLR, VCAP<br>and RB7                                                                       |  |
| DI60b              | Іісн   | Input High Injection Current                                          | 0                                                                                                                                                                                                    | _    | +5 <sup>(5,6,7)</sup> | mA    | All pins except VDD, VSS,<br>AVDD, AVSS, MCLR, VCAP,<br>RB7 and all 5V tolerant<br>pins <sup>(6)</sup>                               |  |
| DI60c              | ∑lict  | Total Input Injection Current<br>(sum of all I/O and control<br>pins) | -20 <sup>(8)</sup>                                                                                                                                                                                   | _    | +20(8)                | mA    | Absolute instantaneous sum<br>of all $\pm$ input injection cur-<br>rents from all I/O pins<br>(   IICL +   IICH   ) $\leq \sum$ IICT |  |

#### TABLE 30-11: DC CHARACTERISTICS: I/O PIN INPUT SPECIFICATIONS (CONTINUED)

**Note 1:** The leakage current on the MCLR pin is strongly dependent on the applied voltage level. The specified levels represent normal operating conditions. Higher leakage current can be measured at different input voltages.

2: Negative current is defined as current sourced by the pin.

3: See the "Pin Diagrams" section for the 5V tolerant I/O pins.

4: VIL source < (Vss – 0.3). Characterized but not tested.

5: Non-5V tolerant pins VIH source > (VDD + 0.3), 5V tolerant pins VIH source > 5.5V. Characterized but not tested.

6: Digital 5V tolerant pins cannot tolerate any "positive" input injection current from input sources > 5.5V.

7: Non-zero injection currents can affect the ADC results by approximately 4-6 counts.

8: Any number and/or combination of I/O pins not excluded under IICL or IICH conditions are permitted provided the mathematical "absolute instantaneous" sum of the input injection currents from all pins do not exceed the specified limit. Characterized but not tested.

### FIGURE 30-7: OUTPUT COMPARE x MODULE (OCx) TIMING CHARACTERISTICS



#### TABLE 30-27: OUTPUT COMPARE x MODULE TIMING REQUIREMENTS

| AC CHARACTERISTICS |        |                               | $\begin{array}{l} \mbox{Standard Operating Conditions: 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array}$ |      |      |                       |                    |  |  |
|--------------------|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-----------------------|--------------------|--|--|
| Param<br>No.       | Symbol | Characteristic <sup>(1)</sup> | Min.                                                                                                                                                                                                                                                                                  | Тур. | Max. | Units                 | Conditions         |  |  |
| OC10               | TccF   | OCx Output Fall Time          | —                                                                                                                                                                                                                                                                                     |      |      | ns                    | See Parameter DO32 |  |  |
| OC11               | TccR   | OCx Output Rise Time          | —                                                                                                                                                                                                                                                                                     | —    | —    | ns See Parameter DO31 |                    |  |  |

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

#### FIGURE 30-8: OCx/PWMx MODULE TIMING CHARACTERISTICS



#### TABLE 30-28: OCx/PWMx MODE TIMING REQUIREMENTS

| AC CHARACTERISTICS |        |                                   | $ \begin{array}{l} \mbox{Standard Operating Conditions: 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ & -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array} $ |      |          |            |  |
|--------------------|--------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------------|--|
| Param<br>No.       | Symbol | Characteristic <sup>(1)</sup>     | Min.                                                                                                                                                                                                                                                                                      | Тур. | Units    | Conditions |  |
| OC15               | Tfd    | Fault Input to PWMx I/O<br>Change | —                                                                                                                                                                                                                                                                                         | _    | Tcy + 20 | ns         |  |
| OC20               | TFLT   | Fault Input Pulse Width           | Tcy + 20                                                                                                                                                                                                                                                                                  | _    | —        | ns         |  |

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

# TABLE 30-47:SPI1 SLAVE MODE (FULL-DUPLEX, CKE = 0, CKP = 1, SMP = 0)TIMING REQUIREMENTS

| AC CHARACTERISTICS |                       |                                                 | $\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 <sup>(1)</sup>                   | Min.                                                                                                                                                                                                                                                                                | Typ. <sup>(2)</sup> | Max. | Units | Conditions                     |  |
| SP70               | FscP                  | Maximum SCK1 Input Frequency                    | —                                                                                                                                                                                                                                                                                   | —                   | 15   | MHz   | (Note 3)                       |  |
| SP72               | TscF                  | SCK1 Input Fall Time                            | —                                                                                                                                                                                                                                                                                   | -                   | _    | ns    | See Parameter DO32<br>(Note 4) |  |
| SP73               | TscR                  | SCK1 Input Rise Time                            | _                                                                                                                                                                                                                                                                                   | —                   | —    | ns    | See Parameter DO31<br>(Note 4) |  |
| SP30               | TdoF                  | SDO1 Data Output Fall Time                      |                                                                                                                                                                                                                                                                                     |                     | _    | ns    | See Parameter DO32<br>(Note 4) |  |
| SP31               | TdoR                  | SDO1 Data Output Rise Time                      | —                                                                                                                                                                                                                                                                                   | -                   | _    | ns    | See Parameter DO31<br>(Note 4) |  |
| SP35               | TscH2doV,<br>TscL2doV | SDO1 Data Output Valid after<br>SCK1 Edge       | —                                                                                                                                                                                                                                                                                   | 6                   | 20   | ns    |                                |  |
| SP36               | TdoV2scH,<br>TdoV2scL | SDO1 Data Output Setup to<br>First SCK1 Edge    | 30                                                                                                                                                                                                                                                                                  | _                   | _    | ns    |                                |  |
| SP40               | TdiV2scH,<br>TdiV2scL | Setup Time of SDI1 Data Input to SCK1 Edge      | 30                                                                                                                                                                                                                                                                                  | _                   | _    | ns    |                                |  |
| SP41               | TscH2diL,<br>TscL2diL | Hold Time of SDI1 Data Input to SCK1 Edge       | 30                                                                                                                                                                                                                                                                                  | —                   | _    | ns    |                                |  |
| SP50               | TssL2scH,<br>TssL2scL | $\overline{SS1}$ ↓ to SCK1 ↑ or SCK1 ↓<br>Input | 120                                                                                                                                                                                                                                                                                 |                     | —    | ns    |                                |  |
| SP51               | TssH2doZ              | SS1 ↑ to SDO1 Output<br>High-Impedance          | 10                                                                                                                                                                                                                                                                                  | —                   | 50   | ns    | (Note 4)                       |  |
| SP52               | TscH2ssH,<br>TscL2ssH | SS1 ↑ after SCK1 Edge                           | 1.5 Tcy + 40                                                                                                                                                                                                                                                                        | —                   | _    | ns    | (Note 4)                       |  |

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

2: Data in "Typical" column is at 3.3V, +25°C unless otherwise stated.

**3:** The minimum clock period for SCK1 is 66.7 ns. Therefore, the SCK1 clock generated by the master must not violate this specification.

4: Assumes 50 pF load on all SPI1 pins.

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

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



|                          | Units            | MILLIMETERS |       |       |  |  |  |
|--------------------------|------------------|-------------|-------|-------|--|--|--|
| Dimension                | Dimension Limits |             |       | MAX   |  |  |  |
| Number of Pins           | Ν                | 28          |       |       |  |  |  |
| Pitch                    | е                | 0.65 BSC    |       |       |  |  |  |
| Overall Height           | Α                | -           | -     | 2.00  |  |  |  |
| Molded Package Thickness | A2               | 1.65        | 1.75  | 1.85  |  |  |  |
| Standoff                 | A1               | 0.05        | -     | -     |  |  |  |
| Overall Width            | E                | 7.40        | 7.80  | 8.20  |  |  |  |
| Molded Package Width     | E1               | 5.00        | 5.30  | 5.60  |  |  |  |
| Overall Length           | D                | 9.90        | 10.20 | 10.50 |  |  |  |
| Foot Length              | L                | 0.55        | 0.75  | 0.95  |  |  |  |
| Footprint                | L1               | 1.25 REF    |       |       |  |  |  |
| Lead Thickness           | с                | 0.09        | -     | 0.25  |  |  |  |
| Foot Angle               | ¢                | 0°          | 4°    | 8°    |  |  |  |
| Lead Width               | b                | 0.22        | _     | 0.38  |  |  |  |

#### Notes:

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

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

- 3. 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-073B

# 36-Terminal Very Thin Thermal Leadless Array Package (TL) – 5x5x0.9 mm Body with Exposed Pad [VTLA]

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



Microchip Technology Drawing C04-187C Sheet 1 of 2



### 44-Lead Plastic Quad Flat, No Lead Package (ML) - 8x8 mm Body [QFN]

Note:

Microchip Technology Drawing C04-103C Sheet 1 of 2