



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 - Microcontrollers</u>"

| Details                    |                                                                               |
|----------------------------|-------------------------------------------------------------------------------|
| Product Status             | Active                                                                        |
| Core Processor             | dsPIC                                                                         |
| Core Size                  | 16-Bit                                                                        |
| Speed                      | 30 MIPs                                                                       |
| Connectivity               | CANbus, I <sup>2</sup> C, SPI, UART/USART                                     |
| Peripherals                | AC'97, Brown-out Detect/Reset, I2S, LVD, POR, PWM, WDT                        |
| Number of I/O              | 52                                                                            |
| Program Memory Size        | 66KB (22K x 24)                                                               |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | 1K x 8                                                                        |
| RAM Size                   | 4K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                   |
| Data Converters            | A/D 16x12b                                                                    |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                                 |
| Package / Case             | 64-TQFP                                                                       |
| Supplier Device Package    | 64-TQFP (10x10)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic30f5011-30i-pt |

FIGURE 1-1: dsPIC30F5011 BLOCK DIAGRAM Y Data Bus X Data Bus 16 16 Interrupt Data Latch Data Latch PSV & Table
Data Access
Control Block Controller Y Data X Data 416 RAM (2 Kbytes RAM (2 Kbytes) AN0/VREF+/CN2/RB0 Address Address 16 AN1/VREF-/CN3/RB1 24 Latch Latch AN2/SS1/LVDIN/CN4/RB2 AN3/CN5/RB3 16 17 16 1 16 AN4/IC7/CN6/RB4 X RAGU AN5/IC8/CN7/RB5 Y AGU PCU PCH PCL X WAGU PGC/EMUC/AN6/OCFA/RB6 Program Counter PGD/EMUD/AN7/RB7 Stack Control Logic Loop Control Logic Address Latch AN8/RB8 Program AN9/RB9 Memory (66 Kbytes AN10/RB10 AN11/RB11 Data EEPROM AN11/RB11 AN12/RB12 AN13/RB13 AN14/RB14 AN15/OCFB/CN12/RB15 (1 Kbyte) Effective Address Data Latch 16 **ROM Latch** 6 PORTB 24 ΙR T2CK/RC1 T3CK/RC2 16 16 EMUD1/SOSCI/T4CK/CN1/RC13 EMUC1/SOSCO/T1CK/CN0/RC14 16 x 16 OSC2/CLKO/RC15 W Reg Array Decode PORTC Instruction ¥6¥6 Decode & Control EMUC2/OC1/RD0 EMUD2/OC2/RD1 OC3/RD2 Control Signals V V V DSP Divide to Various Blocks Power-up Engine Unit OC4/RD3 CC5/IC5/CN13/RD4 OC6/IC6/CN14/RD5 Timing Generation Oscillator OSC1/CLKI tart-up Time OC7/CN15/RD6  $\boxtimes$ ALÚ<16> OC8/CN16/RD7 POR/BOR IC1/INT1/RD8  $\boxtimes$ IC2/INT2/RD9 16 IC3/INT3/RD10 Watchdog MCLR Timer  $\boxtimes$ Low-Voltage PORTD Detect VDD, VSS AVDD, AVSS Input Output CAN1, 12-bit ADC Capture Compare I<sup>2</sup>C™ CAN2 C1RX/RF0 Module Module C1TX/RF1 U1RX/SDI1/RF2 EMUD3/U1TX/SDO1/RF3 U2RX/CN17/RF4 U2TX/CN18/RF5 SPI1 UART1, EMUC3/SCK1/INT0/RF6 DCI Timers PORTE C2RX/RG0 C2TX/RG1 SCL/RG2 SDA/RG3 SCK2/CN8/RG6 SDI2/CN9/RG7 SDO2/CN10/RG8 SS2/CN11/RG9 CSDI/RG12 CSDO/RG13 CSCK/RG14 COFS/RG15 **PORTG** 

FIGURE 1-2: dsPIC30F5013 BLOCK DIAGRAM CN22/RA6 Y Data Bus CN23/RA7 X Data Bus VREF-/RA9 <u>/1</u>6 16 VREF+/RA10 INT1/RA12 INT2/RA12 Interrupt Data Latch Data Latch PSV & Table Data Access Control Block Controlle Y Data X Data INT3/RA14 16 RAM RAM INT4/RA15 (2 Kbytes) (2 Kbytes) PORTA Address Address 24 Latch Latch PGD/EMUD/AN0/CN2/RB0 PGC/EMUC/AN1/CN3/RB1 16 17 16 16 AN2/SS1/LVDIN/CN4/RB2 X RAGU Y AGU AN3/CN5/RB3 PCÚ PCH PCL X WAGU AN4/CN6/RB4 Program Counter AN5/CN7/RB5 Loop Control Logic Address Latch AN6/OCFA/RB6 AN7/RB7 Program Memory (66 Kbytes) X AN8/RB8 AN9/RB9 AN9/RB9 AN10/RB10 Data EEPROM (1 Kbyte) Effective Address AN11/RB11 AN12/RB12 Data Latch 16 X AN13/RB13 AN14/RB14 ROM Latch AN15/OCFB/CN12/RB15 24 PORTB T2CK/RC1 ΙR T3CK/RC2 T4CK/RC3 16 16 T5CK/RC4 16 x 16 EMUD1/SOSCI/CN1/RC13 EMUC1/SOSCO/T1CK/CN0/RC14 W Reg Array Decode OSC2/CLKO/RC15 Instruction PORTC Decode & Control EMUC2/OC1/RD0 EMUD2/OC2/RD1 Control Signals V V V OC3/RD2 DSP OC4/RD3 Divide to Various Blocks Power-up Engine Unit OC5/CN13/RD4 OC6/CN14/RD5 Timer OC7/CN15/RD6 Timing Generation Oscillator OSC1/CLKI OC8/CN16/RD7 tart-up Time XIC1/RD8 ALU<16> IC2/RD9 POR/BOR IC3/RD10  $\boxtimes$ 16 16 IC4/RD11 Watchdog MCLR IC5/RD12 Timer IC6/CN19/RD13  $\times$ Low-Voltage IC7/CN20/RD14 VDD, VSS AVDD, AVSS Detect IC8/CN21/RD15 C1RX/RF0 Input Output CAN1  $I^2C^TM$ C1TX/RF1 12-bit ADC Capture Compare CAN2 U1RX/RF2 Module Module U1TX/RF3 U2RX/CN17/RF4 U2TX/CN18/RF5 EMUC3/SCK1/INT0/RF6 SDI1/RF7 SPI1. UART1, EMUD3/SDO1/RF8 DCI Timers PORTE C2RX/RG0 C2TX/RG1 SCL/RG2 SDA/RG3 SCK2/CN8/RG6 SDI2/CN9/RG7 SDO2/CN10/RG8 SS2/CN11/RG9 SSZ/CN1//RC CSDI/RG12 CSDO/RG13 CSCK/RG14 COFS/RG15

© 2011 Microchip Technology Inc.

NOTES:

## 7.3.2 WRITING A BLOCK OF DATA EEPROM

To write a block of data EEPROM, write to all sixteen latches first, and then set the NVMCON register and program the block.

#### **EXAMPLE 7-5: DATA EEPROM BLOCK WRITE**

```
#LOW ADDR WORD, WO ; Init pointer
           #HIGH ADDR WORD, W1
VOM
MOV
           W1_TBLPAG
MOV
           #data1,W2
                            ; Get 1st data
                            ; write data
TRIWTI.
           W2,[ W0]++
                            ; Get 2nd data
MOV
           #data2,W2
           W2 [ W0]++
TBLWTL
                             ; write data
VOM
          #data3,W2
                            ; Get 3rd data
TBLWTL
          W2 [ W0]++
                            ; write data
                            ; Get 4th data
VOM
          #data4.W2
          W2,[ W0]++
TBLWTL
                             ; write data
          #data5,W2
MOV.
                             ; Get 5th data
TBLWTL
          W2 [ W0]++
                            ; write data
MOV
          #data6,W2
                            ; Get 6th data
           W2 [ W0]++
                            ; write data
TBIWTI
                             ; Get 7th data
VOM
          #data7,W2
          W2 [ W0]++
TBLWTL
                             ; write data
          #data8,W2
                            ; Get 8th data
TBLWTL
          W2,[ W0]++
                            ; write data
                            ; Get 9th data
VOM
          #data9,W2
                            ; write data
; Get 10th data
TBLWTL
          W2 [ W0]++
          #data10.W2
VOM
TBLWTL
           W2 [ W0]++
                            ; write data
VOM
           #data11,W2
                            ; Get 11th data
                            ; write data
           W2 [ W0]++
TBLWTL
                            ; Get 12th data
           #data12,W2
VOM
          W2 [ W0]++
TBLWTL
                             ; write data
          #data13,W2
                            ; Get 13th data
TBLWTL
          W2,[ W0]++
                            ; write data
                            ; Get 14th data
          #data14,W2
MOV
TBLWTL
          W2 [ W0]++
                             ; write data
                             ; Get 15th data
           #data15,W2
VOM
TBLWTL
           W2 [ W0]++
                            ; write data
VOM
           #data16,W2
                            ; Get 16th data
                            ; write data. The NVMADR captures last table access address.
TBLWTL
           W2 [ W0]++
MOV
           #0x400A,W0
                             ; Select data EEPROM for multi word op
MOV
           W0,NVMCON
                             ; Operate Key to allow program operation
           #5
DISI
                             ; Block all interrupts with priority <7 for next 5 instructions
MOV
           #0x55,W0
MOV
           W0 NVMKEY
                             ; Write the 0x55 key
MOV
           #0xAA,W1
MOV
           W1 NVMKEY
                             ; Write the OxAA key
           NVMCON, #WR
BSET
                             ; Start write cycle
NOP
NOP
```

#### 7.4 Write Verify

Depending on the application, good programming practice may dictate that the value written to the memory should be verified against the original value. This should be used in applications where excessive writes can stress bits near the specification limit.

#### 7.5 Protection Against Spurious Write

There are conditions when the device may not want to write to the data EEPROM memory. To protect against spurious EEPROM writes, various mechanisms have been built-in. On power-up, the WREN bit is cleared, and the Power-up Timer prevents EEPROM write.

The write initiate sequence and the WREN bit together help prevent an accidental write during brown-out, power glitch or software malfunction.

PORTD REGISTER MAP FOR dsPIC30F5011<sup>(1)</sup> **TABLE 8-5:** 

| ֡֝֝֝֝֝֝֡֜֝֝֡֜֝֝֡֓֓֓֜֝֡֜֜֜֜֜֓֓֓֓֜֜֜֜֜֜֜֡֓֜֡֓֡֓֡֡֡֜֜֜֡֡֡֡֓֜֜֡֡֡֓֜֡֡֡֡֡֡ | 2          | -      |        | 2      |                                              | 25      |         |                  |        |        |        |        |                                                                    |        |        |        |        |                                                                                                                                 |
|-----------------------------------------------------------------------|------------|--------|--------|--------|----------------------------------------------|---------|---------|------------------|--------|--------|--------|--------|--------------------------------------------------------------------|--------|--------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------|
| SFR<br>Name                                                           | Addr.      | Bit 15 | Bit 14 | Bit 13 | SFR Addr. Bit 15 Bit 14 Bit 13 Bit 12 Bit 11 | Bit 11  | Bit 10  | Bit 9            | Bit 8  | Bit 7  | Bit 6  | Bit 5  | Bit 10 Bit 9 Bit 8 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Reset State                                                                                                                     |
| TRISD                                                                 | TRISD 02D2 | ı      | I      | 1      | I                                            | TRISD11 | TRISD10 | TRISD9           | TRISD8 | TRISD7 | TRISD6 | TRISD5 | TRISD4                                                             | TRISD3 | TRISD2 | TRISD1 | TRISD0 | TRISD10 TRISD9 TRISD8 TRISD7 TRISD6 TRISD5 TRISD4 TRISD3 TRISD2 TRISD1 TRISD0 0000 1111 1111 1111                               |
| PORTD 02D4                                                            | 02D4       | I      | 1      | -      | _                                            | RD11    | RD10    | RD10 RD9 RD8 RD7 | RD8    | RD7    | RD6    | RD5    | RD4                                                                | RD3    | RD2    | RD1    | RD0    | RD6         RD5         RD4         RD3         RD2         RD1         RD0         0000         0000         0000         0000 |
| LATD 02D6                                                             | 02D6       | I      | I      | I      | I                                            | LATD11  | LATD10  | LATD9            | LATD8  | LATD7  | LATD6  | LATD5  | LATD4                                                              | LATD3  | LATD2  | LATD1  | LATD0  | LATD10 LATD9 LATD8 LATD7 LATD6 LATD5 LATD4 LATD3 LATD2 LATD1 LATD0 0000 0000 0000 0000                                          |

— = unimplemented, read as ' $^\circ$ ' Refer to the " $^\circ$ sPIC30F Family Reference Manual" (DS70046) for descriptions of register bit fields.

## PORTD REGISTER MAP FOR dsPIC30F5013<sup>(1)</sup> TABLE 8-6:

|             | ;<br>; |         | !       | i<br>)  |                                                   |        | ) . ) ) |                                                              |        |        |         |        |             |               |        |        |        |                                                                                                   |     |
|-------------|--------|---------|---------|---------|---------------------------------------------------|--------|---------|--------------------------------------------------------------|--------|--------|---------|--------|-------------|---------------|--------|--------|--------|---------------------------------------------------------------------------------------------------|-----|
| SFR<br>Name | Addr.  | Bit 15  | Bit 14  | Bit 13  | Addr. Bit 15 Bit 14 Bit 13 Bit 12 Bit 11          | Bit 11 | Bit 10  | Bit 10 Bit 9 Bit 8 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 | Bit 8  | Bit 7  | Bit 6   | Bit 5  | Bit 4       | Bit 3         | Bit 2  | Bit 1  | Bit 0  | Reset State                                                                                       |     |
| TRISD       | 02D2   | TRISD15 | TRISD14 | TRISD13 | TRISD 02D2 TRISD15 TRISD14 TRISD13 TRISD12 TRISD1 | 7      | TRISD10 | TRISD9                                                       | TRISD8 | TRISD7 | TRISD6  | TRISD5 | TRISD4      | <b>TRISD3</b> | TRISD2 | TRISD1 | TRISD0 | TRISD10 TRISD9 TRISD8 TRISD7 TRISD6 TRISD5 TRISD4 TRISD3 TRISD2 TRISD1 TRISD0 1111 1111 1111 1111 | 1   |
| PORTD       | 02D4   | RD15    | RD14    | RD13    | PORTD 02D4 RD15 RD14 RD13 RD12 RD11               | RD11   | RD10    | RD10 RD9                                                     | RD8    | RD7    | SOA 9OA | RD5    | RD4 RD3 RD2 | RD3           | RD2    | RD1    | RD0    | RD0 0000 0000 0000 0000                                                                           | 0.0 |
| LATD        | 02D6   | LATD15  | LATD14  | LATD13  | -ATD 02D6 LATD15 LATD14 LATD13 LATD12 LATD11      | LATD11 | LATD10  | LATD9                                                        | LATD8  | LATD7  | LATD6   | LATD5  | LATD4       | LATD3         | LATD2  | LATD1  | LATD0  | LATD10 LATD9 LATD8 LATD7 LATD6 LATD5 LATD4 LATD3 LATD2 LATD1 LATD0 0000 0000 0000 0000            | 0.0 |
|             |        |         |         |         |                                                   |        |         |                                                              |        |        |         |        |             |               |        |        |        |                                                                                                   | 1   |

Refer to the "dsPIC30F Family Reference Manual" (DS70046) for descriptions of register bit fields. Note

## PORTF REGISTER MAP FOR dsPIC30F5011<sup>(1)</sup> **TABLE 8-7**:

|   | Reset State                                            | TRISF6 TRISF5 TRISF4 TRISF3 TRISF2 TRISF1 TRISF0 0000 0000 0111 1111 | RFO 0000 0000 0000 0000 | LATF6 LATF5 LATF4 LATF3 LATF2 LATF1 LATF0 0000 0000 0000 0000 |
|---|--------------------------------------------------------|----------------------------------------------------------------------|-------------------------|---------------------------------------------------------------|
|   | Bit 0                                                  | TRISF0                                                               | RF0                     | LATF0                                                         |
|   | Bit 1 Bit 0                                            | TRISF1                                                               | RF1                     | LATF1                                                         |
|   | Bit 2                                                  | TRISF2                                                               | RF2                     | LATF2                                                         |
|   | Bit 10 Bit 9 Bit 8 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 | TRISF3                                                               | RF3                     | LATF3                                                         |
|   | Bit 4                                                  | TRISF4                                                               | RF4                     | LATF4                                                         |
|   | Bit 5                                                  | TRISF5                                                               | RF5                     | LATF5                                                         |
|   | Bit 6                                                  | TRISF6                                                               | RF6                     | LATF6                                                         |
|   | Bit 7                                                  | I                                                                    | 1                       | 1                                                             |
|   | Bit 8                                                  | Ι                                                                    | Ι                       | 1                                                             |
|   | Bit 9                                                  | Ι                                                                    | -                       | I                                                             |
| 5 | Bit 10                                                 | I                                                                    | -                       | 1                                                             |
|   | Bit 11                                                 | Ι                                                                    | -                       | I                                                             |
|   | Bit 12                                                 | I                                                                    | 1                       | I                                                             |
|   | SFR Addr. Bit 15 Bit 14 Bit 13 Bit 12                  | I                                                                    | 1                       | I                                                             |
|   | Bit 14                                                 | Ι                                                                    | _                       | I                                                             |
| - | Bit 15                                                 | Ι                                                                    | _                       | 1                                                             |
|   | Addr.                                                  | TRISF 02DE                                                           | PORTF 02E0              | 02E2                                                          |
| 1 | SFR<br>Name                                            | TRISF                                                                | PORTF                   | LATF                                                          |

— = unimplemented, read as ' $^\circ$ ' Refer to the "dsPIC30F Family Reference Manual" (DS70046) for descriptions of register bit fields. Legend: Note 1:

## PORTF REGISTER MAP FOR dsPIC30F5013<sup>(1)</sup> TABLE 8-8:

| SFR Name         Addr.         Bit 15         Bit 14         Bit 15         Bit 14         Bit 3         Bit 2         Bit 14         Bit 13         Bit 14         Bit 14         Bit 15         Bit 14         Bit 15         Bit 15         Bit 14         Bit 15         Bit 15 </th <th></th> <th></th> <th></th> <th></th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |             |                     |                     |                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------|---------------------|---------------------|
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Reset State | 0000 0001 1111 1111 | 0000 0000 0000 0000 | 0000 0000 0000 0000 |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 0       | TRISF0              | RF0                 | LATF0               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 1       | TRISF1              | RF1                 | LATF1               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 2       | TRISF2              | RF2                 | LATF2               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 3       | TRISF3              | RF3                 | LATF3               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 4       | TRISF4              |                     | LATF4               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 5       | TRISF5              | RF5                 | LATF5               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 6       | TRISF6              | RF6                 | LATF6               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11     Bit 10     Bit 9       INDE     -     -     -     -     -     -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 7       | TRISF7              | RF7                 | LATF7               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11       2DE     —     —     —     —       02E0     —     —     —     —       02E0     —     —     —     —       02E0     —     —     —     —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Bit 8       | TRISF8              | RF8                 | LATF8               |
| Addr.     Bit 15     Bit 14     Bit 13     Bit 12     Bit 11       2DE     —     —     —     —       02E0     —     —     —     —       02E0     —     —     —     —       02E0     —     —     —     —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Bit 9       | Ι                   | _                   | 1                   |
| Addr. Bit 15 Bit 14 Bit 13 Bit 12 Bit 12 Bit 12 Bit 12 Bit 12 Bit 14 Bit 13 Bit 12 Bit 13 Bit 12 Bit 12 Bit 13 Bit 12 Bit 13 Bit 12 Bit 13 Bit 12 Bit 13 Bit | Bit 10      | I                   | I                   | I                   |
| Addr. Bit 15 Bit 14 Bit 13 Bit 12    DE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Bit 11      | I                   | ı                   | 1                   |
| Addr. Bit 15 Bit 14 Bit 13  2DE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bit 12      | I                   | Ι                   | I                   |
| Addr. Bit 15 Bit 14  2DE  22E0  22E2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Bit 13      | I                   | -                   | I                   |
| SFR<br>Name         Addr.         Bit 15           TRISF         02DE         —           PORTF         02E2         —           LATF         02E2         —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Bit 14      | I                   | I                   | I                   |
| Name Addr. TRISF 02DE PORTF 02E0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Bit 15      | I                   | Ι                   | I                   |
| SFR<br>Name<br>TRISF<br>PORTF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Addr.       | 02DE                | 02E0                | 02E2                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SFR<br>Name | TRISF               | PORTF               | LATF                |

Legend: Note 1:

— = unimplemented, read as '0' Reference Manual' (DS70046) for descriptions of register bit fields.

# PORTG REGISTER MAP FOR dsPIC30F5011/5013<sup>(1)</sup> TABLE 8-9:

|       |                                           | 1111                                            | 0000                           | 0000                                        |
|-------|-------------------------------------------|-------------------------------------------------|--------------------------------|---------------------------------------------|
|       | Reset State                               | 11 1100                                         | 0000 0000 0000 0000            | 0000 00                                     |
|       | Re                                        | TRISG3 TRISG2 TRISG1 TRISG0 1111 0011 1100 1111 |                                | LATG3 LATG2 LATG1 LATG0 0000 0000 0000 0000 |
|       | Bit 0                                     | TRISG0                                          | RG0                            | LATG0                                       |
|       | Bit 1                                     | TRISG1                                          | RG1                            | LATG1                                       |
|       | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 | TRISG2                                          | RG2                            | LATG2                                       |
|       | Bit 3                                     | TRISG3                                          | RG3                            |                                             |
|       | Bit 4                                     |                                                 | 1                              | 1                                           |
|       | Bit 5                                     | Ι                                               | Ι                              | Ι                                           |
|       | Bit 6                                     | TRISG6                                          | RG6                            | LATG6                                       |
|       | Bit 7                                     | TRISG7                                          | RG7                            | LATG7                                       |
| • • • | Bit 8                                     | TRISG9 TRISG8 TRISG7 TRISG6                     | RG8                            | LATG9 LATG8 LATG7 LATG6                     |
|       | Bit 11 Bit 10 Bit 9 Bit 8                 | TRISG9                                          | RG9                            | LATG9                                       |
|       | Bit 10                                    | 1                                               | _                              | ı                                           |
| •     | Bit 11                                    | _                                               | -                              | _                                           |
|       | Bit 12                                    | TRISG12                                         | RG12                           | LATG12                                      |
|       | Bit 13                                    | TRISG13                                         | RG13                           | LATG13                                      |
|       | Addr. Bit 15 Bit 14 Bit 13 Bit 12         | RISG 02E4 TRISG15 TRISG14 TRISG13 TRISG12       | PORTG 02E6 RG15 RG14 RG13 RG12 | LATG 02E8 LATG15 LATG14 LATG13 LATG12       |
|       | Bit 15                                    | TRISG15                                         | RG15                           | LATG15                                      |
|       | Addr.                                     | 02E4                                            | 02E6                           | 02E8                                        |
|       | SFR<br>Name                               | TRISG                                           | PORTG                          | LATG                                        |

— = unimplemented, read as '0' Reference Manual' (DS70046) for descriptions of register bit fields. Legend: Note 1:

## 15.4.1 10-BIT MODE SLAVE TRANSMISSION

Once a slave is addressed in this fashion with the full 10-bit address (we will refer to this state as "PRIOR\_ADDR\_MATCH"), the master can begin sending data bytes for a slave reception operation.

#### 15.4.2 10-BIT MODE SLAVE RECEPTION

Once addressed, the master can generate a Repeated Start, Reset the high byte of the address and set the R\_W bit without generating a Stop bit, thus initiating a slave transmit operation.

#### 15.5 Automatic Clock Stretch

In the Slave modes, the module can synchronize buffer reads and write to the master device by clock stretching.

#### 15.5.1 TRANSMIT CLOCK STRETCHING

Both 10-bit and 7-bit Transmit modes implement clock stretching by asserting the SCLREL bit after the falling edge of the ninth clock, if the TBF bit is cleared, indicating the buffer is empty.

In Slave Transmit modes, clock stretching is always performed irrespective of the STREN bit.

Clock synchronization takes place following the ninth clock of the transmit sequence. If the device samples an ACK on the falling edge of the ninth clock and if the TBF bit is still clear, then the SCLREL bit is automatically cleared. The SCLREL being cleared to '0' will assert the SCL line low. The user's ISR must set the SCLREL bit before transmission is allowed to continue. By holding the SCL line low, the user has time to service the ISR and load the contents of the I2CTRN before the master device can initiate another transmit sequence.

- Note 1: If the user loads the contents of I2CTRN, setting the TBF bit before the falling edge of the ninth clock, the SCLREL bit will not be cleared and clock stretching will not occur.
  - **2:** The SCLREL bit can be set in software, regardless of the state of the TBF bit.

#### 15.5.2 RECEIVE CLOCK STRETCHING

The STREN bit in the I2CCON register can be used to enable clock stretching in Slave Receive mode. When the STREN bit is set, the SCL pin will be held low at the end of each data receive sequence.

#### 15.5.3 CLOCK STRETCHING DURING 7-BIT ADDRESSING (STREN = 1)

When the STREN bit is set in Slave Receive mode, the SCL line is held low when the buffer register is full. The method for stretching the SCL output is the same for both 7 and 10-bit Addressing modes.

Clock stretching takes place following the ninth clock of the receive sequence. On the falling edge of the ninth clock at the end of the ACK sequence, if the RBF bit is set, the SCLREL bit is automatically cleared, forcing the SCL output to be held low. The user's ISR must set the SCLREL bit before reception is allowed to continue. By holding the SCL line low, the user has time to service the ISR and read the contents of the I<sup>2</sup>CRCV before the master device can initiate another receive sequence. This will prevent buffer overruns from occurring.

- Note 1: If the user reads the contents of the I2CRCV, clearing the RBF bit before the falling edge of the ninth clock, the SCLREL bit will not be cleared and clock stretching will not occur.
  - 2: The SCLREL bit can be set in software regardless of the state of the RBF bit. The user should be careful to clear the RBF bit in the ISR before the next receive sequence in order to prevent an overflow condition.

#### 15.5.4 CLOCK STRETCHING DURING 10-BIT ADDRESSING (STREN = 1)

Clock stretching takes place automatically during the addressing sequence. Because this module has a register for the entire address, it is not necessary for the protocol to wait for the address to be updated.

After the address phase is complete, clock stretching will occur on each data receive or transmit sequence as was described earlier.

#### 15.6 Software Controlled Clock Stretching (STREN = 1)

When the STREN bit is '1', the SCLREL bit may be cleared by software to allow software to control the clock stretching. The logic will synchronize writes to the SCLREL bit with the SCL clock. Clearing the SCLREL bit will not assert the SCL output until the module detects a falling edge on the SCL output and SCL is sampled low. If the SCLREL bit is cleared by the user while the SCL line has been sampled low, the SCL output will be asserted (held low). The SCL output will remain low until the SCLREL bit is set, and all other devices on the I<sup>2</sup>C bus have de-asserted SCL. This ensures that a write to the SCLREL bit will not violate the minimum high time requirement for SCL.

If the STREN bit is '0', a software write to the SCLREL bit will be disregarded and have no effect on the SCLREL bit.

#### 16.3.4 TRANSMIT INTERRUPT

The transmit interrupt flag (U1TXIF or U2TXIF) is located in the corresponding interrupt flag register.

The transmitter generates an edge to set the UxTXIF bit. The condition for generating the interrupt depends on the UTXISEL control bit:

- a) If UTXISEL = 0, an interrupt is generated when a word is transferred from the transmit buffer to the Transmit Shift register (UxTSR). This implies that the transmit buffer has at least one empty word.
- b) If UTXISEL = 1, an interrupt is generated when a word is transferred from the transmit buffer to the Transmit Shift register (UxTSR) and the transmit buffer is empty.

Switching between the two Interrupt modes during operation is possible and sometimes offers more flexibility.

#### 16.3.5 TRANSMIT BREAK

Setting the UTXBRK bit (UxSTA<11>) will cause the UxTX line to be driven to logic '0'. The UTXBRK bit overrides all transmission activity. Therefore, the user should generally wait for the transmitter to be Idle before setting UTXBRK.

To send a break character, the UTXBRK bit must be set by software and must remain set for a minimum of 13 baud clock cycles. The UTXBRK bit is then cleared by software to generate Stop bits. The user must wait for a duration of at least one or two baud clock cycles in order to ensure a valid Stop bit(s) before reloading the UxTXB, or starting other transmitter activity. Transmission of a break character does not generate a transmit interrupt.

#### 16.4 Receiving Data

## 16.4.1 RECEIVING IN 8-BIT OR 9-BIT DATA MODE

The following steps must be performed while receiving 8-bit or 9-bit data:

- Set up the UART (see Section 16.3.1 "Transmitting in 8-bit data mode").
- Enable the UART (see Section 16.3.1 "Transmitting in 8-bit data mode").
- A receive interrupt will be generated when one or more data words have been received, depending on the receive interrupt settings specified by the URXISEL bits (UxSTA<7:6>).
- Read the OERR bit to determine if an overrun error has occurred. The OERR bit must be reset in software.
- Read the received data from UxRXREG. The act of reading UxRXREG will move the next word to the top of the receive FIFO, and the PERR and FERR values will be updated.

#### 16.4.2 RECEIVE BUFFER (UXRXB)

The receive buffer is 4 words deep. Including the Receive Shift register (UxRSR), the user effectively has a 5-word deep FIFO buffer.

URXDA (UxSTA<0>) = 1 indicates that the receive buffer has data available. URXDA = 0 implies that the buffer is empty. If a user attempts to read an empty buffer, the old values in the buffer will be read and no data shift will occur within the FIFO.

The FIFO is reset during any device Reset. It is not affected when the device enters or wakes up from a Power-Saving mode.

#### 16.4.3 RECEIVE INTERRUPT

The receive interrupt flag (U1RXIF or U2RXIF) can be read from the corresponding interrupt flag register. The interrupt flag is set by an edge generated by the receiver. The condition for setting the receive interrupt flag depends on the settings specified by the URXISEL<1:0> (UxSTA<7:6>) control bits.

- a) If URXISEL<1:0> = 00 or 01, an interrupt is generated every time a data word is transferred from the Receive Shift register (UxRSR) to the receive buffer. There may be one or more characters in the receive buffer.
- b) If URXISEL<1:0> = 10, an interrupt is generated when a word is transferred from the Receive Shift register (UxRSR) to the receive buffer, which as a result of the transfer, contains 3 characters.
- c) If URXISEL<1:0> = 11, an interrupt is set when a word is transferred from the Receive Shift register (UxRSR) to the receive buffer, which as a result of the transfer, contains 4 characters (i.e., becomes full).

Switching between the Interrupt modes during operation is possible, though generally not advisable during normal operation.

#### 16.5 Reception Error Handling

## 16.5.1 RECEIVE BUFFER OVERRUN ERROR (OERR BIT)

The OERR bit (UxSTA<1>) is set if all of the following conditions occur:

- a) The receive buffer is full.
- b) The Receive Shift register is full, but unable to transfer the character to the receive buffer.
- c) The Stop bit of the character in the UxRSR is detected, indicating that the UxRSR needs to transfer the character to the buffer.

Once OERR is set, no further data is shifted in UxRSR (until the OERR bit is cleared in software or a Reset occurs). The data held in UxRSR and UxRXREG remains valid.

#### 16.5.2 FRAMING ERROR (FERR)

The FERR bit (UxSTA<2>) is set if a '0' is detected instead of a Stop bit. If two Stop bits are selected, both Stop bits must be '1', otherwise FERR will be set. The read-only FERR bit is buffered along with the received data. It is cleared on any Reset.

#### 16.5.3 PARITY ERROR (PERR)

The PERR bit (UxSTA<3>) is set if the parity of the received word is incorrect. This error bit is applicable only if a Parity mode (odd or even) is selected. The read-only PERR bit is buffered along with the received data bytes. It is cleared on any Reset.

#### 16.5.4 IDLE STATUS

When the receiver is active (i.e., between the initial detection of the Start bit and the completion of the Stop bit), the RIDLE bit (UxSTA<4>) is '0'. Between the completion of the Stop bit and detection of the next Start bit, the RIDLE bit is '1', indicating that the UART is Idle.

#### 16.5.5 RECEIVE BREAK

The receiver will count and expect a certain number of bit times based on the values programmed in the PDSEL (UxMODE<2:1>) and STSEL (UxMODE<0>) bits.

If the break is longer than 13 bit times, the reception is considered complete after the number of bit times specified by PDSEL and STSEL. The URXDA bit is set, FERR is set, zeros are loaded into the receive FIFO, interrupts are generated if appropriate and the RIDLE bit is set.

When the module receives a long break signal and the receiver has detected the Start bit, the data bits and the invalid Stop bit (which sets the FERR), the receiver must wait for a valid Stop bit before looking for the next Start bit. It cannot assume that the break condition on the line is the next Start bit.

Break is regarded as a character containing all '0's with the FERR bit set. The break character is loaded into the buffer. No further reception can occur until a Stop bit is received. Note that RIDLE goes high when the Stop bit has not yet been received.

#### 16.6 Address Detect Mode

Setting the ADDEN bit (UxSTA<5>) enables this special mode in which a 9th bit (URX8) value of '1' identifies the received word as an address, rather than data. This mode is only applicable for 9-bit data communication. The URXISEL control bit does not have any impact on interrupt generation in this mode since an interrupt (if enabled) will be generated every time the received word has the 9th bit set.

#### 16.7 Loopback Mode

Setting the LPBACK bit enables this special mode in which the UxTX pin is internally connected to the UxRX pin. When configured for the Loopback mode, the UxRX pin is disconnected from the internal UART receive logic. However, the UxTX pin still functions as in a normal operation.

To select this mode:

- 1. Configure UART for desired mode of operation.
- 2. Set LPBACK = 1 to enable Loopback mode.
- 3. Enable transmission as defined in **Section 16.3** "**Transmitting Data**".

#### 16.8 Baud Rate Generator

The UART has a 16-bit Baud Rate Generator to allow maximum flexibility in baud rate generation. The Baud Rate Generator register (UxBRG) is readable and writable. The baud rate is computed as follows:

BRG = 16-bit value held in UxBRG register (0 through 65535)

Fcy = Instruction Clock Rate (1/Tcy)

The Baud Rate is given by Equation 16-1.

#### **EQUATION 16-1: BAUD RATE**

 $Baud\ Rate = FCY/(16*(BRG+1))$ 

Therefore, the maximum baud rate possible is

Fcy/16 (if BRG = 0),

and the minimum baud rate possible is

Fcy/(16\* 65536).

With a full 16-bit Baud Rate Generator at 30 MIPS operation, the minimum baud rate achievable is 28.5 bps.

#### 17.3 Modes of Operation

The CAN module can operate in one of several operation modes selected by the user. These modes include:

- Initialization Mode
- · Disable Mode
- · Normal Operation Mode
- · Listen Only Mode
- · Loopback Mode
- Error Recognition Mode

Modes are requested by setting the REQOP<2:0> bits (CiCTRL<10:8>). Entry into a mode is Acknowledged by monitoring the OPMODE<2:0> bits (CiCTRL<7:5>). The module will not change the mode and the OPMODE bits until a change in mode is acceptable, generally during bus Idle time which is defined as at least 11 consecutive recessive bits.

#### 17.3.1 INITIALIZATION MODE

In the Initialization mode, the module will not transmit or receive. The error counters are cleared and the interrupt flags remain unchanged. The programmer will have access to configuration registers that are access restricted in other modes. The module will protect the user from accidentally violating the CAN protocol through programming errors. All registers which control the configuration of the module can not be modified while the module is on-line. The CAN module will not be allowed to enter the Configuration mode while a transmission is taking place. The Configuration mode serves as a lock to protect the following registers.

- · All Module Control Registers
- · Baud Rate and Interrupt Configuration Registers
- · Bus Timing Registers
- · Identifier Acceptance Filter Registers
- · Identifier Acceptance Mask Registers

#### 17.3.2 DISABLE MODE

In Disable mode, the module will not transmit or receive. The module has the ability to set the WAKIF bit due to bus activity, however, any pending interrupts will remain and the error counters will retain their value.

If the REQOP<2:0> bits (CiCTRL<10:8>) = 001, the module will enter the Module Disable mode. If the module is active, the module will wait for 11 recessive bits on the CAN bus, detect that condition as an Idle bus, then accept the module disable command. When the OPMODE<2:0> bits (CiCTRL<7:5>) = 001, that indicates whether the module successfully went into Module Disable mode. The I/O pins will revert to normal I/O function when the module is in the Module Disable mode.

The module can be programmed to apply a low-pass filter function to the CiRX input line while the module or the CPU is in Sleep mode. The WAKFIL bit (CiCFG2<14>) enables or disables the filter.

Note:

Typically, if the CAN module is allowed to transmit in a particular mode of operation and a transmission is requested immediately after the CAN module has been placed in that mode of operation, the module waits for 11 consecutive recessive bits on the bus before starting transmission. If the user switches to Disable mode within this 11-bit period, then this transmission is aborted and the corresponding TXABT bit is set and TXREQ bit is cleared.

#### 17.3.3 NORMAL OPERATION MODE

Normal operating mode is selected when REQOP<2:0> = 000. In this mode, the module is activated and the I/O pins assume the CAN bus functions. The module transmits and receives CAN bus messages via the CxTX and CxRX pins.

#### 17.3.4 LISTEN ONLY MODE

If the Listen Only mode is activated, the module on the CAN bus is passive. The transmitter buffers revert to the port I/O function. The receive pins remain inputs. For the receiver, no error flags or Acknowledge signals are sent. The error counters are deactivated in this state. The Listen Only mode can be used for detecting the baud rate on the CAN bus. To use this, it is necessary that there are at least two further nodes that communicate with each other.

#### 17.3.5 LISTEN ALL MESSAGES MODE

The module can be set to ignore all errors and receive any message. The Listen All Messages mode is activated by setting the REQOP<2:0> bits to '111'. In this mode, the data which is in the message assembly buffer until the time an error occurred, is copied in the receive buffer and can be read via the CPU interface.

#### 17.3.6 LOOPBACK MODE

If the Loopback mode is activated, the module connects the internal transmit signal to the internal receive signal at the module boundary. The transmit and receive pins revert to their port I/O function.

#### · Receive Error Interrupts:

A receive error interrupt will be indicated by the ERRIF bit. This bit shows that an error condition occurred. The source of the error can be determined by checking the bits in the CAN Interrupt Status register, CiINTF.

#### - Invalid Message Received:

If any type of error occurred during reception of the last message, an error will be indicated by the IVRIF bit.

#### Receiver Overrun:

The RXnOVR bit indicates that an overrun condition occurred.

#### - Receiver Warning:

The RXWAR bit indicates that the receive error counter (RERRCNT<7:0>) has reached the warning limit of 96.

#### - Receiver Error Passive:

The RXEP bit indicates that the receive error counter has exceeded the error passive limit of 127 and the module has gone into error passive state.

#### 17.5 Message Transmission

#### 17.5.1 TRANSMIT BUFFERS

The CAN module has three transmit buffers. Each of the three buffers occupies 14 bytes of data. Eight of the bytes are the maximum 8 bytes of the transmitted message. Five bytes hold the standard and extended identifiers and other message arbitration information.

#### 17.5.2 TRANSMIT MESSAGE PRIORITY

Transmit priority is a prioritization within each node of the pending transmittable messages. There are 4 levels of transmit priority. If TXPRI<1:0> (CiTXnCON<1:0>, where n = 0, 1 or 2 represents a particular transmit buffer) for a particular message buffer is set to '11', that buffer has the highest priority. If TXPRI<1:0> for a particular message buffer is set to '10' or '01', that buffer has an intermediate priority. If TXPRI<1:0> for a particular message buffer is '00', that buffer has the lowest priority.

#### 17.5.3 TRANSMISSION SEQUENCE

To initiate transmission of the message, the TXREQ bit (CiTXnCON<3>) must be set. The CAN bus module resolves any timing conflicts between setting of the TXREQ bit and the Start-of-Frame (SOF), ensuring that if the priority was changed, it is resolved correctly before the SOF occurs. When TXREQ is set, the TXABT (CiTXnCON<6>), TXLARB (CiTXnCON<5>) and TXERR (CiTXnCON<4>) flag bits are automatically cleared.

Setting TXREQ bit simply flags a message buffer as enqueued for transmission. When the module detects an available bus, it begins transmitting the message which has been determined to have the highest priority.

If the transmission completes successfully on the first attempt, the TXREQ bit is cleared automatically, and an interrupt is generated if TXIE was set.

If the message transmission fails, one of the error condition flags will be set, and the TXREQ bit will remain set indicating that the message is still pending for transmission. If the message encountered an error condition during the transmission attempt, the TXERR bit will be set, and the error condition may cause an interrupt. If the message loses arbitration during the transmission attempt, the TXLARB bit is set. No interrupt is generated to signal the loss of arbitration.

## 17.5.4 ABORTING MESSAGE TRANSMISSION

The system can also abort a message by clearing the TXREQ bit associated with each message buffer. Setting the ABAT bit (CiCTRL<12>) will request an abort of all pending messages. If the message has not yet started transmission, or if the message started but is interrupted by loss of arbitration or an error, the abort will be processed. The abort is indicated when the module sets the TXABT bit and the TXnIF flag is not automatically set.

#### 17.5.5 TRANSMISSION ERRORS

The CAN module will detect the following transmission errors:

- · Acknowledge Error
- · Form Error
- · Bit Error

These transmission errors will not necessarily generate an interrupt but are indicated by the transmission error counter. However, each of these errors will cause the transmission error counter to be incremented by one. Once the value of the error counter exceeds the value of 96, the ERRIF bit (CilNTF<5>) and the TXWAR bit (CilNTF<10>) are set. Once the value of the error counter exceeds the value of 96, an interrupt is generated and the TXWAR bit in the Error Flag register is set.

#### 21.0 INSTRUCTION SET SUMMARY

Note:

This data sheet summarizes features of this group of dsPIC30F devices and is not intended to be a complete reference source. For more information on the CPU, peripherals, register descriptions and general device functionality, refer to the "dsPIC30F Family Reference Manual" (DS70046). For more information on the device instruction set and programming, refer to the "16-bit MCU and DSC Programmer's Reference Manual" (DS70157).

The dsPIC30F instruction set adds many enhancements to the previous PIC® MCU instruction sets, while maintaining an easy migration from PIC MCU instruction sets.

Most instructions are a single program memory word (24 bits). Only three instructions require two program memory locations.

Each single-word instruction is a 24-bit word divided into an 8-bit opcode which specifies the instruction type, and one or more operands which further specify the operation of the instruction.

The instruction set is highly orthogonal and is grouped into five basic categories:

- · Word or byte-oriented operations
- · Bit-oriented operations
- · Literal operations
- DSP operations
- · Control operations

Table 21-1 shows the general symbols used in describing the instructions.

The dsPIC30F instruction set summary in Table 21-2 lists all the instructions, along with the status flags affected by each instruction.

Most word or byte-oriented W register instructions (including barrel shift instructions) have three operands:

- The first source operand which is typically a register 'Wb' without any address modifier
- The second source operand which is typically a register 'Ws' with or without an address modifier
- The destination of the result which is typically a register 'Wd' with or without an address modifier

However, word or byte-oriented file register instructions have two operands:

- · The file register specified by the value 'f'
- The destination, which could either be the file register 'f' or the W0 register, which is denoted as 'WREG'

Most bit-oriented instructions (including simple rotate/shift instructions) have two operands:

- The W register (with or without an address modifier) or file register (specified by the value of 'Ws' or 'f')
- The bit in the W register or file register (specified by a literal value or indirectly by the contents of register 'Wb')

The literal instructions that involve data movement may use some of the following operands:

- A literal value to be loaded into a W register or file register (specified by the value of 'k')
- The W register or file register where the literal value is to be loaded (specified by 'Wb' or 'f')

However, literal instructions that involve arithmetic or logical operations use some of the following operands:

- The first source operand which is a register 'Wb' without any address modifier
- The second source operand which is a literal value
- The destination of the result (only if not the same as the first source operand) which is typically a register 'Wd' with or without an address modifier

The MAC class of DSP instructions may use some of the following operands:

- The accumulator (A or B) to be used (required operand)
- The W registers to be used as the two operands
- · The X and Y address space prefetch operations
- · The X and Y address space prefetch destinations
- · The accumulator write back destination

The other DSP instructions do not involve any multiplication, and may include:

- · The accumulator to be used (required)
- The source or destination operand (designated as Wso or Wdo, respectively) with or without an address modifier
- The amount of shift specified by a W register 'Wn' or a literal value

The control instructions may use some of the following operands:

- · A program memory address
- The mode of the table read and table write instructions

TABLE 21-2: INSTRUCTION SET OVERVIEW (CONTINUED)

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

#### 22.0 DEVELOPMENT SUPPORT

The PIC® microcontrollers and dsPIC® digital signal controllers are supported with a full range of software and hardware development tools:

- · Integrated Development Environment
  - MPLAB® IDE Software
- · Compilers/Assemblers/Linkers
  - MPLAB C Compiler for Various Device Families
  - HI-TECH C for Various Device Families
  - MPASM<sup>TM</sup> Assembler
  - MPLINK™ Object Linker/ MPLIB™ Object Librarian
  - MPLAB Assembler/Linker/Librarian for Various Device Families
- · Simulators
  - MPLAB SIM Software Simulator
- Emulators
  - MPLAB REAL ICE™ In-Circuit Emulator
- · In-Circuit Debuggers
  - MPLAB ICD 3
  - PICkit™ 3 Debug Express
- · Device Programmers
  - PICkit™ 2 Programmer
  - MPLAB PM3 Device Programmer
- Low-Cost Demonstration/Development Boards, Evaluation Kits, and Starter Kits

## 22.1 MPLAB Integrated Development Environment Software

The MPLAB IDE software brings an ease of software development previously unseen in the 8/16/32-bit microcontroller market. The MPLAB IDE is a Windows® operating system-based application that contains:

- A single graphical interface to all debugging tools
  - Simulator
  - Programmer (sold separately)
  - In-Circuit Emulator (sold separately)
  - In-Circuit Debugger (sold separately)
- · A full-featured editor with color-coded context
- A multiple project manager
- Customizable data windows with direct edit of contents
- · High-level source code debugging
- · Mouse over variable inspection
- Drag and drop variables from source to watch windows
- · Extensive on-line help
- Integration of select third party tools, such as IAR C Compilers

The MPLAB IDE allows you to:

- · Edit your source files (either C or assembly)
- One-touch compile or assemble, and download to emulator and simulator tools (automatically updates all project information)
- · Debug using:
  - Source files (C or assembly)
  - Mixed C and assembly
  - Machine code

MPLAB IDE supports multiple debugging tools in a single development paradigm, from the cost-effective simulators, through low-cost in-circuit debuggers, to full-featured emulators. This eliminates the learning curve when upgrading to tools with increased flexibility and power.

TABLE 23-5: DC CHARACTERISTICS: OPERATING CURRENT (IDD) (CONTINUED)

| DC CHARACT       | ERISTICS                  |      | (unless oth | erwise stated<br>emperature | ,<br>-40°C ≤TA ≤+85 | o 5.5V  °C for Industrial  5°C for Extended |
|------------------|---------------------------|------|-------------|-----------------------------|---------------------|---------------------------------------------|
| Parameter<br>No. | Typical <sup>(1)</sup>    | Max  | Units       |                             | Co                  | nditions                                    |
| Operating Cur    | rent (IDD) <sup>(2)</sup> |      |             |                             |                     |                                             |
| DC23a            | 13.5                      | 20   | mA          | 25°C                        |                     |                                             |
| DC23b            | 14                        | 21   | mA          | 85°C                        | 3.3V                |                                             |
| DC23c            | 15                        | 22.5 | mA          | 125°C                       |                     | 4 MIPS                                      |
| DC23e            | 23                        | 34.5 | mA          | 25°C                        |                     | 4 1/11/25                                   |
| DC23f            | 23.5                      | 35   | mA          | 85°C                        | 5V                  |                                             |
| DC23g            | 24                        | 36   | mA          | 125°C                       |                     |                                             |
| DC24a            | 32                        | 48   | mA          | 25°C                        |                     |                                             |
| DC24b            | 32.5                      | 49   | mA          | 85°C                        | 3.3V                |                                             |
| DC24c            | 33                        | 49.5 | mA          | 125°C                       |                     | 10 MIPS                                     |
| DC24e            | 53.5                      | 80   | mA          | 25°C                        |                     | TO MIPS                                     |
| DC24f            | 54                        | 81   | mA          | 85°C                        | 5V                  |                                             |
| DC24g            | 54                        | 81   | mA          | 125°C                       |                     |                                             |
| DC27d            | 101                       | 152  | mA          | 25°C                        |                     |                                             |
| DC27e            | 100                       | 150  | mA          | 85°C                        | 5V                  | 20 MIPS                                     |
| DC27f            | 100                       | 150  | mA          | 125°C                       |                     |                                             |
| DC29a            | 145                       | 217  | mA          | 25°C                        | 5V                  | 30 MIPS                                     |
| DC29b            | 144                       | 216  | mA          | 85°C                        | 3V                  | JU WIIFS                                    |

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

<sup>2:</sup> The supply current is mainly a function of the operating voltage and frequency. Other factors such as I/O pin loading and switching rate, oscillator type, internal code execution pattern and temperature also have an impact on the current consumption. The test conditions for all IDD measurements are as follows: OSC1 driven with external square wave from rail to rail. All I/O pins are configured as Inputs and pulled to VDD. MCLR = VDD, WDT, FSCM, LVD and BOR are disabled. CPU, SRAM, Program Memory and Data Memory are operational. No peripheral modules are operating.

#### FIGURE 23-10: OUTPUT COMPARE MODULE (OCx) TIMING CHARACTERISTICS



#### TABLE 23-27: OUTPUT COMPARE MODULE TIMING REQUIREMENTS

| AC CHA       | ARACTER | ISTICS                        | (unless | d Operati<br>otherwis<br>ng temper | ature -40 | °C ≤TA ≤ | V to 5.5V<br>-85°C for Industrial<br>-125°C for Extended |
|--------------|---------|-------------------------------|---------|------------------------------------|-----------|----------|----------------------------------------------------------|
| Param<br>No. | Symbol  | Characteristic <sup>(1)</sup> | Min     | Typ <sup>(2)</sup>                 | Max       | Units    | Conditions                                               |
| OC10         | TccF    | OCx Output Fall Time          | _       | _                                  | _         | ns       | See Parameter DO32                                       |
| OC11         | TccR    | OCx Output Rise Time          | _       | _                                  | _         | ns       | See Parameter DO31                                       |

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

<sup>2:</sup> Data in "Typ" column is at 5V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested.

TABLE 23-29: DCI MODULE (MULTICHANNEL, I<sup>2</sup>S MODES) TIMING REQUIREMENTS

| AC CHA       | ARACTERIS | STICS                                                                    | Standard O<br>(unless oth<br>Operating to | erwise st          | <b>ated)</b><br>e -40°C: | ≤Ta ≤+85° | <b>5.5V</b> C for Industrial °C for Extended |
|--------------|-----------|--------------------------------------------------------------------------|-------------------------------------------|--------------------|--------------------------|-----------|----------------------------------------------|
| Param<br>No. | Symbol    | Characteristic <sup>(1)</sup>                                            | Min                                       | Typ <sup>(2)</sup> | Max                      | Units     | Conditions                                   |
| CS10         | TCSCKL    | CSCK Input Low Time<br>(CSCK pin is an input)                            | Tcy / 2 + 20                              | _                  | _                        | ns        |                                              |
|              |           | CSCK Output Low Time <sup>(3)</sup> (CSCK pin is an output)              | 30                                        | _                  | _                        | ns        |                                              |
| CS11         | Тсѕскн    | CSCK Input High Time (CSCK pin is an input)                              | Tcy / 2 + 20                              | _                  | _                        | ns        |                                              |
|              |           | CSCK Output High Time <sup>(3)</sup> (CSCK pin is an output)             | 30                                        | _                  | _                        | ns        |                                              |
| CS20         | Tcsckf    | CSCK Output Fall Time <sup>(4)</sup><br>(CSCK pin is an output)          | _                                         | 10                 | 25                       | ns        |                                              |
| CS21         | Tcsckr    | CSCK Output Rise Time <sup>(4)</sup> (CSCK pin is an output)             | _                                         | 10                 | 25                       | ns        |                                              |
| CS30         | Tcsdof    | CSDO Data Output Fall Time(4)                                            | _                                         | 10                 | 25                       | ns        |                                              |
| CS31         | Tcsdor    | CSDO Data Output Rise Time <sup>(4)</sup>                                | _                                         | 10                 | 25                       | ns        |                                              |
| CS35         | TDV       | Clock edge to CSDO data valid                                            | _                                         | _                  | 10                       | ns        |                                              |
| CS36         | TDIV      | Clock edge to CSDO tri-stated                                            | 10                                        | _                  | 20                       | ns        |                                              |
| CS40         | TCSDI     | Setup time of CSDI data input to CSCK edge (CSCK pin is input or output) | 20                                        | _                  | _                        | ns        |                                              |
| CS41         | THCSDI    | Hold time of CSDI data input to CSCK edge (CSCK pin is input or output)  | 20                                        | _                  | _                        | ns        |                                              |
| CS50         | Tcofsf    | COFS Fall Time<br>(COFS pin is output)                                   | _                                         | 10                 | 25                       | ns        | Note 1                                       |
| CS51         | Tcofsr    | COFS Rise Time<br>(COFS pin is output)                                   | _                                         | 10                 | 25                       | ns        | Note 1                                       |
| CS55         | Tscofs    | Setup time of COFS data input to CSCK edge (COFS pin is input)           | 20                                        | _                  | _                        | ns        |                                              |
| CS56         | THCOFS    | Hold time of COFS data input to CSCK edge (COFS pin is input)            | 20                                        | _                  | _                        | ns        |                                              |

- Note 1: These parameters are characterized but not tested in manufacturing.
  - **2:** Data in "Typ" column is at 5V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested.
  - **3:** The minimum clock period for CSCK is 100 ns. Therefore, the clock generated in Master mode must not violate this specification.
  - 4: Assumes 50 pF load on all DCI pins.



FIGURE 23-14: SPI MODULE MASTER MODE (CKE = 0) TIMING CHARACTERISTICS

TABLE 23-31: SPI MASTER MODE (CKE = 0) TIMING REQUIREMENTS

| AC CHA       | ARACTERIST            | rics                                         | Standard (<br>(unless ot<br>Operating | herwise s          | <b>tated)</b><br>re -40°C | ≤TA ≤+85° | o <b>5.5V</b> °C for Industrial  5°C for Extended |
|--------------|-----------------------|----------------------------------------------|---------------------------------------|--------------------|---------------------------|-----------|---------------------------------------------------|
| Param<br>No. | Symbol                | Characteristic <sup>(1)</sup>                | Min                                   | Typ <sup>(2)</sup> | Max                       | Units     | Conditions                                        |
| SP10         | TscL                  | SCKx Output Low Time <sup>(3)</sup>          | Tcy / 2                               | _                  | _                         | ns        |                                                   |
| SP11         | TscH                  | SCKx Output High Time <sup>(3)</sup>         | Tcy/2                                 | _                  |                           | ns        |                                                   |
| SP20         | TscF                  | SCKx Output Fall Time <sup>(4</sup>          | _                                     | _                  | _                         | ns        | See parameter<br>DO32                             |
| SP21         | TscR                  | SCKx Output Rise Time <sup>(4)</sup>         | _                                     | _                  | _                         | ns        | See parameter<br>DO31                             |
| SP30         | TdoF                  | SDOx Data Output Fall Time <sup>(4)</sup>    | _                                     | _                  | _                         | ns        | See parameter<br>DO32                             |
| SP31         | TdoR                  | SDOx Data Output Rise<br>Time <sup>(4)</sup> | _                                     | _                  | _                         | ns        | See parameter<br>DO31                             |
| SP35         | TscH2doV,<br>TscL2doV | SDOx Data Output Valid after SCKx Edge       | _                                     | _                  | 30                        | ns        |                                                   |
| SP40         | TdiV2scH,<br>TdiV2scL | Setup Time of SDIx Data Input to SCKx Edge   | 20                                    | _                  | _                         | ns        |                                                   |
| SP41         | TscH2diL,<br>TscL2diL | Hold Time of SDIx Data Input to SCKx Edge    | 20                                    | _                  | _                         | ns        |                                                   |

- Note 1: These parameters are characterized but not tested in manufacturing.
  - 2: Data in "Typ" column is at 5V, 25°C unless otherwise stated. Parameters are for design guidance only and are not tested.
  - **3:** The minimum clock period for SCK is 100 ns. Therefore, the clock generated in Master mode must not violate this specification.
  - 4: Assumes 50 pF load on all SPI pins.

| I <sup>2</sup> C 10-bit Slave Mode Operation            | 93    | Internal Clock Timing Examples                     | 175   |
|---------------------------------------------------------|-------|----------------------------------------------------|-------|
| Reception                                               | 94    | Internet Address                                   | . 215 |
| Transmission                                            |       | Interrupt Controller                               |       |
| I <sup>2</sup> C 7-bit Slave Mode Operation             | 93    | Register Map                                       |       |
| Reception                                               | 93    | Interrupt Priority                                 |       |
| Transmission                                            |       | Traps                                              | 37    |
| I <sup>2</sup> C Master Mode Operation                  | 95    | Interrupt Sequence                                 | 39    |
| Baud Rate Generator                                     | 96    | Interrupt Stack Frame                              | 39    |
| Clock Arbitration                                       | 96    | Interrupts                                         |       |
| Multi-Master Communication, Bus Collision and bitration |       | L                                                  |       |
| Reception                                               | 95    | Load Conditions                                    | 173   |
| Transmission                                            |       | Low Voltage Detect (LVD)                           | . 147 |
| I <sup>2</sup> C Master Mode Support                    |       | Low-Voltage Detect Characteristics                 |       |
| I <sup>2</sup> C Module                                 |       | LVDL Characteristics                               |       |
| Addresses                                               |       |                                                    |       |
| Bus Data Timing Characteristics                         |       | M                                                  |       |
| Master Mode                                             | 104   | Memory Organization                                | 23    |
| Slave Mode                                              |       | Core Register Map                                  |       |
| Bus Data Timing Requirements                            | 150   | Microchip Internet Web Site                        |       |
| Master Mode                                             | 105   | Modes of Operation                                 |       |
| Slave Mode                                              |       | Disable                                            | 109   |
|                                                         | 197   | Initialization                                     |       |
| Bus Start/Stop Bits Timing Characteristics              | 404   | Listen All Messages                                |       |
| Master Mode                                             |       | Listen Only                                        |       |
| Slave Mode                                              |       | Loopback                                           |       |
| General Call Address Support                            |       | Normal Operation                                   |       |
| Interrupts                                              |       | Modulo Addressing                                  |       |
| IPMI Support                                            |       |                                                    |       |
| Operating Function Description                          |       | Applicability                                      |       |
| Operation During CPU Sleep and Idle Modes               |       | Incrementing Buffer Operation Example              |       |
| Pin Configuration                                       |       | Start and End Address                              |       |
| Programmer's Model                                      | 91    | W Address Register Selection                       |       |
| Register Map                                            | 97    | MPLAB ASM30 Assembler, Linker, Librarian           |       |
| Registers                                               | 91    | MPLAB Integrated Development Environment Software. |       |
| Slope Control                                           | 95    | MPLAB PM3 Device Programmer                        |       |
| Software Controlled Clock Stretching (STREN =           | 1) 94 | MPLAB REAL ICE In-Circuit Emulator System          |       |
| Various Modes                                           | 91    | MPLINK Object Linker/MPLIB Object Librarian        | . 160 |
| I <sup>2</sup> S Mode Operation                         | 125   | N                                                  |       |
| Data Justification                                      |       |                                                    |       |
| Frame and Data Word Length Selection                    | 125   | NVM                                                |       |
| Idle Current (IIDLE)                                    | 167   | Register Map                                       | 51    |
| In-Circuit Serial Programming (ICSP)                    |       | 0                                                  |       |
| Input Capture (CAPX) Timing Characteristics             |       |                                                    |       |
| Input Capture Module                                    |       | OC/PWM Module Timing Characteristics               |       |
| Interrupts                                              |       | Operating Current (IDD)                            | . 165 |
| Register Map                                            |       | Oscillator                                         |       |
| Input Capture Operation During Sleep and Idle Modes     |       | Configurations                                     | . 140 |
| CPU Idle Mode                                           |       | Fail-Safe Clock Monitor                            | 142   |
| CPU Sleep Mode                                          |       | Fast RC (FRC)                                      | 141   |
| •                                                       |       | Initial Clock Source Selection                     |       |
| Input Capture Timing Requirements                       |       | Low Power RC (LPRC)                                | . 141 |
| Input Change Notification Module                        |       | LP Oscillator Control                              |       |
| dsPIC30F5011 Register Map (Bits 15-8)                   |       | Phase Locked Loop (PLL)                            |       |
| dsPIC30F5011 Register Map (Bits 7-0)                    |       | Start-up Timer (OST)                               |       |
| dsPIC30F5013 Register Map (Bits 15-8)                   |       | Operating Modes (Table)                            |       |
| dsPIC30F5013 Register Map (Bits 7-0)                    |       | System Overview                                    |       |
| Instruction Addressing Modes                            |       | Oscillator Selection                               |       |
| File Register Instructions                              |       | Oscillator Start-up Timer                          | . 131 |
| Fundamental Modes Supported                             |       | Timing Characteristics                             | 179   |
| MAC Instructions                                        | 42    |                                                    |       |
| MCU Instructions                                        | 41    | Timing Requirements                                |       |
| Move and Accumulator Instructions                       | 42    | Output Compare Interrupts                          |       |
| Other Instructions                                      | 42    | Output Compare Module                              |       |
| Instruction Set                                         |       | Register Map                                       |       |
| Overview                                                | 154   | Timing Characteristics                             |       |
| Summary                                                 | 151   | Timing Requirements                                |       |
| •                                                       |       | Output Compare Operation During CPU Idle Mode      | 84    |

| Output Compare Sleep Mode Operation            | 84           | Oscillator Start-up Timer (OST)                        | 137        |
|------------------------------------------------|--------------|--------------------------------------------------------|------------|
| P                                              |              | POR                                                    | 445        |
|                                                | 202          | Operating without FSCM and PWRT                        |            |
| Packaging Information                          |              | With Long Crystal Start-up Time                        |            |
| Marking                                        |              | POR (Power-on Reset)                                   |            |
| Peripheral Module Disable (PMD) Registers      |              | Power-on Reset (POR)                                   |            |
| Pinout Descriptions                            |              | Power-up Timer (PWRT)                                  |            |
| PLL Clock Timing Specifications                | 1/5          | Reset Sequence                                         |            |
| POR. See Power-on Reset.                       |              | Reset Sources                                          | 37         |
| Port Write/Read Example                        | 58           | Reset Sources                                          |            |
| PORTA                                          |              | Brown-out Reset (BOR)                                  |            |
| Register Map for dsPIC30F5013                  | 59           | Illegal Instruction Trap                               |            |
| PORTB                                          |              | Trap Lockout                                           |            |
| Register Map for dsPIC30F5011/5013             | 59           | Uninitialized W Register Trap                          | 37         |
| PORTC                                          |              | Watchdog Time-out                                      | 37         |
| Register Map for dsPIC30F5011                  | 59           | Reset Timing Characteristics                           | 178        |
| Register Map for dsPIC30F5013                  | 59           | Reset Timing Requirements                              | 179        |
| PORTD                                          |              | Run-Time Self-Programming (RTSP)                       | 47         |
| Register Map for dsPIC30F5011                  | 60           |                                                        |            |
| Register Map for dsPIC30F5013                  |              | <b>S</b>                                               |            |
| PORTF                                          |              | Simple Capture Event Mode                              | 77         |
| Register Map for dsPIC30F5011                  | 60           | Buffer Operation                                       |            |
| Register Map for dsPIC30F5013                  |              | Hall Sensor Mode                                       |            |
| PORTG                                          |              | Prescaler                                              |            |
| Register Map for dsPIC30F5011/5013             | 61           | Timer2 and Timer3 Selection Mode                       |            |
| Power Saving Modes                             |              | Simple OC/PWM Mode Timing Requirements                 |            |
| Idle                                           |              | • • • • • • • • • • • • • • • • • • • •                |            |
|                                                |              | Simple Output Compare Match Mode                       |            |
| Sleep and Idla                                 |              | Simple PWM Mode                                        |            |
| Sleep and Idle                                 |              | Input Pin Fault Protection                             |            |
| Power-Down Current (IPD)                       | 168          | Period                                                 |            |
| Power-up Timer                                 |              | Software Simulator (MPLAB SIM)                         |            |
| Timing Characteristics                         |              | Software Stack Pointer, Frame Pointer                  |            |
| Timing Requirements                            |              | CALL Stack Frame                                       |            |
| Program Address Space                          | 23           | SPI Module                                             |            |
| Construction                                   |              | Framed SPI Support                                     |            |
| Data Access from Program Memory Usin           | ng Program   | Operating Function Description                         | 87         |
| Space Visibility                               | 26           | Operation During CPU Idle Mode                         | 89         |
| Data Access From Program Memory Usir           | ng Table In- | Operation During CPU Sleep Mode                        | 89         |
| structions                                     | 25           | SDOx Disable                                           | 87         |
| Data Access from, Address Generation           | 24           | Slave Select Synchronization                           | 89         |
| Data Space Window into Operation               | 27           | SPI1 Register Map                                      | 90         |
| Data Table Access (LS Word)                    |              | SPI2 Register Map                                      |            |
| Data Table Access (MS Byte)                    |              | Timing Characteristics                                 |            |
| Memory Map                                     |              | Master Mode (CKE = 0)                                  | 189        |
| Table Instructions                             |              | Master Mode (CKE = 1)                                  |            |
| TBLRDH                                         | 25           | Slave Mode (CKE = 1)                                   |            |
| TBLRDL                                         |              | Timing Requirements                                    | . 101, 102 |
| TBLWTH                                         |              | Master Mode (CKE = 0)                                  | 180        |
| TBLWTL                                         |              | Master Mode (CKE = 1)                                  |            |
|                                                |              |                                                        |            |
| Program and EEPROM Characteristics             |              | Slave Mode (CKE = 0)                                   |            |
| Program Counter                                |              | Slave Mode (CKE = 1)                                   |            |
| Programmable                                   |              | Word and Byte Communication                            |            |
| Programmer's Model                             |              | Status Bits, Their Significance and the Initialization |            |
| Diagram                                        |              | for RCON Register, Case 1                              |            |
| Programming Operations                         |              | Status Bits, Their Significance and the Initialization |            |
| Algorithm for Program Flash                    | 49           | for RCON Register, Case 2                              |            |
| Erasing a Row of Program Memory                | 49           | Status Register                                        |            |
| Initiating the Programming Sequence            |              | Symbols Used in Opcode Descriptions                    | 152        |
| Loading Write Latches                          |              | System Integration                                     | 137        |
| Protection Against Accidental Writes to OSCCON |              | Register Map                                           |            |
| R                                              |              | T                                                      |            |
|                                                | 216          | Table Instruction Operation Summers                    | 17         |
| Reader Response                                |              | Table Instruction Operation Summary                    | 41         |
| Reset                                          |              | Temperature and Voltage Specifications                 | 470        |
| BOR, Programmable                              |              | AC                                                     |            |
| Brown-out Reset (BOR)                          | 13/          | Timer1 Module                                          | სპ         |