

Welcome to E-XFL.COM

### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

### Details

E·XFI

| Betans                     |                                                                               |
|----------------------------|-------------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                      |
| Core Processor             | dsPIC                                                                         |
| Core Size                  | 16-Bit                                                                        |
| Speed                      | 20 MIPS                                                                       |
| Connectivity               | CANbus, I <sup>2</sup> C, SPI, UART/USART                                     |
| Peripherals                | Brown-out Detect/Reset, Motor Control PWM, QEI, POR, PWM, WDT                 |
| Number of I/O              | 68                                                                            |
| Program Memory Size        | 66KB (22K x 24)                                                               |
| Program Memory Type        | FLASH                                                                         |
| EEPROM Size                | 1K x 8                                                                        |
| RAM Size                   | 2K x 8                                                                        |
| Voltage - Supply (Vcc/Vdd) | 2.5V ~ 5.5V                                                                   |
| Data Converters            | A/D 16x10b                                                                    |
| Oscillator Type            | Internal                                                                      |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                             |
| Mounting Type              | Surface Mount                                                                 |
| Package / Case             | 80-TQFP                                                                       |
| Supplier Device Package    | 80-TQFP (12x12)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/dspic30f5016-20i-pt |
|                            |                                                                               |

Email: info@E-XFL.COM

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

## 2.2 Pins Used During Programming

The pins identified in Table 2-1 are used for device programming. Refer to the appropriate device data sheet for complete pin descriptions.

### TABLE 2-1: dsPIC30F PIN DESCRIPTIONS DURING PROGRAMMING

| Pin Name | Pin Type | Pin Description    |
|----------|----------|--------------------|
| MCLR/VPP | Р        | Programming Enable |
| Vdd      | Р        | Power Supply       |
| Vss      | Р        | Ground             |
| PGC      | I        | Serial Clock       |
| PGD      | I/O      | Serial Data        |

Legend: I = Input, O = Output, P = Power

## 2.3 Program Memory Map

The program memory space extends from 0x0 to 0xFFFFFE. Code storage is located at the base of the memory map and supports up to 144 Kbytes (48K instruction words). Code is stored in three, 48 Kbyte memory panels that reside on-chip. Table 2-2 shows the location and program memory size of each device.

Locations 0x800000 through 0x8005BE are reserved for executive code memory. This region stores either the programming executive or debugging executive. The programming executive is used for device programming, while the debug executive is used for incircuit debugging. This region of memory cannot be used to store user code.

Locations 0xF80000 through 0xF8000E are reserved for the Configuration registers. The bits in these registers may be set to select various device options, and are described in **Section 5.7 "Configuration Bits Programming"**.

Locations 0xFF0000 and 0xFF0002 are reserved for the Device ID registers. These bits can be used by the programmer to identify what device type is being programmed and are described in **Section 10.0 "Device ID"**. The device ID reads out normally, even after code protection is applied.

Figure 2-2 illustrates the memory map for the dsPIC30F devices.

## 2.4 Data EEPROM Memory

The Data EEPROM array supports up to 4 Kbytes of data and is located in one memory panel. It is mapped in program memory space, residing at the end of User Memory Space (see Figure 2-2). Table 2-2 shows the location and size of data EEPROM in each device.

### TABLE 2-2: CODE MEMORY AND DATA EEPROM MAP AND SIZE

| Device                               | Code Memory map<br>(Size in Instruction Words) | Data EEPROM Memory Map<br>(Size in Bytes) |  |  |
|--------------------------------------|------------------------------------------------|-------------------------------------------|--|--|
| dsPIC30F2010                         | 0x000000-0x001FFE (4K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F2011                         | 0x000000-0x001FFE (4K)                         | None (0K)                                 |  |  |
| dsPIC30F2012                         | 0x000000-0x001FFE (4K)                         | None (0K)                                 |  |  |
| dsPIC30F3010                         | 0x000000-0x003FFE (8K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F3011                         | 0x000000-0x003FFE (8K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F3012                         | 0x000000-0x003FFE (8K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F3013                         | 0x000000-0x003FFE (8K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F3014                         | 0x000000-0x003FFE (8K)                         | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F4011                         | 0x000000-0x007FFE (16K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F4012                         | 0x000000-0x007FFE (16K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F4013                         | 0x000000-0x007FFE (16K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F5011                         | 0x000000-0x00AFFE (22K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F5013                         | 0x000000-0x00AFFE (22K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F5015                         | 0x000000-0x00AFFE (22K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F5016                         | 0x000000-0x00AFFE (22K)                        | 0x7FFC00-0x7FFFFE (1K)                    |  |  |
| dsPIC30F6010                         | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |
| dsPIC30F6010A                        | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFF (4K)                    |  |  |
| dsPIC30F6011 0x000000-0x015FFE (44K) |                                                | 0x7FF800-0x7FFFFE (2K)                    |  |  |
| dsPIC30F6011A                        | 0x000000-0x015FFE (44K)                        | 0x7FF800-0x7FFFFE (2K)                    |  |  |
| dsPIC30F6012                         | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |
| dsPIC30F6012A                        | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |
| dsPIC30F6013                         | 0x000000-0x015FFE (44K)                        | 0x7FF800-0x7FFFFE (2K)                    |  |  |
| dsPIC30F6013A                        | 0x000000-0x015FFE (44K)                        | 0x7FF800-0x7FFFFE (2K)                    |  |  |
| dsPIC30F6014                         | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |
| dsPIC30F6014A                        | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |
| dsPIC30F6015                         | 0x000000-0x017FFE (48K)                        | 0x7FF000-0x7FFFFE (4K)                    |  |  |

## 5.0 DEVICE PROGRAMMING

## 5.1 Overview of the Programming Process

Once the programming executive has been verified in memory (or loaded if not present), the dsPIC30F can be programmed using the command set shown in Table 5-1. A detailed description for each command is provided in Section 8.0 "Programming Executive Commands".

| Command | Description                                             |  |  |
|---------|---------------------------------------------------------|--|--|
| SCHECK  | Sanity check                                            |  |  |
| READD   | Read data EEPROM, Configuration registers and device ID |  |  |
| READP   | Read code memory                                        |  |  |
| PROGD   | Program one row of data EEPROM and verify               |  |  |
| PROGP   | Program one row of code memory and verify               |  |  |
| PROGC   | Program Configuration bits and verify                   |  |  |
| ERASEB  | Bulk Erase, or erase by segment                         |  |  |
| ERASED  | Erase data EEPROM                                       |  |  |
| ERASEP  | Erase code memory                                       |  |  |
| QBLANK  | Query if the code memory and data<br>EEPROM are blank   |  |  |
| QVER    | Query the software version                              |  |  |

TABLE 5-1: COMMAND SET SUMMARY

A high-level overview of the programming process is illustrated in Figure 5-1. The process begins by entering Enhanced ICSP mode. The chip is then bulk erased, which clears all memory to '1' and allows the device to be programmed. The Chip Erase is verified before programming begins. Next, the code memory, data Flash and Configuration bits are programmed. As these memories are programmed, they are each verified to ensure that programming was successful. If no errors are detected, the programming is complete and Enhanced ICSP mode is exited. If any of the verifications fail, the procedure should be repeated, starting from the Chip Erase. If Advanced Security features are enabled, then individual Segment Erase operations need to be performed, based on user selections (i.e., based on the specific needs of the user application). The specific operations that are used typically depend on the order in which various segments need to be programmed for a given application or system.

Section 5.2 "Entering Enhanced ICSP Mode" through Section 5.8 "Exiting Enhanced ICSP Mode" describe the programming process in detail.

## FIGURE 5-1: PROGRAMMING FLOW



## TABLE 5-6: FOSC CONFIGURATION BITS DESCRIPTION FOR dsPIC30F2011/2012, dsPIC30F3010/3011/3012/3013/3014, dsPIC30F4013, dsPIC30F5015/5016, dsPIC30F6010A/6011A/6012A/6013A/6014A AND dsPIC30F6015 (CONTINUED)

| Bit Field | Register | Description                                                                    |  |
|-----------|----------|--------------------------------------------------------------------------------|--|
| FPR<4:0>  | FOSC     | Alternate Oscillator Mode (when FOS<2:0> = 011b)                               |  |
|           |          | 1xxxx = Reserved (do not use)                                                  |  |
|           |          | 0111x = Reserved (do not use)                                                  |  |
|           |          | 01101 = Reserved (do not use)                                                  |  |
|           |          | 01100 = ECIO – External clock. OSC2 pin is I/O                                 |  |
|           |          | 01011 = EC – External clock. OSC2 pin is system clock output (Fosc/4)          |  |
|           |          | 01010 = Reserved (do not use)                                                  |  |
|           |          | 01001 = ERC – External RC oscillator. OSC2 pin is system clock output (Fosc/4) |  |
|           |          | 01000 = ERCIO – External RC oscillator. OSC2 pin is I/O                        |  |
|           |          | 00111 = Reserved (do not use)                                                  |  |
|           |          | 00110 = Reserved (do not use)                                                  |  |
|           |          | 00101 = Reserved (do not use)                                                  |  |
|           |          | 00100 = XT – XT crystal oscillator (4 MHz-10 MHz crystal)                      |  |
|           |          | 00010 = HS – HS crystal oscillator (10 MHz-25 MHz crystal)                     |  |
|           |          | 00001 = Reserved (do not use)                                                  |  |
|           |          | 00000 = XTL – XTL crystal oscillator (200 kHz-4 MHz crystal)                   |  |

| Bit Field | Register | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EBS       | FBS      | Boot Segment Data EEPROM Code Protection (only present in dsPIC30F5011/<br>5013/6010A/6011A/6012A/6013A/6014A/6015)<br>1 = No Data EEPROM is reserved for Boot Segment<br>0 = 128 bytes of Data EEPROM are reserved for Boot Segment in dsPIC30F5011/<br>5013, and 256 bytes in dsPIC30F6010A/6011A/6012A/6013A/6014A/6015                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| BSS<2:0>  | FBS      | Boot Segment Program Memory Code Protection (only present in<br>dsPIC30F5011/5013/6010A/6011A/6012A/6013A/6014A/6015)         111 = No Boot Segment         110 = Standard security; Small-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0003FF]         101 = Standard security; Medium-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF]         100 = Standard security; Large-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF]         100 = Standard security; Large-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x001FF]         011 = No Boot Segment         010 = High security; Small-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0003FF]         011 = High security; Medium-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0003FF]         001 = High security; Medium-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF]         001 = High security; Large-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF]         000 = High security; Large-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF]         000 = High security; Large-sized Boot Program Flash<br>[Boot Segment starts after BS and ends at 0x0007FF] |
| BWRP      | FBS      | Boot Segment Program Memory Write Protection (only present in<br>dsPIC30F5011/5013/6010A/6011A/6012A/6013A/6014A/6015)<br>1 = Boot Segment program memory is not write-protected<br>0 = Boot Segment program memory is write-protected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| RSS<1:0>  | FSS      | Secure Segment Data RAM Code Protection (only present in dsPIC30F5011/         5013/6010A/6011A/6012A/6013A/6014A/6015)         11 = No Data RAM is reserved for Secure Segment         10 = Small-sized Secure RAM         [(256 - N) bytes of RAM are reserved for Secure Segment]         01 = Medium-sized Secure RAM         [(768 - N) bytes of RAM are reserved for Secure Segment in dsPIC30F5011/         5013, and (2048 - N) bytes in dsPIC30F6010A/6011A/6012A/6013A/6014A/         6015]         00 = Large-sized Secure RAM         [(1024 - N) bytes of RAM are reserved for Secure Segment in dsPIC30F5011/         5013, and (4096 - N) bytes in dsPIC30F6010A/6011A/6012A/6013A/6014A/         6015]         where N = Number of bytes of RAM reserved for Boot Sector.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ESS<1:0>  | FSS      | <ul> <li>Secure Segment Data EEPROM Code Protection (only present in dsPIC30F5011/5013/6010A/6011A/6012A/6013A/6014A/6015)</li> <li>11 = No Data EEPROM is reserved for Secure Segment</li> <li>10 = Small-sized Secure Data EEPROM <ul> <li>[(128 – N) bytes of Data EEPROM are reserved for Secure Segment in dsPIC30F5011/5013, and (256 – N) bytes in dsPIC30F6010A/6011A/6012A/6013A/6014A/6015]</li> </ul> </li> <li>01 = Medium-sized Secure Data EEPROM <ul> <li>[(256 – N) bytes of Data EEPROM are reserved for Secure Segment in dsPIC30F5011/5013, and (512 – N) bytes in dsPIC30F6010A/6011A/6012A/6013A/6014A/6015]</li> </ul> </li> <li>01 = Large-sized Secure Data EEPROM <ul> <li>[(512 – N) bytes of Data EEPROM</li> <li>[(512 – N) bytes of Data EEPROM are reserved for Secure Segment in dsPIC30F5011/5013, (1024 – N) bytes in dsPIC30F6011A/6013A, and (2048 – N) bytes in dsPIC30F6010A/6012A/6014A/6015]</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## TABLE 5-7: CONFIGURATION BITS DESCRIPTION (CONTINUED)

## 5.7.2 PROGRAMMING METHODOLOGY

System operation Configuration bits are inherently different than all other memory cells. Unlike code memory, data EEPROM and code-protect Configuration bits, the system operation bits cannot be erased. If the chip is erased with the ERASEB command, the system-operation bits retain their previous value. Consequently, you should make no assumption about the value of the system operation bits. They should always be programmed to their desired setting.

Configuration bits are programmed as a single word at a time using the PROGC command. The PROGC command specifies the configuration data and Configuration register address. When Configuration bits are programmed, any unimplemented bits must be programmed with a '0', and any reserved bits must be programmed with a '1'.

Four PROGC commands are required to program all the Configuration bits. Figure 5-5 illustrates the flowchart of Configuration bit programming.

Note: If the General Code Segment Code Protect (GCP) bit is programmed to '0', code memory is code-protected and cannot be read. Code memory must be verified before enabling read protection. See Section 5.7.4 "Code-Protect Configuration Bits" for more information about code-protect Configuration bits.

## 5.7.3 PROGRAMMING VERIFICATION

Once the Configuration bits are programmed, the contents of memory should be verified to ensure that the programming was successful. Verification requires the Configuration bits to be read back and compared against the copy held in the programmer's buffer. The READD command reads back the programmed Configuration bits and verifies whether the programming was successful.

Any unimplemented Configuration bits are read-only and read as '0'.

## 5.7.4 CODE-PROTECT CONFIGURATION BITS

The FBS, FSS and FGS Configuration registers are special Configuration registers that control the size and level of code protection for the Boot Segment, Secure Segment and General Segment, respectively. For each segment, two main forms of code protection are provided. One form prevents code memory from being written (write protection), while the other prevents code memory from being read (read protection).

The BWRP, SWRP and GWRP bits control write protection; and BSS<2:0>, SSS<2:0> and GSS<1:0> bits control read protection. The Chip Erase ERASEB command sets all the code protection bits to '1', which allows the device to be programmed.

When write protection is enabled, any programming operation to code memory will fail. When read protection is enabled, any read from code memory will cause a '0x0' to be read, regardless of the actual contents of code memory. Since the programming executive always verifies what it programs, attempting to program code memory with read protection enabled will also result in failure.

It is imperative that all code protection bits are '1' while the device is being programmed and verified. Only after the device is programmed and verified should any of the above bits be programmed to '0' (see Section 5.7 "Configuration Bits Programming").

In addition to code memory protection, parts of data EEPROM and/or data RAM can be configured to be accessible only by code resident in the Boot Segment and/or Secure Segment. The sizes of these "reserved" sections are user-configurable, using the EBS, RBS<1:0>, ESS<1:0> and RSS<1:0> bits.

- Note 1: All bits in the FBS, FSS and FGS Configuration registers can only be programmed to a value of '0'. ERASEB is the only way to reprogram code-protect bits from ON ('0') to OFF ('1').
  - 2: If any of the code-protect bits in FBS, FSS, or FGS are clear, the entire device must be erased before it can be reprogrammed.

| Opcode | Mnemonic              | Length<br>(16-bit<br>words) | Time Out | Description                                                                                               |  |
|--------|-----------------------|-----------------------------|----------|-----------------------------------------------------------------------------------------------------------|--|
| 0x0    | SCHECK                | 1                           | 1 ms     | Sanity check.                                                                                             |  |
| 0x1    | READD                 | 4                           | 1 ms/row | Read N 16-bit words of data EEPROM, Configuration registers or device ID starting from specified address. |  |
| 0x2    | READP                 | 4                           | 1 ms/row | Read N 24-bit instruction words of code memory starting from specified address.                           |  |
| 0x3    | Reserved              | N/A                         | N/A      | This command is reserved. It will return a NACK.                                                          |  |
| 0x4    | PROGD <sup>(2)</sup>  | 19                          | 5 ms     | Program one row of data EEPROM at the specified address, the verify.                                      |  |
| 0x5    | PROGP(1)              | 51                          | 5 ms     | Program one row of code memory at the specified address, then verify.                                     |  |
| 0x6    | PROGC                 | 4                           | 5 ms     | Write byte or 16-bit word to specified Configuration register.                                            |  |
| 0x7    | ERASEB                | 2                           | 5 ms     | Bulk Erase (entire code memory or data EEPROM), or erase by segment.                                      |  |
| 0x8    | ERASED <sup>(2)</sup> | 3                           | 5 ms/row | Erase rows of data EEPROM from specified address.                                                         |  |
| 0x9    | ERASEP(1)             | 3                           | 5 ms/row | Erase rows of code memory from specified address.                                                         |  |
| 0xA    | QBLANK                | 3                           | 300 ms   | Query if the code memory and data EEPROM are blank.                                                       |  |
| 0xB    | QVER                  | 1                           | 1 ms     | Query the programming executive software version.                                                         |  |

## TABLE 8-1: PROGRAMMING EXECUTIVE COMMAND SET

Note 1: One row of code memory consists of (32) 24-bit words. Refer to Table 5-2 for device-specific information.
2: One row of data EEPROM consists of (16) 16-bit words. Refer to Table 5-3 for device-specific information.

## 8.5 Command Descriptions

All commands that are supported by the programming executive are described in Section 8.5.1 "SCHECK Command" through Section 8.5.11 "QVER Command".

### 8.5.1 SCHECK COMMAND

| 15 | 12     | 11 0   | ) |
|----|--------|--------|---|
|    | Opcode | Length |   |

| Field  | Description |
|--------|-------------|
| Opcode | 0x0         |
| Length | 0x1         |

The SCHECK command instructs the programming executive to do nothing, but generate a response. This command is used as a "sanity check" to verify that the programming executive is operational.

### Expected Response (2 words):

0x1000 0x0002

Note: This instruction is not required for programming, but is provided for development purposes only.

## 8.5.2 READD COMMAND

| 15    | 12        | 11 | 8 | 7        | 0 |
|-------|-----------|----|---|----------|---|
| Орс   | ode       |    |   | Length   |   |
| Reser | ved0      |    |   | Ν        |   |
|       | Reserved1 |    |   | Addr_MSB |   |
|       | Addr_LS   |    |   |          |   |

| Field     | Description                                  |
|-----------|----------------------------------------------|
| Opcode    | 0x1                                          |
| Length    | 0x4                                          |
| Reserved0 | 0x0                                          |
| N         | Number of 16-bit words to read (max of 2048) |
| Reserved1 | 0x0                                          |
| Addr_MSB  | MSB of 24-bit source address                 |
| Addr_LS   | LS 16 bits of 24-bit source address          |

The READD command instructs the programming executive to read N 16-bit words of memory starting from the 24-bit address specified by Addr\_MSB and Addr\_LS. This command can only be used to read 16-bit data. It can be used to read data EEPROM, Configuration registers and the device ID.

### Expected Response (2+N words):

0x1100 N + 2 Data word 1

Data word N

Note: Reading unimplemented memory will cause the programming executive to reset.

# dsPIC30F Flash Programming Specification

#### 8.5.11 QVER COMMAND

| 15 | 12 | 11 |
|----|----|----|
|    |    |    |

| 15 12  | 11 0   |
|--------|--------|
| Opcode | Length |
|        |        |

| Field  | Description |
|--------|-------------|
| Opcode | 0xB         |
| Length | 0x1         |

The QVER command queries the version of the programming executive software stored in test memory. The "version.revision" information is returned in the response's QE Code using a single byte with the following format: main version in upper nibble and revision in the lower nibble (i.e., 0x23 is version 2.3 of programming executive software).

### Expected Response (2 words):

0x1BMN (where "MN" stands for version M.N) 0x0002

#### 9.0 **PROGRAMMING EXECUTIVE** RESPONSES

#### 9.1 Overview

The programming executive sends a response to the programmer for each command that it receives. The response indicates if the command was processed correctly, and includes any required response or error data.

The programming executive response set is shown in Table 9-1. This table contains the opcode, mnemonic and description for each response. The response format is described in Section 9.2 "Response Format".

#### **TABLE 9-1: PROGRAMMING EXECUTIVE RESPONSE SET**

| Opcode | Mnemonic | Description                       |
|--------|----------|-----------------------------------|
| 0x1    | PASS     | Command successfully processed.   |
| 0x2    | FAIL     | Command unsuccessfully processed. |
| 0x3    | NACK     | Command not known.                |

#### 9.2 **Response Format**

As shown in Example 9-1, all programming executive responses have a general format consisting of a two word header and any required data for the command. Table 9-2 lists the fields and their descriptions.

## EXAMPLE 9-1: FORMAT

| 15 12  | 11 8       | 7         | 0 |
|--------|------------|-----------|---|
| Opcode | Last_Cmd   | QE_Code   |   |
|        | Lenç       | gth       |   |
|        | D_1 (if ap | plicable) |   |
|        |            |           |   |
|        | D_N (if ap | plicable) |   |

#### **TABLE 9-2**: FIELDS AND DESCRIPTIONS

| Field    | Description                                                |
|----------|------------------------------------------------------------|
| Opcode   | Response opcode.                                           |
| Last_Cmd | Programmer command that generated the response.            |
| QE_Code  | Query code or Error code.                                  |
| Length   | Response length in 16-bit words (includes 2 header words.) |
| D_1      | First 16-bit data word (if applicable).                    |
| D_N      | Last 16-bit data word (if applicable).                     |

#### 9.2.1 Opcode FIELD

The Opcode is a 4-bit field in the first word of the response. The Opcode indicates how the command was processed (see Table 9-1). If the command is processed successfully, the response opcode is PASS. If there is an error in processing the command, the response opcode is FAIL, and the QE Code indicates the reason for the failure. If the command sent to the programming executive is not identified, the programming executive returns a NACK response.

#### 9.2.2 Last Cmd FIELD

The Last Cmd is a 4-bit field in the first word of the response and indicates the command that the programming executive processed. Since the programming executive can only process one command at a time, this field is technically not required. However, it can be used to verify whether the programming executive correctly received the command that the programmer transmitted.

## 11.0 ICSP™ MODE

## 11.1 ICSP Mode

ICSP mode is a special programming protocol that allows you to read and write to the dsPIC30F programming executive. The ICSP mode is the second (and slower) method used to program the device. This mode also has the ability to read the contents of executive memory to determine whether the programming executive is present. This capability is accomplished by applying control codes and instructions serially to the device using pins PGC and PGD.

In ICSP mode, the system clock is taken from the PGC pin, regardless of the device's oscillator Configuration bits. All instructions are first shifted serially into an internal buffer, then loaded into the Instruction register and executed. No program fetching occurs from internal memory. Instructions are fed in 24 bits at a time. PGD is used to shift data in and PGC is used as both the serial shift clock and the CPU execution clock.

Data is transmitted on the rising edge and latched on the falling edge of PGC. For all data transmissions, the Least Significant bit (LSb) is transmitted first.

Note 1: During ICSP operation, the operating frequency of PGC must not exceed 5 MHz.
2: Because ICSP is slower, it is recommended that only Enhanced ICSP (E-ICSP) mode be used for device programming, as described in Section 5.1 "Overview of the Programming Process".

## 11.2 ICSP Operation

Upon entry into ICSP mode, the CPU is idle. Execution of the CPU is governed by an internal state machine. A 4-bit control code is clocked in using PGC and PGD, and this control code is used to command the CPU (see Table 11-1).

The SIX control code is used to send instructions to the CPU for execution, while the REGOUT control code is used to read data out of the device via the VISI register. The operation details of ICSP mode are provided in Section 11.2.1 "SIX Serial Instruction Execution" and Section 11.2.2 "REGOUT Serial Instruction Execution".

# TABLE 11-1:CPU CONTROL CODES IN<br/>ICSP™ MODE

| 4-bit<br>Control<br>Code | Mnemonic | Description                              |
|--------------------------|----------|------------------------------------------|
| d0000b                   | SIX      | Shift in 24-bit instruction and execute. |
| 0001b                    | REGOUT   | Shift out the VISI register.             |
| 0010b-1111b              | N/A      | Reserved.                                |

### 11.2.1 SIX SERIAL INSTRUCTION EXECUTION

The SIX control code allows execution of dsPIC30F assembly instructions. When the SIX code is received, the CPU is suspended for 24 clock cycles as the instruction is then clocked into the internal buffer. Once the instruction is shifted in, the state machine allows it to be executed over the next four clock cycles. While the received instruction is executed, the state machine simultaneously shifts in the next 4-bit command (see Figure 11-2).

- Note 1: Coming out of the ICSP entry sequence, the first 4-bit control code is always forced to SIX and a forced NOP instruction is executed by the CPU. Five additional PGC clocks are needed on startup, thereby resulting in a 9-bit SIX command instead of the normal 4-bit SIX command. After the forced SIX is clocked in, ICSP operation resumes as normal (the next 24 clock cycles load the first instruction word to the CPU). See Figure 11-1 for details.
  - 2: TBLRDH, TBLRDL, TBLWTH and TBLWTL instructions must be followed by a NOP instruction.

## 11.4 Flash Memory Programming in ICSP Mode

Programming in ICSP mode is described in Section 11.4.1 "Programming Operations" through Section 11.4.3 "Starting and Stopping a Programming Cycle". Step-by-step procedures are described in Section 11.5 "Erasing Program Memory in Normal-Voltage Systems" through Section 11.13 "Reading the Application ID Word". All programming operations must use serial execution, as described in Section 11.2 "ICSP Operation".

## 11.4.1 PROGRAMMING OPERATIONS

Flash memory write and erase operations are controlled by the NVMCON register. Programming is performed by setting NVMCON to select the type of erase operation (Table 11-2) or write operation (Table 11-3), writing a key sequence to enable the programming and initiating the programming by setting the WR control bit, NVMCON<15>.

In ICSP mode, all programming operations are externally timed. An external 2 ms delay must be used between setting the WR control bit and clearing the WR control bit to complete the programming operation.

### TABLE 11-2: NVMCON ERASE OPERATIONS

| NVMCON<br>Value | Erase Operation                                                                                    |
|-----------------|----------------------------------------------------------------------------------------------------|
| 0x407F          | Erase all code memory, data memory (does not erase UNIT ID).                                       |
| 0x4075          | Erase 1 row (16 words) of data<br>EEPROM.                                                          |
| 0x4074          | Erase 1 word of data EEPROM.                                                                       |
| 0x4072          | Erase all executive memory.                                                                        |
| 0x4071          | Erase 1 row (32 instruction words) from 1 panel of code memory.                                    |
| 0x406E          | Erase Boot Secure and General<br>Segments, then erase FBS, FSS and<br>FGS configuration registers. |
| 0x4066          | Erase all Data EEPROM allocated to<br>Boot Segment.                                                |
| 0x405E          | Erase Secure and General Segments,<br>then erase FSS and FGS configuration<br>registers.           |
| 0x4056          | Erase all Data EEPROM allocated to Secure Segment.                                                 |
| 0x404E          | Erase General Segment, then erase FGS configuration register.                                      |
| 0x4046          | Erase all Data EEPROM allocated to General Segment.                                                |

# TABLE 11-3: NVMCON WRITE OPERATIONS

| NVMCON<br>Value | Write Operation                                                    |
|-----------------|--------------------------------------------------------------------|
| 0x4008          | Write 1 word to configuration                                      |
|                 | memory.                                                            |
| 0x4005          | Write 1 row (16 words) to data memory.                             |
| 0x4004          | Write 1 word to data memory.                                       |
| 0x4001          | Write 1 row (32 instruction words) into 1 panel of program memory. |

### 11.4.2 UNLOCKING NVMCON FOR PROGRAMMING

Writes to the WR bit (NVMCON<15>) are locked to prevent accidental programming from taking place. Writing a key sequence to the NVMKEY register unlocks the WR bit and allows it to be written to. The unlock sequence is performed as follows:

| MOV<br>MOV | #0x55, W8<br>W8, NVMKEY                                                                   |
|------------|-------------------------------------------------------------------------------------------|
| MOV        | #0xAA, W9                                                                                 |
| MOV        | W9, NVMKEY                                                                                |
| Note:      | Any working register, or working register pair, can be used to write the unlock sequence. |

## 11.4.3 STARTING AND STOPPING A PROGRAMMING CYCLE

Once the unlock key sequence has been written to the NVMKEY register, the WR bit (NVMCON<15>) is used to start and stop an erase or write cycle. Setting the WR bit initiates the programming cycle. Clearing the WR bit terminates the programming cycle.

All erase and write cycles must be externally timed. An external delay must be used between setting and clearing the WR bit. Starting and stopping a programming cycle is performed as follows:

| BSET                                            | NVMCON, | #WR |
|-------------------------------------------------|---------|-----|
| <wait< td=""><td>2 ms&gt;</td><td></td></wait<> | 2 ms>   |     |
| BCLR                                            | NVMCON, | #WR |

## 11.5 Erasing Program Memory in Normal-Voltage Systems

The procedure for erasing program memory (all code memory, data memory, executive memory and codeprotect bits) consists of setting NVMCON to 0x407F, unlocking NVMCON for erasing and then executing the programming cycle. This method of bulk erasing program memory only works for systems where VDD is between 4.5 volts and 5.5 volts. The method for erasing program memory for systems with a lower VDD (3.0 volts-4.5 volts) is described in Section 6.1 "Erasing Memory". Table 11-4 shows the ICSP programming process for bulk-erasing program memory. This process includes the ICSP command code, which must be transmitted (for each instruction) to the Least Significant bit first using the PGC and PGD pins (see Figure 11-2).

If an individual Segment Erase operation is required, the NVMCON value must be replaced by the value for the corresponding Segment Erase operation.

| Note: | Program memory must be erased before |
|-------|--------------------------------------|
|       | writing any data to program memory.  |

# TABLE 11-4:SERIAL INSTRUCTION EXECUTION FOR BULK ERASING PROGRAM MEMORY<br/>(ONLY IN NORMAL-VOLTAGE SYSTEMS)

| 08A<br>80A                                                    | GOTO 0x100<br>GOTO 0x100<br>NOP<br>the FBS Configuration register. <sup>(1)</sup><br>MOV #0x4008, W10<br>MOV W10, NVMCON |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 00<br>000<br>DN to program<br>08A<br>00A<br><b>TBLPAG and</b> | GOTO 0×100<br>NOP<br>the FBS Configuration register. <sup>(1)</sup><br>MOV #0×4008, W10                                  |
| DN to program                                                 | NOP<br>the FBS Configuration register. <sup>(1)</sup><br>MOV #0x4008, W10                                                |
| DN to program                                                 | the FBS Configuration register. <sup>(1)</sup>                                                                           |
| BA<br>BOA<br>CHANCE TBLPAG and                                | MOV #0x4008, W10                                                                                                         |
| BOA<br>TBLPAG and                                             |                                                                                                                          |
| e TBLPAG and                                                  | MOV W10, NVMCON                                                                                                          |
|                                                               |                                                                                                                          |
| '80                                                           | write pointer (W7) for TBLWT instruction for Configuration register. <sup>(1)</sup>                                      |
|                                                               | MOV #0xF8, W0                                                                                                            |
| .90                                                           | MOV W0, TBLPAG                                                                                                           |
| 67                                                            | MOV #0x6, W7                                                                                                             |
| onfiguration Re                                               | egister data to W6. <sup>(1)</sup>                                                                                       |
| 300                                                           | CLR W6                                                                                                                   |
| 000                                                           | NOP                                                                                                                      |
| onfiguration Re                                               | egister write latch. Advance W7 to point to next Configuration register. <sup>(1)</sup>                                  |
| 386                                                           | TBLWTL W6, [W7++]                                                                                                        |
| NVMCON for p                                                  | programming the Configuration register. <sup>(1)</sup>                                                                   |
| 58                                                            | MOV #0x55, W8                                                                                                            |
| A9                                                            | MOV #0xAA, W9                                                                                                            |
| 338                                                           | MOV W8, NVMKEY                                                                                                           |
| 339                                                           | MOV W9, NVMKEY                                                                                                           |
| orogramming c                                                 | ycle. <sup>(1)</sup>                                                                                                     |
| 61                                                            | BSET NVMCON, #WR                                                                                                         |
| 000                                                           | NOP                                                                                                                      |
| 000                                                           | NOP                                                                                                                      |
|                                                               | Externally time 2 ms                                                                                                     |
| 000                                                           | NOP                                                                                                                      |
| 000                                                           | NOP                                                                                                                      |
| 61                                                            | BCLR NVMCON, #WR                                                                                                         |
| 000                                                           | NOP                                                                                                                      |
| 000                                                           | NOP                                                                                                                      |
| os 5-7 one time                                               | e to program 0x0000 to RESERVED2 Configuration register. <sup>(1)</sup>                                                  |
| VICON to erase                                                | e all Program Memory.                                                                                                    |
| 'FA                                                           | MOV #0x407F, W10                                                                                                         |
| 30A                                                           | MOV W10, NVMCON                                                                                                          |
| O<br>OS<br>M                                                  | 5-7 one time<br>CON to erase                                                                                             |

**Note 1:** Steps 2-8 are only required for the dsPIC30F5011/5013 devices. These steps may be skipped for all other devices in the dsPIC30F family.

# TABLE 11-4:SERIAL INSTRUCTION EXECUTION FOR BULK ERASING PROGRAM MEMORY<br/>(ONLY IN NORMAL-VOLTAGE SYSTEMS) (CONTINUED)

| Command<br>(Binary) | Data<br>(Hexadecimal) | Description                                                                                  |  |
|---------------------|-----------------------|----------------------------------------------------------------------------------------------|--|
| 0000                | 200558                | MOV #0x55, W8                                                                                |  |
| 0000                | 883B38                | MOV W8, NVMKEY                                                                               |  |
| 0000                | 200AA9                | MOV #0xAA, W9                                                                                |  |
| 0000                | 883B39                | MOV W9, NVMKEY                                                                               |  |
| Step 11: Initia     | te the erase cycle.   |                                                                                              |  |
| 0000                | A8E761                | BSET NVMCON, #WR                                                                             |  |
| 0000                | 000000                | NOP                                                                                          |  |
| 0000                | 000000                | NOP                                                                                          |  |
| -                   | _                     | Externally time 'P13a' ms (see Section 13.0 "AC/DC Characteristics and Timing Requirements") |  |
| 0000                | 000000                | NOP                                                                                          |  |
| 0000                | 000000                | NOP                                                                                          |  |
| 0000                | A9E761                | BCLR NVMCON, #WR                                                                             |  |
| 0000                | 000000                | NOP                                                                                          |  |
| 0000                | 000000                | NOP                                                                                          |  |

**Note 1:** Steps 2-8 are only required for the dsPIC30F5011/5013 devices. These steps may be skipped for all other devices in the dsPIC30F family.

# TABLE 11-5:SERIAL INSTRUCTION EXECUTION FOR ERASING PROGRAM MEMORY<br/>(EITHER IN LOW-VOLTAGE OR NORMAL-VOLTAGE SYSTEMS) (CONTINUED)

| Command<br>(Binary) | Data<br>(Hexadecimal)   | Description                                                                                  |
|---------------------|-------------------------|----------------------------------------------------------------------------------------------|
|                     |                         | stored in NVMADRU:NVMADR. When W6 rolls over to 0x0, NVMADRU must be                         |
| incre               | emented.                |                                                                                              |
| 0000                | 430307                  | ADD W6, W7, W6                                                                               |
| 0000                | AF0042                  | BTSC SR, #C                                                                                  |
| 0000                | EC2764                  | INC NVMADRU                                                                                  |
| 0000                | 883B16                  | MOV W6, NVMADR                                                                               |
| Step 7: Res         | et device internal PC.  |                                                                                              |
| 0000                | 040100                  | GOTO 0x100                                                                                   |
| 0000                | 000000                  | NOP                                                                                          |
| Step 8: Rep         | eat Steps 3-7 until all | rows of code memory are erased.                                                              |
| Step 9: Initia      | alize NVMADR and N      | VMADRU to erase executive memory and initialize W7 for row address updates.                  |
| 0000                | EB0300                  | CLR W6                                                                                       |
| 0000                | 883B16                  | MOV W6, NVMADR                                                                               |
| 0000                | 200807                  | MOV #0x80, W7                                                                                |
| 0000                | 883B27                  | MOV W7, NVMADRU                                                                              |
| 0000                | 200407                  | MOV #0x40, W7                                                                                |
| Step 10: Set        | t NVMCON to erase ?     | 1 row of executive memory.                                                                   |
| 0000                | 24071A                  | MOV #0x4071, W10                                                                             |
| 0000                | 883B0A                  | MOV W10, NVMCON                                                                              |
| Step 11: Unl        | lock the NVMCON to      | erase 1 row of executive memory.                                                             |
| 0000                | 200558                  | MOV #0x55, W8                                                                                |
| 0000                | 883B38                  | MOV W8, NVMKEY                                                                               |
| 0000                | 200AA9                  | MOV #0xAA, W9                                                                                |
| 0000                | 883B39                  | MOV W9, NVMKEY                                                                               |
| Step 12: Init       | iate the erase cycle.   |                                                                                              |
| 0000                | A8E761                  | BSET NVMCON, #WR                                                                             |
| 0000                | 000000                  | NOP                                                                                          |
| 0000                | 000000                  | NOP                                                                                          |
| _                   | _                       | Externally time 'P13a' ms (see Section 13.0 "AC/DC Characteristics and Timing Requirements") |
| 0000                | 000000                  | NOP                                                                                          |
| 0000                | 000000                  | NOP                                                                                          |
| 0000                | A9E761                  | BCLR NVMCON, #WR                                                                             |
| 0000                | 000000                  | NOP                                                                                          |
| 0000                | 000000                  | NOP                                                                                          |
| <b>Step 13:</b> Up  | date the row address    | stored in NVMADR.                                                                            |
| 0000                | 430307                  | ADD W6, W7, W6                                                                               |
| 0000                | 883B16                  | MOV W6, NVMADR                                                                               |
| Step 14: Re         | set device internal PC  | D.                                                                                           |
| 0000                | 040100                  | GOTO 0x100                                                                                   |
| 0000                | 000000                  | NOP                                                                                          |
| <b>Step 15</b> : Re | peat Steps 10-14 unti   | I all 24 rows of executive memory are erased.                                                |
|                     |                         | NVMADRU to erase data memory and initialize W7 for row address updates.                      |
| 0000                | 2XXXX6                  | MOV # <lower 16-bits="" address="" data="" eeprom="" of="" starting="">, W6</lower>          |
| 0000                | 883B16                  | MOV W6, NVMADR                                                                               |
| 0000                | 2007F6                  | MOV #0x7F, W6                                                                                |
| 0000                | 883B16                  | MOV W6, NVMADRU                                                                              |
|                     | 200207                  | MOV #0x20, W7                                                                                |
|                     | 200201                  |                                                                                              |
| 0000                | 1                       | 1 row of data memory.                                                                        |
| 0000                | 1                       | I row of data memory.           MOV         #0x4075, W10                                     |

## 11.7 Writing Configuration Memory

The FOSC, FWDT, FBORPOR and FICD registers are not erasable. It is recommended that all Configuration registers be set to a default value after erasing program memory. The FWDT, FBORPOR and FICD registers can be set to a default all '1's value by programming 0xFFFF to each register. Since these registers contain unimplemented bits that read as '0' the default values shown in Table 11-6 will be read instead of 0xFFFF. The recommended default FOSC value is 0xC100, which selects the FRC clock oscillator setting.

The FGS, FBS and FSS Configuration registers are special since they enable code protection for the device. For security purposes, once any bit in these registers is programmed to '0' (to enable some code protection feature), it can only be set back to '1' by performing a Bulk Erase or Segment Erase as described in **Section 11.5 "Erasing Program Memory in Normal-Voltage Systems**". Programming these bits from a '0' to '1' is not possible, but they may be programmed from a '1' to a '0' to enable code protection.

Table 11-7 shows the ICSP programming details for clearing the Configuration registers. In Step 1, the Reset vector is exited. In Step 2, the write pointer (W7) is loaded with 0x0000, which is the original destination address (in TBLPAG 0xF8 of program memory). In Step 3, the NVMCON is set to program one Configura-

tion register. In Step 4, the TBLPAG register is initialized, to 0xF8, for writing to the Configuration registers. In Step 5, the value to write to the each Configuration register (0xFFFF) is loaded to W6. In Step 6, the Configuration register data is written to the write latch using the TBLWTL instruction. In Steps 7 and 8, the NVMCON is unlocked for programming and the programming cycle is initiated, as described in Section 11.4 "Flash Memory Programming in ICSP Mode". In Step 9, the internal PC is set to 0x100 as a safety measure to prevent the PC from incrementing into unimplemented memory. Lastly, Steps 3-9 are repeated six times until all seven Configuration registers are cleared.

| TABLE 11-6: | DEFAULT CONFIGURATION |  |  |
|-------------|-----------------------|--|--|
|             | REGISTER VALUES       |  |  |

| Address  | Register | Default Value |  |
|----------|----------|---------------|--|
| 0xF80000 | FOSC     | 0xC100        |  |
| 0xF80002 | FWDT     | 0x803F        |  |
| 0xF80004 | FBORPOR  | 0x87B3        |  |
| 0xF80006 | FBS      | 0x310F        |  |
| 0xF80008 | FSS      | 0x330F        |  |
| 0xF8000A | FGS      | 0x0007        |  |
| 0xF8000C | FICD     | 0xC003        |  |

# TABLE 11-7:SERIAL INSTRUCTION EXECUTION FOR WRITING CONFIGURATION<br/>REGISTERS

| Command<br>(Binary)  | Data<br>(Hexadecimal)                               | Description                                     |  |
|----------------------|-----------------------------------------------------|-------------------------------------------------|--|
| Step 1: Exit th      | e Reset vector.                                     |                                                 |  |
| 0000<br>0000<br>0000 | 040100<br>040100<br>000000                          | GOTO 0x100<br>GOTO 0x100<br>NOP                 |  |
| Step 2: Initiali     | ze the write pointer (                              | W7) for the TBLWT instruction.                  |  |
| 0000                 | 200007                                              | MOV #0x0000, W7                                 |  |
| Step 3: Set th       | e NVMCON to progr                                   | am 1 Configuration register.                    |  |
| 0000<br>0000         | 24008A<br>883B0A                                    | MOV #0x4008, W10<br>MOV W10, NVMCON             |  |
| Step 4: Initiali     | ze the TBLPAG regis                                 | ster.                                           |  |
| 0000                 | 200F80<br>880190                                    | MOV #0xF8, W0<br>MOV W0, TBLPAG                 |  |
| Step 5: Load         | Step 5: Load the Configuration register data to W6. |                                                 |  |
| 0000                 | 2xxxx0<br>000000                                    | MOV # <config_value>, W0<br/>NOP</config_value> |  |

## 11.9 Writing Data EEPROM

The procedure for writing data EEPROM is very similar to the procedure for writing code memory, except that fewer words are programmed in each operation. When writing data EEPROM, one row of data EEPROM is programmed at a time. Each row consists of sixteen 16-bit data words. Since fewer words are programmed during each operation, only working registers W0:W3 are used as temporary holding registers for the data to be programmed.

Table 11-9 shows the ICSP programming details for writing data EEPROM. Note that a different NVMCON value is required to write to data EEPROM, and that the TBLPAG register is hard-coded to 0x7F (the upper byte address of all locations of data EEPROM).

|             | OFRIAL INOTRUCTION EVECUTION FOR WRITING RATA FERROM |
|-------------|------------------------------------------------------|
| TABLE 11-9: | SERIAL INSTRUCTION EXECUTION FOR WRITING DATA EEPROM |

| Command<br>(Binary) | Data<br>(Hexadecimal)          | Description                                                 |  |  |  |
|---------------------|--------------------------------|-------------------------------------------------------------|--|--|--|
| Step 1: Exit th     | Step 1: Exit the Reset vector. |                                                             |  |  |  |
| 0000                | 040100                         | GOTO 0x100                                                  |  |  |  |
| 0000                | 040100                         | GOTO 0x100                                                  |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| Step 2: Set the     | e NVMCON to write              | 16 data words.                                              |  |  |  |
| 0000                | 24005A                         | MOV #0x4005, W10                                            |  |  |  |
| 0000                | 883B0A                         | MOV W10, NVMCON                                             |  |  |  |
| Step 3: Initializ   | ze the write pointer           | W7) for TBLWT instruction.                                  |  |  |  |
| 0000                | 2007F0                         | MOV #0x7F, W0                                               |  |  |  |
| 0000                | 880190                         | MOV W0, TBLPAG                                              |  |  |  |
| 0000                | 2xxxx7                         | MOV # <destinationaddress15:0>, W7</destinationaddress15:0> |  |  |  |
| Step 4: Load \      | W0:W3 with the nex             | 4 data words to program.                                    |  |  |  |
| 0000                | 2xxxx0                         | MOV # <wordo>, WO</wordo>                                   |  |  |  |
| 0000                | 2xxxx1                         | MOV # <word1>, W1</word1>                                   |  |  |  |
| 0000                | 2xxxx2                         | MOV # <word2>, W2</word2>                                   |  |  |  |
| 0000                | 2xxxx3                         | MOV # <word3>, W3</word3>                                   |  |  |  |
| Step 5: Set the     | e read pointer (W6)            | and load the (next set of) write latches.                   |  |  |  |
| 0000                | EB0300                         | CLR W6                                                      |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | BB1BB6                         | TBLWTL [W6++], [W7++]                                       |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | BB1BB6                         | TBLWTL [W6++], [W7++]                                       |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | BB1BB6                         | TBLWTL [W6++], [W7++]                                       |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | BB1BB6                         | TBLWTL [W6++], [W7++]                                       |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| 0000                | 000000                         | NOP                                                         |  |  |  |
| Step 6: Repea       | at steps 4-5 four time         | es to load the write latches for 16 data words.             |  |  |  |
|                     |                                |                                                             |  |  |  |

| Comman<br>(Binary) |                        | Description                                                            |  |  |
|--------------------|------------------------|------------------------------------------------------------------------|--|--|
| Step 7: Un         | lock the NVMCON for    | writing.                                                               |  |  |
| 0000               | 200558                 | MOV #0x55, W8                                                          |  |  |
| 0000               | 883B38                 | MOV W8, NVMKEY                                                         |  |  |
| 0000               | 200AA9                 | MOV #0xAA, W9                                                          |  |  |
| 0000               | 883B39                 | MOV W9, NVMKEY                                                         |  |  |
| Step 8: Init       | iate the write cycle.  |                                                                        |  |  |
| 0000               | A8E761                 | BSET NVMCON, #WR                                                       |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| _                  | -                      | Externally time 'P12a' ms (see Section 13.0 "AC/DC Characteristics and |  |  |
|                    |                        | Timing Requirements")                                                  |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| 0000               | A9E761                 | BCLR NVMCON, #WR                                                       |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |
| Step 9: Re         | set device internal PC |                                                                        |  |  |
| 0000               | 040100                 | GOTO 0x100                                                             |  |  |
| 0000               | 000000                 | NOP                                                                    |  |  |

## TABLE 11-9: SERIAL INSTRUCTION EXECUTION FOR WRITING DATA EEPROM (CONTINUED)

## 11.10 Reading Code Memory

Reading from code memory is performed by executing a series of TBLRD instructions and clocking out the data using the REGOUT command. To ensure efficient execution and facilitate verification on the programmer, four instruction words are read from the device at a time.

Table 11-10 shows the ICSP programming details for reading code memory. In Step 1, the Reset vector is exited. In Step 2, the 24-bit starting source address for reading is loaded into the TBLPAG and W6 registers. The upper byte of the starting source address is stored to TBLPAG, while the lower 16 bits of the source address are stored to W6.

To minimize the reading time, the packed instruction word format that was utilized for writing is also used for reading (see Figure 11-5). In Step 3, the write pointer W7 is initialized, and four instruction words are read from code memory and stored to working registers W0:W5. In Step 4, the four instruction words are clocked out of the device from the VISI register using the REGOUT command. In Step 5, the internal PC is reset to 0x100, as a precautionary measure, to prevent the PC from incrementing into unimplemented memory when large devices are being read. Lastly, in Step 6, Steps 3-5 are repeated until the desired amount of code memory is read.

| Command<br>(Binary) | Data<br>(Hexadecimal) |                | Description                                             |
|---------------------|-----------------------|----------------|---------------------------------------------------------|
| Step 1: Exit th     | e Reset vector.       |                |                                                         |
| 0000                | 040100                | GOTO 0x100     |                                                         |
| 0000                | 040100                | GOTO 0x100     |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| Step 2: Initiali    | ze TBLPAG and t       | the read point | er (W6) for TBLRD instruction.                          |
| 0000                | 200xx0                | MOV            | # <sourceaddress23:16>, W0</sourceaddress23:16>         |
| 0000                | 880190                | MOV            | WO, TBLPAG                                              |
| 0000                | 2xxxx6                | MOV            | <pre>#<sourceaddress15:0>, W6</sourceaddress15:0></pre> |
| Step 3: Initiali    | ze the write point    | er (W7) and s  | tore the next four locations of code memory to W0:W5.   |
| 0000                | EB0380                | CLR            | W7                                                      |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BA1B96                | TBLRDL         | [W6], [W7++]                                            |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BADBB6                | TBLRDH.B       | [W6++], [W7++]                                          |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BADBD6                | TBLRDH.B       | [++W6], [W7++]                                          |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BA1BB6                | TBLRDL         | [W6++], [W7++]                                          |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BA1B96                | TBLRDL         | [W6], [W7++]                                            |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BADBB6                | TBLRDH.B       | [W6++], [W7++]                                          |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BADBD6                | TBLRDH.B       | [++W6], [W7++]                                          |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | BA0BB6                | TBLRDL         | [W6++], [W7]                                            |
| 0000                | 000000                | NOP            |                                                         |
| 0000                | 000000                | NOP            |                                                         |

## APPENDIX A: DEVICE-SPECIFIC INFORMATION

## A.1 Checksum Computation

The checksum computation is described in **Section 6.8 "Checksum Computation"**. Table A-1 shows how this 16-bit computation can be made for each dsPIC30F device. Computations for read code protection are shown both enabled and disabled. The checksum values assume that the Configuration registers are also erased. However, when code protection is enabled, the value of the FGS register is assumed to be 0x5.

## A.2 dsPIC30F5011 and dsPIC30F5013

## A.2.1 ICSP PROGRAMMING

The dsPIC30F5011 and dsPIC30F5013 processors require that the FBS and FSS registers be programmed with 0x0000 before the device is chip erased. The steps to perform this action are shown in Table 11-4.

## A.2.2 ENHANCED ICSP PROGRAMMING

The dsPIC30F5011 and dsPIC30F5013 processors require that the FBS and FSS registers be programmed with 0x0000 using the PROGC command before the ERASEB command is used to erase the chip.

| Device       | Read Code<br>Protection | Checksum Computation | Erased<br>Value | Value with<br>0xAAAAAA at 0x0<br>and Last<br>Code Address |
|--------------|-------------------------|----------------------|-----------------|-----------------------------------------------------------|
| dsPIC30F2010 | Disabled                | CFGB+SUM(0:001FFF)   | 0xD406          | 0xD208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F2011 | Disabled                | CFGB+SUM(0:001FFF)   | 0xD406          | 0xD208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F2012 | Disabled                | CFGB+SUM(0:001FFF)   | 0xD406          | 0xD208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F3010 | Disabled                | CFGB+SUM(0:003FFF)   | 0xA406          | 0xA208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F3011 | Disabled                | CFGB+SUM(0:003FFF)   | 0xA406          | 0xA208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F3012 | Disabled                | CFGB+SUM(0:003FFF)   | 0xA406          | 0xA208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F3013 | Disabled                | CFGB+SUM(0:003FFF)   | 0xA406          | 0xA208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F3014 | Disabled                | CFGB+SUM(0:003FFF)   | 0xA406          | 0xA208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F4011 | Disabled                | CFGB+SUM(0:007FFF)   | 0x4406          | 0x4208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F4012 | Disabled                | CFGB+SUM(0:007FFF)   | 0x4406          | 0x4208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F4013 | Disabled                | CFGB+SUM(0:007FFF)   | 0x4406          | 0x4208                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F5011 | Disabled                | CFGB+SUM(0:00AFFF)   | 0xFC06          | 0xFA08                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F5013 | Disabled                | CFGB+SUM(0:00AFFF)   | 0xFC06          | 0xFA08                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |
| dsPIC30F5015 | Disabled                | CFGB+SUM(0:00AFFF)   | 0xFC06          | 0xFA08                                                    |
|              | Enabled                 | CFGB                 | 0x0404          | 0x0404                                                    |

## TABLE A-1: CHECKSUM COMPUTATION

Item Description:

**SUM(a:b)** = Byte sum of locations a to b inclusive (all 3 bytes of code memory)

CFGB = Configuration Block (masked) = Byte sum of ((FOSC&0xC10F) + (FWDT&0x803F) + (FBORPOR&0x87B3) + (FBS&0x310F) + (FSS&0x330F) + (FGS&0x0007) + (FICD&0xC003))

### Note the following details of the code protection feature on Microchip devices:

- · Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip's Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as "unbreakable."

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip's code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights.

## QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV ISO/TS 16949:2002

### Trademarks

The Microchip name and logo, the Microchip logo, dsPIC, KEELOQ, KEELOQ logo, MPLAB, PIC, PICmicro, PICSTART, PIC<sup>32</sup> logo, rfPIC and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

FilterLab, Hampshire, HI-TECH C, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Application Maestro, CodeGuard, dsPICDEM, dsPICDEM.net, dsPICworks, dsSPEAK, ECAN, ECONOMONITOR, FanSense, HI-TIDE, In-Circuit Serial Programming, ICSP, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, Omniscient Code Generation, PICC, PICC-18, PICDEM, PICDEM.net, PICkit, PICtail, REAL ICE, rfLAB, Select Mode, Total Endurance, TSHARC, UniWinDriver, WiperLock and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

All other trademarks mentioned herein are property of their respective companies.

© 2010, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

Printed on recycled paper.

ISBN: 978-1-60932-636-4

Microchip received ISO/TS-16949:2002 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company's quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001:2000 certified.



## **Worldwide Sales and Service**

### AMERICAS

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

www.microchip.com

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

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

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

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

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

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

Kokomo Kokomo, IN Tel: 765-864-8360 Fax: 765-864-8387

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

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

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

### ASIA/PACIFIC

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

Tel: 61-2-9868-6733 Fax: 61-2-9868-6755

**China - Beijing** Tel: 86-10-8528-2100 Fax: 86-10-8528-2104

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

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

**China - Hong Kong SAR** Tel: 852-2401-1200 Fax: 852-2401-3431

China - Nanjing Tel: 86-25-8473-2460

Fax: 86-25-8473-2470 China - Qingdao Tel: 86-532-8502-7355 Fax: 86-532-8502-7205

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

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

**China - Shenzhen** Tel: 86-755-8203-2660 Fax: 86-755-8203-1760

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

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

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

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

## ASIA/PACIFIC

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

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

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

**Japan - Yokohama** Tel: 81-45-471- 6166 Fax: 81-45-471-6122

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

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

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

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

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

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

**Taiwan - Hsin Chu** Tel: 886-3-6578-300 Fax: 886-3-6578-370

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

Taiwan - Taipei Tel: 886-2-2500-6610 Fax: 886-2-2508-0102

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

## EUROPE

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

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

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

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

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

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

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

08/04/10