Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs. With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas. We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry! # Contact us Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China ### **LAN9210** # Small Form Factor Single-Chip Ethernet Controller with HP Auto-MDIX Support #### **PRODUCT FEATURES** #### Datasheet #### **Highlights** - Optimized for standard performance applications - Efficient architecture with low CPU overhead - Easily interfaces to most 16-bit embedded CPU's - Integrated PHY with HP Auto-MDIX support - Integrated checksum offload engine helps reduce CPU load - Low pin count and small body size package for small form factor system designs - Supports audio & video streaming over Ethernet: multiple standard-definition (SD) MPEG2 streams #### **Target Applications** - Basic cable, satellite, and IP set-top boxes - Digital video recorders - Video-over IP solutions, IP PBX & video phones - Wireless routers & access points - Audio distribution systems - Printers, kiosks, security systems - General embedded applications #### **Key Benefits** - Non-PCI Ethernet controller for performance sensitive applications - 16-bit interface - Burst-mode read support - Minimizes dropped packets - Internal buffer memory can store over 200 packets - Automatic PAUSE and back-pressure flow control - Minimizes CPU overhead - Supports Slave-DMA - Interrupt Pin with Programmable Hold-off timer - Reduces system cost and increases design flexibility - SRAM-like interface easily interfaces to most embedded CPU's or SoC's - Reduced Power Modes - Numerous power management modes - Wake on LAN - Magic packet wakeup - Wakeup indicator event signal - Link Status Change - Single chip Ethernet controller - Fully compliant with IEEE 802.3/802.3u standards - Integrated Ethernet MAC and PHY - 10BASE-T and 100BASE-TX support - Full- and Half-duplex support - Full-duplex flow control - Backpressure for half-duplex flow control - Preamble generation and removal - Automatic 32-bit CRC generation and checking - Automatic payload padding and pad removal - Loop-back modes - Flexible address filtering modes - One 48-bit perfect address - 64 hash-filtered multicast addresses - Pass all multicast - Promiscuous mode - Inverse filtering - Pass all incoming with status report - Disable reception of broadcast packets - Integrated 10/100 Ethernet PHY - Supports HP Auto-MDIX - Auto-negotiation - Supports energy-detect power down - Host bus interface - Simple, SRAM-like interface - 16-bit data bus - 16Kbyte FIFO with flexible TX/RX allocation - One configurable host interrupt - Miscellaneous features - Small form factor, 56-pin QFN lead-free RoHS Compliant package - Integrated 1.8V regulator - Integrated checksum offload engine - Mixed endian support - General Purpose Timer - Optional EEPROM interface - Support for 3 status LEDs multiplexed with Programmable GPIO signals - Single 3.3V Power Supply with 5V tolerant I/O - 0°C to +70°C Commercial Temperature Support ### Order Number(s): LAN9210-ABZJ for 56-pin, QFN Lead-free RoHS Compliant package (0 to +70°C Temp Range) This product meets the halogen maximum concentration values per IEC61249-2-21 For RoHS compliance and environmental information, please visit www.smsc.com/rohs Copyright © 2012 SMSC or its subsidiaries. All rights reserved. Circuit diagrams and other information relating to SMSC products are included as a means of illustrating typical applications. Consequently, complete information sufficient for construction purposes is not necessarily given. Although the information has been checked and is believed to be accurate, no responsibility is assumed for inaccuracies. SMSC reserves the right to make changes to specifications and product descriptions at any time without notice. Contact your local SMSC sales office to obtain the latest specifications before placing your product order. The provision of this information does not convey to the purchaser of the described semiconductor devices any licenses under any patent rights or other intellectual property rights of SMSC or others. All sales are expressly conditional on your agreement to the terms and conditions of the most recently dated version of SMSC's standard Terms of Sale Agreement dated before the date of your order (the "Terms of Sale Agreement"). The product may contain design defects or errors known as anomalies which may cause the product's functions to deviate from published specifications. Anomally sheets are available upon request. SMSC products are not designed, intended, authorized or warranted for use in any life support or other application where product failure could cause or contribute to personal injury or severe property damage. Any and all such uses without prior written approval of an Officer of SMSC and further testing and/or modification will be fully at the risk of the customer. Copies of this document or other SMSC literature, as well as the Terms of Sale Agreement, may be obtained by visiting SMSC's website at http://www.smsc.com. SMSC is a registered trademark of Standard Microsystems Corporation ("SMSC"). Product names and company names are the trademarks of their respective holders. SMSC DISCLAIMS AND EXCLUDES ANY AND ALL WARRANTIES, INCLUDING WITHOUT LIMITATION ANY AND ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND AGAINST INFRINGEMENT AND THE LIKE, AND ANY AND ALL WARRANTIES ARISING FROM ANY COURSE OF DEALING OR USAGE OF TRADE. IN NO EVENT SHALL SMSC BE LIABLE FOR ANY DIRECT, INCIDENTAL, INDIRECT, SPECIAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES; OR FOR LOST DATA, PROFITS, SAVINGS OR REVENUES OF ANY KIND; REGARDLESS OF THE FORM OF ACTION, WHETHER BASED ON CONTRACT; TORT; NEGLIGENCE OF SMSC OR OTHERS; STRICT LIABILITY; BREACH OF WARRANTY; OR OTHERWISE; WHETHER OR NOT ANY REMEDY OF BUYER IS HELD TO HAVE FAILED OF ITS ESSENTIAL PURPOSE, AND WHETHER OR NOT SMSC HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. # **Table of Contents** | Chap | er 1 General Description | | |-----------------|-------------------------------------------------|------| | | | | | 1.2 | Internal Block Overview | | | 1.3 | 10/100 Ethernet PHY | | | 1.4 | 10/100 Ethernet MAC | | | 1.5 | Receive and Transmit FIFOs | | | 1.6 | nterrupt Controller | . 12 | | 1.7 | GPIO Interface | | | 1.8 | Serial EEPROM Interface | . 12 | | 1.9 | Power Management Controls | . 12 | | 1.10 | General Purpose Timer | . 12 | | 1.11 | Host Bus Interface (SRAM Interface) | . 13 | | <u> </u> | | 1.4 | | <b>Cnap</b> 2.1 | er 2 Pin Description and Configuration | | | 2.2 | Buffer Types | | | | Suiler Types | . 13 | | Chap | er 3 Functional Description | 21 | | 3.1 | 10/100 Ethernet MAC | . 21 | | 3.2 | Flow Control | | | | 3.2.1 Full-Duplex Flow Control | | | | 3.2.2 Half-Duplex Flow Control (Backpressure) | | | | 3.2.3 Virtual Local Area Network (VLAN) Support | | | 3.3 | Address Filtering Functional Description | | | 3.4 | Filtering Modes | | | J. <del>4</del> | 3.4.1 Perfect Filtering | | | | · · · · · · · · · · · · · · · · · · · | | | ٥. | | | | 3.5 | Wake-up Frame Detection | | | | 3.5.1 Magic Packet Detection | | | 3.6 | Checksum Offload Engines (COE) | | | | 3.6.1 Receive Checksum Offload Engine (RXCOE) | | | | 3.6.2 Transmit Checksum Offload Engine (TXCOE) | | | 3.7 | Host Bus Operations | | | | 3.7.1 Bus Writes | . 32 | | | 3.7.2 Bus Reads | . 33 | | | 3.7.3 Mixed Endian Support | . 33 | | | 3.7.4 Word Swap Function | . 33 | | 3.8 | General Purpose Timer (GP Timer) | | | 3.9 | EEPROM Interface | | | | 3.9.1 MAC Address Auto-Load | | | | 3.9.2 EEPROM Host Operations | | | 3.10 | Power Management | | | 5.10 | 3.10.1 System Description | | | | 3.10.2 Functional Description | | | | · · · · · · · · · · · · · · · · · · · | | | 2 4 4 | 3.10.3 Internal PHY Power-Down Modes | | | 3.11 | Detailed Reset Description | 40 | | | 3.11.1 Hardware Reset Input (nRESET) | | | | 3.11.2 Resume Reset Timing | | | | 3.11.3 Soft Reset (SRST) | | | | 3.11.4 PHY Reset Timing | | | 3.12 | TX Data Path Operation | 47 | | | 3.12.1 | TX Buffer Format | 49 | |------------|---------|-------------------------------------------------------------------|--------------| | | 3.12.2 | TX Command Format | . 50 | | | 3.12.3 | TX Data Format | . 52 | | | 3.12.4 | TX Status Format | 53 | | | 3.12.5 | Calculating Actual TX Data FIFO Usage | . 54 | | | 3.12.6 | Transmit Examples | | | | 3.12.7 | Transmitter Errors | | | | 3.12.8 | Stopping and Starting the Transmitter | | | 3.13 | | a Path Operation | | | | 3.13.1 | RX Slave PIO Operation | | | | 3.13.2 | RX Packet Format | | | | 3.13.3 | RX Status Format | | | | 3.13.4 | Stopping and Starting the Receiver | | | | 3.13.5 | Receiver Errors | | | | | | | | Chaj | oter 4 | Internal Ethernet PHY | 66 | | 4.1 | Top Lev | el Functional Description | 66 | | 4.2 | 100Base | e-TX Transmit | 66 | | | 4.2.1 | 4B/5B Encoding | | | | 4.2.2 | Scrambling | . 68 | | | 4.2.3 | NRZI and MLT3 Encoding | | | | 4.2.4 | 100M Transmit Driver | | | | 4.2.5 | 100M Phase Lock Loop (PLL) | | | 4.3 | 100Base | e-TX Receive | | | | 4.3.1 | 100M Receive Input | | | | 4.3.2 | Equalizer, Baseline Wander Correction and Clock and Data Recovery | | | | 4.3.3 | NRZI and MLT-3 Decoding | | | | 4.3.4 | Descrambling | | | | 4.3.5 | Alignment. | | | | 4.3.6 | 5B/4B Decoding | | | 4.4 | | -T Transmit | | | 7.7 | 4.4.1 | 10M Transmit Data across the internal MII bus | | | | 4.4.2 | Manchester Encoding | | | | 4.4.3 | 10M Transmit Drivers | | | 4.5 | _ | -T Receive | | | 4.5 | 4.5.1 | 10M Receive Input and Squelch | | | | 4.5.1 | Manchester Decoding | | | | 4.5.2 | Jabber Detection | | | 4.6 | | | | | 4.6 | | gotiation | | | 4.7 | | Detection | | | | 4.7.1 | Re-starting Auto-negotiation | | | | 4.7.2 | Disabling Auto-negotiation. | | | 4.0 | 4.7.3 | Half vs. Full-Duplex | | | 4.8 | HP Auto | -MDIX | . 74 | | Char | oter 5 | Register Description | 76 | | 5.1 | | Nomenclature and Access Attributes | | | 5.1 | | TX FIFO Ports | | | J.Z | 5.2.1 | RX FIFO Ports | | | | 5.2.1 | | | | <b>5</b> 2 | - | TX FIFO Ports | | | 5.3 | • | Control and Status Registers | | | | 5.3.1 | ID_REV—Chip ID and Revision | | | | 5.3.2 | IRQ_CFG—Interrupt Configuration Register | | | | 5.3.3 | INT_STS—Interrupt Status Register | . <b>0</b> 1 | ### Datasheet | | 5.3.4 | INT_EN—Interrupt Enable Register | |-------------------------|---------|-------------------------------------------------------------------------------------------------------------| | | 5.3.5 | BYTE_TEST—Byte Order Test Register84 | | | 5.3.6 | FIFO_INT—FIFO Level Interrupts | | | 5.3.7 | RX_CFG—Receive Configuration Register85 | | | 5.3.8 | TX_CFG—Transmit Configuration Register | | | 5.3.9 | HW_CFG—Hardware Configuration Register | | | 5.3.10 | RX_DP_CTRL—Receive Datapath Control Register | | | 5.3.11 | RX_FIFO_INF—Receive FIFO Information Register | | | 5.3.12 | TX_FIFO_INF—Transmit FIFO Information Register | | | 5.3.13 | PMT_CTRL— Power Management Control Register | | | 5.3.14 | GPIO_CFG—General Purpose IO Configuration Register | | | 5.3.15 | GPT_CFG-General Purpose Timer Configuration Register | | | 5.3.16 | GPT_CNT-General Purpose Timer Current Count Register | | | 5.3.17 | WORD_SWAP—Word Swap Control | | | 5.3.18 | FREE_RUN—Free-Run 25MHz Counter | | | 5.3.19 | RX_DROP- Receiver Dropped Frames Counter | | | 5.3.20 | MAC CSR CMD – MAC CSR Synchronizer Command Register | | | 5.3.21 | MAC_CSR_DATA – MAC CSR Synchronizer Data Register | | | 5.3.22 | AFC_CFG – Automatic Flow Control Configuration Register | | | 5.3.23 | E2P_CMD – EEPROM Command Register | | | 5.3.24 | E2P_DATA – EEPROM Data Register | | 5.4 | | ontrol and Status Registers | | · · · | 5.4.1 | MAC_CR—MAC Control Register | | | 5.4.2 | ADDRH—MAC Address High Register | | | 5.4.3 | ADDRL—MAC Address Low Register | | | 5.4.4 | HASHH—Multicast Hash Table High Register | | | 5.4.5 | HASHL—Multicast Hash Table Low Register | | | 5.4.6 | MII_ACC—MII Access Register | | | 5.4.7 | MII_DATA—MII Data Register | | | 5.4.8 | FLOW—Flow Control Register | | | 5.4.9 | VLAN1—VLAN1 Tag Register | | | 5.4.10 | VLAN2—VLAN2 Tag Register | | | 5.4.11 | WUFF—Wake-up Frame Filter | | | 5.4.12 | WUCSR—Wake-up Control and Status Register | | | 5.4.13 | COE_CR—Checksum Offload Engine Control Register | | 5.5 | | gisters | | 0.0 | 5.5.1 | Basic Control Register | | | 5.5.2 | Basic Status Register | | | 5.5.3 | PHY Identifier 1 | | | 5.5.4 | PHY Identifier 2 | | | 5.5.5 | Auto-negotiation Advertisement | | | 5.5.6 | Auto-negotiation Link Partner Ability | | | 5.5.7 | Auto-negotiation Expansion | | | 5.5.8 | Mode Control/Status | | | 5.5.9 | Special Modes | | | 5.5.10 | Special Control/Status Indications | | | 5.5.10 | · | | | 5.5.11 | Interrupt Source Flag | | | 5.5.12 | PHY Special Control/Status | | | 0.0.13 | FTTT Opecial Control/Status | | Chai | pter 6 | Гіming Diagrams | | Спа <sub>ј</sub><br>6.1 | | erface Timing | | U. I | 6.1.1 | Special Restrictions on Back-to-Back Write/Read Cycles | | | 6.1.2 | Special Restrictions on Back-to-Back Write/Read Cycles | | | U. I. C | - Openial Regulation of Davis a Davis (CDavis Regulation Collegen) - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, | | Cha | pter 9 Datasheet Revision History | 146 | |-------------------|--------------------------------------------------|-----| | <b>Cha</b><br>8.1 | pter 8 Package Outline | | | 7.7 | Clock Circuit | 143 | | 7.6 | DC Electrical Specifications | | | 7.5 | Worst Case Current Consumption | | | 7.4 | Power Consumption (Device and System Components) | | | 7.3 | Power Consumption (Device Only) | | | 7.2 | Operating Conditions** | | | 7.1 | Absolute Maximum Ratings* | | | Cha | pter 7 Operational Characteristics | 137 | | 6.9 | EEPROM Timing | 136 | | 6.8 | Reset Timing | | | 6.7 | TX Data FIFO Direct PIO Writes | | | 6.6 | PIO Writes | | | 6.5 | RX Data FIFO Direct PIO Burst Reads | | | 6.4 | RX Data FIFO Direct PIO Reads | | | 6.3 | PIO Burst Reads | | | 6.2 | PIO Reads | 129 | # **List of Figures** | Figure 1.1 | System Block Diagram | . 10 | |------------|---------------------------------------------------------|------| | Figure 1.2 | Internal Block Diagram | . 11 | | Figure 2.1 | Pin Configuration (Top View) | 14 | | Figure 3.1 | VLAN Frame | | | Figure 3.2 | RXCOE Checksum Calculation | 28 | | Figure 3.3 | Type II Ethernet Frame | 29 | | Figure 3.4 | Ethernet Frame with VLAN Tag | | | Figure 3.5 | Ethernet Frame with Length Field and SNAP Header | | | Figure 3.6 | Ethernet Frame with VLAN Tag and SNAP Header | | | Figure 3.7 | Ethernet Frame with Multiple VLAN Tags and SNAP Header | | | | LAN9210 Host Data Path Diagram | | | | FIFO Access Byte Ordering | | | | EEPROM Access Flow Diagram | | | | EEPROM ERASE Cycle | | | | EEPROM ERAL Cycle | | | | EEPROM EWDS Cycle | | | | EEPROM EWEN Cycle | | | | EEPROM READ Cycle | | | • | EEPROM WRITE Cycle | | | • | EEPROM WRAL Cycle | | | | PME and PME_INT Signal Generation | | | | Simplified Host TX Flow Diagram | | | | TX Buffer Format | | | | TX Example 1 | | | | TX Example 2 | | | | TX Example 3 | | | | Host Receive Routine Using Interrupts | | | | Host Receive Routine with Polling | | | | RX Packet Format | | | | RX Packet Format with RX Checksum | | | • | 100Base-TX Data Path | | | Figure 4.2 | Receive Data Path | | | Figure 4.3 | Direct Cable Connection vs. Cross-over Cable Connection | | | Figure 5.1 | Memory Map | | | Figure 5.2 | Example ADDRL, ADDRH and EEPROM Setup | | | Figure 6.1 | PIO Read Cycle Timing. | | | Figure 6.2 | PIO Burst Read Cycle Timing | | | Figure 6.3 | RX Data FIFO Direct PIO Read Cycle Timing | | | Figure 6.4 | RX Data FIFO Direct PIO Burst Read Cycle Timing | | | Figure 6.5 | PIO Write Cycle Timing | | | Figure 6.6 | TX Data FIFO Direct PIO Write Timing | | | Figure 6.7 | | 135 | | Figure 6.8 | EEPROM Timing | | | Figure 8.1 | 56 Pin QFN Package Definition | | | rigure 8.2 | 56 Pin QFN Recommended PCB Land Pattern | 145 | # **List of Tables** | | Host Bus Interface Signals | | |------------|-------------------------------------------------|------| | | LAN Interface Signals | | | Table 2.3 | Serial EEPROM Interface Signals | . 16 | | | System and Power Signals | | | Table 2.5 | 56-QFN Package Pin Assignments | . 19 | | Table 2.6 | Buffer Types | . 19 | | | Address Filtering Modes | | | Table 3.2 | Wake-Up Frame Filter Register Structure | . 26 | | | Filter i Byte Mask Bit Definitions | | | Table 3.4 | Filter i Command Bit Definitions | . 26 | | Table 3.5 | Filter i Offset Bit Definitions | . 27 | | Table 3.6 | Filter i CRC-16 Bit Definitions | . 27 | | Table 3.7 | TX Checksum Preamble | . 32 | | Table 3.8 | Endian Ordering Logic Operation | . 36 | | Table 3.9 | Required EECLK Cycles | . 42 | | Table 3.10 | Power Management States | . 44 | | Table 3.11 | Reset Sources and Affected Circuitry | . 46 | | Table 3.12 | TX Command 'A' Format | . 51 | | Table 3.13 | TX Command 'B' Format | . 52 | | Table 3.14 | TX DATA Start Offset | . 52 | | Table 4.1 | 4B/5B Code Table | . 67 | | Table 4.2 | CRS Behavior | . 74 | | Table 5.1 | Direct Address Register Map | . 78 | | | RX Alignment Bit Definitions | | | Table 5.3 | Valid TX/RX FIFO Allocations | . 89 | | Table 5.4 | EEPROM Enable Bit Definitions | . 95 | | Table 5.5 | Backpressure Duration Bit Mapping | 100 | | Table 5.6 | MAC CSR Register Map | 104 | | Table 5.7 | ADDRL, ADDRH and EEPROM Byte Ordering | 109 | | Table 5.8 | LAN9210 PHY Control and Status Register | 116 | | Table 5.9 | MODE Control | 122 | | Table 6.1 | Read After Write Timing Rules | 127 | | Table 6.2 | Read After Read Timing Rules | 128 | | Table 6.3 | PIO Read Timing | 129 | | Table 6.4 | PIO Burst Read Timing | 130 | | Table 6.5 | RX Data FIFO Direct PIO Read Timing | 131 | | Table 6.6 | RX Data FIFO Direct PIO Burst Read Cycle Timing | 132 | | Table 6.7 | PIO Write Cycle Timing | 133 | | | TX Data FIFO Direct PIO Write Timing | 134 | | Table 6.9 | Reset Timing | 135 | | Table 6.10 | EEPROM Timing Values | 136 | | Table 7.1 | Power Consumption Device Only | 138 | | Table 7.2 | Power Consumption Device and System Components | 139 | | Table 7.3 | Maximum Supply Current Characteristics | 140 | | Table 7.4 | I/O Buffer Characteristics | 141 | | Table 7.5 | 100BASE-TX Transceiver Characteristics | 142 | | Table 7.6 | 10BASE-T Transceiver Characteristics | | | | LAN9210 Crystal Specifications | | | | 56 Pin QFN Package Parameters | | | Table 9.1 | Customer Revision History | 146 | ## **Chapter 1 General Description** The LAN9210 is a full-featured, single-chip 10/100 Ethernet controller designed for embedded applications where performance, flexibility, ease of integration and system cost control are required. The LAN9210 is fully IEEE 802.3 10BASE-T and 802.3u 100BASE-TX compliant, and supports HP Auto-MDIX. The LAN9210 includes an integrated Ethernet MAC and PHY with a high-performance SRAM-like slave interface. The simple, yet highly functional host bus interface provides a glue-less connection to most common 16-bit microprocessors and microcontrollers as well as 32-bit microprocessors with a 16-bit external bus. The integrated checksum offload engines enable the automatic generation of the 16-bit checksum for received and transmitted Ethernet frames, offloading the task from the CPU. The LAN9210 also includes large transmit and receive data FIFOs to accommodate high latency applications. In addition, the LAN9210 memory buffer architecture allows highly efficient use of memory resources by optimizing packet granularity. #### **Applications** The LAN9210 is well suited for many medium-performance embedded applications, including: - Printers, kiosks, POS terminals and security systems - Audio distribution systems - General embedded systems - Basic cable, satellite and IP set-top boxes - Voice-over-IP solutions The LAN9210 also supports features which reduce or eliminate packet loss. Its internal 16-KByte SRAM can hold over 200 received packets. If the receive FIFO gets too full, the LAN9210 can automatically generate flow control packets to the remote node, or assert back-pressure on the remote node by generating network collisions. The LAN9210 supports numerous power management and wakeup features. The LAN9210 can be placed in a reduced power mode and can be programmed to issue an external wake signal via several methods, including "Magic Packet", "Wake on LAN" and "Link Status Change". This signal is ideal for triggering system power-up using remote Ethernet wakeup events. The device can be removed from the low power state via a host processor command. ### 1.1 Block Diagram Figure 1.1 System Block Diagram The SMSC LAN9210 integrated 10/100 MAC/PHY controller is a peripheral chip that performs the function of translating parallel data from a host controller into Ethernet packets. The LAN9210 Ethernet MAC/PHY controller is designed and optimized to function in an embedded environment. All communication is performed with programmed I/O transactions using the simple SRAM-like host interface bus. The diagram shown above, describes a typical system configuration of the LAN9210 in a typical embedded environment. The LAN9210 is a general purpose, platform independent, Ethernet controller. The LAN9210 consists of four major functional blocks. The four blocks are: - 10/100 Ethernet PHY - 10/100 Ethernet MAC - RX/TX FIFOs - Host Bus Interface (HBI) ### 1.2 Internal Block Overview This section provides an overview of each of these functional blocks as shown in Figure 1.2, "Internal Block Diagram". Figure 1.2 Internal Block Diagram ### 1.3 10/100 Ethernet PHY The LAN9210 integrates an IEEE 802.3 physical layer for twisted pair Ethernet applications. The PHY can be configured for either 100 Mbps (100BASE-TX) or 10 Mbps (10BASE-T) Ethernet operation in either full or half duplex configurations. The PHY block supports HP Auto-MDIX and auto-negotiation. Minimal external components are required for the utilization of the Integrated PHY. #### 1.4 10/100 Ethernet MAC The transmit and receive data paths are separate within the MAC allowing the highest performance especially in full duplex mode. The data paths connect to the PIO interface Function via separate busses to increase performance. Payload data as well as transmit and receive status is passed on these busses. A third internal bus is used to access the MAC's Control and Status Registers (CSR's). This bus is accessible from the host through the PIO interface function. On the backend, the MAC interfaces with the internal 10/100 PHY through a MII (Media Independent Interface) port internal to the LAN9210. The MAC CSR's also provide a mechanism for accessing the PHY's internal registers through the internal SMI (Serial Management Interface) bus. The MAC Interface Layer (MIL), within the MAC, contains a 2K Byte transmit and a 128 Byte receive FIFO which is separate from the TX and RX FIFOs. The FIFOs within the MAC are not directly accessible from the host interface. The differentiation between the TX/RX FIFO memory buffers and the MAC buffers is that when the transmit or receive packets are in the MAC buffers, the host no longer can control or access the TX or RX data. The MAC buffers (both TX and RX) are in effect the working buffers of the Ethernet MAC logic. In the case of reception, the data must be moved first to the RX FIFOs for the host to access the data. For TX operations, the MIL operates in store-and-forward mode and will gueue an entire frame before beginning transmission. ### 1.5 Receive and Transmit FIFOs The Receive and Transmit FIFOs allow increased packet buffer storage to the MAC. The FIFOs are a conduit between the host interface and the MAC through which all transmitted and received data and status information is passed. Deep FIFOs allow a high degree of latency tolerance relative to the various transport and OS software stacks thus reducing or minimizing overrun conditions. Like the MAC, the FIFOs have separate receive and transmit data paths. In addition, the RX and TX FIFOs are configurable in size, allowing increased flexibility. ### 1.6 Interrupt Controller The LAN9210 supports a single programmable interrupt. The programmable nature of this interrupt allows the user the ability to optimize performance dependent upon the application requirement. Both the polarity and buffer type of the interrupt pin are configurable for the external interrupt processing. The interrupt line can be configured as an open-drain output to facilitate the sharing of interrupts with other devices. In addition, a programmable interrupt de-assertion interval is provided. ### 1.7 GPIO Interface A 3-bit GPIO and 2-bit GPO (Multiplexed on the EEPROM and LED Pins) interface is included in the LAN9210. It is accessible through the host bus interface via the CSRs. The GPIO signals can function as inputs, push-pull outputs and open drain outputs. The GPIO's (GPO's are not configurable) can also be configured to trigger interrupts with programmable polarity. #### 1.8 Serial EEPROM Interface A serial EEPROM interface is included in the LAN9210. The serial EEPROM is optional and can be programmed with the LAN9210 MAC address. The LAN9210 can optionally load the MAC address automatically after hardware reset, or soft reset. ### 1.9 Power Management Controls The LAN9210 supports comprehensive array of power management modes to allow use in power sensitive applications. Wake on LAN, Link Status Change and Magic Packet detection are supported by the LAN9210. An external PME (Power Management Event) interrupt is provided to indicate detection of a wakeup event. ### 1.10 General Purpose Timer The general-purpose timer has no dedicated function within the LAN9210 and may be programmed to issue a timed interrupt. ### 1.11 Host Bus Interface (SRAM Interface) The host bus interface provides a FIFO interface for the transmit and receive data paths, as well as an interface for the LAN9210 Control and Status Registers (CSR's). The host bus interface is the primary bus for connection to the embedded host system. This interface models an asynchronous SRAM. TX FIFO, RX FIFO, and CSR's are accessed through this interface. Programmed I/O transactions are supported. The LAN9210 host bus interface supports 16-bit bus transfers. Internally, all data paths are 32-bits wide. The LAN9210 can be interfaced to either Big-Endian or Little-Endian processors and includes mixed endian support for FIFO accesses. # **Chapter 2 Pin Description and Configuration** Figure 2.1 Pin Configuration (Top View) ### 2.1 Pin List Table 2.1 Host Bus Interface Signals | NAME | SYMBOL | BUFFER<br>TYPE | #<br>PINS | DESCRIPTION | |----------------------|----------|----------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Host Data | D[15:0] | I/O8 | 16 | Bi-directional data port. | | Host Address | A[7:1] | IS | 7 | 7-bit Address Port. Used to select Internal CSR's and TX and RX FIFOs. | | Read Strobe | nRD | IS | 1 | Active low strobe to indicate a read cycle. | | Write Strobe | nWR | IS | 1 | Active low strobe to indicate a write cycle. This signal, qualified with nCS, is also used to wakeup the LAN9210 when it is in a reduced power state. | | Chip Select | nCS | IS | 1 | Active low signal used to qualify read and write operations. This signal qualified with nWR is also used to wakeup the LAN9210 when it is in a reduced power state. | | Interrupt<br>Request | IRQ | O8/OD8 | 1 | Programmable Interrupt request. Programmable polarity, source and buffer types. | | FIFO Select | FIFO_SEL | IS | 1 | When driven high all accesses to the LAN9210 are to the RX or TX Data FIFOs. In this mode, the A[7:3] upper address inputs are ignored. | Table 2.2 LAN Interface Signals | NAME | SYMBOL | BUFFER<br>TYPE | NUM<br>PINS | DESCRIPTION | |-------------------------------|--------|----------------|-------------|------------------------------------------------------------------------| | TPO+ | TPO+ | AO | 1 | Transmit Positive Output (normal)<br>Receive Positive Input (reversed) | | TPO- | TPO- | AO | 1 | Transmit Negative Output (normal)<br>Receive Negative Input (reversed) | | TPI+ | TPI+ | Al | 1 | Receive Positive Input (normal)<br>Transmit Positive Input (reversed) | | TPI- | TPI- | Al | 1 | Receive Negative Input (normal)<br>Transmit Negative Output (reversed) | | PHY External Bias<br>Resistor | EXRES1 | Al | 1 | Must be connected to ground through a 12.4K ohm 1% resistor. | **Note:** The pin names for the twisted pair pins shown above apply to a normal connection. If HP Auto-MDIX is enabled and a reverse connection is detected, or a reverse connection is manually selected, the input pins become outputs, and vice-versa, as indicated in the descriptions. **Table 2.3 Serial EEPROM Interface Signals** | NAME | SYMBOL | BUFFER<br>TYPE | NUM<br>PINS | DESCRIPTION | |----------------------------------------|-----------------------------|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EEPROM Data,<br>GPO3, TX_EN,<br>TX_CLK | EEDIO/GPO3/<br>TX_EN/TX_CLK | I/O8 | 1 | <b>EEPROM Data:</b> This bi-directional pin can be connected to a serial EEPROM DIO. This is optional. | | | | | | General Purpose Output 3: This pin can also function as a general purpose output, or it can be configured to monitor the TX_EN or TX_CLK signals on the internal MII port. When configured as a GPO signal, or as a TX_EN/TX_CLK monitor, the EECS pin is deasserted so as to never unintentionally access the serial EEPROM. This signal cannot function as a general-purpose input. | | EEPROM Chip<br>Select | EECS | O8 | 1 | Serial EEPROM chip select. | | EEPROM Clock,<br>GPO4 RX_DV,<br>RX_CLK | EECLK/GPO4/<br>RX_DV/RX_CLK | O8<br>(PU) | 1 | EEPROM Clock: Serial EEPROM Clock pin. General Purpose Output 4: This pin can also function as a general-purpose output, or it can be configured to monitor the RX_DV or RX_CLK signals on the internal MII port. When configured as a GPO signal, or as an RX_DV/RX_CLK monitor, the EECS pin is deasserted so as to never unintentionally access the serial EEPROM. This signal cannot function as a general-purpose input. Note: When the EEPROM interface is not used, the EECLK pin must be left unconnected. Note: This pin must not be pulled low by an external resistor or driven low externally under any conditions. | Table 2.4 System and Power Signals | NAME | SYMBOL | BUFFER<br>TYPE | NUM<br>PINS | DESCRIPTION | | |---------------------|-------------|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Crystal 1, Clock In | XTAL1/CLKIN | ICLK | 1 | External 25MHz Crystal Input. This pin can also be connected to single-ended TTL oscillator (CLKIN). If this method is implemented, XTAL2 should be left unconnected. | | | Crystal 2 | XTAL2 | OCLK | 1 | External 25MHz Crystal output. | | | Reset | nRESET | IS<br>(PU) | 1 | Active-low reset input. Resets all logic and registers within the LAN9210. This signal is pulled high with a weak internal pull-up resistor. Note: The LAN9210 must be reset on power-up via nRESET or following power-up via a soft reset (SRST). The LAN9210 must always be read at least once after reset, or upon return from a power-saving state or write operations will not function. See Section 3.11, "Detailed Reset Description," on page 46 for additional information | | | Wakeup Indicator | PME | O8/OD8 | 1 | When programmed to do so, is asserted when the LAN9210 detects a wake event and is requesting the system to wake up from the associated sleep state. The polarity and buffer type of this signal is programmable. Note: Detection of a Power Management Event, and assertion of the PME signal will not wakeup the LAN9210. The LAN9210will only wake up when it detects a host write cycle (assertion of nCS and nWR). Although any write to the LAN9210, regardless of the data written, will wake-up the device when it is in a power-saving mode, it is required that the BYTE_TEST register be used for this purpose. | | | Auto-MDIX Enable | AMDIX_EN | I<br>(PU) | 1 | Enables Auto-MDIX. Pull high or leave unconnected to enable Auto-MDIX, pull low to disable Auto-MDIX. | | | No Connect | NC | | 1 | No Connect. This pin must be left open. | | Table 2.4 System and Power Signals (continued) | NAME | SYMBOL | BUFFER<br>TYPE | NUM<br>PINS | DESCRIPTION | |-----------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | General Purpose I/O data, nLED1 (Speed Indicator), nLED2 (Link & Activity Indicator), nLED3 (Full- Duplex Indicator). | GPIO[2:0]/<br>nLED[3:1] | IS/O12/<br>OD12 | 3 | General Purpose I/O data: These three general-purpose signals are fully programmable as either push-pull output, open-drain output or input by writing the GPIO_CFG configuration register in the CSR's. They are also multiplexed as GP LED connections. GPIO signals are Schmitt-triggered inputs. When configured as LED outputs these signals are open-drain. | | maioator). | | | | nLED1 (Speed Indicator). This signal is driven low when the operating speed is 100Mb. During auto-negotiation, when the cable is disconnected, and during 10Mbs operation, this signal is driven high. | | | | | | nLED2 (Link & Activity Indicator). This signal is driven low (LED on) when the LAN9210 detects a valid link. This signal is pulsed high (LED off) for 80mS whenever transmit or receive activity is detected. This signal is then driven low again for a minimum of 80mS, after which time it will repeat the process if TX or RX activity is detected. Effectively, LED2 is activated solid for a link. When transmit or receive activity is sensed LED2 will flash as an activity indicator. | | | | | | nLED3 (Full-Duplex Indicator). This signal is driven low when the link is operating in full-duplex mode. | | +3.3V I/O Power | VDD_IO | Р | 5 | +3.3V I/O logic power supply pins | | Common Ground | VSS | Р | 1 pad | Common Ground | | +3.3V Analog<br>Power | VDD_A33 | Р | 3 | +3.3V analog power supply pins. See Note 2.1. | | +1.8V Analog<br>Power | VDD_A18 | Р | 1 | +1.8V analog power supply pin. This pin must be connected externally to VDD_CORE. See Note 2.1. | | Core Voltage<br>Decoupling | VDD_CORE | Р | 2 | +1.8 V from internal core regulator. Both pins must be connected together externally. Each pin requires a 0.01uF decoupling capacitor. In addition, pin 2 requires a bulk 4.7uF capacitor (<2 Ohm ESR) in parallel. These pins must not be used to supply power to other external devices. See Note 2.1. | Note 2.1 Please refer to the SMSC application note AN16.6 - "Migrating from LAN9215 to the LAN9210/LAN9211" for additional details. Table 2.5 56-QFN Package Pin Assignments | PIN<br>NUM | PIN NAME | PIN<br>NUM | PIN NAME | PIN<br>NUM | PIN NAME | PIN<br>NUM | PIN NAME | |-------------|-------------|------------|----------|------------|------------|------------|-------------| | 1 | VDD_IO | 15 | nRD | 29 | D6 | 43 | IRQ | | 2 | VDD_CORE | 16 | nWR | 30 | VDD_IO | 44 | TPO- | | 3 | GPIO0/nLED1 | 17 | nCS | 31 | D5 | 45 | TPO+ | | 4 | GPIO1/nLED2 | 18 | VDD_IO | 32 | D4 | 46 | VDD_A33 | | 5 | GPIO2/nLED3 | 19 | D15 | 33 | D3 | 47 | TPI- | | 6 | A7 | 20 | D14 | 34 | D2 | 48 | TPI+ | | 7 | A6 | 21 | D13 | 35 | D1 | 49 | VDD_A33 | | 8 | A5 | 22 | D12 | 36 | D0 | 50 | EXRES1 | | 9 | A4 | 23 | D11 | 37 | VDD_CORE | 51 | VDD_A33 | | 10 | A3 | 24 | VDD_IO | 38 | EEDIO/GPO3 | 52 | AMDIX_EN | | 11 | A2 | 25 | D10 | 39 | EECS | 53 | VDD_A18 | | 12 | A1 | 26 | D9 | 40 | EECLK/GPO4 | 54 | XTAL2 | | 13 | FIFO_SEL | 27 | D8 | 41 | PME | 55 | XTAL1/CLKIN | | 14 | NC | 28 | D7 | 42 | nRESET | 56 | VDD_IO | | EXPOSED PAD | | | | | | | | EXPOSED PAD MUST BE CONNECTED TO VSS # 2.2 Buffer Types Table 2.6 Buffer Types | TYPE | DESCRIPTION | | | | |------|---------------------------------------|--|--|--| | I | Input pin | | | | | IS | Schmitt triggered Input | | | | | O12 | Output with 12mA sink and 12mA source | | | | | OD12 | Open-drain output with 12mA sink | | | | | OD8 | Open-drain output with 8mA sink | | | | | O8 | Output 8mA symmetrical drive | | | | | PU | 50uA (typical) internal pull-up | | | | ### Table 2.6 Buffer Types | TYPE | DESCRIPTION | | | | |------|-----------------------------------|--|--|--| | PD | 50uA (typical) internal pull-down | | | | | Al | Analog input | | | | | AO | Analog output | | | | | AIO | Analog bi-directional | | | | | ICLK | Crystal oscillator input pin | | | | | OCLK | Crystal oscillator output pin | | | | Note 2.2 # **Chapter 3 Functional Description** ### 3.1 10/100 Ethernet MAC The Ethernet Media Access controller (MAC) incorporates the essential protocol requirements for operating an Ethernet/IEEE 802.3-compliant node and provides an interface between the host subsystem and the internal Ethernet PHY. The MAC can operate in either 100-Mbps or 10-Mbps mode. The MAC operates in both half-duplex and full-duplex modes. When operating in half-duplex mode, the MAC complies fully with Section 4 of ISO/IEC 8802-3 (ANSI/IEEE standard) and ANSI/IEEE 802.3 standards. When operating in full-duplex mode, the MAC complies with IEEE 802.3x full-duplex operation standard. The MAC provides programmable enhanced features designed to minimize host supervision, bus utilization, and pre- or post-message processing. These features include the ability to disable retries after a collision, dynamic FCS (Frame Check Sequence) generation on a frame-by-frame basis, automatic pad field insertion and deletion to enforce minimum frame size attributes, layer 3 checksum calculation for transmit and receive operations, and automatic retransmission and detection of collision frames. The MAC can sustain transmission or reception of minimally-sized back-to-back packets at full line speed with an interpacket gap (IPG) of 9.6 microseconds for 10 Mbps and 0.96 microseconds for 100 Mbps. The primary attributes of the MAC Function are: - Transmit and receive message data encapsulation - Framing (frame boundary delimitation, frame synchronization) - Error detection (physical medium transmission errors) - Media access management - Medium allocation (collision detection, except in full-duplex operation) - Contention resolution (collision handling, except in full-duplex operation) - Flow control during full-duplex mode - Decoding of control frames (PAUSE command) and disabling the transmitter - Generation of control frames - Interface to the internal PHY. - Checksum offload engine for calculation of layer 3 transmit and receive checksum. The transmit and receive data paths are separate within the LAN9210 from the MAC to host interface allowing the highest performance, especially in full duplex mode. Payload data as well as transmit and receive status are passed on these busses. A third internal bus is used to access the MAC's "Control and Status Registers" (CSR's). This bus is also accessible from the host. On the backend, the MAC interfaces with the 10/100 PHY through an MII (Media Independent Interface) port which is internal to the LAN9210. The MAC CSR's also provide a mechanism for accessing the PHY's internal registers through the internal SMI (Serial Management Interface) bus. The receive and transmit FIFOs allow increased packet buffer storage to the MAC. The FIFOs are a conduit between the host interface and the MAC through which all transmitted and received data and status information is passed. Deep FIFOs allow a high degree of latency tolerance relative to the various transport and OS software stacks reducing and minimizing overrun conditions. Like the MAC, the FIFOs have separate receive and transmit data paths. The LAN9210 can store up to 250 Ethernet packets utilizing FIFOs, totaling 16K bytes, with a packet granularity of 4 bytes. This memory is shared by the RX and TX blocks and is configurable in terms of allocation. This depth of buffer storage minimizes or eliminates receive overruns. ### 3.2 Flow Control The LAN9210 Ethernet MAC supports full-duplex flow control using the pause operation and control frame. It also supports half-duplex flow control using back pressure. ### 3.2.1 Full-Duplex Flow Control The pause operation inhibits data transmission of data frames for a specified period of time. A Pause operation consists of a frame containing the globally assigned multicast address (01-80-C2-00-00-01), the PAUSE opcode, and a parameter indicating the quantum of slot time (512 bit times) to inhibit data transmissions. The PAUSE parameter may range from 0 to 65,535 slot times. The Ethernet MAC logic, on receiving a frame with the reserved multicast address and PAUSE opcode, inhibits data frame transmissions for the length of time indicated. If a Pause request is received while a transmission is in progress, then the pause will take effect after the transmission is complete. Control frames are received and processed by the MAC and are passed on. The MAC also transmits control frames (pause command) via both hardware and software control. The software driver requests the MAC to transmit a control frame and gives the value of the PAUSE time to be used in the control frame. The MAC Function constructs a control frame with the appropriate values set in all the different fields (as defined in the 802.3x specification) and transmits the frame to the MII interface. The transmission of the control frame is not affected by the current state of the Pause timer value that is set because of a recently received control frame. ### 3.2.2 Half-Duplex Flow Control (Backpressure) In half-duplex mode, back pressure is used for flow control. Whenever the receive buffer/FIFO becomes full or crosses a certain threshold level, the MAC starts sending a Jam signal. The MAC transmit logic enters a state at the end of current transmission (if any), where it waits for the beginning of a received frame. Once a new frame starts, the MAC starts sending the jam signal, which will result in a collision. After sensing the collision, the remote station will back off its transmission. The MAC continues sending the jam to make other stations defer transmission. The MAC only generates this collision-based back pressure when it receives a new frame, in order to avoid any late collisions. ### 3.2.3 Virtual Local Area Network (VLAN) Support Virtual Local Area Networks or VLANs, as defined within the IEEE 802.3 standard, provide network administrators one means of grouping nodes within a larger network into broadcast domains. To implement a VLAN, four extra bytes are added to the basic Ethernet packet. As shown in Figure 3.1, "VLAN Frame", the four bytes are inserted after the Source Address Field and before the Type/Length field. The first two bytes of the VLAN tag identify the tag, and by convention are set to the value 0x8100. The last two bytes identify the specific VLAN associated with the packet; they also provide a priority field. The LAN9210 supports VLAN-tagged packets. The LAN9210 provides two registers which are used to identify VLAN-tagged packets. One register should normally be set to the conventional VLAN ID of 0x8100. The other register provides a way of identifying VLAN frames tagged with a proprietary (not 0x8100) identifier. If a packet arrives bearing either of these tags in the two bytes succeeding the Source Address field, the controller will recognize the packet as a VLAN-tagged packet. In this case, the controller increases the maximum allowed packet size from 1518 to 1522 bytes (normally the controller filters packets larger than 1518 bytes). This allows the packet to be received, and then processed by host software, or to be transmitted on the network. Figure 3.1 VLAN Frame ### 3.3 Address Filtering Functional Description The Ethernet address fields of an Ethernet Packet, consists of two 6-byte fields: one for the destination address and one for the source address. The first bit of the destination address signifies whether it is a physical address or a multicast address. The LAN9210 address check logic filters the frame based on the Ethernet receive filter mode that has been enabled. Filter modes are specified based on the state of the control bits in Table 3.1, "Address Filtering Modes", which shows the various filtering modes used by the Ethernet MAC Function. These bits are defined in more detail in the "MAC Control Register". Please refer to Section 5.4.1, "MAC\_CR—MAC Control Register" for more information on this register. If the frame fails the filter, the Ethernet MAC function does not receive the packet. The host has the option of accepting or ignoring the packet. **Table 3.1 Address Filtering Modes** | MCPAS | PRMS | INVFILT | но | HPFILT | DESCRIPTION | |-------|------|---------|----|--------|-----------------------------------------------------------------------------------------------| | 0 | 0 | 0 | 0 | 0 | MAC address perfect filtering only for all addresses. | | 0 | 0 | 0 | 0 | 1 | MAC address perfect filtering for physical address and hash filtering for multicast addresses | | Table 3.1 | Address | Filterina | Modes ( | (continued) | ١ | |-----------|---------|-----------|---------|-------------|---| |-----------|---------|-----------|---------|-------------|---| | MCPAS | PRMS | INVFILT | но | HPFILT | DESCRIPTION | |-------|------|---------|----|--------|--------------------------------------------------------------------------------| | 0 | 0 | 0 | 1 | 1 | Hash Filtering for physical and multicast addresses | | 0 | 0 | 1 | 0 | 0 | Inverse Filtering | | Х | 1 | 0 | Х | X | Promiscuous | | 1 | 0 | 0 | 0 | Х | Pass all multicast frames. Frames with physical addresses are perfect-filtered | | 1 | 0 | 0 | 1 | 1 | Pass all multicast frames. Frames with physical addresses are hash-filtered | ### 3.4 Filtering Modes ### 3.4.1 Perfect Filtering This filtering mode passes only incoming frames whose destination address field exactly matches the value programmed into the MAC Address High register and the MAC address low register. The MAC address is formed by the concatenation of the above two registers in the MAC CSR Function. ### 3.4.2 Hash Only Filtering This type of filtering checks for incoming Receive packets with either multicast or physical destination addresses, and executes an imperfect address filtering against the hash table. During imperfect hash filtering, the destination address in the incoming frame is passed through the CRC logic and the upper six bits of the CRC register are used to index the contents of the hash table. The hash table is formed by merging the register's multicast hash table high and multicast hash table low in the MAC CSR Function to form a 64-bit hash table. The most significant bit determines the register to be used (High/Low), while the other five bits determine the bit within the register. A value of 00000 selects Bit 0 of the multicast hash table low register and a value of 11111 selects Bit 31 of the multicast hash table high register. #### 3.4.2.1 Hash Perfect Filtering In hash perfect filtering, if the received frame is a physical address, the LAN9210 Packet Filter block perfect-filters the incoming frame's destination field with the value programmed into the MAC Address High register and the MAC Address Low register. If the incoming frame is a multicast frame, however, the LAN9210 packet filter function performs an imperfect address filtering against the hash table. The imperfect filtering against the hash table is the same imperfect filtering process described in the "Hash Only Filtering" section above. #### 3.4.2.2 Inverse Filtering In inverse filtering, the Packet Filter Block accepts incoming frames with a destination address not matching the perfect address (i.e., the value programmed into the MAC Address High register and the MAC Address Low register in the CRC block and rejects frames with destination addresses matching the perfect address). For all filtering modes, when the MCPAS bit is set, all multicast frames are accepted. When the PRMS bit is set, all frames are accepted regardless of their destination address. This includes all broadcast frames as well. ### 3.5 Wake-up Frame Detection Setting the Wake-Up Frame Enable bit (WUEN) in the "WUCSR—Wake-up Control and Status Register", places the LAN9210 MAC in the wake-up frame detection mode. In this mode, normal data reception is disabled, and detection logic within the MAC examines receive data for the pre-programmed wake-up frame patterns. The LAN9210 can be programmed to notify the host of the wake-up frame detection with the assertion of the host interrupt (IRQ) or assertion of the power management event signal (PME). Upon detection, the Wake-Up Frame Received bit (WUFR) in the WUCSR is set. When the host clears the WUEN bit the LAN9210 will resume normal receive operation. Before putting the MAC into the wake-up frame detection state, the host must provide the detection logic with a list of sample frames and their corresponding byte masks. This information is written into the Wake-up Frame Filter register (WUFF). Please refer to Section 5.4.11, "WUFF—Wake-up Frame Filter," on page 114 for additional information on this register. The MAC supports four programmable filters that support many different receive packet patterns. If remote wake-up mode is enabled, the remote wake-up function receives all frames addressed to the MAC. It then checks each frame against the enabled filter and recognizes the frame as a remote wake-up frame if it passes the wakeup frame filter register's address filtering and CRC value match. In order to determine which bytes of the frames should be checked by the CRC module, the MAC uses a programmable byte mask and a programmable pattern offset for each of the four supported filters. The pattern's offset defines the location of the first byte that should be checked in the frame. Since the destination address is checked by the address filtering Function, the pattern offset is always greater than 12 The byte mask is a 31-bit field that specifies whether or not each of the 31 contiguous bytes within the frame, beginning in the pattern offset, should be checked. If bit j in the byte mask is set, the detection logic checks byte offset +j in the frame. In order to load the Wake-up Frame Filter register, the host LAN driver software must perform eight writes to the Wake-up Frame Filter register (WUFF). The Diagram shown in Table 3.2, "Wake-Up Frame Filter Register Structure" below, shows the wake-up frame filter register's structure. - **Note 3.1** Wake-up frame detection can be performed when the LAN9210 is in the D0 or D1 power states. In the D0 state, wake-up frame detection is enabled when the WUEN bit is set. - **Note 3.2** Wake-up frame detection, as well as Magic Packet detection, is always enabled and cannot be disabled when the device enters the D1 state. - Note 3.3 When wake-up frame detection is enabled via the WUEN bit of the WUCSR—Wake-up Control and Status Register, a broadcast wake-up frame will wake-up the device despite the state of the Disable Broadcast Frame (BCAST) bit in the MAC\_CR—MAC Control Register.