

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             | PIC                                                                            |
| Core Size                  | 16-Bit                                                                         |
| Speed                      | 70 MIPs                                                                        |
| Connectivity               | I <sup>2</sup> C, IrDA, LINbus, SPI, UART/USART                                |
| Peripherals                | Brown-out Detect/Reset, DMA, POR, PWM, WDT                                     |
| Number of I/O              | 35                                                                             |
| Program Memory Size        | 512KB (170K x 24)                                                              |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | -                                                                              |
| RAM Size                   | 24K x 16                                                                       |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                                      |
| Data Converters            | A/D 9x10b/12b                                                                  |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 44-TQFP                                                                        |
| Supplier Device Package    | 44-TQFP (10x10)                                                                |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24ep512gp204-i-pt |
|                            |                                                                                |

Email: info@E-XFL.COM

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



#### FIGURE 4-5: PROGRAM MEMORY MAP FOR dsPIC33EP512GP50X, dsPIC33EP512MC20X/50X AND PIC24EP512GP/MC20X DEVICES

| IABLE 4   | -14:  | PVVIVI G | ENERA  | IUR Z R | EGIST     |                                                        | FOR as                                     | PIC33EP  |            | 202/202   |          | 16246 | PXXX    |          |          | CES ONL | _ T     |               |
|-----------|-------|----------|--------|---------|-----------|--------------------------------------------------------|--------------------------------------------|----------|------------|-----------|----------|-------|---------|----------|----------|---------|---------|---------------|
| 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 |
| PWMCON2   | 0C40  | FLTSTAT  | CLSTAT | TRGSTAT | FLTIEN    | CLIEN                                                  | TRGIEN                                     | ITB      | MDCS       | DTC       | <1:0>    | DTCP  | _       | MTBS     | CAM      | XPRES   | IUE     | 0000          |
| IOCON2    | 0C42  | PENH     | PENL   | POLH    | POLL      | PMOD                                                   | 0<1:0>                                     | OVRENH   | OVRENL     | OVRDA     | \T<1:0>  | FLTD  | \T<1:0> | CLDA     | AT<1:0>  | SWAP    | OSYNC   | C000          |
| FCLCON2   | 0C44  | _        |        | (       | CLSRC<4:0 | )>                                                     | CLPOL CLMOD FLTSRC<4:0> FLTPOL FLTMOD<1:0> |          |            |           |          |       | D<1:0>  | 00F8     |          |         |         |               |
| PDC2      | 0C46  |          |        |         |           |                                                        | PDC2<15:0>                                 |          |            |           |          |       |         | 0000     |          |         |         |               |
| PHASE2    | 0C48  |          |        |         |           |                                                        |                                            | Р        | HASE2<15:0 | >         |          |       |         |          |          |         |         | 0000          |
| DTR2      | 0C4A  | _        | _      |         |           |                                                        |                                            |          | [          | DTR2<13:0 | >        |       |         |          |          |         |         | 0000          |
| ALTDTR2   | 0C4C  | _        | _      |         |           |                                                        |                                            |          | AL         | TDTR2<13  | :0>      |       |         |          |          |         |         | 0000          |
| TRIG2     | 0C52  |          |        |         |           |                                                        |                                            | TI       | RGCMP<15:0 | )>        |          |       |         |          |          |         |         | 0000          |
| TRGCON2   | 0C54  |          | TRGDI  | V<3:0>  |           | _                                                      | —                                          | _        | _          | _         | -        |       |         | TRO      | GSTRT<5: | 0>      |         | 0000          |
| LEBCON2   | 0C5A  | PHR      | PHF    | PLR     | PLF       | F FLTLEBEN CLLEBEN — — — — BCH BCL BPHH BPHL BPLH BPLL |                                            |          |            |           |          | BPLL  | 0000    |          |          |         |         |               |
| LEBDLY2   | 0C5C  | _        | _      | _       | _         |                                                        |                                            |          |            |           | LEB<11:0 | )>    |         |          |          |         |         | 0000          |
| AUXCON2   | 0C5E  | _        | _      | —       | —         |                                                        | BLANK                                      | SEL<3:0> |            | _         | —        |       | CHOPS   | SEL<3:0> |          | CHOPHEN | CHOPLEN | 0000          |

I- DIGGOEDV/VMOGOV/EGV AND DIGGOEDV/VMOGOV DEVICED ONLY

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

## TABLE 4-15: PWM GENERATOR 3 REGISTER MAP FOR dsPIC33EPXXXMC20X/50X AND PIC24EPXXXMC20X DEVICES ONLY

| 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 |
|-----------|-------|---------|--------|---------|-----------|----------------------------------------------------|--------|--------|-------------|-----------|--------|---------|---------|-------|----------|-------|--------|---------------|
| PWMCON3   | 0C60  | FLTSTAT | CLSTAT | TRGSTAT | FLTIEN    | CLIEN                                              | TRGIEN | ITB    | MDCS        | DTC<      | <1:0>  | DTCP    | —       | MTBS  | CAM      | XPRES | IUE    | 0000          |
| IOCON3    | 0C62  | PENH    | PENL   | POLH    | POLL      | PMOD                                               | )<1:0> | OVRENH | OVRENL      | OVRDA     | T<1:0> | FLTD    | AT<1:0> | CLD   | AT<1:0>  | SWAP  | OSYNC  | C000          |
| FCLCON3   | 0C64  |         |        | (       | CLSRC<4:0 | )>                                                 |        | CLPOL  | CLMOD       |           | FLT    | SRC<4:0 | >       |       | FLTPOL   | FLTMO | D<1:0> | 00F8          |
| PDC3      | 0C66  |         |        |         |           |                                                    |        |        | PDC3<15:0>  | •         |        |         |         |       |          |       |        | 0000          |
| PHASE3    | 0C68  |         |        |         |           |                                                    |        | F      | PHASE3<15:0 | )>        |        |         |         |       |          |       |        | 0000          |
| DTR3      | 0C6A  |         | —      |         |           |                                                    |        |        | [           | DTR3<13:0 | >      |         |         |       |          |       |        | 0000          |
| ALTDTR3   | 0C6C  |         | —      |         |           |                                                    |        |        | AL          | TDTR3<13  | :0>    |         |         |       |          |       |        | 0000          |
| TRIG3     | 0C72  |         |        |         |           |                                                    |        | Т      | RGCMP<15:   | 0>        |        |         |         |       |          |       |        | 0000          |
| TRGCON3   | 0C74  |         | TRGDI  | V<3:0>  |           | _                                                  | _      | _      | _           | _         | _      |         |         | TR    | GSTRT<5: | 0>    |        | 0000          |
| LEBCON3   | 0C7A  | PHR     | PHF    | PLR     | PLF       | FLTLEBEN CLLEBEN — — — BCH BCL BPHH BPHL BPLH BPLL |        |        |             |           |        | 0000    |         |       |          |       |        |               |
| LEBDLY3   | 0C7C  |         | —      | _       | _         | LEB<11:0>(                                         |        |        |             |           |        | 0000    |         |       |          |       |        |               |
| AUXCON3   | 0C7E  |         | —      | —       | —         | BLANKSEL<3:0> — — CHOPSEL<3:0> CHOPHEN CHOPLEN C   |        |        |             |           |        | 0000    |         |       |          |       |        |               |

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

.

----

.

#### TABLE 4-42: OP AMP/COMPARATOR 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 |
|--------------------------|-------|--------|--------|--------|--------|--------|---------|---------|-------|-------|--------|----------|-------|---------|--------|-----------|-------|---------------|
| CMSTAT                   | 0A80  | PSIDL  | _      | -      | —      | C4EVT  | C3EVT   | C2EVT   | C1EVT | —     | -      | —        | —     | C4OUT   | C3OUT  | C2OUT     | C10UT | 0000          |
| CVRCON                   | 0A82  |        | CVR2OE | _      | _      | _      | VREFSEL | _       | _     | CVREN | CVR10E | CVRR     | CVRSS |         | CVR<   | 3:0>      |       | 0000          |
| CM1CON                   | 0A84  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | _       | _      | CCH       | <1:0> | 0000          |
| CM1MSKSRC                | 0A86  |        | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM1MSKCON                | 0A88  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM1FLTR                  | 0A8A  |        | _      | _      | _      | _      | _       | _       | _     | _     | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM2CON                   | 0A8C  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | _       | _      | CCH       | <1:0> | 0000          |
| CM2MSKSRC                | 0A8E  |        | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM2MSKCON                | 0A90  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM2FLTR                  | 0A92  | _      | _      | _      | _      | _      | _       | _       | _     |       | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM3CON <sup>(1)</sup>    | 0A94  | CON    | COE    | CPOL   | _      | _      | OPMODE  | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | _       | _      | CCH       | <1:0> | 0000          |
| CM3MSKSRC(1)             | 0A96  | _      | _      | _      | _      |        | SELSR   | CC<3:0> |       |       | SELSRC | B<3:0>   |       |         | SELSRC | A<3:0>    |       | 0000          |
| CM3MSKCON <sup>(1)</sup> | 0A98  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM3FLTR <sup>(1)</sup>   | 0A9A  | _      | _      | _      | _      | _      | _       | _       | _     |       | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |
| CM4CON                   | 0A9C  | CON    | COE    | CPOL   | _      | _      | _       | CEVT    | COUT  | EVPOL | _<1:0> | _        | CREF  | _       | _      | CCH       | <1:0> | 0000          |
| CM4MSKSRC                | 0A9E  | _      | _      |        |        |        | SELSR   | CC<3:0> | -     |       | SELSRC | B<3:0>   | •     |         | SELSRC | A<3:0>    |       | 0000          |
| CM4MSKCON                | 0AA0  | HLMS   | _      | OCEN   | OCNEN  | OBEN   | OBNEN   | OAEN    | OANEN | NAGS  | PAGS   | ACEN     | ACNEN | ABEN    | ABNEN  | AAEN      | AANEN | 0000          |
| CM4FLTR                  | 0AA2  | _      | _      |        | _      | _      | _       | _       | _     | —     | C      | FSEL<2:0 | >     | CFLTREN | (      | CFDIV<2:0 | >     | 0000          |

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

Note 1: These registers are unavailable on dsPIC33EPXXXGP502/MC502/MC502/MC202 and PIC24EP256GP/MC202 (28-pin) devices.

#### TABLE 4-43: CTMU REGISTER MAP

| File N | lame | 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 |
|--------|------|-------|---------|---------|----------|--------|----------|----------|----------|----------|---------|---------|-------|-------|---------|-------|-------|-------|---------------|
| CTMUC  | CON1 | 033A  | CTMUEN  | —       | CTMUSIDL | TGEN   | EDGEN    | EDGSEQEN | IDISSEN  | CTTRIG   | _       | _       | _     | _     | _       | _     | _     | _     | 0000          |
| CTMUC  | CON2 | 033C  | EDG1MOD | EDG1POL |          | EDG1   | SEL<3:0> |          | EDG2STAT | EDG1STAT | EDG2MOD | EDG2POL |       | EDG2S | EL<3:0> |       | _     | -     | 0000          |
| CTMU   | ICON | 033E  |         |         | ITRIM<5  | 5:0>   |          |          | IRNG     | <1:0>    |         | _       | _     | _     | _       | _     | -     | _     | 0000          |

dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

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

## TABLE 4-44: JTAG INTERFACE 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 |
|-----------|------|--------|--------|--------|--------|--------|-----------------|-------|-------|-------|--------|---------|-------|-------|-------|-------|-------|---------------|
| JDATAH    | 0FF0 | _      | —      | _      | _      |        |                 |       |       |       | JDATAH | <27:16> |       |       |       |       |       | xxxx          |
| JDATAL    | 0FF2 |        |        |        |        |        | JDATAL<15:0> 00 |       |       |       |        |         |       | 0000  |       |       |       |               |

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

DS70000657H-page 97

## 5.2 RTSP Operation

RTSP allows the user application to erase a single page of memory and to program two instruction words at a time. See the General Purpose and Motor Control Family tables (Table 1 and Table 2, respectively) for the page sizes of each device.

For more information on erasing and programming Flash memory, refer to "Flash Programming" (DS70609) in the "dsPIC33/PIC24 Family Reference Manual".

## 5.3 **Programming Operations**

A complete programming sequence is necessary for programming or erasing the internal Flash in RTSP mode. The processor stalls (waits) until the programming operation is finished.

For erase and program times, refer to Parameters D137a and D137b (Page Erase Time), and D138a and D138b (Word Write Cycle Time) in Table 30-14 in **Section 30.0 "Electrical Characteristics"**.

Setting the WR bit (NVMCON<15>) starts the operation and the WR bit is automatically cleared when the operation is finished.

#### 5.3.1 PROGRAMMING ALGORITHM FOR FLASH PROGRAM MEMORY

Programmers can program two adjacent words (24 bits x 2) of program Flash memory at a time on every other word address boundary (0x000002, 0x000006, 0x00000A, etc.). To do this, it is necessary to erase the page that contains the desired address of the location the user wants to change.

For protection against accidental operations, the write initiate sequence for NVMKEY must be used to allow any erase or program operation to proceed. After the programming command has been executed, the user application must wait for the programming time until programming is complete. The two instructions following the start of the programming sequence should be NOPS.

Refer to **Flash Programming**" (DS70609) in the "*dsPIC33/PIC24 Family Reference Manual*" for details and codes examples on programming using RTSP.

## 5.4 Flash Memory Resources

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

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

#### 5.4.1 KEY RESOURCES

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

## 5.5 Control Registers

Four SFRs are used to erase and write the program Flash memory: NVMCON, NVMKEY, NVMADRH and NVMADRL.

The NVMCON register (Register 5-1) enables and initiates Flash memory erase and write operations.

NVMKEY (Register 5-4) is a write-only register that is used for write protection. To start a programming or erase sequence, the user application must consecutively write 0x55 and 0xAA to the NVMKEY register.

There are two NVM Address registers: NVMADRH and NVMADRL. These two registers, when concatenated, form the 24-bit Effective Address (EA) of the selected word for programming operations or the selected page for erase operations.

The NVMADRH register is used to hold the upper 8 bits of the EA, while the NVMADRL register is used to hold the lower 16 bits of the EA.

# dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| U-0    | U-0   | U-0   | U-0   | U-0        | U-0   | U-0   | U-0   |
|--------|-------|-------|-------|------------|-------|-------|-------|
| —      | —     |       |       | —          | —     | —     | —     |
| bit 15 |       |       |       |            |       |       | bit 8 |
|        |       |       |       |            |       |       |       |
| U-0    | R/W-0 | R/W-0 | R/W-0 | R/W-0      | R/W-0 | R/W-0 | R/W-0 |
| —      |       |       |       | U1RXR<6:0> | >     |       |       |
| bit 7  |       |       |       |            |       |       | bit 0 |
|        |       |       |       |            |       |       |       |

#### REGISTER 11-10: RPINR18: PERIPHERAL PIN SELECT INPUT REGISTER 18

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

bit 15-7 Unimplemented: Read as '0' bit 6-0 U1RXR<6:0>: Assign UART1 Receive (U1RX) to the Corresponding RPn Pin bits (see Table 11-2 for input pin selection numbers) 1111001 = Input tied to RPI121 . . . . . . . . . .

#### REGISTER 11-11: RPINR19: PERIPHERAL PIN SELECT INPUT REGISTER 19

| U-0     | U-0   | U-0   | U-0   | U-0        | U-0   | U-0   | U-0   |
|---------|-------|-------|-------|------------|-------|-------|-------|
| 0-0     | 0-0   | 0-0   | 0-0   | 0-0        | 0-0   | 0-0   | 0-0   |
|         | —     |       | _     | _          | —     | —     |       |
| bit 15  |       |       |       |            |       |       | bit 8 |
|         |       |       |       |            |       |       |       |
| U-0     | R/W-0 | R/W-0 | R/W-0 | R/W-0      | R/W-0 | R/W-0 | R/W-0 |
| —       |       |       |       | U2RXR<6:0> | >     |       |       |
| bit 7   |       |       |       |            |       |       | bit 0 |
|         |       |       |       |            |       |       |       |
| Legend: |       |       |       |            |       |       |       |
|         |       |       |       |            |       |       |       |

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

bit 15-7 Unimplemented: Read as '0'

<sup>0000000 =</sup> Input tied to Vss

# dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

| U-0             | U-0        | R/W-0                               | R/W-0 | R/W-0                    | R/W-0            | R/W-0           | R/W-0 |
|-----------------|------------|-------------------------------------|-------|--------------------------|------------------|-----------------|-------|
| —               | —          |                                     |       | RP57                     | R<5:0>           |                 |       |
| bit 15          |            |                                     |       |                          |                  |                 | bit 8 |
|                 |            |                                     |       |                          |                  |                 |       |
| U-0             | U-0        | R/W-0                               | R/W-0 | R/W-0                    | R/W-0            | R/W-0           | R/W-0 |
| _               | —          |                                     |       | RP56                     | R<5:0>           |                 |       |
| bit 7           |            |                                     |       |                          |                  |                 | bit 0 |
|                 |            |                                     |       |                          |                  |                 |       |
| Legend:         |            |                                     |       |                          |                  |                 |       |
| R = Readable I  | bit        | W = Writable                        | bit   | U = Unimplen             | nented bit, read | d as '0'        |       |
| -n = Value at P | OR         | '1' = Bit is set                    | :     | '0' = Bit is clea        | ared             | x = Bit is unkr | iown  |
|                 |            |                                     |       |                          |                  |                 |       |
| bit 15-14       | Unimplemen | ted: Read as '                      | 0'    |                          |                  |                 |       |
| bit 13-8        |            | : Peripheral Ou<br>-3 for periphera |       | is Assigned to<br>mbers) | RP57 Output F    | Pin bits        |       |
| bit 7-6         | Unimplemen | ted: Read as '                      | 0'    |                          |                  |                 |       |

## REGISTER 11-24: RPOR6: PERIPHERAL PIN SELECT OUTPUT REGISTER 6

| (see Table 11-3 for peripheral function numbers) |
|--------------------------------------------------|
|                                                  |

### REGISTER 11-25: RPOR7: PERIPHERAL PIN SELECT OUTPUT REGISTER 7

| U-0    | U-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0  | R/W-0 | R/W-0 |
|--------|-----|-------|-------|-------|--------|-------|-------|
| —      | —   |       |       | RP97  | R<5:0> |       |       |
| bit 15 |     |       |       |       |        |       | bit 8 |

RP56R<5:0>: Peripheral Output Function is Assigned to RP56 Output Pin bits

| U-0   | U-0 | U-0 | U-0 | U-0 | U-0 | U-0 | U-0   |
|-------|-----|-----|-----|-----|-----|-----|-------|
| —     | —   | —   |     | —   | —   |     | —     |
| bit 7 |     |     |     |     |     |     | bit 0 |

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

bit 15-14 Unimplemented: Read as '0'

bit 13-8 **RP97R<5:0>:** Peripheral Output Function is Assigned to RP97 Output Pin bits (see Table 11-3 for peripheral function numbers)

bit 7-0 Unimplemented: Read as '0'

bit 5-0

# 13.0 TIMER2/3 AND TIMER4/5

- Note 1: This data sheet summarizes the features of the dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X and PIC24EPXXXGP/MC20X family of devices. It is not intended to be a comprehensive reference source. To complement the information in this data sheet, refer to "Timers" (DS70362) of the "dsPIC33/PIC24 Family Reference Manual", which is available from the Microchip web site (www.microchip.com).
  - 2: Some registers and associated bits described in this section may not be available on all devices. Refer to **Section 4.0 "Memory Organization"** in this data sheet for device-specific register and bit information.

The Timer2/3 and Timer4/5 modules are 32-bit timers, which can also be configured as four independent 16-bit timers with selectable operating modes.

As 32-bit timers, Timer2/3 and Timer4/5 operate in three modes:

- Two Independent 16-Bit Timers (e.g., Timer2 and Timer3) with all 16-Bit Operating modes (except Asynchronous Counter mode)
- Single 32-Bit Timer
- Single 32-Bit Synchronous Counter
- They also support these features:
- Timer Gate Operation
- Selectable Prescaler Settings
- Timer Operation during Idle and Sleep modes
- Interrupt on a 32-Bit Period Register Match
- Time Base for Input Capture and Output Compare Modules (Timer2 and Timer3 only)
- ADC1 Event Trigger (32-bit timer pairs, and Timer3 and Timer5 only)

Individually, all four of the 16-bit timers can function as synchronous timers or counters. They also offer the features listed previously, except for the event trigger; this is implemented only with Timer2/3. The operating modes and enabled features are determined by setting the appropriate bit(s) in the T2CON, T3CON, and T4CON, T5CON registers. T2CON and T4CON are shown in generic form in Register 13-1. T3CON and T5CON are shown in Register 13-2.

For 32-bit timer/counter operation, Timer2 and Timer4 are the least significant word (lsw); Timer3 and Timer5 are the most significant word (msw) of the 32-bit timers.

Note: For 32-bit operation, T3CON and T5CON control bits are ignored. Only T2CON and T4CON control bits are used for setup and control. Timer2 and Timer4 clock and gate inputs are utilized for the 32-bit timer modules, but an interrupt is generated with the Timer3 and Timer5 interrupt flags.

A block diagram for an example 32-bit timer pair (Timer2/3 and Timer4/5) is shown in Figure 13-3.

**Note:** Only Timer2, 3, 4 and 5 can trigger a DMA data transfer.

# 16.0 HIGH-SPEED PWM MODULE (dsPIC33EPXXXMC20X/50X AND PIC24EPXXXMC20X DEVICES ONLY)

- 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 "High-Speed PWM" (DS70645) in 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 dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices support a dedicated Pulse-Width Modulation (PWM) module with up to 6 outputs.

The high-speed PWMx module consists of the following major features:

- Three PWM generators
- Two PWM outputs per PWM generator
- Individual period and duty cycle for each PWM pair
- Duty cycle, dead time, phase shift and frequency resolution of Tcy/2 (7.14 ns at Fcy = 70MHz)
- Independent Fault and current-limit inputs for six PWM outputs
- · Redundant output
- Center-Aligned PWM mode
- Output override control
- Chop mode (also known as Gated mode)
- Special Event Trigger
- Prescaler for input clock
- PWMxL and PWMxH output pin swapping
- Independent PWM frequency, duty cycle and phase-shift changes for each PWM generator
- Dead-time compensation
- Enhanced Leading-Edge Blanking (LEB) functionality
- Frequency resolution enhancement
- PWM capture functionality

**Note:** In Edge-Aligned PWM mode, the duty cycle, dead time, phase shift and frequency resolution are 8.32 ns.

The high-speed PWMx module contains up to three PWM generators. Each PWM generator provides two PWM outputs: PWMxH and PWMxL. The master time base generator provides a synchronous signal as a common time base to synchronize the various PWM outputs. The individual PWM outputs are available on the output pins of the device. The input Fault signals and current-limit signals, when enabled, can monitor and protect the system by placing the PWM outputs into a known "safe" state.

Each PWMx can generate a trigger to the ADC module to sample the analog signal at a specific instance during the PWM period. In addition, the high-speed PWMx module also generates a Special Event Trigger to the ADC module based on either of the two master time bases.

The high-speed PWMx module can synchronize itself with an external signal or can act as a synchronizing source to any external device. The SYNCI1 input pin that utilizes PPS, can synchronize the high-speed PWMx module with an external signal. The SYNC01 pin is an output pin that provides a synchronous signal to an external device.

Figure 16-1 illustrates an architectural overview of the high-speed PWMx module and its interconnection with the CPU and other peripherals.

## 16.1 PWM Faults

The PWMx module incorporates multiple external Fault inputs to include FLT1 and FLT2 which are remappable using the PPS feature, FLT3 and FLT4 which are available only on the larger 44-pin and 64-pin packages, and FLT32 which has been implemented with Class B safety features, and is available on a fixed pin on all dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices.

These Faults provide a safe and reliable way to safely shut down the PWM outputs when the Fault input is asserted.

## 16.1.1 PWM FAULTS AT RESET

During any Reset event, the PWMx module maintains ownership of the Class B Fault, FLT32. At Reset, this Fault is enabled in Latched mode to ensure the fail-safe power-up of the application. The application software must clear the PWM Fault before enabling the highspeed motor control PWMx module. To clear the Fault condition, the FLT32 pin must first be pulled low externally or the internal pull-down resistor in the CNPDx register can be enabled.

Note: The Fault mode may be changed using the FLTMOD<1:0> bits (FCLCON<1:0>), regardless of the state of FLT32.

| R/W-0                          | U-0                                                                        | U-0                                                                                                                        | U-0                                                              | U-0                  | U-0                       | R/W-0           | R/W-0   |
|--------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|----------------------|---------------------------|-----------------|---------|
| CHPCLKEN                       | —                                                                          | —                                                                                                                          | —                                                                | —                    | —                         | CHOPC           | LK<9: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   |
|                                |                                                                            |                                                                                                                            | CHOPC                                                            | LK<7:0>              |                           |                 |         |
| bit 7                          |                                                                            |                                                                                                                            |                                                                  |                      |                           |                 | bit 0   |
|                                |                                                                            |                                                                                                                            |                                                                  |                      |                           |                 |         |
| Legend:                        |                                                                            |                                                                                                                            |                                                                  |                      |                           |                 |         |
| R = Readable I                 | bit                                                                        | W = Writable                                                                                                               | bit                                                              | U = Unimplei         | mented bit, read          | as '0'          |         |
| -n = Value at P                | OR                                                                         | '1' = Bit is set                                                                                                           |                                                                  | '0' = Bit is cleared |                           | x = Bit is unkr | nown    |
| bit 15<br>bit 14-10<br>bit 9-0 | 1 = Chop clos<br>0 = Chop clos<br>Unimplemen<br>CHOPCLK<9<br>The frequence | Enable Chop<br>ck generator is<br>ck generator is<br>ted: Read as '<br>9:0>: Chop Clo<br>y of the chop c<br>ncy = (FP/PCL) | enabled<br>disabled<br>0'<br>ck Divider bits<br>lock signal is g | given by the fo      | ollowing expressi<br>+ 1) | on:             |         |

## REGISTER 16-5: CHOP: PWMx CHOP CLOCK GENERATOR REGISTER

### REGISTER 16-6: MDC: PWMx MASTER DUTY CYCLE REGISTER

| R/W-0                                                                | R/W-0 | R/W-0           | R/W-0     | R/W-0  | R/W-0 | R/W-0 | R/W-0 |
|----------------------------------------------------------------------|-------|-----------------|-----------|--------|-------|-------|-------|
|                                                                      |       |                 | MDC       | <15:8> |       |       |       |
| 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 |
|                                                                      |       |                 | MD        | C<7:0> |       |       |       |
| bit 7                                                                |       |                 |           |        |       |       | bit 0 |
|                                                                      |       |                 |           |        |       |       |       |
| Legend:                                                              |       |                 |           |        |       |       |       |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0' |       |                 | ad as '0' |        |       |       |       |
| -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit      |       | x = Bit is unkr | nown      |        |       |       |       |

bit 15-0 MDC<15:0>: PWMx Master Duty Cycle Value bits

## 17.2 QEI Control Registers

|  | REGISTER 17-1: | QEI1CON: QEI1 CONTROL REGISTER |
|--|----------------|--------------------------------|
|--|----------------|--------------------------------|

| U-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0         —       INTDIV2 <sup>(3)</sup> INTDIV1 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         bit 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------|---------------------|--|--|
| bit 15       bit 2         U-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0         -       INTDIV2 <sup>(3)</sup> INTDIV1 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         -       INTDIV2 <sup>(3)</sup> INTDIV1 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         -       INTDIV2 <sup>(3)</sup> INTDIV1 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         bit 7       -       intdividue       W= Writable bit       U = Unimplemented bit, read as '0'       bit 15       GEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Module counters are enabled       0 = Module counters are disabled, but SFRs can be read or written to         bit 13       GEISDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         bit 12-10       PIMOD-2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved       100 = Modulo Count mode for position counter         100 = Next index event after home event initializes position counter with contents of QEI1IC register       100 = Next index input event initializes position counter with contents of QEI1IC register       100 = Index input event dees not affect position coun                                                                                                                                                                                                  | R/W-0        | U-0                                                                                              | R/W-0                                                                                                          | R/W-0                                                                                        | R/W-0                                                                                          | R/W-0                                                      | R/W-0                             | R/W-0               |  |  |
| U-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0       R/W-0         -       INTDIV2 <sup>(3)</sup> INTDIV1 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         bit 7       bit 0       Dit 7       Dit 7       Dit 7       Dit 7       Dit 7         Legend:       R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'       Dit 7         en value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN:       Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0         0 = Module counters are enabled       0 = Module counters are disabled, but SFRs can be read or written to       Dit 13       QEISDL: QEI Stop in Idle Mode bit         1 = Discontinues module operation in Idle mode       0 = Continues module operation in Idle mode       Di Continues module operation in Idle mode         Dit 12-10       PIMOD<2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved         100 = Modulo Count mode for position counter       101 = Resets the position counter       101 = Resets the position counter with contents of QEI1IC register         101 = Resets the position counter when the position counter with contents of QEI1IC register       000 = Index input even                                                                                                                                                                                                                                          | QEIEN        | _                                                                                                | QEISIDL                                                                                                        | PIMOD2 <sup>(1)</sup>                                                                        | PIMOD1 <sup>(1)</sup>                                                                          | PIMOD0 <sup>(1)</sup>                                      | IMV1 <sup>(2)</sup>               | IMV0 <sup>(2)</sup> |  |  |
| -       INTDIV2 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         bit 7       bit 7       bit 0         Legend:       R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'       bit 0         -n = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are disabled, but SFRs can be read or written to         bit 14       Unimplemented: Read as '0'       Bit is cleared       x = Bit is unknown         bit 13       QEISDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation unter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved       110 = Modulo Count mode for position counter         10 = Resets the position counter when the position counter with contents of QEI1IC register       100 = Second index event after home event initializes position counter with contents of QEI1IC register         10 = Next index input event frees the position counter       110 = Resets the position counter         11 = Reserved       11 = First index event after home event initializes position counter with contents of QEI1IC register         10 = Next index input event free home event initializes position counter with contents of QEI1IC register                                                                                                                                          | bit 15       |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   | bit 8               |  |  |
| -       INTDIV2 <sup>(3)</sup> INTDIV0 <sup>(3)</sup> CNTPOL       GATEN       CCM1       CCM0         bit 7       bit 7       bit 0         Legend:       R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'       bit 0         -n = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are disabled, but SFRs can be read or written to         bit 14       Unimplemented: Read as '0'       Bit is cleared       x = Bit is unknown         bit 13       QEISDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation unter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved       110 = Modulo Count mode for position counter         10 = Resets the position counter when the position counter with contents of QEI1IC register       100 = Second index event after home event initializes position counter with contents of QEI1IC register         10 = Next index input event frees the position counter       110 = Resets the position counter         11 = Reserved       11 = First index event after home event initializes position counter with contents of QEI1IC register         10 = Next index input event free home event initializes position counter with contents of QEI1IC register                                                                                                                                          |              |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
| bit 7       bit 0         Legend:       W = Writable bit       U = Unimplemented bit, read as '0'         n = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Module counters are enabled         0 = Module counters are disabled, but SFRs can be read or written to       0 = Module counters are disabled, but SFRs can be read or written to         bit 14       Unimplemented: Read as '0'       0 = Continues module operation when device enters Idle mode         0 = Continues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         bit 12-10       PIMOD-2:0-: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved       110 = Resets the position counter         101 = Resets the position counter when the position counter with contents of QEI1IC register         101 = Nexet input event after home event initializes position counter with contents of QEI1IC register         010 = Next index input event resets the position counter         011 = Every index input event resets the position counter         012 = Nease B match occurs when QEB = 1         0 = Phase B match occurs when QEB = 0         bit 8       IMV0: Index Match Value for Phase A bit <sup>(2)</sup> 1 = Phase A match occurs when QEA = 1 <t< td=""><td>U-0</td><td></td><td></td><td></td><td>R/W-0</td><td>R/W-0</td><td>R/W-0</td><td>R/W-0</td></t<>                                                                       | U-0          |                                                                                                  |                                                                                                                |                                                                                              | R/W-0                                                                                          | R/W-0                                                      | R/W-0                             | R/W-0               |  |  |
| Legend:         R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         In = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0         0 = Module counters are enabled       0 = Module counters are disabled, but SFRs can be read or written to       0         bit 14       Unimplemented: Read as '0'       0         bit 13       QEISIDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode         0 = Continues module operation in Idle mode       0 = Continues module operation in Idle mode         11 = Reserved       111 = Reserved         110 = Modulo Count mode for position counter       101 = Resets the position counter when the position counter equals QEI1GEC register         100 = Second index event after home event initializes position counter with contents of QEI1IC register       100 = Second index event after home event initializes position counter with contents of QEI1IC register         101 = First index vent after home event initializes position counter with contents of QEI1IC register       001 = Every index input event resets the position counter         010 = Next index input event does not affect position counter       001 = Every index input event after home event initializes position counter with contents of QEI1IC register                                                                                                                                |              | INTDIV2 <sup>(3)</sup>                                                                           | INTDIV1 <sup>(3)</sup>                                                                                         | INTDIV0 <sup>(3)</sup>                                                                       | CNTPOL                                                                                         | GATEN                                                      | CCM1                              |                     |  |  |
| R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         In = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Bit is cleared       x = Bit is unknown         bit 15       QEISIDL: QEI Stop in Idle Mode bit       1 = Module counters are disabled, but SFRs can be read or written to       bit 14         Unimplemented: Read as '0'       East as '0'       East as '0'       East as '0'         bit 13       QEISIDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         bit 12-10       PIMOD<2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved         110 = Modulo Count mode for position counter       10 = Second index event after home event initializes position counter with contents of QEI1IC register         100 = Second index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes the position counter         101 = Reserved       III = First index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes position counter with contents of QEI1IC register         102 = Next index input event does not affect position counter       01 = Phase                                                                                              | bit 7        |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   | bit 0               |  |  |
| R = Readable bit       W = Writable bit       U = Unimplemented bit, read as '0'         In = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Bit is cleared       x = Bit is unknown         bit 15       QEISIDL: QEI Stop in Idle Mode bit       1 = Module counters are disabled, but SFRs can be read or written to       bit 14         Unimplemented: Read as '0'       East as '0'       East as '0'       East as '0'         bit 13       QEISIDL: QEI Stop in Idle Mode bit       1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         bit 12-10       PIMOD<2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved         110 = Modulo Count mode for position counter       10 = Second index event after home event initializes position counter with contents of QEI1IC register         100 = Second index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes the position counter         101 = Reserved       III = First index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes position counter with contents of QEI1IC register         102 = Next index input event does not affect position counter       01 = Phase                                                                                              | Logondy      |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
| n = Value at POR       '1' = Bit is set       '0' = Bit is cleared       x = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Bit is unknown         bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit       1 = Module counters are enabled       0 = Bit is unknown         bit 14       Unimplemented: Read as '0'       0'       0'       Bit is cleared       0 = Continues module operation when device enters ldle mode       0 = Continues module operation in ldle mode         bit 12-10       PIMOD<2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved         110 = Modulo Count mode for position counter       10 = Second index event after home event initializes position counter with contents of QEI11C register         100 = Second index event after home event initializes position counter with contents of QEI11C register       10 = Next index input event resets the position counter with contents of QEI11C register         101 = Every index input event resets the position counter       00 = Index input event does not affect position counter         001 = Every index input event genst bit <sup>(2)</sup> 1 = Phase B match occurs when QEB = 1         011 = Phase B match occurs when QEB = 1       0 = Phase B match occurs when QEA = 1         015 = Phase A match occurs when QEA = 1       0 = Phase A match occurs when QEA = 1         015 = Phase A match occurs when QEA =                                                                                                  |              | lo hit                                                                                           |                                                                                                                | hit                                                                                          | II – Unimplor                                                                                  | monted bit read                                            | ac '0'                            |                     |  |  |
| bit 15       QEIEN: Quadrature Encoder Interface Module Counter Enable bit         1 = Module counters are enabled       0 = Module counters are disabled, but SFRs can be read or written to         bit 14       Unimplemented: Read as '0'         bit 13       QEISIDL: QEI Stop in Idle Mode bit         1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation in Idle mode       0 = Continues module operation in Idle mode         11 = Discontinues module operation in Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation in Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation in Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation in Idle mode       0 = Continues module operation in Idle mode         0 = Continues module operation counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved         110 = Modulo Count mode for position counter       100 = Second index event after home event initializes position counter with contents of QEI1IC register         011 = First index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event resets the position counter         001 = Nevery index input eve                                                                                                  |              |                                                                                                  |                                                                                                                |                                                                                              | •                                                                                              |                                                            |                                   |                     |  |  |
| <ul> <li>1 = Module counters are enabled</li> <li>0 = Module counters are disabled, but SFRs can be read or written to</li> <li>bit 14</li> <li>Unimplemented: Read as '0'</li> <li>bit 13</li> <li>QEISIDL: QEI Stop in Idle Mode bit</li> <li>1 = Discontinues module operation when device enters Idle mode</li> <li>0 = Continues module operation in Idle mode</li> <li>0 = Continues module operation in Idle mode</li> <li>0 = Continues module operation counter Initialization Mode Select bits<sup>(1)</sup></li> <li>111 = Reserved</li> <li>110 = Modulo Count mode for position counter</li> <li>101 = Resets the position counter when the position counter equals QEI1GEC register</li> <li>100 = Second index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event initializes the position counter with contents of QEI1IC register</li> <li>010 = Next index input event resets the position counter with contents of QEI1IC register</li> <li>011 = Every index input event resets the position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index Match Value for Phase B bit<sup>(2)</sup></li> <li>1 = Phase B match occurs when QEB = 1</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>bit 8</li> <li>IMV0: Index Match Value for Phase A bit<sup>(2)</sup></li> <li>1 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 0</li> <li>bit 7</li> <li>Unimplemented: Read as '0'</li> </ul> | -n = value a | PUR                                                                                              | I = Bit is set                                                                                                 |                                                                                              | 0 = Bit is cle                                                                                 | ared                                                       | x = Bit is unkr                   | lown                |  |  |
| bit 13       QEISDL: QEI Stop in Idle Mode bit         1 = Discontinues module operation when device enters Idle mode       0 = Continues module operation in Idle mode         bit 12-10       PIMOD<2:0>: Position Counter Initialization Mode Select bits <sup>(1)</sup> 111 = Reserved       110 = Modulo Count mode for position counter         100 = Modulo Count mode for position counter       101 = Resets the position counter when the position counter equals QEI1GEC register         100 = Second index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes the position counter with contents of QEI1IC register         011 = First index event after home event initializes position counter with contents of QEI1IC register       010 = Next index input event initializes the position counter with contents of QEI1IC register         011 = Every index input event resets the position counter       001 = Every index input event for position counter         001 = Index input event does not affect position counter       000 = Index input event does not affect position counter         001 = Phase B match occurs when QEB = 1       0 = Phase B match occurs when QEB = 0         0it 8       IMV0: Index Match Value for Phase A bit <sup>(2)</sup> 1 = Phase A match occurs when QEA = 1       0 = Phase A match occurs when QEA = 0         0it 7       Unimplemented: Read as '0'                                                                                                                                                                                   | bit 15       | 1 = Module co                                                                                    | ounters are ena                                                                                                | abled                                                                                        |                                                                                                |                                                            |                                   |                     |  |  |
| <ul> <li>1 = Discontinues module operation when device enters Idle mode</li> <li>0 = Continues module operation in Idle mode</li> <li>bit 12-10</li> <li>PIMOD&lt;2:0&gt;: Position Counter Initialization Mode Select bits<sup>(1)</sup></li> <li>111 = Reserved</li> <li>10 = Modulo Count mode for position counter</li> <li>10 = Resets the position counter when the position counter equals QEI1GEC register</li> <li>100 = Second index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event resets the position counter with contents of QEI1IC register</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event operation when QEB = 1</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>bit 8</li> <li>IMV0: Index Match Value for Phase A bit<sup>(2)</sup></li> <li>1 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 0</li> <li>bit 7</li> <li>Unimplemented: Read as '0'</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                  | bit 14       |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
| <ul> <li>0 = Continues module operation in Idle mode</li> <li>bit 12-10</li> <li>PIMOD&lt;2:0&gt;: Position Counter Initialization Mode Select bits<sup>(1)</sup></li> <li>111 = Reserved</li> <li>10 = Modulo Count mode for position counter</li> <li>101 = Resets the position counter when the position counter equals QEI1GEC register</li> <li>100 = Second index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event resets the position counter with contents of QEI1IC register</li> <li>001 = Every index input event resets the position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event QEB = 1</li> <li>0 = Phase B match occurs when QEB = 1</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>bit 8</li> <li>IMV0: Index Match Value for Phase A bit<sup>(2)</sup></li> <li>1 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 0</li> <li>bit 7</li> <li>Unimplemented: Read as '0'</li> </ul>                                                                                                                                                                                                                                                                                              | bit 13       | •                                                                                                |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
| <ul> <li>111 = Reserved</li> <li>10 = Modulo Count mode for position counter</li> <li>101 = Resets the position counter when the position counter equals QEI1GEC register</li> <li>100 = Second index event after home event initializes position counter with contents of QEI1IC register</li> <li>011 = First index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event initializes the position counter with contents of QEI1IC register</li> <li>011 = Every index input event resets the position counter with contents of QEI1IC register</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event does not affect position counter</li> <li>011 = Phase B match occurs when QEB = 1</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>1 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 0</li> <li>0 = Phase A match occurs when QEA = 0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                | dle mode                                                   |                                   |                     |  |  |
| <ul> <li>110 = Modulo Count mode for position counter</li> <li>101 = Resets the position counter when the position counter equals QEI1GEC register</li> <li>100 = Second index event after home event initializes position counter with contents of QEI1IC register</li> <li>011 = First index event after home event initializes position counter with contents of QEI1IC register</li> <li>010 = Next index input event initializes the position counter with contents of QEI1IC register</li> <li>001 = Every index input event resets the position counter</li> <li>000 = Index input event does not affect position counter</li> <li>000 = Index input event for Phase B bit<sup>(2)</sup></li> <li>1 = Phase B match occurs when QEB = 1</li> <li>0 = Phase B match occurs when QEB = 0</li> <li>bit 8</li> <li>IMV0: Index Match Value for Phase A bit<sup>(2)</sup></li> <li>1 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 1</li> <li>0 = Phase A match occurs when QEA = 0</li> <li>bit 7</li> <li>Unimplemented: Read as '0'</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | bit 12-10    | PIMOD<2:0>                                                                                       | : Position Cour                                                                                                | nter Initializatio                                                                           | on Mode Selec                                                                                  | t bits <sup>(1)</sup>                                      |                                   |                     |  |  |
| 1 = Phase B match occurs when QEB = 1         0 = Phase B match occurs when QEB = 0         bit 8       IMV0: Index Match Value for Phase A bit <sup>(2)</sup> 1 = Phase A match occurs when QEA = 1         0 = Phase A match occurs when QEA = 0         bit 7       Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |              | 110 = Modulo<br>101 = Resets<br>100 = Second<br>011 = First in<br>010 = Next in<br>001 = Every i | b Count mode f<br>the position co<br>d index event a<br>dex event after<br>idex input even<br>index input even | bunter when the<br>fter home event<br>home event in<br>t initializes the<br>put resets the p | e position cou<br>at initializes posi<br>nitializes positi<br>position coun<br>position counte | sition counter wit<br>on counter with<br>ter with contents | h contents of C<br>contents of QE | EI1IC register      |  |  |
| 0 = Phase B match occurs when QEB = 0         bit 8         IMV0: Index Match Value for Phase A bit <sup>(2)</sup> 1 = Phase A match occurs when QEA = 1         0 = Phase A match occurs when QEA = 0         bit 7         Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | bit 9        | IMV1: Index I                                                                                    | Match Value for                                                                                                | <sup>-</sup> Phase B bit <sup>(2</sup>                                                       | )                                                                                              |                                                            |                                   |                     |  |  |
| bit 8       IMV0: Index Match Value for Phase A bit <sup>(2)</sup> 1 = Phase A match occurs when QEA = 1         0 = Phase A match occurs when QEA = 0         bit 7       Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |              |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
| 1 = Phase A match occurs when QEA = 10 = Phase A match occurs when QEA = 0bit 7Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |              |                                                                                                  |                                                                                                                |                                                                                              | <b>N</b>                                                                                       |                                                            |                                   |                     |  |  |
| 0 = Phase A match occurs when QEA = 0         bit 7         Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | bit 8        |                                                                                                  |                                                                                                                |                                                                                              | 1                                                                                              |                                                            |                                   |                     |  |  |
| bit 7 Unimplemented: Read as '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | bit 7        |                                                                                                  |                                                                                                                |                                                                                              |                                                                                                |                                                            |                                   |                     |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              | -                                                                                                |                                                                                                                |                                                                                              | inters onerate                                                                                 | as timers and th                                           |                                   | > hits are          |  |  |

**Note 1:** When CCM<1:0> = 10 or 11, all of the QEI counters operate as timers and the PIMOD<2:0> bits are ignored.

2: When CCM<1:0> = 00, and QEA and QEB values match the Index Match Value (IMV), the POSCNTH and POSCNTL registers are reset. QEA/QEB signals used for the index match have swap and polarity values applied, as determined by the SWPAB and QEAPOL/QEBPOL bits.

3: The selected clock rate should be at least twice the expected maximum quadrature count rate.



#### FIGURE 18-1: SPIX MODULE BLOCK DIAGRAM

| R/W-0                                                                                                                                    | R/W-0                                                  | R/W-0                                                                        | R/W-0            | R/W-0              | R/W-0           | R/W-0           | R/W-0    |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------|------------------|--------------------|-----------------|-----------------|----------|--|--|--|
| EDG1MOD                                                                                                                                  | EDG1POL                                                | EDG1SEL3                                                                     | EDG1SEL2         | EDG1SEL1           | EDG1SEL0        | EDG2STAT        | EDG1STAT |  |  |  |
| bit 15                                                                                                                                   |                                                        | 1                                                                            |                  | 11                 |                 |                 | bit 8    |  |  |  |
|                                                                                                                                          |                                                        |                                                                              |                  |                    |                 |                 |          |  |  |  |
| R/W-0                                                                                                                                    | R/W-0                                                  | R/W-0                                                                        | R/W-0            | R/W-0              | R/W-0           | U-0             | U-0      |  |  |  |
| EDG2MOD                                                                                                                                  | EDG2POL                                                | EDG2SEL3                                                                     | EDG2SEL2         | EDG2SEL1           | EDG2SEL0        | —               | _        |  |  |  |
| bit 7                                                                                                                                    |                                                        |                                                                              |                  | 1 1                |                 | 1               | bit (    |  |  |  |
|                                                                                                                                          |                                                        |                                                                              |                  |                    |                 |                 |          |  |  |  |
| Legend:                                                                                                                                  |                                                        |                                                                              |                  |                    |                 |                 |          |  |  |  |
| R = Readabl                                                                                                                              | le bit                                                 | W = Writable                                                                 | oit              | U = Unimplem       | ented bit, read | l as '0'        |          |  |  |  |
| -n = Value at                                                                                                                            | POR                                                    | '1' = Bit is set                                                             |                  | '0' = Bit is clea  | red             | x = Bit is unkr | nown     |  |  |  |
|                                                                                                                                          |                                                        |                                                                              |                  |                    |                 |                 |          |  |  |  |
| bit 15                                                                                                                                   | EDG1MOD: E                                             | Edge 1 Edge Sa                                                               | ampling Mode     | Selection bit      |                 |                 |          |  |  |  |
|                                                                                                                                          | 1 = Edge 1 is                                          | s edge-sensitive                                                             | 9                |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | •                                                      | s level-sensitive                                                            |                  |                    |                 |                 |          |  |  |  |
| bit 14                                                                                                                                   | it 14 EDG1POL: Edge 1 Polarity Select bit              |                                                                              |                  |                    |                 |                 |          |  |  |  |
| <ul> <li>1 = Edge 1 is programmed for a positive edge response</li> <li>0 = Edge 1 is programmed for a negative edge response</li> </ul> |                                                        |                                                                              |                  |                    |                 |                 |          |  |  |  |
| L:1 40 40                                                                                                                                | •                                                      |                                                                              | •                | •                  |                 |                 |          |  |  |  |
| bit 13-10                                                                                                                                |                                                        | :0>: Edge 1 So                                                               | urce Select bits | 5                  |                 |                 |          |  |  |  |
|                                                                                                                                          | 1xxx = Reserved<br>01xx = Reserved                     |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0011 = CTED1 pin                                       |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0010 = CTED2 pin                                       |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0001 = OC1 module<br>0000 = Timer1 module              |                                                                              |                  |                    |                 |                 |          |  |  |  |
| hit O                                                                                                                                    |                                                        |                                                                              | :+               |                    |                 |                 |          |  |  |  |
| bit 9                                                                                                                                    |                                                        | Edge 2 Status b                                                              |                  | vritten to control | the odge cou    | reo             |          |  |  |  |
|                                                                                                                                          | 1 = Edge 2 h                                           |                                                                              |                  |                    | the edge sou    | ice.            |          |  |  |  |
|                                                                                                                                          | 0 = Edge 2 has not occurred                            |                                                                              |                  |                    |                 |                 |          |  |  |  |
| bit 8                                                                                                                                    | EDG1STAT: E                                            | Edge 1 Status b                                                              | it               |                    |                 |                 |          |  |  |  |
|                                                                                                                                          |                                                        | ndicates the status of Edge 1 and can be written to control the edge source. |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 1 = Edge 1 has occurred<br>0 = Edge 1 has not occurred |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | -                                                      |                                                                              |                  |                    |                 |                 |          |  |  |  |
| bit 7                                                                                                                                    |                                                        | Edge 2 Edge Sa                                                               |                  | Selection bit      |                 |                 |          |  |  |  |
|                                                                                                                                          |                                                        | s edge-sensitive<br>s level-sensitive                                        |                  |                    |                 |                 |          |  |  |  |
| bit 6                                                                                                                                    | •                                                      | dge 2 Polarity                                                               |                  |                    |                 |                 |          |  |  |  |
| Sit 0                                                                                                                                    |                                                        | s programmed f                                                               |                  | dae response       |                 |                 |          |  |  |  |
|                                                                                                                                          |                                                        | s programmed f                                                               |                  |                    |                 |                 |          |  |  |  |
| bit 5-2                                                                                                                                  | EDG2SEL<3                                              | :0>: Edge 2 So                                                               | urce Select bits | 3                  |                 |                 |          |  |  |  |
|                                                                                                                                          | 1111 <b>= Rese</b>                                     | rved                                                                         |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 01xx = Rese                                            |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0100 = CMP <sup>2</sup><br>0011 = CTEE                 |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0010 = CTEE                                            |                                                                              |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          |                                                        | Ji pili                                                                      |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          | 0001 = OC1                                             | module                                                                       |                  |                    |                 |                 |          |  |  |  |
|                                                                                                                                          |                                                        | module                                                                       |                  |                    |                 |                 |          |  |  |  |

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

# dsPIC33EPXXXGP50X, dsPIC33EPXXXMC20X/50X AND PIC24EPXXXGP/MC20X

## REGISTER 24-4: PTGT0LIM: PTG TIMER0 LIMIT REGISTER<sup>(1)</sup>

| R/W-0                                                                 | R/W-0 | R/W-0 | R/W-0           | R/W-0     | R/W-0 | R/W-0 | R/W-0 |
|-----------------------------------------------------------------------|-------|-------|-----------------|-----------|-------|-------|-------|
|                                                                       |       |       | PTGT0           | _IM<15: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 |
|                                                                       |       |       | PTGT0           | LIM<7:0>  |       |       |       |
| bit 7                                                                 |       |       |                 |           |       |       | bit 0 |
|                                                                       |       |       |                 |           |       |       |       |
| Legend:                                                               |       |       |                 |           |       |       |       |
| R = Readable bit W = Writable bit U = Unimplemented bit, read as '0'  |       |       |                 | d as '0'  |       |       |       |
| -n = Value at POR '1' = Bit is set '0' = Bit is cleared x = Bit is un |       |       | x = Bit is unkr | nown      |       |       |       |

#### bit 15-0 **PTGT0LIM<15:0>:** PTG Timer0 Limit Register bits General Purpose Timer0 Limit register (effective only with a PTGT0 Step command).

**Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1).

## REGISTER 24-5: PTGT1LIM: PTG TIMER1 LIMIT REGISTER<sup>(1)</sup>

| R/W-0          | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |
|----------------|-------|-------|-------|-------|-------|-------|-------|--|--|
| PTGT1LIM<15: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 |  |  |
|---------------|-------|-------|-------|-------|-------|-------|-------|--|--|
| PTGT1LIM<7:0> |       |       |       |       |       |       |       |  |  |
| bit 7         |       |       |       |       |       |       |       |  |  |

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

bit 15-0 **PTGT1LIM<15:0>:** PTG Timer1 Limit Register bits

General Purpose Timer1 Limit register (effective only with a PTGT1 Step command).

**Note 1:** This register is read-only when the PTG module is executing Step commands (PTGEN = 1 and PTGSTRT = 1).

| Base<br>Instr<br># | Assembly<br>Mnemonic |        |                                                  | Description                               | # of<br>Words | # of<br>Cycles <sup>(2)</sup> | Status Flags<br>Affected |  |
|--------------------|----------------------|--------|--------------------------------------------------|-------------------------------------------|---------------|-------------------------------|--------------------------|--|
| 46                 | MOV                  | MOV    | f,Wn                                             | Move f to Wn                              | 1             | 1                             | None                     |  |
|                    |                      | MOV    | f                                                | Move f to f                               | 1             | 1                             | None                     |  |
|                    |                      | MOV    | f,WREG                                           | Move f to WREG                            | 1             | 1                             | None                     |  |
|                    |                      | MOV    | #litl6,Wn                                        | Move 16-bit literal to Wn                 | 1             | 1                             | None                     |  |
|                    |                      | MOV.b  | #lit8,Wn                                         | Move 8-bit literal to Wn                  | 1             | 1                             | None                     |  |
|                    |                      | MOV    | Wn,f                                             | Move Wn to f                              | 1             | 1                             | None                     |  |
|                    |                      | MOV    | Wso,Wdo                                          | Move Ws to Wd                             | 1             | 1                             | None                     |  |
|                    |                      | MOV    | WREG, f                                          | Move WREG to f                            | 1             | 1                             | None                     |  |
|                    |                      | MOV.D  | Wns,Wd                                           | Move Double from W(ns):W(ns + 1) to<br>Wd | 1             | 2                             | None                     |  |
|                    |                      | MOV.D  | Ws , Wnd                                         | Move Double from Ws to W(nd +<br>1):W(nd) | 1             | 2                             | None                     |  |
| 47                 | MOVPAG               | MOVPAG | #lit10,DSRPAG                                    | Move 10-bit literal to DSRPAG             | 1             | 1                             | None                     |  |
|                    |                      | MOVPAG | #lit9,DSWPAG                                     | Move 9-bit literal to DSWPAG              | 1             | 1                             | None                     |  |
|                    |                      | MOVPAG | #lit8,TBLPAG                                     | Move 8-bit literal to TBLPAG              | 1             | 1                             | None                     |  |
|                    |                      | MOVPAG | Ws, DSRPAG                                       | Move Ws<9:0> to DSRPAG                    | 1             | 1                             | None                     |  |
|                    |                      | MOVPAG | Ws, DSWPAG                                       | Move Ws<8:0> to DSWPAG                    | 1             | 1                             | None                     |  |
|                    |                      | MOVPAG | Ws, TBLPAG                                       | Move Ws<7:0> to TBLPAG                    | 1             | 1                             | None                     |  |
| 48                 | MOVSAC               | MOVSAC | Acc,Wx,Wxd,Wy,Wyd,AWB <sup>(1)</sup>             | Prefetch and store accumulator            | 1             | 1                             | None                     |  |
| 49                 | MPY                  | MPY    | Wm*Wn,Acc,Wx,Wxd,Wy,Wyd(1)                       | Multiply Wm by Wn to Accumulator          | 1             | 1                             | OA,OB,OAB,<br>SA,SB,SAB  |  |
|                    |                      | MPY    | Wm*Wm,Acc,Wx,Wxd,Wy,Wyd <sup>(1)</sup>           | Square Wm to Accumulator                  | 1             | 1                             | OA,OB,OAB,<br>SA,SB,SAB  |  |
| 50                 | MPY.N                | MPY.N  | Wm*Wn,Acc,Wx,Wxd,Wy,Wyd(1)                       | -(Multiply Wm by Wn) to Accumulator       | 1             | 1                             | None                     |  |
| 51                 | MSC                  | MSC    | Wm*Wm, Acc, Wx, Wxd, Wy, Wyd, AWB <sup>(1)</sup> | Multiply and Subtract from Accumulator    | 1             | 1                             | OA,OB,OAB,<br>SA,SB,SAB  |  |

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

Note 1: These instructions are available in dsPIC33EPXXXMC20X/50X and PIC24EPXXXMC20X devices only.

2: Read and Read-Modify-Write (e.g., bit operations and logical operations) on non-CPU SFRs incur an additional instruction cycle.

#### TABLE 30-18: PLL CLOCK TIMING SPECIFICATIONS

| АС СНА       | C CHARACTERISTICS |                                                                  |                                                | $\begin{tabular}{lllllllllllllllllllllllllllllllllll$ |     |     |                    |  |
|--------------|-------------------|------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------|-----|-----|--------------------|--|
| Param<br>No. | Symbol            | Characteristic                                                   | Min. Typ. <sup>(1)</sup> Max. Units Conditions |                                                       |     |     | Conditions         |  |
| OS50         | Fplli             | PLL Voltage Controlled Oscillator<br>(VCO) Input Frequency Range | 0.8                                            | —                                                     | 8.0 | MHz | ECPLL, XTPLL modes |  |
| OS51         | Fvco              | On-Chip VCO System Frequency                                     | 120                                            | —                                                     | 340 | MHz |                    |  |
| OS52         | TLOCK             | PLL Start-up Time (Lock Time)                                    | 0.9                                            | 1.5                                                   | 3.1 | ms  |                    |  |
| OS53         | DCLK              | CLKO Stability (Jitter) <sup>(2)</sup>                           | -3                                             | 0.5                                                   | 3   | %   |                    |  |

**Note 1:** Data in "Typical" column is at 3.3V, +25°C unless otherwise stated. Parameters are for design guidance only and are not tested.

2: This jitter specification is based on clock cycle-by-clock cycle measurements. To get the effective jitter for individual time bases, or communication clocks used by the application, use the following formula:

$$Effective Jitter = \frac{DCLK}{\sqrt{\frac{FOSC}{Time Base or Communication Clock}}}$$

For example, if Fosc = 120 MHz and the SPIx bit rate = 10 MHz, the effective jitter is as follows:

Effective Jitter = 
$$\frac{DCLK}{\sqrt{\frac{120}{10}}} = \frac{DCLK}{\sqrt{12}} = \frac{DCLK}{3.464}$$

#### TABLE 30-19: INTERNAL FRC ACCURACY

| AC CHA                                                                                                  | RACTERISTICS           | $\begin{array}{ll} \mbox{Standard Operating Conditions: 3.0V to 3.6V (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.         Characteristic         Min.         Typ.         Max.         Units         Condit |                        |                                                                                                                                                                                                                                                                              | Conditio   | ons         |   |                                                                     |                |  |
| Internal                                                                                                | FRC Accuracy @ FRC Fre | equency =                                                                                                                                                                                                                                                                    | : 7.37 MHz | <u>,(1)</u> |   |                                                                     |                |  |
| F20a                                                                                                    | FRC                    | -1.5                                                                                                                                                                                                                                                                         | 0.5        | +1.5        | % | $-40^{\circ}C \le TA \le -10^{\circ}C$                              | VDD = 3.0-3.6V |  |
|                                                                                                         |                        | -1                                                                                                                                                                                                                                                                           | 0.5        | +1          | % | $-10^{\circ}C \le TA \le +85^{\circ}C \qquad VDD = 3.0-3.6^{\circ}$ |                |  |
| F20b                                                                                                    | FRC                    | -2                                                                                                                                                                                                                                                                           | 1          | +2          | % | $+85^{\circ}C \le TA \le +125^{\circ}C$                             | VDD = 3.0-3.6V |  |

Note 1: Frequency is calibrated at +25°C and 3.3V. TUNx bits can be used to compensate for temperature drift.

#### TABLE 30-20: INTERNAL LPRC ACCURACY

| AC CH                       | ARACTERISTICS               | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |      |      |       |                                           |                |  |
|-----------------------------|-----------------------------|------------------------------------------------------|------|------|-------|-------------------------------------------|----------------|--|
| Param<br>No. Characteristic |                             | Min.                                                 | Тур. | Max. | Units | Conditions                                |                |  |
| LPRC (                      | @ 32.768 kHz <sup>(1)</sup> |                                                      |      |      |       |                                           |                |  |
| F21a                        | LPRC                        | -30                                                  | —    | +30  | %     | $-40^{\circ}C \le TA \le -10^{\circ}C$    | VDD = 3.0-3.6V |  |
|                             |                             | -20                                                  |      | +20  | %     | $-10^{\circ}C \leq TA \leq +85^{\circ}C$  | VDD = 3.0-3.6V |  |
| F21b                        | LPRC                        | -30                                                  | _    | +30  | %     | $+85^{\circ}C \leq TA \leq +125^{\circ}C$ | VDD = 3.0-3.6V |  |

**Note 1:** The change of LPRC frequency as VDD changes.

| АС СНА       | ARACTERIS | TICS                                                         |                     | $\begin{array}{l} \mbox{Standard Operating Conditions: 3.0V to 3.6V} \\ \mbox{(unless otherwise stated)} \\ \mbox{Operating temperature} & -40^{\circ}C \leq TA \leq +85^{\circ}C \mbox{ for Industrial} \\ -40^{\circ}C \leq TA \leq +125^{\circ}C \mbox{ for Extended} \end{array}$ |      |               |       |                                                                               |
|--------------|-----------|--------------------------------------------------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|-------|-------------------------------------------------------------------------------|
| Param<br>No. | Symbol    | Characteristic <sup>(1)</sup>                                |                     | Min.                                                                                                                                                                                                                                                                                  | Тур. | Max.          | Units | Conditions                                                                    |
| TB10         | TtxH      | TxCK High<br>Time                                            | Synchronous<br>mode | Greater of:<br>20 or<br>(Tcy + 20)/N                                                                                                                                                                                                                                                  | _    | _             | ns    | Must also meet<br>Parameter TB15,<br>N = prescale<br>value<br>(1, 8, 64, 256) |
| TB11         | TtxL      | TxCK Low<br>Time                                             | Synchronous<br>mode | Greater of:<br>20 or<br>(Tcy + 20)/N                                                                                                                                                                                                                                                  | _    |               | ns    | Must also meet<br>Parameter TB15,<br>N = prescale<br>value<br>(1, 8, 64, 256) |
| TB15         | TtxP      | TxCK<br>Input<br>Period                                      | Synchronous<br>mode | Greater of:<br>40 or<br>(2 Tcy + 40)/N                                                                                                                                                                                                                                                | —    | —             | ns    | N = prescale<br>value<br>(1, 8, 64, 256)                                      |
| TB20         | TCKEXTMRL | Delay from External TxCK<br>Clock Edge to Timer<br>Increment |                     | 0.75 Tcy + 40                                                                                                                                                                                                                                                                         | —    | 1.75 Tcy + 40 | ns    |                                                                               |

| <b>TABLE 30-24</b> | TIMER2 AND TIM | IER4 (TYPE B TIMER | R) EXTERNAL CLOCK TIMING REQUIREMENTS | j. |
|--------------------|----------------|--------------------|---------------------------------------|----|
|--------------------|----------------|--------------------|---------------------------------------|----|

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

## TABLE 30-25: TIMER3 AND TIMER5 (TYPE C TIMER) EXTERNAL CLOCK TIMING REQUIREMENTS

| AC CHARACTERISTICS |                                    |                                                              | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |               |      |               |            |                                          |
|--------------------|------------------------------------|--------------------------------------------------------------|------------------------------------------------------|---------------|------|---------------|------------|------------------------------------------|
| Param<br>No.       | Symbol Characteristic <sup>1</sup> |                                                              | Min.                                                 | Тур.          | Max. | Units         | Conditions |                                          |
| TC10               | TtxH                               | TxCK High<br>Time                                            | Synchronous                                          | Tcy + 20      |      |               | ns         | Must also meet<br>Parameter TC15         |
| TC11               | TtxL                               | TxCK Low<br>Time                                             | Synchronous                                          | Тсү + 20      | _    | —             | ns         | Must also meet<br>Parameter TC15         |
| TC15               | TtxP                               | TxCK Input<br>Period                                         | Synchronous, with prescaler                          | 2 Tcy + 40    | —    | _             | ns         | N = prescale<br>value<br>(1, 8, 64, 256) |
| TC20               | TCKEXTMRL                          | Delay from External TxCK<br>Clock Edge to Timer<br>Increment |                                                      | 0.75 Tcy + 40 | _    | 1.75 Tcy + 40 | ns         |                                          |

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

| AC CHA       | RACTER  | ISTICS           |                           | $\begin{array}{llllllllllllllllllllllllllllllllllll$ |             |            |                        |  |
|--------------|---------|------------------|---------------------------|------------------------------------------------------|-------------|------------|------------------------|--|
| Param<br>No. | Symbol  | Characte         | eristic <sup>(4)</sup>    | Min. <sup>(1)</sup>                                  | -40<br>Max. | Units      | Conditions             |  |
| IM10         | TLO:SCL | Clock Low Time   | 100 kHz mode              | Tcy/2 (BRG + 2)                                      | _           | μS         |                        |  |
|              |         |                  | 400 kHz mode              | TCY/2 (BRG + 2)                                      |             | μS         |                        |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | TCY/2 (BRG + 2)                                      |             | μs         |                        |  |
| IM11         | THI:SCL | Clock High Time  | 100 kHz mode              | Tcy/2 (BRG + 2)                                      |             | μS         |                        |  |
|              |         | Ū                | 400 kHz mode              | Tcy/2 (BRG + 2)                                      |             | μ <b>S</b> |                        |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | TCY/2 (BRG + 2)                                      |             | μ <b>S</b> |                        |  |
| 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 + 2)                                      |             | μ <b>S</b> | Only relevant for      |  |
|              |         | Setup Time       | 400 kHz mode              | Tcy/2 (BRG + 2)                                      |             | μS         | Repeated Start         |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 2)                                      | _           | μs         | condition              |  |
| IM31         | THD:STA | Start Condition  | 100 kHz mode              | Tcy/2 (BRG + 2)                                      |             | μ <b>s</b> | After this period, the |  |
|              |         | Hold Time        | 400 kHz mode              | Tcy/2 (BRG +2)                                       |             | μS         | first clock pulse is   |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | Tcy/2 (BRG + 2)                                      | _           | μS         | generated              |  |
| IM33         | Tsu:sto | Stop Condition   | 100 kHz mode              | Tcy/2 (BRG + 2)                                      | _           | μs         |                        |  |
|              |         | Setup Time       | 400 kHz mode              | Tcy/2 (BRG + 2)                                      | _           | μs         | 1                      |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | TCY/2 (BRG + 2)                                      | —           | μS         |                        |  |
| IM34         | THD:STO | Stop Condition   | 100 kHz mode              | Tcy/2 (BRG + 2)                                      | _           | μs         |                        |  |
|              |         | Hold Time        | 400 kHz mode              | Tcy/2 (BRG + 2)                                      | —           | μS         |                        |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | TCY/2 (BRG + 2)                                      | —           | μS         |                        |  |
| 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                                                  | _           | μ <b>s</b> | free before a new      |  |
|              |         |                  | 1 MHz mode <sup>(2)</sup> | 0.5                                                  | _           | μ <b>s</b> | transmission can star  |  |
| IM50         | Св      | Bus Capacitive L |                           | _                                                    | 400         | pF         |                        |  |
| IM51         | TPGD    | Pulse Gobbler De | -                         | 65                                                   | 390         | ns         | (Note 3)               |  |

## TABLE 30-49: I2Cx BUS DATA TIMING REQUIREMENTS (MASTER MODE)

Note 1: BRG is the value of the l<sup>2</sup>C<sup>™</sup> Baud Rate Generator. Refer to "Inter-Integrated Circuit (l<sup>2</sup>C<sup>™</sup>)" (DS70330) in the "dsPIC33/PIC24 Family Reference Manual". Please see the Microchip web site for the latest family reference manual sections.

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

NOTES:

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

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





Microchip Technology Drawing C04-052C Sheet 1 of 2

# **Worldwide Sales and Service**

#### AMERICAS

Corporate Office 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: http://www.microchip.com/ support Web Address: www.microchip.com

Atlanta Duluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Boston Westborough, MA Tel: 774-760-0087 Fax: 774-760-0088

Chicago Itasca, IL Tel: 630-285-0071 Fax: 630-285-0075

**Cleveland** Independence, OH Tel: 216-447-0464 Fax: 216-447-0643

**Dallas** Addison, TX Tel: 972-818-7423 Fax: 972-818-2924

Detroit Farmington Hills, MI Tel: 248-538-2250 Fax: 248-538-2260

Indianapolis Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453

Los Angeles Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

Santa Clara Santa Clara, CA Tel: 408-961-6444 Fax: 408-961-6445

Toronto Mississauga, Ontario, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Asia Pacific Office Suites 3707-14, 37th Floor Tower 6, The Gateway Harbour City, Kowloon Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 Australia - Sydney Tel: 61-2-9868-6733

Fax: 61-2-9868-6755 China - Beijing

Tel: 86-10-8569-7000 Fax: 86-10-8528-2104

China - Chengdu Tel: 86-28-8665-5511 Fax: 86-28-8665-7889

China - Chongqing Tel: 86-23-8980-9588 Fax: 86-23-8980-9500

China - Hangzhou Tel: 86-571-2819-3187

Fax: 86-571-2819-3189 China - Hong Kong SAR

Tel: 852-2943-5100 Fax: 852-2401-3431

**China - Nanjing** Tel: 86-25-8473-2460 Fax: 86-25-8473-2470

**China - Qingdao** Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

**China - Shanghai** Tel: 86-21-5407-5533 Fax: 86-21-5407-5066

China - Shenyang Tel: 86-24-2334-2829 Fax: 86-24-2334-2393

**China - Shenzhen** Tel: 86-755-8864-2200 Fax: 86-755-8203-1760

**China - Wuhan** Tel: 86-27-5980-5300 Fax: 86-27-5980-5118

**China - Xian** Tel: 86-29-8833-7252 Fax: 86-29-8833-7256

**China - Xiamen** Tel: 86-592-2388138 Fax: 86-592-2388130

**China - Zhuhai** Tel: 86-756-3210040 Fax: 86-756-3210049

#### ASIA/PACIFIC

India - Bangalore Tel: 91-80-3090-4444 Fax: 91-80-3090-4123

**India - New Delhi** Tel: 91-11-4160-8631 Fax: 91-11-4160-8632

India - Pune Tel: 91-20-2566-1512 Fax: 91-20-2566-1513

**Japan - Osaka** Tel: 81-6-6152-7160 Fax: 81-6-6152-9310

**Japan - Tokyo** Tel: 81-3-6880- 3770 Fax: 81-3-6880-3771

**Korea - Daegu** Tel: 82-53-744-4301 Fax: 82-53-744-4302

Korea - Seoul Tel: 82-2-554-7200 Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala Lumpur Tel: 60-3-6201-9857 Fax: 60-3-6201-9859

Malaysia - Penang Tel: 60-4-227-8870 Fax: 60-4-227-4068

Philippines - Manila Tel: 63-2-634-9065 Fax: 63-2-634-9069

Singapore Tel: 65-6334-8870 Fax: 65-6334-8850

**Taiwan - Hsin Chu** Tel: 886-3-5778-366 Fax: 886-3-5770-955

Taiwan - Kaohsiung Tel: 886-7-213-7828 Fax: 886-7-330-9305

**Taiwan - Taipei** Tel: 886-2-2508-8600 Fax: 886-2-2508-0102

**Thailand - Bangkok** Tel: 66-2-694-1351 Fax: 66-2-694-1350

#### EUROPE

Austria - Wels Tel: 43-7242-2244-39 Fax: 43-7242-2244-393 Denmark - Copenhagen Tel: 45-4450-2828 Fax: 45-4485-2829

France - Paris Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

**Germany - Munich** Tel: 49-89-627-144-0 Fax: 49-89-627-144-44

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Netherlands - Drunen Tel: 31-416-690399 Fax: 31-416-690340

**Spain - Madrid** Tel: 34-91-708-08-90 Fax: 34-91-708-08-91

**UK - Wokingham** Tel: 44-118-921-5869 Fax: 44-118-921-5820

11/29/12