

# **MCP2505X**

## **Programming Specifications**

# This document includes the programming specifications for the following devices:

- MCP25050
- MCP25055

## 1.0 OVERVIEW

This specification describes the requirements to program a device. Programming is accomplished through a serial interface. A serial interface reduces the number of device pins that must be controlled and eases the application requirements for the device to be programmed while in the users system. This capability increases design flexibility, and is referred to as In-Circuit Serial Programming<sup>™</sup> (ICSP<sup>™</sup>).

## 1.1 Hardware Requirements

The MCP2505X requires two programmable power supplies, one for VDD (2.0V to 6.0V recommended) and one for VPP (12V to 14V). Both supplies should have a minimum resolution of 0.25V.

## 1.2 Programming Mode

The programming mode for the MCP2505X allows programming of user program memory and the configuration word.

## PACKAGE TYPES:



## 2.0 MCP2505X MEMORY

The MCP2505X has two memory spaces. The first is the User EPROM Memory. This memory stores the default configuration values for the device. The second memory space is the configuration memory. This contains the values for the device oscillator and reset pin configurations.

## 2.1 User EPROM Memory Map

The User EPROM memory space extends from 0x00 to 0x45. Table 2-1 shows this program memory map.

This User EPROM memory is offset within the device memory map. When programming the device, an offset to the addresses in Table 2-1 is required.

- Note 1: An offset of 0x10 is required to be added to the addresses shown in the User Program Memory Map (Table 2-1) when programming these locations. Therefore, there should be 16 Increment Address commands before programming the contents of the User EPROM Memory.
  - 2: Do not program outside the specified user EPROM memory range or improper operation may occur.

## 2.2 Configuration Memory

Configuration memory is accessed with the Load Configuration command. Once in configuration memory, the only way to access the User EPROM Memory is to reset the device and re-enter Programming mode, as described in Section 3.1. Only the lower 3 bits should be programmed. The remaining 11 bits are reserved and should be programmed as a '1'. Programming these bits as a '1' will ensure that the factory value is not modified. When verifying this location, only verify against the lower 3 bits (the bits that were programmed).

#### TABLE 2-1:USER EPROM MEMORY MAP

| Address<br>(1) | Location<br>Name | Address<br>(1) | Location<br>Name |
|----------------|------------------|----------------|------------------|
| 00h            | IOINTEN          | 23h            | TXID0EID0        |
| 01h            | IOINTPO          | 24h            | TXID1SIDH        |
| 02h            | GPLAT            | 25h            | TXID1SIDL        |
| 03h            | (2)              | 26h            | TXID1EID8        |
| 04h            | OPTREG1          | 27h            | TXID1EID0        |
| 05h            | T1CON            | 28h            | TXID2SIDH        |
| 06h            | T2CON            | 29h            | TXID2SIDL        |
| 07h            | PR1              | 2Ah            | TXID2EID8        |
| 08h            | PR2              | 2Bh            | TXID2EID0        |
| 09h            | PWM1DCH          | 2Ch            | ADCMP3H          |
| 0Ah            | PWM2DCH          | 2Dh            | ADCMP3L          |
| 0Bh            | CNF1             | 2Eh            | ADCMP2H          |
| 0Ch            | CNF2             | 2Fh            | ADCMP2L          |
| 0Dh            | CNF3             | 30h            | ADCMP1H          |
| 0Eh            | ADCON0           | 31h            | ADCMP1L          |
| 0Fh            | ADCON1           | 32h            | ADCMP0H          |
| 10h            | STCON            | 33h            | ADCMP0L          |
| 11h            | OPTREG2          | 34h            | GPDDR            |
| 12h            | (3)              | 35h            | USER0            |
| 13h            | (3)              | 36h            | USER1            |
| 14h            | RXMSIDH          | 37h            | USER2            |
| 15h            | RXMSIDL          | 38h            | USER3            |
| 16h            | RXMEID8          | 39h            | USER4            |
| 17h            | RXMEID0          | 3Ah            | USER5            |
| 18h            | RXF0SIDH         | 3Bh            | USER6            |
| 19h            | RXF0SIDL         | 3Ch            | USER7            |
| 1Ah            | RXF0EID8         | 3Dh            | USER8            |
| 1Bh            | RXF0EID0         | 3Eh            | USER9            |
| 1Ch            | RXF1SIDH         | 3Fh            | USERA            |
| 1Dh            | RXF1SIDL         | 40h            | USERB            |
| 1Eh            | RXF1EID8         | 41h            | USERC            |
| 1Fh            | RXF1EID0         | 42h            | USERD            |
| 20h            | <b>TXID0SIDH</b> | 43h            | USERE            |
| 21h            | TXID0SIDL        | 44h            | USERF            |
| 22h            | TXID0EID8        | 45h            | CHKSUM           |

Note 1: An offset of 0x10 is required.

- 2: Reserved, Program this location as 0x3FFF.
- **3:** Unimplemented, Program this location as 0x3FFF.

## 3.0 PROGRAMMING MODE ENTRY

A specific hardware sequence is required to force the device from the normal operating mode into Programming programming mode. After entering into the Programming mode, the 2-wire serial interface can be used to send the commands to the MCP2505X. These commands are discussed in Section 4.0.

## 3.1 Programming Entry Sequence

The Programming mode is entered by raising VDD. Then while holding the CLOCK and DATA pins (GP5 and GP4) low, raising the RST pin from VIL (Parameter PD8) to VIHH (Parameter PD4).

Once in this mode, the User EPROM memory and the configuration memory can be accessed (read and programmed). The interface is serial and the CLOCK pin (GP5) is a Schmitt Trigger input in this mode.

The sequence that forces the device into the Programming mode also puts all other logic into the reset state (the RST pin was initially at VIL). This means that all I/ O are in the reset state (High impedance inputs).

**Note 1:** Do not power any I/O pins before VDD is applied.

Figure 7-2 shows the waveform for entry into Programming mode.

## 3.2 Programming Operation

The CLOCK pin (GP5) is used as a clock input pin. The DATA pin (GP4) is used for entering command bits and data input/output during serial communication.

To input a command, the CLOCK pin (GP5) is cycled six times. Each command bit is latched on the falling edge of the clock with the least significant bit (LSb) of the command being input first. The data on the DATA pin (GP4) is required to have a minimum setup and hold time (see Parameter P3 and Parameter P4) with respect to the falling edge of the clock. Commands that have data associated with them (read and load) are specified to have a minimum delay between the command and the data (Parameter P6).

After this delay, the clock pin is cycled 16 times with the first cycle being a start bit and the last cycle being a stop bit. The data is input/output LSb first. During a read operation the LSb will be transmitted onto the DATA pin (GP4) on the rising edge of the second cycle, and during a load operation the LSb will be latched on the falling edge of the second cycle.

All commands and data words are transmitted LSb first. The DATA pin value is latched on the falling edge of the CLOCK pin. A minimum time between the command and the data word (or another command) is required. This separation time is shown in Parameter P6 of the Electrical Specification.

The commands that are available are listed in Table 4-1. The waveforms for these commands are shown in Figure 7-3 through Figure 7-8.

## 4.0 PROGRAMMING COMMANDS

There are six commands that the MCP2505X will execute when in Programming mode. These commands are shown in Table 4-1. Three of the commands have data that are required. The Load commands supply data to the MCP2505X, and the Read command retrieve data from the MCP2505X.

When the device enters into Programming mode, the address pointer is pointing to 0x00. The User Program Memory has an offset of 0x10. So before starting to program a desired location in the User Program Memory Map, the Increment Address command must be executed 16 times.

| Command               | Mapping<br>(MSb LSb) |   |   |   | • | ) | Data                        |  |  |
|-----------------------|----------------------|---|---|---|---|---|-----------------------------|--|--|
| Load<br>Configuration | 0                    | 0 | 0 | 0 | 0 | 0 | 0, data(14), 0              |  |  |
| Load Data             | 0                    | 0 | 0 | 0 | 1 | 0 | 0,1,1,0,1,0,0,<br>data(8),0 |  |  |
| Read Data             | 0                    | 0 | 0 | 1 | 0 | 0 | 0, <b>data(14)</b> , 0      |  |  |
| Increment<br>Address  | 0                    | 0 | 0 | 1 | 1 | 0 |                             |  |  |
| Begin<br>Programming  | 0                    | 0 | 1 | 0 | 0 | 0 |                             |  |  |
| End<br>Programming    | 0                    | 0 | 1 | 1 | 1 | 0 |                             |  |  |

TABLE 4-1:PROGRAMMINGCOMMANDS

## 4.1 Load Configuration

After receiving this command, the address pointer points to the Configuration memory space. To address the MCP250XX Configuration word the Increment command must be given seven times (see Figure 4-2). Then by applying 16 clock cycles to the CLOCK pin, a 14-bit "data word" will be loaded into the Transfer Latch (ready to be programmed into the configuration word, see Register 5-1). Only the lower 3 bits of the "data word" should be programmed. The remaining 11 bits of the "data word" are reserved and should be programmed as a '1'. Programming these bits as a '1' will ensure that the factory value is not modified. When verifying this location, only verify against the lower 3 bits (the bits that were programmed).

After the Load Configuration command is supplied, the only way to have the address pointer return to pointing at the User Program Memory is to exit the Programming mode. This is accomplished by taking the voltage on the  $\overrightarrow{RST}$  pin to a low level (VIL, Parameter PD8) and the re-entering into Programming mode (see Section 3.1).

Figure 7-3 shows the waveform for the Load Configuration command and Table 7-3 specifies the timing parameters that must be meet.

## 4.2 Load Data

After receiving this command, the chip will load in a 14-bit "data word" into the Transfer latch when 16 clock cycles are applied to the CLOCK pin.

Figure 7-4 shows the waveform for the Load Data command and Table 7-4 specifies the timing parameters that must be meet.

## 4.3 Read Data

After receiving this command (the first 6 bits), the device data word at the memory address currently accessed is loaded into the Transfer latch. Then as the Data is transmitted, the DATA (GP4) pin is automatically configured into an output on the second rising clock edge, and reverts back to an input (hi-impedance) after the 16th rising edge.

Figure 7-5 shows the waveform for the Read Data command and Table 7-5 specifies the timing parameters that must be meet.

This command is useful in the verify sequence of the programming algorithm. This is used to verify that if the value that was programmed at this location has been "well programmed". That is, that the memory cell was able to retain the value previously written. A memory verification should be done at the minimum and maximum voltage that the device will experience within the application.

## 4.4 Increment Address

The address pointer is incremented when this command is received.

Figure 7-6 shows the waveform for the Increment Address command and Table 7-6 specifies the timing parameters that must be meet.

## 4.5 Begin Programming

Programming of the appropriate memory (User Program Memory or Configuration Memory) will begin after this command is received and decoded. This programming pulse will continue until an End Programming command is received. Each programming pulse should meet a minimum time duration (Parameter P11 in Electrical Specification's Table 7-7).

| Note: | A load command (load configuration or |
|-------|---------------------------------------|
|       | load data) must be given before every |
|       | Begin Programming command.            |

Programming should be performed with a series of programming pulses (Parameter P11). A programming pulse is defined as the time between the Begin Programming command and the End Programming command.

Figure 7-7 shows the waveform for the Begin Programming command and Table 7-7 specifies the timing parameters that must be met.

Example 4-1 shows a typical command sequence that would be used in the over programming of a device.

| Step | Command           | Comment                                                           |
|------|-------------------|-------------------------------------------------------------------|
| 1    | Load Command      | ; Data or Configuration                                           |
| 2    | Begin Programming | ; Pulse #1<br>; Wait required delay                               |
| 3    | End Programming   |                                                                   |
| 4    | Load Command      | ; Data or Configuration                                           |
| 5    | Begin Programming | ; Pulse #2<br>; Wait required delay                               |
| 6    | End Programming   |                                                                   |
| :    | :                 | ; Repeat Load/Begin/<br>; End Programming<br>; sequence as needed |

#### EXAMPLE 4-1: Command Sequence

## 4.6 End Programming

After receiving this command, the chip stops programming the memory (configuration program memory or user program memory) that it was programming at the time.

Figure 7-8 shows the waveform for the End Programming command and Table 7-8 specifies the timing parameters that must be met.

## 4.7 Programming Algorithm Requires Variable VDD

The algorithm calls for program verification at VDDmin as well as VDDmax. Verification at VDDmin guarantees good "erase margin". Verification at VDDmax guarantees good "program margin".

The actual programming must be done with VDD in the VDDP range (Parameter PD1).

- VDDP = VDD range required during programming.
- VDDV = VDD range required during verification.
- VDDMIN = Minimum operating VDD specification for the device.
- VDDMAX = Maximum operating VDD specification for the device.

Programmers must verify the MCP2505X at its specified VDDMAX and VDDMIN levels. Since Microchip may introduce future versions of the MCP2505X with a broader VDD range, it is best that these levels are user selectable (defaults are ok).

Note: Any programmer not meeting these requirements may only be classified as "prototype" or "development" programmer but not a "production" quality programmer.







FIGURE 4-2: PROGRAM FLOW CHART - MCP2505X CONFIGURATION WORD

## 5.0 CONFIGURATION WORD

The MCP2505X family members have several configuration bits. These bits can be programmed (reads '0') or left unprogrammed (reads '1') to select various device configurations. Register 5-1 provides an overview of configuration bits. Only the lower 3 bits should be programmed. The remaining 11 bits are reserved and should be programmed as a '1'. Programming these bits as a '1' will ensure that the factory value is not modified.

## **REGISTER 5-1: CONFIGURATION REGISTER**

| _ | R-x    | R-x | R-x | R-x | R-x | R-x | R-x | R-x | R-x | R-x | R-x | R/P-1 | R/P-1 | R/P-1 |
|---|--------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------|-------|-------|
|   | Ι      | _   | —   | —   | _   | _   | _   | —   | —   | _   | —   | RSTEN | FOSC1 | FOSC0 |
|   | bit 13 |     |     |     |     |     |     |     |     |     |     |       |       | bit 0 |

- bit 13-3 Reserved: Read as 'x', Program as '1'.
- bit 2 **RSTEN:** Reset on GP7 Enable bit  $1 = \overline{RST}$  function is enabled on the GP7 I/O pin 0 = GP7 is a general purpose I/O pin
- bit 1-0 FOSC1:FOSC0: Oscillator Selection bits
  - 11 = RC oscillator
  - 10 = EC (External Clock)
  - 01 = XT oscillator
  - 00 = LP oscillator

#### Legend:

| Logona.                 |                      |                                    |
|-------------------------|----------------------|------------------------------------|
| R = Readable bit        | P = Programmable bit | U = Unimplemented bit, read as '0' |
| - n = Value when device | e is unprogrammed    | x = Unknown state                  |

## 6.0 MEMORY VERIFICATION

The User EPROM memory and configuration word is checksummed. This enhances the validation that the correct user's values are programmed into the devices memory.

## 6.1 Checksum Calculations

Checksum is calculated by reading the contents of the MCP2505X User EPROM memory locations and adding the values up. The entire User EPROM memory is read (00h - 45h). Any carry bits exceeding 16 bits are ignored. Finally, the configuration word (appropriately masked) is added to the checksum. Checksum computation for each member of the MCP2505X devices is shown in Table 6-1.

The checksum is calculated by summing the following:

- The contents of all User EPROM memory locations
- The configuration word, appropriately masked

The least significant 16 bits of this sum is the check-sum.

The Table 6-1 describes how to calculate the checksum. When calculating a checksum by reading a device, the entire User EPROM memory can be read and summed. The configuration word and ID locations can always be read.

## TABLE 6-1: CHECKSUM COMPUTATION

|          |                                     |              | Value                                                 |  |  |  |  |
|----------|-------------------------------------|--------------|-------------------------------------------------------|--|--|--|--|
| Device   | Checksum <sup>(1)</sup>             | Unprogrammed | When:<br>Addr. 0x000 = 0x25E6<br>Addr. 0x045 = 0x25E6 |  |  |  |  |
| MCP2505X | (SUM[0x000:0x045] + (CFGW & 0x07) ) | 0x7FC1       | 0x4B8F                                                |  |  |  |  |

Legend: SUM[a:b] = [Sum of locations a through b inclusive]

CFGW = Configuration Word

#### Note 1: Checksum = [Sum of all the individual expressions] MODULO [0xFFFF]

= Addition

+

&

## 7.0 PROGRAM/VERIFY MODE ELECTRICAL CHARACTERISTICS

## 7.1 DC Characteristics



#### FIGURE 7-1: PROGRAMMING DC CHARACTERISTICS WAVEFORMS

#### TABLE 7-1: DC CHARACTERISTICS FOR PROGRAMMING MODE (PROGRAM/VERIFY)

#### Standard Operating Conditions:

Operating Temperature:  $+10^{\circ}C \le TA \le +40^{\circ}C$ , unless otherwise stated, (25°C is recommended) Operating Voltage:  $4.5V \le VDD \le 5.5V$ , unless otherwise stated.

| Parameter<br>No. | Sym. | Character                                  | Min.                                            | Тур.    | Max.  | Units   | Conditions |                       |
|------------------|------|--------------------------------------------|-------------------------------------------------|---------|-------|---------|------------|-----------------------|
| PD1              | VDDP | Supply voltage during                      | programming                                     | 4.75    | 5.0   | 5.25    | V          | —                     |
| PD2              | Iddp | Supply current (from<br>during programming | Supply current (from VDD)<br>during programming |         |       | 20      | mA         |                       |
| PD3              | Vddv | Supply voltage during                      | y verify                                        | Vddmin  | —     | VDDmax  | V          | Note 1                |
| PD4              | Vihh | Voltage on MCLR/VPI<br>programming/verify  | 12.75                                           | -       | 13.25 | V       |            |                       |
| PD6              | IPP  | Programming supply<br>(from VPP)           | current                                         | _       | —     | 50      | mA         | —                     |
| PD8              | VIL  | Voltage input low                          | DATA (GP4)                                      | Vss     | —     | 0.2 Vdd | V          | Schmitt Trigger input |
|                  |      | level                                      | CLOCK (GP5)                                     | Vss     | —     | 0.2 Vdd | V          | Schmitt Trigger input |
|                  |      |                                            | RESET                                           | Vss     | —     | 0.2 Vdd | V          | —                     |
| PD9              | Vih  | Voltage input high                         | Voltage input high DATA (GP4)                   |         | _     | Vdd     | V          | Schmitt Trigger input |
|                  |      | level                                      | CLOCK (GP5)                                     | 0.8 Vdd | —     | Vdd     | V          | Schmitt Trigger input |
|                  |      |                                            | RESET                                           | 0.8 Vdd | —     | Vdd     | V          | —                     |

## 7.2 Timing (AC) Characteristics





#### TABLE 7-2: PROGRAMMING MODE ENTRY TIMING

| Parameter<br>No. | Symbol | Characteristic                                 | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------|------|------|------|-------|------------|
| P1               | TR     | RST/VPP rise time (VSS to VIHH)                | 0.15 | —    | 1.0  | μs    | —          |
| P2               | TF     | RST Fall time                                  | 0.5  | —    | 1.0  | μs    | —          |
| P8               | THLD0  | Hold time after VDD valid to VPP = VIHH        | 0    | —    |      | ns    | —          |
| P8A              | TPPDP  | Hold time after VPP = VIHH to CLOCK $\uparrow$ | 2    | —    | _    | μs    | —          |
| P8B              | THLD0  | Hold time after VDD valid to CLOCK $\uparrow$  | 2    | —    | —    | μs    |            |
| P9               | TCLOCK | CLOCK pin Period (in Time)                     | 250  | —    |      | ns    | —          |
| P9A              | FCLOCK | CLOCK pin Period (in Frequency)                | _    | —    | 4    | MHz   | —          |
| P10A             | TCLKH  | CLOCK pin High time                            | 100  | —    |      | ns    |            |
| P10B             | TCLKL  | CLOCK pin Low time                             | 100  | —    |      | ns    |            |



#### FIGURE 7-3: LOAD CONFIGURATION COMMAND WAVEFORM

#### **TABLE 7-3**: LOAD CONFIGURATION COMMAND TIMING

| Parameter<br>No. | Symbol | Characteristic                                                               | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------------------------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$                                 | 100  | _    |      | ns    | —          |
| P4               | THLD1  | Data in hold time after clock $\downarrow$                                   | 100  | _    | _    | ns    | —          |
| P6               |        | Delay between clock $\downarrow$ to clock $\uparrow$ of next command or data | 1.0  | -    |      | μs    |            |

## FIGURE 7-4: LOAD DATA COMMAND WAVEFORM



#### TABLE 7-4: LOAD DATA COMMAND TIMING

| Parameter<br>No. | Symbol | Characteristic                                                               | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------------------------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$                                 | 100  | —    | _    | ns    | —          |
| P4               | THLD1  | Data in hold time after clock $\downarrow$                                   | 100  | -    | _    | ns    | —          |
| P6               |        | Delay between clock $\downarrow$ to clock $\uparrow$ of next command or data | 1.0  | —    | _    | μs    | —          |

#### FIGURE 7-5: READ DATA COMMAND WAVEFORM



## TABLE 7-5: READ DATA COMMAND TIMING

| Parameter<br>No. | Symbol | Characteristic                                                                                             | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------------------------------------------------------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$                                                               | 100  |      | _    | ns    |            |
| P4               | THLD1  | Data in hold time after clock $\downarrow$                                                                 | 100  |      | —    | ns    | —          |
| P5               |        | Data input not driven to next clock<br>input (delay required between com-<br>mand/data or command/command) | 0.9  |      | _    | μs    |            |
| P6               |        | Delay between clock $\downarrow$ to clock $\uparrow$ of next command or data                               | 1.0  | _    | —    | μs    |            |
| P7               | TDLY3  | Clock ↑ to data out valid<br>(during read data)                                                            | _    | _    | 200  | ns    |            |





#### TABLE 7-6: INCREMENT ADDRESS TIMING

| Parameter<br>No. | Symbol | Characteristic                                                               | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------------------------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$                                 | 100  | —    | _    | ns    | —          |
| P4               | THLD1  | Data in hold time after clock $\downarrow$                                   | 100  | _    | _    | ns    | —          |
| P6               |        | Delay between clock $\downarrow$ to clock $\uparrow$ of next command or data | 1.0  | _    | _    | μs    |            |

## FIGURE 7-7: BEGIN PROGRAMMING COMMAND WAVEFORM



## TABLE 7-7: BEGIN PROGRAMMING COMMAND TIMING

| Parameter<br>No. | Symbol | Characteristic                               |                      | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|----------------------------------------------|----------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$ |                      | 100  |      |      | ns    | _          |
| P4               | THLD1  | Data in hold time after clock $\downarrow$   |                      | 100  | _    | _    | ns    | _          |
| P11              |        | Programming Pulse Width                      | User Memory          | 90   | 100  | 110  | μs    | _          |
|                  |        |                                              | Configuration Memory | 90   | 100  | 110  | μs    | _          |





## TABLE 7-8: END PROGRAMMING COMMAND TIMING

| Parameter<br>No. | Symbol | Characteristic                                                               |                      | Min. | Тур. | Max. | Units | Conditions |
|------------------|--------|------------------------------------------------------------------------------|----------------------|------|------|------|-------|------------|
| P3               | TSET1  | Data in setup time before clock $\downarrow$                                 |                      | 100  | —    | —    | ns    | —          |
| P4               | THLD1  | Data in hold time after clock $\downarrow$                                   |                      | 100  | _    | _    | ns    | —          |
| P6               |        | Delay between clock $\downarrow$ to clock $\uparrow$ of next command or data |                      | 1.0  |      |      | μs    | —          |
| P11              |        | Programming Pulse Width <sup>(1)</sup>                                       | User Memory          | 90   | 100  | 110  | μs    | —          |
|                  |        |                                                                              | Configuration Memory | 90   | 100  | 110  | μs    |            |

Note 1: Only required if the previous command was the Begin Programming Command.

NOTES:

"All rights reserved. Copyright © 2001, Microchip Technology Incorporated, USA. Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. in the U.S.A. and other countries. All rights reserved. All other trademarks mentioned herein are the property of their respective companies. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights."

#### Trademarks

The Microchip name, logo, PIC, PICmicro, PICMASTER, PICSTART, PRO MATE, KEELOQ, SEEVAL, MPLAB and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

Total Endurance, ICSP, In-Circuit Serial Programming, FilterLab, MXDEV, microID, FlexROM, fuzzyLAB, MPASM, MPLINK, MPLIB, PICDEM, ICEPIC, Migratable Memory, FanSense, ECONOMONITOR, SelectMode and microPort are trademarks of Microchip Technology Incorporated in the U.S.A.

Serialized Quick Term Programming (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.

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



Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro<sup>®</sup> 8-bit MCUs, KEELoo<sup>®</sup> code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 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: 480-792-7627 Web Address: http://www.microchip.com

Rocky Mountain 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456

Atlanta 500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307 Austin

Analog Product Sales 8303 MoPac Expressway North Suite A-201 Austin, TX 78759 Tel: 512-345-2030 Fax: 512-345-6085

Boston 2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821

Boston Analog Product Sales Unit A-8-1 Millbrook Tarry Condominium 97 Lowell Road Concord, MA 01742

Tel: 978-371-6400 Fax: 978-371-0050 Chicago 333 Pierce Road, Suite 180

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

Dallas

4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924

**Dayton** Two Prestige Place, Suite 130 Miamisburg, OH 45342 Tel: 937-291-1654 Fax: 937-291-9175

Detroit Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260

Los Angeles 18201 Von Karman, Suite 1090 Irvine, CA 92612

Tel: 949-263-1888 Fax: 949-263-1338 Mountain View

Analog Product Sales 1300 Terra Bella Avenue Mountain View, CA 94043-1836 Tel: 650-968-9241 Fax: 650-967-1590

#### New York

150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335 **San Jose** Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955 **Toronto** 

6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509

#### ASIA/PACIFIC

Australia Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia Tel: 61-2-9868-6733 Fax: 61-2-9868-6755 China - Beijing Microchip Technology Beijing Office Unit 915 New China Hong Kong Manhattan Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104 China - Shanghai Microchip Technology Shanghai Office Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060 Hong Kong Microchip Asia Pacific RM 2101, Tower 2, Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431 India Microchip Technology Inc. India Liaison Office **Divyasree Chambers** 1 Floor, Wing A (A3/A4) No. 11, O'Shaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062 Japan Microchip Technology Intl. Inc. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122

#### ASIA/PACIFIC (continued)

Korea

Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea Tel: 82-2-554-7200 Fax: 82-2-558-5934 Singapore Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-334-8870 Fax: 65-334-8850 Taiwan Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

#### EUROPE

#### Denmark

Microchip Technology Denmark ApS **Regus Business Centre** Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910 France Arizona Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79 **Germany** Arizona Microchip Technology GmbH Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44 Germany Analog Product Sales Lochhamer Strasse 13 D-82152 Martinsried, Germany Tel: 49-89-895650-0 Fax: 49-89-895650-22 Italv Arizona Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883 United Kingdom Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820

01/30/01

All rights reserved. © 2001 Microchip Technology Incorporated. Printed in the USA. 3/01

Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchip's products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, except as maybe explicitly expressed herein, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. in the U.S.A. and other countries. All rights reserved. All other trademarks mentioned herein are the property of their respective companies.