KSZ8852HLE Two-Port 10/100 Mb/s Ethernet Switch with 8 or 16-Bit Host Interface Revision 1.1 General Description The KSZ8852 product line consists of industrial capable Ethernet switches, providing integrated communication for a range of Industrial Ethernet and general Ethernet applications. The KSZ8852 product enables distributed, daisy-chained topologies preferred for industrial Ethernet networks. Conventional centralized (i.e., star-wired) topologies are also supported for fault tolerant arrangements. A flexible 8 or 16-bit general bus interface is provided for interfacing to an external host processor. The wire-speed, store-and-forward switching fabric provides a full complement of QoS and congestion control features optimized for real-time Ethernet. The KSZ8852 product is built upon Micrel’s industryleading Ethernet technology, with features designed to offload host processing and streamline your overall design: • Wire-speed Ethernet switching fabric with extensive filtering • Two integrated 10/100BASE-TX PHY transceivers, featuring the industry’s lowest power consumption • Full-featured QoS support • Flexible management options that support common standard interfaces A robust assortment of power management features including energy-efficient Ethernet (EEE) have been designed in to satisfy energy-efficient environments. Datasheets and support documentation are available on Micrel’s web site at: www.micrel.com. KSZ8852 Top Level Architecture LinkMD is a registered trademark of Micrel, Inc. ETHERSYNCH is a trademark of Micrel, Inc. Magic Packet is a registered trademark of Advanced Micro Devices, Inc. Micrel Inc. • 2180 Fortune Drive • San Jose, CA 95131 • USA • tel +1 (408) 944-0800 • fax + 1 (408) 474-1000 • http://www.micrel.com August 31, 2015 Revision 1.1 Micrel, Inc. KSZ8852HLE Functional Diagram KSZ8852HLE Functional Diagram August 31, 2015 2 Revision 1.1 Micrel, Inc. KSZ8852HLE Features Advanced Switch Capabilities • Non-blocking store-and-forward switch fabric assures fast packet delivery by utilizing 1024 entry forwarding table • IEEE 802.1Q VLAN for up to 16 groups with a full range of VLAN IDs • IEEE 802.1p/Q tag insertion or removal on a per-port basis (egress) and support double-tagging • VLAN ID tag/untag options on per port basis • Fully compliant with IEEE 802.3 / 802.3u standards • IEEE 802.3x full-duplex with force mode option and half−duplex backpressure collision flow control • IEEE 802.1w rapid spanning tree protocol support • IGMP v1/v2/v3 snooping for multicast packet filtering • QoS/CoS packets prioritization support: 802.1p, DiffServ-based and re-mapping of 802.1p priority field per port basis on four priority levels • IPv4/IPv6 QoS support • IPv6 multicast listener discovery (MLD) snooping support • Programmable rate limiting at the ingress and egress ports • Broadcast storm protection • 1K entry forwarding table with 32K frame buffer • 4 priority queues with dynamic packet mapping for IEEE 802.1P, IPv4 TOS (DIFFSERV), IPv6 Traffic Class, etc. • Source address filtering for implementing ring topologies Management Capabilities • The KSZ8852 includes all the functions of a 10/100BASE-T/TX switch system which combines a switch engine, frame buffer management, address look−up table, queue management, MIB counters, media access controllers (MAC) and PHY transceivers • Non-blocking store-and-forward switch fabric assures fast packet delivery by utilizing 1024 entry forwarding table • Port mirroring/monitoring/sniffing: ingress and/or egress traffic to any port • MIB counters for fully compliant statistics gathering − 34 counters per port • Loopback modes for remote failure diagnostics • Rapid spanning tree protocol support (RSTP) for topology management and ring/linear recovery Robust PHY Ports • Two integrated IEEE 802.3 / 802.3u compliant Ethernet transceivers supporting 10BASE-T and 100BASE-TX • On-chip termination resistors and internal biasing for differential pairs to reduce power • HP Auto MDI/MDI-X™ crossover support eliminating the need to differentiate between straight or crossover cables in applications MAC Ports • Three internal media access control (MAC) units • 2Kbyte Jumbo packet support • Tail tagging mode (one byte added before FCS) support at Port 3 to inform the processor which ingress port receives the packet and its priority • Programmable MAC addresses for Port 1 and Port 2 and self-address filtering support • MAC filtering function to filter or forward unknown unicast packets Comprehensive Configuration Registers Access • Complete register access via the parallel Host Interface • Facility to load MAC Address from EEPROM at power up and reset time • I/O Pin Strapping facility to set certain register bits from I/O pins at reset time • Control registers configurable on-the-fly Host Interface • Selectable 8- or 16-bit wide interface • Supports Big- and Little-endian processors • Indirect data bus for data, address and byte enable to access any I/O registers and RX/TX FIFO buffers • Large internal memory with 12KByte for RX FIFO and 6Kbytes for TX FIFO. • Programmable low, high and overrun water marks for flow control in RX FIFO • Efficient architecture design with configurable host interrupt schemes to minimize host CPU overhead and utilization • Queue management unit (QMU) supervises data transfers across this interface August 31, 2015 3 Revision 1.1 Micrel, Inc. KSZ8852HLE Power and Power Management Packaging • Single 3.3V power supply with optional VDD I/O for 1.8V, 2.5V or 3.3V • Integrated low-voltage (~1.3V) low-noise regulator (LDO) output for digital and analog core power • Supports IEEE P802.3az™ Energy Efficient Ethernet (EEE) to reduce power consumption in transceivers in LPI state • Full-chip hardware or software power down (all registers value are not saved and strap-in value will re-strap after release the power down) • Energy detect power down (EDPD), which disables the PHY transceiver when cables are removed • Wake On LAN supported with configurable packet control • Dynamic clock tree control to reduce clocking in areas not in use • Power consumption less than 0.5W • Commercial Temperature Range: 0°C to +70°C and Extended Industrial Temperature Ranges: –40°C to +105°C and –40°C to +115°C • 64−pin (10mm × 10mm) lead free (ROHS) LQFP package with heat exposed ground paddle for low thermal resistance • 0.11µm technology for lower power consumption Target Applications • • • • • General and Industrial Ethernet applications Wireless LAN Access Point and Gateway Set top / Game box Test and measurement equipment Automotive Additional Features • Single 25MHz +50ppm reference clock requirement • Comprehensive programmable two LED indicators support for link, activity, full/half duplex and 10/100 speed August 31, 2015 4 Revision 1.1 Micrel, Inc. KSZ8852HLE Ordering Information Temperature Range Package Lead Finish KSZ8852HLECA 0°C to +70°C 64−Pin 10mm×10mm LQFP with exposed pad Sn Commercial Temperature Range Switch KSZ8852HLEWA −40°C to +105°C 64−Pin 10mm×10mm LQFP with exposed pad Sn Extended (105°C) Industrial Temperature Range Switch KSZ8852HLEYA −40°C to +115°C 64−Pin 10mm×10mm LQFP with exposed pad Sn Extended (115°C) Industrial Temperature Range Switch Part Number (1) KSZ8852HLE-EVAL Description KSZ8852 Evaluation Board Note: 1. Contact Micrel for availability. Revision History Revision Date Summary of Changes 1.0 11/21/13 Initial Draft 1.1 8/31/15 Cleanup: part number on first page; remove table from last page. August 31, 2015 5 Revision 1.1 Micrel, Inc. KSZ8852HLE Contents General Description ................................................................................................................................................................ 1 Functional Diagram ................................................................................................................................................................. 2 Features .................................................................................................................................................................................. 3 Management Capabilities .................................................................................................................................................... 3 Robust PHY Ports ............................................................................................................................................................... 3 MAC Ports ........................................................................................................................................................................... 3 Advanced Switch Capabilities ............................................................................................................................................. 3 Comprehensive Configuration Registers Access ................................................................................................................ 3 Host Interface ...................................................................................................................................................................... 3 Power and Power Management .......................................................................................................................................... 4 Additional Features .............................................................................................................................................................. 4 Packaging ............................................................................................................................................................................ 4 Target Applications .............................................................................................................................................................. 4 Ordering Information ............................................................................................................................................................... 5 Revision History ...................................................................................................................................................................... 5 Contents .................................................................................................................................................................................. 6 List of Figures ........................................................................................................................................................................ 13 List of Tables ......................................................................................................................................................................... 14 Acronyms .............................................................................................................................................................................. 15 Pin Configuration ................................................................................................................................................................... 17 Pin Description ...................................................................................................................................................................... 18 Strapping Options ................................................................................................................................................................. 23 Functional Description ........................................................................................................................................................... 24 Direction Terminology ........................................................................................................................................................... 24 Physical (PHY) Block ............................................................................................................................................................ 25 100BASE-TX Transmit ...................................................................................................................................................... 25 100BASE−TX Receive ...................................................................................................................................................... 25 Scrambler/De−Scrambler (100BASE−TX Only) ................................................................................................................ 25 PLL Clock Synthesizer (Recovery) .................................................................................................................................... 25 10BASE-T Receive ............................................................................................................................................................ 25 MDI/MDI−X Auto Crossover .................................................................................................................................................. 26 Straight Cable ................................................................................................................................................................ 26 Crossover Cable ............................................................................................................................................................ 27 Auto Negotiation .................................................................................................................................................................... 28 ® LinkMD Cable Diagnostics .................................................................................................................................................. 29 Access............................................................................................................................................................................ 29 Usage ............................................................................................................................................................................. 29 On−Chip Termination Resistors ........................................................................................................................................ 29 Loopback Support ............................................................................................................................................................. 30 Far-End Loopback ......................................................................................................................................................... 30 Near−End (Remote) Loopback ...................................................................................................................................... 30 Media Access Controller (MAC) Block .................................................................................................................................. 31 Mac Operation ................................................................................................................................................................... 31 Address Lookup ................................................................................................................................................................. 31 Learning ............................................................................................................................................................................. 31 Migration ............................................................................................................................................................................ 31 Aging .................................................................................................................................................................................. 31 Forwarding ......................................................................................................................................................................... 31 Inter Packet Gap (IPG) ...................................................................................................................................................... 34 Back-Off Algorithm ............................................................................................................................................................ 34 Late Collision ..................................................................................................................................................................... 34 Legal Packet Size .............................................................................................................................................................. 34 Flow Control....................................................................................................................................................................... 34 Half-Duplex Backpressure ................................................................................................................................................. 34 Broadcast Storm Protection............................................................................................................................................... 35 Port Individual MAC Address and Source Port Filtering ................................................................................................... 35 August 31, 2015 6 Revision 1.1 Micrel, Inc. KSZ8852HLE Address Filtering Function ................................................................................................................................................. 35 Switch Block .......................................................................................................................................................................... 37 Switching Engine ............................................................................................................................................................... 37 Spanning Tree Support ..................................................................................................................................................... 37 Rapid Spanning Tree Support ........................................................................................................................................... 38 Discarding State ............................................................................................................................................................. 38 Learning State ................................................................................................................................................................ 38 Forwarding State ............................................................................................................................................................ 38 Tail Tagging Mode ......................................................................................................................................................... 38 IGMP Support .................................................................................................................................................................... 39 “IGMP” Snooping ........................................................................................................................................................... 39 “Multicast Address Insertion” in the Static MAC Table .................................................................................................. 39 IPv6 MLD Snooping ....................................................................................................................................................... 39 Port Mirroring Support ....................................................................................................................................................... 40 “Receive Only” Mirror-on-a-Port .................................................................................................................................... 40 “Transmit Only” Mirror-on-a-Port ................................................................................................................................... 40 “Receive and Transmit” Mirror-on-Two-Ports ................................................................................................................ 40 IEEE 802.1Q VLAN Support.............................................................................................................................................. 40 QoS Priority Support .......................................................................................................................................................... 41 Port-Based Priority ............................................................................................................................................................ 41 802.1p-Based Priority ........................................................................................................................................................ 41 802.1p Priority Field Re-mapping ...................................................................................................................................... 42 DiffServ-Based Priority ...................................................................................................................................................... 42 Rate-Limiting Support ........................................................................................................................................................ 42 MAC Address Filtering Function ........................................................................................................................................ 42 Queue Management Unit (QMU) .......................................................................................................................................... 43 Transmit Queue (TXQ) Frame Format .............................................................................................................................. 43 Frame Transmitting Path Operation in TXQ ...................................................................................................................... 44 Driver Routine for Transmitting Packets from Host Processor to KSZ8852 ..................................................................... 45 Receive Queue (RXQ) Frame Format............................................................................................................................... 46 Frame Receiving Path Operation in RXQ ......................................................................................................................... 46 Driver Routine for Receiving Packets from the KSZ8852 to the Host Processor ............................................................. 47 Device Clocks........................................................................................................................................................................ 48 Power .................................................................................................................................................................................... 49 Internal Low Voltage LDO Regulator .................................................................................................................................... 50 Power Management .............................................................................................................................................................. 51 Normal Operation Mode .................................................................................................................................................... 51 Energy Detect Mode .......................................................................................................................................................... 51 Global Soft Power-Down Mode ......................................................................................................................................... 52 Energy-Efficient Ethernet (EEE) ........................................................................................................................................ 52 Wake-On-LAN ................................................................................................................................................................... 53 Detection of Energy ........................................................................................................................................................... 53 Detection of Linkup ............................................................................................................................................................ 53 Wake-Up Packet ................................................................................................................................................................ 53 Magic Packet™ ................................................................................................................................................................. 53 Interrupt Generation on Power Management Related Events ....................................................................................... 54 To Generate an Interrupt on the PME Signal Pin .......................................................................................................... 54 To Generate an Interrupt on the INTRN Signal Pin ....................................................................................................... 54 Interfaces............................................................................................................................................................................... 55 Bus Interface Unit (BIU) / Host Interface ........................................................................................................................... 55 Supported Transfers ...................................................................................................................................................... 55 Physical Data Bus Size .................................................................................................................................................. 55 Little and Big Endian Support ........................................................................................................................................ 56 Asynchronous Interface ................................................................................................................................................. 56 BIU Summary................................................................................................................................................................. 57 Serial EEPROM Interface .................................................................................................................................................. 58 Device Registers ................................................................................................................................................................... 59 August 31, 2015 7 Revision 1.1 Micrel, Inc. KSZ8852HLE Register Map of CPU Accessible I/O Registers .................................................................................................................... 61 I/O Registers ...................................................................................................................................................................... 61 Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF)....................................... 61 Internal I/O Register Space Mapping for Host Interface Unit (0x100 - 0x16F) .............................................................. 67 Internal I/O Register Space Mapping for the QMU (0x170 − 0x1FF) ............................................................................ 69 Special Control Registers (0x700 − 0x7FF) ................................................................................................................... 71 Register Bit Definitions .......................................................................................................................................................... 72 Internal I/O Register Mapping for Switch Control and Configuration (0x000 - 0x0FF)...................................................... 72 Chip ID and Enable Register (0x00 - 0x001): CIDER .................................................................................................... 72 Switch Global Control Register 1 (0x002 - 0x003): SGCR1 .............................................................................................. 72 Switch Global Control Register 2 (0x004 – 0x005): SGCR2 ............................................................................................. 74 Switch Global Control Register 3 (0x006 - 0x007): SGCR3 .............................................................................................. 75 0x008 – 0x00B: Reserved ................................................................................................................................................. 75 Switch Global Control Register 6 (0x00C - 0x00D): SGCR6 ............................................................................................ 76 Switch Global Control Register 7 (0x00E - 0x00F): SGCR7 ............................................................................................. 77 MAC Address Register 1 (0x010 - 0x011): MACAR1........................................................................................................ 78 MAC Address Register 2 (0x012 - 0x013): MACAR2........................................................................................................ 78 MAC Address Register 3 (0x014 - 0x015): MACAR3........................................................................................................ 78 Type-of-Service (TOS) Priority Control Registers ................................................................................................................. 79 TOS Priority Control Register 1 (0x016-– 0x017): TOSR1 ............................................................................................... 79 TOS Priority Control Register 2 (0x018 - 0x019): TOSR2 ................................................................................................ 80 TOS Priority Control Register 3 (0x01A - 0x01B): TOSR3 ................................................................................................ 81 TOS Priority Control Register 4 (0x01C - 0x1D): TOSR4 ................................................................................................. 81 TOS Priority Control Register 5 (0x01E - 0x1F): TOSR5 .................................................................................................. 82 TOS Priority Control Register 6 (0x020 - 0x021): TOSR6 ................................................................................................ 83 TOS Priority Control Register 7 (0x022 - 0x023): TOSR7 ................................................................................................ 83 TOS Priority Control Register 8 (0x024 - 0x025): TOSR8 ................................................................................................ 84 Indirect Access Data Registers ............................................................................................................................................. 85 Indirect Access Data Register 1 (0x026 - 0x027): IADR1 ................................................................................................. 85 Indirect Access Data Register 2 (0x028 - 0x029): IADR2 ................................................................................................. 85 Indirect Access Data Register 3 (0x02A - 0x02B): IADR3 ................................................................................................ 85 Indirect Access Data Register 4 (0x02C - 0x02D): IADR4 ................................................................................................ 85 Indirect Access Data Register 5 (0x02E - 0x02F): IADR5 ................................................................................................ 86 Indirect Access Control Register (0x030 - 0x031): IACR .................................................................................................. 86 Power Management Control and Wake-Up Event Status ..................................................................................................... 87 Power Management Control and Wake-Up Event Status (0x032 – 0x033): PMCTRL ..................................................... 87 Power Management Event Enable Register (0x034 - 0x035): PMEE ............................................................................... 88 Go Sleep Time and Clock Tree Power-Down Control Registers .......................................................................................... 89 Go Sleep Time Register (0x036 - 0x037): GST ................................................................................................................ 89 Clock Tree Power-Down Control Register (0x038 - 0x039): CTPDC................................................................................ 89 0x03A – 0x04B: Reserved ................................................................................................................................................. 89 PHY and MII Basic Control Registers ................................................................................................................................... 90 PHY 1 and MII Basic Control Register (0x04C-– 0x04D): P1MBCR................................................................................. 90 PHY 1 and MII Basic Status Register (0x04E - 0x04F): P1MBSR .................................................................................... 91 PHY 1 PHYID Low Register (0x050 - 0x051): PHY1ILR ................................................................................................... 92 PHY 1 PHYID High Register (0x052 - 0x053): PHY1IHR ................................................................................................. 92 PHY 1 Auto-Negotiation Advertisement Register (0x054 - 0x055): P1ANAR ................................................................... 93 PHY 1 Auto−Negotiation Link Partner Ability Register (0x056 - 0x057): P1ANLPR ......................................................... 94 PHY 2 and MII Basic Control Register (0x058 - 0x059): P2MBCR ................................................................................... 94 PHY 2 and MII Basic Status Register (0x05A - 0x05B): P2MBSR.................................................................................... 96 PHY2 PHYID Low Register (0x05C - 0x05D): PHY2ILR .................................................................................................. 97 PHY 2 PHYID High Register (0x05E - 0x05F): PHY2IHR ................................................................................................. 97 PHY 2 Auto-Negotiation Advertisement Register (0x060 - 0x061): P2ANAR ................................................................... 97 PHY 2 Auto-Negotiation Link Partner Ability Register (0x062 -0x063): P2ANLPR ........................................................... 98 0x0x064 - 0x065: Reserved............................................................................................................................................... 98 PHY1 Special Control and Status Register (0x066 - 0x067): P1PHYCTRL ..................................................................... 98 0x068 –-0x069: Reserved ................................................................................................................................................. 98 August 31, 2015 8 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY2 Special Control and Status Register (0x06A - 0x06B): P2PHYCTRL .................................................................... 99 Port 1 Control Registers ...................................................................................................................................................... 100 Port 1 Control Register 1 (0x06C - 0x06D): P1CR1 ........................................................................................................ 100 Port 1 Control Register 2 (0x06E - 0x06F): P1CR2 ........................................................................................................ 102 Port 1 VID Control Register (0x070 - 0x071): P1VIDCR ................................................................................................. 103 Port 1 Control Register 3 (0x072 - 0x073): P1CR3 ......................................................................................................... 103 Port 1 Ingress Rate Control Register 0 (0x074 - 0x075): P1IRCR0 ................................................................................ 104 Port 1 Ingress Rate Control Register 1 (0x076 - 0x077): P1IRCR1 ................................................................................ 105 Port 1 Egress Rate Control Register 0 (0x078 - 0x079): P1ERCR0 ............................................................................... 105 Port 1 Egress Rate Control Register 1 (0x07A - 0x07B): P1ERCR1 .............................................................................. 105 Port 1 PHY Special Control/Status, LinkMD (0x07C - 0x07D): P1SCSLMD .................................................................. 106 Port 1 Control Register 4 (0x07E - 0x07F): P1CR4 ........................................................................................................ 107 Port 1 Status Register (0x080 - 0x081): P1SR................................................................................................................ 108 0x082 - 0x083: Reserved ................................................................................................................................................ 109 Port 2 Control Registers ...................................................................................................................................................... 110 Port 2 Control Register 1 (0x084 - 0x085): P2CR1 ......................................................................................................... 110 Port 2 Control Register 2 (0x086 - 0x087): P2CR2 ......................................................................................................... 112 Port 2 VID Control Register (0x088 - 0x089): P2VIDCR ................................................................................................. 113 Port 2 Control Register 3 (0x08A-0x08B): P2CR3 .......................................................................................................... 113 Port 2 Ingress Rate Control Register 0 (0x08C - 0x08D): P2IRCR0............................................................................... 114 Port 2 Ingress Rate Control Register 1 (0x08E - 0x08F): P2IRCR1 ............................................................................... 114 Port 2 Egress Rate Control Register 0 (0x090 - 0x091): P2ERCR0 ............................................................................... 115 Port 2 Egress Rate Control Register 1 (0x092 – 0x093): P2ERCR1 .............................................................................. 115 Port 2 PHY Special Control/Status, LinkMD (0x094 - 0x095): P2SCSLMD .................................................................... 116 Port 2 Control Register 4 (0x096 - 0x097): P2CR4 ......................................................................................................... 117 Port 2 Status Register (0x098 - 0x099): P2SR................................................................................................................ 119 0x09A – 0x09B: Reserved ............................................................................................................................................... 120 Port 3 Control Registers ...................................................................................................................................................... 121 Port 3 Control Register 1 (0x09C - 0x09D): P3CR1 ........................................................................................................ 121 Port 3 Control Register 2 (0x09E - 0x09F): P3CR2 ........................................................................................................ 122 Port 3 VID Control Register (0x0A0 - 0x0A1): P3VIDCR ................................................................................................ 123 Port 3 Control Register 3 (0x0A2 - 0x0A3): P3CR3 ........................................................................................................ 123 Port 3 Ingress Rate Control Register 0 (0x0A4 - 0x0A5): P3IRCR0 ............................................................................... 124 Port 3 Ingress Rate Control Register 1 (0x0A6 - 0x0A7): P3IRCR1 ............................................................................... 124 Port 3 Egress Rate Control Register 0 (0x0A8 - 0x0A9): P3ERCR0 .............................................................................. 124 Port 3 Egress Rate Control Register 1 (0x0AA - 0x0AB): P3ERCR1 ............................................................................. 125 Switch Global Control Registers ......................................................................................................................................... 126 Switch Global Control Register 8 (0x0AC - 0x0AD): SGCR8 .......................................................................................... 126 Switch Global Control Register 9 (0x0AE - 0x0AF): SGCR9 .......................................................................................... 127 Source Address Filtering Registers .................................................................................................................................... 128 Source Address Filtering MAC Address 1 Register Low (0x0B0 - 0x0B1): SAFMACA1L .............................................. 128 Source Address Filtering MAC Address 1 Register Middle (0x0B2 - 0x0B3): SAFMACA1M ......................................... 128 Source Address Filtering MAC Address 1 Register High (0x0B4 - 0x0B5): SAFMACA1H............................................. 128 Source Address Filtering MAC Address 2 Register Low (0x0B6 - 0x0B7): SAFMACA2L .............................................. 128 Source Address Filtering MAC Address 2 Register Middle (0x0B8 - 0x0B9): SAFMACA2M ......................................... 128 Source Address Filtering MAC Address 2 Register High (0x0BA - 0x0BB): SAFMACA2H ............................................ 128 0x0BC - 0x0C7: Reserved ............................................................................................................................................... 128 TXQ Rate Control Registers ............................................................................................................................................... 129 Port 1 TXQ Rate Control Register 1 (0x0C8 - 0x0C9): P1TXQRCR1............................................................................. 129 Port 1 TXQ Rate Control Register 2 (0x0CA - 0x0CB): P1TXQRCR2 ............................................................................ 129 Port 2 TXQ Rate Control Register 1 (0x0CC - 0x0CD): P2TXQRCR1 ........................................................................... 130 Port 2 TXQ Rate Control Register 2 (0x0CE - 0x0CF): P2TXQRCR2 ............................................................................ 130 Port 3 TXQ Rate Control Register 1 (0x0D0 - 0x0D1): P3TXQRCR1............................................................................. 131 Port 3 TXQ Rate Control Register 2 (0x0D2 - 0x0D3): P3TXQRCR2............................................................................. 131 0x0D4 - 0x0DB: Reserved ............................................................................................................................................... 131 Auto-Negotiation Next Page Registers ............................................................................................................................... 132 Port 1 Auto-Negotiation Next Page Transmit Register (0x0DC - 0x0DD): P1ANPT ....................................................... 132 August 31, 2015 9 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Auto-Negotiation Link Partner Received Next Page Register (0x0DE - 0x0DF): P1ALPRNP ............................. 133 EEE and Link Partner Advertisement Registers ................................................................................................................. 134 Port 1 EEE and Link Partner Advertisement Register (0x0E0 – 0x0E1): P1EEEA ......................................................... 134 Port 1 EEE Wake Error Count Register (0x0E2 - 0x0E3): P1EEEWEC ......................................................................... 135 Port 1 EEE Control/Status and Auto-Negotiation Expansion Register (0x0E4 - 0x0E5): P1EEECS.............................. 135 Port 1 LPI Recovery Time Counter Register (0x0E6): P1LPIRTC .................................................................................. 137 Buffer Load to LPI Control 1 Register (0x0E7): BL2LPIC1 ............................................................................................. 137 Port 2 Auto−Negotiation Next Page Transmit Register (0x0E8 - 0x0E9): P2ANPT ....................................................... 137 Port 2 Auto-Negotiation Link Partner Received Next Page Register (0x0EA - 0x0EB): P2ALPRNP ............................. 138 Port 2 EEE and Link Partner Advertisement Register (0x0EC - 0x0ED): P2EEEA ........................................................ 138 Port 2 EEE Wake Error Count Register (0x0EE - 0x0EF): P2EEEWEC......................................................................... 139 Port 2 EEE Control/Status and Auto-Negotiation Expansion Register (0x0F0 - 0x0F1): P2EEECS .............................. 140 Port 2 LPI Recovery Time Counter Register (0x0F2): P2LPIRTC .................................................................................. 141 PCS EEE Control Register (0x0F3): PCSEEEC ............................................................................................................. 142 Empty TXQ to LPI Wait Time Control Register (0x0F4 - 0x0F5): ETLWTC.................................................................... 142 Buffer Load to LPI Control 2 Register (0x0F6 - 0x0F7): BL2LPIC2 ................................................................................ 142 0x0F8 - 0x0FF: Reserved ................................................................................................................................................ 142 Internal I/O Register Space Mapping for Interrupts, BIU, and Global Reset (0x100 - 0x1FF)........................................... 143 0x100 - 0x107: Reserved ................................................................................................................................................ 143 Chip Configuration Register (0x108 - 0x109): CCR ........................................................................................................ 143 0x10A - 0x10F: Reserved ................................................................................................................................................ 143 Host MAC Address Registers: MARL, MARM and MARH ................................................................................................. 144 Host MAC Address Register Low (0x110 - 0x111): MARL ............................................................................................. 144 Host MAC Address Register Middle (0x112 - 0x113): MARM ........................................................................................ 144 Host MAC Address Register High (0x114 - 0x115): MARH ............................................................................................ 144 0x116 - 0x121: Reserved ................................................................................................................................................ 144 EEPROM Control Register (0x122 - 0x123): EEPCR ..................................................................................................... 145 Memory BIST Info Register (0x124 - 0x125): MBIR ........................................................................................................ 145 Global Reset Register (0x126 - 0x127): GRR ................................................................................................................. 146 0x128 - 0x129: Reserved ................................................................................................................................................ 146 Wake-Up Frame Control Register (0x12A - 0x12B): WFCR ........................................................................................... 147 0x12C - 0x12F: Reserved................................................................................................................................................ 147 Wake-Up Frame 0 CRC0 Register (0x130 - 0x131): WF0CRC0 .................................................................................... 147 Wake-Up Frame 0 CRC1 Register (0x132- 0x133): WF0CRC1 ..................................................................................... 148 Wake-Up Frame 0 Byte Mask 0 Register (0x134 - 0x135): WF0BM0 ............................................................................ 148 Wake-Up Frame 0 Byte Mask 1 Register (0x136 - 0x137): WF0BM1 ............................................................................ 148 Wake-Up Frame 0 Byte Mask 2 Register (0x138 - 0x139): WF0BM2 ............................................................................ 148 Wake-Up Frame 0 Byte Mask 3 Register (0x13A - 0x13B): WF0BM3............................................................................ 148 0x13C – 0x13F: Reserved ............................................................................................................................................... 148 Wake-Up Frame 1 CRC0 Register (0x140 – 0x141): WF1CRC0 ................................................................................... 149 Wake-Up Frame 1 CRC1 Register (0x142 – 0x143): WF1CRC1 ................................................................................... 149 Wake-Up Frame 1 Byte Mask 0 Register (0x144 – 0x145): WF1BM0............................................................................ 149 Wake-Up Frame 1 Byte Mask 1 Register (0x146 – 0x147): WF1BM1............................................................................ 149 Wake-Up Frame 1 Byte Mask 2 Register (0x148 – 0x149): WF1BM2............................................................................ 150 Wake-Up Frame 1 Byte Mask 3 Register (0x14A – 0x14B): WF1BM3 ........................................................................... 150 0x14C – 0x14F: Reserved ............................................................................................................................................... 150 Wake-Up Frame 2 CRC0 Register (0x150 – 0x151): WF2CRC0 ................................................................................... 150 Wake-Up Frame 2 CRC1 Register (0x152 – 0x153): WF2CRC1 ................................................................................... 150 Wake-Up Frame 2 Byte Mask 0 Register (0x154 – 0x155): WF2BM0............................................................................ 150 Wake-Up Frame 2 Byte Mask 1 Register (0x156 – 0x157): WF2BM1............................................................................ 151 Wake-Up Frame 2 Byte Mask 2 Register (0x158 – 0x159): WF2BM2............................................................................ 151 Wake-Up Frame 2 Byte Mask 3 Register (0x15A – 0x15B): WF2BM3 ........................................................................... 151 0x15C – 0x15F: Reserved ............................................................................................................................................... 151 Wake-Up Frame 3 CRC0 Register (0x160 – 0x161): WF3CRC0 ................................................................................... 152 Wake-Up Frame 3 CRC1 Register (0x162 – 0x163): WF3CRC1 ................................................................................... 152 Wake-Up Frame 3 Byte Mask 0 Register (0x164 – 0x165): WF3BM0............................................................................ 152 Wake-Up Frame 3 Byte Mask 1 Register (0x166 – 0x167): WF3BM1............................................................................ 152 August 31, 2015 10 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 3 Byte Mask 2 Register (0x168 – 0x169): WF3BM2............................................................................ 152 Wake-Up Frame 3 Byte Mask 3 Register (0x16A - 0x16B): WF3BM3............................................................................ 153 0x16C – 0x16F: Reserved ............................................................................................................................................... 153 Internal I/O Register Space Mapping for the Queue Management Unit (QMU) (0x170 - 0x1FF) ..................................... 154 Transmit Control Register (0x170 - 0x171): TXCR ......................................................................................................... 154 Transmit Status Register (0x172 - 0x173): TXSR ........................................................................................................... 155 Receive Control Register 1 (0x174 - 0x175): RXCR1 ..................................................................................................... 155 Receive Control Register 2 (0x176 - 0x177): RXCR2 ..................................................................................................... 156 TXQ Memory Information Register (0x178 - 0x179): TXMIR .......................................................................................... 157 0x17A - 0x17B: Reserved................................................................................................................................................ 157 Receive Frame Header Status Register (0x17C - 0x17D): RXFHSR ............................................................................. 157 Receive Frame Header Byte Count Register (0x17E - 0x17F): RXFHBCR ................................................................... 158 TXQ Command Register (0x180 - 0x181): TXQCR ........................................................................................................ 159 RXQ Command Register (0x182 - 0x183): RXQCR ....................................................................................................... 159 TX Frame Data Pointer Register (0x184 - 0x185): TXFDPR .......................................................................................... 160 RX Frame Data Pointer Register (0x186 - 0x187): RXFDPR ......................................................................................... 161 0x188 - 0x18B: Reserved ................................................................................................................................................ 161 RX Duration Timer Threshold Register (0x18C - 0x18D): RXDTTR ............................................................................... 161 RX Data Byte Count Threshold Register (0x18E - 0x18F): RXDBCTR .......................................................................... 161 Internal I/O Register Space Mapping for Interrupt Registers (0x190 - 0x193) ................................................................... 162 Interrupt Enable Register (0x190 - 0x191): IER .............................................................................................................. 162 Interrupt Status Register (0x192-– 0x193): ISR .............................................................................................................. 163 0x194 - 0x19B: Reserved ................................................................................................................................................ 164 Internal I/O Register Space Mapping for the Queue Management Unit (QMU) (0x19C - 0x1B9) ..................................... 165 RX Frame Count and Threshold Register (0x19C -0x19D): RXFCTR ............................................................................ 165 TX Next Total Frames Size Register (0x19E - 0x19F): TXNTFSR ................................................................................. 165 MAC Address Hash Table Register 0 (0x1A0 - 0x1A1): MAHTR0 ................................................................................. 165 Multicast Table Register 0 ........................................................................................................................................... 165 MAC Address Hash Table Register 1 (0x1A2 - 0x1A3): MAHTR1 ................................................................................. 166 Multicast Table Register 1 ........................................................................................................................................... 166 MAC Address Hash Table Register 2 (0x1A4 - 0x1A5): MAHTR2 ................................................................................. 166 Multicast Table Register 2 ........................................................................................................................................... 166 MAC Address Hash Table Register 3 (0x1A6 - 0x1A7): MAHTR3 ................................................................................. 166 Multicast Table Register 3 ........................................................................................................................................... 166 0x1A8 - 0x1AF: Reserved ............................................................................................................................................... 166 Flow Control Low Water Mark Register (0x1B0 - 0x1B1): FCLWR................................................................................. 166 Flow Control High Water Mark Register (0x1B2 - 0x1B3): FCHWR ............................................................................... 167 Flow Control Overrun Water Mark Register (0x1B4 - 0x1B5): FCOWR ......................................................................... 167 0x1B6 - 0x1B7: Reserved RX Frame Count Register (0x1B8 - 0x1B9): RXFC .............................................................. 167 0x1BA - 0x747: Reserved................................................................................................................................................ 168 Analog Control 1 Register (0x748 - 0x749): ANA_CNTRL_1 ......................................................................................... 168 0x74A - 0x74B: Reserved................................................................................................................................................ 168 Analog Control 3 Register (0x74C - 0x74D): ANA_CNTRL_3 ........................................................................................ 168 0x74E - 0x7FF: Reserved................................................................................................................................................ 168 Management Information Base (MIB) Counters ................................................................................................................. 169 MIB Counter Examples:................................................................................................................................................... 171 Additional MIB Information .............................................................................................................................................. 171 Static MAC Address Table .................................................................................................................................................. 172 Static MAC Table Lookup Examples: .............................................................................................................................. 173 Dynamic MAC Address Table ............................................................................................................................................. 174 Dynamic MAC Address Lookup Example: ...................................................................................................................... 174 VLAN Table ......................................................................................................................................................................... 175 VLAN Table Lookup Examples:....................................................................................................................................... 175 (2) Absolute Maximum Ratings .............................................................................................................................................. 176 (3) Operating Ratings ............................................................................................................................................................ 176 (5) Electrical Characteristics .................................................................................................................................................. 176 Timing Specifications .......................................................................................................................................................... 181 August 31, 2015 11 Revision 1.1 Micrel, Inc. KSZ8852HLE Host Interface Read / Write Timing ................................................................................................................................. 181 Auto−Negotiation Timing ................................................................................................................................................. 182 Serial EEPROM Interface Timing .................................................................................................................................... 183 Reset Timing and Power Sequencing ................................................................................................................................. 184 Reset Circuit Guidelines ...................................................................................................................................................... 185 Reference Circuits – LED Strap-In Pins .............................................................................................................................. 186 Reference Clock – Connection and Selection .................................................................................................................... 187 Selection of Reference Crystal............................................................................................................................................ 187 Selection of Isolation Transformers..................................................................................................................................... 188 (11) Package Information and Recommended Landing Pattern ............................................................................................ 189 August 31, 2015 12 Revision 1.1 Micrel, Inc. KSZ8852HLE List of Figures Figure 1. Typical Straight Cable Connection ........................................................................................................................ 26 Figure 2. Typical Crossover Cable Connection .................................................................................................................... 27 Figure 3. Auto-Negotiation and Parallel Operation ............................................................................................................... 28 Figure 4. Near-End and Far-End Loopback .......................................................................................................................... 30 Figure 5. Destination Address Lookup Flow Chart in Stage One ......................................................................................... 32 Figure 6. Destination Address Resolution Flow Chart in Stage Two .................................................................................... 33 Figure 7. Tail Tag Frame Format .......................................................................................................................................... 38 Figure 8. 802.1p Priority Field Format .................................................................................................................................. 41 Figure 9. Host TX Single Frame in Manual Enqueue Flow Diagram .................................................................................... 45 Figure 10. Host RX Single or Multiple Frames in Auto-Dequeue Flow Diagram .................................................................. 47 Figure 11. Recommended Low-Voltage Power Connection using an External Low-Voltage-Regulator .............................. 49 Figure 12. Recommended Low-Voltage Power Connections using the Internal Low-Voltage Regulator ............................ 50 Figure 13. Traffic Activity and EEE ....................................................................................................................................... 52 Figure 14. KSZ8852 8-Bit and 16-Bit Data Bus Connections ............................................................................................... 57 Figure 15. Interface and Register Mapping........................................................................................................................... 59 Figure 16. Host Interface Read/Write Timing...................................................................................................................... 181 Figure 17. Auto-Negotiation Timing .................................................................................................................................... 182 Figure 18. Serial EEPROM Timing ..................................................................................................................................... 183 Figure 19. KSZ8852 Reset and Power Sequence Timing .................................................................................................. 184 Figure 20. Sample Reset Circuit ......................................................................................................................................... 185 Figure 21. Recommended Reset Circuit for Interfacing with a CPU/FPGA Reset Output ................................................. 185 Figure 22. Typical LED Strap-In Circuit .............................................................................................................................. 186 Figure 23. 25MHz Crystal and Oscillator Clock Connections ............................................................................................. 187 August 31, 2015 13 Revision 1.1 Micrel, Inc. KSZ8852HLE List of Tables Table 1. MDI/MDI-X Pin Definitions ...................................................................................................................................... 26 Table 2. MAC Address Filtering Scheme .............................................................................................................................. 36 Table 3. Spanning Tree States ............................................................................................................................................. 37 Table 4. Tail Tag Rules ......................................................................................................................................................... 39 Table 5. FID + DA Lookup in VLAN Mode ............................................................................................................................ 40 Table 6. FID + SA Lookup in VLAN Mode ............................................................................................................................ 41 Table 7. Frame Format for Transmit Queue ......................................................................................................................... 43 Table 8. Transmit Control Word Bit Fields ............................................................................................................................ 43 Table 9. Transmit Byte Count Format ................................................................................................................................... 44 Table 10. Register Setting for Transmit Function Block ....................................................................................................... 44 Table 11. Frame Format for Receive Queue ........................................................................................................................ 46 Table 12. Register Settings for Receive Function Block ....................................................................................................... 46 Table 13. KSZ8852 Device Clocks ....................................................................................................................................... 48 Table 14. Voltage Options and Requirements ...................................................................................................................... 49 Table 15. Power Management and Internal Blocks .............................................................................................................. 51 Table 16. Available Interfaces ............................................................................................................................................... 55 Table 17. Bus Interface Unit Signal Grouping....................................................................................................................... 56 Table 18. KSZ8852 Serial EEPROM Format ........................................................................................................................ 58 Table 19. Mapping of Functional Areas within the Address Space ...................................................................................... 60 Table 20. Ingress or Egress Data Rate Limits .................................................................................................................... 104 Table 21. Format of Per-Port MIB Counters ....................................................................................................................... 169 Table 22. Port 1 MIB Counters - Indirect Memory Offset .................................................................................................... 170 Table 23. "All Ports Dropped Packet" MIB Counter Format ............................................................................................... 171 Table 24. "All Ports Dropped Packet" MIB Counters− Indirect Memory Offsets................................................................. 171 Table 25. Static MAC Table Format (8 Entries) .................................................................................................................. 172 Table 26. Dynamic MAC Address Table Format (1024 Entries) ........................................................................................ 174 Table 27. VLAN Table Format (16 Entries) ......................................................................................................................... 175 Table 28. Host Interface Read/Write Timing Parameters ................................................................................................... 181 Table 29. Auto-Negotiation Timing Parameters .................................................................................................................. 182 Table 30. Serial EEPROM Timing Parameters ................................................................................................................... 183 (8, 9, 10) Table 31. Reset Timing Parameters .......................................................................................................................... 184 Table 32. Typical Reference Crystal Characteristics .......................................................................................................... 187 Table 33. Transformer Selection Criteria ............................................................................................................................ 188 Table 34. Qualified Single Port Magnetic ............................................................................................................................ 188 August 31, 2015 14 Revision 1.1 Micrel, Inc. KSZ8852HLE Acronyms BIU Bus Interface Unit The host interface function that performs code conversion, buffering, and the like required for communications to and from a network. BPDU Bridge Protocol Data Unit A packet containing ports, addresses, etc. to make sure data being passed through a bridged network arrives at its proper destination. CMOS Complementary Metal Oxide Semiconductor A common semiconductor manufacturing technique in which positive and negative types of transistors are combined to form a current gate that in turn forms an effective means of controlling electrical current through a chip. CRC Cyclic Redundancy Check A common technique for detecting data transmission errors. CRC for Ethernet is 32 bits long. CUT-THROUGH SWITCH A switch typically processes received packets by reading in the full packet (storing), then processing the packet to determine where it needs to go, then forwarding it. A cut−through switch simply reads in the first bit of an incoming packet and forwards the packet. Cut−through switches do not store the packet. DA Destination Address The address to send packets. DMA Direct Memory Access A design in which memory on a chip is controlled independently of the CPU. EMI Electromagnetic Interference A naturally occurring phenomena when the electromagnetic field of one device disrupts, impedes or degrades the electromagnetic field of another device by coming into proximity with it. In computer technology, computer devices are susceptible to EMI because electromagnetic fields are a byproduct of passing electricity through a wire. Data lines that have not been properly shielded are susceptible to data corruption by EMI. FCS Frame Check Sequence See CRC. FID Frame or Filter ID Specifies the frame identifier. Alternately is the filter identifier. IGMP Internet Group Management Protocol The protocol defined by RFC 1112 for IP multicast transmissions. IPG Inter-Packet Gap A time delay between successive data packets mandated by the network standard for protocol reasons. In Ethernet, the medium has to be "silent" (i.e., no data transfer) for a short period of time before a node can consider the network idle and start to transmit. IPG is used to correct timing differences between a transmitter and receiver. During the IPG, no data is transferred, and information in the gap can be discarded or additions inserted without impact on data integrity. ISI Inter-Symbol Interference The disruption of transmitted code caused by adjacent pulses affecting or interfering with each other. ISA Industry Standard Architecture A bus architecture used in the IBM PC/XT and PC/AT. JUMBO PACKET A packet larger than the standard Ethernet packet (1500 bytes). Large packet sizes allow for more efficient use of bandwidth, lower overhead, less processing, etc. MAC Media Access Controller A functional block responsible for implementing the Media Access Control layer which is a sub layer of the Data Link Layer. MDI Medium Dependent Interface An Ethernet port connection that allows network hubs or switches to connect to other hubs or switches without a null−modem, or crossover, cable. MDI provides the standard interface to a particular media (copper or fiber) and is therefore “media dependent”. August 31, 2015 15 Revision 1.1 Micrel, Inc. KSZ8852HLE Acronyms (Continued) MDI-X Medium Dependent Interface Crossover An Ethernet port connection that allows networked end stations (i.e., PCs or workstations) to connect to each other using a null−modem, or crossover, cable. For 10/100 full−duplex networks, an end point (such as a computer) and a switch are wired so that each transmitter connects to the far end receiver. When connecting two computers together, a cable that crosses the TX and RX is required to do this. With auto MDI−X, the PHY senses the correct TX and RX roles, eliminating any cable confusion. MIB Management Information Base The MIB comprises the management portion of network devices. This can include things like monitoring traffic levels and faults (statistical), and can also change operating parameters in network nodes (static forwarding addresses). MII Media Independent Interface The MII accesses PHY registers as defined in the IEEE 802.3 specification. NIC Network Interface Card An expansion board inserted into a computer to allow it to be connected to a network. Most NICs are designed for a particular type of network, protocol, and media, although some can serve multiple networks. NPVID Non-Port VLAN ID The port VLAN ID value is used as a VLAN reference. NRZ Non-Return to Zero A type of signal data encoding whereby the signal does not return to a zero state in between bits. PHY A device or functional block which performs the physical layer interface function in a network. PLL Phase-Locked Loop An electronic circuit that controls an oscillator so that it maintains a constant phase angle (i.e., lock) on the frequency of an input, or reference, signal. A PLL ensures that a communication signal is locked on a specific frequency and can also be used to generate, modulate, and demodulate a signal and divide a frequency. QMU Queue Management Unit Manages packet traffic between MAC/PHY interface and the system host. The QMU has built−in packet memories for receive and transmit functions called TXQ (Transmit Queue) and RXQ (Receive Queue). SA Source Address The address from which information has been sent. TDR Time Domain Reflectometry TDR is used to pinpoint flaws and problems in underground and aerial wire, cabling, and fiber optics. They send a signal down the conductor and measure the time it takes for the whole or part of the signal to return. VLAN Virtual Local Area Network A configuration of computers that acts as if all computers are connected by the same physical network but which may be located virtually anywhere. August 31, 2015 16 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Configuration 64-Pin LQFP (Top View) (Bottom paddle is GND) August 31, 2015 17 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Description Pin Number Pin Name Type Pin Function 1 RXM1 I/O Port 1 physical receive (MDI) or transmit (MDIX) signal (− differential). 2 RXP1 I/O Port 1 physical receive (MDI) or transmit (MDIX) signal (+ differential). 3 AGND GND 4 TXM1 I/O Port 1 physical transmit (MDI) or receive (MDIX) signal (− differential). 5 TXP1 I/O Port 1 physical transmit (MDI) or receive (MDIX) signal (+ differential). 6 VDD_AL P Analog Ground. This pin is used as an input for the low voltage analog power. Its source should have appropriate filtering with a ferrite bead and capacitors. Current Set 7 ISET O 8 AGND GND 9 VDD_A3.3 P 3.3V analog VDD input power supply with well decoupling capacitors. 10 RXM2 I/O Port 2 physical receive (MDI) or transmit (MDIX) signal (− differential). 11 RXP2 I/O Port 2 physical receive (MDI) or transmit (MDIX) signal (+ differential). 12 AGND GND 13 TXM2 I/O Port 2 physical transmit (MDI) or receive (MDIX) signal (− differential). 14 TXP2 I/O Port 2 physical transmit (MDI) or receive (MDIX) signal (+ differential). 15 N/U I This unused input should be connected to GND. 16 VDD_COL P This pin is used as a second input for the low voltage analog power. Its source should have appropriate filtering with a ferrite bead and capacitors. Sets the physical transmit output current. Pull-down this pin with a 6.49KΩ (1%) resistor to ground. Analog Ground. Analog Ground. Full Chip Power−Down 17 PWRDN IPU 18 X1 I 19 X2 O 20 DGND GND 21 VDD_IO P Active Low (Low = power down; High or floating = normal operation). While this pin is asserted low, all I/O pins will be tri-stated. All registers will be set to their default state. While this pin is asserted, power consumption will be minimal. When the pin is de-asserted power consumption will climb to nominal and the device will be in the same state as having been reset by the reset pin (RSTN, pin 63). 25MHz Crystal or Oscillator Clock Connection Pins (X1, X2) connect to a crystal or frequency oscillator source. If an oscillator is used, X1 connects to a VDD_IO voltage tolerant oscillator and X2 is a no connect. This clock requirement is ±50ppm. Digital Ground. 3.3V, 2.5V or 1.8V digital VDD input power pin for IO logic and the internal Low Voltage regulator. Shared Data Bus Bit[15] or BE3 22 SD15/BE3 I/O (PD) This is data bit (D15) access when CMD = “0”. This is Byte Enable 3 (BE3, 4th byte enable and active high) at double-word boundary access in 16-bit bus mode when CMD = “1”. This pin must be tied to GND in 8-bit bus mode. I/O (PD) This is data bit (D14) access when CMD = “0”. This is Byte Enable 2 (BE2, 3rd byte enable and active high) at double-word boundary access in 16-bit bus mode when CMD = “1”. This pin must be tied to GND in 8-bit bus mode. Shared Data Bus Bit [14] or BE2 23 SD14/BE2 Shared Data Bus Bit [13] or BE1 24 August 31, 2015 SD13/BE1 I/O (PD) This is data bit (D13) access when CMD = “0”. This is Byte Enable 1 (BE1, 2nd byte enable and active high) at double-word boundary access in 16-bit bus mode when CMD = “1”. This pin must be tied to GND in 8-bit bus mode. 18 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Description (Continued) Pin Number Pin Name Type Pin Function Shared Data Bus Bit [12] or BE0 25 SD12/BE0 I/O (PD) 26 SD11 I/O (PD) 27 SD10/A10 I/O (PD) 28 SD9/A9 I/O (PD) 29 DGND GND 30 VDD_IO P 31 SD8/A8 IPU/O This is data bit (D12) access when CMD = “0”. This is Byte Enable 0 (BE0, 1st byte enable and active high) at double-word boundary access in 16-bit bus mode when CMD = “1”. This pin must be tied to GND in 8-bit bus mode. Shared Data Bus Bit [11] This is data bit (D11) access when CMD = “0”. Don’t care when CMD = “1”. This pin must be tied to GND in 8-bit bus mode. Shared Data Bus bit [10] This is data bit (D10) access when CMD = “0”. In 8-bit bus mode, this pin must be tied to GND. In 16-bit bus mode, this is address A10 access when CMD = “1”. Shared Data Bus Bit[ 9] or A9 This is data bit (D9) access when CMD = “0”. In 8−bit bus mode, this pin must be tied to GND. In 16-bit bus mode, this is address A9 access when CMD = “1”. Digital Ground. 3.3V, 2.5V or 1.8V digital VDD input power pin for IO logic and the internal low voltage regulator. Shared Data Bus Bit [8] or A8 This is data bit (D8) access when CMD = “0”. In 8-bit bus mode, this pin must be tied to GND. In 16-bit bus mode, this is address A8 access when CMD = “1”. Shared Data Bus Bit [7] or A7 32 SD7/A7 IPD/O This is data bit (D7) access when CMD = “0”. In 8-bit bus mode, this is address A7 (1st write) or Don’t care (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A7 access when CMD = “1”. Shared Data Bus Bit [6] or A6 33 SD6/A6 IPU/O This is data bit (D6) access when CMD = “0”. In 8-bit bus mode, this is address A6 (1st write) or Don’t care (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A6 access when CMD = “1”. Shared Data Bus Bit [5] or A5 34 SD5/A5 IPU/O This is data bit (D5) access when CMD = “0”. In 8-bit bus mode, this is address A5 (1st write) or Don’t care (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A5 access when CMD = “1”. Shared Data Bus Bit [4] or A4 35 SD4/A4 IPD/O This is data bit (D4) access when CMD = “0”. In 8-bit bus mode, this is address A4 (1st write) or Don’t care (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A4 access when CMD = “1”. Shared Data Bus Bit [3] or A3 36 SD3/A3 I/O (PD) This is data bit (D3) access when CMD = “0”. In 8-bit bus mode, this is address A3 (1st write) or Don’t care (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A3 access when CMD = “1”. Shared Data Bus Bit [2] or A2 37 SD2/A2 I/O (PD) This is data bit (D2) access when CMD = “0”. In 8-bit bus mode, this is address A2 (1st write) or A10 (2nd write) access when CMD = “1”. In 16-bit bus mode, this is address A2 access when CMD = “1”. Shared Data Bus Bit [1] or A1 or A9 38 August 31, 2015 SD1/A1/A9 I/O (PD) This is data bit (D1) access when CMD = “0”. In 8-bit bus mode, this is address A1 (1st write) or A9 (2nd write) access when CMD = “1”. In 16-bit bus mode, this is “Don’t care” when CMD = “1”. 19 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Description (Continued) Pin Number Pin Name Type Pin Function 39 DGND GND Digital Ground. 40 VDD_L P This pin can be used in two ways; as the pin to input a low voltage to the device if the internal low voltage regulator is not used, or as the low voltage output if the internal low voltage regulator is used. Shared Data Bus Bit [0] or A0 or A8 41 SD0/A0/A8 IPU/O This is data bit (D0) access when CMD = “0”. In 8-bit bus mode, this is address A0 (1st write) or A8 (2nd write) access when CMD = “1”. In 16−bit bus mode, this is “Don’t care” when CMD = “1”. Command Type 42 CMD IPD 43 INTRN OPU This command input decides the SD[15:0] shared data bus access information. When command input is low, the access of shared data bus is for data access either SD[15:0] −> DATA[15:0] in 16−bit bus mode or SD[7:0] −> DATA[7:0] in 8-bit bus mode. When command input is high, in 16−bit bus mode: The access of shared data bus is for address A[10:2] access at shared data bus SD[10:2] and SD[1:0] is “don’t care". Byte enable BE[3:0] at SD[15:12] and the SD[11] is “don’t care”. in 8-bit bus mode: It is for address A[7:0] during 1st write access at shared data bus SD[7:0] or A[10:8] during 2nd write access at shared data bus SD[2:0] (SD[7:3] is don’t care). Interrupt Output This is an active low signal going to the host CPU to indicate an interrupt status bit is set. This pin needs an external 4.7KΩ pull-up resistor. Read Strobe 44 RDN IPU 45 WRN IPU This signal is an active low signal used as the asynchronous read strobe during read access cycles by the host processor. It is recommended that it be pulled up with a 4.7KΩ resistor. Write Strobe This is an asynchronous write strobe signal used during write cycles from the external host processor. It is a low active signal. Power Management Event 46 PME/EEPROM IPD/O This output signal indicates that a Wake On LAN event has been detected. The KSZ8852 is requesting the system to wake up from low power mode. Its assertion polarity is programmable with the default polarity to be active low. Config Mode: (EEPROM) At the end of the power up/reset period, this pin is sampled and the pull-up/pull-down value is latched. The value latched will indicate if a Serial EEPROM is present or not. See the Strapping Options section for details. Chip Select 47 CSN IPU 48 N/U O(PU) This unused output should be unconnected. 49 N/U O(PU) This unused output should be unconnected. 50 DGND GND Digital Ground. 51 VDD_L P 52 N/U O(PU) August 31, 2015 This signal is the Chip Select signal that is used by the external host processor for accesses to the device. It is an active low signal. This pin can be used in two ways; as the pin to input a low voltage to the device if the internal low voltage regulator is not used, or as the low voltage output if the internal low voltage regulator is used. This unused output should be unconnected. 20 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Description (Continued) Pin Number Pin Name Type 53 EESK O(PD) 54 EEDIO I/O(PD) 55 EECS O(PD) 56 VDD_IO P 57 DGND GND 58 N/U O(PU) Pin Function EEPROM Serial Clock Output A serial output clock is used to load configuration data into the KSZ8852 from the external EEPROM when it is present. EEPROM Data Input/Output Serial data input/output is from/to external EEPROM when it is present. EEPROM Chip Select Output This signal is used to select an external EEPROM device when it is present. 3.3V, 2.5V or 1.8V digital VDD input power pin for IO logic and the internal Low Voltage regulator. Digital Ground. This unused output should be unconnected. Programmable LED Outputs to Indicate Port 1 and Port 2 Activity/Status 59 P1LED1 IPU/O The LED is ON (active) when output is LOW; the LED is OFF (inactive) when output is HIGH. The Port 1 LED pins outputs are determined by the table below if Reg. 0x06C – 0x06D, bits [14:12] are set to ‘000’. Otherwise, the Port 1 LED pins are controlled via the processor by setting Reg. 0x06C – 0x06D, bits [14:12] to a non-zero value. The Port 2 LED pins outputs are determined by the table below if Reg. 0x084 – 0x085, bits [14:12] are set to ‘000’. Otherwise, the Port 2 LED pins are controlled via the processor by setting Reg. 0x084 – 0x085, bits [14:12] to a non-zero value. Automatic Port 1 and Port 2 indicators are defined as follows: Two bits [9:8] in SGCR7 Control Register 60 61 P1LED0/H816 P2LED1 00 (Default) 01 10 11 P1LED1/P2LED1 Speed ACT Duplex Duplex P1LED0/P2LED0 LINK/ACT LINK LINK/ACT LINK IPU/O O LINK = LED ON On/Blink Speed = LED ON (100BT) Duplex = LED ON (Full duplex) Config Mode: (P1LED1) ACT = LED Blink LINK/ACT = LED LED OFF (10BT) LED OFF (Half duplex) At the end of the power up/reset period, this pin is sampled and the pull-up/pulldown value is latched. It must be at a logic high level at this time. See the Strapping Options section for details. Config Mode: (P1LED0/H816) At the end of the power up/reset period, this pin is sampled and the pull-up/pulldown value is latched. The value latched will determine if 8-bit or 16-bit mode will be used for the host interface. See the Strapping Options section for details. Config Mode: (P2LED0/LEBE) 62 August 31, 2015 P2LED0/LEBE IPU/O At the end of the power up/reset period, this pin is sampled and the pull-up/pulldown value is latched. The value latched will determine if “Little Endian” or “Big Endian” mode will be used for the host interface. See the Strapping Options section for details. 21 Revision 1.1 Micrel, Inc. KSZ8852HLE Pin Description (Continued) Pin Number Pin Name Type 63 RSTN IPU 64 N/U I 65 (Bottom pad) GND GND Pin Function Reset Hardware reset pin (Active Low). This reset input is required to be low for a minimum of 10ms after supply voltages VDD_IO and 3.3V are stable. This unused input should be connected to GND. Ground. Legend: P = Power supply. GND = Ground. I/O = Bi−directional. I = Input. O = Output. IPD = Input with internal pull-down (58K ±30%). IPU = Input with internal pull-up (58K ±30%). OPD = Output with internal pull-down (58K ±30%). OPU = Output with internal pull-up (58K ±30%). IPU/O = Input with internal pull-up (58K ±30%) during power-up/reset; output pin otherwise. IPD/O = Input with internal pull-down (58K ±30%) during power-up/reset; output pin otherwise. I/O (PD) = Bi-directional Input/Output with internal pull-down (58K ±30%). I/O (PU) = Bi-directional Input/Output with internal pull-up (58K ±30%). August 31, 2015 22 Revision 1.1 Micrel, Inc. KSZ8852HLE Strapping Options Pin Number Pin Name Type 46 PME/ EEPROM IPD/O 59 P1LED1 IPU/O Pin Function During Power-up / Reset EEPROM Select Pull-up = EEPROM present NC or pull-down (default) = EEPROM not present This pin value is latched into register CCR, bit [9] at the end of the Power-Up/Reset time. Reserved NC or pull-up (default) = Normal Operation Pull-down = Reserved 8 or 16-Bit Host Interface Mode Select 60 P1LED0/ H816 62 P2LED0/ LEBE IPU/O NC or pull-up (default) = 16-bit bus mode Pull-down = 8-bit bus mode This pin value is also latched into register CCR, bit [7:6] at the end of the Power-Up/Reset time. Endian Mode Select for 8/16-bit Host Interface IPU/O NC or pull-up (default) = Little Endian Pull-down = Big Endian This pin value is latched into register CCR, bit [10] at the end of the power-up/reset time. Notes: IPU/O = Input with internal pull-up (58K ±30%) during power−up/reset; output pin otherwise. IPD/O = Input with internal pull-down (58K ±30%) during power−up/reset; output pin otherwise. All strap-in pins are latched during power−up or reset as well as re−strap−in when hardware/software power-down and hardware reset. August 31, 2015 23 Revision 1.1 Micrel, Inc. KSZ8852HLE Functional Description The KSZ8852 is a highly integrated networking device that incorporates a Layer-2 switch, two 10BT/100BT physical layer transceivers (PHYs) and associated MAC units, and a bus interface unit (BIU) with one general 8/16-bit host interface. The KSZ8852 operates in a managed mode. In managed mode, a host processor can access and control all PHY, Switch, and MAC related registers within the device via the host interface. Physical signal transmission and reception are enhanced through the use of analog circuits in the PHY that make the design more efficient and allow for low power consumption. Both power management and Energy Efficient Ethernet (EEE) are designed to save more power while device is in idle state. Wake on LAN is implemented to allow the KSZ8852 to monitor the network for packets intended to wake up the system which is upstream from the KSZ8852. The KSZ8852 is fully compliant to IEEE802.3u standards. Direction Terminology Readers should note that two different terminologies are used in this datasheet to describe the direction of data flow. In the standard terminology that is used for all switches, directions are described from the point of view of the switch core: “transmit” indicates data flow out of the KSZ8852 on any of the three ports, while “receive” indicates data flow into the KSZ8852. This terminology is used for the MIB counters. When referencing the QMU block, which is located on port 3 between the internal MAC and the external 8/16-bit host interface, directions are revered. They are described from the point of view of the external host processor. “Transmit” indicates data flow from the host into port 3 of the KSZ8852, while “receive” indicates data flow out of the KSZ8852 on port 3. Since both terminologies are used for port 3, it is important to note whether or not a particular section refers to the QMU. August 31, 2015 24 Revision 1.1 Micrel, Inc. KSZ8852HLE Physical (PHY) Block 100BASE-TX Transmit The 100BASE-TX transmit function performs parallel-to-serial conversion, 4B/5B coding, scrambling, NRZ-to-NRZI conversion, and MLT3 encoding and transmission. The circuitry starts with a parallel-to-serial conversion, which converts the MII data from the MAC into a 125MHz serial bit stream. The data and control stream is then converted into 4B/5B coding, followed by a scrambler. The serialized data is further converted from NRZ-to-NRZI format, and then transmitted in MLT3 current output. An external 6.49kΩ (1%) resistor for the 1:1 transformer ratio sets the output current. The output signal has a typical rise/fall time of 4ns and complies with the ANSI TP-PMD standard regarding amplitude balance, overshoot, and timing jitter. The wave-shaped 10BASE-T output driver is also incorporated into the 100BASE-TX driver. 100BASE-TX Receive The 100BASE-TX receiver function performs adaptive equalization, DC restoration, MLT3-to-NRZI conversion, data and clock recovery, NRZI-to-NRZ conversion, de-scrambling, 4B/5B decoding, and serial-to-parallel conversion. The receiving side starts with the equalization filter to compensate for inter-symbol interference (ISI) over the twisted pair cable. Since the amplitude loss and phase distortion is a function of the cable length, the equalizer has to adjust its characteristics to optimize performance. In this design, the variable equalizer makes an initial estimation based on comparisons of incoming signal strength against some known cable characteristics, and then tunes itself for optimization. This is an ongoing process and self-adjusts against environmental changes such as temperature variations. Next, the equalized signal goes through a DC restoration and data conversion block. The DC restoration circuit is used to compensate for the effect of baseline wander and to improve the dynamic range. The differential data conversion circuit converts the MLT3 format back to NRZI. The slicing threshold is also adaptive. The clock recovery circuit extracts the 125MHz clock from the edges of the NRZI signal. This recovered clock is then used to convert the NRZI signal into the NRZ format. This signal is sent through the de-scrambler followed by the 4B/5B decoder. Finally, the NRZ serial data is converted to an MII format and provided as the input data to the MAC. Scrambler/De-Scrambler (100BASE-TX Only) The purpose of the scrambler is to spread the power spectrum of the signal to reduce electromagnetic interference (EMI) and baseline wander. Transmitted data is scrambled through the use of an 11-bit wide linear feedback shift register (LFSR). The scrambler generates a 2047-bit non-repetitive sequence. Then, the receiver de-scrambles the incoming data stream using the same sequence as at the transmitter. PLL Clock Synthesizer (Recovery) The internal PLL clock synthesizer generates 125MHz, 62.5MHz and 31.25MHz clocks for the KSZ8852 system timing. These internal clocks are generated from an external 25MHz crystal or oscillator. 100BASE-T Transmit The 10BASE-T driver is incorporated with the 100BASE-TX driver to allow for transmission using the same magnets. They are internally wave-shaped and pre-emphasized into outputs with typical 2.3V amplitude. The harmonic contents are at least 27dB below the fundamental frequency when driven by an all-ones Manchester-encoded signal. 10BASE-T Receive On the receive side, input buffers and level detecting squelch circuits are employed. A differential input receiver circuit and a phase-locked loop (PLL) perform the decoding function. The Manchester-encoded data stream is separated into clock signal and NRZ data. A squelch circuit rejects signals with levels less than 400mV or with short pulse widths to prevent noise at the RXP1 or RXM1 input from falsely triggering the decoder. When the input exceeds the squelch limit, the PLL locks onto the incoming signal and the KSZ8852 decodes a data frame. The receiver clock is maintained active during idle periods in between data reception. August 31, 2015 25 Revision 1.1 Micrel, Inc. KSZ8852HLE MDI/MDI−X Auto Crossover To eliminate the need for crossover cables between similar devices, the KSZ8852 supports HP-Auto MDI/MDI-X and IEEE 802.3u standard MDI/MDI-X auto crossover. HP-Auto MDI/MDI-X is the default. The auto-sense function detects remote transmit and receive pairs and correctly assigns these transmit and receive pairs for the KSZ8852 device. This feature is extremely useful when end users are unaware of cable types in addition to saving on an additional uplink configuration connection. The auto-crossover feature can be disabled through the port control registers. The IEEE 802.3u standard MDI and MDI-X definitions are as below: Table 1. MDI/MDI-X Pin Definitions MDI−X MDI RJ45 Pins Signals RJ45 Pins Signals 1 TD+ 1 RD+ 2 TD− 2 RD− 3 RD+ 3 TD+ 6 RD− 6 TD− Straight Cable A straight cable connects an MDI device to an MDI-X device or an MDI-X device to an MDI device. Figure 1 shows a typical straight cable connection between a network interface card (NIC) and a switch, or hub (MDI-X). Figure 1. Typical Straight Cable Connection August 31, 2015 26 Revision 1.1 Micrel, Inc. KSZ8852HLE Crossover Cable A crossover cable connects an MDI device to another MDI device, or an MDI-X device to another MDI-X device. Figure 2 shows a typical crossover cable connection between two chips or hubs (two MDI-X devices). Figure 2. Typical Crossover Cable Connection August 31, 2015 27 Revision 1.1 Micrel, Inc. KSZ8852HLE Auto Negotiation The KSZ8852 conforms to the auto-negotiation protocol as described by IEEE 802.3. It allows each port to operate at either 10BASE-T or 100BASE-TX. Auto-negotiation allows unshielded twisted pair (UTP) link partners to select the best common mode of operation. In auto-negotiation, the link partners advertise capabilities across the link to each other and then compare their own capabilities with those they received from their link partners. The highest speed and duplex setting that is common to the two link partners is selected as the mode of operation. Auto-negotiation is also used to negotiate support for Energy Efficient Ethernet (EEE). The following list shows the speed and duplex operation mode from highest to lowest. • Highest: 100BASE-TX, full-duplex • High: 100BASE-TX, half-duplex • Low: 10BASE-T, full-duplex • Lowest: 10BASE-T, half-duplex If Auto-negotiation is not supported or the link partner to the KSZ8852 is forced to bypass auto-negotiation, the mode is set by observing the signal at the receiver. This is known as parallel mode because while the transmitter is sending autonegotiation advertisements, the receiver is listening for advertisements or a fixed signal protocol. The link setup is shown in the Figure 3. Figure 3. Auto-Negotiation and Parallel Operation August 31, 2015 28 Revision 1.1 Micrel, Inc. KSZ8852HLE LinkMD® Cable Diagnostics The KSZ8852 LinkMD uses time domain reflectometry (TDR) to analyze the cabling plant for common cabling problems such as open circuits, short circuits, and impedance mismatches. LinkMD works by sending a pulse of known amplitude and duration down the MDI and MDI-X pairs and then analyzes the shape of the reflected signal. Timing the pulse duration gives an indication of the distance to the cabling fault with a maximum distance of 200m and an accuracy of ±2m. Internal circuitry displays the TDR information in a user-readable digital format in register P1SCSLMD[8:0] or P2SCSLMD[8:0]. Access LinkMD is initiated by accessing register P1SCSLMD (0x07C) or P2SCSLMD (0x094), the PHY special control/status, and LinkMD register. Usage Before initiating LinkMD, the value 0x8008 must be written to the ANA_CNTRL_3 Register (0x74C – 0x74D). This needs to be done once (after power-on reset), but does not need to be repeated for each initiation of LinkMD. Auto-MDIX must also be disabled before using LinkMD. To disable Auto-MDIX, write a ‘1’ to P1CR4[10] or P2CR4[10] to enable manual control over the pair used to transmit the LinkMD pulse. The self-clearing cable diagnostic test enable bit, P1SCSLMD[12] or P2SCSLMD[12], is set to ‘1’ to start the test on this pair. When bit P1SCSLMD[12] or P2SCSLMD[12] returns to ‘0’, the test is completed. The test result is returned in bits P1SCSLMD[14:13] or P2SCSLMD[14:13] and the distance is returned in bits P1SCSLMD[8:0] or P2SCSLMD[8:0]. The cable diagnostic test results are as follows: 00 = Valid test, normal condition 01 = Valid test, open circuit in cable 10 = Valid test, short circuit in cable 11 = Invalid test, LinkMD failed If P1SCSLMD[14:13] or P2SCSLMD[14:13] is “11”, this indicates an invalid test, and it occurs when the KSZ8852 is unable to shut down the link partner. In this instance, the test is not run, as it is not possible for the KSZ8852 to determine if the detected signal is a reflection of the signal generated or a signal from another source. Cable distance can be approximated by the following formula: P1SCSLMD[8:0] x 0.4m for Port 1 cable distance P2SCSLMD[8:0] x 0.4m for Port 2 cable distance This constant (0.4m) may be calibrated for different cabling conditions, including cables with a velocity of propagation that varies significantly from the norm. On-Chip Termination Resistors The KSZ8852 reduces board cost and simplifies board layout by using on-chip termination resistors for RX/TX differential pairs, eliminating the need for external termination resistors. The on-chip termination and internal biasing will provide significant power savings when compared with using external biasing and termination resistors. August 31, 2015 29 Revision 1.1 Micrel, Inc. KSZ8852HLE Loopback Support The KSZ8852 provides two loopback modes. One is Near-End (Remote) Loopback to support remote diagnosing of failures on line side, and the other is Far-end loopback to support local diagnosing of failures through all blocks of the device. In loopback mode, the speed of the PHY port will be set to 100BASE-TX full-duplex mode. Far-End Loopback Far-end loopback is conducted between the KSZ8852’s two PHY ports. The loopback path starts at the “Originating” PHY port’s receive inputs (RXP/RXM), wraps around at the “loopback” PHY port’s PMD/PMA (Physical Media Dependent/Physical Media Attachment), and ends at the “Originating” PHY port’s transmit outputs (TXP/TXM). Bit[8] of registers P1CR4 and P2CR4 is used to enable far-end loopback for Ports 1 and 2, respectively. As an alternative, Bit[14] of registers P1MBCR and P2MBCR can be used to enable far-end loopback. The Port 2 far-end loopback path is illustrated in the Figure 4. Near−End (Remote) Loopback Near−end (Remote) loopback is conducted at either PHY Port 1 or PHY Port 2 of the KSZ8852. The loopback path starts at the PHY port’s receive inputs (RXPx/RXMx), wraps around at the same PHY port’s PMD/PMA, and ends at the same PHY port’s transmit outputs (TXPx/TXMx). Bit[1] of registers P1PHYCTRL and P2PHYCTRL is used to enable near-end loopback for Ports 1 and 2, respectively. As an alternative, Bit[9] of registers P1SCSLMD and P2SCSLMD can be used to enable near-end loopback. The near-end loopback paths for Port 1 and Port 2 are illustrated in Figure 4. Figure 4. Near-End and Far-End Loopback August 31, 2015 30 Revision 1.1 Micrel, Inc. KSZ8852HLE MAC (Media Access Controller) Block Mac Operation The KSZ8852 strictly abides by IEEE 802.3 standards to maximize compatibility. Additionally, there is an added MAC filtering function to filter unicast packets. The MAC filtering function is useful in applications such as VoIP where restricting certain packets reduces congestion and thus improves performance. Address Lookup The internal dynamic MAC address lookup table stores MAC addresses and their associated information. It contains a 1K entry unicast address learning table plus switching information. The KSZ8852 is guaranteed to learn 1K addresses and distinguishes itself from hash−based lookup tables, which depending upon the operating environment and probabilities, may not guarantee the absolute number of addresses they can learn. Learning The internal lookup engine updates the dynamic MAC address table with a new entry if the following conditions are met: • The received packet's Source Address (SA) does not exist in the lookup table. • The received packet has no receiving errors, and the packet size is of legal length. The lookup engine inserts the qualified SA into the table, along with the port number and time stamp. If the table is full, the oldest entry of the table is deleted to make room for the new entry. Migration The internal lookup engine also monitors whether a station has moved. If a station has moved, it updates the dynamic table accordingly. Migration happens when the following conditions are met: • The received packet's SA is in the table but the associated source port information is different. • The received packet has no receiving errors, and the packet size is of legal length. The lookup engine updates the existing record in the table with the new source port information. Aging The lookup engine updates the time stamp information of a record whenever the corresponding SA appears. The time stamp is used in the aging process. If a record is not updated for a period of time, the lookup engine removes the record from the table. The lookup engine constantly performs the aging process and continuously removes aging records. The aging period is about 300 seconds, ±75 seconds. This feature can be enabled or disabled through global register SGCR1[10]. Forwarding The KSZ8852 forwards packets using the algorithm that is depicted in the following flowcharts. Figure 5 shows stage one of the forwarding algorithm where the search engine looks up the VLAN ID, static table, and dynamic table for the destination address, and comes up with “port to forward 1” (PTF1). PTF1 is then further modified by spanning tree, IGMP snooping, port mirroring, and port VLAN processes to come up with “port to forward 2” (PTF2), as shown in Figure 6. The packet is sent to PTF2. The KSZ8852 will not forward the following packets: • Error packets: These include framing errors, frame check sequence (FCS) errors, alignment errors, and illegal size packet errors. • IEEE802.3x PAUSE frames: KSZ8852 intercepts these packets and performs full duplex flow control accordingly. • "Local" packets: Based on destination address (DA) lookup. If the destination port from the lookup table matches the port from which the packet originated, the packet is defined as "local." August 31, 2015 31 Revision 1.1 Micrel, Inc. KSZ8852HLE Figure 5. Destination Address Lookup Flow Chart in Stage One August 31, 2015 32 Revision 1.1 Micrel, Inc. KSZ8852HLE Figure 6. Destination Address Resolution Flow Chart in Stage Two August 31, 2015 33 Revision 1.1 Micrel, Inc. KSZ8852HLE Inter Packet Gap (IPG) If a frame is successfully transmitted, then the minimum 96-bit time for IPG is measured between two consecutive packets. If the current packet is experiencing collisions, the minimum 96-bit time for IPG is measured from carrier sense (CRS) to the next transmit packet. Back-Off Algorithm The KSZ8852 implements the IEEE standard 802.3 binary exponential back-off algorithm in half-duplex mode. After 16 collisions, the packet is dropped. Late Collision If a transmit packet experiences collisions after 512 bit times of the transmission, the packet is dropped. Legal Packet Size The KSZ8852 discards packets less than 64 bytes and can be programmed to accept packet sizes up to 1536 bytes in SGCR2[1]. The KSZ8852 can also be programmed for special applications to accept packet sizes up to 2000 bytes in SGCR1[4]. Flow Control The KSZ8852 supports standard 802.3x flow control frames on both transmit and receive sides. In the receive direction, if a PAUSE control frame is received on any port, the KSZ8852 will not transmit the next normal frame on that port until the timer, specified in the PAUSE control frame, expires. If another pause frame is received before the current timer expires, the timer will be updated with the new value in the second PAUSE frame. During this flow controlled period, only flow control packets from the KSZ8852 are transmitted. In the transmit direction, the KSZ8852 has intelligent and efficient ways to determine when to invoke flow control and send PAUSE frames. The flow control is based on availability of the system resources, including available buffers, available transmit queues and available receive queues. The KSZ8852 issues a PAUSE frame containing the maximum pause time defined in IEEE standard 802.3x. Once the resource is freed up, the KSZ8852 then sends out another flow control frame with zero pause time to turn off the flow control (turn on transmission to the port). A hysteresis feature is provided to prevent the flow control mechanism from being constantly activated and deactivated. On Port 3, a flow control handshake exists internally between the QMU and the port 3 MAC. In the QMU, there are three programmable threshold levels for flow control in the RXQ FIFO: 1) low water mark register FCLWR (0x1B0), 2) high water mark register FCHWR (0x1B2) and 3) overrun water mark register FCOWR (0x1B4). The QMU will send a PAUSE frame internally to the MAC when the RXQ buffer fills with egress packets above the high water mark level (default 3.072 Kbytes available). It sends a stop PAUSE frame when the RXQ buffer drops below the low water mark level (default 5.12 Kbytes available). The QMU will drop new packets from the switch when the RXQ buffer fills beyond the overrun water mark level (default 256 bytes available). Half-Duplex Backpressure A half-duplex backpressure option (non-IEEE 802.3 standard) is also provided. The activation and deactivation conditions are the same as in full-duplex mode. If backpressure is required, the KSZ8852 sends preambles to defer the other stations' transmission (carrier sense deference). To avoid jabber and excessive deference (as defined in the 802.3 standard), after a certain time, the KSZ8852 discontinues the carrier sense and then raises it again quickly. This short silent time (no carrier sense) prevents other stations from sending out packets thus keeping other stations in a carrier sense deferred state. If the port has packets to send during a backpressure situation, the carrier sense type backpressure is interrupted and those packets are transmitted instead. If there are no additional packets to send, carrier sense type backpressure is reactivated again until chip resources free up. If a collision occurs, the binary exponential back-off algorithm is skipped and carrier sense is generated immediately, thus reducing the chance of further collision and carrier sense is maintained to prevent packet reception. To ensure no packet loss in 10BASE-T or 100BASE-TX half-duplex mode, the user must enable the following bits: • Aggressive back off (bit[8] in SGCR1) • No excessive collision drop (bit[3] in SGCR2) • Back pressure flow control enable (bit[11] in P1CR2/P2CR2) Note: These bits are not set in default, since this is not the IEEE standard. August 31, 2015 34 Revision 1.1 Micrel, Inc. KSZ8852HLE Broadcast Storm Protection The KSZ8852 has an intelligent option to protect the switch system from receiving too many broadcast packets. As the broadcast packets are forwarded to all ports except the source port, an excessive number of switch resources (bandwidth and available space in transmit queues) may be utilized. The KSZ8852 has the option to include “multicast packets” for storm control. The broadcast storm rate parameters are programmed globally, and can be enabled or disabled on a per port basis in P1CR1[7] and P2CR1[7]. The rate is based on a 67ms interval for 100BT and a 670ms interval for 10BT. At the beginning of each interval, the counter is cleared to zero and the rate limit mechanism starts to count the number of bytes during the interval. The rate definition is described in SGCR3[2:0][15:8]. The default setting is 0x63 (99 decimal). This is equal to a rate of 1%, calculated as follows: 148,800 frames/sec × 67ms/interval X 1% = 99 frames/interval (approx.) = 0x63 Note: 148,800 frames/sec is based on 64−byte block of packets in 100BASE−T with 12 bytes of IPG and 8 bytes of preamble between two packets. Port Individual MAC Address and Source Port Filtering The KSZ8852 can provide individual MAC addresses for port 1 and port 2. They can be set at registers 0x0B0h-0x0B5h and 0x0B6-0x0BB. Received packets can be filtered (dropped) if their source address matches the MAC address of port 1 or port 2. This feature can be enabled by setting bits [11:10] in the P1CR1 or P2CR1 registers. One example of usage is that a packet will be dropped after it completes a full round trip within a ring network. Address Filtering Function The KSZ8852 supports 11 different address filtering schemes as shown in Table 2. The Ethernet destination address (DA) field inside the packet is the first 6−byte field which uses to compare with either the host MAC address registers (0x110 0x115) or the MAC address hash table registers (0x1A0 – 0x1A7) for address filtering operation. The first bit (bit[40]) of the destination address (DA) in the Ethernet packet decides whether this is a physical address if bit[40] is “0” or a multicast address if bit[40] is “1”. August 31, 2015 35 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 2. MAC Address Filtering Scheme Receive Control Register (0x174 − 0x175): RXCR1 Item Address Filtering Mode 1 2 3 4 RX ALL (Bit [4]) RX Inverse (Bit [1]) RX Physical Address (Bit [11]) RX Multicast Address (Bit [8]) Perfect 0 0 1 1 All Rx frames are passed only if the DA exactly matches the MAC address in MARL, MARM and MARH registers. Inverse perfect 0 1 1 1 All Rx frames are passed if the DA is not matching the MAC address in MARL, MARM and MARH registers. 0 All Rx frames with either multicast or physical destination address are filtering against the MAC address hash table. 0 All Rx frames with either multicast or physical destination address are filtering not against the MAC address hash table. All Rx frames which are filtering out at item 3 (Hash only) only are passed in this mode. Hash only Inverse hash only 0 0 0 1 0 0 Description 5 Hash perfect (Default) 0 0 1 0 All Rx frames are passed with Physical address (DA) matching the MAC address and to enable receive multicast frames that pass the hash table when Multicast address is matching the MAC address hash table. 6 Inverse hash perfect 0 1 1 0 All Rx frames which are filtering out at item 5 (Hash perfect) only are passed in this mode. 7 Promiscuous 1 1 0 0 All Rx frames are passed without any conditions. 8 Hash only with Multicast address passed 0 All Rx frames are passed with Physical address (DA) matching the MAC address hash table and with Multicast address without any conditions. 9 Perfect with Multicast address passed 1 All Rx frames are passed with Physical address (DA) matching the MAC address and with Multicast address without any conditions. 10 Hash only with Physical address passed 1 0 1 0 All Rx frames are passed with Multicast address matching the MAC address hash table and with Physical address without any conditions. 11 Perfect with Physical address passed 1 0 0 1 All Rx frames are passed with Multicast address matching the MAC address and with Physical address without any conditions. 1 1 0 0 0 1 Notes: Bit [0] (RX Enable), Bit [5] (RX Unicast Enable) and Bit [6] (RX Multicast Enable) must set to 1 in RXCR1 register. The KSZ8852 will discard frame with SA same as the MAC Address if bit[0] is set in RXCR2 register. August 31, 2015 36 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Block Switching Engine The KSZ8852 features a high−performance switching engine to move data to and from the MAC’s packet buffers. It operates in store and forward mode, while the efficient switching mechanism reduces overall latency. The switching engine has a 32KByte internal frame buffer. This resource is shared between all the ports. There are a total of 256 buffers available. Each buffer is sized at 128 Bytes. “Transmit = egress” applies to all three ports in the context of the switch core. This includes the MIB counters. It also applies to the TX priority queues (sometimes called TXQs) which are not to be confused with the TX queue (TXQ) in the QMU. This would generally include Registers 0x000 – 0x16B. Spanning Tree Support To support spanning tree, the host port is the designated port for the processor. The other ports (Port 1 and Port 2) can be configured in one of the five spanning tree states via “transmit enable”, “receive enable” and “learning disable” register settings in registers P1CR2 and P2CR2 for Ports 1 and 2, respectively. Table 3 shows the port setting and software actions taken for each of the five spanning tree states. Table 3. Spanning Tree States Disable State The port should not forward or receive any packets. Learning is disabled. Blocking State Only packets to the processor are forwarded. Listening State Only packets to and from the processor are forwarded. Learning is disabled. Learning State Only packets to and from the processor are forwarded. Learning is enabled. Forwarding State Packets are forwarded and received normally. Learning is enabled. August 31, 2015 Port Setting Software Action xmit enable = “0”, receive enable = “0”, learning disable = “1” The processor should not send any packets to the port. The switch may still send specific packets to the processor (packets that match some entries in the Static MAC Address Table with “overriding bit” set) and the processor should discard those packets. Address learning is disabled on the port in this state. xmit enable = “0”, receive enable = “0”, earning disable = ”1” The processor should not send any packets to the port(s) in this state. The processor should program the Static MAC Address Table with the entries that it needs to receive (for example, BPDU packets). The “overriding” bit should also be set so that the switch will forward those specific packets to the processor. Address learning is disabled on the port in this state. xmit enable = “0”, receive enable = “0”, learning disable = “1” The processor should program the Static MAC Address Table with the entries that it needs to receive (for example, BPDU packets). The “overriding” bit should be set so that the switch will forward those specific packets to the processor. The processor may send packets to the port(s) in this state. Address learning is disabled on the port in this state. xmit enable = “0”, receive enable = “0”, learning disable = “0” The processor should program the Static MAC Address Table with the entries that it needs to receive (for example, BPDU packets). The “overriding” bit should be set so that the switch will forward those specific packets to the processor. The processor may send packets to the port(s) in this state. Address learning is enabled on the port in this state. xmit enable = “1”, receive enable = “1”, learning disable = “0” The processor programs the Static MAC Address Table with the entries that it needs to receive (for example, BPDU packets). The “overriding” bit is set so that the switch forwards those specific packets to the processor. The processor can send packets to the port(s) in this state. Address learning is enabled on the port in this state. 37 Revision 1.1 Micrel, Inc. KSZ8852HLE Rapid Spanning Tree Support There are three operational states assigned to each port for RSTP (Discarding, Learning, and Forwarding): • Discarding ports do not participate in the active topology and do not learn MAC addresses. • Discarding state: the state includes three states of the disable, blocking and listening of STP. • Port setting: xmit enable = “0”, receive enable = “0”, learning disable = “1”. Discarding State Software action: The host processor should not send any packets to the port. The switch may still send specific packets to the processor (packets that match some entries in the static table with “overriding bit” set) and the processor should discard those packets. When the port’s learning capability (learning disable = ’1’) is disabled, setting bits [10:9] in the SGCR8 register will rapidly flush the port related entries in the dynamic MAC table and static MAC table. The processor is connected to Port 3 via the host interface. Address learning is disabled on the port in this state. Learning State Ports in “Learning States” learn MAC addresses, but do not forward user traffic. Learning State: Only packets to and from the processor are forwarded. Learning is enabled. Port setting for Learning State: transmit enable = “0”, receive enable = “0”, learning disable = ”0”. Software action: The processor should program the static MAC table with the entries that it needs to receive (e.g., BPDU packets). The “overriding” bit should be set so that the switch will forward those specific packets to the processor. The processor may send packets to the port(s) in this state (see Tail Tagging Mode section for details.) Address learning is enabled on the port in this state. Ports in forwarding states fully participate in both data forwarding and MAC learning. Forwarding State Forwarding state: Packets are forwarded and received normally. Learning is enabled. Port setting: transmit enable = “1”, receive enable = “1”, learning disable = “0”. Software action: The processor should program the static MAC table with the entries that it needs to receive (e.g., BPDU packets). The “overriding” bit should be set so that the switch will forward those specific packets to the processor. The processor may send packets to the port(s) in this state, see “Tail Tagging Mode” section for details. Address learning is enabled on the port in this state. RSTP uses only one type of BPDU called RSTP BPDUs. They are similar to STP Configuration BPDUs with the exception of a type field set to “version 2” for RSTP and “version 0” for STP, and a flag field carrying additional information. Tail Tagging Mode Tail tag mode is only seen and used by the Port 3 host interface, which should be connected to a processor. It is an effective way to retrieve the ingress port information for spanning tree protocol, IGMP snooping, and other applications. Bits [1:0] in the one byte tail tagging are used to indicate the source/destination port in Port 3. Bits [3:2] are used for priority setting of the ingress frame in Port 3. Other bits are not used. The tail tag feature is enabled by setting bit [8] in the SGCR8 register. Figure 7. Tail Tag Frame Format August 31, 2015 38 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 4. Tail Tag Rules Ingress to Port 3 (Host −> KSZ8852) Bit [1:0] Destination Port 00 Normal (Address Look up) 01 Port 1 10 Port 2 11 Port 1 and Port 2 Bit [3:2] Frame Priority 00 Priority 0 01 Priority 1 10 Priority 2 11 Priority 3 Egress from Port 3 (KSZ8852 −> Host) Bit [0] Source Port 0 Port 1 1 Port 2 IGMP Support For internet group management protocol (IGMP) support in Layer 2, the KSZ8852 provides two components: “IGMP” Snooping The KSZ8852 traps IGMP packets and forwards them only to the processor (host port). The IGMP packets are identified as IP packets (either Ethernet IP packets, or IEEE 802.3 SNAP IP packets) with IP version = 0x4 and protocol version number = 0x2. “Multicast Address Insertion” in the Static MAC Table Once the multicast address is programmed in the Static MAC Address Table, the multicast session is trimmed to the subscribed ports, instead of broadcasting to all ports. To enable IGMP support, set bit[14] to ‘1’ in the SGCR2 register. Also, Tail Tagging Mode needs to be enabled, so that the processor knows which port the IGMP packet was received on. This is achieved by setting bit[8] to ‘1’ in the SGCR8 register. IPv6 MLD Snooping The KSZ8852 traps IPv6 multicast listener discovery (MLD) packets and forwards them only to the processor (host port). MLD snooping is controlled by SGCR2, bit[13] (MLD snooping enable) and SGCR2 bit[12] (MLD option). Setting SGCR2 bit[13] causes the KSZ8852 to trap packets that meet all of the following conditions: • IPv6 multicast packets • Hop count limit = “1” • IPv6 next header = “1”or “58” (or = “0” with hop−by−hop next header = “1” or “58”) • If SGCR2[12] = “1”, IPv6 next header = “43”, “44”, “50”, “51”, or “60” (or = “0” with hop−by−hop next header = “43”, “44”, “50”, “51”, or “60”) August 31, 2015 39 Revision 1.1 Micrel, Inc. KSZ8852HLE Port Mirroring Support KSZ8852 supports “Port Mirroring” comprehensively as illustrated in the following sub-sections: “Receive Only” Mirror-on-a-Port All the packets received on the port are mirrored on the sniffer port. For example, Port 1 is programmed to be “receive sniff” and the host port is programmed to be the “sniffer port”. A packet received on Port 1 is destined to Port 2 after the internal lookup. The KSZ8852 forwards the packet to both Port 2 and the host port. The KSZ8852 can optionally even forward “bad” received packets to the “sniffer port”. “Transmit Only” Mirror-on-a-Port All the packets transmitted on the port are mirrored on the sniffer port. For example, Port 1 is programmed to be “transmit sniff” and the host port is programmed to be the “sniffer port”. A packet received on Port 2 is destined to Port 1 after the internal lookup. The KSZ8852 forwards the packet to both Port 1 and the host port. “Receive and Transmit” Mirror-on-Two-Ports All the packets received on port A and transmitted on port B are mirrored on the sniffer port. To turn on the “AND” feature, set register SGCR2, bit 8 to “1”. For example, Port 1 is programmed to be “receive sniff”, Port 2 is programmed to be “transmit sniff”, and the host port is programmed to be the “sniffer port”. A packet received on Port 1 is destined to Port 2 after the internal lookup. The KSZ8852 forwards the packet to both Port 2 and the host port. Multiple ports can be selected as “receive sniff” or “transmit sniff”. In addition, any port can be selected as the “sniffer port”. All these per port features can be selected through registers P1CR2, P2CR2, and P3CR2 for Ports 1, 2, and the host port, respectively. IEEE 802.1Q VLAN Support The KSZ8852 supports 16 active VLANs out of the 4096 possible VLANs specified in the IEEE 802.1Q specification. KSZ8852 provides a 16−entry VLAN table, which converts the 12−bits VLAN ID (VID) to the 4−bits Filter ID (FID) for address lookup. If a non−tagged or null−VID−tagged packet is received, the ingress port default VID is used for lookup. In VLAN mode, the lookup process starts with VLAN table lookup to determine whether the VID is valid. If the VID is not valid, the packet is dropped and its address is not learned. If the VID is valid, the FID is retrieved for further lookup. The FID + Destination Address (FID+DA) are used to determine the destination port. The FID + Source Address (FID+SA) are used for address learning (see Table 5 and Table 6). Advanced VLAN features are also supported in the KSZ8852, such as “VLAN ingress filtering” and “discard non PVID” defined in bits [14:13] of P1CR2, P2CR2 and P3CR2 registers. These features can be controlled on per port basis. Table 5. FID + DA Lookup in VLAN Mode DA Found in Static MAC Table? Use FID Flag? FID Match? DA+FID Found in Dynamic MAC Table? No Don’t Care Don’t Care No Broadcast to the membership ports defined in the VLAN Table bits [18:16] No Don’t Care Don’t Care Yes Send to the destination port defined in the Dynamic MAC Address Table bits [53:52] Yes 0 Don’t Care Don’t Care Send to the destination port(s) defined in the Static MAC Address Table bits [50:48] Yes 1 No No Broadcast to the membership ports defined in the VLAN Table bits [18:16] Yes 1 No Yes Send to the destination port defined in the Dynamic MAC Address Table bits [53:52] Yes 1 Yes Don’t Care August 31, 2015 40 Action Send to the destination port(s) defined in the Static MAC Address Table bits [50:48] Revision 1.1 Micrel, Inc. KSZ8852HLE Table 6. FID + SA Lookup in VLAN Mode FID+SA Found in Dynamic MAC Table? Action No Learn and add FID+SA to the Dynamic MAC Address Table Yes Update time stamp QoS Priority Support The KSZ8852 provides quality-of-service (QoS) for applications such as VoIP and video conferencing. The KSZ8852 offer 1, 2, and 4 priority queues option per port. This is controlled by bit[0] and bit[8] in P1CR1, P2CR1 and P3CR1 registers as shown below: • Bit[0], Bit[8] = ‘00’ Egress port is a single output queue as default. • Bit[0], Bit[8] = ‘01’ Egress port can be split into two priority transmit queues. (Q0 and Q1) • Bit[0], Bit[8] = ‘10’ Egress port can be split into four priority transmit queues. (Q0, Q1, Q2 and Q3) The four priority transmit queues is a new feature in the KSZ8852. Queue 3 is the highest priority queue and Queue 0 is the lowest priority queue. If a port's transmit queue is not split, high priority and low priority packets have equal priority in the transmit queue. There is an additional option for every port via bits[15,7] in the P1ITXQRCR1, P1TXQRCR2, P2TXQRCR1, P2TXQRCR2, P3TXQRCR1, and P3TXQRCR2 Registers to select either always to deliver high priority packets first or use weighted fair queuing for the four priority queues scale by 8:4:2:1. Port-Based Priority With port-based priority, each ingress port is individually classified as a specific priority level. All packets received at the high-priority receiving port are marked as high priority and are sent to the high-priority transmit queue if the corresponding transmit queue is split. Bits[4:3] of registers P1CR1, P2CR1, and P3CR1 is used to enable port-based priority for Ports 1, 2, and the host port, respectively. 802.1p-Based Priority For 802.1p−based priority, the KSZ8852 examines the ingress (incoming) packets to determine whether they are tagged. If tagged, the 3−bit priority field in the VLAN tag is retrieved and used to look up the “priority mapping” value, as specified by the register SGCR6. The “priority mapping” value is programmable. Figure 8 illustrates how the 802.1p priority field is embedded in the 802.1Q VLAN tag. Figure 8. 802.1p Priority Field Format August 31, 2015 41 Revision 1.1 Micrel, Inc. KSZ8852HLE 802.1p based priority is enabled by bit[5]of registers P1CR1, P2CR1, and P3CR1 for Ports 1, 2, and the host port, respectively. The KSZ8852 provides the option to insert or remove the priority tagged frame's header at each individual egress port. This header, consisting of the 2 bytes VLAN protocol ID (VPID) and the 2 bytes tag control information field (TCI), is also referred to as the 802.1Q VLAN tag. Tag insertion is enabled by bit [2] of registers P1CR1, P2CR1, and P3CR1 for Ports 1, 2, and the host port, respectively. At the egress port, untagged packets are tagged with the ingress port’s default tag. The default tags are programmed in register sets P1VIDCR, P2VIDCR, and P3VIDCR for Ports 1, 2, and the host port, respectively. The KSZ8852 does not add tags to already tagged packets. Tag removal is enabled by bit [1] of registers P1CR1, P2CR1, and P3CR1 for Ports 1, 2, and the host port, respectively. At the egress port, tagged packets will have their 802.1Q VLAN Tags removed. The KSZ8852 will not modify untagged packets. The CRC is recalculated for both tag insertion and tag removal. 802.1p Priority Field Re-mapping This is a QoS feature that allows the KSZ8852 to set the “user priority ceiling” at any ingress port. If the ingress packet’s priority field has a higher priority value than the default tag’s priority field of the ingress port, the packet’s priority field is replaced with the default tag’s priority field. The “user priority ceiling” is enabled by bit[3] of registers P1CR2, P2CR2, and P3CR2 for Ports 1, 2, and the host port, respectively. DiffServ-Based Priority DiffServ−based priority uses the TOS registers shown in the Type-of-Service (TOS) Priority Control Registers section. The TOS priority control registers implement a fully-decoded, 128-bit differentiated services code point (DSCP) register to determine packet priority from the 6-bit TOS field in the IP header. When the most significant 6 bits of the TOS field are fully decoded, the resultant of the 64 possibilities is compared with the corresponding bits in the DSCP register to determine priority. Rate-Limiting Support The KSZ8852 supports hardware rate limiting from 64Kbps to 99Mbps (refer to Table 20), independently on the “receive side” and on the “transmit side” as per port basis. For 10BASE-T, a rate setting above 10Mbps means the rate is not limited. On the receive side, the data receive rate for each priority at each port can be limited by setting up ingress rate control registers. On the transmit side, the data transmit rate for each priority queue at each port can be limited by setting up egress rate control registers. The size of each frame has options to include minimum inter-frame gap (IFG) or preamble byte, in addition to the data field (from packet DA to FCS). For ingress rate limiting, KSZ8852 provides options to selectively choose frames from all types, multicast, broadcast, and flooded unicast frames. The KSZ8852 counts the data rate from those selected type of frames. Packets are dropped at the ingress port when the data rate exceeds the specified rate limit. For egress rate limiting, the “leaky bucket” algorithm is applied to each output priority queue for shaping output traffic. Inter frame gap is stretched on a per frame base to generate smooth, non-burst egress traffic. The throughput of each output priority queue is limited by the egress rate specified. If any egress queue receives more traffic than the specified egress rate throughput, packets may be accumulated in the output queue and packet memory. After the memory of the queue or the port is used up, packet dropping or flow control will be triggered. As a result of congestion, the actual egress rate may be dominated by flow control/dropping at the ingress end, and may be therefore slightly less than the specified egress rate. To reduce congestion, it is a good practice to make sure the egress bandwidth exceeds the ingress bandwidth. MAC Address Filtering Function When a packet is received, the destination MAC address is looked up in both the static and dynamic MAC address tables. If the address is not found in either of these tables, then the destination MAC address is “unknown”. By default, an unknown unicast packet is forwarded to all ports except the port at which it was received. An optional feature makes it possible to specify the port or ports to which to forward unknown unicast packets. It is also possible to specify no ports, meaning that unknown unicast packets will be discarded. This feature is enabled by setting bit [7] in SGCR7. The unicast MAC address filtering function is useful in preventing the broadcast of unicast packets that could degrade the quality of this port in applications such as voice-over-internet protocol (VoIP). August 31, 2015 42 Revision 1.1 Micrel, Inc. KSZ8852HLE Queue Management Unit (QMU) The Queue Management Unit (QMU) manages packet traffic on port 3 between the internal MAC and the external host processor interface. It has built−in packet memory for receive and transmit functions called transmit queue (TXQ) and receive queue (RXQ). The RXQ capacity is 12Kbytes, and the TXQ capacity is 6Kbytes. These FIFOs support back−to−back, non−blocking frame transfer performance. There are control registers for system control, frame status registers for current packet transmit/receive status, and interrupts to inform the host of the real time TX/RX status. Please refer to the Direction Terminology section for a discussion of the different terminology used to describe the QMU. Transmit Queue (TXQ) Frame Format The frame format for the transmit queue is shown in Table 7. The first word contains the control information for the frame to transmit. The second word is used to specify the total number of bytes of the frame. The packet data follows. The packet data area holds the frame itself. It may or may not include the CRC checksum depending upon whether hardware CRC checksum generation is enabled in bit [1] in TXCR register. Multiple frames can be pipelined in both the transmit queue and receive queue as long as there is enough queue memory, thus avoiding overrun. For each transmitted frame, the transmit status information for the frame is located in the TXSR (0x172) register. Table 7. Frame Format for Transmit Queue Packet Memory Address Offset (Bytes) Bit 0 1st Byte Bit 15 2nd Byte 0 Control Word (High byte and low byte need to swap in Big−Endian mode) 2 Byte Count (High byte and low byte need to swap in Big−Endian mode) 4 − Up Transmit Packet Data (Maximum size is 2000) Since multiple packets can be pipelined into the TX packet memory for transmit, the transmit status reflects the status of the packet that is currently being transferred on the MAC interface, which may or may not be the last queued packet in the TX queue. The transmit control word is the first 16-bit word in the TX packet memory, followed by a 16-bit byte count. It must be word aligned. Each control word corresponds to one TX packet. Table 8 gives the transmit control word bit fields. Table 8. Transmit Control Word Bit Fields Bit Description 15 TXIC Transmit Interrupt on Completion: When this bit is set, the KSZ8852 sets the transmit interrupt after the present frame has been transmitted. 14 − 10 Reserved 9−8 Reserved 7−6 Reserved 5−0 TXFID Transmit Frame ID: This field specifies the frame ID that is used to identify the frame and its associated status information in the transmit status register. August 31, 2015 43 Revision 1.1 Micrel, Inc. KSZ8852HLE The transmit byte count specifies the total number of bytes to be transmitted from the TXQ. Its format is given Table 9. Table 9. Transmit Byte Count Format Bit Description 15 − 11 Reserved. 10 − 0 TXBC Transmit Byte Count: Transmit Byte Count. Hardware uses the byte count information to conserve the TX buffer memory for better utilization of the packet memory. Note: The hardware behavior is unknown if an incorrect byte count information is written to this field. Writing a “0” value to this field is not permitted. The data area contains six bytes of destination address (DA) followed by six bytes of source address (SA), followed by a variable-length number of bytes. On transmit, all bytes are provided by the CPU, including the source address. The KSZ8852 does not insert its own SA. The IEEE 802.3 frame length word (frame type in Ethernet) is not interpreted by the KSZ8852. It is treated transparently as data both for transmit operations. Frame Transmitting Path Operation in TXQ This section describes the typical register settings for transmitting packets from a host processor to the KSZ8852 using the generic bus interface. The user can use the default value for most of the transmit registers. Table 10 describes all the registers which need to be set and used for transmitting single frames. Table 10. Register Setting for Transmit Function Block Register Name [bit](offset) Description TXCR[3:0](0x170) TXCR[8:5](0x170) Set transmit control function as below: Set bit[3] to enable transmitting flow control. Set bit [2] to enable transmitting padding. Set bit[1] to enable transmitting CRC. Set bit [0] to enable transmitting block operation. Set transmit checksum generation for ICMP, UDP, TCP and IP packet. TXMIR[12:0](0x178) The amount of free transmit memory available is represented in units of byte. The TXQ memory (6KByte) is used for both frame payload and control word. TXQCR[0](0x180) For single frame to transmit, set this bit[0] = “1” (manual enqueue). The KSZ8852 will enable current TX frame prepared in the TX buffer is queued for transmit; this is only transmit one frame at a time. Note: This bit is self-clearing after the frame is finished transmitting. The software should wait for the bit to be cleared before setting up another new TX frame. TXQCR[1](0x180) When this bit is written as “1”, the KSZ8852 will generate interrupt (bit[6] in the ISR register) to CPU when TXQ memory is available based upon the total amount of TXQ space requested by CPU at TXNTFSR (0x19E) register. Note: This bit is self−clearing after the frame is finished transmitting. The software should wait for the bit to be cleared before set to “1” again. RXQCR[3](0x182) Set bit[3] to start DMA access from host CPU either read (receive frame data) or write (transmit data frame) TXFDPR[14](0x184) Set bit[14] to enable TXQ transmit frame data pointer register increments automatically on accesses to the data register. IER[14][6](0x190) Set bit[14] to enable transmit interrupt in interrupt enable register. Set bit[6] to enable transmit space available interrupt in interrupt enable register. ISR[15:0](0x192) Write all ones (0xFFFF) to clear all interrupt status bits after interrupt occurred in interrupt enable register. TXNTFSR[15:0](0x19E) The host CPU is used to program the total amount of TXQ buffer space which is required for next total transmit frames size in double−word count. August 31, 2015 44 Revision 1.1 Micrel, Inc. KSZ8852HLE Driver Routine for Transmitting Packets from Host Processor to KSZ8852 The transmit routine is called by the upper layer to transmit a contiguous block of data through the Ethernet controller. It is the user’s choice to decide how the transmit routine is implemented. If the Ethernet controller encounters an error while transmitting the frame, it’s the user’s choice to decide whether the driver should attempt to retransmit the same frame or discard the data. Figure 9 shows the step−by−step process for transmitting a single packet from host processor to the KSZ8852. Each DMA write operation from the host CPU to the “write TXQ frame buffer” begins with writing a control word and a byte count of the frame header. At the end of the write, the host CPU must write each piece of frame data to align with a double word boundary at the end. For example, the host CPU has to write up to 68 bytes if the transmit frame is 65 bytes. Figure 9. Host TX Single Frame in Manual Enqueue Flow Diagram August 31, 2015 45 Revision 1.1 Micrel, Inc. KSZ8852HLE Receive Queue (RXQ) Frame Format The frame format for the receive queue is shown in Table 11. The first word contains the status information for the frame received. The second word is the total number of bytes of the RX frame. Following that is the packet data area. The packet data area holds the frame itself. It includes the CRC checksum. Table 11. Frame Format for Receive Queue Packet Memory Address Offset (Bytes) Bit 15 2nd Byte Bit 0 1st Byte Status Word 0 (High byte and low byte need to swap in Big−Endian mode. Also see description in RXFHSR register) Byte Count 2 4 - Up (High byte and low byte need to swap in Big−Endian mode. Also see description in RXFHBCR register) Receive Packet Data (Maximum size is 2000) Frame Receiving Path Operation in RXQ This section describes the typical register settings for receiving packets from KSZ8852 to the host processor via the generic bus interface. Users can use the default value for most of the receive registers. Table 12 describes all registers which need to be set and used for receiving single or multiple frames. Table 12. Register Settings for Receive Function Block Register Name [bit](offset) Description RXCR1 (0x174) RXCR2 (0x176) Set receive control function as below: Set RXCR1[10] to enable receiving flow control. Set RXCR1[0] to enable receiving block operation. Set receive checksum check for ICMP, UDP, TCP, and IP packet. Set receive address filtering scheme as shown in Table 2. RXFHSR[15:0] (0x17C) This register (read only) indicates the current received frame header status information. RXFHBCR[11:0] (0x17E) This register (read only) indicates the current received frame header byte count information. RXQCR[12:3] (0x182) Set RXQ control function as below: Set bit[3] to start DMA access from host CPU either read (receive frame data) or write (transmit data frame). Set bit[4] to automatically enable RXQ frame buffer de−queue. Set bit[5] to enable RX frame count threshold and read bit[10] for status. Set bit[6] to enable RX data byte count threshold and read bit[11] for status. Set bit[7] to enable RX frame duration timer threshold and read bit[12] for status. Set bit[9] to enable RX IP header two−byte offset. RXFDPR[14] (0x186) Set bit[14] to enable RXQ address register increments automatically on accesses to the data register. RXDTTR[15:0] (0x18C) Used to program the received frame duration timer value. When Rx frame duration in RXQ exceeds this threshold in 1uS interval count and bit[7] of RXQCR register is set to “1”, the KSZ8852 will generate RX interrupt in ISR[13] and indicate the status in RXQCR[12]. Used to program the received data byte count value. When the number of received bytes in RXQ exceeds RXDBCTR[15:0] (0x18E) this threshold in byte count and bit [6] of RXQCR register is set to “1”, the KSZ8852 will generate RX interrupt in ISR[13] and indicate the status in RXQCR[11]. IER[13] (0x190) Set bit[13] to enable receive interrupt in interrupt enable register. ISR[15:0] (0x192) Write all ones (0xFFFF) to clear all interrupt status bits after interrupt occurred in interrupt status register. RXFC[15:8] (0x1B8) Rx Frame Count. This indicates the total number of frames received in the RXQ frame buffer when the receive interrupt (Reg. ISR, bit [13]) occurred. RXFCTR[7:0] (0x19C) Used to program the received frame count threshold value. When the number of received frames in RXQ exceeds this threshold value and bit[5] of RXQCR register is set to “1”, the KSZ8852 will generate an RX interrupt in ISR[13] and indicate the status in RXQCR[10]. August 31, 2015 46 Revision 1.1 Micrel, Inc. KSZ8852HLE Driver Routine for Receiving Packets from the KSZ8852 to the Host Processor The software driver receives data packet frames from the KSZ8852 device either as a result of polling or an interrupt based service. When an interrupt is received, the operating system invokes the interrupt service routine that is in the interrupt vector table. If your system has operating system support, to minimize interrupt lockout time, the interrupt service routine should handle at interrupt level only those tasks that require minimum execution time, such as error checking or device status change. The routine should queue all the time-consuming work to transfer the packet from the KSZ8852 RXQ into system memory at task level. Figure 10 shows the step-by-step for receive packets from KSZ8852 to host processor. Note: For each DMA read operation from the host CPU to read the RXQ frame buffer, the first read data (byte in 8-bit bus mode, word in 16-bit bus mode) is dummy data and must be discarded by the host CPU. Afterward, the host CPU must read each data frame to align it with a double word boundary at the end. For example, the host CPU has to read up to 68 bytes if the number of received frames is 65 bytes. Figure 10. Host RX Single or Multiple Frames in Auto-Dequeue Flow Diagram August 31, 2015 47 Revision 1.1 Micrel, Inc. KSZ8852HLE In order to read received frames from RXQ without error, the software driver must follow these steps: 1. When a receive interrupt occurs and the software driver writes a “1” to clear the RX interrupt in the ISR register; the KSZ8852 will update the Rx frame counter (RXFC) register for this interrupt. 2. When the software driver reads back the Rx frame count (RXFC) register, the KSZ8852 will update both the receive frame header status and byte count registers (RXFHSR/RXFHBCR). 3. When the software driver reads back both the receive frame header status and byte count registers (RXFHSR/RXFHBCR), the KSZ8852 will update the next receive frame header status and byte count registers (RXFHSR/RXFHBCR). Device Clocks A 25MHz crystal or oscillator clock is required to operate the device. This clock is used as input to a PLL clock synthesizer which generates 125MHz, 62.5MHz, and 31.25MHz clocks for the KSZ8852 system timing. Table 13 summarizes the clocking. Table 13. KSZ8852 Device Clocks Clock Usage Used for general system internal clocking. 25MHz SEEPROM Clock Used to generate an internal 125MHz clock. Used to clock data to or from the Serial EEPROM. Source A 25MHz crystal connected between pins X1 and X2. (or) A 25MHz oscillator that is connected to only the X1 pin. The X2 pin is left unconnected. Strapping Option None 2.5MHz, divided down from the 25MHz input clock. Can also be software generated via Register 0x122 - 0x123 (EEPCR). After reset time, this is the only way to generate the clock to the Serial EEPROM for access. Note that the clock tree power-down control register (0x038 - 0x039) CTPDC is used to power-down the clocks in various areas of the device. There are no other internal register bits which control the clock generation or usage in the device. August 31, 2015 48 Revision 1.1 Micrel, Inc. KSZ8852HLE Power The KSZ8852 device requires a single 3.3V supply to operate. An internal low voltage LDO provides the necessary low voltage (nominal ~1.3V) to power the analog and digital logic cores. The various I/O’s can be operated at 1.8V, 2.5V, and 3.3V. Table 14 illustrates the various voltage options and requirements of the device. Table 14. Voltage Options and Requirements Power Signal Name Device Pin VDD_A3.3 9 VDD_IO 21, 30, 56 VDD_AL 6 Filtered low-voltage analog input voltage. This is where filtered low voltage is fed back into the device to power the analog block. VDD_COL 16 Filtered low-voltage AD input voltage. This pin feeds low voltage to digital circuits within the analog block. VDD_L 40, 51 Requirement 3.3V input power to the analog blocks in the device. Choice of 1.8V or 2.5V or 3.3V for the I/O circuits. These input power pins power the I/O circuitry of the device. This voltage is also used as the input to the internal low-voltage regulator. Output of internal low voltage LDO regulator. This voltage is available on these pins to allow connection to external capacitors and ferrite beads for filtering and power integrity. These pins must be externally connected to pins 6 and 16. If the internal LDO regulator is turned off, these pins become power inputs. AGND 3, 8, 12 Analog Ground. DGND 20, 29, 39, 50, 57 Digital Ground. The preferred method of configuring the low-voltage related power pins when using an external low-voltage regulator is illustrated in Figure 11. The number of capacitors, values of capacitors, and exact placement of components will depend on the specific design. Figure 11. Recommended Low-Voltage Power Connection using an External Low-Voltage-Regulator August 31, 2015 49 Revision 1.1 Micrel, Inc. KSZ8852HLE Internal Low Voltage LDO Regulator The KSZ8852 reduces board cost and simplifies board layout by integrating a low-noise internal low-voltage LDO regulator to supply the nominal ~1.3V core power voltage for a single 3.3V power supply solution. If it is desired to take advantage of an external low-voltage supply that is available, the internal low-voltage regulator can be disabled to save power. The LDO_Off bit, Bit [7] in Register 0x748 is used to enable or disable the internal low-voltage regulator. The default state of the LDO_Off bit is “0” which enables the internal low-voltage regulator. Turning off the internal low-voltage regulator will require software to write a “1” to that control bit. During the time from power up to setting this bit, both the external voltage supply and the internal regulator will be supplying power. Note that it is not necessary to turn off the internal low-voltage regulator. No damage will occur if it is left on. However, leaving it on will result in less than optimized power consumption. The internal regulator takes its power from VDD_IO, and functions best when VDD_IO is 3.3V or 2.5V. If VDD_IO is 1.8V, the output voltage will be decreased somewhat. For optimal performance, an external power supply, in place of the internal regulator, is recommended when VDD_IO is 1.8V. The preferred method of configuring the low-voltage related power pins for using the internal low-voltage regulator is illustrated in Figure 12. The output of the internal regulator is available on pins 40 and 51 and is filtered using external capacitors and a ferrite bead to supply power to pins 6 and 16. The number of capacitors, values of capacitors, and exact placement of components will depend upon the specific design. Figure 12. Recommended Low-Voltage Power Connections using the Internal Low-Voltage Regulator August 31, 2015 50 Revision 1.1 Micrel, Inc. KSZ8852HLE Power Management The KSZ8852 supports enhanced power management features in low power state with energy detection to ensure lowpower dissipation during device idle periods. There are three operation modes under the power management function which is controlled by two bits in the power management control and wake-up event status register (PMCTRL, 0x032 – 0x033) as shown below: • PMCTRL[1:0] = “00” Normal Operation Mode • PMCTRL[1:0] = “01” Energy Detect Mode • PMCTRL[1:0] = “10” Global Soft Power-Down Mode Table 15 indicates all internal function blocks status under three different power management operation modes. Table 15. Power Management and Internal Blocks KSZ8852 Function Blocks Power Management Operation Modes Normal Mode Energy Detect Mode Soft Power-Down Mode Internal PLL Clock Enabled Enabled Disabled Tx/Rx PHYs Enabled Energy detect at Rx Disabled MACs Enabled Disabled Disabled Host Interface Enabled Enabled Disabled Normal Operation Mode Normal operation mode is the power management mode entered into after device power−up or after hardware reset pin 63. It is established via bits [1:0] = “00” in the PMCTRL register. When the KSZ8852 is in normal operation mode, all PLL clocks are running, PHYs and MACs are on, and the CPU is ready to read or write the KSZ8852 through host interface. During the normal operation mode, the host CPU can change the power management mode bits [1:0] in the PMCTRL register to transition to another desired power management mode Energy Detect Mode Energy Detect mode provides a mechanism to save more power than in normal operation mode when the KSZ8852 is not connected to an active link partner. For example, if the cable is not present or it is connected to a powered down partner, the KSZ8852 can automatically enter the low power state in energy detect mode. Once activity resumes after attaching a cable or by a link partner attempting to establish a link, the KSZ8852 will automatically power up into the normal power state in energy detect normal power state. Energy detect mode consists of two states, normal power state and low power state. While in low power state, the KSZ8852 reduces power consumption by disabling all circuitry except the energy detect circuitry of the receiver. Energy detect mode is enabled by setting bits [1:0] = “01” in the PMCTRL register. When the KSZ8852 is in this mode, it will monitor the cable energy. If there is no energy on the cable for a time longer than a pre−configured value determined by bits[7:0] (Go−Sleep Time) in the GST register, the device will go into the low power state. When the KSZ8852 is in low power state, it will keep monitoring the cable energy. Once energy is detected from the cable and is present for a time longer than 100ns, the KSZ8852 will enter the normal power state. The KSZ8852 will assert the PME output pin if the corresponding enable bit[0] is set in the PMEE register (0x034) or generate an interrupt to signal that an energy detect event has occurred if the corresponding enable bit[2] is set in the IER register (0x190). Once the local power management unit detects the PME output is asserted or that the interrupt is active, it will power up the host processor and issue a Wake-up command which is a read cycle to read the globe reset register, GRR (0x126) to wake up the KSZ8852 from the low power state to the normal power state. When the KSZ8852 device is in the normal power state, it is able to transmit or receive packet from the cable. August 31, 2015 51 Revision 1.1 Micrel, Inc. KSZ8852HLE Global Soft Power-Down Mode Soft power-down mode is entered by setting bits [1:0] = “10” in PMCTRL register. When the device is in this mode, all PLL clocks are disabled, the PHYs and the MACs are off, all internal registers value will change to their default value (except the BIU, QMU registers), and the host CPU interface is only used to wake-up this device from the current soft power-down mode to normal operation mode by setting bits [1:0] = “00” in the PMCTRL register. Note that the registers within the QMU block will not be changed to their default values when a soft power-down is issued. All strap-in pins are sampled to latch any new values when soft power-down is disabled. Energy-Efficient Ethernet (EEE) Energy Efficient Ethernet (EEE) is implemented in the KSZ8852 as described in the IEEE 802.3AZ specification for MII operations on Port 1 and Port 2. EEE is not performed at Port 3 since that is a Parallel Host interface. The MII connections between the MAC and PHY blocks are internal to the chip and are not visible to the user. The standards are defined around a MAC that supports special signaling associated with EEE. EEE saves power by keeping the voltage on the Ethernet cable at approximately 0V for as often as possible during periods of no traffic activity. This is called lowpower idle state (LPI). However, the link will respond automatically when traffic resumes and do so in such a way as to not cause blocking or dropping of any packets. (The wake up time for 100BT is specified to be less than 30µs.) The transmit and receive directions are independently controlled. Note the EEE is not specified or implemented for 10BT. In 10BT, the transmitter is already OFF during idle periods. The EEE feature is enabled by default. EEE is auto-negotiated independently for each direction on a link, and is enabled only if both nodes on a link support it. To disable EEE, clear the next page enable bit(s) for the desired port(s) in the PCSEEEC register (0x0F3) and restart auto-negotiation. Based on the EEE specification, the energy savings from EEE occurs at the PHY level. However, the KSZ8852 reduces the power consumption not only in the PHY block but also in the MAC and switch blocks by shutting down any unused clocks as much as possible when the device is at LPI state. A comprehensive LPI request on/off policy is also built-in at the switch level to determine when to issue LPI requests and when to stop the LPI request. Some software control options are provided in the device to terminate the LPI request in the early phase when certain events occur to reduce the latency impact during LPI recovery. A configurable LPI recovery time register is provided at each port to specify the recovery time (25µs at default) required for the KSZ8852 and its link partner before they are ready to transmit and receive a packet after going back to the normal state. For details, refer the KSZ8852 EEE registers (0x0E0 – 0x0F7) description. Figure 13 illustrates the time during which LPI mode is active is during what is called quiet time. Figure 13. Traffic Activity and EEE August 31, 2015 52 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-On-LAN Wake-on-LAN is considered a power-management feature in that it can be used to communicate to a specific network device and tell it to “wake up” from sleep mode and be prepared to transfer data. The KSZ8852 can be programmed to notify the host of the wake-up detected condition. It does so by assertion of the interrupt signal pin (INTRN) or the power management event signal pin (PME). A wake-up event is a request for hardware and/or software external to the network device to put the system into a powered state (working). There are four events that will trigger the wake-up interrupt to occur. They are: 1. Detection of an energy signal over a pre-configured value (Indicated by bit[2] in the ISR register being set) 2. Detection of a linkup in the network link state (Indicated by bit[3] in the ISR register being set) 3. Receipt of a Magic Packet (Indicated by bit[4] in the ISR register being set) 4. Receipt of a network wake-up frame (Indicated by bit[5] in the ISR register being set) There are also other types of wake-up events that are not listed here as manufacturers may choose to implement these in their own way. Detection of Energy The energy is detected from the cable and is continuously presented for a time longer than pre-configured value, especially when this energy change may impact the level at which the system should re-enter to the normal power state. Detection of Linkup Link status wake events are useful to indicate a linkup in the network’s connectivity status. Wake-Up Packet Wake-up packets are certain types of packets with specific CRC values that a system recognizes as a ‘Wake-Up’ frame. The KSZ8852 supports up to four user defined wake−up frames shown below: • Wake-up frame 0 is defined in wake-up frame registers (0x130 – 0x13B) and is enabled by bit [0] in the Wake-Up frame register (0x12A). • Wake-up frame 1 is defined in wake-up frame registers (0x140 – 0x14B) and is enabled by bit [1] in the Wake-Up frame register (0x12A). • Wake-up frame 2 is defined in wake-up frame registers (0x150 – 0x15B) and is enabled by bit [2] in the Wake-Up frame register (0x12A). • Wake-up frame 3 is defined in wake-up frame registers (0x160 – 0x16B) and is enabled by bit [3] in the Wake-Up frame register (0x12A). Magic Packet™ Magic Packet (MP) technology is used to remotely wake up a sleeping or powered off PC on a LAN. This is accomplished by sending a specific packet of information, called a MP frame, to a node on the network. When a PC capable of receiving the specific frame goes to sleep, it enables the MP RX mode in the LAN controller, and when the LAN controller receives a MP frame, the LAN controller will alert the system to wake up. MP is a standard feature integrated into the KSZ8852. The controller implements multiple advanced power-down modes including MP to conserve power and operate more efficiently. Once the KSZ8852 has been put into MP enable mode (WFCR[7] = “1”), it scans all incoming frames addressed to the node for a specific data sequence, which indicates to the controller this is a MP frame. The specific sequence consists of 16 duplications of the IEEE address of this node, with no breaks or interruptions. This sequence can be located anywhere within the packet, but must be preceded by a synchronization stream. The synchronization stream allows the scanning state machine to be much simpler. The synchronization stream is defined as 6 bytes of FFh. The device will also accept a broadcast frame, as long as the 16 duplications of the IEEE address match the address of the machine to be awakened. Example: If the IEEE address for a particular node on a network is 11h 22h, 33h, 44h, 55h, 66h, the LAN controller would be scanning for the data sequence (assuming an Ethernet frame): DESTINATION SOURCE – MISC − FF FF FF FF FF FF − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 August 31, 2015 53 Revision 1.1 Micrel, Inc. KSZ8852HLE 66 −11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − 11 22 33 44 55 66 − MISC − CRC. There are no further restrictions on an MP frame. For example, the sequence could be in a TCP/IP packet or an IPX packet. The frame may be bridged or routed across the network without affecting its ability to wake−up a node at the frame’s destination. If the LAN controller scans a frame and does not find the specific sequence shown above, it discards the frame and takes no further action. If the KSZ8852 controller detects the data sequence, however, it then alerts the PC’s power management circuitry (assert the PME pin) to wake up the system. Interrupt Generation on Power Management Related Events There are two ways an interrupt can be generated to the host whenever a power management related event takes place. The resulting interrupts are via the PME signal pin or via the INTRN signal pin. The usage is described in the following sub-sections: To Generate an Interrupt on the PME Signal Pin The PMEE register (0x034 - 0x035) contains the bits needed to control generating an interrupt on the PME signal pin whenever specific power management related events occur. The power management events controlled by this register includes detection of a Wake-Up frame, detection of a MP, detection that the link has changed state, and detection of energy on the Ethernet lines. To Generate an Interrupt on the INTRN Signal Pin The IER register (0x190 - 0x191) contains the bits needed to control generating an interrupt on the INTRN signal pin whenever specific power management related events occur. The power management events controlled by this register includes detection of a wake-up from a link state change and wake-up from detection of energy on the Ethernet lines. August 31, 2015 54 Revision 1.1 Micrel, Inc. KSZ8852HLE Interfaces The KSZ8852 device incorporates a number of interfaces to enable it to be designed into a standard network environment as well as a vendor unique environment. The available interfaces and details of each usage are provided in Table 16. Table 16. Available Interfaces Interface Type Usage Registers Accessed Host Bus Configuration and Data Flow Provides a path for network data to be transferred to and from the host processor. Provides in-band communication between a host processor and the KSZ8852 device for configuration, control, and monitoring. ALL Serial EEPROM Configuration and Register Access Device can access the Serial EEPROM to load the MAC Address at power-up. In addition, the remainder of EEPROM space can be written or read and used as needed by the host. 110h − 115h PHY Data Flow Interface to the two internal PHY devices. N/A Bus Interface Unit (BIU) / Host Interface The BIU manages the host interface which is a generic indirect data bus interface, and is designed to communicate with embedded processors. Typically, no glue logic is required when interfacing to standard asynchronous buses and processors. Supported Transfers The BIU can support asynchronous transfers in SRAM-like slave mode. To support the data transfers, the BIU provides a group of signals as shown in Table 17. These signals are SD[15:0], CMD, CSN, RDN, WRN, and INTRN. Note that it is intended that the CSN signal be driven by logic within the host processor or by some external logic which decode the base address so the KSZ8852 device does not have to do address range decoding. Physical Data Bus Size The BIU supports an 8-bit or 16-bit host standard data bus. Depending on the size of the physical data bus, the KSZ8852 can support 8-bit or 16-bit data transfers. For a 16-bit data bus mode, the KSZ8852 allows an 8−bit and 16−bit data transfer. For an 8-bit data bus mode, the KSZ8852 only allows an 8−bit data transfer. The KSZ8852 supports internal data byte-swapping. This means that the system/host data bus HD[7:0] connects to SD[7:0] for an 8−bit data bus interface. For a 16-bit data bus, the system/host data bus HD[15:8] and HD[7:0] connects to SD[15:8] and SD[7:0] respectively. August 31, 2015 55 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 17. Bus Interface Unit Signal Grouping Signal Type Function Shared Data Bus SD[15:0] I/O 16-bit Mode & CMD = “0” SD[15:0] = D[15:0] data 16-bit Mode & CMD = “1”: SD[10:2] = A[10:2] Address SD[15:12] = BE[3:0] Byte enable SD[1:0] and SD[11] are not used 8-bit Mode & CMD = “0” SD[7:0] = D[7:0] data 8-bit Mode & CMD = “1” SD[7:0] = A[7:0] = 1st address access SD[2:0] = A[10:8] = 2nd address access SD[7:3] = Not used during 2nd address access Command Type CMD Input CSN Input INTRN Output RDN Input WRN Input This command input determines the SD[15:0] shared data bus access cycle information. 0: Data access 1: Command access for address and byte enable Chip Select Chip Select is an active low signal used to enable the shared data bus access. Interrupt This low active signal is asserted low when an interrupt is being requested. Asynchronous Read This low active signal is asserted low during a read cycle. A 4.7K pull-up resistor is recommended on this signal. Asynchronous Write This low active signal is asserted low during a write cycle. Little and Big Endian Support The KSZ8852 supports either Little−Endian or Big−Endian processors. The external strap pin 62 (P2LED0) is used to select between two modes. The KSZ8852 host interface operates in Little Endian mode if this pin is pulled up during reset, or in Big Endian mode if this pin is pulled down during reset. If there is no external load on pin 62 during reset, it will be pulled up by its internal pull-up resistor, placing the interface into Little Endian mode. Bit [11] (Endian mode selection) in RXFDPR register can be used to program either Little Endian mode (bit[11] = “0”) or Big Endian mode (bit [11] = “1”). Changes to this register bit will over-ride the pin 62 strap-in selection. Software in the host processor must take care to avoid unintentionally changing bit [11] when writing to register RXFDPR. Asynchronous Interface For asynchronous transfers, the asynchronous interface uses RDN (read) or WRN (write) signal strobe for data latching. The host utilizes the rising edge of RDN to latch read data and the KSZ8852 will use the falling edge of WRN to latch write data. All asynchronous transfers are either single-data or burst-data transfers. Byte or word data bus access (transfers) is supported. The BIU, however, provides flexible asynchronous interfacing to communicate with various applications and architectures. No additional address latch is required. The BIU qualifies both chip select (CSN) pin and write enable (WRN) pin to write the Address A[10:2] and BE[3:0] value (in 16-bit mode) or Address A[10:0] value (in 8-bit mode with two write accesses) into KSZ8852 when CMD (Command type) pin is high. The BIU qualifies the CSN pin as well as the read enable (RDN) or write enable (WRN) pin to read or write the SD[15:0] (16-bit mode) or SD[7:0] (8-bit mode) data value from or to KSZ8852 when command type (CMD) pin is low. In order for software to read back the previous CMD register write value when CMD is “1”, the BIU qualifies both the CSN pin and the RDN pin to read the Address A[10:2] and BE[3:0] value (in 16−bit mode) back from the KSZ8852 when CMD pin is high. Reading back the addresses in 8-bit mode is not a valid operation. August 31, 2015 56 Revision 1.1 Micrel, Inc. KSZ8852HLE BIU Summary Figure 14 shows the connection for different data bus sizes. All of control and status registers in the KSZ8852 are accessed indirectly depending upon the CMD pin. The command sequence to access the specified control or status register is to write the register’s address (when CMD = “1”) then read or write this register data (when CMD = “0”). If both RDN and WRN signals in the system are only used for KSZ8852, the CSN pin can be forced to active low to simplify the system design. The CMD pin can be connected to host address line HA[0] for 8-bit bus mode or HA[1] for 16-bit bus mode. Figure 14. KSZ8852 8-Bit and 16-Bit Data Bus Connections Example: Assume that the register space is located at an external I/O base address of 0x0300, a 16-bit data path is used, and it is desired to read two bytes of data from address 0xD0: • External address decoding should decode the 0x0300 base address and create a signal for the CSN pin. • The host address line 1 (HA[1]) is connected to the CMD input pin. For a host write to the device, the HA[1] being asserted will make CMD = “1” which will indicate that the data on the DS[15:0] bus are address and byte enable bits. • As shown in Figure 14, the address bits A[10:2] are on SD[10:2]. • Write a value of 0x30D0 (register offset of 0xD0 with BE[1:0] (set on the SD[16:0] bus) to address 0x0302. (This sets up the address for the upcoming read operation by writing the desired destination address to be read.) • Read the value from address 0x0300 with HA[1] = 0 (CMD =” “0”). The CSN pin is driven again by the decode of the base address of 0x0300. August 31, 2015 57 Revision 1.1 Micrel, Inc. KSZ8852HLE Serial EEPROM Interface A serial EEPROM interface has been incorporated into the device to enable loading the MAC address into the device at power-up time with a value from an external serial EEPROM. This feature is turned on using a strapping option on pin 46. At power-up time, the voltage on pin 46 is sampled. If the voltage is found to be high, the first seven words of the serial EEPROM will be read. Registers 0x110 – 0x115 will be loaded with words 01h – 03h. A pull-up resistor is connected to pin 46 to create a high state at power-up time (see Strapping Options). After the de−assertion of RSTN, the KSZ8852 reads in the seven words of data. Note that a 3−wire 1Kbit serial EEPROM utilizing 7−bit addresses must be used. Other size options will not function correctly. A 93C46 or equivalent type device meets these requirements. The EEPROM must be organized in 16−bit mode. If the EEDIO pin (pin 54) is pulled high, then the KSZ8852 performs an automatic read of words 0h – 6h in the external EEPROM after the de−assertion of reset. The EEPROM values are placed in certain host−accessible registers. EEPROM read/write functions can also be performed by software read/writes to the EEPCR (0x122) registers. See Figure 18 in the Timing Specification section for the details of the serial EEPROM access timing. A sample of the KSZ8852 EEPROM format is shown in Table 18. Table 18. KSZ8852 Serial EEPROM Format Word 15 8 0h 7 0 Reserved 1h Host MAC Address Byte 2 Host MAC Address Byte 1 2h Host MAC Address Byte 4 Host MAC Address Byte 3 3h Host MAC Address Byte 6 Host MAC Address Byte 5 4h - 6h Reserved 7h - 3Fh Not used for the KSZ8852 (Available for user defined purposes) August 31, 2015 58 Revision 1.1 Micrel, Inc. KSZ8852HLE Device Registers The KSZ8852 device has a rich set of registers available to manage the functionality of the device. Access to these registers is via the host interface (BIU). The device can be programmed to automatically load register locations 0x110 0x115 with a MAC address stored in Word locations 01h - 03h in an external serial EEPROM. Figure 15 provides a global picture of accessibility via the various interfaces and addressing ranges from the perspective of each interface. Figure 15. Interface and Register Mapping The registers within the linear 0x000 - 0x7FF address space are all accessible via the host interface bus by a microprocessor or CPU. The mapping of the various functions within that linear address space is summarized in Table 19. August 31, 2015 59 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 19. Mapping of Functional Areas within the Address Space Register Locations Device Area 0x000 - 0x0FF Switch Control and Configuration Registers which control the overall functionality of the Switch, MAC, and PHYs 0x026 - 0x031 Indirect Access Registers Registers used to indirectly address and access four distinct areas within the device. − MIB (Management Information Base) Counters − Static MAC Address Table − Dynamic MAC Address Table − VLAN Table 0x044 - 0x06B PHY1 and PHY2 Registers 0x100 - 0x16F Interrupts, Global Reset, BIU 0x170 - 0x7FF QMU and Global Registers August 31, 2015 Description The same PHY registers as specified in IEEE 802.3 specification. Registers and bits associated with interrupts, global reset, and the BIU Registers and bits associated with the QMU 60 Revision 1.1 Micrel, Inc. KSZ8852HLE Register Map of CPU Accessible I/O Registers The registers in the address range 00h through 7FFh can be read or written by a local CPU attached to the host interface. If enabled, registers 0x110 - 0x115 can be loaded at power on time by contents in the serial EEPROM. These registers are used for configuring the MAC address of the device. I/O Registers The following I/O register space mapping table applies to 8-bit or 16-bit locations. Depending upon the mode selected, each I/O access can be performed using 8-bit or 16-bit wide transfers. Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) I/O Register Offset Location Register Name Default Value 0x000 0x001 CIDER 0x8433 Chip ID and Enable Register [15:0] 0x002 - 0x003 0x002 0x003 SGCR1 0x3450 Switch Global Control Register 1 [15:0] 0x004 - 0x005 0x004 0x005 SGCR2 0x00F0 Switch Global Control Register 2 [15:0] 0x006 - 0x007 0x006 0x007 SGCR3 0x6320 Switch Global Control Register 3 [15:0] 0x008 - 0x00B 0x008 0x00B Reserved (4-Bytes) Don’t Care 0x00C - 0x00D 0x00C 0x00D SGCR6 0xFA50 Switch Global Control Register 6 [15:0] 0x00E - 0x00F 0x00E 0x00F SGCR7 0x0827 Switch Global Control Register 7 [15:0] 0x010 - 0x011 0x010 0x011 MACAR1 0x0010 MAC Address Register 1 [15:0] 0x012 - 0x013 0x012 0x013 MACAR2 0xA1FF MAC Address Register 2 [15:0] 0x014 - 0x015 0x014 0x015 MACAR3 0xFFFF MAC Address Register 3 [15:0] 0x016 - 0x017 0x016 0x017 TOSR1 0x0000 TOS Priority Control Register 1 [15:0] 0x018 - 0x019 0x018 0x019 TOSR2 0x0000 TOS Priority Control Register 2 [15:0] 0x01A - 0x01B 0x01A 0x01B TOSR3 0x0000 TOS Priority Control Register 3 [15:0] 0x01C - 0x01D 0x01C 0x01D TOSR4 0x0000 TOS Priority Control Register 4 [15:0] 16-Bit 8-Bit 0x000 - 0x001 August 31, 2015 61 Description None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) (Continued) I/O Register Offset Location Register Name Default Value 0x01E 0x01F TOSR5 0x0000 TOS Priority Control Register 5 [15:0] 0x020 - 0x021 0x020 0x021 TOSR6 0x0000 TOS Priority Control Register 6 [15:0] 0x022 - 0x023 0x022 0x023 TOSR7 0x0000 TOS Priority Control Register 7 [15:0] 0x024 - 0x025 0x024 0x025 TOSR8 0x0000 TOS Priority Control Register 8 [15:0] 0x026 - 0x027 0x026 0x027 IADR1 0x0000 Indirect Access Data Register 1 [15:0] 0x028 - 0x029 0x028 0x029 IADR2 0x0000 Indirect Access Data Register 2 [15:0] 0x02A - 0x02B 0x02A 0x02B IADR3 0x0000 Indirect Access Data Register 3 [15:0] 0x02C - 0x02D 0x02C 0x02D IADR4 0x0000 Indirect Access Data Register 4 [15:0] 0x02E - 0x02F 0x02E 0x02F IADR5 0x0000 Indirect Access Data Register 5 [15:0] 0x030 - 0x031 0x030 0x031 IACR 0x0000 Indirect Access Control Register [15:0] 0x032 - 0x033 0x032 0x033 PMCTRL 0x0000 Power Management Control and Wake−up Event Status Register [15:0] 0x034 - 0x035 0x034 0x035 PMEE 0x0000 Power Management Event Enable Register [15:0] 0x036 - 0x037 0x036 0x037 GST 0x008E Go Sleep Time Register [15:0] 0x038 - 0x039 0x038 0x039 CTPDC 0x0000 Clock Tree Power Down Control Register [15:0] 0x03A - 0x04B 0x03A 0x04B Reserved (18−Bytes) Don’t care 0x04C - 0x04D 0x04C 0x04D P1MBCR 0x3120 PHY 1 and MII Basic Control Register [15:0] 0x04E - 0x04F 0x04E 0x04F P1MBSR 0x7808 PHY 1 and MII Basic Status Register [15:0] 0x050 - 0x051 0x050 0x051 PHY1ILR 0x1430 PHY 1 PHYID Low Register [15:0] 0x052 - 0x053 0x052 0x053 PHY1IHR 0x0022 PHY 1 PHYID High Register [15:0] 16-Bit 8-Bit 0x01E - 0x01F August 31, 2015 62 Description None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) (Continued) I/O Register Offset Location Register Name Default Value 0x054 0x055 P1ANAR 0x05E1 PHY 1 Auto-Negotiation Advertisement Register [15:0] 0x056 - 0x057 0x056 0x057 P1ANLPR 0x0001 PHY 1 Auto-Negotiation Link Partner Ability Register [15:0] 0x058 - 0x059 0x058 0x059 P2MBCR 0x3120 PHY 2 and MII Basic Control Register [15:0] 0x05A - 0x05B 0x05A 0x05B P2MBSR 0x7808 PHY 2 and MII Basic Status Register [15:0] 0x05C - 0x05D 0x05C 0x05D PHY2ILR 0x1430 PHY 2 PHYID Low Register [15:0] 0x05E - 0x05F 0x05E 0x05F PHY2IHR 0x0022 PHY 2 PHYID High Register [15:0] 0x060 - 0x061 0x060 0x061 P2ANAR 0x05E1 PHY 2 Auto-Negotiation Advertisement Register [15:0] 0x062 - 0x063 0x062 0x063 P2ANLPR 0x0001 PHY 2 Auto-Negotiation Link Partner Ability Register [15:0] 0x064 - 0x065 0x064 0x065 Reserved (2-Bytes) Don’t Care 0x066 - 0x067 0x066 0x067 P1PHYCTRL 0x0004 0x068 - 0x069 0x068 0x069 Reserved (2-Bytes) Don’t Care 0x06A - 0x06B 0x06A 0x06B P2PHYCTRL 0x0004 PHY 2 Special Control and Status Register [15:0] 0x06C - 0x06D 0x06C 0x06D P1CR1 0x0000 Port 1 Control Register 1 [15:0] 0x06E - 0x06F 0x06E 0x06F P1CR2 0x0607 Port 1 Control Register 2 [15:0] 0x070 - 0x071 0x070 0x071 P1VIDCR 0x0001 Port 1 VID Control Register [15:0] 0x072 - 0x073 0x072 0x073 P1CR3 0x0000 Port 1 Control Register 3 [15:0] 0x074 - 0x075 0x074 0x075 P1IRCR0 0x0000 Port 1 Ingress Rate Control Register 0 [15:0] 0x076 - 0x077 0x076 0x077 P1IRCR1 0x0000 Port 1 Ingress Rate Control Register 1 [15:0] 16-Bit 8-Bit 0x054 - 0x055 August 31, 2015 63 Description None PHY 1 Special Control and Status Register [15:0] None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) (Continued) I/O Register Offset Location Register Name Default Value 0x078 0x079 P1ERCR0 0x0000 Port 1 Egress Rate Control Register 0 [15:0] 0x07A - 0x07B 0x07A 0x07B P1ERCR1 0x0000 Port 1 Egress Rate Control Register 1 [15:0] 0x07C - 0x07D 0x07C 0x07D P1SCSLMD 0x0400 Port 1 PHY Special Control/Status, LinkMD Register [15:0] 0x07E - 0x07F 0x07E 0x07F P1CR4 0x00FF Port 1 Control Register 4 [15:0] 0x080 - 0x081 0x080 0x081 P1SR 0x8000 Port 1 Status Register [15:0] 0x082 - 0x083 0x082 0x083 Reserved (2-Bytes) Don’t Care 0x084 - 0x085 0x084 0x085 P2CR1 0x0000 Port 2 Control Register 1 [15:0] 0x086 - 0x087 0x086 0x087 P2CR2 0x0607 Port 2 Control Register 2 [15:0] 0x088 - 0x089 0x088 0x089 P2VIDCR 0x0001 Port 2 VID Control Register [15:0] 0x08A - 0x08B 0x08A 0x08B P2CR3 0x0000 Port 2 Control Register 3 [15:0] 0x08C - 0x08D 0x08C 0x08D P2IRCR0 0x0000 Port 2 Ingress Rate Control Register 0 [15:0] 0x08E - 0x08F 0x08E 0x08F P2IRCR1 0x0000 Port 2 Ingress Rate Control Register 1 [15:0] 0x090 - 0x091 0x090 0x091 P2ERCR0 0x0000 Port 2 Egress Rate Control Register 0 [15:0] 0x092 - 0x093 0x092 0x093 P2ERCR1 0x0000 Port 2 Egress Rate Control Register 1 [15:0] 0x094 - 0x095 0x094 0x095 P2SCSLMD 0x0400 Port 2 PHY Special Control/Status, LinkMD Register [15:0] 0x096 - 0x097 0x096 0x097 P2CR4 0x00FF Port 2 Control Register 4 [15:0] 0x098 - 0x099 0x098 0x099 P2SR 0x8000 Port 2 Status Register [15:0] 0x09A - 0x09B 0x09A 0x09B Reserved (2-Bytes) Don’t care 16-Bit 8-Bit 0x078 - 0x079 August 31, 2015 Description ® 64 None None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) (Continued) I/O Register Offset Location Register Name Default Value 0x09C 0x09D P3CR1 0x0000 Port 3 Control Register 1 [15:0] 0x09E - 0x09F 0x09E 0x09F P3CR2 0x0607 Port 3 Control Register 2 [15:0] 0x0A0 - 0x0A1 0x0A0 0x0A1 P3VIDCR 0x0001 Port 3 VID Control Register [15:0] 0x0A2 - 0x0A3 0x0A2 0x0A3 P3CR3 0x0000 Port 3 Control Register 3 [15:0] 0x0A4 - 0x0A5 0x0A4 0x0A5 P3IRCR0 0x0000 Port 3 Ingress Rate Control Register 0 [15:0] 0x0A6 - 0x0A7 0x0A6 0x0A7 P3IRCR1 0x0000 Port 3 Ingress Rate Control Register 1 [15:0] 0x0A8 - 0x0A9 0x0A8 0x0A9 P3ERCR0 0x0000 Port 3 Egress Rate Control Register 0 [15:0] 0x0AA - 0x0AB 0x0AA 0x0AB P3ERCR1 0x0000 Port 3 Egress Rate Control Register 1 [15:0] 0x0AC - 0x0AD 0x0AC 0x0AD SGCR8 0x8000 Switch Global Control Register 8 [15:0] 0x0AE - 0x0AF 0x0AE 0x0AF SGCR9 0x0000 Switch Global Control Register 9 [15:0] 0x0B0 - 0x0B1 0x0B0 0x0B1 SAFMACA1L 0x0000 Source Address Filtering MAC Address 1 Register Low [15:0] 0x0B2 - 0x0B3 0x0B2 0x0B3 SAFMACA1M 0x0000 Source Address Filtering MAC Address 1 Register Middle [15:0] 0x0B4 - 0x0B5 0x0B4 0x0B5 SAFMACA1H 0x0000 Source Address Filtering MAC Address 1 Register High [15:0] 0x0B6 - 0x0B7 0x0B6 0x0B7 SAFMACA2L 0x0000 Source Address Filtering MAC Address 2 Register Low [15:0] 0x0B8 - 0x0B9 0x0B8 0x0B9 SAFMACA2M 0x0000 Source Address Filtering MAC Address 2 Register Middle [15:0] 0x0BA - 0x0BB 0x0BA 0x0BB SAFMACA2H 0x0000 Source Address Filtering MAC Address 2 Register High [15:0] 0x0BC - 0x0C7 0x0BC 0x0C7 Reserved (12−Bytes) Don’t Care 0x0C8 - 0x0C9 0x0C8 0x0C9 P1TXQRCR1 0x8488 16-Bit 8-Bit 0x09C - 0x09D August 31, 2015 65 Description None Port 1 TXQ Rate Control Register 1 [15:0] Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Switch Control and Configuration (0x000 - 0x0FF) (Continued) I/O Register Offset Location Register Name Default Value Description 0x0CA 0x0CB P1TXQRCR2 0x8182 Port 1 TXQ Rate Control Register 2 [15:0] 0x0CC - 0x0CD 0x0CC 0x0CD P2TXQRCR1 0x8488 Port 2 TXQ Rate Control Register 1 [15:0] 0x0CE - 0x0CF 0x0CE 0x0CF P2TXQRCR2 0x8182 Port 2 TXQ Rate Control Register 2 [15:0] 0x0D0 - 0x0D1 0x0D0 0x0D1 P3TXQRCR1 0x8488 Port 3 TXQ Rate Control Register 1 [15:0] 0x0D2 - 0x0D3 0x0D2 0x0D3 P3TXQRCR2 0x8182 Port 3 TXQ Rate Control Register 2 [15:0] 0x0D4 - 0x0DB 0x0D4 0x0DB Reserved (8−Bytes) Don’t Care 0x0DC - 0x0DD 0x0DC 0x0DD P1ANPT 0x2001 Port 1 Auto−Negotiation Next Page Transmit Register [15:0] 0x0DE - 0x0DF 0x0DE 0x0DF P1ALPRNP 0x0000 Port 1 Auto−Negotiation Link Partner Received Next Page Register [15:0] 0x0E0 - 0x0E1 0x0E0 0x0E1 P1EEEA 0x0002 Port 1 EEE and Link Partner Advertisement Register [15:0] 0x0E2 - 0x0E3 0x0E2 0x0E3 P1EEEWEC 0x0000 Port 1 EEE Wake Error Count Register [15:0] 0x0E4 - 0x0E5 0x0E4 0x0E5 P1EEECS 0x8064 Port 1 EEE Control/Status and Auto−Negotiation Expansion Register [15:0] 0x0E6 - 0x0E7 0x0E6 0x0E7 P1LPIRTC BL2LPIC1 0x27 0x08 Port 1 LPI Recovery Time Counter Register [7:0] Buffer Load to LPI Control 1 Register [7:0] 0x0E8 - 0x0E9 0x0E8 0x0E9 P2ANPT 0x2001 Port 2 Auto−Negotiation Next Page Transmit Register [15:0] 0x0EA - 0x0EB 0x0EA 0x0EB P2ALPRNP 0x0000 Port 2 Auto−Negotiation Link Partner Received Next Page Register [15:0] 0x0EC - 0x0ED 0x0EC 0x0ED P2EEEA 0x0002 Port 2 EEE and Link Partner Advertisement Register [15:0] 0x0EE - 0x0EF 0x0EE 0x0EF P2EEEWEC 0x0000 Port 2 EEE Wake Error Count Register [15:0] 0x0F0 - 0x0F1 0x0F0 0x0F1 P2EEECS 0x8064 Port 2 EEE Control/Status and Auto−Negotiation Expansion Register [15:0] 0x0F2 - 0x0F3 0x0F2 0x0F3 P2LPIRTC PCSEEEC 0x27 0x03 Port 2 LPI Recovery Time Counter Register [7:0] PCS EEE Control Register [7:0] 0x0F4 - 0x0F5 0x0F4 0x0F5 ETLWTC 0x03E8 Empty TXQ to LPI Wait Time Control Register [15:0] 0x0F6 - 0x0F7 0x0F6 0x0F7 BL2LPIC2 0xC040 Buffer Load to LPI Control 2 Register [15:0] 0x0F8 - 0x0FF 0x0F8 0x0FF Reserved (8−Bytes) Don’t Care 16-Bit 8-Bit 0x0CA - 0x0CB August 31, 2015 66 None None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Host Interface Unit (0x100 - 0x16F) I/O Register Offset Location Register Name Default Value 0x100 0x107 Reserved (8−Bytes) Don’t Care None 0x108 - 0x109 0x108 0x109 CCR Read only Chip Configuration Register [15:0] 0x10A - 0x10F 0x10A 0x10F Reserved (6−Bytes) Don’t Care None 0x110 - 0x111 0x110 0x111 MARL − MAC Address Register Low [15:0] 0x112 - 0x113 0x112 0x113 MARM − MAC Address Register Middle [15:0] 0x114 - 0x115 0x114 0x115 MARH − MAC Address Register High [15:0] 0x116 - 0x121 0x116 0x121 Reserved (12−Bytes) Don’t Care 0x122 - 0x123 0x122 0x123 EEPCR 0x0000 EEPROM Control Register [15:0] 0x124 - 0x125 0x124 0x125 MBIR 0x0000 Memory BIST Info Register [15:0] 0x126 - 0x127 0x126 0x127 GRR 0x0000 Global Reset Register [15:0] 0x128 - 0x129 0x128 0x129 Reserved (2−Bytes) Don’t Care 16-Bit 8-Bit 0x100 - 0x107 August 31, 2015 67 Description None None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Host Interface Unit (0x100 - 0x16F) (Continued) I/O Register Offset Location Register Name Default Value 0x12A 0x12B WFCR 0x0000 0x12C - 0x12F 0x12C 0x12F Reserved (4−Bytes) Don’t Care 0x130 - 0x131 0x130 0x131 WF0CRC0 0x0000 Wake-Up Frame 0 CRC0 Register [15:0] 0x132 - 0x133 0x132 0x133 WF0CRC1 0x0000 Wake-Up Frame 0 CRC1 Register [15:0] 0x134 - 0x135 0x134 0x135 WF0BM0 0x0000 Wake-Up Frame 0 Byte Mask 0 Register [15:0] 0x136 - 0x137 0x136 0x137 WF0BM1 0x0000 Wake-Up Frame 0 Byte Mask 1 Register [15:0] 0x138 - 0x139 0x138 0x139 WF0BM2 0x0000 Wake-Up Frame 0 Byte Mask 2 Register [15:0] 0x13A - 0x13B 0x13A 0x13B WF0BM3 0x0000 Wake-Up Frame 0 Byte Mask 3 Register [15:0] 0x13C - 0x13F 0x13C 0x13F Reserved (4−Bytes) Don’t care 0x140 - 0x141 0x140 0x141 WF1CRC0 0x0000 Wake-Up Frame 1 CRC0 Register [15:0] 0x142 - 0x143 0x142 0x143 WF1CRC1 0x0000 Wake-Up Frame 1 CRC1 Register [15:0] 0x144 - 0x145 0x144 0x145 WF1BM0 0x0000 Wake-Up Frame 1 Byte Mask 0 Register [15:0] 0x146 - 0x147 0x146 0x147 WF1BM1 0x0000 Wake-Up Frame 1 Byte Mask 1 Register [15:0] 0x148 - 0x149 0x148 0x149 WF1BM2 0x0000 Wake-Up Frame 1 Byte Mask 2 Register [15:0] 0x14A - 0x14B 0x14A 0x14B WF1BM3 0x0000 Wake-Up Frame 1 Byte Mask 3 Register [15:0] 0x14C - 0x14F 0x14C 0x14F Reserved (4−Bytes) Don’t Care 0x150 - 0x151 0x150 0x151 WF2CRC0 0x0000 Wake-Up Frame 2 CRC0 Register [15:0] 0x152 - 0x153 0x152 0x153 WF2CRC1 0x0000 Wake-Up Frame 2 CRC1 Register [15:0] 0x154 - 0x155 0x154 0x155 WF2BM0 0x0000 Wake-Up Frame 2 Byte Mask 0 Register [15:0] 16-Bit 8-Bit 0x12A - 0x12B August 31, 2015 Description Wake-Up Frame Control Register [15:0] 68 None None None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Host Interface Unit (0x100 - 0x16F) (Continued) I/O Register Offset Location Register Name Default Value 0x156 0x157 WF2BM1 0x0000 Wake-Up Frame 2 Byte Mask 1 Register [15:0] 0x158 - 0x159 0x158 0x159 WF2BM2 0x0000 Wake-Up Frame 2 Byte Mask 2 Register [15:0] 0x15A - 0x15B 0x15A 0x15B WF2BM3 0x0000 Wake-Up Frame 2 Byte Mask 3 Register [15:0] 0x15C - 0x15F 0x15C 0x15F Reserved (4−Bytes) Don’t Care 0x160 - 0x161 0x160 0x161 WF3CRC0 0x0000 Wake-Up Frame 3 CRC0 Register [15:0] 0x162 - 0x163 0x162 0x163 WF3CRC1 0x0000 Wake-Up Frame 3 CRC1 Register [15:0] 0x164 - 0x165 0x164 0x165 WF3BM0 0x0000 Wake-Up Frame 3 Byte Mask 0 Register [15:0] 0x166 - 0x167 0x166 0x167 WF3BM1 0x0000 Wake-Up Frame 3 Byte Mask 1 Register [15:0] 0x168 - 0x169 0x168 0x169 WF3BM2 0x0000 Wake-Up Frame 3 Byte Mask 2 Register [15:0] 0x16A - 0x16B 0x16A 0x16B WF3BM3 0x0000 Wake-Up Frame 3 Byte Mask 3 Register [15:0] 0x16C - 0x16F 0x16C 0x16F Reserved (4−Bytes) Don’t Care 16-Bit 8-Bit 0x156 - 0x157 Description None None Internal I/O Register Space Mapping for the QMU (0x170 − 0x1FF) I/O Register Offset Location Register Name Default Value 0x170 0x171 TXCR 0x0000 Transmit Control Register [15:0] 0x172 - 0x173 0x172 0x173 TXSR 0x0000 Transmit Status Register [15:0] 0x174 - 0x175 0x174 0x175 RXCR1 0x0800 Receive Control Register 1 [15:0] 0x176 - 0x177 0x176 0x177 RXCR2 0x0114 Receive Control Register 2 [15:0] 0x178 - 0x179 0x178 0x179 TXMIR 0x1800 TXQ Memory Information Register [15:0] 0x17A - 0x17B 0x17A 0x17B Reserved Don’t Care 16-Bit 8-Bit 0x170 - 0x171 August 31, 2015 69 Description None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for the QMU (0x170 − 0x1FF) (Continued) I/O Register Offset Location Register Name Default Value 0x17C 0x17D RXFHSR 0x0000 Receive Frame Header Status Register [15:0] 0x17E - 0x17F 0x17E 0x17F RXFHBCR 0x0000 Receive Frame Header Byte Count Register [15:0] 0x180 - 0x181 0x180 0x181 TXQCR 0x0000 TXQ Command Register [15:0] 0x182 - 0x183 0x182 0x183 RXQCR 0x0000 RXQ Command Register [15:0] 0x184 - 0x185 0x184 0x185 TXFDPR 0x0000 TX Frame Data Pointer Register [15:0] 0x186 - 0x187 0x186 0x187 RXFDPR – RX Frame Data Pointer Register [15:0] 0x188 - 0x18B 0x188 0x18B Reserved (4−Bytes) Don’t Care 0x18C - 0x18D 0x18C 0x18D RXDTTR 0x0000 RX Duration Timer Threshold Register [15:0] 0x18E - 0x18F 0x18E 0x18F RXDBCTR 0x0000 RX Data Byte Count Threshold Register [15:0] 0x190 - 0x191 0x190 0x191 IER 0x0000 Interrupt Enable Register [15:0] 0x192 - 0x193 0x192 0x193 ISR 0x0000 Interrupt Status Register [15:0] 0x194 - 0x19B 0x194 0x19B Reserved (8−Bytes) Don’t Care 0x19C - 0x19D 0x19C 0x19D RXFCTR 0x0000 RX Frame Count Threshold Register [7:0], 15:8 are Reserved 0x19E - 0x19F 0x19E 0x19F TXNTFSR 0x0000 TX Next Total Frames Size Register [15:0] 0x1A0 - 0x1A1 0x1A0 0x1A1 MAHTR0 0x0000 MAC Address Hash Table Register 0 [15:0] 0x1A2 - 0x1A3 0x1A2 0x1A3 MAHTR1 0x0000 MAC Address Hash Table Register 1 [15:0] 0x1A4 - 0x1A5 0x1A4 0x1A5 MAHTR2 0x0000 MAC Address Hash Table Register 2 [15:0] 16-Bit 8-Bit 0x17C - 0x17D August 31, 2015 70 Description None None Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for the QMU (0x170 - 0x1FF) (Continued) I/O Register Offset Location Register Name Default Value 0x1A6 0x1A7 MAHTR3 0x0000 0x1A8 - 0x1AF 0x1A8 0x1AF Reserved (8-Bytes) Don’t Care 0x1B0 - 0x1B1 0x1B0 0x1B1 FCLWR 0x0600 Flow Control Low Water Mark Register [15:0] 0x1B2 - 0x1B3 0x1B2 0x1B3 FCHWR 0x0400 Flow Control High Water Mark Register [15:0] 0x1B4 - 0x1B5 0x1B4 0x1B5 FCOWR 0x0040 Flow Control Overrun Water Mark Register [15:0] 0x1B6 - 0x1B7 0x1B6 0x1B7 Reserved (2-Bytes) Don’t Care 0x1B8 - 0x1B9 0x1B8 0x1B9 RXFC 0x0000 0x1BA - 0x1FF 0x1BA 0x1FF Reserved (70-Bytes) Don’t Care 16-Bit 8-Bit 0x1A6 - 0x1A7 Description MAC Address Hash Table Register 3 [15:0] None None RX Frame Count[15:8], Reserved [7:0] None Special Control Registers (0x700 − 0x7FF) I/O Register Offset Location Register Name Default Value 0x700 0x747 Reserved (72-Bytes) Don’t Care 0x748 - 0x749 0x748 0x749 ANA_CNTRL_1 0x0000 0x74A - 0x74B 0x74A 0x74B Reserved (2-Bytes) Don’t Care 0x74C - 0x74D 0x74C 0x74D ANA_CNTRL_3 0x0000 0x74E - 0x7FF 0x74E 0x7FF Reserved (178-Bytes) Don’t Care 16-Bit 8-Bit 0x700 - 0x747 August 31, 2015 Description None Analog Control 1 Register None Analog Control 3 Register 71 None Revision 1.1 Micrel, Inc. KSZ8852HLE Register Bit Definitions The section provides details of the bit definitions for the registers summarized in the previous section. Writing to a bit or register defined as reserved could potentially cause unpredictable results. If it is necessary to write to registers which contain both writable and reserved bits in the same register, the user should first read back the reserved bits (RO or RW), then “OR” the desired settable bits with the value read and write back the “ORed” value back to the register. Bit Type Definition: RO = Read only WO = Write only RW = Read/Write SC = Self-Clear W1C = Write “1” to Clear (Write a “1” to clear this bit) Internal I/O Register Mapping for Switch Control and Configuration (0x000 - 0x0FF) Chip ID and Enable Register (0x00 - 0x001): CIDER This register contains the chip ID and switch-enable control. Bit Default Value R/W 15−8 0x84 RO 7−4 0x3 RO 3−1 001 RO 0 1 RW Description Family ID Chip family ID. Chip ID 0x3 is assigned to the KSZ8852HL Revision ID Chip revision ID. Start Switch 1 = Start the chip. 0 = Switch is disabled. Switch Global Control Register 1 (0x002 - 0x003): SGCR1 This register contains global control bits for the switch function. Bit Default R/W 15 0 RW 14 0 RW Description Pass All Frames 1 = Switch all packets including bad ones. Used solely for debugging purposes. Works in conjunction with Sniffer mode only. Receive 2000 Byte Packet Length Enable 1 = Enables the receipt of packets up to and including 2000 bytes in length. 0 = Discards the received packets if their length is greater than 2000 bytes. IEEE 802.3x Transmit Direction Flow Control Enable 13 1 RW 1 = Enables transmit direction flow control feature. 0 = Disable transmit direction flow control feature. The switch will not generate any flow control packets. IEEE 802.3x Receive Direction Flow Control Enable 12 1 August 31, 2015 RW 1 = Enables receive direction flow control feature. 0 = Disable receive direction flow control feature. The switch will not react to any received flow control packets. 72 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 1 (0x002 - 0x003): SGCR1 (Continued) Bit Default R/W Description Frame Length Field Check 11 0 RW 1 = Enable checking frame length field in the IEEE packets. If the actual length does not match, the packet will be dropped (for Length/Type field < 1500). 0 = Disable checking frame length field in the IEEE packets. Aging Enable 10 1 RW 9 0 RW 1 = Enable aging function in the chip. 0 = Disable aging function in the chip. Fast Age Enable 1 = Turn on fast aging (800 us). Aggressive Back−Off Enable 8 0 RW 1 = Enable more aggressive back-off algorithm in half−duplex mode to enhance performance. This is not an IEEE standard. 7−6 01 RW Reserved Enable Flow Control when Exceeding Ingress Limit 5 0 RW 1 = Flow control frame will be sent to link partner when exceeding the ingress rate limit. 0 = Frame will be dropped when exceeding the ingress rate limit Receive 2K Byte Packets Enable 4 1 RW 3 0 RW 2−1 00 RW 1 = Enable packet length up to 2K bytes. While set, SGCR2 bits[2,1] will have no effect. 0 = Discard packet if packet length is greater than 2000 bytes. Pass Flow Control Packet 1 = Switch will not filter 802.1x “flow control” packets. Reserved Link Change Age 0 0 August 31, 2015 RW 1 = Link change from “link” to “no link” will cause fast aging (<800us) to age address table faster. After an age cycle is complete, the age logic will return to normal (300 + 75 seconds). Note: If any port is unplugged, all addresses will be automatically aged out. 73 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 2 (0x004 – 0x005): SGCR2 This register contains global control bits for the switch function. Bit Default R/W 15 0 RW Description 802.1Q VLAN Enable 1 = 802.1Q VLAN mode is turned on. VLAN table must be set up before the operation. 0 = 802.1Q VLAN is disabled. IGMP Snoop Enable 14 0 RW 13 0 RW 12 0 RW 11−9 000 RW 1 = IGMP snoop is enabled. 0 = IGMP snoop is disabled. IPv6 MLD Snooping Enable 1 = Enable IPv6 MLD snooping. IPv6 MLD Snooping Option 1 = Enable IPv6 MLD snooping option. Reserved Sniff Mode Select 8 0 RW 1 = Performs RX and TX sniff (both the source port and destination port need to match). 0 = Performs RX or TX sniff (either the source port or destination port needs to match). This is the mode used to implement RX only sniff. Unicast Port−VLAN Mismatch Discard 7 1 RW 1 = No packets can cross the VLAN boundary. 0 = Unicast packets (excluding unknown/multicast/broadcast) can cross the VLAN boundary. Multicast Storm Protection Disable 6 1 RW 1 = “Broadcast Storm Protection” does not include multicast packets. Only DA = FF-FF-FF-FF-FF-FF packets are regulated. 0 = “Broadcast Storm Protection” includes DA = FF-FF-FF-FF-FF-FF and DA[40] = “1” packets. Back Pressure Mode 5 1 RW 1 = Carrier sense−based back pressure is selected. 0 = Collision−based back pressure is selected. Flow Control and Back Pressure Fair Mode 4 1 RW 3 0 RW 1 = Fair mode is selected. In this mode, if a flow control port and a non−flow control port talk to the same destination port, packets from the non−flow control port may be dropped. This prevents the flow control port from being flow controlled for an extended period of time. 0 = In this mode, if a flow control port and a non−flow control port talk to the same destination port, the flow control port is flow controlled. This may not be “fair” to the flow control port. No Excessive Collision Drop August 31, 2015 1 = The switch does not drop packets when 16 or more collisions occur. 0 = The switch drops packets when 16 or more collisions occur. 74 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 2 (0x004 – 0x005): SGCR2 (Continued) Bit Default R/W Description Huge Packet Support 2 0 RW 1 = Accepts packet sizes up to 1916 bytes (inclusive). This bit setting overrides setting from bit 1 of the same register. 0 = The max packet size is determined by bit [1] of this register. Legal Maximum Packet Size Check Enable 1 0 RW 1 = 1522 bytes for tagged packets, 1518 bytes for untagged packets. Any packets larger than the specified value are dropped. 0 = Accepts packet sizes up to 1536 bytes (inclusive). Priority Buffer Reserve 0 0 RW 1 = Each port is pre−allocated 48 buffers, used exclusively for high priority (q3, q2, and q1) packets. Effective only when the multiple queue feature is turned on. 0 = Each port is pre−allocated 48 buffers used for all priority packets (q3, q2, q1, and q0). Switch Global Control Register 3 (0x006 - 0x007): SGCR3 This register contains global control bits for the switch function. Bit Default R/W Description 15−8 0x63 RW These bits, along with SGCR3[2:0], determine how many 64−byte blocks of packet data are allowed on an input port in a preset period. The period is 67ms for 100BT or 670ms for 10BT. The default is 1%. 7 0 RO Reserved Broadcast Storm Protection Rate Bit [7:0] Switch Host Port in Half-Duplex Mode 6 0 RW 5 1 RW 4 0 RW 1 = Enable host port interface half−duplex mode. 0 = Enable host port interface full−duplex mode. Switch Host Port Flow Control Enable 1 = Enable full−duplex flow control on Switch Host port. 0 = Disable full−duplex flow control on Switch Host port Switch MII 10BT 1 = The Switch is in 10Mbps mode. 0 = The Switch is in 100Mbps mode. Null VID Replacement 3 0 RW 1 = Replaces NULL VID with port VID (12 bits). 0 = No replacement for NULL VID. Broadcast Storm Protection Rate Bit [10:8] 2−0 000 RW These bits, along with SGCR3[15:8] determine how many 64−byte blocks of packet data are allowed on an input port in a preset period. The period is 67ms for 100BT or 670ms for 10BT. The default is 1%. Broadcast storm protection rate: 148,800 frames/sec * 67ms/interval * 1% = 99 frames/interval (approx. 0x63) 0x008 – 0x00B: Reserved August 31, 2015 75 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 6 (0x00C - 0x00D): SGCR6 This register contains global control bits for the switch function. Bit Default R/W 15−14 11 R/W 13−12 11 R/W 11−10 10 R/W Description Tag_0x7 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x7. Tag_0x6 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x6. Tag_0x5 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x5. Tag_0x4 9−8 10 R/W 7−6 01 R/W 5−4 01 R/W 3−2 00 R/W 1−0 00 R/W IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x4. Tag_0x3 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x3. Tag_0x2 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x2. Tag_0x1 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x1. Tag_0x0 August 31, 2015 IEEE 802.1p mapping. The value in this field is used as the frame’s priority when its VLAN Tag has a value of 0x0. 76 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 7 (0x00E - 0x00F): SGCR7 This register contains global control bits for the switch function. Bit Default R/W Description 15−10 0x02 R/W Reserved Port LED Mode When read, these two bits provide the current setting of the LED display mode for P1/2LED1 and P1/2LED0 as defined as below. Reg. 0x06C – 0x06D, bits [14:12] determine if this automatic functionality is utilized or if the Port 1 LEDs are controlled by the local processor. Reg. 0x084 – 0x085, bits [14:12] determine if this automatic functionality is utilized or if the Port 2 LEDs are controlled by the local processor. 9−8 00 R/W LED Mode P1/2LED1 P1/2LED0 00 Speed Link & Activity 01 Activity Link 10 Full Duplex Link & Activity 11 Full Duplex Link Unknown Default Port Enable 7 0 R/W Send packets with unknown destination address to specified ports in bits [2:0]. 1 = Enable to send unknown DA packet Driver Strength Selection 6−5 01 or 10 R/W 4−3 00 R/W These two bits determine the drive strength of all I/O pins except for the following category of pins: LED pins, INTRN, and RSTN. 00 = 4mA. 01 = 8mA. (Default when VDD_IO is 3.3V or 2.5V) 10 = 12mA. (Default when VDD_IO is 1.8V) 11 = 16mA. Reserved Unknown Packet Default Port(s) 2−0 Specify which ports to send packets with unknown destination addresses. Feature is enabled by bit [7]. 111 R/W Bit[2] = For Port 3 (host port) Bit[1] = For Port 2 Bit[0] = For Port 1 August 31, 2015 77 Revision 1.1 Micrel, Inc. KSZ8852HLE MAC Address Register 1 (0x010 - 0x011): MACAR1 This register contains the two MSBs of the MAC address for the switch function. This MAC address is used for sending PAUSE frames. Bit Default R/W 15−0 0x0010 RW Description MACA[47:32] Specifies MAC Address 1 for sending PAUSE frame. MAC Address Register 2 (0x012 - 0x013): MACAR2 This register contains the MAC address for the switch function. This MAC address is used for sending PAUSE frames. Bit Default R/W 15−0 0xA1FF RW Description MACA[31:16] Specifies MAC Address 2 for sending PAUSE frame. MAC Address Register 3 (0x014 - 0x015): MACAR3 This register contains the two LSBs of the MAC address for the switch function. This MAC address is used for sending PAUSE frames. Bit Default R/W 15−0 0xFFFF RW August 31, 2015 Description MACA[15:0] Specifies MAC Address 3 for sending PAUSE frame. 78 Revision 1.1 Micrel, Inc. KSZ8852HLE Type-of-Service (TOS) Priority Control Registers TOS Priority Control Register 1 (0x016-– 0x017): TOSR1 The IPv4/IPv6 type-of-service (TOS) priority control registers are used to define a 2-bit priority to each of the 64 possible values in the 6-bit differentiated services code point (DSCP) field in the IP header of ingress frames. This register contains the TOS priority control bits for the switch function. Bit Default R/W Description 15−14 00 RW 13−12 00 R/W 11−10 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x14. 9−8 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x10. 7−6 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x0c. 5−4 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x08. 3−2 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x04. 1−0 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x00. DSCP[15:14] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x1c. DSCP[13:12] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x18. DSCP[11:10] DSCP[9:8] DSCP[7:6] DSCP[5:4] DSCP[3:2] DSCP[1:0] August 31, 2015 79 Revision 1.1 Micrel, Inc. KSZ8852HLE TOS Priority Control Register 2 (0x018 - 0x019): TOSR2 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W Description DSCP[31:30] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x3c. DSCP[29:28] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x38. DSCP[27:26] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x34. DSCP[25:24] 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x30. DSCP[23:22] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x2c. DSCP[21:20] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x28. DSCP[19:18] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x24. DSCP[17:16] August 31, 2015 The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x20. 80 Revision 1.1 Micrel, Inc. KSZ8852HLE TOS Priority Control Register 3 (0x01A - 0x01B): TOSR3 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W Description DSCP[47:46] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x5c. DSCP[45:44] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x58. DSCP[43:42] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x54. DSCP[41:40] 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x50. DSCP[39:38] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x4c. DSCP[37:36] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x48. DSCP[35:34] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x44. DSCP[33:32] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x40. TOS Priority Control Register 4 (0x01C - 0x1D): TOSR4 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W Description DSCP[63:62] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x7c. DSCP[61:60] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x78. DSCP[59:58] August 31, 2015 The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x74. 81 Revision 1.1 Micrel, Inc. KSZ8852HLE TOS Priority Control Register 4 (0x01C - 0x1D): TOSR4 (Continued) Bit Default R/W 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W Description DSCP[57:56] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x70. DSCP[55:54] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x6c. DSCP[53:52] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x68. DSCP[51:50] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x64. DSCP[49:48] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x60. TOS Priority Control Register 5 (0x01E - 0x1F): TOSR5 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W Description DSCP[79:78] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x9c. DSCP[77:76] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x98. DSCP[75:74] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x94. DSCP[73:72] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x90. DSCP[71:70] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x8c. DSCP[69:68] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x88. DSCP[67:66] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x84. DSCP[65:64] August 31, 2015 The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0x80. 82 Revision 1.1 Micrel, Inc. KSZ8852HLE TOS Priority Control Register 6 (0x020 - 0x021): TOSR6 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW Description DSCP[95:94] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value is 0xbc. DSCP[93:92] 13−12 00 R/W 11−10 00 R/W 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xb8. DSCP[91:90] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xb4. DSCP[89:88] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xb0. DSCP[87:86] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xac. DSCP[85:84] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xa8. DSCP[83:82] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xa4. DSCP[81:80] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xa0. TOS Priority Control Register 7 (0x022 - 0x023): TOSR7 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W 9−8 00 R/W Description DSCP[111:110] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xdc. DSCP[109:108] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xd8. DSCP[107:106] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xd4. DSCP[105:104] August 31, 2015 The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xd0. 83 Revision 1.1 Micrel, Inc. KSZ8852HLE TOS Priority Control Register 7 (0x022 - 0x023): TOSR7 (Continued) Bit Default R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W Description DSCP[103:102] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xcc. DSCP[101:100] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xc8. DSCP[99:98] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xc4. DSCP[97:96] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xc0. TOS Priority Control Register 8 (0x024 - 0x025): TOSR8 This register contains the TOS priority control bits for the switch function. Bit Default R/W 15−14 00 RW 13−12 00 R/W 11−10 00 R/W 9−8 00 R/W 7−6 00 R/W 5−4 00 R/W 3−2 00 R/W 1−0 00 R/W Description DSCP[127:126] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xfc DSCP[125:124] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xf8. DSCP[123:122] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xf4. DSCP[121:120] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xf0. DSCP[119:118] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xec. DSCP[117:116] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xe8. DSCP[115:114] The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xe4. DSCP[113:112] August 31, 2015 The value in this field is used as the frame’s priority when bits [7:2] of the IP TOS/DiffServ/Traffic Class value are 0xe0. 84 Revision 1.1 Micrel, Inc. KSZ8852HLE Indirect Access Data Registers Indirect Access Data Register 1 (0x026 - 0x027): IADR1 This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Bit Default R/W Description 15−8 0x00 RO Reserved CPU Read Status 7 0 RO 6−3 0x0 RO 2−0 000 RO Only for dynamic and statistics counter reads. 1 = Read is still in progress. 0 = Read has completed. Reserved Indirect Data [66:64] Bits [66:64] of indirect data. Indirect Access Data Register 2 (0x028 - 0x029): IADR2 This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Bit Default R/W 15−0 0x0000 RW Description Indirect Data [47:32] Bits [47:32] of indirect data. Indirect Access Data Register 3 (0x02A - 0x02B): IADR3 This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Bit Default R/W 15−0 0x0000 RW Description Indirect Data [63:48] Bits [63:48] of indirect data. Indirect Access Data Register 4 (0x02C - 0x02D): IADR4 This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Bit Default R/W 15−0 0x0000 RW August 31, 2015 Description Indirect Data [15:0] Bits [15:0] of indirect data. 85 Revision 1.1 Micrel, Inc. KSZ8852HLE Indirect Access Data Register 5 (0x02E - 0x02F): IADR5 This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Bit Default R/W 15−0 0x0000 RW Description Indirect Data [31:16] Bits [31:16] of indirect data. Indirect Access Control Register (0x030 - 0x031): IACR This register is used to indirectly read or write the data in the Management Information Base (MIB) Counters, Static MAC Address Table, Dynamic MAC Address Table, or the VLAN Table. Writing to IACR triggers a command. Read or write access is determined by register bit [12]. Bit Default R/W Description 15−13 000 RW Reserved 12 0 RW Read or Write Access Selection 1 = Read cycle. 0 = Write cycle. Table Select 11−10 00 RW 9−0 0x000 RW August 31, 2015 00 = Static MAC address table selected. 01 = VLAN table selected. 10 = Dynamic MAC address table selected. 11 = MIB counter selected. Indirect Address [9:0] Bits [9:0] of indirect address. 86 Revision 1.1 Micrel, Inc. KSZ8852HLE Power Management Control and Wake-Up Event Status Power Management Control and Wake-Up Event Status (0x032 – 0x033): PMCTRL This register controls the power management mode and provides Wake-Up event status. Bit Default R/W Description 15−6 0x000 RO Reserved 5 0 RW (W1C) 4 0 RW (W1C) 3 0 RW (W1C) 2 0 RW (W1C) Wake-Up Frame Detect Status 1 = A wake-up frame has been detected at the host QMU (Write a “1” to clear). 0 = No wake-up frame has been detected. Magic Packet Detect Status 1 = A Magic Packet has been detected at either Port 1 or Port 2 (Write a “1” to clear). 0 = No Magic Packet has been detected. Link-Up Detect Status 1 = Link-up has been detected at either Port 1 or Port 2 (Write a “1” to clear). 0 = No link-up has been detected. Energy Detect Status 1 = Energy is detected at either Port 1 or Port 2 (Write a “1” to clear). 0 = No energy is detected. Power Management Mode 1−0 00 August 31, 2015 RW These two bits are used to control device power management mode. 00 = Normal mode. 01 = Energy detect mode. 10 = Global soft power-down mode. 11 = Reserved. 87 Revision 1.1 Micrel, Inc. KSZ8852HLE Power Management Event Enable Register (0x034 - 0x035): PMEE This register contains the power management event enable control bits. Bit Default R/W Description 15−5 0x000 RW Reserved 4 0 RW PME Polarity: 1 = The PME pin is active high. 0 = The PME pin is active low. PME Waked Up By Wake−Up Frame Enable 3 0 RW 2 0 RW 1 = The PME pin will be asserted when a magic packet is detected. 0 = PME won’t be asserted by the magic packet detection 1 0 RW 1 = The PME pin will be asserted when a link-up is detected at Port 1 or Port 2. 0 = PME won’t be asserted by the link-up detection 1 = The PME pin will be asserted when a wake-up frame is detected. 0 = PME won’t be asserted by the wake-−up frame detection PME Waked Up By Magic Packet Enable PME Waked Up By Link-Up Enable PME Waked Up By Energy Detect Enable 0 0 August 31, 2015 RW 1 = The PME pin will be asserted when energy on line is detected at Port 1 or Port 2. 0 = PME won’t be asserted by the energy detection. 88 Revision 1.1 Micrel, Inc. KSZ8852HLE Go Sleep Time and Clock Tree Power-Down Control Registers Go Sleep Time Register (0x036 - 0x037): GST This register contains the value which is used to control the minimum go−sleep time period when the device transitions from normal power state to low power state in energy detect mode. Bit Default R/W Description 15−8 0x00 RO Reserved Go Sleep Time 7−0 0x8E RW This value is used to control the minimum period the no-energy event has to be detected consecutively before the device enters the low power state during energy detect mode. The unit is 20ms. The default go sleep time is around 3.0 seconds. Clock Tree Power-Down Control Register (0x038 - 0x039): CTPDC This register contains the power down control bits for all clocks. Bit Default R/W Description 15−5 0x000 RO Reserved 4 0 RW Reserved Switch Clock Auto Shut Down Enable 3 0 RW 1 = When no packet transfer is detected on the MII interface of all ports (Port 1, Port 2, and Port 3) longer than the time specified in bit[1:0] of current register, the device will shut down the switch clock automatically. The switch clock will be woken up automatically when the MII interface on any port becomes busy. 0 = Switch clock is always on. CPU Clock Auto Shut Down Enable 2 0 RW 1 = When no packet transfer is detected on either the host interface or the MII interface of all ports (Port 1, Port 2, and Port 3) for a time period longer than the time specified in bit[1:0] of current register, the device will shut down the CPU clock automatically. The CPU clock will be woken up automatically when host activity is detected or the MII interface of any port becomes busy. 0 = CPU clock is always on. Shutdown Wait Period 1−0 00 RW These two bits specify the time for device to monitor host/MII activity continuously before it could shut down switch or CPU clock. 00 = 5.3 second. 01 = 1.6 second. 10 = 1ms. 11 = 3.2µs. 0x03A – 0x04B: Reserved August 31, 2015 89 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY and MII Basic Control Registers PHY 1 and MII Basic Control Register (0x04C-– 0x04D): P1MBCR This register contains media independent interface (MII) control bits for the switch Port 1 function as defined in the IEEE 802.3 specification. Bit Default R/W Description 15 0 RO Reserved Bit is Same As: Far-End Loopback 14 0 RW 1 = Perform loopback as follows: Start: RXP2/RXM2 (Port 2) Loop back: PMD/PMA of Port 1’s PHY End: TXP2/TXM2 (Port 2) 0 = Normal operation. Force 100BT 13 1 RW 12 1 RW 11 0 RW 10 0 RO 9 0 RW/SC 1 = Force 100Mbps if auto-negotiation is disabled (bit [12]) 0 = Force 10Mbps if auto-negotiation is disabled (bit [12]) Bit [8] in P1CR4 Bit [6] in P1CR4 Auto-Negotiation Enable Bit [7] in P1CR4 1 = Auto-negotiation enabled. 0 = Auto-negotiation disabled. Power-Down 1 = Power-down. 0 = Normal operation. Bit [11] in P1CR4 Isolate Not supported. Restart Auto-Negotiation 1 = Restart auto-negotiation. 0 = Normal operation. Bit [13] in P1CR4 Force Full Duplex 8 1 RW 7 0 RO 6 0 RO 5 1 R/W 1 = Force full duplex. 0 = Force half duplex. This bit determines duplex when auto-negotiation is disabled (bit [12]). It also determines duplex if auto-negotiation is enabled but fails. When AN is enabled, this bit should be set to zero. Bit [5] in P1CR4 Collision Test Not supported. Reserved HP_MDI-X August 31, 2015 1 = HP Auto MDI-X mode. 0 = Micrel Auto MDI-X mode. Bit [15] in P1SR 90 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 1 and MII Basic Control Register (0x04C - 0x04D): P1MBCR (Continued) Bit Default R/W Description Bit is Same As: Force MDI-X 4 0 RW Bit [9] in P1CR4 3 0 RW 1 = Disable Auto MDI-X. 0 = Normal operation. Bit [10] in P1CR4 2 0 RW Reserved Bit [12] in P1CR4 1 = Force MDI-X. 0 = Normal operation. Disable Auto MDI-X Disable Transmit 1 0 RW 1 = Disable transmit. 0 = Normal operation. 0 0 RW Reserved Bit [14] in P1CR4 PHY 1 and MII Basic Status Register (0x04E - 0x04F): P1MBSR This register contains the Media Independent Interface (MII) status bits for the switch Port 1 function. Bit Default R/W Description 15 0 RO 1 = 100 BASE-T4 capable. 0 = Not 100 BASE-T4 capable. Bit is Same As: T4 Capable 100BT Full Capable 14 1 RO 1 = 100BASE-TX full-duplex capable. 0 = Not 100BASE-TX full-duplex capable. 13 1 RO 1 = 100BASE-TX half-duplex capable. 0 = Not 100BASE=TX half-duplex capable. 100BT Half Capable 10BT Full Capable 12 1 RO 1 = 10BASE−T full−duplex capable. 0 = Not 10BASE−T full−duplex capable. 11 1 RO 1 = 10BASE-T half-duplex capable. 0 = Not 10BASE-T half-duplex capable. 10−7 0x0 RO Reserved 6 0 RO 10BT Half Capable August 31, 2015 Preamble Suppressed Not supported. 91 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 1 and MII Basic Status Register (0x04E - 0x04F): P1MBSR (Continued) Bit Default R/W Description Bit is Same As: Auto-Negotiation Complete 5 0 RO 1 = Auto-negotiation complete. 0 = Auto-negotiation not completed. Bit [6] in P1SR 4 0 RO Reserved Bit [8] in P1SR 3 1 RO Auto-Negotiation Capable 1 = Auto-negotiation capable. 0 = Not auto-negotiation capable. Link Status 2 0 RO 1 0 RO Bit [5] in P1SR 1 = Link is up. 0 = Link is down. Jabber Test Not supported. Extended Capable 0 0 RO 1 = Extended register capable. 0 = Not extended register capable. PHY 1 PHYID Low Register (0x050 - 0x051): PHY1ILR This register contains the PHY ID (low) for the switch Port 1 function. Bit Default R/W Description 15−0 0x1430 RO PHY 1 ID Low Word Low order PHY 1 ID bits. PHY 1 PHYID High Register (0x052 - 0x053): PHY1IHR This register contains the PHY ID (high) for the switch Port 1 function. Bit Default R/W Description 15−0 0x0022 RO PHY 1 ID High Word High order PHY 1 ID bits. August 31, 2015 92 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 1 Auto-Negotiation Advertisement Register (0x054 - 0x055): P1ANAR This register contains the auto-negotiation advertisement bits for the switch Port 1 function. Bit Default R/W Description 15 0 RO Next page Not supported. 14 0 RO Reserved 13 0 RO Remote fault Not supported. 12−11 00 RO Reserved Bit is Same As: 10 1 RW Pause (flow control capability) 1 = Advertise pause ability. 0 = Do not advertise pause capability. 9 0 RW Reserved 8 1 RW Advertise 100BT Full-Duplex 1 = Advertise 100BT full-duplex capable. 0 = Do not advertise 100BT full-duplex capability. Bit [3] in P1CR4 7 1 RW Advertise 100BT Half-Duplex 1= Advertise 100BT half-duplex capable. 0 = Do not advertise 100BT half-duplex capability. Bit [2] in P1CR4 6 1 RW Advertise 10BT Full-Duplex 1 = Advertise 10BT full-duplex capable. 0 = Do not advertise 10BT full-duplex capability. Bit [1] in P1CR4 5 1 RW Advertise 10BT Half-Duplex 1 = Advertise 10BT half-duplex capable. 0 = Do not advertise 10BT half-duplex capability. Bit [0] in P1CR 4−0 0x01 RO Selector Field 802.3 August 31, 2015 93 Bit [4] in P1CR4 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 1 Auto−Negotiation Link Partner Ability Register (0x056 - 0x057): P1ANLPR This register contains the auto−negotiation link partner ability bits for the switch Port 1 function. Bit Default R/W Description Bit is Same As: 15 0 RO Next page Not supported. 14 0 RO LP ACK Not supported. 13 0 RO Remote fault Not supported. 12−11 00 RO Reserved 10 0 RO Pause Link partner pause capability. 9 0 RO Reserved 8 0 RO Advertise 100BT Full-Duplex Link partner 100BT full-duplex capability. Bit [3] in P1SR 7 0 RO Advertise 100BT Half-Duplex Link partner 100 half-duplex capability. Bit [2] in P1SR 6 0 RO Advertise 10BT Full-Duplex Link partner 10BT full-duplex capability. Bit [1] in P1SR 5 0 RO Advertise 10BT Half-Duplex Link partner 10BT half-duplex capability. Bit [0] in P1SR 4−0 0x01 RO Reserved Bit [4] in P1SR PHY 2 and MII Basic Control Register (0x058 - 0x059): P2MBCR This register contains media independent interface (MII) control bits for the switch Port 2 function as defined in the IEEE 802.3 specification. Bit Default R/W Description 15 0 RO Reserved Bit is Same As: Far−End Loopback 14 0 RW 13 1 RW 12 1 RW 1 = Perform loop back, as follows: Start: RXP1/RXM1 (Port 1) Loop back: PMD/PMA of Port 2’s PHY End: TXP1/TXM1 (Port 1) 0 = Normal operation. Bit [8] in P2CR4 Force 100BT August 31, 2015 1 = Force 100Mbps if auto-negotiation is disabled (bit [12]) 0 = Force 10Mbps if auto-negotiation is disabled (bit [12]) Bit [6] in P2CR4 Auto-Negotiation Enable Bit [7] in P2CR4 1 = Auto-negotiation enabled. 0 = Auto-negotiation disabled. 94 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 2 and MII Basic Control Register (0x058 - 0x059): P2MBCR (Continued) Bit Default R/W 11 0 RW 10 0 RO Description Bit is Same As: Power Down 1 = Power down. 0 = Normal operation. Bit [11] in P2CR4 Isolate Not supported. Restart Auto-Negotiation 9 0 RW/SC 1 = Restart auto-negotiation. 0 = Normal operation, Bit [13] in P2CR4 Force Full Duplex 1 = Force full duplex. 0 = Force half duplex. This bit determines duplex when auto-negotiation is disabled (bit [12]). It also determines duplex if auto-negotiation is enabled but fails. When AN is enabled, this bit should be set to zero. 8 1 RW Bit [5] in P2CR4 7 0 RO 6 0 RO 5 1 R/W 4 0 RW 1 = Force MDI-X. 0 = Normal operation. 3 0 RW 1 = Disable Auto MDI-X. 0 = Normal operation. Bit [10] in P2CR4 2 0 RW Reserved Bit [12] in P2CR4 1 0 RW 1 = Disable transmit. 0 = Normal operation. 0 0 RW Reserved Collision Test Not supported. Reserved HP_MDI-X 1 = HP Auto MDI-X mode. 0 = Micrel Auto MDI-X mode. Bit [15] in P2SR Force MDI-X Bit [9] in P2CR4 Disable Auto MDI-X Disable Transmit August 31, 2015 Bit [14] in P2CR4 95 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 2 and MII Basic Status Register (0x05A - 0x05B): P2MBSR This register contains the Media Independent Interface (MII) status bits for the switch Port 2 function Bit Default R/W Description Bit is Same As: 15 0 RO T4 Capable 1 = 100BASE-T4 capable. 0 = Not 100BASE-T4 capable. 14 1 RO 100BT Full Capable 1 = 100BASE-TX full-duplex capable. 0 = Not 100BASE-TX full-duplex capable. 13 1 RO 100BT Half Capable 1 = 100BASE-TX half-duplex capable. 0 = Not 100BASE-TX half-duplex capable. 12 1 RO 10BT Full Capable 1 = 10BASE-T full-duplex capable. 0 = Not 10BASE-T full-duplex capable. 11 1 RO 10BT Half Capable 1 = 10BASE-T half-duplex capable. 0 = Not 10BASE-T half-duplex capable. 10−7 0x0 RO Reserved 6 0 RO Preamble suppressed Not supported. 5 0 RO Auto-Negotiation Complete 1 = Auto-negotiation complete. 0 = Auto-negotiation not completed. Bit [6] in P2SR 4 0 RO Reserved Bit [8] in P2SR 3 1 RO Auto-Negotiation Capable 1 = Auto-negotiation capable. 0 = Not auto-negotiation capable. 2 0 RO Link Status 1 = Link is up. 0 = Link is down. 1 0 RO Jabber test Not supported. RO Extended Capable 1 = Extended register capable. 0 = Not extended register capable. 0 0 August 31, 2015 Bit [5] in P2SR 96 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY2 PHYID Low Register (0x05C - 0x05D): PHY2ILR This register contains the PHY ID (low) for the switch Port 2 function. Bit Default R/W Description 15−0 0x1430 RO PHY 2 ID Low Word Low order PHY 2 ID bits. PHY 2 PHYID High Register (0x05E - 0x05F): PHY2IHR This register contains the PHY ID (high) for the switch Port 2 function. Bit Default R/W Description 15−0 0x0022 RO PHY 2 ID High Word High order PHY 2 ID bits. PHY 2 Auto-Negotiation Advertisement Register (0x060 - 0x061): P2ANAR This register contains the auto-negotiation advertisement bits for the switch Port 2 function. Bit Default R/W Description 15 0 RO Next page Not supported. 14 0 RO Reserved 13 0 RO Remote fault Not supported. 12−11 00 RO Reserved Bit is Same As: 10 1 RW Pause (flow control capability) 1 = Advertise pause ability. 0 = Do not advertise pause capability. 9 0 RW Reserved 8 1 RW Advertise 100BT Full-Duplex 1 = Advertise 100BT full-duplex capable. 0 = Do not advertise 100BT full-duplex capability. Bit [3] in P2CR4 7 1 RW Advertise 100BT Half-Duplex 1= Advertise 100BT half-duplex capable. 0 = Do not advertise 100BT half-duplex capability. Bit [2] in P2CR4 6 1 RW Advertise 10BT Full-Duplex 1 = Advertise 10BT full-duplex capable. 0 = Do not advertise 10BT full-duplex capability. Bit [1] in P2CR4 5 1 RW Advertise 10BT Half-Duplex 1 = Advertise 10BT half-duplex capable. 0 = Do not advertise 10BT half-duplex capability. Bit [0] in P2CR4 4−0 0x01 RO Selector Field 802.3 August 31, 2015 97 Bit [4] in P2CR4 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY 2 Auto-Negotiation Link Partner Ability Register (0x062 -0x063): P2ANLPR This register contains the auto-negotiation link partner ability bits for the switch Port 2 function. Bit Default R/W Description Bit is Same As: 15 0 RO Next page Not supported. 14 0 RO LP ACK Not supported. 13 0 RO Remote fault Not supported. 12−11 00 RO Reserved 10 0 RO Pause Link partner pause capability. 9 0 RO Reserved 8 0 RO Advertise 100BT Full-Duplex Link partner 100BT full-duplex capability. Bit [3] in P2SR 7 0 RO Advertise 100BT Half-Duplex Link partner 100 half-duplex capability. Bit [2] in P2SR 6 0 RO Advertise 10BT Full-Duplex Link partner 10BT full-duplex capability. Bit [1] in P2SR 5 0 RO Advertise 10BT Half-Duplex Link partner 10BT half-duplex capability. Bit [0] in P2SR 4−0 0x01 RO Reserved Bit [4] in P2SR 0x0x064 - 0x065: Reserved PHY1 Special Control and Status Register (0x066 - 0x067): P1PHYCTRL This register contains control and status information of PHY 1. Bit Default R/W Description 15−6 0x000 RO Reserved 5 0 RO Polarity Reverse 1 = Polarity is reversed. 0 = Polarity is not reversed. Bit [13] in P1SR 4 0 RO MDI-X Status 0 = MDI 1 = MDI-X Bit [7] in P1SR 3 0 RW Force Link 1 = Force link pass. 0 = Normal operation. Bit [11] in P1SCSLMD RW Enable Energy Efficient Ethernet (EEE) on 10BTe 1 = Disable 10BTe. 0 = Enable 10BTe. 2 1 Bit is Same As: 1 0 RW Remote (Near-End) Loopback 1 = Perform remote loopback at Port 1's PHY (RXP1/RXM1 −> TXP1/TXM1) 0 = Normal operation 0 0 RW Reserved Bit [9] in P1SCSLMD 0x068 –-0x069: Reserved August 31, 2015 98 Revision 1.1 Micrel, Inc. KSZ8852HLE PHY2 Special Control and Status Register (0x06A - 0x06B): P2PHYCTRL This register contains control and status information of PHY 2. Bit Default R/W Description 15-6 0x000 RO Reserved Bit is Same As: 5 0 RO Polarity Reverse 1 = Polarity is reversed. 0 = Polarity is not reversed. Bit [13] in P2SR 4 0 RO MDI-X Status 0 = MDI 1 = MDI-X Bit [7] in P2SR 3 0 RW Force Link 1 = Force link pass. 0 = Normal operation. Bit [11] in P2SCSLMD 2 1 RW Enable Energy Efficient Ethernet (EEE) on 10BTe 1 = Disable 10BTe. 0 = Enable 10BTe. 1 0 RW Remote (Near-End) Loopback 1 = Perform remote loopback at Port 2's PHY (RXP2/RXM2 −> TXP2/TXM2) 0 = Normal operation 0 0 RW Reserved August 31, 2015 99 Bit [9] in P2SCSLMD Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Control Registers Port 1 Control Register 1 (0x06C - 0x06D): P1CR1 This register contains control bits for the switch Port 1 function. Bit Default R/W Description 15 0 RO Reserved Port 1 LED Direct Control These bits directly control the Port 1 LED pins. 14-12 11 000 0 R/W 0xx = Normal LED function as set up via Reg. 0x00E - 0x00F, Bits [9:8]. 100 = Both Port 1 LEDs off. 101 = Port 1 LED1 off, LED0 on. 110 = Port 1 LED1 on, LED0 off. 111 = Both Port 1 LEDs on. RW Source Address Filtering Enable for MAC Address 2 1 = Enable the source address filtering function when the SA matches MAC Address 2 in SAFMACA2 (0x0B6 - 0x0BB) . 0 = Disable source address filtering function. 10 0 RW Source Address Filtering Enable for MAC Address 1 1 = Enable the source address filtering function when the SA matches MAC Address 1 in SAFMACA1 (0x0B0 - 0x0B5) . 0 = Disable source address filtering function. 9 0 RW Drop Tagged Packet Enable 1 = Enable to drop tagged ingress packets. 0 = Disable to drop tagged ingress packets. 8 0 RW TX Two Queues Select Enable 1 = The Port 1 output queue is split into two priority queues (q0 and q1). 0 = Single output queue on Port 1. There is no priority differentiation even though packets are classified into high or low priority. 7 0 RW Broadcast Storm Protection Enable 1 = Enable broadcast storm protection for ingress packets on Port 1. 0 = Disable broadcast storm protection. 6 0 RW Diffserv Priority Classification Enable 1 = Enable DiffServ priority classification for ingress packets on Port 1. 0 = Disable DiffServ function. 5 0 RW 802.1p Priority Classification Enable 1 = Enable 802.1p priority classification for ingress packets on Port 1. 0 = Disable 802.1p. August 31, 2015 100 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Control Register 1 (0x06C - 0x06D): P1CR1 (Continued) Bit 4−3 2 1 0 Default 00 0 0 0 August 31, 2015 R/W Description RW Port−Based Priority Classification 00 = Ingress packets on Port 1 are classified as priority 0 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 01 = Ingress packets on Port 1 are classified as priority 1 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 10 = Ingress packets on Port 1 are classified as priority 2 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 11 = Ingress packets on Port 1 are classified as priority 3 queue if “Diffserv” or “802.1p” classification is not enabled or fails to classify. Note: “DiffServ”, “802.1p” and port priority can be enabled at the same time. The OR’ed result of 802.1p and DSCP overwrites the port priority. RW Tag Insertion 1 = When packets are output on Port 1, the switch adds 802.1p/q tags to packets without 802.1p/q tags when received. The switch will not add tags to packets already tagged. The tag inserted is the ingress port’s “port VID”. 0 = Disable tag insertion. RW Tag Removal 1 = When packets are output on Port 1, the switch removes 802.1p/q tags from packets with 802.1p/q tags when received. The switch will not modify packets received without tags. 0 = Disable tag removal. RW TX Multiple Queues Select Enable 1 = The Port 1 output queue is split into four priority queues (q0, q1, q2 and q3). 0 = Single output queue on Port 1. There is no priority differentiation even though packets are classified into high or low priority. 101 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Control Register 2 (0x06E - 0x06F): P1CR2 This register contains control bits for the switch Port 1 function. Bit Default R/W Description 15 0 RW Reserved 14 0 RW Ingress VLAN Filtering 1 = The switch discards packets whose VID port membership in VLAN table bits [18:16] does not include the ingress port VID. 0 = No ingress VLAN filtering. 13 0 RW Discard Non PVID Packets 1 = The switch discards packets whose VID does not match the ingress port default VID. 0 = No packets are discarded. 12 0 RW Force Flow Control 1 = Always enable flow control on the port, regardless of auto-negotiation result. 0 = The flow control is enabled based on auto-negotiation result. 11 0 RW Back Pressure Enable 1 = Enable port’s half−duplex back pressure. 0 = Disable port’s half−duplex back pressure. 10 1 RW Transmit Enable 1 = Enable packet transmission on the port. 0 = Disable packet transmission on the port. 9 1 RW Receive Enable 1 = Enable packet reception on the port. 0 = Disable packet reception on the port. 8 0 RW Learning Disable 1 = Disable switch address learning capability. 0 = Enable switch address learning. 7 0 RW Sniffer Port 1 = Port is designated as a sniffer port and transmits packets that are monitored. 0 = Port is a normal port. RW Receive Sniff 1 = All packets received on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No receive monitoring. 6 0 5 0 RW Transmit Sniff 1 = All packets transmitted on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No transmit monitoring. 4 0 RW Reserved RW User Priority Ceiling 1 = If the packet’s “priority field” is greater than the “user priority field” in the port VID control register bit[15:13], replace the packet’s “priority field” with the “user priority field” in the port VID control register bit[15:13]. 0 = Do not compare and replace the packet’s “priority field.” RW Port VLAN Membership Define the port’s Port VLAN membership. Bit [2] stands for the host port, bit [1] for Port 2, and bit [0] for Port 1. The port can only communicate within the membership. A ‘1’ includes a port in the membership; a ‘0’ excludes a port from the membership. 3 2−0 0 111 August 31, 2015 102 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 VID Control Register (0x070 - 0x071): P1VIDCR This register contains the control bits for the switch Port 1 function. This register has two main uses. It is associated with the ingress of untagged packets and used for egress tagging as well as being used for address lookup and providing a default VID for the ingress of untagged or null−VID−tagged packets. Bit Default R/W Description 15−13 000 RW Default Tag[15:13] Port’s default tag, containing “User Priority Field” bits. 12 0 RW Default Tag[12] Port’s default tag, containing the CFI bit. 11−0 0x001 RW Default Tag[11:0] Port’s default tag, containing the VID[11:0]. Port 1 Control Register 3 (0x072 - 0x073): P1CR3 This register contains the control bits for the switch Port 1 function. Bit Default 15−5 4 3−2 1 0 R/W Description 0x000 RO Reserved 0 RW Reserved RW Ingress Limit Mode These bits determine what kinds of frames are limited and counted against ingress rate limiting as follows: 00 = Limit and count all frames. 01 = Limit and count Broadcast, Multicast, and flooded Unicast frames. 10 = Limit and count Broadcast and Multicast frames only. 11 = Limit and count Broadcast frames only. RW Count Inter Frame Gap Count IFG Bytes. 1 = Each frame’s minimum inter frame gap. IFG bytes (12 per frame) are included in ingress and egress rate calculations. 0 = IFG bytes are not counted. RW Count Preamble Count preamble Bytes. 1 = Each frame’s preamble bytes (8 per frame) are included in ingress and egress rate limiting calculations. 0 = Preamble bytes are not counted. 00 0 0 August 31, 2015 103 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Ingress Rate Control Register 0 (0x074 - 0x075): P1IRCR0 This register contains the Port 1 ingress rate limiting control for priority 1 and priority 0. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Ingress Data Rate Limit for Priority 1 Frames Ingress priority 1 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10 Mbps or 100 Mbps with no limit. 7 0 RW Reserved RW Ingress Data Rate Limit for Priority 0 Frames Ingress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10 Mbps or 100 Mbps with no limit. 6−0 0x00 Table 20. Ingress or Egress Data Rate Limits Data Rate Limit for Ingress or Egress 100BT for Priority [3:0] Register Bit [14:8] or Bit[6:0] 10BT for Priority [3:0] Register Bit [14:8] or Bit[6:0] 0x01 to 0x64 for the rate matches 1Mbps to 100Mbps respectively 0x01 to 0x0A for the rate matches 1Mbps to 10Mbps respectively 0x00 (default) for the rate is no limit (full 100Mbps) 0x00 (default) for the rate is no limit (full 10Mbps) 64 Kbps 0x65 128 Kbps 0x66 192 Kbps 0x67 256 Kbps 0x68 320 Kbps 0x69 384 Kbps 0x6A 448 Kbps 0x6B 512 Kbps 0x6C 576 Kbps 0x6D 640 Kbps 0x6E 704 Kbps 0x6F 768 Kbps 0x70 832 Kbps 0x71 896 Kbps 0x72 960 Kbps 0x73 August 31, 2015 104 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Ingress Rate Control Register 1 (0x076 - 0x077): P1IRCR1 This register contains the Port 1 ingress rate limiting control bits for priority 3 and priority 2. Bit Default R/W Description 15 0 RW Reserved Ingress Data Rate Limit for Priority 3 Frames 14−8 0x00 RW Ingress priority 3 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 7 0 RW Reserved 6−0 0x00 RW Ingress Data Rate Limit for Priority 2 Frames Ingress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 1 Egress Rate Control Register 0 (0x078 - 0x079): P1ERCR0 This register contains the Port 1 egress rate limiting control bits for priority 1 and priority 0. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Egress Data Rate Limit for Priority 1 Frames Egress priority 1 frames will be limited or discarded as shown in Table 20 Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Egress Rate Limit Control Enable 7 0 RW 6−0 0x00 RW 1 = Enable egress rate limit control. 0 = Disable egress rate limit control. Egress Data Rate Limit for Priority 0 Frames Egress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 1 Egress Rate Control Register 1 (0x07A - 0x07B): P1ERCR1 This register contains the Port 1 egress rate limiting control bits for priority 3 and priority 2. Bit Default R/W Description 15 0 RW Reserved Egress Data Rate Limit for Priority 3 Frames 14−8 0x00 RW Egress priority 3 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 7 0 RW Reserved 6−0 0x00 RW Egress Data Rate Limit for Priority 2 Frames August 31, 2015 Egress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 105 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 PHY Special Control/Status, LinkMD (0x07C - 0x07D): P1SCSLMD This register contains the LinkMD control and status information of PHY 1. Bit Default R/W 15 0 RO Description Bit is Same As: CDT_10m_Short 1 = Less than 10 meter short. CDT_Result 14−13 00 RO [00] = Normal condition. [01] = Open condition has been detected in cable. [10] = Short condition has been detected in cable. [11] = Cable diagnostic test has failed. CDT_Enable 12 0 RW/ SC 1 = Cable diagnostic test is enabled. It is self-cleared after the CDT test is done. 0 = Indicates that the cable diagnostic test is completed and the status information is valid for reading. Force_Link 11 0 RW 10 1 RW Force link. 1 = Force link pass. 0 = Normal operation. Bit [3] in P1PHYCTRL Reserved Remote (Near-End) Loopback 9 0 RW 8−0 0x000 RO August 31, 2015 1 = Perform remote loopback at Port 1's PHY (RXP1/RXM1 −> TXP1/TXM1) 0 = Normal operation Bit [1] in P1PHYCTRL CDT_Fault_Count Distance to the fault. It’s approximately 0.4m*CDT_Fault_Count. 106 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Control Register 4 (0x07E - 0x07F): P1CR4 This register contains the control bits for the switch Port 1 function. Bit Default R/W Description 15 0 RW Reserved Bit is Same As: Disable Transmit 14 0 RW 13 0 RW/SC 12 0 RW Bit [1] in P1MBCR 1 = Disable the port’s transmitter. 0 = Normal operation. Restart Auto-Negotiation 1 = Restart auto-negotiation. 0 = Normal operation. Bit [9] in P1MBCR Reserved Bit [2] in P1MBCR Power Down 11 0 RW 1 = Power down. 0 = Normal operation. No change to registers setting. Bit [11] in P1MBCR Disable Auto MDI/MDI-X 10 0 RW 1 = Disable Auto-MDI/MDI-X function. 0 = Enable Auto-MDI/MDI-X function. Bit [3] in P1MBCR Force MDI-X 9 0 RW 1 = If Auto-MDI/MDI-X is disabled, force PHY into MDI-X mode. 0 = Do not force PHY into MDI-X mode. Bit [4] in P1MBCR Far-End Loopback 8 0 RW 1 = Perform loopback, as indicated: Start: RXP2/RXM2 (Port 2). Loopback: PMD/PMA of Port 1’s PHY. End: TXP2/TXM2 (Port 2). 0 = Normal operation. Bit [14] in P1MBCR Auto-Negotiation Enable 7 1 RW 6 1 RW 1 = Auto-negotiation is enabled. 0 = Disable auto-negotiation, speed, and duplex are decided by bits [6:5] of the same register. Bit [12] in P1MBCR Force Speed August 31, 2015 1 = Force 100BT if auto-negotiation is disabled (bit [7]). 0 = Force 10BT if auto-negotiation is disabled (bit [7]). 107 Bit [13] in P1MBCR Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Control Register 4 (0x07E – 0x07F): P1CR4 (Continued) Bit Default R/W Description Bit is Same As: Force Duplex 5 1 RW 1 = Force full-duplex if auto-negotiation is disabled. 0 = Force half-duplex if auto-negotiation is disabled. This bit also determines duplex if auto-negotiation is enabled but fails. When AN is enabled, this bit should be set to zero. Bit[ 8] in P1MBCR Advertised Flow Control Capability 4 1 RW 1 = Advertise flow control (pause) capability. 0 = Suppress flow control (pause) capability from transmission to link partner. Bit [10 ] in P1ANAR Advertised 100BT Full-Duplex Capability 3 1 RW 1 = Advertise 100BT full-duplex capability. 0 = Suppress 100BT full-duplex capability from transmission to link partner. Bit [8] in P1ANAR Advertised 100BT Half-Duplex Capability 2 1 RW 1 = Advertise 100BT half-duplex capability. 0 = Suppress 100BT half-duplex capability from transmission to link partner. Bit [7] in P1ANAR Advertised 10BT Full-Duplex Capability 1 1 RW 1 = Advertise 10BT full-duplex capability. 0 = Suppress 10BT full-duplex capability from transmission to link partner. Bit [6] in P1ANAR Advertised 10BT Half-Duplex Capability 0 1 RW 1 = Advertise 10BT half-duplex capability. 0 = Suppress 10BT half-duplex capability from transmission to link partner. Bit [5] in P1ANAR Port 1 Status Register (0x080 - 0x081): P1SR This register contains the status bits for the switch Port 1 function. Bit Default R/W Description Bit is Same As: HP_MDI-X 15 1 RW 1 = HP Auto-MDI-X mode. 0 = Micrel Auto-MDI-X mode. 14 0 RO Reserved 13 0 RO Bit [5] in P1MBCR Polarity Reverse 1 = Polarity is reversed. 0 = Polarity is not reversed. Bit [5] in P1PHYCTRL Transmit Flow Control Enable 12 0 RO 11 0 RO 1 = Transmit flow control feature is active. 0 = Transmit flow control feature is inactive. Receive Flow Control Enable August 31, 2015 1 = Receive flow control feature is active. 0 = Receive flow control feature is inactive. 108 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Status Register (0x080 - 0x081): P1SR (Continued) Bit Default R/W Description Bit is Same As: Operation Speed 10 0 RO 1 = Link speed is 100Mbps. 0 = Link speed is 10Mbps. Operation Duplex 9 0 RO 1 = Link duplex is full. 0 = Link duplex is half. 8 0 RO Reserved Bit [4] in P1MBSR MDI-X Status 7 0 RO 6 0 RO 5 0 RO 4 0 RO Bit [4] in P1PHYCTRL 0 = MDI. 1 = MDI-X. Auto-Negotiation Done 1 = Auto-negotiation done. 0 = Auto-negotiation not done. Bit [5] in P1MBSR Link Status 1 = Link good. 0 = Link not good. Bit [2] in P1MBSR Partner Flow Control Capability 1 = Link partner flow control (pause) capable. 0 = Link partner not flow control (pause) capable. Bi t [10] in P1ANLPR Partner 100BT Full-Duplex Capability 3 0 RO 1 = Link partner 100BT full-duplex capable. 0 = Link partner not 100BT full-duplex capable. 2 0 RO 1 = Link partner 100BT half-duplex capable. 0 = Link partner not 100BT half-duplex capable. 1 0 RO 1 = Link partner 10BT full-duplex capable. 0 = Link partner not 10BT full-duplex capable. Bit [8] in P1ANLPR Partner 100BT Half-Duplex Capability Bit [7] in P1ANLPR Partner 10BT Full-Duplex Capability Bit [6] in P1ANLPR Partner 10BT Half-Duplex Capability 0 0 RO 1 = Link partner 10BT half-duplex capable. 0 = Link partner not 10BT half−duplex capable. Bit [5] in P1ANLPR 0x082 - 0x083: Reserved August 31, 2015 109 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Registers Port 2 Control Register 1 (0x084 - 0x085): P2CR1 This register contains control bits for the switch Port 2 function. Bit Default R/W Description 15 0 RO Reserved Port 2 LED Direct Control 14 - 12 000 R/W These bits directly control the Port 2 LED pins. 0xx = Normal LED function as set up via Reg. 0x00E - 0x00F, Bits [9:8]. 100 = Both Port 2 LEDs off. 101 = Port 2 LED1 off, LED0 on. 110 = Port 2 LED1 on, LED0 off. 111 = Both Port 2 LEDs on. Source Address Filtering Enable MAC Address 2 11 0 RW 1 = Enable the source address filtering function when the SA matches the MAC Address 2 in SAFMACA2 (0x0B6 - 0x0BB). 0 = Disable source address filtering function. Source Address Filtering Enable for MAC Address 1 10 0 RW 1 = Enable the source address filtering function when the SA matches the MAC Address 1 in SAFMACA1 (0x0B0 - 0x0B5). 0 = Disable source address filtering function. Drop Tagged Packet Enable 9 0 RW 1 = Enable to drop tagged ingress packets. 0 = Disable to drop tagged ingress packets. TX Two Queues Select Enable 8 0 RW 1 = The Port 2 output queue is split into two priority queues (q0 and q1) 0 = Single output queue on Port 2. There is no priority differentiation even though packets are classified into high or low priority. Broadcast Storm Protection Enable 7 0 RW 1 = Enable broadcast storm protection for ingress packets on Port 2. 0 = Disable broadcast storm protection. 6 0 RW 1 = Enable DiffServ priority classification for ingress packets on Port 2. 0 = Disable DiffServ function. 5 0 RW 1 = Enable 802.1p priority classification for ingress packets on Port 2. 0 = Disable 802.1p. Diffserv Priority Classification Enable 802.1p Priority Classification Enable August 31, 2015 110 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 1 (0x084 - 0x085): P2CR1 (Continued) Bit Default R/W Description Port-Based Priority Classification 4−3 00 RW 00 = Ingress packets on Port 2 are classified as priority 0 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 01 = Ingress packets on Port 2 are classified as priority 1 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 10 = Ingress packets on Port 2 are classified as priority 2 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 11 = Ingress packets on Port 2 are classified as priority 3 queue if “Diffserv” or “802.1p” classification is not enabled or fails to classify. Note: “DiffServ”, “802.1p” and port priority can be enabled at the same time. The OR’ed result of 802.1p and DSCP overwrites the port priority. Tag Insertion 2 0 RW 1 = When packets are output on Port 2, the switch adds 802.1p/q tags to packets without 802.1p/q tags when received. The switch will not add tags to packets already tagged. The tag inserted is the ingress port’s “port VID”. 0 = Disable tag insertion. Tag Removal 1 0 RW 1 = When packets are output on Port 2, the switch removes 802.1p/q tags from packets with 802.1p/q tags when received. The switch will not modify packets received without tags. 0 = Disable tag removal. TX Multiple Queues Select Enable 0 0 August 31, 2015 RW 1 = The Port 2 output queue is split into four priority queues (q0, q1, q2 and q3). 0 = Single output queue on Port 2. There is no priority differentiation even though packets are classified into high or low priority. 111 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 2 (0x086 - 0x087): P2CR2 This register contains the control bits for the switch Port 2 function. Bit Default R/W Description 15 0 RW Reserved Ingress VLAN Filtering 14 0 RW 13 0 RW 12 0 RW 1 = The switch discards packets whose VID port membership in VLAN table bits [18:16] does not include the ingress port VID. 0 = No ingress VLAN filtering. Discard Non PVID Packets 1 = The switch discards packets whose VID does not match the ingress port default VID. 0 = No packets are discarded. Force Flow Control 1 = Always enable flow control on the port, regardless of auto-negotiation result. 0 = The flow control is enabled based on auto-negotiation result. Back-Pressure Enable 11 0 RW 10 1 RW 9 1 RW 1 = Enable port’s half-duplex back pressure. 0 = Disable port’s half-duplex back pressure. Transmit Enable 1 = Enable packet transmission on the port. 0 = Disable packet transmission on the port. Receive Enable 1 = Enable packet reception on the port. 0 = Disable packet reception on the port. Learning Disable 8 0 RW 1 = Disable switch address learning capability. 0 = Enable switch address learning. 7 0 RW 1 = Port is designated as a sniffer port and transmits packets that are monitored. 0 = Port is a normal port. Sniffer Port Receive Sniff 6 0 RW 1 = All packets received on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No receive monitoring. Transmit Sniff 5 0 RW 4 0 RW August 31, 2015 1 = All packets transmitted on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No transmit monitoring. Reserved 112 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 2 (0x086 - 0x087): P2CR2 (Continued) Bit Default R/W Description User Priority Ceiling 3 0 RW 1 = If the packet’s “priority field” is greater than the “user priority field” in the port VID control register bit[15:13], replace the packet’s “priority field” with the “user priority field” in the port VID control register bit[15:13]. 0 = Do not compare and replace the packet’s “priority field.” Port VLAN Membership 2−0 111 RW Define the port’s Port VLAN membership. Bit [2] stands for the host port, bit [1] for Port 2, and bit[0] for Port 1. The port can only communicate within the membership. A ‘1’ includes a port in the membership; a ‘0’ excludes a port from the membership. Port 2 VID Control Register (0x088 - 0x089): P2VIDCR This register contains control bits for the switch Port 2 function. This P2VIDCR Control register serves two purposes: 5. Associated with the ingress untagged packets, and used for egress tagging. 6. Default VID for the ingress untagged or null-VID-tagged packets, and used for address lookup Bit Default R/W 15−13 000 RW 12 0 RW 11−0 0x001 RW Description Default Tag[15:13] Port’s default tag, containing “User Priority Field” bits. Default Tag[12] Port’s default tag, containing CFI bit. Default Tag[11:0] Port’s default tag, containing VID[11:0]. Port 2 Control Register 3 (0x08A-0x08B): P2CR3 This register contains control bits for the switch Port 2 function. Bit Default R/W Description 15−5 0x000 RO Reserved 4 0 RW Reserved Ingress Limit Mode 3−2 00 August 31, 2015 RW These bits determine what kinds of frames are limited and counted against ingress limiting as follows: 00 = Limit and count all frames. 01 = Limit and count Broadcast, Multicast, and flooded Unicast frames. 10 = Limit and count Broadcast and Multicast frames only. 11 = Limit and count Broadcast frames only. 113 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 3 (0x08A - 0x08B): P2CR3 (Continued) Bit Default R/W Description Count Inter Frame Gap 1 0 RW Count IFG Bytes. 1 = Each frame’s minimum inter frame gap. IFG bytes (12 per frame) are included in ingress and egress rate limiting calculations. 0 = IFG bytes are not counted. Count Preamble 0 0 RW Count preamble Bytes. 1 = Each frame’s preamble bytes (8 per frame) are included in ingress and egress rate limiting calculations. 0 = Preamble bytes are not counted. Port 2 Ingress Rate Control Register 0 (0x08C - 0x08D): P2IRCR0 This register contains the Port 2 ingress rate limiting control bits for priority 1 and priority 0. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Ingress Data Rate Limit for Priority 1 Frames Ingress priority 1 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or100 Mbps with no limit. 7 0 RW Reserved Ingress Data Rate Limit for Priority 0 Frames 6−0 0x00 RW Ingress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 2 Ingress Rate Control Register 1 (0x08E - 0x08F): P2IRCR1 This register contains the Port 2 ingress rate limiting control bits for priority 3 and priority 2 frames. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Ingress Data Rate Limit for Priority 3 Frames Ingress priority 3 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10 Mbps or 100 Mbps with no limit. 7 0 RW 6−0 0x00 RW Reserved Ingress Data Rate Limit for Priority 2 Frames Ingress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10 Mbps or 100 Mbps with no limit. August 31, 2015 114 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Egress Rate Control Register 0 (0x090 - 0x091): P2ERCR0 This register contains the Port 2 egress rate limiting control bits for priority 1 and priority 0 frames. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Egress Data Rate Limit for Priority 1 Frames Egress priority 1 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Egress Rate Limit Control Enable 7 0 RW 6−0 0x00 RW 1 = Enable egress rate limit control. 0 = Disable egress rate limit control. Egress Data Rate Limit for Priority 0 Frames Egress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 2 Egress Rate Control Register 1 (0x092 – 0x093): P2ERCR1 This register contains the Port 2 egress rate limiting control bits for priority 3 and priority 2 frames. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Egress Data Rate Limit for Priority 3 Frames Egress priority 3 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 7 0 RW Reserved Egress Data Rate Limit for Priority 2 Frames 6−0 0x00 RW Egress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. August 31, 2015 115 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 PHY Special Control/Status, LinkMD (0x094 - 0x095): P2SCSLMD This register contains the LinkMD control and status information of PHY 2. Bit Default R/W 15 0 RO Description Bit is Same As: CDT_10m_Short 1 = Less than 10 meter short. CDT_Result 14−13 00 RO [00] = Normal condition. [01] = Open condition has been detected in cable. [10] = Short condition has been detected in cable. [11] = Cable diagnostic test has failed. CDT_Enable 12 0 RW/ SC 11 0 RW 10 1 RW 1 = Cable diagnostic test is enabled. It is self− cleared after the CDT test is done. 0 = Indicates that the cable diagnostic test is completed and the status information is valid for reading. Force_Link Bit [3] in P2PHYCTRL 1 = Force link pass. 0 = Normal operation. Reserved Remote (Near−End) Loopback 9 0 RW 8−0 0x000 RO August 31, 2015 1 = Perform remote loopback at Port 2's PHY (RXP2/RXM2 −> TXP2/TXM2) 0 = Normal operation Bit [1] in P2PHYCTRL CDT_Fault_Count Distance to the fault. It’s approximately 0.4m*CDT_Fault_Count. 116 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 4 (0x096 - 0x097): P2CR4 This register contains the control bits for the switch Port 2 function. Bit Default R/W Description 15 0 RW Reserved 14 0 RW Bit is Same As: Disable Transmit Bit[1] in P2MBCR 1 = Disable the port’s transmitter. 0 = Normal operation. Restart Auto-Negotiation 13 0 RW/SC 12 0 RW 1 = Restart auto-negotiation. 0 = Normal operation. Bit [9] in P2MBCR Reserved Bit [2] in P2MBCR Power Down 11 0 RW 10 0 RW 9 0 RW 1 = Power down. 0 = Normal operation. No change to registers setting Bit [11] in P2MBCR Disable Auto-MDI/MDI-X 1 = Disable Auto-MDI/MDI-X function. 0 = Enable Auto-MDI/MDI-X function. Bit [3] in P2MBCR Force MDI-X 1 = If Auto−MDI/MDI−X is disabled, force PHY into MDI−X mode. 0 = Do not force PHY into MDI−X mode. Bit [4] in P2MBCR Far-End Loopback 8 0 RW 1 = Perform loopback, as indicated: Start: RXP1/RXM1 (Port 1). Loopback: PMD/PMA of Port 2’s PHY. End: TXP1/TXM1 (Port 1). 0 = Normal operation. Bit [14] in P2MBCR Auto-Negotiation Enable 7 1 RW 6 1 RW 1 = Auto-negotiation is enabled. 0 = Disable auto-negotiation, speed, and duplex are decided by bits [6:5] of the same register. Bit [12] in P2MBCR Force Speed August 31, 2015 1 = Force 100BT if auto-negotiation is disabled (bit [7]). 0 = Force 10BT if auto-negotiation is disabled (bit [7]). 117 Bit [13] in P2MBCR Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Control Register 4 (0x096 - 0x097): P2CR4 (Continued) Bit Default R/W Description Bit is Same As: Force Duplex 5 1 RW 1 = Force full duplex if auto-negotiation is disabled. 0 = Force half duplex if auto-negotiation is disabled. This bit also determines duplex if auto-negotiation is enabled but fails. When AN is enabled, this bit should be set to zero. Bit [8] in P2MBCR Advertised Flow Control Capability 4 1 RW 1 = Advertise flow control (pause) capability. 0 = Suppress flow control (pause) capability from transmission to link partner. Bit [10] in P2ANAR Advertised 100BT Full-Duplex Capability 3 1 RW 1 = Advertise 100BT full-duplex capability. 0 = Suppress 100BT full-duplex capability from transmission to link partner. Bit [8] in P2ANAR Advertised 100BT Half-Duplex Capability 2 1 RW 1 = Advertise 100BT half-duplex capability. 0 = Suppress 100BT half-duplex capability from transmission to link partner. Bit [7] in P2ANAR Advertised 10BT Full-Duplex Capability 1 1 RW 1 = Advertise 10BT full-duplex capability. 0 = Suppress 10BT full-duplex capability from transmission to link partner. Bit [6] in P2ANAR Advertised 10BT Half-Duplex Capability 0 1 August 31, 2015 RW 1 = Advertise 10BT half-duplex capability. 0 = Suppress 10BT half-duplex capability from transmission to link partner. 118 Bit [5] in P2ANAR Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Status Register (0x098 - 0x099): P2SR This register contains the status bits for the switch Port 2 function. Bit Default R/W Description 15 1 RW 1 = HP Auto MDI-X mode. 0 = Micrel Auto MDI-X mode. 14 0 RO Reserved Bit is Same As: HP_MDIX Bit [5] in P2MBCR Polarity Reverse 13 0 RO Bit [5] in P2PHYCTRL 12 0 RO 11 0 RO 1 = Receive flow control feature is active. 0 = Receive flow control feature is inactive. 10 0 RO 1 = Link speed is 100Mbps. 0 = Link speed is 10Mbps. 9 0 RO 1 = Link duplex is full. 0 = Link duplex is half. 8 0 RO Reserved 7 0 RO 1 = Polarity is reversed. 0 = Polarity is not reversed. Transmit Flow Control Enable 1 = Transmit flow control feature is active. 0 = Transmit flow control feature is inactive. Receive Flow Control Enable Operation Speed Operation Duplex Bit [4] in P2MBSR MDI-X Status Bit [4] in P2PHYCTRL 0 = MDI. 1 = MDI-X. Auto-Negotiation Done 6 0 RO 5 0 RO 1 = Auto-negotiation done. 0 = Auto-negotiation not done. Bit [5] in P2MBSR Link Status Bit [2] in P2MBSR 1 = Link good. 0 = Link not good. Partner Flow Control Capability 4 0 RO 3 0 RO 1 = Link partner flow control (pause) capable. 0 = Link partner not flow control (pause) capable. Bit [10] in P2ANLPR Partner 100BT Full-Duplex Capability August 31, 2015 1 = Link partner 100BT full-duplex capable. 0 = Link partner not 100BT full-duplex capable. 119 Bit [8] in P2ANLPR Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Status Register (0x098 - 0x099): P2SR (Continued) Bit Default R/W Description Bit is Same As: Partner 100BT Half-Duplex Capability 2 0 RO 1 0 RO 1 = Link partner 100BT half-duplex capable. 0 = Link partner not 100BT half-duplex capable. Bit [7] in P2ANLPR Partner 10BT Full-Duplex Capability 1 = Link partner 10BT full-duplex capable. 0 = Link partner not 10BT full-duplex capable. Bit [6] in P2ANLPR Partner 10BT Half-Duplex Capability 0 0 RO 1 = Link partner 10BT half-duplex capable. 0 = Link partner not 10BT half-duplex capable. Bit [5] in P2ANLPR 0x09A – 0x09B: Reserved August 31, 2015 120 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 Control Registers Port 3 Control Register 1 (0x09C - 0x09D): P3CR1 This register contains control bits for the switch Port 3 function. Bit Default R/W Description 15−10 0x00 RO Reserved 9 0 RW Drop Tagged Packet Enable 1 = Enable to drop tagged ingress packets. 0 = Disable to drop tagged ingress packets. TX Two Queues Select Enable 8 0 RW 7 0 RW 6 0 RW 1 = The Port 3 output queue is split into two priority queues (q0 and q1). 0 = Single output queue on Port 3. There is no priority differentiation even though packets are classified into high or low priority. Broadcast Storm Protection Enable 1 = Enable broadcast storm protection for ingress packets on Port 3. 0 = Disable broadcast storm protection. Diffserv Priority Classification Enable 1 = Enable DiffServ priority classification for ingress packets on Port 3. 0 = Disable DiffServ function. 802.1p Priority Classification Enable 5 0 RW 1 = Enable 802.1p priority classification for ingress packets on Port 3. 0 = Disable 802.1p. Port-Based Priority Classification 4−3 00 RW 00 = Ingress packets on Port 3 are classified as priority 0 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 01 = Ingress packets on Port 3 are classified as priority 1 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 10 = Ingress packets on Port 3 are classified as priority 2 queue if “DiffServ” or “802.1p” classification is not enabled or fails to classify. 11 = Ingress packets on Port 3 are classified as priority 3 queue if “Diffserv” or “802.1p” classification is not enabled or fails to classify. Note: “DiffServ”, “802.1p” and port priority can be enabled at the same time. The OR’ed result of 802.1p and DSCP overwrites the port priority. Tag Insertion 2 0 RW 1 = When packets are output on Port 3, the switch adds 802.1p/q tags to packets without 802.1p/q tags when received. The switch will not add tags to packets already tagged. The tag inserted is the ingress port’s “port VID”. 0 = Disable tag insertion. Tag Removal 1 0 RW 1 = When packets are output on Port 3, the switch removes 802.1p/q tags from packets with 802.1p/q tags when received. The switch will not modify packets received without tags. 0 = Disable tag removal. TX Multiple Queues Select Enable 0 0 August 31, 2015 RW 1 = The Port 3 output queue is split into four priority queues (q0, q1, q2 and q3). 0 = Single output queue on Port 3. There is no priority differentiation even though packets are classified into high or low priority. 121 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 Control Register 2 (0x09E - 0x09F): P3CR2 This register contains control bits for the switch Port 3 function. Bit Default R/W Description 15 0 RW Reserved Ingress VLAN Filtering 1 = The switch discards packets whose VID port membership in VLAN table bits [18:16] does not include the ingress port VID. 0 = No ingress VLAN filtering. 14 0 RW 13 0 RW 1 = The switch discards packets whose VID does not match the ingress port default VID. 0 = No packets are discarded. 12 0 RW Reserved Discard Non PVID Packets Back Pressure Enable 11 0 RW 10 1 RW 1 = Enable port’s half−duplex back pressure. 0 = Disable port’s half−duplex back pressure. Transmit Enable 1 = Enable packet transmission on the port. 0 = Disable packet transmission on the port. Receive Enable 9 1 RW 1 = Enable packet reception on the port. 0 = Disable packet reception on the port. 8 0 RW 1 = Disable switch address learning capability. 0 = Enable switch address learning. 7 0 RW 1 = Port is designated as a sniffer port and transmits packets that are monitored. 0 = Port is a normal port. Learning Disable Sniffer Port Receive Sniff 6 0 RW 1 = All packets received on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No receive monitoring. Transmit Sniff 5 0 RW 4 0 RW 1 = All packets transmitted on the port are marked as “monitored packets” and forwarded to the designated “sniffer port.” 0 = No transmit monitoring. Reserved User Priority Ceiling 3 0 RW 1 = If the packet’s “priority field” is greater than the “user priority field” in the port VID control register bit[15:13], replace the packet’s “priority field” with the “user priority field” in the port VID control register bit[15:13]. 0 = Do not compare and replace the packet’s “priority field.” Port VLAN Membership 2−0 111 August 31, 2015 RW Define the port’s Port VLAN membership. Bit [2] stands for the host port, bit [1] for Port 2, and bit [0] for Port 1. The port can only communicate within the membership. A ‘1’ includes a port in the membership; a ‘0’ excludes a port from the membership. 122 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 VID Control Register (0x0A0 - 0x0A1): P3VIDCR This register contains control bits for the switch Port 3 function. This P3VIDCR Control register serves two purposes: 7. Associated with the ingress untagged packets, and used for egress tagging. 8. Default VID for the ingress untagged or null-VID-tagged packets, and used for address lookup Bit Default R/W 15−13 000 RW 12 0 RW 11−0 0x001 RW Description Default Tag[15:13] Port’s default tag, containing “User Priority Field” bits. Default Tag[12] Port’s default tag, containing CFI bit. Default Tag[11:0] Port’s default tag, containing VID[11:0]. Port 3 Control Register 3 (0x0A2 - 0x0A3): P3CR3 This register contains control bits for the switch Port 3 function. Bit Default R/W Description 15−8 0x00 RO Reserved 7 0 RW Reserved 6−4 000 RW Reserved Ingress Limit Mode 3−2 00 RW These bits determine what kinds of frames are limited and counted against ingress rate limiting as follows: 00 = Limit and count all frames. 01 = Limit and count Broadcast, Multicast, and flooded Unicast frames. 10 = Limit and count Broadcast and Multicast frames only. 11 = Limit and count Broadcast frames only. Count Inter Frame Gap 1 0 RW Count IFG Bytes. 1 = Each frame’s minimum inter frame gap. IFG bytes (12 per frame) are included in ingress and egress rate limiting calculations. 0 = IFG bytes are not counted. Count Preamble 0 0 August 31, 2015 RW Count preamble Bytes. 1 = Each frame’s preamble bytes (8 per frame) are included in ingress and egress rate limiting calculations. 0 = Preamble bytes are not counted. 123 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 Ingress Rate Control Register 0 (0x0A4 - 0x0A5): P3IRCR0 This register contains the Port 3 ingress rate limiting control bits for priority 1 and priority 0. Bit Default R/W Description 15 0 RW Reserved Ingress Data Rate Limit for Priority 1 Frames 14−8 0x00 RW Ingress priority 1 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 7 0 RW Reserved 6−0 0x00 RW Ingress Data Rate Limit for Priority 0 Frames Ingress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 3 Ingress Rate Control Register 1 (0x0A6 - 0x0A7): P3IRCR1 This register contains the Port 3 ingress rate limiting control bits for priority 3 and priority 2. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Ingress priority 3 frames will be limited or discarded as shown in Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 7 0 RW Reserved Ingress Data Rate Limit for Priority 3 Frames Ingress Data Rate Limit for Priority 2 Frames 6−0 0x00 RW Ingress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Port 3 Egress Rate Control Register 0 (0x0A8 - 0x0A9): P3ERCR0 This register contains the Port 3 egress rate limiting control bits for priority 1 and priority 0. Bit Default R/W Description 15 0 RW Reserved 14−8 0x00 RW Egress Data Rate Limit for Priority 1 Frames Egress priority 1 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. Egress Rate Limit Control Enable 7 0 RW 6−0 0x00 RW 1 = Enable egress rate limit control. 0 = Disable egress rate limit control. Egress Data Rate Limit for Priority 0 Frames August 31, 2015 Egress priority 0 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 124 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 Egress Rate Control Register 1 (0x0AA - 0x0AB): P3ERCR1 This register contains the Port 3 egress rate limiting control bits for priority 3 and priority 2. Bit Default R/W Description 15 0 RW Reserved Egress Data Rate Limit for Priority 3 Frames 14−8 0x00 RW Egress priority 3 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 10Mbps with no limit. 7 0 RW Reserved 6−0 0x00 RW Egress Data Rate Limit for Priority 2 Frames August 31, 2015 Egress priority 2 frames will be limited or discarded as shown in the Table 20. Note: The default value 0x00 is full rate at 10Mbps or 100Mbps with no limit. 125 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Registers Switch Global Control Register 8 (0x0AC - 0x0AD): SGCR8 This register contains the global control bits for the switch function. Bit Default R/W Description Two Queue Priority Mapping 15−14 10 RW 13−11 000 RO 10 0 RW/ SC 9 0 RW These bits determine the mapping between the priority of the incoming frames and the destination onchip queue in a two queue configuration which uses egress queues 0 and 1. ‘00’ = Egress Queue 1 receives priority 3 frames Egress Queue 0 receives priority 0, 1, 2 frames ‘01’ = Egress Queue 1 receives priority 1, 2, 3 frames Egress Queue 0 receives priority 0 frames ‘10’ = Egress Queue 1 receives priority 2, 3 frames Egress Queue 0 receives priority 0, 1 frames ‘11’ = Egress Queue 1 receives priority 1, 2, 3 frames Egress Queue 0 receives priority 0 frames Reserved Flush Dynamic MAC Table Before flushing the dynamic MAC table, switch address learning must be disabled by setting bit[8] in the P1CR2, P2CR2 and P3CR2 registers. Flush Static MAC Table 1 = Enable flush static MAC table for spanning tree application 0 = Disable flush static MAC table for spanning tree application Port 3 Tail Tag Mode Enable 8 0 RW 1 = Enable tail tag mode 0 = Disable tail tag mode 7−0 0x00 RW 0x01 - 0xFF = Enable to force PAUSE off iteration limit time (a unit number is 160ms) 0x00 = Disable Force PAUSE Off Iteration Limit Force PAUSE Off Iteration Limit Time Enable August 31, 2015 126 Revision 1.1 Micrel, Inc. KSZ8852HLE Switch Global Control Register 9 (0x0AE - 0x0AF): SGCR9 This register contains the global control bits for the switch function. Bit Default R/W Description 15−11 0x00 RO Reserved 10−8 000 RW Define the forwarding port for frame with invalid VID. Bit [10] stands for the host port, bit [9] for Port 2, and bit [8] for Port 1. 7−6 00 RW Reserved 5 0 RW Forwarding Invalid Frame Enable Insert Source Port PVID Tag when Untagged Frame from Port 3 to Port 2 1 = Enable 0 = Disable Enable Insert Source Port PVID Tag when Untagged Frame from Port 3 to Port 1 4 0 RW 3 0 RW 2 0 RW 1 = Enable 0 = Disable Enable Insert Source Port PVID Tag when Untagged Frame from Port 2 to Port 3 1 = Enable 0 = Disable Enable Insert Source Port PVID Tag when Untagged Frame from Port 2 to Port 1 1 = Enable 0 = Disable Enable Insert Source Port PVID Tag when Untagged Frame from Port 1 to Port 3 1 0 RW 0 0 RW 1 = Enable 0 = Disable Enable Insert Source Port PVID Tag when Untagged Frame from Port 1 to Port 2 August 31, 2015 1 = Enable 0 = Disable 127 Revision 1.1 Micrel, Inc. KSZ8852HLE Source Address Filtering Registers Source Address Filtering MAC Address 1 Register Low (0x0B0 - 0x0B1): SAFMACA1L Register bit fields for the low word of MAC Address 1. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address1 Low The least significant word of MAC Address 1. Source Address Filtering MAC Address 1 Register Middle (0x0B2 - 0x0B3): SAFMACA1M Register bit fields for the middle word of MAC Address 1. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address Middle 1 The middle word of MAC Address 1. Source Address Filtering MAC Address 1 Register High (0x0B4 - 0x0B5): SAFMACA1H Register bit fields for the high word of MAC Address 1. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address High 1 The most significant word of MAC Address 1. Source Address Filtering MAC Address 2 Register Low (0x0B6 - 0x0B7): SAFMACA2L Register bit fields for the low word of MAC Address 2. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address Low 2 The least significant word of MAC Address 2. Source Address Filtering MAC Address 2 Register Middle (0x0B8 - 0x0B9): SAFMACA2M Register bit fields for the middle word of MAC Address 2. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address Middle 2 The middle word of MAC Address 2. Source Address Filtering MAC Address 2 Register High (0x0BA - 0x0BB): SAFMACA2H Register bit fields for the high word of MAC Address 2. Bit Default Value R/W 15−0 0x0000 RW Description Source Filtering MAC Address High 2 The most significant word of MAC Address 2. 0x0BC - 0x0C7: Reserved August 31, 2015 128 Revision 1.1 Micrel, Inc. KSZ8852HLE TXQ Rate Control Registers Port 1 TXQ Rate Control Register 1 (0x0C8 - 0x0C9): P1TXQRCR1 This register contains the q2 and q3 rate control bits for Port 1. Bit Default Value R/W Description Port 1 Transmit Queue 2 (high) Ratio Control 15 1 RW 14−8 0x04 RW 0 = Strict priority. Port 1 will transmit all the packets from this priority queue 2 before transmit lower priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 2 within a certain time. Port 1 Transmit Queue 2 (high) Ratio This ratio indicates the number of packet for high-priority packet can transmit within a given period. Port 1 Transmit Queue 3 (highest) Ratio Control 7 1 RW 6−0 0x08 RW 0 = Strict priority. Port 1 will transmit all the packets from this priority queue 3 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 3 within a certain time. Port 1 Transmit Queue 3 (highest) Ratio This ratio indicates the number of packet for highest priority packet can transmit within a given period. Port 1 TXQ Rate Control Register 2 (0x0CA - 0x0CB): P1TXQRCR2 This register contains the q0 and q1 rate control bits for Port 1. Bit Default Value R/W Description Port 1 Transmit Queue 0 (lowest) Ratio Control 15 1 RW 14−8 0x01 RW 0 = Strict priority. Port 1 will transmit all the packets from this priority queue 0 after transmit higher priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 0 within a certain time. Port 1 Transmit Queue 0 (lowest) Ratio This ratio indicates the number of packet for lowest priority packet can transmit within a given period. Port 1 Transmit Queue 1 (low) Ratio Control 7 1 RW 6−0 0x02 RW 0 = Strict priority. Port 1 will transmit all the packets from this priority queue 1 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 1 within a certain time. Port 1 Transmit Queue 1 (low) Ratio August 31, 2015 This ratio indicates the number of packet for low priority packet can transmit within a given period. 129 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 TXQ Rate Control Register 1 (0x0CC - 0x0CD): P2TXQRCR1 This register contains the q2 and q3 rate control bits for Port 2. Bit Default Value R/W Description Port 2 Transmit Queue 2 (high) Ratio Control 15 1 RW 14−8 0x04 RW 0 = Strict priority. Port 2 will transmit all the packets from this priority queue 2 before transmit lower priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 2 within a certain time. Port 2 Transmit Queue 2 (high) Ratio This ratio indicates the number of packet for high priority packet can transmit within a given period. Port 2 Transmit Queue 3 (highest) Ratio Control 7 1 RW 6−0 0x08 RW 0 = Strict priority. Port 2 will transmit all the packets from this priority queue 3 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 3 within a certain time. Port 2 Transmit Queue 3 (highest) Ratio This ratio indicates the number of packet for highest priority packet can transmit within a given period. Port 2 TXQ Rate Control Register 2 (0x0CE - 0x0CF): P2TXQRCR2 This register contains the q0 and q1 rate control bits for Port 2. Bit Default Value R/W Description Port 2 Transmit Queue 0 (lowest) Ratio Control 15 1 RW 14−8 0x01 RW 0 = Strict priority. Port 2 will transmit all the packets from this priority queue 0 after transmit higher priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 0 within a certain time. Port 2 Transmit Queue 0 (lowest) Ratio This ratio indicates the number of packet for lowest priority packet can transmit within a given period. Port 2 Transmit Queue 1 (low) Ratio Control 7 1 RW 6−0 0x02 RW 0 = Strict priority. Port 2 will transmit all the packets from this priority queue 1 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 1 within a certain time. Port 2 Transmit Queue 1 (low) Ratio August 31, 2015 This ratio indicates the number of packet for low priority packet can transmit within a given period. 130 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 3 TXQ Rate Control Register 1 (0x0D0 - 0x0D1): P3TXQRCR1 This register contains the q2 and q3 rate control bits for Port 3. Bit Default Value R/W Description Port 3 Transmit Queue 2 (high) Ratio Control 15 1 RW 14−8 0x04 RW 0 = Strict priority. Port 3 will transmit all the packets from this priority queue 2 before transmit lower priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 2 within a certain time. Port 3 Transmit Queue 2 (high) Ratio This ratio indicates the number of packet for high priority packet can transmit within a given period. Port 3 Transmit Queue 3 (highest) Ratio Control 7 1 RW 6−0 0x08 RW 0 = Strict priority. Port 3 will transmit all the packets from this priority queue 3 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 3 within a certain time. Port 3 Transmit Queue 3 (highest) Ratio This ratio indicates the number of packet for highest priority packet can transmit within a given period. Port 3 TXQ Rate Control Register 2 (0x0D2 - 0x0D3): P3TXQRCR2 This register contains the q0 and q1 rate control bits for Port 3. Bit Default Value R/W Description Port 3 Transmit Queue 0 (lowest) Ratio Control 15 1 RW 14−8 0x01 RW 0 = Strict priority. Port 3 will transmit all the packets from this priority queue 0 after transmit higher priority queue. 1 = Bit[14:8] reflect the number of packets allow to transmit from this priority queue 0 within a certain time. Port 3 Transmit Queue 0 (lowest) Ratio This ratio indicates the number of packet for lowest priority packet can transmit within a given period. Port 3 Transmit Queue 1 (low) Ratio Control 7 1 RW 6−0 0x02 RW 0 = Strict priority. Port 3 will transmit all the packets from this priority queue 1 before transmit lower priority queue. 1 = Bit[6:0] reflect the number of packets allow to transmit from this priority queue 1 within a certain time. Port 3 Transmit Queue 1 (low) Ratio This ratio indicates the number of packet for low priority packet can transmit within a given period. 0x0D4 - 0x0DB: Reserved August 31, 2015 131 Revision 1.1 Micrel, Inc. KSZ8852HLE Auto-Negotiation Next Page Registers Port 1 Auto-Negotiation Next Page Transmit Register (0x0DC - 0x0DD): P1ANPT This register contains the Port 1 auto-negotiation next page transmit related bits. Bit Default R/W Description Next Page 15 0 RO 14 0 RO Next page (NP) is used by the next page function to indicate whether or not this is the last next page to be transmitted. NP shall be set as follows: 1 = Additional Next Page(s) will follow. 0 = Last page. Reserved Message Page 13 1 RO Message page (MP) is used by the next page function to differentiate a message page from an unformatted page. MP shall be set as follows: 1 = Message page. 0 = Unformatted page. Acknowledge 2 12 0 RO Acknowledge 2 (Ack2) is used by the next page function to indicate that a device has the ability to comply with the message. Ack2 shall be set as follows: 1 = Able to comply with message. 0 = Unable to comply with message. Toggle 11 0 RO 10−0 0x001 RO August 31, 2015 Toggle (T) is used by the arbitration function to ensure synchronization with the link partner during next page exchange. This bit shall always take the opposite value of the toggle bit in the previously exchanged link code word. The initial value of the toggle bit in the first next page transmitted is the inverse of bit [11] in the base link code word and, therefore, may assume a value of logic one or zero. The toggle bit shall be set as follows: 1 = Previous value of the transmitted link code word equal to logic zero. 0 = Previous value of the transmitted link code word equal to logic one. Message and Unformatted Code Field Message/Unformatted code field bits [10:0] 132 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 Auto-Negotiation Link Partner Received Next Page Register (0x0DE - 0x0DF): P1ALPRNP This register contains the Port 1 auto-negotiation link partner received next page related bits. Bit Default R/W Description Next Page 15 0 RO Next Page (NP) is used by the next page function to indicate whether or not this is the last next page to be transmitted. NP shall be set as follows: 1 = Additional next page(s) will follow. 0 = Last page. Acknowledge 14 0 RO Acknowledge (Ack) is used by the auto-negotiation function to indicate that a device has successfully received its link partner’s link code word. The acknowledge bit is encoded in bit [14] regardless of the value of the selector field or link code word encoding. If no next page information is to be sent, this bit shall be set to logic one in the link code word after the reception of at least three consecutive and consistent FLP Bursts (ignoring the acknowledge bit value). Message Page 13 0 RO Message Page (MP) is used by the next page function to differentiate a message page from an unformatted page. MP shall be set as follows: 1 = Message page. 0 = Unformatted page. Acknowledge 2 12 0 RO Acknowledge 2 (Ack2) is used by the next page function to indicate that a device has the ability to comply with the message. Ack2 shall be set as follows: 1 = Able to comply with message. 0 = Unable to comply with message. Toggle 11 0 RO 10−0 0x000 RO August 31, 2015 Toggle (T) is used by the arbitration function to ensure synchronization with the link partner during next page exchange. This bit shall always take the opposite value of the toggle bit in the previously exchanged link code word. The initial value of the toggle bit in the first next page transmitted is the inverse of bit [11] in the base link code word and, therefore, may assume a value of logic one or zero. The toggle bit shall be set as follows: 1 = Previous value of the transmitted link code word equal to logic zero. 0 = Previous value of the transmitted link code word equal to logic one. Message and Unformatted Code Field Message/Unformatted code field bit [10:0] 133 Revision 1.1 Micrel, Inc. KSZ8852HLE EEE and Link Partner Advertisement Registers Port 1 EEE and Link Partner Advertisement Register (0x0E0 – 0x0E1): P1EEEA This register contains the Port 1 EEE advertisement and link partner advertisement information. Bit Default R/W Description 15 0 RO Reserved 14 0 RO 1 = Link Partner EEE is supported for 10GBASE-KR. 0 = Link Partner EEE is not supported for 10GBASE-KR. 13 0 RO 1 = Link Partner EEE is supported for 10GBASE-KX4. 0 = Link Partner EEE is not supported for 10GBASE-KX4. 10GBASE-KR EEE 10GBASE-KX4 EEE 1000BASE-KX EEE 12 0 RO 1 = Link Partner EEE is supported for 1000BASE-KX. 0 = Link Partner EEE is not supported for 1000BASE-KX. 11 0 RO 1 = Link Partner EEE is supported for 10GBASE-T. 0 = Link Partner EEE is not supported for 10GBASE-T. 10 0 RO 1 = Link Partner EEE is supported for 1000BASE-T. 0 = Link Partner EEE is not supported for 1000BASE-T. 10GBASE-T EEE 1000BASE-T EEE 100BASE-TX EEE 9 0 RO 1 = Link Partner EEE is supported for 100BASE-TX. 0 = Link Partner EEE is not supported for 100BASE-TX. 8–7 00 RO Reserved 6 0 RO 10GBASE-KR EEE 1 = Port 1 EEE is supported for 10GBASE-KR. 0 = Port 1 EEE is not supported for 10GBASE-KR. 10GBASE-KX4 EEE 5 0 RO 1 = Port 1 EEE is supported for 10GBASE-KX4. 0 = Port 1 EEE is not supported for 10GBASE-KX4. 1000BASE-KX EEE 4 0 RO 3 0 RO 1 = Port 1 EEE is supported for 1000BASE-KX. 0 = Port 1 EEE is not supported for 1000BASE-KX. 10GBASE-T EEE 1 = Port 1 EEE is supported for 10GBASE−T. 0 = Port 1 EEE is not supported for 10GBASE−T. 1000BASE-T EEE 2 0 RO 1 = Port 1 EEE is supported for 1000BASE-T. 0 = Port 1 EEE is not supported for 1000BASE-T. 100BASE-TX EEE 1 1 RW 0 0 RO August 31, 2015 1 = Port 1 EEE is supported for 100BASE-TX. 0 = Port 1 EEE is not supported for 100BASE-TX. To disable EEE capability, clear the Port 1 Next Page Enable bit in the PCSEEEC register (0x0F3). Reserved 134 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 EEE Wake Error Count Register (0x0E2 - 0x0E3): P1EEEWEC This register contains the Port 1 EEE wake error count information. Bit Default Value R/W Description Port 1 EEE Wake Error Count 15−0 0x0000 RW This counter is incremented by each transition of lpi_wake_timer_done from FALSE to TRUE. It means the Wake-Up time is longer than 20.5µs. The value will be held at all ones in the case of overflow and will be cleared to zero after this register is read. Port 1 EEE Control/Status and Auto-Negotiation Expansion Register (0x0E4 - 0x0E5): P1EEECS This register contains the Port 1 EEE control/status and auto-negotiation expansion information. Bit Default R/W Description 15 1 RW Reserved 14 0 RO Hardware 100BT EEE Enable Status 1 = 100BT EEE is enabled by hardware based NP exchange. 0 = 100BT EEE is disabled. TX LPI Received 13 0 RO/LH (Latching High) 1 = Indicates that the transmit PCS has received low power idle (LPI) signaling one or more times since the register was last read. 0 = Indicates that the PCS has not received low power idle (LPI) signaling. The status will be latched high and stay that way until cleared. To clear this status bit, a “1” needs to be written to this register bit. TX LPI Indication 12 0 RO 1 = Indicates that the transmit PCS is currently receiving low power idle (LPI) signals. 0 = Indicates that the PCS is not currently receiving low power idle (LPI) signals. This bit will dynamically indicate the presence of the TX LPI signal. RX LPI Received 11 0 August 31, 2015 RO/LH (Latching High) 1 = Indicates that the receive PCS has received low power idle (LPI) signaling one or more times since the register was last read. 0 = Indicates that the PCS has not received low power idle (LPI) signaling. The status will be latched high and stay that way until cleared. To clear this status bit, a “1” needs to be written to this register bit. 135 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 EEE Control/Status and Auto−Negotiation Expansion Register (0x0E4 - 0x0E5): P1EEECS (Continued) Bit Default R/W Description RX LPI Indication 1 = Indicates that the receive PCS is currently receiving low power idle (LPI) signals. 0 = Indicates that the PCS is not currently receiving low power idle (LPI) signals. This bit will dynamically indicate the presence of the RX LPI signal. 10 0 RO 9–8 00 RW Reserved 7 0 RO Reserved Received Next Page Location Able 6 1 RO 5 1 RO 1 = Received Next Page storage location is specified by bit [6:5]. 0 = Received Next Page storage location is not specified by bit [6:5]. Received Next Page Storage Location 1 = Link partner Next Pages are stored in P1ALPRNP (Reg. 0x0DE - 0x0DF). 0 = Link partner Next Pages are stored in P1ANLPR (Reg. 0x056 - 0x057). Parallel Detection Fault 4 0 RO/LH (Latching High) 1 = A fault has been detected via the parallel detection function. 0 = A fault has not been detected via the parallel detection function. This bit is cleared after read. Link Partner Next Page Able 3 0 RO 2 1 RO 1 0 RO/LH (Latching High) 1 = Link partner is Next Page abled. 0 = Link partner is not Next Page abled. Next Page Able 1 = Local device is Next Page abled. 0 = Local device is not Next Page abled. Page Received 1 = A New Page has been received. 0 = A New Page has not been received. Link Partner Auto-Negotiation Able 0 0 August 31, 2015 RO 1 = Link partner is auto-negotiation abled. 0 = Link partner is not auto-negotiation abled. 136 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 1 LPI Recovery Time Counter Register (0x0E6): P1LPIRTC This register contains the Port 1 LPI recovery time counter information. Bit Default Value R/W Description Port 1 LPI Recovery Time Counter 7−0 0x27 (25µs) RW This register specifies the time that the MAC device has to wait before it can start to send out packets. This value should be the maximum of the LPI recovery time between local device and remote device. Each count = 640ns. Buffer Load to LPI Control 1 Register (0x0E7): BL2LPIC1 This register contains the buffer load to LPI control 1 information. Bit Default Value R/W Description LPI Terminated by Input Traffic Enable 7 0 RW 1 = LPI request will be stopped if input traffic is detected. 0 = LPI request won’t be stopped by input traffic. 6 0 RO Reserved 5−0 0x08 RW Buffer Load Threshold for Source Port LPI Termination This value defines the maximum buffer usage allowed for a single port before it starts to trigger the LPI termination for the specific source port. (512 bytes per unit) Port 2 Auto−Negotiation Next Page Transmit Register (0x0E8 - 0x0E9): P2ANPT This register contains the Port 2 auto-negotiation next page transmit related bits. Bit Default R/W Description Next Page 15 0 RO 14 0 RO Next page (NP) is used by the next page function to indicate whether or not this is the last next page to be transmitted. NP shall be set as follows: 1 = Additional next page(s) will follow. 0 = Last page. Reserved Message Page 13 1 RO Message page (MP) is used by the next page function to differentiate a message page from an unformatted page. MP shall be set as follows: 1 = Message page. 0 = Unformatted page. Acknowledge 2 12 0 RO Acknowledge 2 (Ack2) is used by the next page function to indicate that a device has the ability to comply with the message. Ack2 shall be set as follows: 1 = Able to comply with message. 0 = Unable to comply with message. Toggle 11 0 RO 10−0 0x001 RO August 31, 2015 Toggle (T) is used by the arbitration function to ensure synchronization with the link partner during next page exchange. This bit shall always take the opposite value of the toggle bit in the previously exchanged link code word. The initial value of the toggle bit in the first next page transmitted is the inverse of bit [11] in the base link code word and, therefore, may assume a value of logic one or zero. The toggle bit shall be set as follows: 1 = Previous value of the transmitted link code word equal to logic zero. 0 = Previous value of the transmitted link code word equal to logic one. Message and Unformatted Code Field Message/Unformatted code field bits [10:0] 137 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 Auto-Negotiation Link Partner Received Next Page Register (0x0EA - 0x0EB): P2ALPRNP This register contains the Port 2 auto-negotiation link partner received next page related bits. Bit Default R/W Description Next Page 15 0 RO Next page (NP) is used by the next page function to indicate whether or not this is the last next page to be transmitted. NP shall be set as follows: 1 = Additional next page(s) will follow. 0 = Last page. Acknowledge 14 0 RO Acknowledge (Ack) is used by the auto-negotiation function to indicate that a device has successfully received its link partner’s link code word. The acknowledge bit is encoded in bit 14] regardless of the value of the selector field or link code word encoding. If no next page information is to be sent, this bit shall be set to logic one in the link code word after the reception of at least three consecutive and consistent FLP bursts (ignoring the acknowledge bit value). Message Page 13 0 RO Message page (MP) is used by the next page function to differentiate a message page from an unformatted page. MP shall be set as follows: 1 = Message Page. 0 = Unformatted Page. Acknowledge 2 12 0 RO Acknowledge 2 (Ack2) is used by the next page function to indicate that a device has the ability to comply with the message. Ack2 shall be set as follows: 1 = Able to comply with message. 0 = Unable to comply with message. Toggle 11 0 RO 10−0 0x000 RO Toggle (T) is used by the arbitration function to ensure synchronization with the link partner during next page exchange. This bit shall always take the opposite value of the toggle bit in the previously exchanged link code word. The initial value of the toggle bit in the first next page transmitted is the inverse of bit [11] in the base link code word and, therefore, may assume a value of logic one or zero. The toggle bit shall be set as follows: 1 = Previous value of the transmitted link code word equal to logic zero. 0 = Previous value of the transmitted link code word equal to logic one. Message and Unformatted Code Field Message/unformatted code field bit [10:0] Port 2 EEE and Link Partner Advertisement Register (0x0EC - 0x0ED): P2EEEA This register contains the Port 2 EEE advertisement and link partner advertisement information. Bit Default R/W Description 15 0 RO Reserved 10GBASE-KR EEE 14 0 RO 1 = Link Partner EEE is supported for 10GBASE-KR. 0 = Link Partner EEE is not supported for 10GBASE-KR. 13 0 RO 1 = Link Partner EEE is supported for 10GBASE-KX4. 0 = Link Partner EEE is not supported for 10GBASE-KX4. 10GBASE-KX4 EEE August 31, 2015 138 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 EEE and Link Partner Advertisement Register (0x0EC - 0x0ED): P2EEEA (Continued) This register contains the Port 2 EEE advertisement and link partner advertisement information. Bit Default R/W Description 12 0 RO 1 = Link Partner EEE is supported for 1000BASE-KX. 0 = Link Partner EEE is not supported for 1000BASE-KX. 1000BASE-KX EEE 10GBASE-T EEE 11 0 RO 1 = Link Partner EEE is supported for 10GBASE-T. 0 = Link Partner EEE is not supported for 10GBASE-T. 10 0 RO 1 = Link Partner EEE is supported for 1000BASE-T. 0 = Link Partner EEE is not supported for 1000BASE-T. 1000BASE-T EEE 100BASE-TX EEE 9 0 RO 1 = Link Partner EEE is supported for 100BASE-TX. 0 = Link Partner EEE is not supported for 100BASE-TX. 8–7 00 RO Reserved 10GBASE-KR EEE 6 0 RO 1 = Port 2 EEE is supported for 10GBASE-KR. 0 = Port 2 EEE is not supported for 10GBASE-KR. 5 0 RO 1 = Port 2 EEE is supported for 10GBASE--KX4. 0 = Port 2 EEE is not supported for 10GBASE-KX4. 10GBASE-KX4 EEE 1000BASE-KX EEE 4 0 RO 3 0 RO 2 0 RO 1 = Port 2 EEE is supported for 1000BASE-KX. 0 = Port 2 EEE is not supported for 1000BASE-KX. 10GBASE-T EEE 1 = Port 2 EEE is supported for 10GBASE-T. 0 = Port 2 EEE is not supported for 10GBASE-T. 1000BASE-T EEE 1 = Port 2 EEE is supported for 1000BASE-T. 0 = Port 2 EEE is not supported for 1000BASE-T. 100BASE-TX EEE 1 1 RW 0 0 RO 1 = Port 2 EEE is supported for 100BASE-TX. 0 = Port 2 EEE is not supported for 100BASE-TX. To disable EEE capability, clear the Port 2 Next Page Enable bit in the PCSEEEC register (0x0F3). Reserved Port 2 EEE Wake Error Count Register (0x0EE - 0x0EF): P2EEEWEC This register contains the Port 2 EEE wake error count information. Bit Default Value R/W Description Port 2 EEE Wake Error Count 15−0 0x0000 August 31, 2015 RW This counter is incremented by each transition of lpi_wake_timer_done from FALSE to TRUE. It means the wake-up time is longer than 20.5µs. The value will be held at all ones in the case of overflow and will be cleared to zero after this register is read. 139 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 EEE Control/Status and Auto-Negotiation Expansion Register (0x0F0 - 0x0F1): P2EEECS This register contains the Port 2 EEE control/status and auto-negotiation expansion information. Bit Default R/W Description 15 1 RW Reserved 14 0 RO Hardware 100BT EEE Enable Status 1 = 100BT EEE is enabled by hardware based NP exchange. 0 = 100BT EEE is disabled. TX LPI Received 13 0 RO/LH (Latching High) 1 = Indicates that the transmit PCS has received low power idle (LPI) signaling one or more times since the register was last read. 0 = Indicates that the PCS has not received low power idle (LPI) signaling. The status will be latched high and stay that way until cleared. To clear this status bit, a “1” needs to be written to this register bit. TX LPI Indication 12 0 RO 1 = Indicates that the transmit PCS is currently receiving low power idle (LPI) signals. 0 = Indicates that the PCS is not currently receiving low power idle (LPI) signals. This bit will dynamically indicate the presence of the TX LPI signal. RX LPI Received 11 0 RO/LH (Latching High) 1 = Indicates that the receive PCS has received low power idle (LPI) signaling one or more times since the register was last read. 0 = Indicates that the PCS has not received low power idle (LPI) signaling. The status will be latched high and stay that way until cleared. To clear this status bit, a “1” needs to be written to this register bit. RX LPI Indication 10 0 RO 9–8 00 RW August 31, 2015 1 = Indicates that the receive PCS is currently receiving low power idle (LPI) signals. 0 = Indicates that the PCS is not currently receiving low power idle (LPI) signals. This bit will dynamically indicate the presence of the RX LPI signal. Reserved 140 Revision 1.1 Micrel, Inc. KSZ8852HLE Port 2 EEE Control/Status and Auto-Negotiation Expansion Register (0x0F0 - 0x0F1): P2EEECS (Continued) Bit Default R/W Description 7 0 RO Reserved Received Next Page Location Able 6 1 RO 5 1 RO 1 = Received next page storage location is specified by bits [6:5]. 0 = Received next page storage location is not specified by bits [6:5]. Received Next Page Storage Location 1 = Link partner next pages are stored in P2ALPRNP (Reg. 0x0EA - 0x0EB). 0 = Link partner next pages are stored in P2ANLPR (Reg. 0x062 - 0x063). Parallel Detection Fault 4 0 RO/LH (Latching High) 1 = A fault has been detected via the parallel detection function. 0 = A fault has not been detected via the parallel detection function. This bit is cleared after read. Link Partner Next Page Able 3 0 RO 2 1 RO 1 0 RO/LH (Latching High) 1 = Link partner is next page abled. 0 = Link partner is not next page abled. Next Page Able 1 = Local device is next page abled. 0 = Local device is not next page abled. Page Received 1 = A new page has been received. 0 = A new page has not been received. Link Partner Auto-Negotiation Able 0 0 RO 1 = Link partner is auto-negotiation abled. 0 = Link partner is not auto-negotiation abled. Port 2 LPI Recovery Time Counter Register (0x0F2): P2LPIRTC This register contains the Port 2 LPI recovery time counter information. Bit Default Value R/W Description Port 2 LPI Recovery Time Counter 7−0 0x27 (25µs) August 31, 2015 RW This register specifies the time that the MAC device has to wait before it can start to send out packets. This value should be the maximum of the LPI recovery time between local device and remote device. Each count = 640ns. 141 Revision 1.1 Micrel, Inc. KSZ8852HLE PCS EEE Control Register (0x0F3): PCSEEEC This register contains the PCS EEE control information. Bit Default R/W Description 7 0 RW Reserved 6 0 RW Reserved 5−2 0x0 RO Reserved Port 2 Next Page Enable 1 1 RW 1 = Enable next page exchange during auto-negotiation. 0 = Skip next page exchange during auto-negotiation. Auto-negotiation uses next page to negotiate EEE. To disable EEE auto-negotiation on port 2, clear this bit to zero. Restarting auto-negotiation may then be required. Port 1 Next Page Enable 0 1 RW 1 = Enable next page exchange during auto-negotiation. 0 = Skip next page exchange during auto-negotiation. Auto-negotiation uses next page to negotiate EEE. To disable EEE auto-negotiation on port 1, clear this bit to zero. Restarting auto-negotiation may then be required. Empty TXQ to LPI Wait Time Control Register (0x0F4 - 0x0F5): ETLWTC This register contains the empty TXQ to LPI wait time control information. Bit Default Value R/W Description Empty TXQ to LPI Wait Time Control 15−0 0x03E8 RW This register specifies the time that the LPI request will be generated after a TXQ has been empty exceeds this configured time. This is only valid when EEE 100BT is enabled. This setting will apply to all the three ports. The unit is 1.3ms. The default value is 1.3 sec. (in a range from 1.3ms to 86 seconds) Buffer Load to LPI Control 2 Register (0x0F6 - 0x0F7): BL2LPIC2 This register contains the buffer load to LPI control 2 information. Bit Default Value R/W Description 15−8 0x00 RO Reserved 7−0 0x40 RW Buffer Load Threshold for All Ports LPI Termination This value defines the maximum buffer usage allowed for a single port before it starts to trigger the LPI termination for every port. (128 bytes per unit) 0x0F8 - 0x0FF: Reserved August 31, 2015 142 Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Interrupts, BIU, and Global Reset (0x100 - 0x1FF) 0x100 - 0x107: Reserved Chip Configuration Register (0x108 - 0x109): CCR This register indicates the chip configuration mode based on strapping and bonding options. Bit Default Value R/W Description 15−11 − RO Reserved Bus Endian Mode − 10 RO The P2LED0/LEBE pin value is latched into this bit during power-up/reset. 0 = Bus in Big Endian mode 1 = Bus in Little Endian mode EEPROM Presence 9 − RO 8 0 RO The PME/EEPROM pin value is latched into this bit during power-up/reset. 0 = No external EEPROM 1 = Use external EEPROM Reserved 8-Bit Data Bus Width − 7 RO This bit value is loaded from P1LED0/H816 (pin 60) to indicate the data bus mode. 0 = Not in 8-bit bus mode operation 1 = In 8-bit bus mode operation 16-Bit Data Bus Width 6 − RO 5 0 RO This bit value is loaded from P1LED0/H816 (pin 60) to indicate the data bus mode. 0 = Not in 16-bit bus mode operation 1 = In 16-bit bus mode operation Reserved Shared Data Bus Mode for Data and Address 4 1 RO 0 = Not valid 1 = Data and address bus are shared. 3–0 0x2 RO Reserved 0x10A - 0x10F: Reserved August 31, 2015 143 Revision 1.1 Micrel, Inc. KSZ8852HLE Host MAC Address Registers: MARL, MARM and MARH These host MAC address registers are loaded starting at word location 0x1 of the EEPROM upon hardware reset. The software driver can read or write these registers values, but it will not modify the original host MAC address values in the EEPROM. These six bytes of host MAC address in external EEPROM are loaded to these three registers as mapped below: • MARL[15:0] = EEPROM 0x1(MAC Byte 2 and 1) • MARM[15:0] = EEPROM 0x2(MAC Byte 4 and 3) • MARH[15:0] = EEPROM 0x3(MAC Byte 6 and 5) The host MAC address is used to define the individual destination address that the KSZ8852 responds to when receiving frames. Network addresses are generally expressed in the form of 01:23:45:67:89:AB, where the bytes are received from left to right, and the bits within each byte are received from right to left (LSB to MSB). For example, the actual transmitted and received bits are on the order of 10000000 11000100 10100010 11100110 10010001 11010101. These three registers value for host MAC address 01:23:45:67:89:AB will be held as below: • MARL[15:0] = 0x89AB • MARM[15:0] = 0x4567 • MARH[15:0] = 0x0123 Host MAC Address Register Low (0x110 - 0x111): MARL Register bit fields for the low word of the host MAC address. Bit Default Value R/W 15−0 − RW Description MARL MAC Address Low The least significant word of the MAC Address. Host MAC Address Register Middle (0x112 - 0x113): MARM The following table shows the register bit fields for the middle word of the host MAC address. Bit Default Value R/W 15−0 − RW Description MARM MAC Address Middle The middle word of the MAC Address. Host MAC Address Register High (0x114 - 0x115): MARH The following table shows the register bit fields for the high word of the Host MAC Address. Bit Default Value R/W 15−0 − RW Description MARH MAC Address High The most significant word of the MAC Address. 0x116 - 0x121: Reserved August 31, 2015 144 Revision 1.1 Micrel, Inc. KSZ8852HLE EEPROM Control Register (0x122 - 0x123): EEPCR To support an external EEPROM, the PME/EEPROM pin should be pulled−up to high; otherwise, it should be pulled−down to low. If an external EEPROM is not used, the software should program the host MAC address. If an EEPROM is used in the design, the chip host MAC address can be loaded from the EEPROM immediately after reset. The KSZ8852 allows the software to access (read or write) the EEPROM directly; that is, the EEPROM access timing can be fully controlled by the software if the EEPROM software access bit is set. Bit Default Value R/W Description 15−6 − RO Reserved. EESRWA EEPROM Software Read or Write Access 5 0 WO 4 0 RW 3 − RO 2 0 RW 1 0 RW 0 = S/W read enable to access EEPROM when software access enabled (bit[4] = “1”) 1 = S/W write enable to access EEPROM when software access enabled (bit[4] = “1”) EESA EEPROM Software Access 0 0 RW 1 = Enable software to access EEPROM through bits [3:0]. 0 = Disable software to access EEPROM. EESB EEPROM Status Bit Data Receive from EEPROM. This bit directly reads the EEDIO pin. EECB_EEPROM_WR_DATA Write Data to EEPROM. This bit directly controls the device’s EEDIO pin. EECB_EEPROM_Clock Serial EEPROM Clock. This bit directly controls the device’s EESK pin. EECB_EEPROM_CS Chip Select for the EEPROM. This bit directly controls the device’s EECS pin. Memory BIST Info Register (0x124 - 0x125): MBIR This register indicates the built-in self-test results for both TX and RX memories after power−up/reset. The device should be reset after the BIST procedure to ensure proper subsequent operation. Bit Default Value R/W Description Memory BIST Done 15 0 RO 0 = BIST In progress 1 = BIST Done 14−13 00 RO Reserved 12 − RO 11 − RO TXMBF TX Memory BIST Completed 0 = TX Memory built-in self-test has not completed. 1 = TX Memory built-in self-test has completed. TXMBFA TX Memory BIST Failed 0 = TX Memory built-in self-test has completed without failure. 1 = TX Memory built-in self-test has completed with failure. TXMBFC TX Memory BIST Fail Count 10−8 − RO 0 = TX Memory built-in self-test completed with no count failure. 1 = TX Memory built-in self-test encountered a failed count condition. 7−5 − RO Reserved August 31, 2015 145 Revision 1.1 Micrel, Inc. KSZ8852HLE Memory BIST Info Register (0x124 - 0x125): MBIR (Continued) Bit Default Value R/W Description 4 − RO RXMBF RX Memory BIST Completed 0 = Completion has not occurred for the Memory built-in self-test 1 = Indicates completion of the RX Memory built-in self-test. 3 − RO RXMBFA RX Memory BIST Failed 0 = No failure with the RX Memory built-in self-test. 1 = Indicates the RX Memory built-in self-test has failed. 2−0 − RO RXMBFC RX Memory BIST Test Fail Count 0 = No count failure for the RX Memory BIST 1 = Indicates the RX Memory built-in self-test failed count. Global Reset Register (0x126 - 0x127): GRR This register controls the global functions with information programmed by the CPU. Bit Default Value R/W Description 15−4 0x000 RW Reserved 3 0 RW 1 = Setting this bit will start the Memory BIST. 0 = Setting this bit will stop the Memory BIST. 2 0 RW Reserved Memory BIST Start QMU Module Soft Reset 1 0 RW 1 = Software reset is active to clear both the TXQ and RXQ memories. 0 = QMU reset is inactive. QMU software reset will flush out all TX/RX packet data inside the TXQ and RXQ memories and reset all the QMU registers to their default value. Global Soft Reset 0 0 RW 1 = Software reset is active. 0 = Software reset is inactive. Global software reset will reset all registers to their default value. The strap-in values are not affected. This bit is not self-clearing. After writing a “1” to this bit, wait for 10ms to elapse then write a “0” for normal operation. 0x128 - 0x129: Reserved August 31, 2015 146 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame Control Register (0x12A - 0x12B): WFCR This register holds control information programmed by the CPU to control the Wake-Up frame function. Bit Default Value R/W Description 15−8 0x00 RO Reserved MPRXE 7 0 RW 6−4 000 RO Magic Packet RX Enable When set, it enables the Magic Packet pattern detection. When reset, the Magic Packet pattern detection is disabled. Reserved WF3E 3 0 RW Wake-Up Frame 3 Enable When set, it enables the Wake-Up frame 3 pattern detection. When reset, the Wake-Up frame 3 pattern detection is disabled. WF2E 2 0 RW Wake-Up Frame 2 Enable When set, it enables the Wake-Up frame 2 pattern detection. When reset, the Wake-Up frame 2 pattern detection is disabled. WF1E 1 0 RW Wake-Up Frame 1 Enable When set, it enables the Wake-Up frame 1 pattern detection. When reset, the Wake-Up frame 1 pattern detection is disabled. WF0E 0 0 RW Wake-Up Frame 0 Enable When set, it enables the Wake-Up frame 0 pattern detection. When reset, the Wake-Up frame 0 pattern detection is disabled. 0x12C - 0x12F: Reserved Wake-Up Frame 0 CRC0 Register (0x130 - 0x131): WF0CRC0 This register contains the expected CRC values of the Wake-Up frame 0 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard; it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W Description WF0CRC0 15−0 0x0000 August 31, 2015 RW Wake-Up Frame 0 CRC (lower 16 bits) The expected CRC value of a Wake-Up frame 0 pattern. 147 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 0 CRC1 Register (0x132- 0x133): WF0CRC1 This register contains the expected CRC values of the Wake-Up frame 0 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard; it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF0CRC1 Wake-Up Frame 0 CRC (upper 16 bits). The expected CRC value of a Wake-Up frame 0 pattern. Wake-Up Frame 0 Byte Mask 0 Register (0x134 - 0x135): WF0BM0 This register contains the first 16 bytes mask values of the Wake-Up frame 0 pattern. Setting bit [0] selects the first byte of the Wake-Up frame 0. Setting bit [15] selects the 16th byte of the Wake-Up frame 0. Bit Default Value R/W 15−0 0x0000 RW Description WF0BM0 Wake-up frame 0 Byte Mask 0 The first 16 byte mask of a Wake-Up frame 0 pattern. Wake-Up Frame 0 Byte Mask 1 Register (0x136 - 0x137): WF0BM1 This register contains the next 16 bytes mask values of the Wake-Up frame 0 pattern. Setting bit [0] selects the 17th byte of the Wake-Up frame 0. Setting bit [15] selects the 32nd byte of the Wake-Up frame 0. Bit Default Value R/W 15−0 0x0000 RW Description WF0BM1 Wake-up frame 0 Byte Mask 1. The next 16 byte mask covering bytes 17 to 32 of a wake-up frame 0 pattern. Wake-Up Frame 0 Byte Mask 2 Register (0x138 - 0x139): WF0BM2 This register contains the next 16 bytes mask values of the Wake-Up frame 0 pattern. Setting bit [0] selects the 33rd byte of the Wake-Up frame 0. Setting bit [15] selects the 48th byte of the Wake-Up frame 0. Bit Default Value R/W 15−0 0x0000 RW Description WF0BM2 Wake-up frame 0 Byte Mask 2. The next 16 byte mask covering bytes 33 to 48 of a wake-up frame 0 pattern. Wake-Up Frame 0 Byte Mask 3 Register (0x13A - 0x13B): WF0BM3 This register contains the last 16 bytes mask values of the Wake-Up frame 0 pattern. Setting bit [0] selects the 49th byte of the Wake-Up frame 0. Setting bit [15] selects the 64th byte of the Wake-Up frame 0. Bit Default Value R/W 15−0 0x0000 RW Description WF0BM3 Wake-up frame 0 Byte Mask 3. The last 16 byte mask covering bytes 49 to 64 of a wake-up frame 0 pattern. 0x13C – 0x13F: Reserved August 31, 2015 148 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 1 CRC0 Register (0x140 – 0x141): WF1CRC0 This register contains the expected CRC values of the Wake-Up frame 1 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard; it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF1CRC0 Wake−Up frame 1 CRC (lower 16 bits). The expected CRC values of a Wake−Up frame 1 pattern. Wake-Up Frame 1 CRC1 Register (0x142 – 0x143): WF1CRC1 This register contains the expected CRC values of the Wake-Up frame 1 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard, it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W Description WF1CRC1 15−0 0x0000 RW Wake−up frame 1 CRC (upper 16 bits). The expected CRC value of a Wake−Up frame 1 pattern. Wake-Up Frame 1 Byte Mask 0 Register (0x144 – 0x145): WF1BM0 This register contains the first 16 bytes mask values of the Wake-Up frame 1 pattern. Setting bit [0] selects the first byte of the Wake-Up frame 1, setting bit [15] selects the 16th byte of the Wake-Up frame 1. Bit Default Value R/W Description WF1BM0 15−0 0x0000 RW Wake−Up frame 1 Byte Mask 0. The first 16 byte mask of a Wake−Up frame 1 pattern. Wake-Up Frame 1 Byte Mask 1 Register (0x146 – 0x147): WF1BM1 This register contains the next 16 bytes mask values of the Wake-Up frame 1 pattern. Setting bit [0] selects the 17th byte of the Wake-Up frame 1. Setting bit [15] selects the 32nd byte of the Wake-Up frame 1. Bit Default Value R/W Description WF1BM1 15−0 0x0000 August 31, 2015 RW Wake-Up frame 1 Byte Mask 1. The next 16 byte mask covering bytes 17 to 32 of a Wake−Up frame 1 pattern. 149 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 1 Byte Mask 2 Register (0x148 – 0x149): WF1BM2 This register contains the next 16 bytes mask values of the Wake-Up frame 1 pattern. Setting bit [0] selects the 33rd byte of the Wake-Up frame 1. Setting bit [15] selects the 48th byte of the Wake-Up frame 1. Bit Default Value R/W 15−0 0x0000 RW Description WF1BM2 Wake−Up frame 1 Byte Mask 2. The next 16 bytes mask covering bytes 33 to 48 of a Wake−Up frame 1 pattern. Wake-Up Frame 1 Byte Mask 3 Register (0x14A – 0x14B): WF1BM3 This register contains the last 16 bytes mask values of the Wake-Up frame 1 pattern. Setting bit 0 selects the 49th byte of the Wake-Up frame 1. Setting bit 15 selects the 64th byte of the Wake-Up frame 1. Bit Default Value R/W 15−0 0x0000 RW Description WF1BM3 Wake−Up Frame 1 Byte Mask 3. The last 16 bytes mask covering bytes 49 to 64 of a Wake−Up frame 1 pattern. 0x14C – 0x14F: Reserved Wake-Up Frame 2 CRC0 Register (0x150 – 0x151): WF2CRC0 This register contains the expected CRC values of the Wake-Up frame 2 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard, it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF2CRC0 Wake−Up frame 2 CRC (lower 16 bits). The expected CRC value of a Wake−Up frame 2 pattern. Wake-Up Frame 2 CRC1 Register (0x152 – 0x153): WF2CRC1 This register contains the expected CRC values of the wake−up frame 2 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard, it is taken over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF2CRC1 Wake-Up frame 2 CRC (upper 16 bits). The expected CRC value of a Wake−Up frame 2 pattern. Wake-Up Frame 2 Byte Mask 0 Register (0x154 – 0x155): WF2BM0 This register contains the first 16 bytes mask values of the Wake-Up frame 2 pattern. Setting bit [0] selects the first byte of the Wake-Up frame 2. Setting bit [15] selects the 16th byte of the Wake-Up frame 2. Bit Default Value R/W 15−0 0x0000 RW August 31, 2015 Description WF2BM0 Wake-Up frame 2 Byte Mask 0. The first 16 byte mask of a Wake−up frame 2 pattern. 150 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 2 Byte Mask 1 Register (0x156 – 0x157): WF2BM1 This register contains the next 16 bytes mask values of the Wake-Up frame 2 pattern. Setting bit [0] selects the 17th byte of the Wake-Up frame 2. Setting bit [15] selects the 32nd byte of the Wake-Up frame 2. Bit Default Value R/W 15−0 0x0000 RW Description WF2BM1 Wake−Up frame 2 Byte Mask 1. The next 16 byte mask covering bytes 17 to 32 of a Wake−Up frame 2 pattern. Wake-Up Frame 2 Byte Mask 2 Register (0x158 – 0x159): WF2BM2 This register contains the next 16 bytes mask values of the Wake-Up frame 2 pattern. Setting bit [0] selects the 33rd byte of the Wake-Up frame 2. Setting bit [15] selects the 48th byte of the Wake-Up frame 2. Bit Default Value R/W 15−0 0x0000 RW Description WF2BM2 Wake−Up frame 2 Byte Mask 2. The next 16 byte mask covering bytes 33 to 48 of a Wake−Up frame 2 pattern. Wake-Up Frame 2 Byte Mask 3 Register (0x15A – 0x15B): WF2BM3 This register contains the last 16 bytes mask values of the Wake-Up frame 2 pattern. Setting bit [0] selects the 49th byte of the Wake-Up frame 2. Setting bit [15] selects the 64th byte of the Wake-Up frame 2. Bit Default Value R/W 15−0 0x0000 RW Description WF2BM3 Wake−Up frame 2 Byte Mask 3. The last 16 byte mask covering bytes 49 to 64 of a Wake−Up frame 2 pattern. 0x15C – 0x15F: Reserved August 31, 2015 151 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 3 CRC0 Register (0x160 – 0x161): WF3CRC0 This register contains the expected CRC values of the Wake-Up frame 3 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard. The CRC value takes over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF3CRC0 Wake−Up frame 3 CRC (lower 16 bits). The expected CRC value of a Wake-Up frame 3 pattern. Wake-Up Frame 3 CRC1 Register (0x162 – 0x163): WF3CRC1 This register contains the expected CRC values of the Wake-Up frame 3 pattern. The value of the CRC calculated is based on the IEEE 802.3 Ethernet standard. The CRC value takes over the bytes specified in the Wake-Up byte mask registers. Bit Default Value R/W 15−0 0x0000 RW Description WF3CRC1 Wake−Up frame 3 CRC (upper 16 bits). The expected CRC value of a Wake-Up frame 3 pattern. Wake-Up Frame 3 Byte Mask 0 Register (0x164 – 0x165): WF3BM0 This register contains the first 16 bytes mask values of the Wake-Up frame 3 pattern. Setting bit [0] selects the first byte of the Wake-Up frame 3, setting bit [15] selects the 16th byte of the Wake-Up frame 3. Bit Default Value R/W 15−0 0x0000 RW Description WF3BM0 Wake-Up Frame 3 Byte Mask 0. The first 16 byte mask of a Wake-Up frame 3 pattern. Wake-Up Frame 3 Byte Mask 1 Register (0x166 – 0x167): WF3BM1 This register contains the next 16 bytes mask values of the Wake-Up frame 3 pattern. Setting bit [0] selects the 17th byte of the Wake-Up frame 3. Setting bit [15] selects the 32nd byte of the Wake-Up frame 3. Bit Default Value R/W 15−0 0x0000 RW Description WF3BM1 Wake-Up Frame 3 Byte Mask 1. The next 16 byte mask covering bytes 17 to 32 of a Wake-Up frame 3 pattern. Wake-Up Frame 3 Byte Mask 2 Register (0x168 – 0x169): WF3BM2 This register contains the next 16 bytes mask values of the Wake-Up frame 3 pattern. Setting bit [0] selects the 33rd byte of the Wake-Up frame 3. Setting bit [15] selects the 48th byte of the Wake-Up frame 3. Bit Default Value R/W 15−0 0x0000 RW Description WF3BM2 August 31, 2015 Wake-Up Frame 3 Byte Mask 2. The next 16 byte mask covering bytes 33 to 48 of a Wake-Up frame 3 pattern. 152 Revision 1.1 Micrel, Inc. KSZ8852HLE Wake-Up Frame 3 Byte Mask 3 Register (0x16A - 0x16B): WF3BM3 This register contains the last 16 bytes mask values of the Wake-Up frame 3 pattern. Setting bit [0] selects the 49th byte of the Wake-Up frame 3. Setting bit [15] selects the 64th byte of the Wake-Up frame 3. Bit Default Value R/W 15−0 0x0000 RW Description WF3BM3 Wake-Up Frame 3 Byte Mask 3. The last 16 byte mask covering bytes 49 to 64 of a Wake-Up frame 3 pattern. 0x16C – 0x16F: Reserved August 31, 2015 153 Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for the Queue Management Unit (QMU) (0x170 - 0x1FF) Transmit Control Register (0x170 - 0x171): TXCR This register holds control information programmed by the CPU to control the QMU transmit module function. Bit Default Value R/W Description 15−9 − RO Reserved. 8 0 RW When this bit is set, the device hardware is enabled to generate an ICMP frame checksum in a non-fragmented ICMP frame. 7 0 RW When this bit is set, the device hardware is enabled to generate a UPD frame checksum in a non-fragmented UDP frame. 6 0 RW 5 0 RW 4 0 RW TCGICMP Transmit Checksum Generation for ICMP TCGUDP Transmit Checksum Generation for UDP TCGTCP Transmit Checksum Generation for TCP When this bit is set, the device hardware is enabled to generate a TCP frame checksum in a non-fragmented TCP frame. TCGIP Transmit Checksum Generation for IP When this bit is set, the device hardware is enabled to generate an IP header checksum in a non-fragmented IP frame. FTXQ Flush Transmit Queue When this bit is set, the transmit queue memory is cleared and TX frame pointer is reset. Note: Disable the TXE transmit enable bit[0] first before setting this bit, then clear this bit to normal operation. TXFCE Transmit Flow Control Enable 3 0 RW When this bit is set and the device is in full-duplex mode, flow control is enabled. The device transmits a PAUSE frame when the receive buffer capacity reaches a threshold level that will cause the buffer to overflow. When this bit is set and the device is in half-duplex mode, back-pressure flow control is enabled. When this bit is cleared, no transmit flow control is enabled. TXPE Transmit Padding Enable 2 0 RW When this bit is set, the device automatically adds a padding field to a packet shorter than 64 bytes. Note: Setting this bit requires enabling the add CRC feature (bit[1] = “1”) to avoid CRC errors for the transmit packet. TXCE Transmit CRC Enable 1 0 RW When this bit is set, the device automatically adds a 32−bit CRC checksum field to the end of a transmit frame. TXE Transmit Enable 0 0 August 31, 2015 RW When this bit is set, the transmit module is enabled and placed in a running state. When reset, the transmit process is placed in the stopped state after the transmission of the current frame is completed. 154 Revision 1.1 Micrel, Inc. KSZ8852HLE Transmit Status Register (0x172 - 0x173): TXSR This register keeps the status of the last transmitted frame in the QMU transmit module. Bit Default Value R/W Description 15−14 00 RO Reserved 13 0 RO 12 0 RO 11−6 − RO 5−0 − RO TXLC Transmit Late Collision This bit is set when a transmit late collision occurs. TXMC Transmit Maximum Collision This bit is set when a transmit maximum collision is reached. Reserved TXFID Transmit Frame ID This field identifies the transmitted frame. All of the transmit status information in this register belongs to the frame with this ID. Receive Control Register 1 (0x174 - 0x175): RXCR1 This register holds control information programmed by the host to control the receive function in the QMU module. Bit Default Value R/W Description FRXQ Flush Receive Queue 15 0 RW 14 0 RW 13 0 RW 12 0 RW 11 1 RW When this bit is set, The receive queue memory is cleared and RX frame pointer is reset. Note: Disable the RXE receive enable bit[0] first before setting this bit, then clear this bit for normal operation. RXUDPFCC Receive UDP Frame Checksum Check Enable While this bit is set, if any received UDP frame has an incorrect UDP checksum, the frame will be discarded. RXTCPFCC Receive TCP Frame Checksum Check Enable While this bit is set, if any received TCP frame has an incorrect TCP checksum, the frame will be discarded. RXIPFCC Receive IP Frame Checksum Check Enable While this bit is set, if any received IP frame has an incorrect IP checksum, the frame will be discarded. RXPAFMA Receive Physical Address Filtering with MAC Address Enable This bit enables the RX function to receive the physical address that passes the MAC Address filtering mechanism (see MAC Address Filtering Scheme in Table 2 for details). RXFCE Receive Flow Control Enable 10 0 RW 9 0 RW 8 0 RW When this bit is set and the device is in full−duplex mode, flow control is enabled, and the device will acknowledge a PAUSE frame from the receive interface; i.e., the outgoing packets are pending in the transmit buffer until the PAUSE frame control timer expires. This field has no meaning in half−duplex mode and should be programmed to “0”. When this bit is cleared, flow control is not enabled. RXEFE Receive Error Frame Enable When this bit is set, frames with CRC error are allowed to be received into the RX queue. When this bit is cleared, all CRC error frames are discarded. RXMAFMA Receive Multicast Address Filtering with MAC Address Enable August 31, 2015 When this bit is set, this bit enables the RX function to receive multicast address that pass the MAC Address filtering mechanism (see MAC Address Filtering Scheme in Table 2 details). 155 Revision 1.1 Micrel, Inc. KSZ8852HLE Receive Control Register 1 (0x174 - 0x175): RXCR1 (Continued) Bit Default Value R/W Description 7 0 RW 6 0 RW 5 0 RW 4 0 RW When this bit is set, the device is enabled to receive all incoming frames, regardless of the frame’s destination address (see MAC Address Filtering Scheme in Table 2 for details). 3–2 00 RW Reserved 1 0 RW RXBE Receive Broadcast Enable When this bit is set, the RX module is enabled to receive all the broadcast frames. RXME Receive Multicast Enable When this bit is set, the RX module is enabled to receive all the multicast frames (including broadcast frames). RXUE Receive Unicast Enable When this bit is set, the RX module is enabled to receive unicast frames that match the 48−bit station MAC address of the module. RXAE Receive All Enable RXINVF Receive Inverse Filtering When this bit is set, the device receives function with address check operation in inverse filtering mode (see MAC Address Filtering Scheme in Table 2 for details). RXE Receive Enable 0 0 RW When this bit is set, the RX block is enabled and placed in a running state. When this bit is cleared, the receive process is placed in the stopped state upon completing reception of the current frame. Receive Control Register 2 (0x176 - 0x177): RXCR2 This register holds control information programmed by the host to control the receive function in the QMU module. Bit Default Value R/W Description 15−9 − RO Reserved EQFCPT Enable QMU Flow Control Pause Timer 8 1 RW 7−5 000 RO While this bit is set, another pause frame will be sent out if the pause timer is expired and RXQ (12KB) is still above the low water mark. The pause timer will reset itself when it expires and RXQ is still above the low water mark and it will be disabled or stop counting when RXQ is below the low water mark. The pause frame is sent out before RXQ is above the high water mark. Reserved IUFFP IPV4/IPV6/UDP Fragment Frame Pass 4 1 RW 3 0 RW While this bit is set, the device will pass the frame without checking the UDP checksum at the received side for IPV6 UDP frames with a fragmented extension header. Operating with this bit cleared is not a valid mode since the hardware cannot calculate a correct UDP checksum without all of the IP fragments. Reserved UDPLFE UDP Lite Frame Enable 2 1 August 31, 2015 RW While this bit is set, the KSZ8852 will check the checksum at receive side and generate the checksum at transmit side for UDP lite frame. While this bit is cleared, the KSZ8852 will pass the checksum check at receive side and skip the checksum generation at transmit side for UDP lite frame. 156 Revision 1.1 Micrel, Inc. KSZ8852HLE Receive Control Register 2 (0x176 - 0x177): RXCR2 (Continued) Bit Default Value R/W Description RXICMPFCC Receive ICMP Frame Checksum Check Enable 1 0 RW 0 0 RW While this bit is set, any received ICMP frame (only a non−fragmented frame) with an incorrect checksum will be discarded. If this bit is not set, the frame will not be discarded even though there is an ICMP checksum error. RXSAF Receive Source Address Filtering While this bit is set, the device will drop the frame if the source address is the same as the MAC Address in the MARL, MARM, MARH registers. TXQ Memory Information Register (0x178 - 0x179): TXMIR This register indicates the amount of free memory available in the TXQ of the QMU module. Bit Default Value R/W Description 15−13 − RO Reserved. TXMA Transmit Memory Available 12−0 0x1800 RO The amount of memory available is represented in units of byte. The TXQ memory is used for both frame payload, control word. Note: Software must be written to ensure that there is enough memory for the next transmit frame including control information before transmit data is written to the TXQ. 0x17A - 0x17B: Reserved Receive Frame Header Status Register (0x17C - 0x17D): RXFHSR This register indicates the received frame header status information. The received frames are reported in the RXFC register. This register contains the status information for the frame received, and the host processor can read as many times as the frame count value in the RXFC register. Bit Default Value R/W Description RXFV Receive Frame Valid 15 − RO 14 − RO 13 − RO 12 − RO 11 − RO 10 − RO 9−8 − RO August 31, 2015 This bit is set if the present frame in the receive packet memory is valid. The status information currently in this location is also valid. When clear, it indicates that there is either no pending receive frame or that the current frame is still in the process of receiving. Reserved RXICMPFCS Receive ICMP Frame Checksum Status When this bit is set, the KSZ8852 received ICMP frame checksum is incorrect. RXIPFCS Receive IP Frame Checksum Status When this bit is set, the KSZ8852 received IP header checksum is incorrect. RXTCPFCS Receive TCP Frame Checksum Status When this bit is set, the KSZ8852 received TCP frame checksum is incorrect. RXUDPFCS Receive UDP Frame Checksum Status When this bit is set, the KSZ8852 received UDP frame checksum is incorrect. Reserved 157 Revision 1.1 Micrel, Inc. KSZ8852HLE Receive Frame Header Status Register (0x17C - 0x17D): RXFHSR (Continued) Bit Default Value R/W 7 − RO 6 − RO 5 − RO 4 − RO Description RXBF Receive Broadcast Frame When this bit is set, it indicates that this frame has a broadcast address. RXMF Receive Multicast Frame When this bit is set, it indicates that this frame has a multicast address (including the broadcast address). RXUF Receive Unicast Frame When this bit is set, it indicates that this frame has a unicast address. Reserved RXFT Receive Frame Type 3 − RO 2 − RO When this bit is set, it indicates that the frame is an Ethernet−type frame (frame length is greater than 1500 bytes). When clear, it indicates that the frame is an IEEE 802.3 frame. This bit is not valid for “runt” frames. Reserved RXRF Receive Runt Frame 1 − RO When this bit is set, it indicates that a frame was damaged by a collision or had a premature termination before the collision window passed. “Runt” frames are passed to the host only if the Pass Bad Frame bit is set. RXCE Receive CRC Error 0 − RO When this bit is set, it indicates that a CRC error has occurred on the current received frame. CRC error frames are passed to the host only if the Pass Bad Frame bit is set. Receive Frame Header Byte Count Register (0x17E - 0x17F): RXFHBCR This register indicates the received frame header byte count information. The received frames are reported in the RXFC register. This register contains the total number of bytes information for the frame received, and the host processor can read as many times as the frame count value in the RXFC register. Bit Default Value R/W Description 15−12 − RO Reserved RXBC Receive Byte Count 11−0 August 31, 2015 − RO This field indicates the present received frame byte size. Note: Always read low byte first for 8−bit mode operation. 158 Revision 1.1 Micrel, Inc. KSZ8852HLE TXQ Command Register (0x180 - 0x181): TXQCR This register is programmed by the host CPU to issue a transmit command to the TXQ. The present transmit frame in the TXQ memory is queued for transmit. Bit Default Value R/W Description 15−3 − RW Reserved 2 0 RW Reserved TXQMAM TXQ Memory Available Monitor 1 0 RW When this bit is written as a “1”, the KSZ8852 will generate interrupt (bit [6] in the ISR register) to the CPU when TXQ memory is available based upon the total amount of TXQ space requested by CPU at TXNTFSR (0x19E) register. Note: This bit is self-clearing after the frame is finished transmitting. The software should wait for the bit to be cleared before setting to “1” again. METFE Manual Enqueue TXQ Frame Enable 0 0 RW When this bit is written as “1”, the KSZ8852 will enable the current TX frame in the TX buffer to be queued for transmit one frame at a time. Note: This bit is self-cleared after the frame transmission is complete. The software should wait for the bit to be cleared before setting up another new TX frame. RXQ Command Register (0x182 - 0x183): RXQCR This register is programmed by the host CPU to issue DMA read or write command to the RXQ and TXQ. This register also is used to control all RX thresholds enable and status. Bit Default Value R/W Description 15−13 − RW Reserved RXDTTS RX Duration Timer Threshold Status 12 − RO When this bit is set, it indicates that RX interrupt is due to the time starting at the first received frame in the RXQ buffer exceeding the threshold set in the RX Duration Timer Threshold Register (0x18C, RXDTTR). This bit will be updated when a “1” is written to bit [13] in the ISR register. RXDBCTS RX Data Byte Count Threshold Status 11 − RO When this bit is set, it indicates that the RX interrupt is due to the number of received bytes in RXQ buffer exceeding the threshold set in the RX Data Byte Count Threshold register (0x18E, RXDBCTR). This bit will be updated when a “1” is written to bit [13] in the ISR register. RXFCTS RX Frame Count Threshold Status 10 − RO When this bit is set, it indicates that the RX interrupt is due to the number of received frames in RXQ buffer exceeding the threshold set in the RX Frame Count Threshold register (0x19C, RXFCTR). This bit will be updated when a “1” is written to bit [13] in the ISR register. RXIPHTOE RX IP Header Two−Byte Offset Enable 9 0 RW When this bit is written as “1”, the device will enable the adding of two bytes before the frame header in order for the IP header inside the frame contents to be aligned with a double word boundary to speed up software operation. 8 − RW Reserved RXDTTE RX Duration Timer Threshold Enable 7 August 31, 2015 0 RW When this bit is written as “1”, the device will enable the RX interrupt (bit [13] in the ISR) when the time starts at the first received frame in the RXQ buffer if it exceeds the threshold set in the RX Duration Timer Threshold register (0x18C, RXDTTR). 159 Revision 1.1 Micrel, Inc. KSZ8852HLE RXQ Command Register (0x182 - 0x183): RXQCR (Continued) Bit Default Value R/W Description RXDBCTE RX Data Byte Count Threshold Enable 6 0 RW When this bit is written as “1”, the device will enable the RX interrupt (bit [13] in ISR) when the number of received bytes in the RXQ buffer exceeds the threshold set in the RX Data Byte Count Threshold register (0x18E, RXDBCTR). RXFCTE RX Frame Count Threshold Enable 5 0 RW When this bit is written as “1”, the device will enable the RX interrupt (bit [13] in ISR) when the number of received frames in the RXQ buffer exceeds the threshold set in the RX Frame Count Threshold register (0x19C, RXFCTR). ADRFE Auto-Dequeue RXQ Frame Enable 4 0 RW When this bit is written as “1”, the device will automatically enable RXQ frame buffer dequeue. The read pointer in the RXQ frame buffer will be automatically adjusted to the next received frame location after the current frame is completely read by the host. SDA Start DMA Access 3 0 RW 2−1 − RW When this bit is written as “1”, the device allows a DMA operation from the host CPU to access either the read RXQ frame buffer or the write TXQ frame buffer with CSN and RDN or WRN signals while the CMD pin is low. All register accesses are disabled except for access to this register during this DMA operation. This bit must be set to “0” when the DMA operation is finished in order to access the rest of the registers. Reserved RRXEF Release RX Error Frame 0 0 RW When this bit is written as “1”, the current RX error frame buffer is released. Note: This bit is self-cleared after the frame memory is released. The software should wait for the bit to be cleared before processing a new RX frame. TX Frame Data Pointer Register (0x184 - 0x185): TXFDPR The value of this register determines the address to be accessed within the TXQ frame buffer. When the auto increment is set, it will automatically increment the pointer value on write accesses to the data register. The counter is incremented by one for every byte access, by two for every word access, and by four for every double word access. Bit Default Value R/W Description 15 − RO Reserved TXFPAI TX Frame Data Pointer Auto Increment 14 0 RW 13−11 − RO 1: When this bit is set, the TX Frame Data Pointer register increments automatically on accesses to the data register. The increment is by one for every byte access, by two for every word access, and by four for every double word access. 0: When this bit is reset, the TX Frame Data Pointer is manually controlled by the user to access the TX frame location. Reserved TXFP TX Frame Data Pointer 10−0 0x000 August 31, 2015 RO TX frame pointer index to the Frame Data register for access. This field is reset to the next available TX frame location when the TX frame data has been enqueued through the TXQ command register. 160 Revision 1.1 Micrel, Inc. KSZ8852HLE RX Frame Data Pointer Register (0x186 - 0x187): RXFDPR Bits [10:0] of this register determine the address to be accessed within the RXQ frame buffer. When the auto increment function is set, it will automatically increment the RXQ Pointer on read accesses to the data register. The counter is incremented is by one for every byte access, by two for every word access, and by four for every double word access. Bit Default Value R/W Description 15 − RO Reserved RXFPAI RX Frame Pointer Auto Increment 14 0 RW 13 − RO 1 = When this bit is set, the RXQ Address register increments automatically on accesses to the data register. The increment is by one for every byte access, by two for every word access, and by four for every double word access. 0 = When this bit is reset, the RX frame data pointer is manually controlled by user to access the RX frame location. Reserved WST Write Sample Time 12 1 RW This bit is used to select the WRN active to write data valid time as shown in Figure 16. 0 = WRN active to write data valid sample time is range of 8ns (minimum) to 16ns (maximum). 1 = WRN active to write data valid sample time is 4ns (maximum). EMS Endian Mode Selection 11 − RW This bit indicates the mode of the 8/16-bit host interface – either big endian or little endian. The mode is determined at reset or power up by the strap-in function on pin 62, and should not be changed when writing to this register. 0 = Set to little endian mode 1 = Set to big endian mode RXFP RX Frame Pointer 10−0 0x000 WO RX Frame data pointer index to the data register for access. This pointer value must reset to 0x000 before each DMA operation from the host CPU to read RXQ frame buffer. 0x188 - 0x18B: Reserved RX Duration Timer Threshold Register (0x18C - 0x18D): RXDTTR This register is used to program the received frame duration timer threshold. Bit Default Value R/W Description RXDTT Receive Duration Timer Threshold 15−0 0x0000 RW These bits are used to program the “received frame duration timer threshold” value in 1µs increments. The maximum value is 0xCFFF. When bit [7] is set to “1” in RXQCR register, the KSZ8852 will set the RX interrupt (bit [13] in ISR) after the timer starts at the first received frame in the RXQ buffer and when it exceeds the threshold set in this register. RX Data Byte Count Threshold Register (0x18E - 0x18F): RXDBCTR This register is used to program the received data byte count threshold. Bit Default Value R/W Description RXDBCT Receive Data Byte Count Threshold 15−0 0x0000 August 31, 2015 RW These bits are used to program the “received data byte threshold” value in byte count. When bit [6] is set to “1” in RXQCR register, the KSZ8852 will set the RX interrupt (bit [13] in ISR) when the number of received bytes in the RXQ buffer exceeds the threshold set in this register. 161 Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for Interrupt Registers (0x190 - 0x193) Interrupt Enable Register (0x190 - 0x191): IER This register enables the interrupts from the QMU and other sources. Bit Default Value R/W Description 15 0 RW 1 = When this bit is set, the link change interrupt is enabled. 0 = When this bit is reset, the link change interrupt is disabled. 14 0 RW 1 = When this bit is set, the transmit interrupt is enabled. 0 = When this bit is reset, the transmit interrupt is disabled. LCIE Link Change Interrupt Enable TXIE Transmit Interrupt Enable RXIE Receive Interrupt Enable 13 0 RW 1 = When this bit is set, the receive interrupt is enabled. 0 = When this bit is reset, the receive interrupt is disabled. 12 0 RW Reserved 11 0 RW 1 = When this bit is set, the receive overrun interrupt is enabled. 0 = When this bit is reset, the receive overrun interrupt is disabled. 10 0 RW Reserved 9 0 RW 1 = When this bit is set, the transmit process stopped interrupt is enabled. 0 = When this bit is reset, the transmit process stopped interrupt is disabled. RXOIE Receive Overrun Interrupt Enable TXPSIE Transmit Process Stopped Interrupt Enable RXPSIE Receive Process Stopped Interrupt Enable 8 0 RW 1 = When this bit is set, the receive process stopped interrupt is enabled. 0 = When this bit is reset, the receive process stopped interrupt is disabled. 7 0 RW Reserved 6 0 RW TXSAIE Transmit Space Available Interrupt Enable 1 = When this bit is set, the transmit memory space available interrupt is enabled. 0 = When this bit is reset, the transmit memory space available interrupt is disabled. RXWFDIE Receive Wake-Up Frame Detect Interrupt Enable 5 0 August 31, 2015 RW 1 = When this bit is set, the receive Wake-Up frame detect interrupt is enabled. 0 = When this bit is reset, the receive Wake-Up frame detect interrupt is disabled. 162 Revision 1.1 Micrel, Inc. KSZ8852HLE Interrupt Enable Register (0x190 - 0x191): IER (Continued) Bit Default Value R/W Description RXMPDIE Receive Magic Packet Detect Interrupt Enable 4 0 RW 3 0 RW 1 = When this bit is set, the receive Magic Packet detect interrupt is enabled. 0 = When this bit is reset, the receive Magic Packet detect interrupt is disabled. LDIE Linkup Detect Interrupt Enable 1 = When this bit is set, the wake-up from Link-Up detected interrupt is enabled. 0 = When this bit is reset, the wake-up from Link-Up detected interrupt is disabled. EDIE Energy Detect Interrupt Enable 2 0 RW 1 = When this bit is set, the wake-up from energy detect interrupt is enabled. 0 = When this bit is reset, the energy detect interrupt is disabled. 1–0 00 RO Reserved Interrupt Status Register (0x192 - 0x193): ISR This register contains the status bits for all interrupt sources. When the corresponding enable bit is set, it causes the interrupt pin to be asserted. This register is usually read by the host CPU and device drivers during an interrupt service routine or polling. The register bits are not cleared when read. The user has to write a “1” to clear. Bit Default Value R/W Description LCIS Link Change Interrupt Status 15 0 RO (W1C) When this bit is set, it indicates that the link status has changed from link up to link down, or link down to link up. This edge-triggered interrupt status is cleared by writing a “1” to this bit. TXIS Transmit Interrupt Status 14 0 RO (W1C) When this bit is set, it indicates that the TXQ MAC has transmitted at least a frame on the MAC interface and the QMU TXQ is ready for new frames from the host. This edge-triggered interrupt status is cleared by writing a “1” to this bit. RXIS Receive Interrupt Status When this bit is set, it indicates that the QMU RXQ has received at least a frame from the MAC interface and the frame is ready for the host CPU to process. This edge-triggered interrupt status is cleared by writing a “1” to this bit. 13 0 RO (W1C) 12 0 RO (W1C) 11 0 RO (W1C) When this bit is set, it indicates that the receive overrun status has occurred. This edge-triggered interrupt status is cleared by writing a “1” to this bit. 10 0 RO (W1C) Reserved Reserved RXOIS Receive Overrun Interrupt Status August 31, 2015 163 Revision 1.1 Micrel, Inc. KSZ8852HLE Interrupt Status Register (0x192 - 0x193): ISR (Continued) Bit Default Value R/W Description TXPSIS Transmit Process Stopped Interrupt Status 9 0 RO (W1C) When this bit is set, it indicates that the transmit process has stopped. This edge-triggered interrupt status is cleared by writing a “1” to this bit. 8 0 RO (W1C) When this bit is set, it indicates that the receive process has stopped. This edge-triggered interrupt status is cleared by writing a “1” to this bit. 7 0 RO 6 0 RO (W1C) 5 0 RO 4 0 RO 3 0 RO RXPSIS Receive Process Stopped Interrupt Status Reserved TXSAIS Transmit Space Available Interrupt Status When this bit is set, it indicates that transmit memory space available status has occurred. RXWFDIS Receive Wake-Up Frame Detect Interrupt Status When this bit is set, it indicates that a Wake-Up frame has been received. Write “1000” to PMCTRL[5:2] to clear this bit. RXMPDIS Receive Magic Packet Detect Interrupt Status When this bit is set, it indicates that a Magic Packet has been received. Write “0100” to PMCTRL[5:2] to clear this bit. LDIS Linkup Detect Interrupt Status When this bit is set, it indicates that wake-up from linkup detect status has occurred. Write “0010” to PMCTRL[5:2] to clear this bit. EDIS Energy Detect Interrupt Status 2 0 RO 1−0 00 RO When this bit is set and bit [2] = “1”, bit [0] = “0” in the IER register, it indicates that wake−up from energy detect status has occurred. When this bit is set and bit [2, 0] = “1” in the IER register, it indicates that wake−up from energy detect status has occurred. Write “0001” to PMCTRL[5:2] to clear this bit. Reserved 0x194 - 0x19B: Reserved August 31, 2015 164 Revision 1.1 Micrel, Inc. KSZ8852HLE Internal I/O Register Space Mapping for the Queue Management Unit (QMU) (0x19C - 0x1B9) RX Frame Count and Threshold Register (0x19C -0x19D): RXFCTR This register is used to program the received frame count threshold. Bit Default Value R/W Description 15−8 0x00 RW Reserved RXFCT Receive Frame Count Threshold 7−0 0x00 RW This register is used to program the received frame count threshold value. When bit [5] set to “1” in the RXQCR register, the device will set interrupt bit [13] in the ISR when the number of received frames in RXQ buffer exceeds the threshold set in this register. The count has to be at least equal to or greater than “1” to enable correct functioning of the hardware. A write of “1” to this register while the receive is enabled will result in erratic hardware operation. TX Next Total Frames Size Register (0x19E - 0x19F): TXNTFSR This register is used by the Host CPU to program the total amount of TXQ buffer space requested for the next transmit. Bit Default Value R/W Description TXNTFSR TX Next TXQ Buffer Frame Space Required 15−0 0x0000 RW The Host CPU programs the contents of this register to indicate the total amount of TXQ buffer space which is required for the next “one-frame” transmission. It contains the frame size in double−word count (multiples of four bytes). When bit [1] (TXQ memory available monitor) is set to “1” in the TXQCR register, the device will generate interrupt (bit [6] in the ISR register) to the CPU when TXQ memory is available based upon the total amount of TXQ space requested by the CPU in this register. MAC Address Hash Table Register 0 (0x1A0 - 0x1A1): MAHTR0 The 64-bit MAC address table is used for group address filtering and it is enabled by selecting item 5 “Hash perfect” mode in Table 2. This value is defined as the six most significant bits from CRC circuit calculation result that is based on 48-bit of DA input. The two most significant bits select one of the four registers to be used, while the others determine which bit within the register. Multicast Table Register 0 Bit Default Value R/W Description HT0 Hash Table 0 15−0 0x0000 RW When the appropriate bit is set, if the packet received with DA matches the CRC, the hashing function is received without being filtered. When the appropriate bit is cleared, the packet will be dropped. Note: When ”Receive All” (RXCR1, bit[4]) and the “Receive Multicast Addr. Filtering with the MAC Address” (RXCR1, bit [8]) bit is set, all multicast addresses are received regardless of the multicast table value. August 31, 2015 165 Revision 1.1 Micrel, Inc. KSZ8852HLE MAC Address Hash Table Register 1 (0x1A2 - 0x1A3): MAHTR1 Multicast Table Register 1 Bit Default Value R/W Description HT1 Hash Table 1 15−0 0x0000 RW When the appropriate bit is set, if the packet received with DA matches the CRC, the hashing function is received without being filtered. When the appropriate bit is cleared, the packet will be dropped. Note: When ”Receive All” (RXCR1, bit[4]) and the “Receive Multicast Addr. Filtering with the MAC Address” (RXCR1, bit [8]) bit is set, all multicast addresses are received regardless of the multicast table value. MAC Address Hash Table Register 2 (0x1A4 - 0x1A5): MAHTR2 Multicast Table Register 2 Bit Default Value R/W Description HT2 Hash Table 2 15−0 0x0000 RW When the appropriate bit is set, if the packet received with DA matches the CRC, the hashing function is received without being filtered. When the appropriate bit is cleared, the packet will be dropped. Note: When ”Receive All” (RXCR1, bit[4]) and the “Receive Multicast Addr. Filtering with the MAC Address” (RXCR1, bit [8]) bit is set, all multicast addresses are received regardless of the multicast table value. MAC Address Hash Table Register 3 (0x1A6 - 0x1A7): MAHTR3 Multicast Table Register 3 Bit Default Value R/W Description HT3 Hash Table 2 15−0 0x0000 RW When the appropriate bit is set, if the packet received with DA matches the CRC, the hashing function is received without being filtered. When the appropriate bit is cleared, the packet will be dropped. Note: When ”Receive All” (RXCR1, bit[4]) and the “Receive Multicast Addr. Filtering with the MAC Address” (RXCR1, bit [8]) bit is set, all multicast addresses are received regardless of the multicast table value. 0x1A8 - 0x1AF: Reserved Flow Control Low Water Mark Register (0x1B0 - 0x1B1): FCLWR This register is used to control the flow control for low water mark in QMU RX queue. Bit Default Value R/W Description 15−12 − RW Reserved 11−0 0x0600 RW FCLWC Flow Control Low Water Mark Configuration August 31, 2015 These bits define the QMU RX queue low water mark configuration. It is in double words count and default is 6KB available buffer space out of 12KB. 166 Revision 1.1 Micrel, Inc. KSZ8852HLE Flow Control High Water Mark Register (0x1B2 - 0x1B3): FCHWR This register is used to control the flow control for high water mark in QMU RX queue. Bit Default Value R/W Description 15−12 − RW Reserved 11−0 0x0400 RW These bits define the QMU RX queue high water mark configuration. It is in double words count and default is 4KB available buffer space out of 12KB. FCHWC Flow Control High Water Mark Configuration Flow Control Overrun Water Mark Register (0x1B4 - 0x1B5): FCOWR This register is used to control the flow control for overrun water mark in QMU RX queue. Bit Default Value R/W Description 15−12 − RW Reserved 11−0 0x0040 RW FCLWC Flow Control Overrun Water Mark Configuration These bits define the QMU RX queue overrun water mark configuration. It is in double words count and default is 256 bytes available buffer space out of 12KB. 0x1B6 - 0x1B7: Reserved August 31, 2015 167 Revision 1.1 Micrel, Inc. KSZ8852HLE RX Frame Count Register (0x1B8 - 0x1B9): RXFC This register indicates the current total amount of received frame count in RXQ frame buffer Bit Default Value R/W Description RXFC RX Frame Count 15−8 0x00 RO 7−0 0x00 RW Indicates the total received frames in RXQ frame buffer when the receive interrupt (bit [13] = “1“ in the ISR) occurred and a '1' is written to clear this bit [13] in the ISR. The host CPU can start to read the updated receive frame header information in RXFHSR/RXFHBCR registers after reading the RX frame count register Reserved 0x1BA - 0x747: Reserved Analog Control 1 Register (0x748 - 0x749): ANA_CNTRL_1 This register contains control bits for the Analog Block. Bit Default R/W Description 15−8 0x00 RW Reserved 7 0 RW LDO Off This bit is used to control the on/off state of the internal Low Voltage regulator. 0 = LDO on (default) 1 = Turn LDO off 6−0 0x00 RW Reserved 0x74A - 0x74B: Reserved Analog Control 3 Register (0x74C - 0x74D): ANA_CNTRL_3 This register contains control bits for the Analog Block. Bit Default R/W Description 15 0 RW HIPLS3 Mask ® This bit must be set prior to initiating the LinkMD function. 14 - 4 0x00 RW Reserved 3 0 RW BTRX Reduce ® This bit must be set prior to initiating the LinkMD function. 2−0 0x00 RW Reserved 0x74E - 0x7FF: Reserved August 31, 2015 168 Revision 1.1 Micrel, Inc. KSZ8852HLE Management Information Base (MIB) Counters The KSZ8852 provides 34 MIB counters for each port. These counters are used to monitor the port activity for network management. The MIB counters are formatted “per port” and “all ports dropped packet” as shown in Table 21. Table 21. Format of Per-Port MIB Counters Bit Name R/W Description Default 31 Overflow RO 1 = Counter overflow. 0 = No counter overflow. 0 30 Count valid RO 1 = Counter value is valid. 0 = Counter value is not valid. 0 29−0 Counter values RO Counter value (read clear) 0x00000000 “Per-port” MIB counters are read using indirect memory access. The base address offsets and address ranges for all three ports are: • Port 1 base address is 0x00 and range is from 0x00 to 0x1F. • Port 2 base address is 0x20 and range is from 0x20 to 0x3F. • Port 3 base address is 0x40 and range is from 0x40 to 0x5F. Per-port MIB counters are read using indirect access control in the IACR register and the indirect access data registers in IADR4[15:0], IADR5[31:16] (0x02C - 0x02F). The Port 1 MIB counters address memory offset as shown in Table 22. August 31, 2015 169 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 22. Port 1 MIB Counters - Indirect Memory Offset Offset Counter Name 0x0 RxLoPriorityByte Rx lo-priority (default) octet count including bad packets 0x1 RxHiPriorityByte Rx hi-priority octet count including bad packets 0x2 RxUndersizePkt Rx undersize packets w/ good CRC 0x3 RxFragments 0x4 RxOversize Rx oversize packets w/ good CRC (maximum: 2000 bytes) 0x5 RxJabbers Rx packets longer than 1522 bytes w/ either CRC errors, alignment errors, or symbol errors (depends on max packet size setting) 0x6 RxSymbolError 0x7 RxCRCError 0x8 RxAlignmentError 0x9 RxControl8808Pkts 0xA RxPausePkts Number of PAUSE frames received by a port. PAUSE frame is qualified with EtherType (88−08h), DA, control opcode (00−01), data length (64B min), and a valid CRC 0xB RxBroadcast Rx good broadcast packets (not including error broadcast packets or valid multicast packets) 0xC RxMulticast Rx good multicast packets (not including MAC control frames, error multicast packets or valid broadcast packets) 0xD RxUnicast 0xE Rx64Octets 0xF Rx65to127Octets Total Rx packets (bad packets included) that are between 65 and 127 octets in length 0x10 Rx128to255Octets Total Rx packets (bad packets included) that are between 128 and 255 octets in length 0x11 Rx256to511Octets Total Rx packets (bad packets included) that are between 256 and 511 octets in length 0x12 Rx512to1023Octets Total Rx packets (bad packets included) that are between 512 and 1023 octets in length 0x13 Rx1024to2000Octets Total Rx packets (bad packets included) that are between 1024 and 2000 octets in length (upper limit depends on max packet size setting) 0x14 TxLoPriorityByte Tx lo-priority good octet count, including PAUSE packets 0x15 TxHiPriorityByte Tx hi-priority good octet count, including PAUSE packets 0x16 TxLateCollision The number of times a collision is detected later than 512 bit−times into the Tx of a packet 0x17 TxPausePkts 0x18 TxBroadcastPkts Tx good broadcast packets (not including error broadcast or valid multicast packets) 0x19 TxMulticastPkts Tx good multicast packets (not including error multicast packets or valid broadcast packets) 0x1A TxUnicastPkts 0x1B TxDeferred 0x1C TxTotalCollision 0x1D TxExcessiveCollision 0x1E TxSingleCollision 0x1F TxMultipleCollision August 31, 2015 Description Rx fragment packets w/ bad CRC, symbol errors or alignment errors Rx packets w/ invalid data symbol and legal packet size. Rx packets within (64,1522) bytes w/ an integral number of bytes and a bad CRC (upper limit depends on max packet size setting) Rx packets within (64,1522) bytes w/ a non−integral number of bytes and a bad CRC (upper limit depends on max packet size setting) Number of MAC control frames received by a port with 88−08h in EtherType field Rx good unicast packets Total Rx packets (bad packets included) that were 64 octets in length Number of PAUSE frames transmitted by a port Tx good unicast packets Tx packets by a port for which the 1st Tx attempt is delayed due to the busy medium Tx total collision, half duplex only A count of frames for which Tx fails due to excessive collisions Successfully Tx frames on a port for which Tx is inhibited by exactly one collision Successfully Tx frames on a port for which Tx is inhibited by more than one collision 170 Revision 1.1 Micrel, Inc. KSZ8852HLE Table 23. "All Ports Dropped Packet" MIB Counter Format Bit Default R/W Description 30−16 − N/A Reserved 15−0 0x0000 RO Counter Value Note: “All ports dropped packet” MIB Counters do not indicate overflow or validity; therefore, the application must keep track of overflow and valid conditions.“ All ports dropped packet” MIB counters are read using indirect memory access. The address offsets for these counters are shown in Table 27. Table 24. "All Ports Dropped Packet" MIB Counters− Indirect Memory Offsets Offset Counter Name Description 0x100 Port 1 TX Drop Packets TX packets dropped due to lack of resources 0x101 Port 2 TX Drop Packets TX packets dropped due to lack of resources 0x102 Port 3 TX Drop Packets TX packets dropped due to lack of resources 0x103 Port 1 RX Drop Packets RX packets dropped due to lack of resources 0x104 Port 2 RX Drop Packets RX packets dropped due to lack of resources 0x105 Port 3 RX Drop Packets RX packets dropped due to lack of resources MIB Counter Examples: 9. MIB Counter Read (read Port 1 “Rx64Octets” counter at indirect address offset 0x0E) Write to Reg. IACR with 0x1c0e (set indirect address and trigger a read MIB counters operation) Then: Read Reg. IADR5 (MIB counter value [31:16]) // If bit [31] = 1, there was a counter overflow, // If bit [30] = 0, restart (re−read) from this register Read Reg. IADR4 (MIB counter value 15:0) 10. MIB Counter Read (read Port 2 “Rx64Octets” counter at indirect address offset 0x2E) Write to Reg. IACR with 0x1c2e (set indirect address and trigger a read MIB counters operation) Then: Read Reg. IADR5 (MIB counter value [31:16]) // If bit [31] = 1, there was a counter overflow, // If bit [30] = 0, restart (re−read) from this register Read Reg. IADR4 (MIB counter value [15:0]) 11. MIB Counter Read (read “Port 1 TX Drop Packets” counter at indirect address offset 0x100) Write to Reg. IACR with 0x1D00 (set indirect address and trigger a read MIB counters operation) Then: Read Reg. IADR4 (MIB counter value [15:0]) Additional MIB Information Per port MIB counters are designed as “read clear”. That is, these counters will be cleared after they are read. All ports dropped packet MIB counters are not cleared after they are accessed. The application needs to keep track of overflow and valid conditions on these counters. August 31, 2015 171 Revision 1.1 Micrel, Inc. KSZ8852HLE Static MAC Address Table The KSZ8852 supports both a static and a dynamic MAC address table. In response to a destination address (DA) look up, the KSZ8852 searches both tables to make a packet forwarding decision. In response to a source address (SA) look up, only the dynamic table is searched for aging, migration and learning purposes. The static DA look up result takes precedence over the dynamic DA look up result. If there is a DA match in both tables, the result from the static table is used. These entries in Table 28 will not be aged out by the KSZ8852. Table 25. Static MAC Table Format (8 Entries) Bit Default Value R/W 57−54 0000 RW 53 0 R/W Description FID Filter VLAN ID − identifies one of the 16 active VLANs. Use FID 1 = Specifies the use of FID+MAC for static table look up. 0 = Specifies only the use of MAC for static table look up. Override 52 0 R/W 1 = Overrides the port setting transmit enable = “0” or receive enable = “0” setting. 0 = Specifies no override. Note: The Override bit also allows usage (turns on the entry) even if the Valid bit = “0”. Valid 51 0 R/W 1 = Specifies that this entry is valid, and the look up result will be used. 0 = Specifies that this entry is not valid. Forwarding Ports 50−48 000 R/W 47−0 0 R/W August 31, 2015 These 3 bits control the forwarding port(s): 000 = No forward. 001 = Forward to Port 1. 010 = Forward to Port 2. 100 = Forward to Port 3. 011 = Forward to Port 1 and Port 2. 110 = Forward to Port 2 and Port 3. 101 = Forward to Port 1 and Port 3. 111 = Broadcasting (excluding the ingress port). MAC Address 48−bit MAC Address 172 Revision 1.1 Micrel, Inc. KSZ8852HLE Static MAC Table Lookup Examples: 12. Static Address Table Read (read the second entry at indirect address offset 0x01) Write to Reg. IACR with 0x1001 (set indirect address and trigger a read static MAC table operation) Then: Read Reg. IADR3 (static MAC table bits [57:48]) Read Reg. IADR2 (static MAC table bits [47:32]) Read Reg. IADR5 (static MAC table bits [31:16]) Read Reg. IADR4 (static MAC table bits [15:0]) 13. Static Address Table Write (write the eighth entry at indirect address offset 0x07) Write to Reg. IADR3 (static MAC table bits [57:48]) Write to Reg. IADR2 (static MAC table bits[ 47:32]) Write to Reg. IADR5 (static MAC table bits [31:16]) Write to Reg. IADR4 (static MAC table bits [15:0]) Write to Reg. IACR with 0x0007 (set indirect address and trigger a write static MAC table operation) August 31, 2015 173 Revision 1.1 Micrel, Inc. KSZ8852HLE Dynamic MAC Address Table The Dynamic MAC Address (Table 26) is a read only table. Table 26. Dynamic MAC Address Table Format (1024 Entries) Bit Default Value R/W Description Data Not Ready 71 RO 1 = Specifies that the entry is not ready, continue retrying until bit is set to “0”. 0 = Specifies that the entry is ready. 70−67 RO Reserved MAC Empty 66 1 RO 1 = Specifies that there is no valid entry in the table 0 = Specifies that there are valid entries in the table Number of Valid Entries 65−56 0x000 55−54 RO RO Indicates how many valid entries in the table. 0x3ff means 1 K entries. 0x001 means 2 entries. 0x000 and bit [66] = “0” means 1 entry. 0x000 and bit [66] = “1” means 0 entry. Timestamp Specifies the 2−bit counter for internal aging. Source Port 53−52 00 RO 51−48 0x0 RO 47−0 0x0000_0000_0000 RO Identifies the source port where FID+MAC is learned: 00 = Port 1 01 = Port 2 10 = Port 3 (host port) FID Specifies the filter ID. MAC Address Specifies the 48−bit MAC Address. Dynamic MAC Address Lookup Example: 14. Dynamic MAC Address Table Read (read the first entry at indirect address offset 0 and retrieve the MAC table size) Write to Reg. IACR with 0x1800 (set indirect address and trigger a read dynamic MAC table operation) Then: Read Reg. IADR1 (dynamic MAC table bits [71:64]) // If bit [71] = “1”, restart (re−read) from this register Read Reg. IADR3 (dynamic MAC table bits [63:48]) Read Reg. IADR2 (dynamic MAC table bits [47:32]) Read Reg. IADR5 (dynamic MAC table bits [31:16]) Read Reg. IADR4 (dynamic MAC table bits [15:0]) August 31, 2015 174 Revision 1.1 Micrel, Inc. KSZ8852HLE VLAN Table The KSZ8852 uses the VLAN table to perform look-ups. If 802.1Q VLAN mode is enabled (SGCR2[15]), this table will be used to retrieve the VLAN information that is associated with the ingress packet. This information includes FID (Filter ID), VID (VLAN ID), and VLAN membership as described in Table 27: Table 27. VLAN Table Format (16 Entries) Bit Default Value R/W Description Valid 19 1 RW 1 = Specifies that this entry is valid, the look up result will be used. 0 = Specifies that this entry is not valid. Membership 18−16 111 R/W Specifies which ports are members of the VLAN. If a DA look up fails (no match in both static and dynamic tables), the packet associated with this VLAN will be forwarded to ports specified in this field. For example: “101” means Port 3 and Port 1 are in this VLAN. FID 15−12 0x0 R/W 11−0 0x001 R/W Specifies the Filter ID. The KSZ8852 supports 16 active VLANs represented by these four bit fields. The FID is the mapped ID. If 802.1Q VLAN is enabled, the look up will be based on FID+DA and FID+SA. VID Specifies the IEEE 802.1Q 12 bits VLAN ID. If 802.1Q VLAN mode is enabled, then KSZ8852 will assign a VID to every ingress packet. If the packet is untagged or tagged with a null VID, then the packet is assigned with the default port VID of the ingress port. If the packet is tagged with non-null VID, then VID in the tag will be used. The look up process will start from the VLAN table look up. If the VID is not valid, then packet will be dropped and no address learning will take place. If the VID is valid, then FID is retrieved. The FID+DA and FID+SA lookups are performed. The FID+DA look up determines the forwarding ports. If FID+DA fails, then the packet will be broadcast to all the members (excluding the ingress port) of the VLAN. If FID+SA fails, then the FID+SA will be learned. VLAN Table Lookup Examples: 15. VLAN Table Read (read the third entry, at the indirect address offset 0x02) Write to Reg. IACR with 0x1402 (set indirect address and trigger a read VLAN table operation) Then: Read Reg. IADR5 (VLAN table bits [19:16]) Read Reg. IADR4 (VLAN table bits [15:0]) 16. VLAN Table Write (write the seventh entry, at the indirect address offset 0x06) Write to Reg. IADR5 (VLAN table bits [19:16]) Write to Reg. IADR4 (VLAN table bits [15:0]) Write to Reg. IACR with 0x1406 (set indirect address and trigger a read VLAN table operation) August 31, 2015 175 Revision 1.1 Micrel, Inc. KSZ8852HLE Absolute Maximum Ratings(2) Operating Ratings(3) Supply Voltage (VDD_A3.3, VDD_IO) ......... –0.5V to +5.0V Supply Voltage (VDD_AL, VDD_L) .............. –0.5V to +1.8V Input Voltage (All Inputs) .............................. –0.5V to +5.0V Output Voltage (All Outputs) ........................ –0.5V to +5.0V Lead Temperature (soldering, 20s) ............................ 260°C Storage Temperature (Ts)......................... –65°C to +150°C Maximum Junction Temperature (TJ) ....................... +125°C HBM ESD Rating ........................................................... 2kV Supply Voltage VDD_A3.3 ...................................... +3.135V to +3.465V VDD_L, VDD_AL, VDD_COL .............. +1.25V to +1.4V VDD_IO (3.3V)............................... +3.135V to +3.465V VDD_IO (2.5V)............................... +2.375V to +2.625V VDD_IO (1.8V)................................... +1.71V to +1.89V Ambient Operating Temperature (TA) Commercial (HLEC) ............................. −40°C to +70°C Extended Industrial (HLEW) ............... −40°C to +105°C Extended Industrial (HLEY) ................ −40°C to +115°C (4) Thermal Resistance Junction-to-Ambient (θJA)................................... 26°C/W Junction-to-Case (θJC) .................................... 10.6°C/W Electrical Characteristics(5) Symbol Condition Parameter/Symbol Min. Typ. Max. Supply Current for 100BASE-TX Operation (Internal Low-Voltage Regulator On, VDD_A3.3 = 3.3V, VDD_IO = 3.3V) 100% Traffic on Both Ports Link, no Traffic on Both Ports, EEE Feature is off. Ports 1 and 2 Powered Down (P1CR4, P2CR4 bit[11] = “1”) Ports 1 and 2 Not Connected, Using EDPD Feature (PMCTRL bits[1:0] = “01”) Ports 1 and 2 Powered Down Using EEE Feature Soft Power-Down Mode (PMCTRL bits[1:0] = “10”) Hardware Power-Down Mode While the PWDRN pin (Pin 17) is held low. IVDD_A3.3 42 IVDD_IO 87 PDISSDEVICE 428 IVDD_A3.3 41 IVDD_IO 86 PDISSDEVICE 421 IVDD_A3.3 4.6 IVDD_IO 70 PDISSDEVICE 246 IVDD_A3.3 5.5 IVDD_IO 70 PDISSDEVICE 249 IVDD_A3.3 5.3 IVDD_IO 71 PDISSDEVICE 251 IVDD_A3.3 0.98 IVDD_IO 2.0 PDISSDEVICE 10 IVDD_A3.3 0.18 IVDD_IO 0 PDISSDEVICE 0.6 Units (6) mA mW mA mW mA mW mA mW mA mW mA mW mA mW Notes: 2. Exceeding the absolute maximum rating may damage the device. 3. The device is not guaranteed to function outside its operating rating. Unused inputs must always be tied to a appropriate logic voltage level (Ground to VDD_IO). 4. The θJC/θJA is under air velocity 0m/s. 5. IVDD_A3.3 measured at pin 9. IVDD_IO measured at pins 21, 30, and 56. IVDD_AL measured at pins 6 and 16. IVDD_DL measured at pins 40 and 51. 6. TA = 25°C. Specification for packaged product only. 7. For PWRDN pin, pin 17, the operating value of VIH is lower than the other CMOS input pins. It is not dependent on VDD_IO. August 31, 2015 176 Revision 1.1 Micrel, Inc. KSZ8852HLE Electrical Characteristics(5) (Continued) Symbol Condition Parameter/Symbol Min. Typ. Max. Units Supply Current for 100BASE-TX Operation (6) (Internal Low Voltage Regulator Off; VDD_A3.3 and VDD_IO = 3.3V; VDD_L, VDD_AL and VDD_COL = 1.4V) 100% Traffic on both ports Link, no traffic on both ports. EEE Feature is off. Ports 1 & 2 Powered Down (P1CR4, P2CR4 bit[11] = “1”) Ports 1 & 2 Not Connected. Using EDPD Feature (PMCTRL bits[1:0] = “01”) Ports 1 and 2 Linked, no traffic. Using EEE Feature Soft Powerdown Mode (PMCTRL bits[1:0] = “10”) Hardware Powerdown Mode. While the PWDRN pin (Pin 17) is held low. August 31, 2015 IVDD_A3.3 40 IVDD_IO 0.6 IVDD_AL + IVDD_DL 88 PDISSDevice 258 IVDD_A3.3 40 IVDD_IO 0.7 IVDD_AL + IVDD_DL 87 PDISSDevice 256 IVDD_A3.3 3.8 IVDD_IO 0.5 IVDD_AL + IVDD_DL 71 PDISSDevice 114 IVDD_A3.3 4.5 IVDD_IO 0.6 IVDD_AL + IVDD_DL 72 PDISSDevice 117 IVDD_A3.3 5.2 IVDD_IO 0.7 IVDD_AL + IVDD_DL 74 PDISSDevice 123 IVDD_A3.3 0.2 IVDD_IO 0.7 IVDD_AL + IVDD_DL 1.1 PDISSDevice 4.3 IVDD_A3.3 0.2 IVDD_IO 0.7 IVDD_AL + IVDD_DL 0.1 PDISSDevice 4.1 177 mA mW mA mW mA mW mA mW mA mW mA mW mA mW Revision 1.1 Micrel, Inc. KSZ8852HLE Symbol Condition Parameter/Symbol Min Typ Max Units Supply Current for 10BASE-T Operation (4 ) (Internal Low Voltage Regulator On; VDD_A3.3 = 3.3V, VDD_IO = 3.3V) 100% traffic on both ports Link, no traffic on both ports IVDD_A3.3 53 IVDD_IO 74 PDISSDevice 417 IVDD_A3.3 17 IVDD_IO 71 PDISSDevice 290 mA mW mA mW Supply Current for 10BASE-T Operation (4 ) (Internal Low Voltage Regulator Off; VDD_A3.3 and VDD_IO = 3.3V; VDD_L, VDD_AL and VDD_COL = 1.4V 100% traffic on both ports Link, no traffic on both ports August 31, 2015 IVDD_A3.3 51 IVDD_IO 0.5 IVDD_AL + IVDD_DL 76 PDISSDevice 277 IVDD_A3.3 16 IVDD_IO 0.6 IVDD_AL + IVDD_DL 74 PDISSDevice 158 178 mA mW mA mW Revision 1.1 Micrel, Inc. KSZ8852HLE Electrical Characteristics(5) (Continued) Symbol Parameter Conditions Min. VLDO Output Voltage at VDD_L VDD_IO = 2.5V or 3.3V; internal regulator enabled; measured at pins 40 and 51 Typ. Max. Units 1.32 V CMOS Inputs (VDD_IO = 3.3V/2.5V/1.8V) VIH Input High Voltage VIL Input Low Voltage IIN Input Current 2.1/1.7/1.3 VIN = GND ~ VDD_IO −10 2.1 V 0.9/0.9/0.6 V 10 µA X1 Crystal/Osc Input Pin VIH Input High Voltage VDD_A3.3 = 3.3V, VDD_IO = any VIL Input Low Voltage VDD_A3.3 = 3.3V, VDD_IO = any IIN Input Current V 0.9 V 10 µA (7) PWRDN Input VIH Input High Voltage VDD_A3.3 = 3.3V, VDD_IO = any VIL Input Low Voltage VDD_A3.3 = 3.3V, VDD_IO = any 1.1 V 0.3 V CMOS Outputs (VDD_IO = 3.3V/2.5V/1.8V) VOH Output High Voltage IOH = −8mA VOL Output Low Voltage IOL = 8mA |IOZ| Output Tri-State Leakage 2.4/1.9/1.5 V 0.4/0.4/0.2 V 10 µA ±1.05 V 2 % 100BASE-TX Transmit (Measured Differentially After 1:1 Transformer) VO Peak Differential Output Voltage 100Ω termination on the differential output Vimb Output Voltage Imbalance 100Ω termination on the differential output tr , tf Rise/Fall Time 3 5 ns Rise/Fall Time Imbalance 0 0.5 ns ±0.25 ns 5 % ±0.95 Duty-Cycle Distortion Overshoot VSET Reference Voltage of ISET Output Jitter 0.65 Peak-to-peak 0.7 5MHz square wave 400 V 1.4 ns 10BASE-T Receive Vsq Squelch Threshold mV 10BASE-T Transmit (Measured Differentially After 1:1 Transformer) VP tr , tf Peak Differential Output Voltage 100Ω termination on the differential output Jitter Added 100Ω termination on the differential output (peak-to-peak) Rise/Fall Time 2.2 2.5 2.8 V 1.8 3.5 ns 25 ns 8 mA LED Outputs ILED Output Drive Current August 31, 2015 Each LED pin (P1/2LED0, P1/2LED1) 179 Revision 1.1 Micrel, Inc. KSZ8852HLE Electrical Characteristics(5) (Continued) Symbol Parameter Conditions Min. Typ. Max. 57 100 187 55 100 190 37 59 102 35 60 110 29 43 70 27 43 76 Units I/O Pin Internal Pull-Up and Pull-Down Effective Resistance R1.8PU I/O Pin Effective Pull-Up Resistance R1.8PD I/O Pin Effective Pull-Down Resistance R2.5PU I/O Pin Effective Pull-Up Resistance R2.5PD I/O Pin Effective Pull-Down Resistance R3.3PU I/O Pin Effective Pull-Up Resistance R3.3PD I/O Pin Effective Pull-Down Resistance August 31, 2015 kΩ VDD_IO = 1.8V kΩ VDD_IO = 2.5V kΩ VDD_IO = 3.3V 180 Revision 1.1 Micrel, Inc. KSZ8852HLE Timing Specifications Host Interface Read / Write Timing Figure 16. Host Interface Read/Write Timing Table 28. Host Interface Read/Write Timing Parameters Symbol Description t1 CSN, CMD valid to RDN, WRN active 0 t2 RDN active to Read Data SD[15:0] valid Note: This is the SD output delay after RDN becomes active until valid read data is available. 24 32 ns t3 RDN inactive to Read data invalid Note: The processor latches valid read data at the rising edge of RDN. 1 2 ns t4 CSN, CMD hold time after RDN, WRN inactive 0 WRN active to write data valid (bit [12] = 0 in RXFDPR) 8 t5 t6 t7 Min. WRN active to write data valid (bit [12] = 1 in RXFDPR) Note: It is better if the processor can provide data in less than 4ns after WRN is active. If the processor provides data more than 4ns after WRN is active, make sure that RXFDPR bit [12] = 0. Typ. Max. Unit ns ns 16 ns 4 ns RDN Read active time (low) 40 ns WRN Write active time (low) 40 ns RDN Read Inactive time (high) 10 ns WRN Write inactive time (high) 10 ns August 31, 2015 181 Revision 1.1 Micrel, Inc. KSZ8852HLE Auto−Negotiation Timing Figure 17. Auto-Negotiation Timing Table 29. Auto-Negotiation Timing Parameters Timing Parameter Description tBTB FLP burst to FLP burst tFLPW FLP burst width tPW Clock/Data pulse width tCTD Clock pulse to data pulse 55.5 64 69.5 µs tCTC Clock pulse to clock pulse 111 128 139 µs Number of Clock/Data pulses per burst 17 August 31, 2015 182 Min. Typ. Max. Unit 8 16 24 ms 2 ms 100 ns 33 Revision 1.1 Micrel, Inc. KSZ8852HLE Serial EEPROM Interface Timing Figure 18. Serial EEPROM Timing Table 30. Serial EEPROM Timing Parameters Timing Parameter Description fSCL EESK Clock Frequency t1 Setup Time for Start Bit 33 ns t2 Hold Time for Start Bit 33 ns t3 Hold Time for Data 20 ns t4 Setup Time for Data 33 ns t5 Output Valid Time for Data 60 ns t6 Setup Time for Stop Bit 33 ns t7 Hold Time for Stop Bit 33 ns August 31, 2015 Min. 183 Typ. Max. Unit 2.5 MHz Revision 1.1 Micrel, Inc. KSZ8852HLE Reset Timing and Power Sequencing The KSZ8852 reset timing requirement is summarized in Figure 19 and Table 31. Figure 19. KSZ8852 Reset and Power Sequence Timing Table 31. Reset Timing Parameters (8, 9, 10) Timing Parameter Description Min. Max. Unit tvr Supply voltages rise time (must be monotonic) 0 μs tsr Stable supply voltages to de-assertion of reset 10 ms tcs Strap-in pin configuration setup time 5 ns tch Strap-in pin configuration hold time 5 ns trc De-assertion of reset to strap-in pin output 6 ns Notes 8. The recommended powering sequence is to bring up all voltages at the same time. However, if that cannot be attained, then a recommended powerup sequence is to have the transceiver (VDD_A3.3) and digital I/Os (VDD_IO) voltages power up before the low-voltage core (VDD_AL, VDD_L, and VDD_COL) voltage, if an external low voltage core supply is used. There is no power sequence requirement between transceiver (VDD_A3.3) and digital I/Os (VDD_IO) power rails. The power-up waveforms should be monotonic for all supply voltages to the KSZ8852. 9. After the de-assertion of reset, it is recommended to wait a minimum of 100μs before starting programming of the device through any interface. 10. The recommended power-down sequence is to have the low-voltage core voltage power-down first before powering down the transceiver and digital I/O voltages. August 31, 2015 184 Revision 1.1 Micrel, Inc. KSZ8852HLE Reset Circuit Guidelines Figure 20 is the recommended reset circuit for powering up the KSZ8852 device if reset is triggered by the power supply. Figure 20. Sample Reset Circuit Figure 21 is the recommended reset circuit for applications where reset is driven by another device (e.g., CPU or FPGA). At power−on−reset, R, C and D1 provide the necessary ramp rise time to reset the KSZ8852 device. The RST_OUT_N from CPU/FPGA provides the warm reset after power up. Figure 21. Recommended Reset Circuit for Interfacing with a CPU/FPGA Reset Output August 31, 2015 185 Revision 1.1 Micrel, Inc. KSZ8852HLE Reference Circuits – LED Strap-In Pins The pull−up and pull−down reference circuits for the P1LED0/H816 and P2LED0/LEBE strapping pins are shown in Figure 22. The supply voltage for the LEDs must be at least ~2.2V, depending on the particular LED and the load resistor used. If VDD_IO is 1.8V, then a different (higher voltage) supply must be used for the LEDs. Figure 22. Typical LED Strap-In Circuit August 31, 2015 186 Revision 1.1 Micrel, Inc. KSZ8852HLE Reference Clock – Connection and Selection Figure 23 shows a crystal or external clock source, such as an oscillator, as the reference clock for the KSZ8852. The reference clock is 25MHz for all operating modes of the KSZ8852. If an oscillator is used, connect it to X1, and leave X2 unconnected. The resistor shown on X2 is optional and can be used to reduce the current to the crystal if needed, depending on the specific crystal that is used. The maximum recommended resistor value is 30Ω. Figure 23. 25MHz Crystal and Oscillator Clock Connections Selection of Reference Crystal Table 32. Typical Reference Crystal Characteristics Characteristics Value Units Frequency 25 MHz Frequency tolerance (max) ±50 ppm Series resistance (max) 50 Ω August 31, 2015 187 Revision 1.1 Micrel, Inc. KSZ8852HLE Selection of Isolation Transformers A 1:1 isolation transformer is required at the line interface. An isolation transformer with integrated common−mode choke is recommended for exceeding FCC requirements. Table 33 gives recommended transformer characteristics. Table 33. Transformer Selection Criteria Parameter Value Turns ratio 1 CT : 1 CT Test Condition Open−circuit inductance (maximum) 350µH 100mV, 100kHz, 8mA Leakage inductance (maximum) 0.4µH 1MHz (min) Inter−winding capacitance (maximum) 12pF D.C. resistance (maximum) 0.9Ω −1.0dB Insertion loss (maximum) HIPOT (maximum) 100kHz – 100MHz 1500Vrms Table 34. Qualified Single Port Magnetic Part Number Auto MDI−X Number of Port H1102NL Yes 1 Pulse (low cost) H1260 Yes 1 Transpower HB726 Yes 1 S558−5999−U7 Yes 1 LF8505 Yes 1 LF−H41S Yes 1 TLA−6T718 Yes 1 Magnetic Manufacturer Pulse Bel Fuse Delta LanKom TDK (Mag Jack) August 31, 2015 188 Revision 1.1 Micrel, Inc. KSZ8852HLE Package Information(11) and Recommended Landing Pattern 64-Pin 10mm × 10mm LQFP Note: 11. Package information is correct as of the publication date. For updates and most current information, go to www.micrel.com. August 31, 2015 189 Revision 1.1 Micrel, Inc. KSZ8852HLE MICREL, INC. 2180 FORTUNE DRIVE SAN JOSE, CA 95131 USA TEL +1 (408) 944-0800 FAX +1 (408) 474-1000 WEB http://www.micrel.com Micrel, Inc. is a leading global manufacturer of IC solutions for the worldwide high performance linear and power, LAN, and timing & communications markets. The Company’s products include advanced mixed-signal, analog & power semiconductors; high-performance communication, clock management, MEMs-based clock oscillators & crystal-less clock generators, Ethernet switches, and physical layer transceiver ICs. Company customers include leading manufacturers of enterprise, consumer, industrial, mobile, telecommunications, automotive, and computer products. Corporation headquarters and state-of-the-art wafer fabrication facilities are located in San Jose, CA, with regional sales and support offices and advanced technology design centers situated throughout the Americas, Europe, and Asia. Additionally, the Company maintains an extensive network of distributors and reps worldwide. Micrel makes no representations or warranties with respect to the accuracy or completeness of the information furnished in this datasheet. This information is not intended as a warranty and Micrel does not assume responsibility for its use. Micrel reserves the right to change circuitry, specifications and descriptions at any time without notice. No license, whether express, implied, arising by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Micrel’s terms and conditions of sale for such products, Micrel assumes no liability whatsoever, and Micrel disclaims any express or implied warranty relating to the sale and/or use of Micrel products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright, or other intellectual property right. Micrel Products are not designed or authorized for use as components in life support appliances, devices or systems where malfunction of a product can reasonably be expected to result in personal injury. Life support devices or systems are devices or systems that (a) are intended for surgical implant into the body or (b) support or sustain life, and whose failure to perform can be reasonably expected to result in a significant injury to the user. A Purchaser’s use or sale of Micrel Products for use in life support appliances, devices or systems is a Purchaser’s own risk and Purchaser agrees to fully indemnify Micrel for any damages resulting from such use or sale. © 2014 Micrel, Incorporated. August 31, 2015 190 Revision 1.1