

## **AN1920**

# **Microchip LAN9252 EEPROM Configuration and Programming**

Author: Kansal Mariam Banu Shaick Ibrahim Microchip Technology Inc.

#### 1.0 INTRODUCTION

The Microchip LAN9252 is a 2/3-port EtherCAT<sup>®</sup> Slave Controller (ESC) with dual integrated Ethernet PHYs. The LAN9252 is typically implemented in Industrial Automation solutions and includes the following main features:

- Integrated high-performance 100Mbps Ethernet transceivers
- 3 FMMUs, 4 SyncManagers, Distributed clock support, 4K bytes of DPRAM
- 8/16-bit host bus interface allowing connection to most 8/16/32-bit embedded controllers
- · SPI / SQI slave interface
- Support for 5 different main configurations:
  - Digital I/O (DIGIO)
  - HBI
  - SPI with GPIO
  - SPI with MII 3-port (MII upstream) mode
  - SPI with MII 3-port (MII downstream) mode
- · 3rd port for flexible network configurations
- Comprehensive power management features
- · Low pin count and small package size

The purpose of this document is to provide details on the various LAN9252 EEPROM configuration and programming options when using the EVB-LAN9252-HBIPLUS and EVB-LAN9252-DIGIO evaluation boards.

#### 1.1 Software Requirements

- Latest version of Beckhoff EtherCAT<sup>®</sup> Slave Stack Tool and required ESI file
- XML Notepad
- LAN9252 ESC configuration data config.xls

#### 1.2 References

- · Microchip LAN9252 Data Sheet
- Microchip EVB-LAN9252-HBIPLUS Evaluation Board User's Guide
- Microchip EVB-LAN9252-DIGIO Evaluation Board User's Guide
- Beckhoff ET1100 Data Sheet

#### 1.3 Terms and Abbreviations

TABLE 1-1: TERMS AND ABBREVIATIONS

| Term | Definition                         |  |
|------|------------------------------------|--|
| DA   | Destination Address                |  |
| ESC  | EtherCAT® Slave Controller         |  |
| EDPD | Energy Detect Power Down           |  |
| EVB  | Engineering Validation Board       |  |
| НВІ  | Host Bus Interface                 |  |
| IDE  | Integrated Development Environment |  |
| SPI  | Serial Protocol Interface          |  |
| SSC  | Slave Stack Code                   |  |

#### 2.0 EEPROM CONFIGURATION

A summary of the LAN9252 ESC registers in EEPROM is shown in Table 2-1. The following list details the sample configurations that can be programed into EEPROM using the ESI files provided along with the LAN9252 EtherCAT<sup>®</sup> SDK. Refer to the corresponding register definitions in LAN9252 Data Sheet for details on each bit function.

#### Sample configuration for simple ESC (DIGIO mode):

- DIGIO 8 Inputs, 8 Outputs
- DIGIO 16 Bidirectional

#### Sample configuration for complex ESC (HBI and SPI mode):

- HBI
  - HBI Indexed 16-Bit Mode
  - HBI Indexed 8-Bit Mode
  - HBI Multiplexed 16-Bit Dual Phase Mode
  - HBI Multiplexed 8-Bit Dual Phase Mode
  - HBI Multiplexed 16-Bit Single Phase Mode
  - HBI Multiplexed 8-Bit Single Phase Mode
- SPI
  - SPI 2-Port Mode

TABLE 2-1: ESC EEPROM CONFIGURABLE REGISTERS

| Register                                   | Bits                                                                   | EEPROM<br>Word / [Bits] |
|--------------------------------------------|------------------------------------------------------------------------|-------------------------|
| BYTE 0 PDI Control Register (0x0140)       | [7:0] Process Data Interface                                           | 0 / [7:0]               |
|                                            | [7] Unused                                                             | 0 / [15]                |
|                                            | [6] Enhanced Link Port 2                                               | 0 / [14]                |
|                                            | [5] Enhanced Link Port 1                                               | 0 / [13]                |
|                                            | [4] Enhanced Link Port 0                                               | 0 / [12]                |
| BYTE 1 ESC Configuration Register (0x0141) | [3] Distributed clocks Latch In Unit  Note: Bit 3 is not set by EEPROM | -                       |
| (0.0141)                                   | [2] Distributed clocks SYNC Out Unit  Note: Bit 2 is not set by EEPROM | -                       |
|                                            | [1] Enhanced Link Detection All Ports                                  | 0 / [9]                 |
|                                            | [0] Device Emulation                                                   | 0 / [8]                 |
|                                            | [7:6] Output Data Sample Collection                                    | 1 / [7:6]               |
| BYTE 2                                     | [5:4] Input Data Sample Selection                                      | 1 / [5:4]               |
| PDI Configuration Register                 | [3] Watchdog Behavior                                                  | 1 / [3]                 |
| (0x0150)                                   | [2] Unidirectional / Bidirectional Mode                                | 1 / [2]                 |
| Digital I/O Mode                           | [1] OUTVALID Mode                                                      | 1 / [1]                 |
|                                            | [0] OUTVALID Polarity                                                  | 1 / [0]                 |

TABLE 2-1: ESC EEPROM CONFIGURABLE REGISTERS (CONTINUED)

| Register                                                                     | Bits                                    | EEPROM<br>Word / [Bits] |
|------------------------------------------------------------------------------|-----------------------------------------|-------------------------|
|                                                                              | [7] HBI ALE Qualification               | 1 / [7]                 |
|                                                                              | [6] HBI Read/Write Mode                 | 1 / [6]                 |
| PDI Configuration Register                                                   | [5] HBI Chip Select Polarity            | 1 / [5]                 |
| (0x0150)                                                                     | [4] HBI Read, Read/Write Polarity       | 1 / [4]                 |
| HBI Mode                                                                     | [3] HBI Write, Enable Polarity          | 1 / [3]                 |
|                                                                              | [2] HBI ALE Polarity                    | 1 / [2]                 |
|                                                                              | [1:0] Reserved                          | 1 / [1:0]               |
|                                                                              | [7] SYNC1 Map                           | 1 / [15]                |
|                                                                              | [6] SYNC1/LATCH1 Configuration          | 1 / [14]                |
| BYTE 3                                                                       | [5:4] SYNC1 Output Driver / Polarity    | 1 / [13:12]             |
| Sync/Latch PDI Configuration Register (0x0151)                               | [3] SYNC0 Map                           | 1 / [11]                |
| (0,0101)                                                                     | [2] SYNC0 / LATCH0 Configuration        | 1 / [10]                |
|                                                                              | [1:0] SYNC0 Output Driver / Polarity    | 1 / [9:8]               |
| BYTE 4 & 5 Pulse Length of SyncSignals Register (0x0983 : 0x0982)            | [15:0] Pulse Length of SyncSignals      | 2 / [15:0]              |
| BYTE 6 & 7                                                                   | [15:8] Reserved                         | 3 / [15:8]              |
| Extended PDI Configuration Register<br>(0x0153 : 0x0152)<br>Digital I/O Mode | [7:0] I/O 15-0 Direction                | 3 / [7:0]               |
| Extended PDI Configuration Register                                          | [15:8] I/O 15-0 Buffer Type             | 3 / [15:8]              |
| (0x0153 : 0x0152)<br>SPI Mode                                                | [7:0] I/O 15-0 Direction                | 3 / [7:0]               |
| BYTE 8 & 9 Configures Station Alias Register (0x0013 : 0x0012)               | [15:0] Configures Station Alias Address | 4 / [15:0]              |
| BYTE 10 & 11  MII Management Control/Status Register (0x0511 : 0x0510)       | [2] MII Link Detection                  | 5 / [15]                |
|                                                                              | [15] MII Link Detection                 |                         |
| ASIC Configuration Register                                                  | [14:8] RESERVED                         | 5 / [14:8]              |
| (0x0143 : 0x0142)                                                            | [7] MII Write Gigabit Register 9 Enable | 5 / [7]                 |
|                                                                              | [6:0] RESERVED                          | 5 / [6:0]               |
| BYTE 12 & 13 Reserved Register (0x0145 : 0x0144)                             | [15:0] RESERVED                         | 6 / [15:0]              |

Note: Refer to the LAN9252 Data Sheet for detailed descriptions of the registers listed in Table 2-1.

#### 3.0 EEPROM CONFIGURATION FOR DIGIO

First, 16 bytes of EEPROM is the configuration straps for LAN9252. Each bit present in the configuration area is directly mapped with EtherCAT core registers.

#### 3.1 Byte 0

| EEPROM<br>Offset- 0 | EtherCAT Core<br>Register | Details                      | Note |
|---------------------|---------------------------|------------------------------|------|
| 0[0:7]              | 0x0140                    | [7:0] Process Data Interface |      |

Byte zero of EEPROM (register 0x140) defines the PDI type to be used. It must be 0x04 for DIGIO.

#### 3.2 Byte 1

| EEPROM<br>Offset- 1 | EtherCAT Core<br>Register | Details                                                                   | Note                                      |
|---------------------|---------------------------|---------------------------------------------------------------------------|-------------------------------------------|
| 1[7]                | 0x0141[7]                 | [7] Unused                                                                |                                           |
| 1[6]                | 0x0141[6]                 | [6] Enhanced link port 2                                                  |                                           |
| 1[5]                | 0x0141[5]                 | [5] Enhanced link port 1                                                  |                                           |
| 1[4]                | 0x0141[4]                 | [4] Enhanced link port 0                                                  |                                           |
| 1[[3:2]             | 0x0141[3:2]               | [3] Distributed Clocks Latch in Unit [2] Distributed Clocks SYNC Out Unit | Bits 2 and 3 are<br>NOT set by<br>EEPROM. |
| 1[1]                | 0x0141[1]                 | [1] Enhanced link detection on all ports                                  |                                           |
| 1[0]                | 0x0141[0]                 | [0] Device emulation                                                      |                                           |

Byte one of EEPROM defines the device emulation for the slave and enhance link detection for each port

**Device emulation-** If this bit is set, then LAN9252 handles the AL state machine (no need for a microcontroller). This bit must be set for DIGIO.

**Enhance link detection** – Both normal and Enhance link detection detects the link establishment. However, if enhance link detection bit set then EtherCAT Core will disconnect a link if at least 32 RX errors (RX\_ER) occur in a fixed interval of time (~10 us) and the link partner is informed by restarting the Auto-Negotiation mechanism via the MII Management. So, the link partner can close that particular port. Register 0x0110:0x0111 shows the status of MII\_LINK and 0x0518:0x051B shows the link detection status updated via MII management interface.

Enhance link detection can be enabled either to all or individual ports.

#### 3.3 Byte 2

Byte two of EEPROM (register 0x150) configures the PDI. In case of DIGIO, it configures method for input output sampling, watchdog behavior, uni-direction or bi-direction and OUTVALID pin.

| EEPROM<br>Offset- 2 | EtherCAT Core<br>Register | Details                                                                                                                                                                                    | Note |
|---------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 2[7:6]              | 0x0150[7:6]               | Output Data Sample Selection                                                                                                                                                               |      |
|                     |                           | 00: End a Frame 01: RESERVED 10: DC SYNC0 event 11: DC SYNC1 event                                                                                                                         |      |
|                     |                           | Note: If OUTVALID Mode = 1, output DATA is updated at Process Data Watchdog trigger event (Output Data Sample Selection bits ignored).                                                     |      |
| 2[5:4]              | 0x0150[5:4]               | Input Data Sample Selection                                                                                                                                                                |      |
|                     |                           | 00: Start of Frame 01: Rising edge of LATCH_IN 10: DC SYNC0 event 11: DC SYNC1 event                                                                                                       |      |
| 2[3]                | 0x0150[3]                 | Watchdog Behavior                                                                                                                                                                          |      |
|                     |                           | O: Outputs are reset immediately after watchdog expires.     Outputs are reset with next output event that follows watchdog expiration.                                                    |      |
| 2[2]                | 0x0150[2]                 | Unidirectional/Bidirectional Mode                                                                                                                                                          |      |
|                     |                           | O: Unidirectional Mode: input/output direction of pins configured individually.  1: Bidirectional Mode: all I/O pins are bidirectional.                                                    |      |
| 2[1]                | 0x0150[1]                 | If this bit is set, then each DIGIO pin is configured as input and output simultaneously. However, byte 6[7:0] (register 0x01523) must be set to the input direction (0x00).               |      |
|                     |                           | O: Output event signaling     Process Data Watchdog trigger (WD_TRIG) signaling on OUTVALID. Output data is updated if watchdog is triggered. Overrides Output Data Sample Selection bits. |      |
| 2[0]                | 0x0150[0]                 | OUTVALID Polarity                                                                                                                                                                          |      |
|                     |                           | 0: Active high<br>1: Active low                                                                                                                                                            |      |

#### 3.3.1 OUTPUT DATA SAMPLE SELECTION

- 1. EOF mode Digital Outputs are updated at the end of each EtherCAT frame.
- 2. DC SYNC0 mode Digital outputs are updated with Distributed Clocks SYNC0 events.
- 3. DC SYNC1 mode Digital outputs are updated with Distributed Clocks SYNC1 events.
- 4. WD\_TRIG mode Digital Outputs are updated at the end of an EtherCAT frame which triggered the Process Data Watchdog (with typical SyncManager configuration: a frame containing write access to at least one of the registers 0x0F00:0x0F01). Digital Outputs are only updated if the EtherCAT frame was correct.

#### 3.3.2 INPUT DATA SAMPLE SELECTION

Digital inputs can be configured by four ways:

- Start of Frame Digital inputs are sampled at the start of each Ethernet frame, so that EtherCAT read commands
  to address 0x1000:0x1001 will present digital input values sampled at the start of the same frame. The SOF signal can be used externally to update the input data because the SOF is signaled before input data is sampled.
- 2. **Rising edge of LATCH\_IN** The sample time can be controlled externally by using the LATCH\_IN signal. The input data is sampled by the ESC each time a rising edge of LATCH\_IN is recognized.
- 3. DC SYNC0 event Digital inputs are sampled at Distributed Clocks SYNC0 events.
- 4. DC SYNC1 event Digital inputs are sampled at Distributed Clocks SYNC1 events.

#### 3.3.3 WATCHDOG BEHAVIOR

This bit controls whether output needs to be reset on a watchdog reset. If it is zero, then the output resets if watchdog expires. If it set to one, outputs are reset with next output event that follows watchdog expiration. Watchdog expires on failure to update the process data. That is, if the application demands the output to remain the same even the link drops, then this bit should be set. In this scenario, the OE\_EXT signal can reset the DIGIOs externally.

#### 3.3.4 UNIDIRECTIONAL/BIDIRECTIONAL MODE

If this bit is set, then each DIGIO pin is configured as input and output simultaneously. However, byte 6[7:0] (register 0x01523) must be set to the input direction (0x00).

#### 3.3.5 OUTVALID MODE

Output of DIGIO signals can either be controlled internally or externally.

If this bit is ZERO, then a pulse on OUTVALID signal indicates the status of DIGIO output. If watchdog expires then the output resets internally.

If this bit is set, then Process Data Watchdog trigger (WD\_TRIG) signaling on OUTVALID pin. Output data is updated if watchdog is triggered, overrides 0x0150[7:6]. The output can be controlled by OE\_EXT signal by the external controller.

#### 3.3.6 OUTVALID POLARITY

This bit defines the polarity of the OUTVALID pin whether it is an active high or low.

#### 3.4 Byte 3

| EEPROM<br>Offset- 3 | EtherCAT Core<br>Register | Detail                                | Note                                                                                                                                                        |
|---------------------|---------------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3[7]                | 0x0151[7]                 | [7] SYNC1 Map                         | SYNC1 mapped to AL Event Request register 0x0220[3] 0: Disabled 1: Enabled                                                                                  |
| 3[6]                | 0x0151[6]                 | [6] SYNC1/LATCH1 Configuration        | To select SYNC1 or LATCH1 functionality 0: LATCH1 Input 1: SYNC1 Output                                                                                     |
| 3[5:4]              | 0x0151[5:4]               | [5:4] SYNC1 Output<br>Driver polarity | It configures the polarity of the SYNC1 signal 00: Push-Pull active low 01: Open Drain (active low) 10: Push-Pull active high 11: Open Source (active high) |
| 3[3]                | 0x0151[3]                 | [3] SYNC0 Map                         | SYNC0 mapped to AL Event Request register 0x0220[2] 0: Disabled 1: Enabled                                                                                  |
| 3[2]                | 0x0151[2]                 | [2] SYNC0/LATCH0 Configuration        | To select SYNC0 or LATCH0 functionality 0: LATCH0 Input 1: SYNC0 Output                                                                                     |

| EEPROM<br>Offset- 3 | EtherCAT Core<br>Register | Detail                                | Note                                                                                                                                                        |
|---------------------|---------------------------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3[1:0]              | 0x0151[1:0]               | [1:0] SYNC0 Output<br>Driver polarity | It configures the polarity of the SYNC0 signal 00: Push-Pull active low 01: Open Drain (active low) 10: Push-Pull active high 11: Open Source (active high) |

If DIGIO supports DC, then configure the bits as per the application.

#### 3.5 Byte 4-5

Pulse Length of SyncSignals Register - (0x0982-0x0983)

| EEPROM<br>Offset- 4:5 | EtherCAT Core<br>Register | Details                            | Note                                                                                            |
|-----------------------|---------------------------|------------------------------------|-------------------------------------------------------------------------------------------------|
| 4-5[15:0]             | 0x0982-<br>0x0983[15:0]   | [15:0] Pulse length of SyncSignals | Pulse length of SyncSignals<br>(in units of 10ns)<br>A value of 0 is used for Acknowledge Mode. |

If DIGIO supports DC, then configure the bits as per the application. Pulse length should be less than the cycle time for periodic updates.

#### 3.6 Byte 6-7

Extended PDI Configuration Register - (0x0152-0x0153)

| EEPROM<br>Offset- 5:6 | EtherCAT Core<br>Register | Details                  | Note                                                                                                                          |
|-----------------------|---------------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 6[7:0]                | 0x0152                    | [7:0] I/O 15-0 Direction | Digital I/Os are configured in pairs as inputs or outputs: 0: Input 1: Output Note: Reserved in bidirectional mode, set to 0. |
| 7[7:0]                | 0x0153                    | [7:0] RESERVED           |                                                                                                                               |

#### 3.7 Byte 8-9

| EEPROM<br>Offset- [7:8] | EtherCAT Core<br>Register | Details                                    | Note                                                                                                                                                                         |
|-------------------------|---------------------------|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8[7:0]- 9[7:0]          | 0x0012-0x0013             | [15:0] Configured Station<br>Alias Address | This field contains the alias address used for node addressing (FPxx commands). More details about different addressing are available at ETG1000 and ETG1020 specifications. |

For DIGIO, this register should be updated as per application requirement.

#### 3.8 BYTE 10

For DIGIO, byte 10 should be set as zero.

#### 3.9 Byte 11

Bit  $8^{\text{th}}$  of Byte 11 should be set as 1 for MII\_LINK detection.

#### 4.0 EEPROM PROGRAMMING

This section details the EEPROM programming procedure using ESI files.

#### 4.1 EtherCAT® Slave Stack Code Tool Installation

- The first step to EEPROM programming is to download and install the Beckhoff EtherCAT<sup>®</sup> Slave Stack Code (SSC) tool. Download the EtherCAT<sup>®</sup> SSC from the following link: http://www.ethercat.org/login.aspx?ReturnUrl=%2fmemberarea%2fstack\_code.aspx
- 2. To continue the download process, enter the ETG user name and password.

FIGURE 4-1: MEMBER AREA LOGIN



3. Enter the Vendor ID, if prompted, and click the "Submit Registration" button, as shown in Figure 4-2.

#### FIGURE 4-2: VENDOR ID SUBMISSION



### **AN1920**

- 4. Enter the required details, check the "Accept" box and click "Register."
- A download link will be sent to the registered email address. Click the emailed download link to download the EtherCAT<sup>®</sup> Slave Stack Code.

#### FIGURE 4-3: SLAVE STACK CODE DOWNLOAD



6. Extract the downloaded .zip file "SSC\_V5i11", which will contain the directory structure shown in Figure 4-4.

#### FIGURE 4-4: SLAVE STACK CODE DIRECTORY STRUCTURE



7. Install the EtherCAT<sup>®</sup> Slave Stack Code Tool. Once installation is complete, ensure the tools shown in Figure 4-5 are seen in the Start Menu.

#### FIGURE 4-5: SLAVE STACK CODE TOOLS



**Note:** Ensure the LAN9252 evaluation board is configured for the ESC configuration which is going to be programmed.

#### 4.2 Simple ESC EEPROM Programming (PDI Configured in DIGIO Mode)

- 1. To program the EEPROM, launch the previously installed EEPROM Programmer utility from the Start Menu.
- 2. Load the required ESI file (all ESI files are provided along with the SDK).
- 3. Connect the LAN9252 evaluation board to the system's Ethernet port using an Ethernet cable.
- 4. Scan for slave devices. If the EtherCAT<sup>®</sup> slave device is detected, the window will appear as shown in Figure 4-6.

#### FIGURE 4-6: EEPROM PROGRAMMER SLAVE DEVICE SCAN



- 5. Choose the required configuration in the "Device Description" field.
- 6. Select the "Program" option under the "Slave" drop-down menu. When programming is complete, the window will appear as shown in Figure 4-7.

#### FIGURE 4-7: EEPROM PROGRAMMER COMPLETE



If the user desires to reconfigure the ESC configuration data with additional options, the ESI file can be edited using an XML editor such as XML Notepad, as shown in Figure 4-8. The user may edit the following fields:

- EtherCAT<sup>®</sup> Slave Controller Configuration Area
- Vendor ID
- Product Code
- · Revision Number
- · Serial Number

## FIGURE 4-8: ESI FILE EDITING IN XML NOTEPAD



**Note:** For easy reconfiguration of ESC data, the ESC configuration config.xls can be used, which is supplied with the EtherCAT<sup>®</sup> SDK.

#### 4.3 Complex ESC EEPROM Programming (PDI Configured in HBI/SPI Mode)

For complex ESC programming where the PDI is configured in HBI or SPI mode, the EEPROM content can be programmed using the ESI file as detailed in Section 4.2, "Simple ESC EEPROM Programming (PDI Configured in DIGIO Mode)". However, if reconfiguration is required, then the following additional steps must first be executed:

- Launch the Beckhoff SSC Tool and open the project file generated during the SSC to SDK integration process.
   Once opened, the Slave Information and ESC Configuration Data can be edited using the tool as shown in Figure 4-9 and Figure 4-10.
- 2. After reconfiguration, create new ESI files by using the "Create New Slave Files" option under the "Projects" dropdown menu. Doing so will create a new folder names "Src" in the desired location. This folder will contain the updated ESI file.
- 3. Use the generated ESI file to program the EEPROM using the EEPROM Programmer utility as previously detailed in Section 4.2, "Simple ESC EEPROM Programming (PDI Configured in DIGIO Mode)".

#### FIGURE 4-9: SSC TOOL SLAVE INFORMATION



#### FIGURE 4-10: SSC TOOL HARDWARE DATA



#### 4.4 **EEPROM Mass Programming**

In cases where gang programming of EEPROM is required without using the EEPROM Programmer tool, a .bin file can be generated from the ESI files using the EEPROM Programmer tool "Save As..." option, as detailed below:

- 1. Load the required ESI file into the EEPROM Programmer tool.
- 2. Select "Save As..." from the "File" drop-down menu, as shown in Figure 4-11.
- 3. Save the file as a ".bin" file.

Once the .bin file is created, it can be used with USB-I2C adapters, such as Aardvark, to program the EEPROMs directly.

#### FIGURE 4-11: EEPROM PROGRAMMER "SAVE AS" OPTION



## **AN1920**

#### APPENDIX A: APPLICATION NOTE REVISION HISTORY

TABLE A-1: REVISION HISTORY

| Revision Level & Date  | Section/Figure/Entry                              | Correction                                                                                              |
|------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| DS00001920B (03-26-19) | Section 3.3, "Byte 2"                             | Unidirectional/Bidirectional Mode modified.                                                             |
|                        | Table 2-1, "ESC EEPROM<br>Configurable Registers" | Table updated: BYTE 3 - "[6]SYNC/LATCH1 Configuration" changed to "[6]SYNC1/LATCH1 Configuration"       |
|                        | Section 1.0, "Introduction"                       | "EVB-LAN9252-HBI" changed to "EVB-LAN9252-HBIPLUS".                                                     |
|                        |                                                   | "SPI with MII - 4-port (MII downstream) mode" changed to "SPI with MII - 3-port (MII downstream) mode". |
|                        | Section 3.0, "EEPROM Configuration for DIGIO"     | Section added.                                                                                          |
| DS00001920A (04-14-15) | Document Release                                  |                                                                                                         |

#### 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 unless otherwise stated.

#### **Trademarks**

The Microchip name and logo, the Microchip logo, AnyRate, AVR, AVR logo, AVR Freaks, BitCloud, chipKIT, chipKIT logo, CryptoMemory, CryptoRF, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KeeLoq, Kleer, LANCheck, LINK MD, maXStylus, maXTouch, MediaLB, megaAVR, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, Prochip Designer, QTouch, SAM-BA, SpyNIC, SST, SST Logo, SuperFlash, tinyAVR, UNI/O, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, EtherSynch, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and Quiet-Wire are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, Anyln, AnyOut, BodyCom, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, INICnet, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, memBrain, Mindi, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, SAM-ICE, Serial Quad I/O, SMART-I.S., SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, 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.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

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

© 2015-2019, Microchip Technology Incorporated, All Rights Reserved.

ISBN: 9781522441946

# QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV = ISO/TS 16949=

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



#### Worldwide Sales and Service

#### **AMERICAS**

Corporate Office 2355 West Chandler Blvd.

Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support:

http://www.microchip.com/

support Web Address:

www.microchip.com

**Atlanta** Duluth, GA

Tel: 678-957-9614 Fax: 678-957-1455

**Austin, TX** Tel: 512-257-3370

**Boston** 

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

Chicago Itasca, IL

Tel: 630-285-0071 Fax: 630-285-0075

Dallas

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

**Detroit** Novi, MI

Tel: 248-848-4000

Houston, TX

Tel: 281-894-5983 Indianapolis

Noblesville, IN Tel: 317-773-8323 Fax: 317-773-5453 Tel: 317-536-2380

Los Angeles

Mission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608 Tel: 951-273-7800

Raleigh, NC Tel: 919-844-7510

New York, NY Tel: 631-435-6000

**San Jose, CA** Tel: 408-735-9110 Tel: 408-436-4270

**Canada - Toronto** Tel: 905-695-1980 Fax: 905-695-2078

#### ASIA/PACIFIC

Australia - Sydney Tel: 61-2-9868-6733

**China - Beijing** Tel: 86-10-8569-7000

China - Chengdu

Tel: 86-28-8665-5511

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

**China - Dongguan** Tel: 86-769-8702-9880

**China - Guangzhou** Tel: 86-20-8755-8029

China - Hangzhou Tel: 86-571-8792-8115

China - Hong Kong SAR Tel: 852-2943-5100

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

China - Qingdao Tel: 86-532-8502-7355

**China - Shanghai** Tel: 86-21-3326-8000

China - Shenyang

Tel: 86-24-2334-2829

**China - Shenzhen** Tel: 86-755-8864-2200

**China - Suzhou** Tel: 86-186-6233-1526

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

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

China - Xiamen
Tel: 86-592-2388138

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

#### ASIA/PACIFIC

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

India - New Delhi

Tel: 91-11-4160-8631

India - Pune

Tel: 91-20-4121-0141

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

Japan - Tokyo

Tel: 81-3-6880- 3770

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

Korea - Seoul

Tel: 82-2-554-7200

Malaysia - Kuala Lumpur Tel: 60-3-7651-7906

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

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

Singapore

Tel: 65-6334-8870

**Taiwan - Hsin Chu** Tel: 886-3-577-8366

Taiwan - Kaohsiung Tel: 886-7-213-7830

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

Thailand - Bangkok Tel: 66-2-694-1351

Vietnam - Ho Chi Minh Tel: 84-28-5448-2100

#### **EUROPE**

Austria - Wels

Tel: 43-7242-2244-39 Fax: 43-7242-2244-393

Denmark - Copenhagen Tel: 45-4450-2828

Fax: 45-4485-2829

Finland - Espoo Tel: 358-9-4520-820

France - Paris

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

Germany - Garching Tel: 49-8931-9700

**Germany - Haan** Tel: 49-2129-3766400

**Germany - Heilbronn** Tel: 49-7131-67-3636

Germany - Karlsruhe Tel: 49-721-625370

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

**Germany - Rosenheim** Tel: 49-8031-354-560

Israel - Ra'anana Tel: 972-9-744-7705

Italy - Milan

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

**Italy - Padova** Tel: 39-049-7625286

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

Norway - Trondheim Tel: 47-7288-4388

Poland - Warsaw Tel: 48-22-3325737

Romania - Bucharest Tel: 40-21-407-87-50

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

**Sweden - Gothenberg** Tel: 46-31-704-60-40

Sweden - Stockholm Tel: 46-8-5090-4654

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