

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

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

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

#### Details

E·XFI

| Product Status             | Active                                                                         |
|----------------------------|--------------------------------------------------------------------------------|
| Core Processor             | PIC                                                                            |
| Core Size                  | 16-Bit                                                                         |
| Speed                      | 16MHz                                                                          |
| Connectivity               | I <sup>2</sup> C, PMP, SPI, UART/USART                                         |
| Peripherals                | Brown-out Detect/Reset, POR, PWM, WDT                                          |
| Number of I/O              | 84                                                                             |
| Program Memory Size        | 128KB (43K x 24)                                                               |
| Program Memory Type        | FLASH                                                                          |
| EEPROM Size                | -                                                                              |
| RAM Size                   | 8K x 8                                                                         |
| Voltage - Supply (Vcc/Vdd) | 2V ~ 3.6V                                                                      |
| Data Converters            | A/D 16x10b                                                                     |
| Oscillator Type            | Internal                                                                       |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                              |
| Mounting Type              | Surface Mount                                                                  |
| Package / Case             | 100-TQFP                                                                       |
| Supplier Device Package    | 100-TQFP (12x12)                                                               |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/pic24fj128ga010-i-pt |

Email: info@E-XFL.COM

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

## PIC24FJXXXGA0XX

The regulator provides power to the core from the other VDD pins. A low-ESR capacitor (such as tantalum) must be connected to the VDDCORE pin (Figure 2-2 and Figure 2-3). This helps to maintain the stability of the regulator. The specifications for core voltage and capacitance are listed in Section 7.0 "AC/DC Characteristics and Timing Requirements".

#### FIGURE 2-2: CONNECTIONS FOR THE ON-CHIP REGULATOR (64/80/100-PIN DEVICES)



#### FIGURE 2-3: CONNECTIONS FOR THE ON-CHIP REGULATOR (28/44-PIN DEVICES)



#### **Pin Diagrams**



#### **Pin Diagrams (Continued)**



#### **Pin Diagrams (Continued)**



#### 2.4 Memory Map

The program memory map extends from 000000h to FFFFFEh. Code storage is located at the base of the memory map and supports up to 44K instruction words (about 128 Kbytes). Table 2-3 shows the program memory size and number of erase and program blocks present in each device variant. Each erase block, or page, contains 512 instructions, and each program block, or row, contains 64 instructions.

Locations 800000h through 8007FEh are reserved for executive code memory. This region stores the programming executive and the debugging executive. The programming executive is used for device programming and the debugging executive is used for in-circuit debugging. This region of memory can not be used to store user code.

The last two implemented program memory locations are reserved for the device Configuration registers.

# TABLE 2-2:FLASH CONFIGURATION<br/>WORD LOCATIONS FOR<br/>PIC24FJXXXGA0XX DEVICES

| Device         | 0       | ition Word<br>esses |
|----------------|---------|---------------------|
|                | 1       | 2                   |
| PIC24FJ16GA    | 002BFEh | 002BFCh             |
| PIC24FJ32GA    | 0057FEh | 0057FCh             |
| PIC24FJ48GA    | 0083FEh | 0083FCh             |
| PIC24FJ64GA    | 00ABFEh | 00ABFCh             |
| PIC24FJ96GA    | 00FFFEh | 00FFFCh             |
| PIC24FJ128GAGA | 0157FEh | 0157FCh             |

Locations, FF0000h and FF0002h, are reserved for the Device ID registers. These bits can be used by the programmer to identify what device type is being programmed. They are described in **Section 6.1 "Device ID"**. The Device ID registers read out normally, even after code protection is applied.

Figure 2-4 shows the memory map for the PIC24FJXXXGA0XX family variants.

|              | ••••                                                | •               |                 |
|--------------|-----------------------------------------------------|-----------------|-----------------|
| Device       | User Memory<br>Address Limit<br>(Instruction Words) | Write<br>Blocks | Erase<br>Blocks |
| PIC24FJ16GA  | 002BFEh (5.5K)                                      | 88              | 11              |
| PIC24FJ32GA  | 0057FEh (11K)                                       | 176             | 22              |
| PIC24FJ48GA  | 0083FEh (16.5K)                                     | 264             | 33              |
| PIC24FJ64GA  | 00ABFEh (22K)                                       | 344             | 43              |
| PIC24FJ96GA  | 00FFFEh (32K)                                       | 512             | 64              |
| PIC24FJ128GA | 0157FEh (44K)                                       | 688             | 86              |

TABLE 2-3: CODE MEMORY SIZE

## PIC24FJXXXGA0XX



### 3.0 DEVICE PROGRAMMING – ICSP

ICSP mode is a special programming protocol that allows you to read and write to PIC24FJXXXGA0XX device family memory. The ICSP mode is the most direct method used to program the device; note, however, that Enhanced ICSP is faster. ICSP mode also has the ability to read the contents of executive memory to determine if the programming executive is present. This capability is accomplished by applying control codes and instructions, serially to the device, using pins, PGCx and PGDx.

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

| Note: | During ICSP  | operation, the operating |
|-------|--------------|--------------------------|
|       | frequency of | PGCx must not exceed     |
|       | 10 MHz.      |                          |

#### 3.1 Overview of the Programming Process

Figure 3-1 shows the high-level overview of the programming process. After entering ICSP mode, the first action is to Chip Erase the device. Next, the code memory is programmed, followed by the device Configuration registers. Code memory (including the Configuration registers) is then verified to ensure that programming was successful. Then, program the code-protect Configuration bits, if required.

#### FIGURE 3-1: HIGH-LEVEL ICSP™ PROGRAMMING FLOW



### 3.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 PGCx and PGDx, and this control code is used to command the CPU (see Table 3-1).

The SIX control code is used to send instructions to the CPU for execution, and the REGOUT control code is used to read data out of the device via the VISI register.

| TABLE 3-1: | CPU CONTROL CODES IN |
|------------|----------------------|
|            | ICSP™ MODE           |

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

| Command<br>(Binary) | Data<br>(Hex)             | Description                                                       |  |
|---------------------|---------------------------|-------------------------------------------------------------------|--|
| Step 1: Exit        | the Reset vector.         |                                                                   |  |
| 0000                | 000000                    | NOP                                                               |  |
| 0000                | 040200                    | GOTO 0x200                                                        |  |
| 0000                | 000000                    | NOP                                                               |  |
| Step 2: Set t       | he NVMCON to era          | se all program memory.                                            |  |
| 0000                | 2404FA                    | MOV #0x404F, W10                                                  |  |
| 0000                | 883B0A                    | MOV W10, NVMCON                                                   |  |
| Step 3: Set         | <b>FBLPAG</b> and perform | n dummy table write to select what portions of memory are erased. |  |
| 0000                | 200000                    | MOV # <pageval>, W0</pageval>                                     |  |
| 0000                | 880190                    | MOV W0, TBLPAG                                                    |  |
| 0000                | 200000                    | MOV #0x0000, W0                                                   |  |
| 0000                | BB0800                    | TBLWTL W0,[W0]                                                    |  |
| 0000                | 000000                    | NOP                                                               |  |
| 0000                | 000000                    | NOP                                                               |  |
| Step 4: Initia      | te the erase cycle.       |                                                                   |  |
| 0000                | A8E761                    | BSET NVMCON, #WR                                                  |  |
| 0000                | 000000                    | NOP                                                               |  |
| 0000                | 000000                    | NOP                                                               |  |
| Step 5: Repe        | eat this step to poll t   | he WR bit (bit 15 of NVMCON) until it is cleared by the hardware. |  |
| 0000                | 040200                    | GOTO 0x200                                                        |  |
| 0000                | 000000                    | NOP                                                               |  |
| 0000                | 803B02                    | MOV NVMCON, W2                                                    |  |
| 0000                | 883C22                    | MOV W2, VISI                                                      |  |
| 0000                | 000000                    | NOP                                                               |  |
| 0001                | <visi></visi>             | Clock out contents of the VISI register.                          |  |
| 0000                | 000000                    | NOP                                                               |  |

#### TABLE 3-4: SERIAL INSTRUCTION EXECUTION FOR CHIP ERASE

#### 3.6 Writing Code Memory

The procedure for writing code memory is the same as the procedure for writing the Configuration registers, except that 64 instruction words are programmed at a time. To facilitate this operation, working registers, W0:W5, are used as temporary holding registers for the data to be programmed.

Table 3-5 shows the ICSP programming details, including the serial pattern with the ICSP command code which must be transmitted, Least Significant bit first, using the PGCx and PGDx pins (see Figure 3-2).

In Step 1, the Reset vector is exited. In Step 2, the NVMCON register is initialized for programming a full row of code memory. In Step 3, the 24-bit starting destination address for programming is loaded into the TBLPAG register and W7 register. (The upper byte of the starting destination address is stored in TBLPAG and the lower 16 bits of the destination address are stored in W7.)

To minimize the programming time, A packed instruction format is used (Figure 3-6).

In Step 4, four packed instruction words are stored in working registers, W0:W5, using the MOV instruction, and the Read Pointer, W6, is initialized. The contents of W0:W5 (holding the packed instruction word data) are shown in Figure 3-6.

In Step 5, eight TBLWT instructions are used to copy the data from W0:W5 to the write latches of code memory. Since code memory is programmed 64 instruction words at a time, Steps 4 and 5 are repeated 16 times to load all the write latches (Step 6).

After the write latches are loaded, programming is initiated by writing to the NVMCON register in Steps 7 and 8. In Step 9, the internal PC is reset to 200h. This is a precautionary measure to prevent the PC from incrementing into unimplemented memory when large devices are being programmed. Lastly, in Step 10, Steps 3-9 are repeated until all of code memory is programmed.

| FIGURE 3-6: | PACKED INSTRUCTION |
|-------------|--------------------|
|             |                    |

| WORDS I | N W<0:5> |
|---------|----------|
|         |          |

|    | 15 |      | 8   | 7  |      | 0 |
|----|----|------|-----|----|------|---|
| W0 |    |      | LS\ | NO |      |   |
| W1 |    | MSB1 |     |    | MSB0 |   |
| W2 |    |      | LS۱ | W1 |      |   |
| W3 |    |      | LS۱ | N2 |      |   |
| W4 |    | MSB3 |     |    | MSB2 |   |
| W5 |    |      | LS۱ | N3 |      |   |
|    |    |      |     |    |      |   |

 TABLE 3-5:
 SERIAL INSTRUCTION EXECUTION FOR WRITING CODE MEMORY

| Command<br>(Binary) | Data<br>(Hex)                                                    | Description |                                                                     |  |
|---------------------|------------------------------------------------------------------|-------------|---------------------------------------------------------------------|--|
| Step 1: Exi         | t the Reset vector.                                              |             |                                                                     |  |
| 0000                | 000000                                                           | NOP         |                                                                     |  |
| 0000                | 040200                                                           | GOTO        | 0x200                                                               |  |
| 0000                | 000000                                                           | NOP         |                                                                     |  |
| Step 2: Set         | the NVMCON to pr                                                 | ogram 64    | 4 instruction words.                                                |  |
| 0000                | 24001A                                                           | MOV         | #0x4001, W10                                                        |  |
| 0000                | 883B0A                                                           | MOV         | W10, NVMCON                                                         |  |
| Step 3: Initi       | Step 3: Initialize the Write Pointer (W7) for TBLWT instruction. |             |                                                                     |  |
| 0000                | 200xx0                                                           | MOV         | <pre>#<destinationaddress23:16>, W0</destinationaddress23:16></pre> |  |
| 0000                | 880190                                                           | MOV         | W0, TBLPAG                                                          |  |
| 0000                | 2xxxx7                                                           | MOV         | <pre>#<destinationaddress15:0>, W7</destinationaddress15:0></pre>   |  |
| Step 4: Loa         | Step 4: Load W0:W5 with the next 4 instruction words to program. |             |                                                                     |  |
| 0000                | 2xxxx0                                                           | MOV         | # <lsw0>, W0</lsw0>                                                 |  |
| 0000                | 2xxxx1                                                           | MOV         | # <msb1:msb0>, W1</msb1:msb0>                                       |  |
| 0000                | 2xxxx2                                                           | MOV         | # <lsw1>, W2</lsw1>                                                 |  |
| 0000                | 2xxxx3                                                           | MOV         | # <lsw2>, W3</lsw2>                                                 |  |
| 0000                | 2xxxx4                                                           | MOV         | # <msb3:msb2>, W4</msb3:msb2>                                       |  |
| 0000                | 2xxxx5                                                           | MOV         | # <lsw3>, W5</lsw3>                                                 |  |

#### 3.7 Writing Configuration Words

The PIC24FJXXXGA0XX family configuration is stored in Flash Configuration Words at the end of the user space program memory and in multiple register Configuration Words located in the test space.

These registers reflect values read at any Reset from program memory locations. The values can be changed only by programming the content of the corresponding Flash Configuration Word and resetting the device. The Reset forces an automatic reload of the Flash stored configuration values by sequencing through the dedicated Flash Configuration Words and transferring the data into the Configuration Words and transferring the data into the Configuration Word once it has been programmed, the device must be Chip Erased, as described in **Section 3.5 "Erasing Program Memory"**, and reprogrammed to the desired value. It is not possible to program a '0' to '1', but they may be programmed from a '1' to '0' to enable code protection.

Table 3-7 shows the ICSP programming details for programming the Configuration Word locations, including the serial pattern with the ICSP command code which must be transmitted, Least Significant bit first, using the PGCx and PGDx pins (see Figure 3-2). In Step 1, the Reset vector is exited. In Step 2, the NVMCON register is initialized for programming of code memory. In Step 3, the 24-bit starting destination address for programming is loaded into the TBLPAG register and W7 register.

The TBLPAG register must be loaded with the following:

- 96 and 64 Kbyte devices 00h
- 128 Kbyte devices 01h

To verify the data by reading the Configuration Words after performing the write in order, the code protection bits initially should be programmed to a '1' to ensure that the verification can be performed properly. After verification is finished, the code protection bit can be programmed to a '0' by using a word write to the appropriate Configuration Word.

#### TABLE 3-6: DEFAULT CONFIGURATION REGISTER VALUES

| Address       | Name | Default Value        |
|---------------|------|----------------------|
| Last Word     | CW1  | 7FFFh <sup>(1)</sup> |
| Last Word – 2 | CW2  | FFFFh                |

**Note 1:** CW1<15> is reserved and must be programmed to '0'.

#### 3.10 Verify Code Memory and Configuration Word

The verify step involves reading back the code memory space and comparing it against the copy held in the programmer's buffer. The Configuration registers are verified with the rest of the code.

The verify process is shown in the flowchart in Figure 3-8. Memory reads occur a single byte at a time, so two bytes must be read to compare against the word in the programmer's buffer. Refer to **Section 3.8** "**Reading Code Memory**" for implementation details of reading code memory.

Note: Because the Configuration registers include the device code protection bit, code memory should be verified immediately after writing if code protection is enabled. This is because the device will not be readable or verifiable if a device Reset occurs after the code-protect bit in CW1 has been cleared.

#### FIGURE 3-8: VERIFY CODE MEMORY FLOW



## 3.11 Reading the Application ID Word

The Application ID Word is stored at address 8005BEh in executive code memory. To read this memory location, you must use the SIX control code to move this program memory location to the VISI register. Then, the REGOUT control code must be used to clock the contents of the VISI register out of the device. The corresponding control and instruction codes that must be serially transmitted to the device to perform this operation are shown in Table 3-10.

After the programmer has clocked out the Application ID Word, it must be inspected. If the Application ID has the value, BBh, the programming executive is resident in memory and the device can be programmed using the mechanism described in **Section 4.0** "**Device Programming – Enhanced ICSP**". However, if the Application ID has any other value, the programming executive is not resident in memory; it must be loaded to memory before the device can be programmed. The procedure for loading the programming executive to memory is described in **Section 5.4** "Programming the Programming Executive to Memory".

## 3.12 Exiting ICSP Mode

Exiting Program/Verify mode is done by removing VIH from MCLR, as shown in Figure 3-9. The only requirement for exit is that an interval, P16, should elapse between the last clock and program signals on PGCx and PGDx before removing VIH.



#### 4.6.2 PROGRAMMING METHODOLOGY

Configuration bits may be programmed a single byte at a time using the PROGW command. This command specifies the configuration data and Configuration register address. When Configuration bits are programmed, any unimplemented or reserved bits must be programmed with a '1'.

Two PROGW commands are required to program the Configuration bits. A flowchart for Configuration bit programming is shown in Figure 4-5.

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

#### 4.6.3 PROGRAMMING VERIFICATION

After 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 READP command reads back the programmed Configuration bits and verifies that the programming was successful.

#### 4.6.4 CODE-PROTECT CONFIGURATION BITS

CW1 Configuration register controls code protection for the PIC24FJXXXGA0XX family. Two forms of code protection are provided. One form prevents code memory from being written (write protection) and the other prevents code memory from being read (read protection).

GWRP (CW1<12>) controls write protection and GCP (CW1<13>) controls read protection. Protection is enabled when the respective bit is '0'.

Erasing sets GWRP and GCP to '1', which allows the device to be programmed.

When write protection is enabled (GWRP = 0), any programming operation to code memory will fail.

When read protection is enabled (GCP = 0), any read from code memory will cause a 0h 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 also will result in failure.

It is imperative that both GWRP and GCP are '1' while the device is being programmed and verified. Only after the device is programmed and verified should either GWRP or GCP be programmed to '0' (see **Section 4.6 "Configuration Bits Programming"**).

| Note: | Bulk Erasing in ICSP mode is the only way |
|-------|-------------------------------------------|
|       | to reprogram code-protect bits from an ON |
|       | state ('0') to an Off state ('1').        |





### 4.7 Exiting Enhanced ICSP Mode

Exiting Program/Verify mode is done by removing VIH from MCLR, as shown in Figure 4-6. The only requirement for exit is that an interval, P16, should elapse between the last clock and program signals on PGCx and PGDx before removing VIH.



EXITING ENHANCED ICSP™ MODE



#### 5.2.6 READC COMMAND

| 15     | 12 | 11 | 8     | 7        | 0 |
|--------|----|----|-------|----------|---|
| Opcode |    |    |       | Length   |   |
| N      |    |    |       | Addr_MSB |   |
| Addr_  |    |    | Addr_ | LS       |   |

| Field    | Description                                               |
|----------|-----------------------------------------------------------|
| Opcode   | 1h                                                        |
| Length   | 3h                                                        |
| N        | Number of 8-bit Device ID registers to read (max. of 256) |
| Addr_MSB | MSB of 24-bit source address                              |
| Addr_LS  | Least Significant 16 bits of 24-bit source address        |

The READC command instructs the programming executive to read N or Device ID registers, starting from the 24-bit address specified by Addr\_MSB and Addr\_LS. This command can only be used to read 8-bit or 16-bit data.

When this command is used to read Device ID registers, the upper byte in every data word returned by the programming executive is 00h and the lower byte contains the Device ID register value.

#### Expected Response (4 + 3 \* (N - 1)/2 words for N odd):

1100h 2 + N Device ID Register 1

Device ID Register N

Note: Reading unimplemented memory will cause the programming executive to reset. Please ensure that only memory locations present on a particular device are accessed.

#### 5.2.7 READP COMMAND

| 15       | 15 12 11 8 7 ( |  |          | 0      |  |
|----------|----------------|--|----------|--------|--|
| Opcode   |                |  |          | Length |  |
|          |                |  | Ν        |        |  |
| Reserved |                |  | Addr_MSB |        |  |
| Addr_LS  |                |  | LS       |        |  |

| Field    | Description                                           |
|----------|-------------------------------------------------------|
| Opcode   | 2h                                                    |
| Length   | 4h                                                    |
| N        | Number of 24-bit instructions to read (max. of 32768) |
| Reserved | 0h                                                    |
| Addr_MSB | MSB of 24-bit source address                          |
| Addr_LS  | Least Significant 16 bits of 24-bit source address    |

The READP command instructs the programming executive to read N 24-bit words of code memory, including Configuration Words, starting from the 24-bit address specified by Addr\_MSB and Addr\_LS. This command can only be used to read 24-bit data. All data returned in response to this command uses the packed data format described in **Section 5.2.2 "Packed Data Format"**.

#### Expected Response (2 + 3 \* N/2 words for N even): 1200h

2 + 3 \* N/2

Least significant program memory word 1

...

Least significant data word N

#### Expected Response (4 + 3 \* (N - 1)/2 words for N odd):

1200h

4 + 3 \* (N – 1)/2

Least significant program memory word 1

•••

MSB of program memory word N (zero padded)

Note: Reading unimplemented memory will cause the programming executive to reset. Please ensure that only memory locations present on a particular device are accessed.

## PIC24FJXXXGA0XX

#### 5.2.8 PROGC COMMAND

| 15 12 11 |  | 8 | 7     |          | 0     |  |
|----------|--|---|-------|----------|-------|--|
| Opcode   |  |   |       | Le       | ength |  |
| Reserved |  |   |       | Addr_MSB |       |  |
|          |  |   | Addr_ | LS       |       |  |
| I        |  |   | Dat   | а        |       |  |

| Field    | Description                                             |
|----------|---------------------------------------------------------|
| Opcode   | 4h                                                      |
| Length   | 4h                                                      |
| Reserved | 0h                                                      |
| Addr_MSB | MSB of 24-bit destination address                       |
| Addr_LS  | Least Significant 16 bits of 24-bit destination address |
| Data     | 8-bit data word                                         |

The PROGC command instructs the programming executive to program a single Device ID register located at the specified memory address.

After the specified data word has been programmed to code memory, the programming executive verifies the programmed data against the data in the command.

#### Expected Response (2 words):

1400h 0002h

#### 5.2.9 PROGP COMMAND

| 15       | 15 12 11 8 7 0 |  |       |    | 0        |  |
|----------|----------------|--|-------|----|----------|--|
| Орс      | ode            |  |       | L  | ength    |  |
| Reserved |                |  |       |    | Addr_MSB |  |
|          |                |  | Addr_ | LS |          |  |
| D_1      |                |  |       |    |          |  |
| D_2      |                |  |       |    |          |  |
|          |                |  |       |    |          |  |
|          | D_96           |  |       |    |          |  |

| Field    | Description                                             |
|----------|---------------------------------------------------------|
| Opcode   | 5h                                                      |
| Length   | 63h                                                     |
| Reserved | 0h                                                      |
| Addr_MSB | MSB of 24-bit destination address                       |
| Addr_LS  | Least Significant 16 bits of 24-bit destination address |
| D_1      | 16-bit data word 1                                      |
| D_2      | 16-bit data word 2                                      |
|          | 16-bit data word 3 through 95                           |
| D_96     | 16-bit data word 96                                     |

The PROGP command instructs the programming executive to program one row of code memory, including Configuration Words (64 instruction words), to the specified memory address. Programming begins with the row address specified in the command. The destination address should be a multiple of 80h.

The data to program to memory, located in command words, D\_1 through D\_96, must be arranged using the packed instruction word format shown in Figure 5-5.

After all data has been programmed to code memory, the programming executive verifies the programmed data against the data in the command.

Expected Response (2 words):

1500h

0002h

Note: Refer to Table 2-3 for code memory size information.

#### 5.3.1.3 QE\_Code Field

The QE\_Code is a byte in the first word of the response. This byte is used to return data for query commands and error codes for all other commands.

When the programming executive processes one of the two query commands (QBLANK or QVER), the returned opcode is always PASS and the QE\_Code holds the query response data. The format of the QE\_Code for both queries is shown in Table 5-3.

TABLE 5-3: QE\_Code FOR QUERIES

| Query  | QE_Code                                                                                               |  |  |  |
|--------|-------------------------------------------------------------------------------------------------------|--|--|--|
| QBLANK | 0Fh = Code memory is NOT blank<br>F0h = Code memory is blank                                          |  |  |  |
| QVER   | 0xMN, where programming executive<br>software version = M.N (i.e., 32h means<br>software version 3.2) |  |  |  |

When the programming executive processes any command other than a query, the QE\_Code represents an error code. Supported error codes are shown in Table 5-4. If a command is successfully processed, the returned QE\_Code is set to 0h, which indicates that there was no error in the command processing. If the verify of the programming for the PROGP or PROGC command fails, the QE\_Code is set to 1h. For all other programming executive errors, the QE\_Code is 2h.

#### TABLE 5-4: QE\_Code FOR NON-QUERY COMMANDS

| QE_Code | Description   |
|---------|---------------|
| 0h      | No error      |
| 1h      | Verify failed |
| 2h      | Other error   |

#### 5.3.1.4 Response Length

The response length indicates the length of the programming executive's response in 16-bit words. This field includes the 2 words of the response header.

With the exception of the response for the READP command, the length of each response is only 2 words.

The response to the READP command uses the packed instruction word format described in **Section 5.2.2** "**Packed Data Format**". When reading an odd number of program memory words (N odd), the response to the READP command is (3 \* (N + 1)/2 + 2) words. When reading an even number of program memory words (N even), the response to the READP command is (3 \* N/2 + 2) words.

| TABLE 5         | -5:    | PROGRAMMI                                  | NG THE      | PROGRAMMING EXECUTIVE (CONTINUED)                                                                                               |
|-----------------|--------|--------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Comma<br>(Binar |        | Data<br>(Hex)                              |             | Description                                                                                                                     |
| Step 7:         |        | eat Steps 5 and 6 to<br>emented by 400h to |             | e second page of executive memory. The W1 Pointer should be e second page.                                                      |
| Step 8:         |        |                                            |             | o write stored diagnostic and calibration as single words. Initialize W1 rs to rewrite stored Diagnostic and Calibration Words. |
| 0000            |        | 200800                                     | MOV         | #0x80, W0                                                                                                                       |
| 0000            |        | 880190                                     | MOV         | W0, TBLPAG                                                                                                                      |
| 0000            |        | 240031                                     | MOV         | #0x4003, W1                                                                                                                     |
| 0000            |        | 883B01                                     | MOV         | W1, NVMCON                                                                                                                      |
| 0000            |        | 207F00                                     | MOV         | #0x07F0, W1                                                                                                                     |
| 0000            |        | 2000C2                                     | MOV         | #0xC, W2                                                                                                                        |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| Step 9:         | Perf   | orm write of a single                      | e word of c | alibration data and initiate single-word write cycle.                                                                           |
| 0000            |        | BB18B2                                     | TBLWTL      | [W2++], [W1++]                                                                                                                  |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| 0000            |        | A8E761                                     | BSET        | NVMCON, #15                                                                                                                     |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| Step 10:        | Repe   | eat this step to poll                      | the WR bit  | (bit 15 of NVMCON) until it is cleared by the hardware.                                                                         |
| 0000            |        | 040200                                     | GOTO        | 0x200                                                                                                                           |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| 0000            |        | 803B00                                     | MOV         | NVMCON, WO                                                                                                                      |
| 0000            |        | 883C20                                     | MOV         | WO, VISI                                                                                                                        |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| 0001            |        | <visi></visi>                              | Clock o     | ut contents of VISI register.                                                                                                   |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| Step 11:        |        | •                                          |             | nes to program the remainder of the Diagnostic and Calibration Words                                                            |
| <b>0</b> / 10   |        | into program mem                           | •           |                                                                                                                                 |
| -               |        |                                            | to program  | 64 instruction words.                                                                                                           |
| 0000            |        | 240010                                     | MOV         | #0x4001, W0                                                                                                                     |
| 0000            |        | 883B00                                     | MOV         | W0, NVMCON                                                                                                                      |
| Step 13:        | Initia | lize TBLPAG and t                          | he Write P  | pinter (W7).                                                                                                                    |
| 0000            |        | 200800                                     | MOV         | #0x80, W0                                                                                                                       |
| 0000            |        | 880190                                     | MOV         | W0, TBLPAG                                                                                                                      |
| 0000            |        | EB0380                                     | CLR         | W7                                                                                                                              |
| 0000            |        | 000000                                     | NOP         |                                                                                                                                 |
| Step 14:        |        |                                            |             | ords of packed programming executive code and initialize W6 for                                                                 |
|                 |        | ramming. Program<br>ter and W7 as a W      |             | from the base of executive memory (800000h) using W6 as a Read                                                                  |
| 0000            |        | 2 <lsw0>0</lsw0>                           | MOV         | # <lsw0>, W0</lsw0>                                                                                                             |
| 0000            |        | 2 <msb1:msb0>1</msb1:msb0>                 | MOV         | # <msb1:msb0>, W1</msb1:msb0>                                                                                                   |
| 0000            |        |                                            | MOV         | # <lsw1>, W2</lsw1>                                                                                                             |
| 0000            |        | 2 <lsw1>2</lsw1>                           |             |                                                                                                                                 |
|                 |        | 2 <lsw1>2<br/>2<lsw2>3</lsw2></lsw1>       | MOV         |                                                                                                                                 |
| 0000            |        |                                            |             | # <lsw2>, W3<br/>#<msb3:msb2>, W4</msb3:msb2></lsw2>                                                                            |

#### 5.4.2 PROGRAMMING VERIFICATION

After the programming executive has been programmed to executive memory using ICSP, it must be verified. Verification is performed by reading out the contents of executive memory and comparing it with the image of the programming executive stored in the programmer.

Reading the contents of executive memory can be performed using the same technique described in **Section 3.8 "Reading Code Memory"**. A procedure for reading executive memory is shown in Table 5-6. Note that in Step 2, the TBLPAG register is set to 80h, such that executive memory may be read. The last eight words of executive memory should be verified with stored values of the Diagnostic and Calibration Words to ensure accuracy.

| Command<br>(Binary)        | Data<br>(Hex)                   | Description                                                                                   |  |  |  |  |
|----------------------------|---------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|
| Step 1: Exit               | the Reset vecto                 | r.                                                                                            |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | 040200                          | GOTO 0x200                                                                                    |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| Step 2: Initia             | alize TBLPAG ar                 | nd the Read Pointer (W6) for TBLRD instruction.                                               |  |  |  |  |
| 0000                       | 200800                          | MOV #0x80, W0                                                                                 |  |  |  |  |
| 0000                       | 880190                          | MOV W0, TBLPAG                                                                                |  |  |  |  |
| 0000                       | EB0300                          | CLR W6                                                                                        |  |  |  |  |
| Step 3: Initia             | alize the Write P               | ointer (W7) to point to the VISI register.                                                    |  |  |  |  |
| 0000                       | 207847                          | MOV #VISI, W7                                                                                 |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| using                      | d and clock out<br>g the REGOUT | the contents of the next two locations of executive memory through the VISI register command. |  |  |  |  |
| 0000                       | BA0B96                          | TBLRDL [W6], [W7]                                                                             |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0001                       | <visi></visi>                   | Clock out contents of VISI register                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | BADBB6                          | TBLRDH.B [W6++], [W7++]                                                                       |  |  |  |  |
| 0000                       | 000000                          | NOP<br>NOP                                                                                    |  |  |  |  |
| 0000 000000<br>0000 BAD3D6 |                                 | TBLRDH.B[++W6], [W7]                                                                          |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0001 <visi></visi>         |                                 | Clock out contents of VISI register                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | BA0BB6                          | TBLRDL [W6++], [W7]                                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| 0001                       | <visi></visi>                   | Clock out contents of VISI register                                                           |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| Step 5: Rese               | et the device int               | ernal PC.                                                                                     |  |  |  |  |
| 0000                       | 040200                          | GOTO 0x200                                                                                    |  |  |  |  |
| 0000                       | 000000                          | NOP                                                                                           |  |  |  |  |
| Stop C. Dop                | aat Stens / and                 | 5 until all desired code memory is read.                                                      |  |  |  |  |

#### TABLE 5-6: READING EXECUTIVE MEMORY

#### 7.0 **AC/DC CHARACTERISTICS AND TIMING REQUIREMENTS**

#### Standard Operating Conditions

| Operating Temperature: 0°C to +70°C. Programming at +25°C is recommended. |        |                                                                                                        |               |         |       |                                     |  |  |
|---------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------|---------------|---------|-------|-------------------------------------|--|--|
| Param<br>No.                                                              | Symbol | Characteristic                                                                                         | Min           | Max     | Units | Conditions                          |  |  |
| D111                                                                      | Vdd    | Supply Voltage During Programming                                                                      | VDDCORE + 0.1 | 3.60    | V     | Normal programming <sup>(1,2)</sup> |  |  |
| D112                                                                      | IPP    | Programming Current on MCLR                                                                            | —             | 5       | μA    |                                     |  |  |
| D113                                                                      | IDDP   | Supply Current During Programming                                                                      | —             | 2       | mA    |                                     |  |  |
| D031                                                                      | VIL    | Input Low Voltage                                                                                      | Vss           | 0.2 Vdd | V     |                                     |  |  |
| D041                                                                      | Viн    | Input High Voltage                                                                                     | 0.8 Vdd       | Vdd     | V     |                                     |  |  |
| D080                                                                      | Vol    | Output Low Voltage                                                                                     |               | 0.4     | V     | IOL = 8.5 mA @ 3.6V                 |  |  |
| D090                                                                      | Vон    | Output High Voltage                                                                                    | 3.0           | _       | V     | Юн = -3.0 mA @ 3.6V                 |  |  |
| D012                                                                      | Сю     | Capacitive Loading on I/O pin (PGDx)                                                                   |               | 50      | pF    | To meet AC specifications           |  |  |
| D013                                                                      | CF     | Filter Capacitor Value on VCAP                                                                         | 4.7           | 10      | μF    | Required for controller core        |  |  |
| P1                                                                        | TPGC   | Serial Clock (PGCx) Period                                                                             | 100           | _       | ns    |                                     |  |  |
| P1A                                                                       | TPGCL  | Serial Clock (PGCx) Low Time                                                                           | 40            | _       | ns    |                                     |  |  |
| P1B                                                                       | Трдсн  | Serial Clock (PGCx) High Time                                                                          | 40            |         | ns    |                                     |  |  |
| P2                                                                        | TSET1  | Input Data Setup Time to Serial Clock $\uparrow$                                                       | 15            |         | ns    |                                     |  |  |
| P3                                                                        | THLD1  | Input Data Hold Time from PGCx ↑                                                                       | 15            | _       | ns    |                                     |  |  |
| P4                                                                        | TDLY1  | Delay Between 4-Bit Command and<br>Command Operand                                                     | 40            | _       | ns    |                                     |  |  |
| P4A                                                                       | TDLY1A | Delay Between 4-Bit Command Operand<br>and Next 4-Bit Command                                          | 40            | _       | ns    |                                     |  |  |
| P5                                                                        | TDLY2  | Delay Between Last PGCx $\downarrow$ of Command<br>Byte to First PGCx $\uparrow$ of Read of Data Word  | 20            |         | ns    |                                     |  |  |
| P6                                                                        | TSET2  | VDD ↑ Setup Time to MCLR ↑                                                                             | 100           | _       | ns    |                                     |  |  |
| P7                                                                        | THLD2  | Input Data Hold Time from MCLR 1                                                                       | 25            | _       | ms    |                                     |  |  |
| P8                                                                        | TDLY3  | Delay Between Last PGCx ↓ of Command<br>Byte to PGDx ↑ by Programming Executive                        | 12            | _       | μS    |                                     |  |  |
| P9                                                                        | TDLY4  | Programming Executive Command<br>Processing Time                                                       | 40            |         | μS    |                                     |  |  |
| P10                                                                       | TDLY6  | PGCx Low Time After Programming                                                                        | 400           | _       | ns    |                                     |  |  |
| P11                                                                       | TDLY7  | Chip Erase Time                                                                                        | 400           | _       | ms    |                                     |  |  |
| P12                                                                       | TDLY8  | Page Erase Time                                                                                        | 40            | _       | ms    |                                     |  |  |
| P13                                                                       | TDLY9  | Row Programming Time                                                                                   | 2             | _       | ms    |                                     |  |  |
| P14                                                                       | Tr     | MCLR Rise Time to Enter ICSP™ mode                                                                     | —             | 1.0     | μS    |                                     |  |  |
| P15                                                                       | Tvalid | Data Out Valid from PGCx ↑                                                                             | 10            |         | ns    |                                     |  |  |
| P16                                                                       | TDLY10 | Delay Between Last PGCx $\downarrow$ and $\overline{MCLR}$ $\downarrow$                                | 0             | _       | s     |                                     |  |  |
| P17                                                                       | THLD3  | $\overline{MCLR} \downarrow to VDD \downarrow$                                                         | 100           |         | ns    |                                     |  |  |
| P18                                                                       | Ткеү1  | Delay from First $\overline{\text{MCLR}} \downarrow$ to First PGCx $\uparrow$ for Key Sequence on PGDx | 40            |         | ns    |                                     |  |  |
| P19                                                                       | Τκεγ2  | Delay from Last PGCx $\downarrow$ for Key<br>Sequence on PGDx to Second MCLR $\uparrow$                | 1             | _       | ms    |                                     |  |  |
| P20                                                                       | TDLY11 | Delay Between PGDx ↓ by Programming<br>Executive to PGDx Driven by Host                                | 23            |         | μs    |                                     |  |  |
| P21                                                                       | TDLY12 | Delay Between Programming Executive<br>Command Response Words                                          | 8             | _       | ns    |                                     |  |  |

VDDCORE must be supplied to the VDDCORE/VCAP pin if the on-chip voltage regulator is disabled. See Section 2.1 Note 1: "Power Requirements" for more information. (Minimum VDDCORE allowing Flash programming is 2.25V.)

2: VDD must also be supplied to the AVDD pins during programming. AVDD and AVSS should always be within ±0.3V of VDD and VSS, respectively.

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

#### Trademarks

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

FilterLab, Linear Active Thermistor, MXDEV, MXLAB, SEEVAL, SmartSensor 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, In-Circuit Serial Programming, ICSP, ICEPIC, Mindi, MiWi, MPASM, MPLAB Certified logo, MPLIB, MPLINK, mTouch, PICkit, PICDEM, PICDEM.net, PICtail, PIC<sup>32</sup> logo, PowerCal, PowerInfo, PowerMate, PowerTool, REAL ICE, rfLAB, Select Mode, Total Endurance, 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.

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



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

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.