# KSZ8895MLUB 

Integrated 5-Port 10/100 Managed Switch
Revision 2.1

## General Description

The KSZ8895MLUB is a highly-integrated Layer 2managed 5-port switch with an optimized design and plentiful features, qualified to meet AEC-Q100 standard for automotive applications. It is designed for costsensitive 10/100Mbps 5-port switch systems with on-chip termination, lowest power consumption and internal core power controller. These features will save more system cost. It has 1.4 Gbps high-performance memory bandwidth, shared memory based switch fabric with full non-blocking configuration. It also provides an extensive feature set such as power management, programmable rate limit and priority ratio, tag/port-based VLAN, packets filtering, quality-of-service (QoS) four-queue prioritization, management interface, and MIB counters. Port 5 is a MAC 5 MII interface with PHY mode as default at switch side. The SW5-MII interface can be connected to a processor with a MAC MII interface.

The KSZ8895MLUB consists of $10 / 100$ PHYs with patented and enhanced mixed-signal technology, media access control (MAC) units, a high-speed non-blocking switch fabric, a dedicated address lookup engine, and an on-chip frame buffer memory. The KSZ8895MLUB contains five MACs and four integrated PHYs. All PHYs support 10/100Base-T/TX.

All registers of MACs and PHYs units can be managed by the SPI interface or the SMI interface. MIIM registers of the PHYs can be accessed through the MDC/MDIO interface. EEPROM can set all control registers for the unmanaged mode.
The KSZ8895MLUB provides multiple CPU control/data interfaces to effectively address both current and emerging fast Ethernet applications.
Datasheets and support documentation are available on Micrel's web site at: www.micrel.com.

## Functional Diagram



## Features

## Advanced Switch Features

- IEEE 802.1q VLAN support for up to 128 VLAN groups (full-range 4096 of VLAN IDs).
- Static MAC table supports up to 32 entries.
- VLAN ID tag/untag options, per port basis.
- IEEE 802.1p/q tag insertion or removal on a per port basis based on ingress port (egress).
- Programmable rate limiting at the ingress and egress on a per port basis.
- Jitter-free per packet based rate-limiting support.
- Broadcast storm protection with percentage control (global and per port basis).
- IEEE 802.1d rapid spanning tree protocol RSTP support.
- Tail tag mode (1byte added before FCS) support at Port 5 to inform the processor which ingress port receives the packet.
- 1.4 Gbps high-performance memory bandwidth and shared memory-based switch fabric with fully nonblocking configuration.
- MII with MAC 5 on Port 5, SW5-MII for MAC 5 MII interface.
- Enable/Disable option for huge frame size up to 2000 bytes per frame.
- IGMP v1/v2 snooping (Ipv4) support for multicast packet filtering.
- IPv4/IPv6 QoS support.
- Support unknown unicast/multicast address and unknown VID packet filtering.
- Self-address filtering.

Comprehensive Configuration Register Access

- Serial management interface (MDC/MDIO) to all PHYs registers and SMI interface (MDC/MDIO) to all registers.
- High-speed SPI (up to 25 MHz ) and $I^{2} C$ master Interface to all internal registers.
- I/O pins strapping and EEPROM to program selective registers in unmanaged switch mode.
- Control registers configurable on the fly (port-priority, 802.1p/d/q, AN...).


## QoSICoS Packet Prioritization Support

- Per port, 802.1p and DiffServ-based.
- 1/2/4-queue QoS prioritization selection.
- Programmable weighted fair queuing for ratio control.
- Re-mapping of 802.1 p priority field per port basis.


## Integrated 5-Port 10/100 Ethernet Switch

- New generation switch with five MACs and five PHYs fully compliant with IEEE 802.3u standard.
- Non-blocking switch fabric assures fast packet delivery by utilizing a 1K MAC address lookup table and a store-andforward architecture.
- On-chip 64Kbyte memory for frame buffering (not shared with 1K unicast address table).
- Full duplex IEEE 802.3x flow control (PAUSE) with force mode option.
- Half-duplex back pressure flow control.
- HP Auto MDI/MDI-X and IEEE Auto crossover support.
- Port 5 MAC5 SW5-MII interface supports PHY mode and MAC mode.
- 7-wire serial network interface (SNI) support for legacy MAC.
- Per port LED Indicators for link, activity, and 10/100 speed.
- Register port status support for link, activity, full/half duplex and 10/100 speed.
- Micrel LinkMD® cable diagnostic capabilities for determining cable opens, shorts, and length.
- On-chip terminations and internal biasing technology for cost down and lowest power consumption.


## Switch Monitoring Features

- Port mirroring/monitoring/sniffing: ingress and/or egress traffic to any port or MII.
- MIB counters for fully-compliant statistics gathering 34 MIB counters per port.
- Loop-back support for MAC, PHY, and remote diagnostic of failure.
- Interrupt for the link change on any ports.


## Low Power Dissipation

- Full-chip hardware power-down.
- Full-chip software power-down/per port software power down.
- Energy-detect mode support $<100 \mathrm{~mW}$ full-chip power consumption when all ports have no activity.
- Very-low, full-chip power consumption (<0.5W), without extra power consumption on transformers.
- Dynamic clock-tree shutdown feature.
- Voltages: Single 3.3 V supply with 3.3 V VDDIO and Internal 1.2V LDO controller enabled or external 1.2V LDO solution:
- Analog VDDAT 3.3V only
- VDDIO support $3.3 \mathrm{~V}, 2.5 \mathrm{~V}$ and 1.8 V
- Low 1.2V core power
- Industrial Temperature Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.
- Available in 128-pin LQFP, lead-free package.


## Applications

- In-vehicle diagnostics (OBD)
- High-speed software download
- Gateway switch
- Head unit
- Rear seat entertainment


## Ordering Information

| Part Number | Temperature Range | Package | Lead Finish/Grade |
| :--- | :---: | :---: | :---: |
| KSZ8895MLUB <br> (Automotive Grade) | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ | $128-$ Pin LQFP | Pb-Free/Automotive |
| KSZ8895MLUB-EVAL Board | Evaluation Board for KSZ8895MLUB |  |  |

## Revision History

| Revision | Date | Summary of Changes |
| :--- | :--- | :--- |
| 1.0 | $03 / 16 / 11$ | Initial |
| 1.1 | $09 / 27 / 11$ | Update some descriptions, updates for descriptions of SMI mode and IGMP mode, update register <br> default values, pins type and some parameters. <br> Revision 1.1 datasheet reflects the revision A4 silicon (0.13um CMOS technology). |
|  | $02 / 21 / 14$ | Updates timing data for MII PHY mode. <br> Update descriptions for VLAN table and I2C master mode. <br> Update the descriptions for the pins 125 and 126. <br> Update the equation in the broadcast storm protection section. <br> Update the operation rating to +/-5\% and TTL min/max I/O voltage in different VDDIO. Change I/O <br> from TTL to CMOS. <br> Update SPI description from 127 to 255 for all registers. <br> Update the table of tail tag rules. <br> Update description for Register 1 bits [7:4]. <br> Update table 8 from bit [57:55] to bit [58:56]. <br> Update the port register control 2 bit [6] description bits [20:16] change to bits [11:7]. <br> Add evaluation Board in the ordering information table. <br> Revision 2.0 datasheet reflects the revision B2 silicon (0.11um CMOS technology). <br> From B2 silicon, add LinkMD feature and ESD to be improved to 5KV. |
| 2.1 | $03 / 31 / 14$ | The part number is changed from KSZ8895MLU to KSZ8895MLUB. Remove port 5 in the pin <br> configuration and pin description. Update notes description for pin 125 and pin 126 in the pins <br> descriptions. Update operating rating and electrical characteristics, correct typos. |

## Contents

List of Figures ..... 13
List of Tables ..... 14
Pin Configuration ..... 15
Pin Description ..... 16
Pin for Strap-In Options. ..... 22
Introduction ..... 25
Physical Layer Transceiver. ..... 25
100BASE-TX Transmit ..... 25
10BASE-T Transmit ..... 25
10BASE-T Receive ..... 26
MDI/MDI-X Auto Crossover ..... 26
Auto-Negotiation ..... 27
LinkMD ${ }^{\circledR}$ Cable Diagnostics ..... 29
On-Chip Termination Resistors ..... 30
Internal 1.2V LDO Controller ..... 30
Power Management ..... 31
Normal Operation Mode ..... 31
Energy Detect Mode ..... 31
Soft Power-Down Mode ..... 32
Power-Saving Mode ..... 32
Port-Based Power-Down Mode ..... 32
Switch Core. ..... 32
Address Look-Up ..... 32
Learning ..... 32
Migration ..... 32
Aging ..... 32
Forwarding ..... 33
Switching Engine ..... 33
Media Access Controller (MAC) Operation ..... 33
MII Interface Operation ..... 36
Port 5 MAC 5 SW5-MII Interface ..... 36
SNI Interface Operation ..... 37
Advanced Functionality ..... 39
QoS Priority Support ..... 39
Port-Based Priority ..... 39
802.1p-Based Priority ..... 39
Spanning Tree Support ..... 40
Rapid Spanning Tree Support ..... 41
Tail Tagging Mode ..... 41
IGMP Support ..... 42
Port Mirroring Support ..... 43
VLAN Support ..... 43
Rate Limiting Support ..... 44
Ingress Rate Limit ..... 44
Egress Rate Limit. ..... 44
Transmit Queue Ratio Programming ..... 45
Filtering for Self-Address, Unknown Unicast/Multicast Address and Unknown VID Packet/IP Multicast ..... 45
Configuration Interfaces ..... 46
$I^{2} \mathrm{C}$ Master Serial Bus Configuration ..... 46
SPI Slave Serial Bus Configuration ..... 46
MII Management Interface (MIIM) ..... 49
Serial Management Interface (SMI) ..... 49
Register Description ..... 51
Global Registers ..... 53
Register 0 ( $0 \times 00$ ): Chip ID0 ..... 53
Register 1 ( $0 \times 01$ ): Chip ID1 / Start Switch ..... 53
Register 2 ( $0 \times 02$ ): Global Control 0 ..... 53
Register 2 ( $0 \times 02$ ): Global Control 0 ..... 54
Register 3 ( $0 \times 03$ ): Global Control 1 ..... 54
Register 3 ( $0 \times 03$ ): Global Control 1 ..... 55
Register 4 ( $0 \times 04$ ): Global Control 2 ..... 56
Register 4 ( $0 \times 04$ ): Global Control 2 ..... 57
Register 5 ( $0 \times 05$ ): Global Control 3 ..... 57
Register 6 ( $0 \times 06$ ): Global Control 4 ..... 58
Register 7 ( $0 \times 07$ ): Global Control 5 ..... 59
Register 8 ( $0 \times 08$ ): Global Control 6 ..... 59
Register 9 ( $0 \times 09$ ): Global Control 7 ..... 59
Register 10 ( $0 \times 0 \mathrm{~A}$ ): Global Control 8 ..... 59
Register 11 ( $0 \times 0 \mathrm{~B}$ ): Global Control 9 ..... 59
Register 11 ( $0 \times 0 \mathrm{~B}$ ): Global Control 9 ..... 60
Register 12 (0×0C): Global Control 10 ..... 61
Register 13 ( $0 \times 0 \mathrm{D}$ ): Global Control 11 ..... 61
Register $14(0 \times 0 \mathrm{E})$ : Power-Down Management Control 1 ..... 62
Register 14 ( $0 \times 0 \mathrm{E}$ ): Power-Down Management Control 1 ..... 62
Register 15 (0×0F): Power-Down Management Control 2 ..... 62
Port Registers ..... 63
Register 16 ( $0 \times 10$ ): Port 1 Control 0 ..... 63
Register 32 ( $0 \times 20$ ): Port 2 Control 0 ..... 63
Register 48 ( $0 \times 30$ ): Port 3 Control 0 ..... 63
Register 64 ( $0 \times 40$ ): Port 4 Control 0 ..... 63
Register $80(0 \times 50)$ : Port 5 Control 0 ..... 63
Register 16 ( $0 \times 10$ ): Port 1 Control 0 ..... 64
Register 32 ( $0 \times 20$ ): Port 2 Control 0 ..... 64
Register 48 ( $0 \times 30$ ): Port 3 Control 0 ..... 64
Register 64 ( $0 \times 40$ ): Port 4 Control 0 ..... 64
Register 80 ( $0 \times 50$ ): Port 5 Control 0 ..... 64
Register 17 ( $0 \times 11$ ): Port 1 Control 1 ..... 64
Register 33 ( $0 \times 21$ ): Port 2 Control 1 ..... 64
Register 49 ( $0 \times 31$ ): Port 3 Control 1 ..... 64
Register 65 ( $0 \times 41$ ): Port 4 Control 1 ..... 64
Register 81 ( $0 \times 51$ ): Port 4 Control 1 ..... 64
Register 18 ( $0 \times 12$ ): Port 1 Control 2 ..... 65
Register 34 ( $0 \times 22$ ): Port 2 Control 2 ..... 65
Register $50(0 \times 32)$ : Port 3 Control 2 ..... 65
Register 66 ( $0 \times 42$ ): Port 4 Control 2 ..... 65
Register 82 ( $0 \times 52$ ): Port 5 Control 2 ..... 65
Register 18 ( $0 \times 12$ ): Port 1 Control 2 ..... 66
Register 34 ( $0 \times 22$ ): Port 2 Control 2 ..... 66
Register 50 ( $0 \times 32$ ): Port 3 Control 2 ..... 66
Register $66(0 \times 42)$ : Port 4 Control 2 ..... 66
Register 82 ( $0 \times 52$ ): Port 5 Control 2 ..... 66
Register 19 ( $0 \times 13$ ): Port 1 Control 3 ..... 67
Register 35 ( $0 \times 23$ ): Port 2 Control 3 ..... 67
Register 51 ( $0 \times 33$ ): Port 3 Control 3 ..... 67
Register 67 ( $0 \times 43$ ): Port 4 Control 3 ..... 67
Register 83 ( $0 \times 53$ ): Port 5 Control 3 ..... 67
Register 20 ( $0 \times 14$ ): Port 1 Control 4 ..... 67
Register 36 ( $0 \times 24$ ): Port 2 Control 4 ..... 67
Register 52 ( $0 \times 34$ ): Port 3 Control 4 ..... 67
Register 68 ( $0 \times 44$ ): Port 4 Control 4 ..... 67
Register 84 ( $0 \times 54$ ): Port 5 Control 4 ..... 67
Register 87 ( $0 \times 57$ ): Reserved Control Register ..... 67
Register 25 ( $0 \times 19$ ): Port 1 Status 0 ..... 68
Register 41 ( $0 \times 29$ ): Port 2 Status 0 ..... 68
Register 57 ( $0 \times 39$ ): Port 3 Status 0 ..... 68
Register 73 ( $0 \times 49$ ): Port 4 Status 0 ..... 68
Register 89 ( $0 \times 59$ ): Reserved ..... 68
Register 26 ( $0 \times 1 \mathrm{~A}$ ): Port 1 PHY Special Control/Status ..... 68
Register $42(0 \times 2 A)$ : Port 2 PHY Special Control/Status ..... 68
Register 58 ( $0 \times 3$ A): Port 3 PHY Special Control/Status ..... 68
Register 74 ( $0 \times 4 \mathrm{~A}$ ): Port 4 PHY Special Control/Status ..... 68
Register 90 ( $0 \times 5 \mathrm{~A}$ ): Reserved ..... 68
Register 27 ( $0 \times 1 B$ ): Port 1 LinkMD Result ..... 69
Register 43 ( $0 \times 2 B$ ): Port 2 LinkMD Result ..... 69
Register 59 ( $0 \times 3 \mathrm{~B}$ ): Port 3 LinkMD Result ..... 69
Register 75 ( $0 \times 4 \mathrm{~B}$ ): Port 4 LinkMD Result ..... 69
Register 91 (0×5B): Reserved ..... 69
Register 28 ( $0 \times 1 \mathrm{C}$ ): Port 1 Control 5 ..... 69
Register 44 ( $0 \times 2 \mathrm{C}$ ): Port 2 Control 5 ..... 69
Register 60 ( $0 \times 3 C$ ): Port 3 Control 5 ..... 69
Register 76 ( $0 \times 4 \mathrm{C}$ ): Port 4 Control 5 ..... 69
Register 92 ( $0 \times 5 \mathrm{C}$ ): Reserved ..... 69
Register 28 ( $0 \times 1 \mathrm{C}$ ): Port 1 Control 5 ..... 70
Register 44 ( $0 \times 2 \mathrm{C}$ ): Port 2 Control 5 ..... 70
Register 60 ( $0 \times 3 \mathrm{C}$ ): Port 3 Control 5 ..... 70
Register $76(0 \times 4 \mathrm{C})$ : Port 4 Control 5 ..... 70
Register 92 ( $0 \times 5 \mathrm{C}$ ): Reserved ..... 70
Register 29 ( $0 \times 1 \mathrm{D}$ ): Port 1 Control 6 ..... 70
Register 45 ( $0 \times 2 \mathrm{D}$ ): Port 2 Control 6 ..... 70
Register 61 ( $0 \times 3 \mathrm{D}$ ): Port 3 Control 6 ..... 70
Register 77 ( $0 \times 4 \mathrm{D}$ ): Port 4 Control 6 ..... 70
Register 93 ( $0 \times 5 \mathrm{D}$ ): Reserved ..... 70
Register 29 ( $0 \times 1 \mathrm{D}$ ): Port 1 Control 6 ..... 71
Register 45 ( $0 \times 2 \mathrm{D}$ ): Port 2 Control 6 ..... 71
Register 61 ( $0 \times 3 \mathrm{D}$ ): Port 3 Control 6 ..... 71
Register 77 ( $0 \times 4 \mathrm{D}$ ): Port 4 Control 6 ..... 71
Register 93 ( $0 \times 5 \mathrm{D}$ ): Reserved ..... 71
Register 30 ( $0 \times 1 \mathrm{E}$ ): Port 1 Status 1 ..... 71
Register 46 ( $0 \times 2 \mathrm{E}$ ): Port 2 Status 1 ..... 71
Register 62 ( $0 \times 3 \mathrm{E}$ ): Port 3 Status 1 ..... 71
Register 78 ( $0 \times 4 \mathrm{E}$ ): Port 4 Status 1 ..... 71
Register 94 (0×5E): Reserved ..... 71
Register 31 ( $0 \times 1$ F): Port 1 Control 7 and Status 2 ..... 72
Register 47 ( $0 \times 2$ F): Port 2 Control 7 and Status 2 ..... 72
Register 63 ( $0 \times 3 F$ ): Port 3 Control 7 and Status 2 ..... 72
Register 79 ( $0 \times 4 \mathrm{~F}$ ): Port 4 Control 7 and Status 2 ..... 72
Register 95 ( $0 \times 5 \mathrm{~F}$ ): Reserved ..... 72
Advanced Control Registers ..... 73
Register 104 (0×68): MAC Address Register 0 ..... 73
Register 105 (0×69): MAC Address Register 1 ..... 73
Register 106 (0×6A): MAC Address Register 2 ..... 73
Register 107 (0×6B): MAC Address Register 3 ..... 73
Register 108 (0×6C): MAC Address Register 4 ..... 73
Register 109 (0×6D): MAC Address Register 5 ..... 73
Register 110 ( $0 \times 6 \mathrm{E}$ ): Indirect Access Control 0 ..... 74
Register 111 (0×6F): Indirect Access Control 1. ..... 74
Register 112 ( $0 \times 70$ ): Indirect Data Register 8 ..... 74
Register 113 ( $0 \times 71$ ): Indirect Data Register 7 ..... 74
Register 114 ( $0 \times 72$ ): Indirect Data Register 6 ..... 74
Register 115 ( $0 \times 73$ ): Indirect Data Register 5 ..... 74
Register 116 ( $0 \times 74$ ): Indirect Data Register 4 ..... 74
Register 117 ( $0 \times 75$ ): Indirect Data Register 3 ..... 75
Register 118 ( $0 \times 76$ ): Indirect Data Register 2 ..... 75
Register 119 ( $0 \times 77$ ): Indirect Data Register 1 ..... 75
Register 120 (0×78): Indirect Data Register 0 ..... 75
Register 124 (0x7C): Interrupt Status Register ..... 75
Register 125 (0x7D): Interrupt Mask Register ..... 76
Register 128 (0x80): Global Control 12 ..... 76
Register 129 (0x81): Global Control 13 ..... 76
Register 130 (0x82): Global Control 14 ..... 77
Register 131 (0x83): Global Control 15 ..... 77
Register 132 (0x84): Global Control 16 ..... 78
Register 133(0x85): Global Control 17 ..... 78
Register 134 (0x86): Global Control 18 ..... 79
Register 135 (0x87): Global Control 19 ..... 79
Register 144 ( $0 \times 90$ ): TOS Priority Control Register 0 ..... 80
Register 145 (0x91): TOS Priority Control Register 1 ..... 80
Register 146 (0x92): TOS Priority Control Register 2 ..... 80
Register 147 (0x93): TOS Priority Control Register 3 ..... 80
Register 148 (0x94): TOS Priority Control Register 4 ..... 81
Register 149 (0x95): TOS Priority Control Register 5 ..... 81
Register 150 (0x96): TOS Priority Control Register 6 ..... 81
Register 151 (0x97): TOS Priority Control Register 7 ..... 81
Register 152 (0x98): TOS Priority Control Register 8 ..... 81
Register 153 (0x99): TOS Priority Control Register 9 ..... 82
Register 154 (0x9A): TOS Priority Control Register 10 ..... 82
Register 155 (0x9B): TOS Priority Control Register 11 ..... 82
Register 156 (0x9C): TOS Priority Control Register 12 ..... 82
Register 157 (0x9D): TOS Priority Control Register 13 ..... 82
Register 158 (0x9E): TOS Priority Control Register 14 ..... 83
Register 159 (0x9F): TOS Priority Control Register 15 ..... 83
Register 176 (0xB0): Port 1 Control 8 ..... 83
Register 192 (0xC0): Port 2 Control 8 ..... 83
Register 208 (0xD0): Port 3 Control 8 ..... 83
Register 224 (0xE0): Port 4 Control 8 ..... 83
Register 240 (0xF0): Port 5 Control 8 ..... 83
Register 176 (0xB0): Port 1 Control 8 ..... 84
Register 192 (0xC0): Port 2 Control 8 ..... 84
Register 208 (0xD0): Port 3 Control 8 ..... 84
Register 224 (0xE0): Port 4 Control 8 ..... 84
Register 240 (0xF0): Port 5 Control 8 ..... 84
Register 177 (0xB1): Port 1 Control 9 ..... 84
Register 193 (0xC1): Port 2 Control 9 ..... 84
Register 209 (0xD1): Port 3 Control 9 ..... 84
Register 225 (0xE1): Port 4 Control 9 ..... 84
Register 241 (0xF1): Port 5 Control 9 ..... 84
Register 178 (0xB2): Port 1 Control 10 ..... 85
Register 194 (0xC2): Port 2 Control 10 ..... 85
Register 210 (0xD2): Port 3 Control 10 ..... 85
Register 226 (0xE2): Port 4 Control 10 ..... 85
Register 242 (0xF2): Port 5 Control 10 ..... 85
Register 179 (0xB3): Port 1 Control 11 ..... 85
Register 195 (0xC3): Port 2 Control 11 ..... 85
Register 211 (0xD3): Port 3 Control 11 ..... 85
Register 227 (0xE3): Port 4 Control 11 ..... 85
Register 243 (0xF3): Port 5 Control 11 ..... 85
Register 180 (0xB4): Port 1 Control 12 ..... 85
Register 196 (0xC4): Port 2 Control 12 ..... 85
Register 212 (0xD4): Port 3 Control 12 ..... 85
Register 228 (0xE4): Port 4 Control 12 ..... 85
Register 244 (0xF4): Port 5 Control 12 ..... 85
Register 181 (0xB5): Port 1 Control 13 ..... 86
Register 197 (0xC5): Port 2 Control 13 ..... 86
Register 213 (0xD5): Port 3 Control 13 ..... 86
Register 229 (0xE5): Port 4 Control 13 ..... 86
Register 245 (0xF5): Port 5 Control 13 ..... 86
Register 182 (0xB6): Port 1 Rate Limit Control ..... 86
Register 198 (0xC6): Port 2 Rate Limit Control ..... 86
Register 214 (0xD6): Port 3 Rate Limit Control ..... 86
Register 230 (0xE6): Port 4 Rate Limit Control ..... 86
Register 246 (0xF6): Port 5 Rate Limit Control ..... 86
Register 183 (0xB7): Port 1 Priority 0 Ingress Limit Control 1 ..... 87
Register 199 (0xC7): Port 2 Priority 0 Ingress Limit Control 1 ..... 87
Register 215 (0xD7): Port 3 Priority 0 Ingress Limit Control 1 ..... 87
Register 231 (0xE7): Port 4 Priority 0 Ingress Limit Control 1 ..... 87
Register 247 (0xF7): Port 5 Priority 0 Ingress Limit Control 1 ..... 87
Register 184 (0xB8): Port 1 Priority 1 Ingress Limit Control 2 ..... 87
Register 200 (0xC8): Port 2 Priority 1 Ingress Limit Control 2. ..... 87
Register 216 (0xD8): Port 3 Priority 1 Ingress Limit Control 2. ..... 87
Register 232 (0xE8): Port 4 Priority 1 Ingress Limit Control 2 ..... 87
Register 248 (0xF8): Port 5 Priority 1 Ingress Limit Control 2 ..... 87
Register 185 (0xB9): Port 1 Priority 2 Ingress Limit Control 3 ..... 87
Register 201 (0xC9): Port 2 Priority 2 Ingress Limit Control 3. ..... 87
Register 217 (0xD9): Port 3 Priority 2 Ingress Limit Control 3. ..... 87
Register 233 (0xE9): Port 4 Priority 2 Ingress Limit Control 3 ..... 87
Register 249 (0xF9): Port 5 Priority 2 Ingress Limit Control 3 ..... 87
Register 186 (0xBA): Port 1 Priority 3 Ingress Limit Control 4 ..... 88
Register 202 (0xCA): Port 2 Priority 3 Ingress Limit Control 4 ..... 88
Register 218 (0xDA): Port 3 Priority 3 Ingress Limit Control 4 ..... 88
Register 234 (0xEA): Port 4 Priority 3 Ingress Limit Control 4 ..... 88
Register 250 (0xFA): Port 5 Priority 3 Ingress Limit Control 4. ..... 88
Register 187 (0xBB): Port 1 Queue 0 Egress Limit Control 1 ..... 88
Register 203 (0xCB): Port 2 Queue 0 Egress Limit Control 1 ..... 88
Register 219 (0xDB): Port 3 Queue 0 Egress Limit Control 1 ..... 88
Register 235 (0xEB): Port 4 Queue 0 Egress Limit Control 1 ..... 88
Register 251 (0xFB): Port 5 Queue 0 Egress Limit Control 1 ..... 88
Register 188 (0xBC): Port 1 Queue 1 Egress Limit Control 2 ..... 88
Register 204 (0xCC): Port 2 Queue 1 Egress Limit Control 2 ..... 88
Register 220 (0xDC): Port 3 Queue 1 Egress Limit Control 2 ..... 88
Register 236 (0xEC): Port 4 Queue 1 Egress Limit Control 2 ..... 88
Register 252 (0xFC): Port 5 Queue 1 Egress Limit Control 2 ..... 88
Register 189 (0xBD): Port 1 Queue 2 Egress Limit Control 3 ..... 89
Register 205 (0xCD): Port 2 Queue 2 Egress Limit Control 3 ..... 89
Register 221 (0xDD): Port 3 Queue 2 Egress Limit Control 3 ..... 89
Register 237 (0xED): Port 4 Queue 2 Egress Limit Control 3 ..... 89
Register 253 (0xFD): Port 5 Queue 2 Egress Limit Control 3 ..... 89
Register 190 (0xBE): Port 1 Queue 3 Egress Limit Control 4 ..... 89
Register 206 (0xCE): Port 2 Queue 3 Egress Limit Control 4 ..... 89
Register 222 (0xDE): Port 3 Queue 3 Egress Limit Control 4 ..... 89
Register 238 (0xEE): Port 4 Queue 3 Egress Limit Control 4 ..... 89
Register 254 (0xFE): Port 5 Queue 3 Egress Limit Control 4 ..... 89
Register 191(0xBF): Testing Register ..... 91
Register 207(0xCF): Reserved Control Register ..... 91
Register 223(0xDF): Test Register 2 ..... 91
Register 239(0xEF): Test Register 3 ..... 91
Register 255(0xFF): Testing Register4 ..... 91
Static MAC Address Table ..... 92
VLAN Table ..... 94
Dynamic MAC Address Table ..... 96
Management Information Base (MIB) Counters ..... 98
Port 1 MIB Counter Indirect Memory Offsets ..... 98
Format of "Per port" MIB Counter ..... 99
MIIM Registers ..... 102
Register Oh: MII Control ..... 102
Register 1h: MII Status ..... 103
Register 2h: PHYID HIGH ..... 103
Register 3h: PHYID LOW ..... 103
Register 4h: Advertisement Ability ..... 104
Register 5h: Link Partner Ability ..... 104
Register 1dh: LinkMD Control/Status ..... 105
Register 1fh: PHY Special Control/Status ..... 105
Absolute Maximum Ratings ..... 107
Operating Ratings ..... 107
Electrical Characteristics ..... 107
Timing Diagrams ..... 109
EEPROM Timing ..... 109
SNI Timing ..... 110
SPI Timing ..... 113
Auto-Negotiation Timing ..... 115
Reset Timing ..... 116
Reset Circuit Diagram. ..... 117
Isolation Transformer Selection ..... 118
Reference Crystal Selection ..... 118
Package Information ..... 119

## List of Figures

Figure 1. Typical Straight Cable Connection ................................................................................................................... 26
Figure 2. Typical Crossover Cable Connection ............................................................................................................... 27
Figure 3. Auto-Negotiation ............................................................................................................................................. 28
Figure 4. Destination Address Lookup Flow Chart (Stage 1) .......................................................................................... 34
Figure 5. Destination Address Resolution Flow Chart (Stage 2) ...................................................................................... 35
Figure 6. 802.1p Priority Field Format ............................................................................................................................ 39
Figure 7. Tail Tag Frame Format ................................................................................................................................... 41
Figure 8. KSZ8895MLUB EEPROM Configuration Timing Diagram ................................................................................ 46
Figure 9. SPI Write Data Cycle ....................................................................................................................................... 47
Figure 10. SPI Read Data Cycle .................................................................................................................................... 47
Figure 11. SPI Multiple Write .......................................................................................................................................... 48
Figure 12. SPI Multiple Read .......................................................................................................................................... 48
Figure 13. EEPROM Interface Input Receive Timing Diagram...................................................................................... 109
Figure 14. EEPROM Interface Output Transmit Timing Diagram................................................................................... 109
Figure 15. SNI Input Timing ......................................................................................................................................... 110
Figure 16. SNI Output Timing ...................................................................................................................................... 110
Figure 17. MAC Mode MII Timing - Data Received from MII ......................................................................................... 111
Figure 18. MAC Mode MII Timing - Data Transmitted from MII ..................................................................................... 111
Figure 19. PHY Mode MII Timing - Data Received from MII......................................................................................... 112
Figure 20. PHY Mode MII Timing - Data Transmitted from MII...................................................................................... 112
Figure 21. SPI Input Timing ......................................................................................................................................... 113
Figure 22. SPI Output Timing...................................................................................................................................... 114
Figure 23. Auto-Negotiation Timing .............................................................................................................................. 115
Figure 24. Reset Timing............................................................................................................................................... 116
Figure 25. Recommended Reset Circuit....................................................................................................................... 117
Figure 26. Recommended Circuit for Interfacing with CPU/FPGA Reset....................................................................... 117
List of Tables
Table 1. MDI/MDI-X Pin Definitions ..... 26
Table 2. Internal Function Block Status ..... 31
Table 3. Switch MAC 5 MII Signals ..... 37
Table 4. SNI Signals ..... 38
Table 5. Tail Tag Rules ..... 42
Table 6. FID+DA Look-Up in the VLAN Mode ..... 43
Table 7. FID+SA Look-Up in the VLAN Mode ..... 44
Table 8. SPI Connections ..... 47
Table 9. MII Management Interface Frame Format ..... 49
Table 10. Serial Management Interface (SMI) Frame Format ..... 49
Table 11. Data Rate Selection in 100BT ..... 90
Table 12. Data Rate Selection in 10BT ..... 90
Table 13. Format of Static MAC Table for Read (32 Entries) ..... 92
Table 14. Format of Static MAC Table for Writes (32 Entries) ..... 93
Table 15. Format of Static VLAN Table (Support Max 4096 VLAN ID Entries and 128 Active VLANs). ..... 94
Table 16. VLAN ID and Indirect Registers ..... 95
Table 17. Format of Dynamic MAC Address Table (1K Entries) ..... 96
Table 18. All Port Dropped Packet MIB Counters ..... 99
Table 19. Format of All Dropped Packet MIB Counters ..... 100
Table 20. EEPROM Timing Parameters ..... 109
Table 21. SNI Timing Parameters. ..... 110
Table 22. MAC Mode MII Timing Parameters ..... 111
Table 23. PHY Mode MII Timing Parameters ..... 112
Table 24. SPI Input Timing Parameters. ..... 113
Table 25. SPI Output Timing Parameters ..... 114
Table 26. Auto-Negotiation Timing Parameters ..... 115
Table 27. Reset Timing Parameters ..... 116
Table 28. Transformer Selection Criteria ..... 118
Table 29. Qualified Magnetic Vendors ..... 118
Table 30. Typical Reference Crystal Characteristics ..... 118

## Pin Configuration



128-Pin LQFP

## Pin Description

| Pin Number | Pin Name | Type ${ }^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |
| :---: | :---: | :---: | :---: | :---: |
| 1 | MDI-XDIS | Ipd | 1-5 | Disable auto MDI/MDI-X. <br> PD (default) = normal operation. <br> PU = disable auto MDI/MDI-X on all ports. |
| 2 | GNDA | GND |  | Analog ground. |
| 3 | VDDAR | P |  | 1.2 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 4 | RXP1 | 1 | 1 | Physical receive signal + (differential). |
| 5 | RXM1 | 1 | 1 | Physical receive signal - (differential). |
| 6 | GNDA | GND |  | Analog ground. |
| 7 | TXP1 | $\bigcirc$ | 1 | Physical transmit signal + (differential). |
| 8 | TXM1 | 0 | 1 | Physical transmit signal - (differential). |
| 9 | VDDAT | P |  | 3.3 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 10 | RXP2 | 1 | 2 | Physical receive signal + (differential). |
| 11 | RXM2 | 1 | 2 | Physical receive signal - (differential). |
| 12 | GNDA | GND |  | Analog ground. |
| 13 | TXP2 | O | 2 | Physical transmit signal + (differential). |
| 14 | TXM2 | 0 | 2 | Physical transmit signal - (differential). |
| 15 | VDDAR | P |  | 1.2 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 16 | GNDA | GND |  | Analog ground. |
| 17 | ISET |  |  | Set physical transmit output current. Pull-down with a $12.4 \mathrm{k} \Omega 1 \%$ resistor. |
| 18 | VDDAT | P |  | 3.3 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 19 | RXP3 | 1 | 3 | Physical receive signal + (differential). |
| 20 | RXM3 | 1 | 3 | Physical receive signal - (differential). |
| 21 | GNDA | GND |  | Analog ground. |
| 22 | TXP3 | 0 | 3 | Physical transmit signal + (differential). |
| 23 | TXM3 | 0 | 3 | Physical transmit signal - (differential). |
| 24 | VDDAT | P |  | 3.3 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 25 | RXP4 | 1 | 4 | Physical receive signal + (differential). |
| 26 | RXM4 | 1 | 4 | Physical receive signal - (differential). |
| 27 | GNDA | GND |  | Analog ground. |
| 28 | TXP4 | $\bigcirc$ | 4 | Physical transmit signal + (differential). |
| 29 | TXM4 | $\bigcirc$ | 4 | Physical transmit signal - (differential). |
| 30 | GNDA | GND |  | Analog ground. |
| 31 | VDDAR | P |  | 1.2 V analog $\mathrm{V}_{\mathrm{DD}}$. |
| 32 | NC | NC |  | No connect. |
| 33 | NC | NC |  | No connect. |
| 34 | GNDA | GND |  | Analog ground. |
| 35 | NC | NC |  | No connect. |
| 36 | NC | NC |  | No connect. |
| 37 | VDDAT | P |  | 3.3 V analog $\mathrm{V}_{\mathrm{DD}}$. |

## Pin Description (Continued)

| Pin Number | Pin Name | Type ${ }^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |
| :---: | :---: | :---: | :---: | :---: |
| 38 | NC | NC |  | No connect. |
| 39 | NC | NC |  | No connect. |
| 40 | NC | NC |  | No connect. |
| 41 | NC | NC |  | No connect. |
| 42 | NC | NC |  | No connect. |
| 43 | NC | NC |  | No connect. |
| 44 | NC | NC |  | No connect. |
| 45 | NC | NC |  | No connect. |
| 46 | NC | NC |  | No connect. |
| 47 | PWRDN_N | Ipu |  | Full-chip power down. Active low. |
| 48 | INTR_N | Opu |  | Interrupt. This pin is Open-Drain output pin. |
| 49 | GNDD | GND |  | Digital ground. |
| 50 | VDDC | P |  | 1.2 V digital core $\mathrm{V}_{\mathrm{DD}}$. |
| 51 | PMTXEN | Ipd | 5 | Reserved for MLUB. No connect. |
| 52 | PMTXD3 | Ipd | 5 | Reserved for MLUB. No connect. |
| 53 | PMTXD2 | Ipd | 5 | Reserved for MLUB. No connect. |
| 54 | PMTXD1 | Ipd | 5 | Reserved for MLUB. No connect. |
| 55 | PMTXD0 | Ipd | 5 | Reserved for MLUB. No connect. |
| 56 | PMTXER | Ipd | 5 | Reserved for MLUB. No connect. |
| 57 | PMTXC | I/O | 5 | Reserved for MLUB. No connect. |
| 58 | GNDD | GND |  | Digital ground. |
| 59 | VDDIO | P |  | 3.3 V , 2.5 V or 1.8 V digital $\mathrm{V}_{\mathrm{DD}}$ for digital I/O circuitry. |
| 60 | PMRXC | I/O | 5 | Reserved for MLUB. No connect. |
| 61 | PMRXDV | Ipd/O | 5 | Reserved for MLUB. No connect. |
| 62 | PMRXD3 | Ipd/O | 5 | Reserved for MLUB. <br> Strap option: <br> PD (default) = enable flow control. <br> PU = disable flow control. |
| 63 | PMRXD2 | Ipd/O | 5 | Reserved for MLUB. <br> Strap option: <br> PD (default) = disable back pressure. <br> PU = enable back pressure. |
| 64 | PMRXD1 | Ipd/O | 5 | Reserved for MLUB. <br> Strap option: <br> PD (default) = drop excessive collision packets. <br> PU = does not drop excessive collision packets. |
| 65 | PMRXD0 | Ipd/O | 5 | Reserved for MLUB. <br> Strap option: <br> PD (default) = disable aggressive back-off algorithm in half-duplex mode. <br> PU = enable for performance enhancement. |
| 66 | PMRXER | Ipd/O | 5 | Reserved for MLUB. <br> Strap option: <br> PD (default) = 1522/1518 bytes; <br> $\mathrm{PU}=$ packet size up to 1536 bytes . |

## Pin Description (Continued)

| Pin Number | Pin Name | Type ${ }^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |
| :---: | :---: | :---: | :---: | :---: |
| 67 | PCRS | Ipd/O | 5 | Reserved for MLUB. <br> Strap option for port 4 only. <br> PD (default) = force half-duplex if auto-negotiation is disabled or fails. <br> PU = force full-duplex if auto negotiation is disabled or fails. Refer to Register 76. |
| 68 | PCOL | Ipd/O | 5 | Reserved for MLUB. <br> Strap option for port 4 only. <br> PD (default) = no force flow control, normal operation. <br> PU = force flow control. Refer to Register 66. |
| 69 | SMTXEN | Ipd |  | Port 5 Switch MII transmit enable. |
| 70 | SMTXD3 | Ipd |  | Port 5 Switch MII transmit bit 3. |
| 71 | SMTXD2 | Ipd |  | Port 5 Switch MII transmit bit 2. |
| 72 | SMTXD1 | Ipd |  | Port 5 Switch MII transmit bit 1. |
| 73 | SMTXD0 | Ipd |  | Port 5 Switch MII transmit bit 0. |
| 74 | SMTXER | Ipd |  | Port 5 Switch MII transmit error. |
| 75 | SMTXC | I/O |  | Port 5 Switch MII transmit clock: Input: SW5-MII MAC mode. Output: SW5-MII PHY modes. |
| 76 | GNDD | GND |  | Digital ground. |
| 77 | VDDIO | P |  | $3.3 \mathrm{~V}, 2.5 \mathrm{~V}$ or 1.8 V digital $\mathrm{V}_{\mathrm{DD}}$ for digital I/O circuitry. |
| 78 | SMRXC | I/O |  | Port 5 Switch MII receive clock: Input: SW5-MII MAC mode. Output: SW5-MII PHY mode. |
| 79 | SMRXDV | Ipd/O |  | Switch MII receive data valid. |
| 80 | SMRXD3 | Ipd/O |  | Port 5 Switch MII receive bit 3. <br> Strap option: <br> PD (default) = Disable Switch SW5-MII full-duplex flow control <br> PU = Enable Switch SW5-MII full-duplex flow control. |
| 81 | SMRXD2 | Ipd/O |  | Port 5 Switch MII receive bit 2. <br> Strap option: <br> PD (default) = Switch SW5-MII in full-duplex mode; <br> PU = Switch SW5-MII in half-duplex mode. |
| 82 | SMRXD1 | Ipd/O |  | Port 5 Switch MII receive bit 1. <br> Strap option: <br> PD (default) =Port 5 Switch SW5-MII in 100Mbps mode; SW5-TMII in 200Mbps mode. <br> PU = Switch SW5-MII in 10Mbps mode. |
| 83 | SMRXD0 | Ipd/O |  | Port 5 Switch MII receive bit 0. <br> Strap option: LED mode <br> PD (default) = mode 0; PU = mode 1. See "Register 11." <br> Mode 0, link at |
|  |  |  |  | Mode 0 Mode 1 |
|  |  |  |  | LEDX_2 |
|  |  |  |  | LEDX_1 |
|  |  |  |  |  |
| 84 | SCOL | Ipd/O |  | Port 5 Switch MII collision detect: Input: SW5-MII MAC modes. Output: SW5-MII PHY modes. |

## Pin Description (Continued)

| Pin Number | Pin Name | Type ${ }^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 85 | SCRS | Ipd/O |  | Port 5 Switch MII modes carrier sense: Input: SW5-MII MAC modes. Output: SW5-MII PHY modes. |  |
| 86 | SCONF1 | Ipd |  | Pin 91,86,87 are dual MII configuration pins for the Port5 MAC5 MII. SW5-MII supports both MAC mode and PHY modes. |  |
|  |  |  |  | Pin\#: (91, 86, 87) | Port5 Switch MAC5 SW5- MII |
|  |  |  |  | 000 | Disable, Otri |
|  |  |  |  | 001 | PHY Mode MII |
|  |  |  |  | 010 | MAC Mode MII |
|  |  |  |  | 011 | PHY Mode SNI |
|  |  |  |  | 100 | Disable (Default) |
|  |  |  |  | 101 | PHY Mode MII |
|  |  |  |  | 110 | MAC Mode MII |
|  |  |  |  | 111 | PHY Mode SNI |
| 87 | SCONFO | Ipd |  | Dual MII configuration pin. See pin 86 descriptions. |  |
| 88 | GNDD | GND |  | Digital ground. |  |
| 89 | VDDC | P |  | 1.2 V digital core $\mathrm{V}_{\mathrm{DD}}$. |  |
| 90 | LED5-2 | Ipu/O | 5 | ```Reserved for MLUB Strap option: aging setup. See "Aging" section. PU (default) = Aging enable \(\mathrm{PD}=\) Aging disable.``` |  |
| 91 | LED5-1 | Ipu/O | 5 | Reserved for MLUB <br> Strap option: <br> PU (default): enable PHY[5] MII I/F. <br> PD: tristate and disable all PHY[5] MII output. (Design should pull this pin down as default for MLUB. |  |
| 92 | LED5-0 | Ipu/O | 5 | ```Reserved for MLUB Strap option for port 4 only. PU (default) = Enable auto-negotiation. PD = Disable auto-negotiation. Strap to register76 bit[7].``` |  |
| 93 | LED4-2 | Ipu/O | 4 | LED indicator 2. |  |
| 94 | LED4-1 | Ipu/O | 4 | LED indicator 1. |  |
| 95 | LED4-0 | Ipu/O | 4 | LED indicator 0. <br> Strap option: <br> PU (default) = Normal mode. <br> PD = Energy Detection mode (EDPD mode). <br> Strap to register 14 bits[4:3] |  |
| 96 | LED3-2 | Ipu/O | 3 | LED indicator 2. |  |
| 97 | LED3-1 | Ipu/O | 3 | LED indicator 1. |  |
| 98 | LED3-0 | Ipu/O | 3 | LED indicator 0. <br> Strap option: <br> PU (default) = Select I/O drive strength (8mA); <br> PD = Select I/O drive strength (12mA). <br> Strap to register132 bit[7-6]. |  |
| 99 | GNDD | GND |  | Digital ground. |  |
| 100 | VDDIO | P |  | $3.3 \mathrm{~V}, 2.5 \mathrm{~V}$ or 1.8 V digital $\mathrm{V}_{\mathrm{DD}}$ for digital I/O circuitry. |  |
| 101 | LED2-2 | Ipu/O | 2 | LED indicator 2. |  |

Pin Description (Continued)

| Pin Number | Pin Name | Type ${ }^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |
| :---: | :---: | :---: | :---: | :---: |
| 102 | LED2-1 | Ipu/O | 2 | LED indicator 1. <br> Strap option: for port 3 only. <br> PU (default) = Enable auto-negotiation. <br> PD = Disable auto-negotiation. Strap to register60 bit[7]. |
| 103 | LED2-0 | Ipu/O | 2 | LED indicator 0. |
| 104 | LED1-2 | Ipu/O | 1 | LED indicator 2. |
| 105 | LED1-1 | Ipu/O | 1 | LED indicator 1. <br> Strap option: for port 3 only. <br> PU (default) = no force flow control, normal operation. <br> PD = force flow control. Strap to register60 bit[4]. |
| 106 | LED1-0 | Ipu/O | 1 | LED indicator 0. <br> Strap option for port 3 only. <br> PU (default) = force half-duplex if auto-negotiation is disabled or fails. <br> $P D=$ force full-duplex if auto negotiation is disabled or fails. <br> Strap to register60 bit[5]. |
| 107 | MDC | Ipu | All | Switch MII management data clock. Or SMI interface clock. |
| 108 | MDIO | Ipu/O | All | Switch MII management data I/O. Or SMI interface data I/O. Features internal pull down to define pin state when not driven. Need an external pull-up when driven. |
| 109 | SPIQ | Ipu/O | All | SPI serial data output in SPI slave mode. |
| 110 | SPIC/SCL | Ipu/O | All | SPI slave mode: clock input <br> (1) Input clock up to 25 MHz in SPI slave mode, <br> (2) output clock at 61 kHz in $\mathrm{I}^{2} \mathrm{C}$ master mode. See "Pin 113." |
| 111 | SSPID/SDA | Ipu/O | All | SPI slave mode: serial data input. <br> (1) Serial data input in SPI slave mode; <br> (2) Serial data input/output in $I^{2} C$ master mode. See "Pin 113." |
| 112 | SPIS_N | Ipu | All | SPI slave mode: chip select (active low). <br> (1) SPI data transfer start in SPI slave mode. When SPIS_N is high, the KSZ8895MLUB is deselected and SPIQ is held in high impedance state, a high-to-low transition to initiate the SPI data transfer. <br> (2) not used in I ${ }^{2} \mathrm{C}$ master mode. |
| 113 | PS1 | Ipd |  | Serial bus configuration pin. <br> For this case, if the EEPROM is not present, the KSZ8895MLUB will start itself with the PS[1.0] = 00 default register values. |
|  |  |  |  | Pin Configuration Serial Bus Configuration |
|  |  |  |  | PS[1.0]=00 ${ }^{\text {a }}$ 2 C Master Mode for EEPROM |
|  |  |  |  | PS[1.0]=01 SMI Interface Mode |
|  |  |  |  | PS[1.0]=10 SPI Slave Mode for CPU Interface |
|  |  |  |  | PS[1.0]=11 $\quad$ Factory Test Mode (BIST) |
| 114 | PSO | Ipd |  | Serial bus configuration pin. See "Pin 113." |
| 115 | RST_N | Ipu |  | Reset the KSZ8895MLUB device. Active low. |
| 116 | GNDD | GND |  | Digital ground. |
| 117 | VDDC | P |  | 1.2V digital core $\mathrm{V}_{\mathrm{DD}}$. |
| 118 | TESTEN | Ipd |  | NC for normal operation. Factory test pin. |
| 119 | SCANEN | Ipd |  | NC for normal operation. Factory test pin. |
| 120 | NC | NC |  | No connect. |

## Pin Description (Continued)

| Pin Number | Pin Name | Type $^{(1)}$ | Port | Pin Function ${ }^{(2)}$ |
| :---: | :---: | :---: | :---: | :--- |
| 121 | X1 | I |  | 25MHz crystal clock connection/or 3.3V Oscillator input. Crystal/Oscillator <br> should be $\pm 50$ ppm tolerance. |
| 122 | X2 | O |  | 25 MHz crystal clock connection. |
| 123 | NC | NC |  | No connect. |

## Notes:

1. $P=$ Power supply.

I = Input.
$\mathrm{O}=$ Output.
I/O = Bidirectional.
GND = Ground.
Ipu = Input w/internal pull-up.
Ipd = Input w/internal pull-down.
$\mathrm{Ipd} / \mathrm{O}=$ Input w/internal pull-down during reset, output pin otherwise.
Ipu/O = Input w/internal pull-up during reset, output pin otherwise.
NC = No connect.
2. $\mathrm{PU}=$ Strap pin pull-up.

PD = Strap pull-down.
OTRI = Output tristated.

## Pin for Strap-In Options

The KSZ8895MLUB can function as a managed switch or unmanaged switch. If no EEPROM or micro-controller exists, the KSZ8895MLUB will operate from its default setting. The strap-in option pins can be configures by external pullup/down resistors and take the effect after power-down reset or warm reset, the functions are described in the following tables.


## Pin for Strap-In Options (Continued)

| Pin Number | Pin Name | PU/PD ${ }^{(1)}$ | Description ${ }^{(2)}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| 86 | SCONF1 | Ipd | Pins 91, 86, 87 are dual MII configuration pins for the Port5 MAC5 MII. SW5-MII supports both MAC mode and PHY modes. |  |
|  |  |  | Pin\#: $(91,86,87)$ | Port5 Switc |
|  |  |  | 000 |  |
|  |  |  | 001 | PH |
|  |  |  | 010 | MA |
|  |  |  | 011 | PHY |
|  |  |  | 100 |  |
|  |  |  | 101 | PH |
|  |  |  | 110 | MA |
|  |  |  | 111 | PHY |
| 87 | SCONFO | Ipd | Dual MII configuration pin. See pin 86 descriptions. |  |
| 90 | LED5-2 | Ipu/O | $\begin{aligned} & \text { Strap option: Aging setup. See "Aging" section } \\ & \text { PU (default) = aging enable; } \\ & \text { PD = aging disable. } \\ & \hline \end{aligned}$ |  |
| 91 | LED5-1 | Ipu/O | Strap option: <br> PU (default): enable PHY[5] MII I/F. <br> PD: tristate all PHY[5] MII output. See "Pin 86 SCONF1." |  |
| 92 | LED5-0 | Ipu/O | Strap option for port 4 only. <br> PU (default) = Enable auto-negotiation. <br> PD = Disable auto-negotiation. Strap to register76 bit[7] |  |
| 95 | LED4-0 | Ipu/O | LED indicator 0. <br> Strap option: <br> PU (default) = Normal mode. <br> PD = Energy Detection mode (EDPD mode). <br> Strap to register 14 bits[4:3] |  |
| 98 | LED3-0 | Ipu/O | LED3 indicator 0. <br> Strap option: <br> PU (default) = Select I/O current drive strength (8mA); <br> PD = Select I/O current drive strength (12mA). <br> Strap to register132 bit[7:6]. |  |
| 102 | LED2-1 | Ipu/O | LED2 indicator 1. <br> Strap option for port 3 only. <br> PU (default) = Enable auto-negotiation. <br> PD = Disable auto-negotiation. <br> Strap to register60 bit[7] |  |
| 105 | LED1-1 | Ipu/O | LED1 indicator 1. <br> Strap option for port 3 only. <br> PU (default) = no force flow control, normal operation. <br> PD = force flow control. Strap to register50 bit[4] |  |

## Pin for Strap-In Options (Continued)

| Pin Number | Pin Name | PU/PD ${ }^{(1)}$ | Description ${ }^{(2)}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| 106 | LED1-0 | Ipu/O | LED1 indicator 0. <br> Strap option for port 3 only. <br> PU (default) = force half-duplex if auto-negotiation is disabled or fails. $P D=$ force full-duplex if auto negotiation is disabled or fails. <br> Strap to register60 bit[5]. |  |
| 113 | PS1 | Ipd | Serial bus configuration pin. For this case, if the EEPROM is not present, the KSZ8895MLUB will start itself with the PS[1:0] =00 default register values. |  |
|  |  |  | Pin Configuration | Serial Bus Configuration |
|  |  |  | PS[1:0]=00 | $1^{2} \mathrm{C}$ Master Mode for EEPROM |
|  |  |  | PS[1:0]=01 | SMI Interface Mode |
|  |  |  | PS[1:0]=10 | SPI Slave Mode for CPU Interface |
|  |  |  | PS[1:0]=11 | Factory Test Mode (BIST) |
| 114 | PS0 | Ipd | Serial bus configuration pin. See "Pin 113." |  |

## Notes:

1. $\quad$ Ipu $=$ Input w/internal pull-up.
$\mathrm{Ipd}=$ Input w/internal pull-down.
Ipd/O = Input w/internal pull-down during reset, output pin otherwise.
Ipu/O = Input w/internal pull-up during reset, output pin otherwise.
2. $\mathrm{PU}=$ Strap pin pull-up.

PD = Strap pull-down.

## Introduction

The KSZ8895MLUB contains four 10/100 physical layer transceivers and five media access control (MAC) units with an integrated Layer 2 managed switch. The device runs in two modes. The first mode is as a 4-port integrated switch. The second is as a 4-port switch with the fifth MAC. In this mode, access to the fifth MAC is provided through a media independent interface (MII).
The KSZ8895MLUB has the flexibility to reside in a managed or unmanaged design. In a managed design, a host processor has complete control of the KSZ8895MLUB via the SPI bus, or via the MDC/MDIO interface with SMI mode. An unmanaged design is achieved through I/O strapping or EEPROM programming at system reset time.
On the media side, the KSZ8895MLUB supports IEEE 802.3 10BASE-T, 100BASE-TX on all ports with Auto MDI/MDIX. The KSZ8895MLUB can be used as fully-managed 4-port standalone switch or hook up to microprocessor by its SW-MII interface for an application solution.
Physical signal transmission and reception are enhanced through the use of patented analog circuitry that makes the design more efficient and allows for lower power consumption and smaller chip die size.
There are a number of major enhancements from the KS8995MA to the KSZ8895MLUB. These include: more host interface options, four queues prioritization, tag as well as port based VLAN, rapid spanning tree support, IGMP snooping support, port mirroring support and more flexible rate limiting and filtering functionality.

## Physical Layer Transceiver

## 100BASE-TX Transmit

The 100BASE-TX transmit function performs parallel-to-serial conversion, 4B/5B coding, scrambling, NRZ-to-NRZI conversion, MLT3 encoding and transmission. The circuit starts with a parallel-to-serial conversion, which converts the MII data from the MAC into a 125 MHz serial bit stream. The data and control stream is then converted into $4 B / 5 B$ coding followed by a scrambler. The serialized data is further converted from NRZ-to-NRZI format, and then transmitted in MLT3 current output. The output current is set by an external $1 \% 12.4 \mathrm{k} \Omega$ resistor for the $1: 1$ transformer ratio. It has a typical rise/fall time of 4 ns and complies with the ANSI TP-PMD standard regarding amplitude balance, overshoot, and timing jitter. The wave-shaped 10BASE-T output is also incorporated into the 100BASE-TX transmitter.

## 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 length of the cable, the equalizer has to adjust its characteristics to optimize the performance. In this design, the variable equalizer will make an initial estimation based on comparisons of incoming signal strength against some known cable characteristics, then tunes itself for optimization. This is an ongoing process and can self-adjust against environmental changes such as temperature variations.
The equalized signal then goes through a DC restoration and data conversion block. The DC restoration circuit is used to compensate for the effect of baseline wander and 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 125 MHz clock from the edges of the NRZI signal. This recovered clock is then used to convert the NRZI signal into the NRZ format. The signal is then sent through the de-scrambler followed by the 4B/5B decoder. Finally, the NRZ serial data is converted to the MII format and provided as the input data to the MAC.

## PLL Clock Synthesizer

The KSZ8895MLUB generates $125 \mathrm{MHz}, 83 \mathrm{MHz}, 41 \mathrm{MHz}, 25 \mathrm{MHz}$ and 10 MHz clocks for system timing. Internal clocks are generated from an external 25 MHz crystal or oscillator.

## Scrambler/De-Scrambler (100BASE-TX Only)

The purpose of the scrambler is to spread the power spectrum of the signal in order to reduce EMI and baseline wander. The data is scrambled through the use of an 11-bit wide linear feedback shift register (LFSR). This can generate a 2047bit non-repetitive sequence. The receiver will then de-scramble the incoming data stream with the same sequence at the transmitter.

## 10BASE-T Transmit

The output 10BASE-T driver is incorporated into the 100BASE-T driver to allow transmission with the same magnetics. They are internally wave-shaped and pre-emphasized into outputs with typical 2.3 V amplitude. The harmonic contents are at least 27 dB below the fundamental when driven by an all-ones Manchester-encoded signal.

## 10BASE-T Receive

On the receive side, input buffer and level detecting squelch circuits are employed. A differential input receiver circuit and a 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 400 mV or with short pulse widths in order to prevent noises at the RXP or RXM input from falsely triggering the decoder. When the input exceeds the squelch limit, the PLL locks onto the incoming signal and the KSZ8895MLUB decodes a data frame. The receiver clock is maintained active during idle periods in between data reception.

## MDIIMDI-X Auto Crossover

To eliminate the need for crossover cables between similar devices, the KSZ8895MLUB supports HP Auto MDI/MDI-X and IEEE 802.3 u 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 transmit and receive pairs for the KSZ8895MLUB device. This feature is extremely useful when end users are unaware of cable types, and also, saves on an additional uplink configuration connection. The auto-crossover feature can be disabled through the port control registers, or MIIM PHY registers. The IEEE 802.3 u standard MDI and MDI-X definitions are highlighted in Table 1:

Table 1. MDI/MDI-X Pin Definitions

| MDI |  | MDI-X |  |
| :---: | :---: | :---: | :---: |
| RJ-45 Pins | Signals | RJ-45 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 depicts a typical straight cable connection between a NIC card (MDI) and a switch, or hub (MDI-X).


Figure 1. Typical Straight Cable Connection

## 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 switches or hubs (two MDI-X devices).


Figure 2. Typical Crossover Cable Connection

## Auto-Negotiation

The KSZ8895MLUB conforms to the auto-negotiation protocol as described by the 802.3 committee. Auto-negotiation allows unshielded twisted pair (UTP) link partners to select the highest common mode of operation. Link partners advertise their capabilities 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.
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 KSZ8895MLUB link partner is forced to bypass auto-negotiation, the KSZ8895MLUB sets its operating mode by observing the signal at its receiver. This is known as parallel detection, and allows the KSZ8895MLUB to establish link by listening for a fixed signal protocol in the absence of auto-negotiation advertisement protocol. The auto-negotiation link-up process is shown in Figure 3.


Figure 3. Auto-Negotiation

## LinkMD ${ }^{\circledR}$ Cable Diagnostics

The LinkMD ${ }^{\circledR}$ feature utilizes time domain reflectometry (TDR) to analyze the cabling plant for common cabling problems such as open circuits, short circuits and impedance mismatches.
LinkMD ${ }^{\circledR}$ 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 maximum distance of 200 m and accuracy of $\pm 2 \mathrm{~m}$. Internal circuitry displays the TDR information in a user-readable digital format.
Note: Cable diagnostics are only valid for copper connections and do not support fiber optic operation.

## Access

LinkMD ${ }^{\circledR}$ is initiated by accessing the PHY special control/status Registers $\{26,42,58,74,90\}$ and the LinkMD result Registers $\{27,43,59,75,91\}$ for ports $1,2,3,4$ and 5 respectively; and in conjunction with the Registers Port Control 12 and 13 for ports $1,2,3,4$ and 5 respectively to disable Auto-Negotiation and Auto MDI/MDIX.
Alternatively, the MIIM PHY Registers 0 and $1 d$ can be used for LinkMD ${ }^{\circledR}$ access also.

## Usage

The following is a sample procedure for using $\operatorname{LinkMD}{ }^{\circledR}$ with Registers $\{26,27,28,29\}$ on port 1.

1. Disable Auto-Negotiation by writing a ' 1 ' to Register 28 (0x1c), bit [7].
2. Disable auto MDI/MDI-X by writing a ' 1 ' to Register 29 ( $0 \times 1 \mathrm{~d}$ ), bit [2] to enable manual control over the differential pair used to transmit the LinkMD ${ }^{\circledR}$ pulse.
3. A software sequence set up to the internal registers for LinkMD only, see an example below.
4. Start cable diagnostic test by writing a ' 1 ' to Register 26 ( $0 \times 1 \mathrm{a}$ ), bit [4]. This enable bit is self-clearing.
5. Wait (poll) for Register 26 ( $0 \times 1 \mathrm{a}$ ), bit [4] to return a ' 0 ', and indicating cable diagnostic test is completed.
6. Read cable diagnostic test results in Register 26 ( $0 \times 1 \mathrm{a}$ ), bits [6:5]. The results are as follows:
$00=$ normal condition $($ valid test $)$
$01=$ open condition detected in cable $($ valid test $)$
$10=$ short condition detected in cable (valid test)
$11=$ cable diagnostic test failed (invalid test)

The '11' case, invalid test, occurs when the KSZ8895 is unable to shut down the link partner. In this instance, the test is not run, since it would be impossible for the KSZ8895 to determine if the detected signal is a reflection of the signal generated or a signal from another source.
7. Get distance to fault by concatenating Register 26 ( $0 \times 1 \mathrm{a}$ ), bit [0] and Register 27 ( $0 \times 1 \mathrm{~b}$ ), bits [7:0]; and multiplying the result by a constant of 0.4. The distance to the cable fault can be determined by the following formula:

## $D($ distance to cable fault $)=0.4 \times\{($ Register 26, bit [0]),(Register 27, bits [7:0]) \}

D (distance to cable fault) is expressed in meters.
Concatenated value of Registers 26 bit [0] and 27 bit [7:0] should be converted to decimal before decrease 26 and multiplying by 0.4.

The constant (0.4) may be calibrated for different cabling conditions, including cables with a velocity of propagation that varies significantly from the norm.
For port 2, 3, 4, 5 and for the MIIM PHY registers, LinkMD ${ }^{\circledR}$ usage is similar.

## A LinkMD example

The following is a sample procedure for using LinkMD ${ }^{\circledR}$ on port 1.
//Set Force 100/Full and Force MDIX mode
I/W is WRITE the register. R is READ register
W 1c ff
W 1d 04
//Set Internal Registers Temporary Adjustment for LinkMD
W 47 b0
W 2700
W 3703 (03-port 1, 04-port2, 05-port3, 06-port4, 07-port5)
W 4780 (bit7-port1, bit6-port2, bit5-port3, bit4-port4, bit3-port5)
W 2700
W 3700
//Enable LinkMD Testing with Fault Cable for port 1
W 1a 10
R1a
R 1b
//Result analysis based on the values of the Register 0x1a and 0x1b for port 1:
//The Register 0x1a bits [6-5] are for the open or the short detection.
//The Register 0x1a bit [0] + the Register 0x1b bits [7-0] = Vct_Fault [8-0]
//The distance to fault is about $0.4 \times\{$ Vct_Fault [8-0] - 26\}
Note:
After end the testing, set all registers above to their default value, the default values are ' 00 ' for the Register ( $0 \times 37$ ) and the Register ( $0 \times 47$ )

## On-Chip Termination Resistors

The KSZ8895MLUB reduces board cost and simplifies board layout by using on-chip termination resistors for all ports and the RX/TX differential pairs without the external termination resistors. The solution of the on chip termination and internal biasing will save about $50 \%$ power consumption compare with using external biasing and termination resistors, and the transformer will not consume power any more.
Internal 1.2V LDO Controller
The KSZ8895MLUB reduces board cost and simplifies board layout by integrating an internal 1.2V LDO controller to drive a low cost MOSFET to supply the 1.2 V core power voltage for a single 3.3 V power supply solution.

## Power Management

The KSZ8895MLUB supports a full-chip hardware power-down mode. When PWRDN Pin 47 (Pin PWRDN $=0$ ) is activated low, the entire chip is powered down. If this pin is de-asserted, the chip will be internally reset.
The KSZ8895MLUB can also use multiple power level of $3.3 \mathrm{~V}, 2.5 \mathrm{~V}$ or 1.8 V for VDDIO to support different I/O voltage.
The KSZ8895MLUB supports enhanced power management feature in low power state with energy detection to ensure low-power dissipation during device idle periods. There are five operation modes under the power management function which is controlled by the register 14 bit [4:3] and the port register control 13 bit 3 as shown below:

- Register 14 bit [4:3] = 00 normal operation mode
- Register 14 bit [4:3] = 01 energy detect mode
- Register 14 bit [4:3] = 10 soft power down mode
- Register 14 bit [4:3] = 11 power saving mode
- Port register 29, 45, 61, 77, 93 Control 13 bit $3=1$ are for the port based power-down mode

Table 2 indicates all internal function blocks status under four different power management operation modes.

Table 2. Internal Function Block Status

| KSZ8895MLUB Function Blocks | Power Management Operation Modes |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Normal Mode | Power-Saving Mode | Energy Detect Mode | Soft Power-Down Mode |
| Internal PLL Clock | Enabled | Enabled | Disabled | Disabled |
| Tx/Rx PHY | Enabled | Rx unused block disabled | Energy detect at Rx | Disabled |
| MAC | Enabled | Enabled | Disabled | Disabled |
| Host Interface | Enabled | Enabled | Disabled | Disabled |

## Normal Operation Mode

This is the default setting bit [4:3] =00 in register 14 after the chip power-up or hardware reset. When KSZ8895MLUB is in this normal operation mode, all PLL clocks are running, PHY and MAC are on and the host interface is ready for CPU read or write.
During the normal operation mode, the host CPU can set the bit [4:3] in register 14 to transit the current normal operation mode to any one of the other three power management operation modes.

## Energy Detect Mode

The energy detect mode provides a mechanism to save more power than in the normal operation mode when the KSZ8895MLUB is not connected to an active link partner. In this mode, the device will save more power based on the regular less power consumption. If the cable is not plugged, the KSZ8895MLUB can automatically enter to a low power state, otherwise known as the energy detect mode. In this mode, KSZ8895MLUB will keep transmitting 120ns width pulses at 1 pulse/s rate. Once activity resumes due to plugging a cable or attempting by the far end to establish link, the KSZ8895MLUB can automatically power up to normal power state in energy detect mode.
Energy detect mode consists of two states, normal power state and low power state. While in low power state, the KSZ8895MLUB reduces power consumption by disabling all circuitry except the energy detect circuitry of the receiver. The energy detect mode is entered by setting bit [4:3] =01 in register 14. When the KSZ8895MLUB is in this mode, it will monitor the cable energy. If there is no energy on the cable for a time longer than pre-configured value at bit [7:0] GoSleep time in register 15, KSZ8895MLUB will go into a low power state. When KSZ8895MLUB is in low power state, it will keep monitoring the cable energy. Once the energy is detected from the cable, KSZ8895MLUB will enter normal power state. When KSZ8895MLUB is at normal power state, it is able to transmit or receive packet from the cable.

## Soft Power-Down Mode

The soft power-down mode is entered by setting bit $[4: 3]=10$ in register 14 . When KSZ8895MLUB is in this mode, all PLL clocks are disabled, also all of PHYs and the MACs are off. Any dummy host access will wake-up this device from current soft power-down mode to normal operation mode and internal reset will be issued to make all internal registers go to the default values.

## Power-Saving Mode

The power saving mode is entered when auto-negotiation mode is enabled, cable is disconnected, and by setting bit [4:3] $=11$ in register 14. When KSZ8895MLUB is in this mode, all PLL clocks are enabled, MAC is on, all internal registers value will not change, and host interface is ready for CPU read or write. In this mode, it mainly controls the PHY transceiver on or off based on line status to achieve power saving. The PHY remains transmitting and only turns off the unused receiver block. Once activity resumes due to plugging a cable or attempting by the far end to establish link, the KSZ8895MLUB can automatically enabled the PHY power up to normal power state from power saving mode.
During this power-saving mode, the host CPU can set bit [4:3] in register 14 to transit the current power saving mode to any one of the other three power management operation modes.

## Port-Based Power-Down Mode

In addition, the KSZ8895MLUB features a per-port power down mode. To save power, a PHY port that is not in use can be powered down via the port registers control 13 bit3, or MIIM PHY registers 0 bit11.

## Switch Core

## Address Look-Up

The internal look-up table stores MAC addresses and their associated information. It contains a 1 K unicast address table plus switching information. The KSZ8895MLUB is guaranteed to learn 1 K addresses and distinguishes itself from a hashbased look-up table, which depending on the operating environment and probabilities, may not guarantee the absolute number of addresses it can learn.

## Learning

The internal look-up engine updates its table with a new entry if the following conditions are met:

- The received packet's source address (SA) does not exist in the look-up table.
- The received packet is good; the packet has no receiving errors and is of legal length.

The look-up engine inserts the qualified SA into the table, along with the port number and time stamp. If the table is full, the last entry of the table is deleted first to make room for the new entry.

## Migration

The internal look-up engine also monitors whether a station is moved. If this occurs, it updates the 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 is good; the packet has no receiving errors and is of legal length.

The look-up engine will update the existing record in the table with the new source port information.

## Aging

The look-up engine will update 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 look-up engine will remove the record from the table. The look-up engine constantly performs the aging process and will continuously remove aging records. The aging period is $300 \pm 75$ seconds. This feature can be enabled or disabled through Register 3 or by external pull-up or pull-down resistors on LED[5][2].

## Forwarding

The KSZ8895MLUB will forward packets using an algorithm that is depicted in the following flowcharts. Figure 6 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 the spanning tree, IGMP snooping, port mirroring, and port VLAN processes to come up with "port to forward 2" (PTF2), as shown in Figure 7. This is where the packet will be sent.

## KSZ8895MLUB Will Not Forward the Following Packets:

- Error packets. These include framing errors, FCS errors, alignment errors, and illegal size packet errors.
- $802.3 x$ pause frames. The KSZ8895MLUB will intercept these packets and perform the appropriate actions.
- "Local" packets. Based on destination address (DA) look-up. If the destination port from the look-up table matches the port where the packet was from, the packet is defined as "local."


## Switching Engine

The KSZ8895MLUB 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 KSZ8895MLUB has a 64 kB internal frame buffer. This resource is shared between all five ports. There are a total of 512 buffers available. Each buffer is sized at 128B.

## Media Access Controller (MAC) Operation

The KSZ8895MLUB strictly abides by IEEE 802.3 standards to maximize compatibility.

## Inter-Packet Gap (IPG)

If a frame is successfully transmitted, the 96 -bit time IPG is measured between the two consecutive MTXEN. If the current packet is experiencing collision, the 96 -bit time IPG is measured from MCRS and the next MTXEN.

## Backoff Algorithm

The KSZ8895MLUB implements the IEEE Standard 802.3 binary exponential backoff algorithm, and optional "aggressive mode" backoff. After 16 collisions, the packet will be optionally dropped, depending on the chip configuration in Register 3. See "Register 3."

## Late Collision

If a transmit packet experiences collisions after 512-bit times of the transmission, the packet will be dropped.

## Illegal Frames

The KSZ8895MLUB discards frames less than 64 bytes and can be programmed to accept frames up to 1536 bytes in Register 4. For special applications, the KSZ8895MLUB can also be programmed to accept frames up to 1916 bytes in Register 4. Since the KSZ8895MLUB supports VLAN tags, the maximum sizing is adjusted when these tags are present.

## Flow Control

The KSZ8895MLUB supports standard 802.3x flow control frames on both transmit and receive sides.
On the receive side, if the KSZ8895MLUB receives a pause control frame, the KSZ8895MLUB will not transmit the next normal frame 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 period (being flow controlled), only flow control packets from the KSZ8895MLUB will be transmitted.
On the transmit side, the KSZ8895MLUB has intelligent and efficient ways to determine when to invoke flow control. The flow control is based on availability of the system resources, including available buffers, available transmit queues and available receive queues.
The KSZ8895MLUB flow controls a port that has just received a packet if the destination port resource is busy. The KSZ8895MLUB issues a flow control frame (XOFF), containing the maximum pause time defined in IEEE standard $802.3 x$. Once the resource is freed up, the KSZ8895MLUB sends out the other flow control frame (XON) with zero pause time to turn off the flow control (turn on transmission to the port). A hysteresis feature is also provided to prevent overactivation and deactivation of the flow control mechanism.
The KSZ8895MLUB flow controls all ports if the receive queue becomes full.


Figure 4. Destination Address Lookup Flow Chart (Stage 1)


Figure 5. Destination Address Resolution Flow Chart (Stage 2)

The KSZ8895MLUB will not forward the following packets:

1. Error packets

These include framing errors, Frame Check Sequence (FCS) errors, alignment errors, and illegal size packet errors.
2. IEEE802.3x PAUSE frames

KSZ8895MLUB intercepts these packets and performs full duplex flow control accordingly.
3. "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."

## Half-Duplex Back Pressure

The KSZ8895MLUB also provides a half-duplex back pressure option (note: this is not in IEEE 802.3 standards). The activation and deactivation conditions are the same as the ones given for full-duplex mode. If back pressure is required, the KSZ8895MLUB sends preambles to defer the other station's transmission (carrier sense deference). To avoid jabber and excessive deference as defined in IEEE 802.3 standards, after a certain period of time, the KSZ8895MLUB discontinues carrier sense but raises it quickly after it drops packets to inhibit other transmissions. This short silent time (no carrier sense) is to prevent other stations from sending out packets and keeps other stations in a carrier sensedeferred state. If the port has packets to send during a back pressure situation, the carrier sense-type back pressure is interrupted and those packets are transmitted instead. If there are no more packets to send, carrier sense-type back pressure becomes active again until switch resources are free. If a collision occurs, the binary exponential backoff algorithm is skipped and carrier sense is generated immediately, reducing the chance of further colliding and maintaining carrier sense to prevent reception of packets. To ensure no packet loss in 10BASE-T or 100BASE-TX half-duplex modes, the user must enable the following:

- Aggressive backoff (Register 3, bit 0)
- No excessive collision drop (Register 4, bit 3)
- Back pressure (Register 4, bit 5)

These bits are not set as the default because this is not the IEEE standard.

## Broadcast Storm Protection

The KSZ8895MLUB has an intelligent option to protect the switch system from receiving too many broadcast packets. Broadcast packets are normally forwarded to all ports except the source port and thus use too many switch resources (bandwidth and available space in transmit queues). The KSZ8895MLUB 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. The rate is based on a $50 \mathrm{~ms}(0.05 \mathrm{~s})$ interval for 100BT and a $500 \mathrm{~ms}(0.5 \mathrm{~s})$ 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 Registers 6 and 7. The default setting for Registers 6 and 7 is $0 \times 4 \mathrm{~A}$ (74 decimal). This is equal to a rate of $1 \%$, calculated as follows:

148,80 frames $/ \mathrm{sec} \times 50 \mathrm{~ms}(0.05 \mathrm{~s})$ interval $\times 1 \%=74$ frames/interval (approx.) $=0 \times 4 \mathrm{~A}$

## MII Interface Operation

The media independent interface (MII) is specified by the IEEE 802.3 committee and provides a common interface between physical layer and MAC layer devices. The KSZ8895MLUB provides such interfaces on port 5 . The SW5-MII interface is used to connect to the fifth MAC. The MII interface contains two distinct groups of signals, one for transmission and the other for receiving.

## Port 5 MAC 5 SW5-MII Interface

Table 3 shows two connection manners:

1. The first is an external MAC connects to SW5-MII PHY mode.
2. The second is an external PHY connects to SW5-MII MAC mode.

Please see the pins [91, 86, and 87] description for detail configuration for the MAC mode and PHY mode, SW5-MII works with 25 MHz and 2.5 MHz clock for 100Base-TX and 10Base-T.

Table 3. Switch MAC 5 MII Signals

| KSZ8895MLUB PHY Mode Connections |  |  | Description | KSZ8895MLUB MAC Mode Connections |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| External MAC | KSZ8895MLUB SW5-MII Signal | Type |  | External PHY | KSZ8895MLUB SW5- <br> MII <br> Signal | Type |
| MTXEN | SMTXEN | Input | Transmit enable | MTXEN | SMRXDV | Output |
| MTXER | SMTXER | Input | Transmit error | MTXER | Not used | Not used |
| MTXD3 | SMTXD[3] | Input | Transmit data bit 3 | MTXD3 | SMRXD[3] | Output |
| MTXD2 | SMTXD[2] | Input | Transmit data bit 2 | MTXD2 | SMRXD[2] | Output |
| MTXD1 | SMTXD[1] | Input | Transmit data bit 1 | MTXD1 | SMRXD[1] | Output |
| MTXDO | SMTXD[0] | Input | Transmit data bit 0 | MTXD0 | SMRXD[0] | Output |
| MTXC | SMTXC | Output | Transmit clock | MTXC | SMRXC | Input |
| MCOL | SCOL | Output | Collision detection | MCOL | SCOL | Input |
| MCRS | SCRS | Output | Carrier sense | MCRS | SCRS | Input |
| MRXDV | SMRXDV | Output | Receive data valid | MRXDV | SMTXEN | Input |
| MRXER | Not used | Output | Receive error | MRXER | SMTXER | Input |
| MRXD3 | SMRXD[3] | Output | Receive data bit 3 | MRXD3 | SMTXD[3] | Input |
| MRXD2 | SMRXD[2] | Output | Receive data bit 2 | MRXD2 | SMTXD[2] | Input |
| MRXD1 | SMRXD[1] | Output | Receive data bit 1 | MRXD1 | SMTXD[1] | Input |
| MRXD0 | SMRXD[0] | Output | Receive data bit 0 | MRXD0 | SMTXD[0] | Input |
| MRXC | SMRXC | Output | Receive clock | MRXC | SMTXC | Input |

The switch MII interface operates in either MAC mode or PHY mode for KSZ8895MLUB. These interfaces are nibble-wide data interfaces and therefore run at $1 / 4$ the network bit rate (not encoded). Additional signals on the transmit side indicate when data is valid or when an error occurs during transmission. Likewise, the receive side has indicators that convey when the data is valid and without physical layer errors. For half-duplex operation there is a signal that indicates a collision has occurred during transmission.
Note that the signal MRXER is not provided on the MII-SW interface for PHY mode operation and the signal MTXER is not provided on the MII-SW interface for MAC mode operation. Normally MRXER would indicate a receive error coming from the physical layer device. MTXER would indicate a transmit error from the MAC device. These signals are not appropriate for this configuration. For PHY mode operation, if the device interfacing with the KSZ8895MLUB has an MRXER pin, it should be tied low. For MAC mode operation, if the device interfacing with the KSZ8895MLUB has an MTXER pin, it should be tied low.

## SNI Interface Operation

The serial network interface (SNI) is compatible with some controllers used for network layer protocol processing. This interface can be directly connected to these types of devices. The signals are divided into two groups, one for transmission and the other for reception. The signals involved are described in Table 4.

Table 4. SNI Signals

| SNI Signal | Description | KSZ8895MLUB Signal |
| :---: | :---: | :---: |
| TXEN | Transmit Enable | SMTXEN |
| TXD | Serial Transmit Data | SMTXD[0] |
| TXC | Transmit Clock | SMTXC |
| COL | Collision Detection | SCOL |
| CRS | Carrier Sense | SMRXDV |
| RXD | Serial Receive Data | SMRXD[0] |
| RXC | Receive Clock | SMRXC |

This interface is a bit-wide data interface and therefore runs at the network bit rate (not encoded). An additional signal on the transmit side indicates when data is valid. Likewise, the receive side has an indicator that conveys when the data is valid.
For half-duplex operation there is a signal that indicates a collision has occurred during transmission.

## Advanced Functionality

## QoS Priority Support

The KSZ8895MLUB provides Quality-of-Service (QoS) for applications such as VoIP and video conferencing. The KSZ8895MLUB offer $1 / 2 / 4$ priority queues option per port by setting the port registers xxx control 9 bit1 and the port registers $x x x$ control 0 bit0, the $1 / 2 / 4$ queues split as follows,
[Port registers $x x x$ control 9 bit1, control 0 bit0]=00 single output queue as default.
[Port registers xxx control 9 bit1, control 0 bit0]=01 egress port can be split into two priority transmit queues.
[Port registers $x x x$ control 9 bit1, control 0 bit0]=10 egress port can be split into four priority transmit queues.
The four priority transmit queues is a new feature in the KSZ8895MLUB. The queue 3 is the highest priority queue and Queue 0 is the lowest priority queue. The port registers xxx control 7 bit1 and the port registers xxx control 0 bit0 are used to enable split transmit queues for ports $1,2,3,4$ and 5 , respectively. 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 to either always deliver high priority packets first or use programmable weighted fair queuing for the four priority queues scale by the port registers control 10, 11, 12 and 13 (default value are $8,4,2,1$ by their bit[6:0].
Register 130 bit[7:6] Prio_2Q[1:0] is used when the 2 Queue configuration is selected, these bits are used to map the 2-bit result of IEEE 802.1p from the registers 128, 129 or TOS/DiffServ mapping from registers 144-159 (for 4 Queues) into two queues mode with priority high or low.
Please see the descriptions of the register 130 bits [7:6] for detail.

## Port-Based Priority

With port-based priority, each ingress port is individually classified as a priority 0-3 receiving port. All packets received at the priority 3 receiving port are marked as high priority and are sent to the high-priority transmit queue if the corresponding transmit queue is split. The Port Registers Control 0 Bits [4:3] is used to enable port-based priority for ports 1, 2, 3, 4 and 5, respectively.

## 802.1p-Based Priority

For 802.1 p-based priority, the KSZ8895MLUB 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 compared against the "priority mapping" value, as specified by the registers 128 and 129, both register 128/129 can map 3-bit priority field of 0-7 value to 2-bit result of 0-3 priority levels. The "priority mapping" value is programmable.
The following figure illustrates how the 802.1p priority field is embedded in the 802.1Q VLAN tag.


Figure 6. 802.1p Priority Field Format
802.1p-based priority is enabled by bit [5] of the port registers control 0 for ports 1, 2, 3, 4 and 5, respectively.

The KSZ8895MLUB 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-byte Tag Control Information field (TCI), is also referred to as the IEEE 802.1Q VLAN tag.
Tag Insertion is enabled by bit [2] of the port registers control 0 and the port register control 8 to select which source port (ingress port) PVID can be inserted on the egress port for ports 1, 2, 3, 4 and 5, respectively. At the egress port, untagged packets are tagged with the ingress port's default tag. The default tags are programmed in the port registers control 3 and control 4 for ports 1, 2, 3, 4 and 5, respectively. The KSZ8895MLUB will not add tags to already tagged packets.
Tag Removal is enabled by bit [1] of the port registers control 0 for ports 1, 2, 3, 4 and 5, respectively. At the egress port, tagged packets will have their 802.1Q VLAN Tags removed. The KSZ8895MLUB will not modify untagged packets.
The CRC is recalculated for both tag insertion and tag removal.
$\mathbf{8 0 2 . 1 p}$ Priority Field Re-mapping is a QoS feature that allows the KSZ8895MLUB to set the "User Priority Ceiling" at any ingress port by the port register control 2 bit 7. 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.

## DiffServ-Based Priority

DiffServ-based priority uses the ToS registers (registers 144 to 159) in the Advanced 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 of DSCP decoded is compared with the corresponding bits in the DSCP register to determine priority.

## Spanning Tree Support

Port 5 is the designated port for spanning tree support.
The other ports (port 1 - port 4) can be configured in one of the five spanning tree states via "transmit enable," "receive enable," and "learning disable" register settings in Registers 18, 34, 50, and 66 for ports 1, 2, 3, and 4, respectively. The following description shows the port setting and software actions taken for each of the five spanning tree states.
Disable state: the port should not forward or receive any packets. Learning is disabled.
Port setting: "transmit enable $=0$, receive enable $=0$, learning disable $=1 . "$
Software action: 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 table with "overriding bit" set) and the processor should discard those packets.
Note: Processor is connected to port 5 via MII interface. Address learning is disabled on the port in this state.

Blocking state: only packets to the processor are forwarded. Learning is disabled.
Port setting: "transmit enable $=0$, receive enable $=0$, learning disable $=1$ "
Software action: the processor should not send any packets to the port(s) in this state. The processor should program the "Static MAC table" with the entries that it needs to receive (e.g., 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.
Listening state: only packets to and from the processor are forwarded. Learning is disabled.
Port setting: "transmit enable $=0$, receive enable $=0$, learning disable $=1$.
"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 disabled on the port in this state.
Learning state: only packets to and from the processor are forwarded. Learning is enabled.
Port setting: "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.
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.

## Rapid Spanning Tree Support

There are three operational states of the Discarding, Learning, and Forwarding assigned to each port for RSTP:
Discarding ports do not participate in the active topology and do not learn MAC addresses.
Discarding state: the state includs three states of the disable, blocking and listening of STP.
Port setting: "transmit enable $=0$, receive enable $=0$, learning disable $=1$."
Software action: 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 table with "overriding bit" set) and the processor should discard those packets. When disable the port's learning capability (learning disable='1'), set the register 1 bit5 and bi4 will flush rapidly with the port related entries in the dynamic MAC table and static MAC table.
Note: Processor is connected to port 5 via MII interface. Address learning is disabled on the port in this 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: "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: 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

The Tail Tag is only seen and used by the port 5 interface, which should be connected to a processor by SW5-MII interface. The one byte tail tagging is used to indicate the source/destination port in port 5. Only bit [3-0] are used for the destination in the tail tagging byte. Other bits are not used. The Tail Tag feature is enabled by setting register 12.


Figure 7. Tail Tag Frame Format

Table 5. Tail Tag Rules

| Ingress to Port $\mathbf{5}$ (Host $->$ KSZ8895MLUB) |  |
| :--- | :--- |
| Bit $[3: 0]$ | Destination |
| $0,0,0,0$ | Reserved |
| $0,0,0,1$ | Port 1 (direct forward to port1) |
| $0,0,1,0$ | Port 2 (direct forward to port2) |
| $0,1,0,0$ | Port 3 (direct forward to port3) |
| $1,0,0,0$ | Port 4 (direct forward to port4) |
| $1,1,1,1$ | Port 1, 2,3 and 4 (direct forward to port 1,2,3,4,) |
| Bit $[7: 4]$ |  |
| $0,0,0,0$ | Queue 0 is used at destination port |
| $0,0,0,1$ | Queue 1 is used at destination port |
| $0,0,1,0$ | Queue 2 is used at destination port |
| $0,0,1,1$ | Queue 3 is used at destination port |
| $x, 1, x, x$ | Whatever send packets to specified port in bit[3:0] |
| $1, x, x, x$ | Bit[6:0] will be ignored as normal (Address look up) |
| Egress from Port 5 (KSZ8895MLUB -> Host) |  |
| Bit $[1: 0]$ | Source |
| 0,0 | Port 1 (packets from port 1) |
| 0,1 | Port 2 (packets from port 2) |
| 1,0 | Port 3 (packets from port 3) |
| 1,1 | Port 4 (packets from port 4) |

## IGMP Support

There are two parts involved to support the Internet Group Management Protocol (IGMP) in Layer 2. The first part is IGMP snooping, the second part is this IGMP packet to be sent back to the subscribed port. Describe them as follows.

## IGMP Snooping

The KSZ8895MLUB traps IGMP packets and forwards them only to the processor (Port 5 SW5-MII/RMII). The IGMP packets are identified as IP packets (either Ethernet IP packets, or IEEE 802.3 SNAP IP packets) with IP version $=0 \times 4$ and protocol version number $=0 \times 2$. Set register 5 bit [6] to '1' to enable IGMP snooping.

## IGMP Send Back to the Subscribed Port

Once the host responds the received IGMP packet, the host should know the original IGMP ingress port and send back the IGMP packet to this port only, otherwise this IGMP packet will be broadcasted to all port to downgrade the performance.
Enable the tail tag mode, the host will know the IGMP packet received port from tail tag bits [1:0] and can send back the response IGMP packet to this subscribed port by setting the bits [3:0] in the tail tag. Enable "Tail tag mode" by setting Register 12 bit 1.

## Port Mirroring Support

KSZ8895MLUB supports "port mirror" comprehensively as:

- "Receive Only" Mirror on a Port

All the packets received on the port will be mirrored on the sniffer port. For example, port 1 is programmed to be " $r x$ sniff," and port 5 is programmed to be the "sniffer port." A packet, received on port 1, is destined to port 4 after the internal look-up. The KSZ8895MLUB will forward the packet to both port 4 and port 5. KSZ8895MLUB can optionally forward even "bad" received packets to port 5.

## - "Transmit Only" Mirror on a Port

All the packets transmitted on the port will be mirrored on the sniffer port. For example, port 1 is programmed to be "tx sniff," and port 5 is programmed to be the "sniffer port." A packet, received on any of the ports, is destined to port 1 after the internal look-up. The KSZ8895MLUB will forward the packet to both ports 1 and 5.

## - "Receive and Transmit" Mirror on Two Ports

All the packets received on port A AND transmitted on port B will be mirrored on the sniffer port. To turn on the "AND" feature, set Register 5 bit 0 to 1. For example, port 1 is programmed to be "rx sniff," port 2 is programmed to be "transmit sniff," and port 5 is programmed to be the "sniffer port." A packet, received on port 1 , is destined to port 4 after the internal look-up. The KSZ8895MLUB will forward the packet to port 4 only, since it does not meet the "AND" condition. A packet, received on port 1, is destined to port 2 after the internal look-up. The KSZ8895MLUB will forward the packet to both port 2 and port 5.

Multiple ports can be selected to be " $r x$ sniffed" or "tx sniffed." And any port can be selected to be the "sniffer port." All these per port features can be selected through Register 17.

## VLAN Support

KSZ8895MLUB supports 128 active VLANs and 4096 possible VIDs specified in IEEE 802.1q. KSZ8895MLUB provides a 128-entry VLAN table, which correspond to 4096 possible VIDs and converts to FID ( 7 bits) for address look-up max 128 active VLANs. If a non-tagged or null-VID-tagged packet is received, the ingress port VID is used for look-up when $802.1 q$ is enabled by the global register 5 control 3 bit 7. In the VLAN mode, the look-up process starts from VLAN table look-up to determine whether the VID is valid. If the VID is not valid, the packet will be dropped and its address will not be learned. If the VID is valid, FID is retrieved for further look-up by the static MAC table or dynamic MAC table. FID+DA is used to determine the destination port. The followed table describes the difference actions at different situations of DA and FID+DA in the static MAC table and dynamic MAC table after the VLAN table finish a look-up action. FID+SA is used for learning purposes. The followed table also describes how to learning in the dynamic MAC table when VLAN table has done a look-up and the static MAC table without a valid entry.

Table 6. FID+DA Look-Up in the VLAN Mode

| DA Found in <br> Static MAC <br> Table | Use FID Flag? | FID Match? | DA+FID Found in <br> Dynamic MAC <br> Table | Action |
| :---: | :---: | :---: | :---: | :--- |
| No | Don't care | Don't care | No | Broadcast to the membership ports defined in the <br> VLAN table bit [11:7]. |
| No | Don't care | Don't care | Yes | Send to the destination port defined in the dynamic <br> MAC table bit [58:56]. |
| Yes | 0 | Don't care | Don't care | Send to the destination port(s) defined in the static <br> MAC table bit [52:48]. |
| Yes | 1 | No | No | Broadcast to the membership ports defined in the <br> VLAN table bit [11:7]. |
| Yes | 1 | No | Yes | Send to the destination port defined in the dynamic <br> MAC table bit [58:56]. |
| Yes | 1 | Yes | Don't care | Send to the destination port(s) defined in the static <br> MAC table bit [52:48]. |

Table 7. FID+SA Look-Up in the VLAN Mode

| SA+FID Found in <br> Dynamic MAC Table | Action |
| :---: | :--- |
| No | The SA+FID will be learned into the dynamic table. |
| Yes | Time stamp will be updated. |

Advanced VLAN features are also supported in KSZ8895MLUB, such as "VLAN ingress filtering" and "discard non PVID" defined in bits [6:5] of the port Register Control 2. These features can be controlled on a port basis.

## Rate Limiting Support

The KSZ8895MLUB provides a fine resolution hardware rate limiting. The rate step is 64 Kbps when the rate limit is less than 1 Mbps rate for 100 BT or 10 BT . The rate step is 1 Mbps when the rate limit is more than 1 Mbps rate for 100 BT or 10BT (refer to Data Rate Selection Table which follow the end of the Port Register Queue 0 - 3 Ingress/Egress Limit Control section). The rate limit is independently on the "receive side" and on the "transmit side" on a per port basis. For 10BASE-T, a rate setting above 10 Mbps 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 IFG (Inter Frame Gap) or Preamble byte, in addition to the data field (from packet DA to FCS).

## Ingress Rate Limit

For ingress rate limiting, KSZ8895MLUB provides options to selectively choose frames from all types, multicast, broadcast, and flooded unicast frames by bits [3-2] of the port rate limit control register. The KSZ8895MLUB 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 or the flow control takes effect without packet dropped when the ingress rate limit flow control is enabled by the port rate limit control register bit 4. The ingress rate limiting supports the port-based, 802.1 p and DiffServbased priorities, the port-based priority is fixed priority $0-3$ selection by bits [ $4-3$ ] of the port register control 0 . The 802.1p and DiffServ-based priority can be mapped to priority $0-3$ by default of the register 128 and 129. In the ingress rate limit, set register 135 global control 19 bit3 for queue-based rate limit to be enabled if use two queues or four queues mode, all related ingress ports and egress port should be spitted to two queues or four queues mode by the port registers control 9 and control 0 . The four queues mode will use Q0-Q3 for priority $0-3$ by bit [ $6-0$ ] of the port register ingress limit control 1 - 4. The two queues mode will use Q0-Q1 for priority 0-1 by bit [6-0] of the port register ingress limit control $1-2$. The priority levels in the packets of the 802.1 p and DiffServ can be programmed to priority $0-3$ by the register 128 and 129 for a re-mapping.

## Egress 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 by the data rate selection table followed the egress rate limit control registers.
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. The egress rate limiting supports the portbased, 802.1 p and DiffServ-based priorities, the port-based priority is fixed priority $0-3$ selection by bits [4-3] of the port register control 0 . The 802.1 p and DiffServ-based priority can be mapped to priority $0-3$ by default of the register 128 and 129. In the egress rate limit, set register 135 global control 19 bit3 for queue-based rate limit to be enabled if use two queues or four queues mode, all related ingress ports and egress port should be spitted to two queues or four queues mode by the port registers control 9 and control 0 . The four queues mode will use Q0-Q3 for priority $0-3$ by bit [ $6-0]$ of the port register egress limit control $1-4$. The two queues mode will use $\mathrm{Q} 0-\mathrm{Q} 1$ for priority $0-1$ by bit $[6-0]$ of the port register egress limit control 1 - 2 .

The priority levels in the packets of the 802.1 p and DiffServ can be programmed to priority $0-3$ by the register 128 and 129 for a re-mapping.
When egress rate limit just use one queue per port for the egress port rate limit, the priority packets will be based on the data rate selection table with the rate limit exact number. If egress rate limit use more than one queue per port for the egress port rate limit, the highest priority packets will be based on the data rate selection table for the rate limit exact number, other lower priority packet rate will be limited based on 8:4:2:1 (default) priority ratio based on the highest priority rate. The transmit queue priority ratio is programmable.
To reduce congestion, it is a good practice to make sure the egress bandwidth exceeds the ingress bandwidth.

## Transmit Queue Ratio Programming

In transmit queues $0-3$ of the egress port, the default priority ratio is $8: 4: 2: 1$, the priority ratio can be programmed by the port registers control $10,11,12$ and 13 . When the transmit rate exceed the ratio limit in the transmit queue, the transmit rate will be limited by the transmit queue $0-3$ ratio of the port register control 10, 11, 12 and 13 . The highest priority queue will be no limited, other lower priority queues will be limited based on the transmit queue ratio.
Filtering for Self-Address, Unknown Unicast/Multicast Address and Unknown VID Packet/IP Multicast
Enable Self-address filtering, the unknown unicast packet filtering and forwarding by the Register 131 Global Control 15. Enable Unknown multicast packet filtering and forwarding by the Register 132 Global Control 16.
Enable Unknown VID packet filtering and forwarding by the Register 133 Global Control 17.
Enable Unknown IP multicast packet filtering and forwarding by the Register 134 Global Control 18.
This function is very useful in preventing those kinds of packets that could degrade the quality of the port in applications such as voice over Internet Protocol (VoIP) and the daisy chain connection to prevent packets into endless loop.

## Configuration Interfaces

## $I^{2} \mathrm{C}$ Master Serial Bus Configuration

If a 2 -wire EEPROM exists, then the KSZ8895MLUB can perform more advanced features like broadcast storm protection and rate control. The EEPROM should have the entire valid configuration data from Register 0 to Register 255 defined in the "Memory Map," except the chipID $=0$ in the register1 and the status registers. After reset, the KSZ8895MLUB will start to read all 255 registers sequentially from the EEPROM. The configuration access time ( $\mathrm{t}_{\mathrm{prgm}}$ ) is less than 30 ms , as shown in Figure 8.


To configure the KSZ8895MLUB with a pre-configured EEPROM use the following steps:

1. At the board level, connect pin 110 on the KSZ8895MLUB to the SCL pin on the EEPROM. Connect pin 111 on the KSZ8895MLUB to the SDA pin on the EEPROM.
2. A[2-0] address pins of EEPROM should be tied to ground for address $\mathrm{A}[2-0]=$ ' 000 ' to be identified by the KSZ8895MLUB.
3. Set the input signals PS[1:0] (pins 113 and 114, respectively) to "00." This puts the KSZ8895MLUB serial bus configuration into $I^{2} \mathrm{C}$ master mode.
4. Be sure the board-level reset signal is connected to the KSZ8895MLUB reset signal on pin 115 (RST_N).
5. Program the contents of the EEPROM before placing it on the board with the desired configuration data. Note that the first byte in the EEPROM must be " 95 " for the loading to occur properly. If this value is not correct, all other data will be ignored.
6. Place EEPROM on the board and power up the board. Assert the active-low board level reset to RST_N on the KSZ8895MLUB. After the reset is de-asserted, the KSZ8895MLUB will begin reading configuration data from the EEPROM. The configuration access time ( $\mathrm{t}_{\text {prgm }}$ ) is less than 30 ms .
Note: For proper operation, make sure that pin 47 (PWRDN_N) is not asserted during the reset operation.

## SPI Slave Serial Bus Configuration

The KSZ8895MLUB can also act as a SPI slave device. Through the SPI, the entire feature set can be enabled, including "VLAN," "IGMP snooping," "MIB counters," etc. The external master device can access any register from Register 0 to Register 255 randomly. The system should configure all the desired settings before enabling the switch in the KSZ8895MLUB. To enable the switch, write a "1" to Register 1 bit 0.
Two standard SPI commands are supported (00000011 for "READ DATA," and 00000010 for "WRITE DATA"). To speed configuration time, the KSZ8895MLUB also supports multiple reads or writes. After a byte is written to or read from the KSZ8895MLUB, the internal address counter automatically increments if the SPI Slave Select Signal (SPIS_N) continues to be driven low. If SPIS_N is kept low after the first byte is read, the next byte at the next address will be shifted out on SPIQ. If SPIS_N is kept low after the first byte is written, bits on the Master Out Slave Input (SPID) line will be written to the next address. Asserting SPIS_N high terminates a read or write operation. This means that the SPIS_N signal must be asserted high and then low again before issuing another command and address. The address counter wraps back to zero once it reaches the highest address. Therefore the entire register set can be written to or read from by issuing a single command and address.
The default SPI clock speed is 12.5 MHz . The KSZ8895MLUB is able to support a SPI bus up to 25 MHz (set register 12 bit[5:4] = 0x10). A high performance SPI master is recommended to prevent internal counter overflow.

To use the KSZ8895MLUB SPI:

1. At the board level, connect KSZ8895MLUB pins as follows:

Table 8. SPI Connections

| KSZ8895MLUB <br> Pin Number | KSZ8895MLUB Signal <br> Name | Microprocessor Signal Description |
| :---: | :---: | :--- |
| 112 | SPIS_N | SPI Slave Select |
| 110 | SPIC | SPI Clock |
| 111 | SPID | Master Out Slave Input |
| 109 | SPIQ | Master In Slave Output |

2. Set the input signals PS[1:0] (pins 113 and 114 , respectively) to " 10 " to set the serial configuration to SPI slave mode.
3. Power up the board and assert a reset signal. After reset wait $100 \mu \mathrm{~s}$, the start switch bit in Register 1 will be set to ' 0 '. Configure the desired settings in the KSZ8895MLUB before setting the start register to ' 1. .
4. Write configuration to registers using a typical SPI write data cycle as shown in Figure 9 or SPI multiple write as shown in Figure 11. Note that data input on SPID is registered on the rising edge of SPIC.
5. Registers can be read and configuration can be verified with a typical SPI read data cycle as shown in Figure 10 or a multiple read as shown in Figure 12. Note that read data is registered out of SPIQ on the falling edge of SPIC.
6. After configuration is written and verified, write a ' 1 ' to Register 1 bit 0 to begin KSZ8895MLUB switch operation.

SPIS_N
SPIC
SPID


SPIQ


Figure 9. SPI Write Data Cycle


Figure 10. SPI Read Data Cycle
SPIS_N
SPIC
SPID

SPIQ


WRITE COMMAND WRITE ADDRESS Byte 1
SPIS_N
SPIC
SPID
SPIQ


Byte 2
Byte 3 ...
Byte N
Figure 11. SPI Multiple Write

SPIS_N
SPIC
SPID
SPIQ


READ COMMAND
READ ADDRESS
Byte 1
SPIS_N
SPIC
SPID
SPIQ


Figure 12. SPI Multiple Read

## MII Management Interface (MIIM)

The KSZ8895MLUB supports the standard IEEE 802.3 MII Management Interface, also known as the Management Data Input/Output (MDIO) Interface. This interface allows upper-layer devices to monitor and control the states of the KSZ8895MLUB. An external device with MDC/MDIO capability is used to read the PHY status or configure the PHY settings. Further details on the MIIM interface are found in Clause 22.2.4.5 of the IEEE 802.3u Specification.
The MIIM interface consists of the following:

- A physical connection that incorporates the data line (pin 108 MDIO) and the clock line (pin 107 MDC).
- A specific protocol that operates across the aforementioned physical connection that allows an external controller to communicate with the KSZ8895MLUB device.
- Access to a set of eight 16 -bit registers, consisting of 8 standard MIIM registers [ $0: 5 \mathrm{~h}$ ], 1d and 1 f MIIM registers per port.

The MIIM Interface can operate up to a maximum clock speed of 10 MHz MDC clock.
Table 9 depicts the MII Management Interface frame format.
Table 9. MII Management Interface Frame Format

|  | Preamble | Start of <br> Frame | Read/Write <br> OP Code | PHY <br> Address <br> Bits[4:0] | REG <br> Address <br> Bits[4:0] | TA | Data Bits[15:0] | Idle |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | 321 1's | 01 | 10 | AAAAA | RRRRR | Z0 | DDDDDDDD_DDDDDDDD | Z |
| Write | 321 's | 01 | 01 | AAAAA | RRRRR | 10 | DDDDDDDD_DDDDDDDD | Z |

The MIIM interface does not have access to all the configuration registers in the KSZ8895MLUB. It can only access the standard MIIM registers. See "MIIM Registers". The SPI interface and MDC/MDIO SMI mode, on the other hand, can be used to access all registers with the entire KSZ8895MLUB feature set.

## Serial Management Interface (SMI)

The SMI is the KSZ8895MLUB non-standard MIIM interface that provides access to all KSZ8895MLUB configuration registers. This interface allows an external device with MDC/MDIO interface to completely monitor and control the states of the KSZ8895MLUB.
The SMI interface consists of the following:

- A physical connection that incorporates the data line (MDIO) and the clock line (MDC).
- A specific protocol that operates across the aforementioned physical connection that allows an external controller to communicate with the KSZ8895MLUB device.
- Access to all KSZ8895MLUB configuration registers. Register access includes the Global, Port and Advanced Control Registers $0-255$ ( $0 \times 00$ - 0xFF), and indirect access to the standard MIIM registers [0:5] and custom MIIM registers [29, 31].

The SMI Interface can operate up to a maximum clock speed of 10 MHz MDC clock.
The following table depicts the SMI frame format.

Table 10. Serial Management Interface (SMI) Frame Format

|  | Preamble | Start of <br> Frame | Read/Write <br> OP Code | PHY <br> Address <br> Bits[4:0] | REG <br> Address <br> Bits[4:0] | TA | Data Bits[15:0] | Idle |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | 321 1's | 01 | 10 | RR11R | RRRRR | Z0 | $0000 \_0000 \_D D D D \_D D D D$ | Z |
| Write | 321 's | 01 | 01 | RR11R | RRRRR | 10 | xxxx_xxxx_DDDD_DDDD | Z |

SMI register Read access is selected when OP Code is set to " 10 " and bits [2:1] of the PHY address is set to ' 11 '. The 8 -bit register address is the concatenation of $\{$ PHY address bits [4:3], PHY address bits [0], REG address bit [4:0]\}. TA is turn-around bits. TA bits [1:0] are 'ZO' means the processor MDIO pin is changed to input Hi-Z from output mode and the followed ' 0 ' is the read response from device, as the switch configuration registers are 8 -bit wide, only the lower 8 bits of data bits [15:0] are used
SMI register Write access is selected when OP Code is set to " 01 " and bits [2:1] of the PHY address is set to ' 11 '. The 8 -bit register address is the concatenation of \{PHY address bits [4:3], PHY address bits [0], REG address bit [4:0]\}. TA bits [1:0] are set to ' 10 ', as the switch configuration registers are 8 -bit wide, only the lower 8 bits of data bits [15:0] are used.
To access the KSZ8895MLUB registers 0-255 (0x00-0xFF), the following applies:
PHYAD [4, 3, 0] and REGAD [4:0] are concatenated to form the 8-bit address; that is, \{PHYAD [4, 3, 0], REGAD [4:0]\} = bits [7:0] of the 8 -bit address.
Registers are 8 data bits wide. For read operation, data bits [15:8] are read back as zeroes. For write operation, data bits [15:8] are not defined, and hence can be set to either zeroes or ones.
SMI register access is the same as the MIIM register access, except for the register access requirements presented in this section.

## Register Description

| Offset |  | Description |
| :---: | :---: | :---: |
| Decimal | Hex |  |
| 0-1 | 0x00-0x01 | Chip ID Registers |
| 2-13 | 0x02-0x0D | Global Control Registers |
| 14-15 | 0x0E-0x0F | Power Down Management Control Registers |
| 16-20 | 0x10-0x14 | Port 1 Control Registers |
| 21-23 | 0x15-0x17 | Port 1 Reserved (Factory Test Registers) |
| 24-31 | 0x18-0x1F | Port 1 Control/Status Registers |
| 32-36 | 0x20-0x24 | Port 2 Control Registers |
| 37-39 | 0x25-0x27 | Port 2 Reserved (Factory Test Registers) |
| 40-47 | 0x28-0x2F | Port 2 Control/Status Registers |
| 48-52 | 0x30-0x34 | Port 3 Control Registers |
| 53-55 | 0x35-0x37 | Port 3 Reserved (Factory Test Registers) |
| 56-63 | 0x38-0x3F | Port 3 Control/Status Registers |
| 64-68 | 0x40-0x44 | Port 4 Control Registers |
| 69-71 | 0x45-0x47 | Port 4 Reserved (Factory Test Registers) |
| 72-79 | 0x48-0x4F | Port 4 Control/Status Registers |
| 80-84 | 0x50-0x54 | Port 5 Control Registers |
| 85-87 | 0x55-0x57 | Port 5 Reserved (Factory Test Registers) |
| 88-95 | 0x58-0x5F | Port 5 Control/Status Registers |
| 96-103 | 0x60-0x67 | Reserved (Factory Testing Registers) |
| 104-109 | 0x68-0x6D | MAC Address Registers |
| 110-111 | 0x6E-0x6F | Indirect Access Control Registers |
| 112-120 | 0x70-0x78 | Indirect Data Registers |
| 121-123 | 0x79-0x7B | Reserved (Factory Testing Registers) |
| 124-125 | 0x7C-0x7D | Port Interrupt Registers |
| 126-127 | 0x7E-0x7F | Reserved (Factory Testing Registers) |
| 128-135 | 0x80-0x87 | Global Control Registers |
| 136 | 0x88 | Switch Self Test Control Register |
| 137-143 | 0x89-0x8F | QM Global Control Registers |
| 144-145 | 0x90-0x91 | TOS Priority Control Registers |
| 146-159 | 0x92-0x9F | TOS Priority Control Registers |
| 160-175 | 0xA0-0xAF | Reserved (Factory Testing Registers) |
| 176-190 | 0xB0-0xBE | Port 1 Control Registers |

## Register Description (Continued)

| Offset |  | Description |
| :---: | :---: | :--- |
| Decimal | Hex |  |
| 191 | $0 \times B F$ | Reserved (Factory Testing Register): Transmit Queue Remap Base Register |
| $192-206$ | $0 \times C 0-0 x C E$ | Port 2 Control Registers |
| 207 | $0 x C F$ | Reserved (Factory Testing Register) |
| $208-222$ | $0 x D 0-0 x D E$ | Port 3 Control Registers |
| 223 | $0 x D F$ | Reserved (Factory Testing Register) |
| $224-238$ | $0 x E 0-0 x E E$ | Port 4 Control Registers |
| 239 | $0 x E F$ | Reserved (Factory Testing Register) |
| $240-254$ | $0 x F 0-0 x F E$ | Port 5 Control Registers |
| 255 | 0xFF | Reserved (Factory Testing Register) |

## Global Registers

Register 0 ( $0 \times 00$ ): Chip ID0

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Family ID | Chip family. | RO | $0 \times 95$ |

Register 1 (0×01): Chip ID1 / Start Switch

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-4 | Chip ID |  | RO | $0 \times 4$ |
| 3-1 | Revision ID | Revision ID | RO | $0 \times 0$ |
| 0 | Start Switch | 1, start the chip when external pins (PS1, PS0) = (01) or (1,0) <br> Note: in $(P S 1, P S 0)=(0,0)$ mode, the chip will start automatically, after trying to read the external EEPROM. If EEPROM does not exist, the chip will use default values for all internal registers. If EEPROM is present, the contents in the EEPROM will be checked. <br> The switch will check: <br> Register $0=0 \times 95$ <br> Register 1 [7:4] chip ID $=00$ <br> If this check is OK, the contents in the EEPROM will override chip register default values. <br> Chip will not start when external pins (PS1, PS0) $=(1,0)$ or $(0,1)$. <br> Note: $(P S 1, P S 0)=(1,1)$ for Factory test only. <br> 0 , stop the switch function of the chip. | R/W | 0 |

## Register 2 ( $0 \times 02$ ): Global Control 0

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | New Back-off Enable | New back-off algorithm designed for UNH <br> $1=$ Enable <br> $0=$ Disable | R/W | 0 |
| 6 | Reserved | Reserved. | RO | 0 |
| 5 | Flush Dynamic MAC Table | Flush the entire dynamic MAC table for RSTP <br> $1=$ Trigger the flush dynamic MAC table <br> operation. This bit is self-clear. <br> $0=$ Normal operation <br> Note: All the entries associated with a port that <br> has its learning capability being turned off <br> (Learning Disable) will be flushed. If you want to <br> flush the entire Table, all ports learning capability <br> must be turned off. | R/W |  |

## Global Registers (Continued)

Register $2(0 \times 02)$ : Global Control 0

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 4 | Flush Static MAC Table | Flush the matched entries in static MAC table for RSTP <br> 1 = Trigger the flush static MAC table operation. This bit is self-clear (SC) <br> $0=$ Normal operation <br> Note: The matched entry is defined as the entry whose Forwarding Ports field contains a single port and MAC address with unicast. This port, in turn, has its learning capability being turned off (Learning Disable). Per port, multiple entries can be qualified as matched entries. | $\begin{aligned} & \mathrm{R} / \mathrm{W} \\ & \text { (SC) } \end{aligned}$ | 0 |
| 3 | Reserved | N/A, don't change | RO | 1 |
| 2 | Reserved | N/A, don't change | RO | 1 |
| 1 | UNH Mode | 1, the switch will drop packets with 0x8808 in T/L filed, or DA $=01-80-C 2-00-00-01$. <br> 0 , the switch will drop packets qualified as "flow control" packets. | R/W | 0 |
| 0 | Link Change Age | 1, link change from "link" to "no link" will cause fast aging ( $<800 \mu \mathrm{~s}$ ) to age address table faster. After an age cycle is complete, the age logic will return to normal ( $300 \pm 75$ seconds). Note: If any port is unplugged, all addresses will be automatically aged out. | R/W | 0 |

Register 3 (0×03): Global Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Pass All Frames | 1, switch all packets including bad ones. Used <br> solely for debugging purpose. Works in <br> conjunction with sniffer mode. | R/W | 0 |
| 6 | 2K Byte Packet Support | $1=$ Enable support 2K Byte packet <br> $0=$ Disable support 2K Byte packet | R/W | 0 |
| 5 |  IEEE 802.3x Transmit <br> Flow Control Disable  | 0, will enable transmit flow control based on AN <br> result. <br> 1, will not enable transmit flow control regardless <br> of AN result. | RMW | Pin PMRXD3 <br> strap option. <br> PD(0): Enable Tx <br> flow control <br> (default). <br> PU(1): Disable <br> Tx/Rx flow <br> control. <br> Note: SPFLC <br> has internal pull- <br> down. |

## Global Registers (Continued)

Register 3 (0×03): Global Control 1

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 4 | IEEE 802.3x Receive <br> Flow Control Disable | 0 , will enable receive flow control based on AN result. <br> 1, will not enable receive flow control regardless of AN result. <br> Note: Bit 5 and bit 4 default values are controlled by the same pin, but they can be programmed independently. | R/W | Pin PMRXD3 strap option. <br> PD (0): Enable Rx flow control (default). <br> PU(1): Disable Tx/Rx flow control. <br> Note: SPFLC has internal pulldown. |
| 3 | Frame Length Field Check | 1, will check frame length field in the IEEE packets. <br> If the actual length does not match, the packet will be dropped (for L/T <1500). | R/W | 0 |
| 2 | Aging Enable | 1, enable age function in the chip. 0 , disable aging function. | R/W | Pin LED[5][2] strap option. PD(0): Aging disable. <br> PU(1): Aging enable (default). <br> Note: LED[5][2] has internal pull up. |
| 1 | Fast Age Enable | 1 = Turn on fast age ( $800 \mu \mathrm{~s}$ ). | R/W | 0 |
| 0 | Aggressive Back Off Enable | 1 = Enable more aggressive back-off algorithm in half duplex mode to enhance performance. This is not an IEEE standard. | R/W | Pin PMRXD0 strap option. PD(0): Disable aggressive back off (default). <br> PU(1): <br> Aggressive back off. <br> Note: SPPE has internal pull down. |

## Global Registers (Continued)

Register 4 ( $0 \times 04$ ): Global Control 2

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Unicast Port-VLAN Mismatch Discard | This feature is used for port VLAN (described in Register 17, Register 33...). <br> 1, all packets can not cross VLAN boundary. <br> 0, unicast packets (excluding unknown/ multicast/broadcast) can cross VLAN boundary. | R/W | 1 |
| 6 | Multicast Storm Protection Disable | 1, "Broadcast Storm Protection" does not include multicast packets. Only DA=FFFFFFFFFFFFF packets will be regulated. <br> 0, "Broadcast Storm Protection" includes DA = FFFFFFFFFFFFF and DA[40] = 1 packets. | R/W | 1 |
| 5 | Back Pressure Mode | 1, carrier sense based backpressure is selected. 0 , collision based backpressure is selected. | R/W | 1 |
| 4 | Flow Control and Back Pressure fair Mode | 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 is to prevent the flow control port from being flow controlled for an extended period of time. <br> 0 , in this mode, if a flow control port and a nonflow control port talk to the same destination port, the flow control port will be flow controlled. This may not be "fair" to the flow control port. | R/W | 1 |
| 3 | No Excessive Collision Drop | 1, the switch will not drop packets when 16 or more collisions occur. <br> 0 , the switch will drop packets when 16 or more collisions occur. | R/W | Pin PMRXD1 strap option. PD(0): (default ) Drop excessive collision packets. PU(1): Don't drop excessive collision packets. Note: SPDECP has internal pull down. |
| 2 | Huge Packet Support | 1, will accept packet sizes up to 1916 bytes (inclusive). This bit setting will override setting from bit 1 of the same register. <br> 0 , the maximum packet size will be determined by bit 1 of this register. | R/W | 0 |

## Global Registers (Continued)

## Register 4 (0×04): Global Control 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :--- | :--- |
| 1 |  | Legal Maximum Packet <br> Size Check Disable | 1, will accept packet sizes up to 1536 bytes <br> (inclusive). <br> 0,1522 bytes for tagged packets (not including <br> packets with STPID from CPU to ports 1-4), 1518 <br> bytes for untagged packets. Any packets larger <br> than the specified value will be dropped. | R/W |

Register 5 ( $0 \times 05$ ): Global Control 3

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | 802.1q VLAN Enable | 1, 802.1q VLAN mode is turned on. VLAN table needs to set up before the operation. <br> $0,802.1 q$ VLAN is disabled. | R/W | 0 |
| 6 | IGMP Snoop Enable on Switch SW5-MII Interface | 1, IGMP snoop enabled. All the IGMP packets will be forwarded to Switch MII port. <br> 0 , IGMP snoop disabled. | R/W | 0 |
| 5 | Enable Direct Mode on Switch SW5-MII Interface | 1, direct mode on port 5 . This is a special mode for the Switch MII interface. Using preamble before MRXDV to direct switch to forward packets, bypassing internal look-up. <br> 0 , normal operation. | R/W | 0 |
| 4 | Enable Pre-Tag on Switch SW5-MII Interface | 1, packets forwarded to Switch MII interface will be pre-tagged with the source port number (preamble before MRXDV). <br> 0 , normal operation. | R/W | 0 |
| 3-2 | Reserved | N/A | RO | 00 |
| 1 | Enable "Tag" Mask | 1, the last 5 digits in the VID field are used as a mask to determine which port(s) the packet should be forwarded to. <br> 0 , no tag masks. <br> Note: Turn off the 802.1q VLAN mode (reg0x5, bit $7=0$ ) for this bit to work. | R/W | 0 |
| 0 | Sniff Mode Select | 1, will do Rx AND Tx sniff (both source port and destination port need to match). <br> 0, will do Rx OR Tx sniff (Either source port or destination port needs to match). <br> This is the mode used to implement Rx only sniff. | R/W | 0 |

## Global Registers (Continued)

Register 6 (0×06): Global Control 4

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Switch SW5-MII Back Pressure Enable | 1, enable half-duplex back pressure on switch MII interface. <br> 0 , disable back pressure on switch MII interface. | R/W | 0 |
| 6 | Switch SW5-MII Half-Duplex Mode | 1, enable MII interface half-duplex mode. 0, enable MII interface full-duplex mode. | R/W | Pin SMRXD2 strap option. PD(0): (default) Full-duplex mode. <br> PU(1): Halfduplex mode. <br> Note: SMRXD2 has internal pulldown. |
| 5 | Switch SW5-MII Flow Control Enable | 1, enable full-duplex flow control on switch MII interface. <br> 0, disable full-duplex flow control on switch MII interface. | R/W | Pin SMRXD3 strap option. PD(0): (default) Disable flow control. <br> PU(1): enable flow control. <br> Note: SMRXD3 has internal pulldown. |
| 4 | Switch SW5-MII Speed | 1, the switch SW5-MII is in 10 Mbps mode. 0 , the switch SW5-MII is in 100Mbps mode. | R/W | Pin SMRXD1 strap option. <br> PD(0): (default) Enable 100Mbps. PU(1): Enable 10Mbps. <br> Note: SMRXD1 has internal pulldown. |
| 3 | Null VID Replacement | 1, will replace null VID with port VID (12 bits). 0 , no replacement for null VID. | R/W | 0 |
| $2-0$ | Broadcast Storm <br> Protection Rate Bit [10:8] | This along with the next register determines how many <br> " 64 byte blocks" of packet data allowed on an input port in a preset period. The period is 50 ms for 100 BT or 500 ms for 10 BT . The default is $1 \%$. | R/W | 000 |

## Global Registers (Continued)

| Register $\mathbf{7}(\mathbf{0 \times 0 7}$ : Global Control 5 |
| :--- |
| Address Name Description Mode Default <br> $7-0$ Broadcast Storm <br> Protection Rate Bit [7:0] This along with the previous register determines <br> how many " 64 byte blocks" of packet data are <br> allowed on an input port in a preset period. The <br> period is 50ms for <br> $100 B T$ or 500 ms for 10BT. The default is $1 \%$. R/W 0x4A ${ }^{(1)}$ |

Note:

1. 148,800 frames $/ \mathrm{sec} \times 1 \%=74$ frames/interval (approx.) $=0 \times 4 \mathrm{~A}$.
Register $8(0 \times 08)$ : Global Control 6

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Factory Testing | Reserved | R/W | $0 \times 24$ |

Register 9 ( $0 \times 09$ ): Global Control 7

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Factory Testing | Reserved | R/W | $0 \times 28$ |

Register 10 ( $0 \times 0 \mathrm{~A}$ ): Global Control 8

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Factory Testing | Reserved | R/W | $0 \times 00$ |

Register 11 ( $0 \times 0 \mathrm{~B}$ ): Global Control 9

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reversed | N/A, don't change | RO | 0 |
| 6 | Reserved | N/A, don't change | RO | 0 |
| 5 | Reserved | N/A, don't change | RO | 0 |
| 4 | Reserved | N/A, don't change | RO | 0 |
| 3 | PHY Power Save | $1=$ disable PHY power-save mode. <br> $0=$ enable PHY power-save mode. | $R / W$ | 0 |
| 2 | Reserved | N/A, don't change | RO | 0 |

## Global Registers (Continued)

Register 11 ( $0 \times 0 \mathrm{~B}$ ): Global Control 9

| Address | Name | Description |  |  | Mode | Default |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | LED Mode | LEDx[2,1,0]=0,1,1 <br> Mode 1, link at <br> 100/Full LEDx[2,1,0]=0,1,0 100/Half <br> LEDx[2,1,0]=0,1,1 <br> 10/Full LEDx[2,1,0]=1,0,0 10/Half <br> LEDx[2,1,0]=1,0,1 <br> ( $0=$ LED on, $1=$ LED off) |  |  | R/W | Pin SMRXD0 strap option. Pulldown(0): Enabled led mode 0. Pullup(1): Enabled led mode 1. Note: SMRXDO has internal pulldown 0 . |
|  |  |  | Mode 0 | Mode 1 |  |  |
|  |  | LEDX_2 | Lnk/Act | 100Lnk/Act |  |  |
|  |  | LEDX_1 | Fulld/Col | 10Lnk/Act |  |  |
|  |  | LEDX_0 | Speed | Fulld |  |  |
| 0 | SPI/SMI Read Sampling Clock Edge Select | Select the SPI/SMI clock edge for sampling SPI/SMI read data <br> 1 = trigger by rising edge of SPI/SMI clock (for high speed SPI about 25 MHz and SMI about 10 MHz ) <br> 0 = trigger by falling edge of SPI/SMI clock |  |  | R/W | 0 |

## Global Registers (Continued)

Register 12 (0×0C): Global Control 10

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Reserved | N/A, don't change | RO | 0 |
| 6 | Reserved | N/A, don't change | RO | 1 |
| 5-4 | CPU interface clock select | Select the internal clock speed for SPI, MDI interface: <br> $00=41.67 \mathrm{MHz}$ (SPI up to 6.25 MHz , MDC up to 6 MHz ) <br> $01=83.33 \mathrm{MHz}$ Default (SPI SCL up to 12.5 MHz , MDC up to 12 MHz ) <br> $10=125 \mathrm{MHz}$ (for high-speed SPI about 25 MHz ) <br> 11 = Reserved | R/W | 01 |
| 3 | Reserved | N/A | RO | 00 |
| 2 | Reserved | N/A, don't change | RO | 1 |
| 1 | Tail Tag Enable | Tail Tag feature is applied for Port 5 only. 1 = Insert 1 Byte of data right before FCS 0 = Do not insert | R/W | 0 |
| 0 | Pass Flow Control Packet | 1 = Switch will not filter 802.1x "flow control" packets <br> 0 = Switch will filter 802.1x "flow control" packets | R/W | 0 |

Register 13 (0×0D): Global Control 11

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Factory Testing | N/A, don't change | RO | 00000000 |

## Global Registers (Continued)

Register 14 (0×0E): Power-Down Management Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved | N/A, don't change | RO | 0 |
| 6 | Reserved | P/ll power down: <br> $1=$ Disable <br> $0=$ Enable <br> 5 | PLL Power Down | Note: It takes the effect in the Energy Detect <br> mode (EDPD mode). |
| $4-3$ | Power Management Mode | Power management mode: <br> $00=$ Normal mode (D0) <br> $01=$ Energy Detection mode (D2) <br> $10=$ soft Power Down mode (D3) <br> $11=$ Power Saving mode (D1) | R/W |  |
|  |  |  | R/W |  |

Register 14 ( $0 \times 0 \mathrm{E}$ ): Power-Down Management Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $2-1$ | Reserved | N/A, don't change | R/W | 00 |
| 0 | Reserved | N/A, don't change | RO | 0 |

Register 15 (0×0F): Power-Down Management Control 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Go_sleep_time[7:0] | When the Energy Detect mode is on, this value is <br> used to control the minimum period that the no <br> energy event has to be detected consecutively <br> before the device enters the low power state. The <br> unit is 20 ms. The default of go_sleep time is 1.6 <br> seconds (80Dec $\times 20 \mathrm{~ms}$ ). | R/W | 01010000 |

## Port Registers

The following registers are used to enable features that are assigned on a per port basis. The register bit assignments are the same for all ports, but the address for each port is different, as indicated:

Register 16 ( $0 \times 10$ ): Port 1 Control 0
Register 32 ( $0 \times 20$ ): Port 2 Control 0
Register 48 ( $0 \times 30$ ): Port 3 Control 0
Register 64 ( $0 \times 40$ ): Port 4 Control 0
Register 80 ( $0 \times 50$ ): Port 5 Control 0

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Broadcast Storm Protection Enable | 1, enable broadcast storm protection for ingress packets on the port. <br> 0 , disable broadcast storm protection. | R/W | 0 |
| 6 | DiffServ Priority Classification Enable | 1, enable DiffServ priority classification for ingress packets on port. <br> 0, disable DiffServ function. | R/W | 0 |
| 5 | 802.1p Priority Classification Enable | 1, enable 802.1p priority classification for ingress packets on port. <br> 0 , disable 802.1p. | R/W | 0 |
| 4-3 | Port-Based Priority Classification Enable | $=00$, ingress packets on port will be classified as priority 0 queue if "Diffserv" or "802.1p" classification is not enabled or fails to classify. <br> $=01$, ingress packets on port will be classified as priority 1 queue if "Diffserv" or "802.1p" classification is not enabled or fails to classify. <br> $=10$, ingress packets on port will be classified as priority 2 queue if "Diffserv" or "802.1p" classification is not enabled or fails to classify. <br> $=11$, ingress packets on port will be classified as priority 3 queue if "Diffserv" or "802.1p" classification is not enabled or fails to classify. <br> Note: "DiffServ", "802.1p" and port priority can be enabled at the same time. The OR'd result of 802.1p and DSCP overwrites the port priority. | R/W | 00 |
| 2 | Tag Insertion | 1, when packets are output on the port, the switch will add 802.1 q tags to packets without 802.1 q tags when received. The switch will not add tags to packets already tagged. The tag inserted is the ingress port's "port VID." <br> 0 , disable tag insertion. | R/W | 0 |
| 1 | Tag Removal | 1, when packets are output on the port, the switch will remove 802.1q tags from packets with 802.1q tags when received. The switch will not modify packets received without tags. <br> 0 , disable tag removal. | R/W | 0 |

## Port Registers (Continued)

Register 16 ( $0 \times 10$ ): Port 1 Control 0
Register 32 ( $0 \times 20$ ): Port 2 Control 0
Register 48 ( $0 \times 30$ ): Port 3 Control 0
Register 64 ( $0 \times 40$ ): Port 4 Control 0
Register 80 ( $0 \times 50$ ): Port 5 Control 0

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 0 | Two Queues Split Enable | This bit0 in the register16/32/48/64/80 should be combination with Register177/193/209/225/241 bit 1 for port 1-5 will select the split of 1/2/4 queues: <br> For port 1, [Register177 bit 1, Register16 bit 0] = [11], Reserved <br> [10], the port output queue is split into four priority queues or if map 802.1p to priority 0-3 mode. <br> [01], the port output queue is split into two priority queues or if map 802.1 p to priority $0-3$ mode. [00], single output queue on the port. There is no priority differentiation even though packets are classified into high or low priority. | R/W | 0 |

Register 17 ( $0 \times 11$ ): Port 1 Control 1
Register 33 ( $0 \times 21$ ): Port 2 Control 1
Register 49 ( $0 \times 31$ ): Port 3 Control 1
Register 65 ( $0 \times 41$ ): Port 4 Control 1
Register 81 ( $0 \times 51$ ): Port 4 Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Sniffer Port | 1, port is designated as sniffer port and will transmit packets that are <br> monitored. <br> 0, port is a normal port. | R/W | 0 |
| 6 | Receive Sniff | 1, all the packets received on the port will be marked as "monitored <br> packets" and forwarded to the designated "sniffer port." <br> 0, no receive monitoring. | R/W | 0 |
| 5 | Transmit Sniff | 1, all the packets transmitted on the port will be marked as "monitored <br> packets" and forwarded to the designated "sniffer port." <br> 0, no transmit monitoring. | R/W | 0 |
| $4-0$ | Port VLAN Membership | Define the port's Port VLAN membership. Bit 4 stands for port 5, bit 3 <br> for port 4...bit 0 for port 1. The port can only communicate within the <br> membership. A '1' includes a port in the membership; a '0' excludes a <br> port from membership. | R/W | 0x1f |

## Port Registers (Continued)

Register 18 ( $0 \times 12$ ): Port 1 Control 2
Register 34 ( $0 \times 22$ ): Port 2 Control 2
Register 50 ( $0 \times 32$ ): Port 3 Control 2
Register 66 ( $0 \times 42$ ): Port 4 Control 2
Register $82(0 \times 52)$ : Port 5 Control 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | User Priority Ceiling | 1, If packet 's "user priority field" is greater than the "user <br> priority field" in the port default tag register, replace the <br> packet's "user priority field" with the "user priority field" in <br> the port default tag register control 3. <br> 0, no replace packet's priority filed with port default tag <br> priority filed of the port register control 3 bit [7:5]. | R/W | 0 |
| 6 | Ingress VLAN Filtering. | 1, the switch will discard packets whose VID port <br> membership in VLAN table bits [11:7] does not include <br> the ingress port. <br> 0, no ingress VLAN filtering. | R/W | 0 |
| 5 | Discard Non-PVID <br> packets | 1, the switch will discard packets whose VID does not <br> match ingress port default VID. <br> 0, no packets will be discarded. | R/W | 0 |

## Port Registers (Continued)

Register 18 ( $0 \times 12$ ): Port 1 Control 2
Register 34 ( $0 \times 22$ ): Port 2 Control 2
Register 50 ( $0 \times 32$ ): Port 3 Control 2
Register 66 ( $0 \times 42$ ): Port 4 Control 2
Register 82 ( $0 \times 52$ ): Port 5 Control 2

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 4 | Force Flow Control | 1, will always enable $R x$ and Tx flow control on the port, regardless of AN result. <br> 0 , the flow control is enabled based on AN result (Default) <br> Note: This bit is reserved for port 5, SW5-MII use the register 6 bit5 for the flow control. | R/W | Strap-in option <br> LED1_1/PCOL For port 3/port 4 LED1_1 default Pull up (1): Not force flow control; PCOL default Pulldown (0): Not force flow control. LED1_1 Pull down (0): Force flow control; PCOL Pullup (1): Force flow control. <br> Note: LED1_1 has internal pull-up; PCOL have internal pull-down. |
| 3 | Back Pressure Enable | 1, enable port half-duplex back pressure. <br> 0 , disable port half-duplex back pressure. <br> Note: This bit is reserved for port 5, SW5-MII use the register 6 bit7 for the back pressure. | R/W | $\overline{0}$ <br> Pin PMRXD2 strap option. <br> Pull-down (0): disable back pressure. <br> Pull-up(1): enable back pressure. Note: PMRXD2 has internal pulldown. |
| 2 | Transmit Enable | 1, enable packet transmission on the port. 0 , disable packet transmission on the port. | R/W | 1 |
| 1 | Receive Enable | 1, enable packet reception on the port. 0 , disable packet reception on the port. | R/W | 1 |
| 0 | Learning Disable | 1, disable switch address learning capability. 0 , enable switch address learning. | R/W | 0 |

## Port Registers (Continued)

Register 19 ( $0 \times 13$ ): Port 1 Control 3
Register 35 ( $0 \times 23$ ): Port 2 Control 3
Register 51 ( $0 \times 33$ ): Port 3 Control 3
Register 67 ( $0 \times 43$ ): Port 4 Control 3
Register $83(0 \times 53)$ : Port 5 Control 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :--- | :---: |
| 0 | Default Tag [15:8] | Port's default tag, containing: <br> $7-5:$ user priority bits <br> $4:$ CFI bit <br> $3-0:$ VID[11:8] | R/W |  |

Register 20 ( $0 \times 14$ ): Port 1 Control 4
Register 36 ( $0 \times 24$ ): Port 2 Control 4
Register 52 ( $0 \times 34$ ): Port 3 Control 4
Register 68 ( $0 \times 44$ ): Port 4 Control 4
Register 84 ( $0 \times 54$ ): Port 5 Control 4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Default Tag [7:0] | Default port 1's tag, containing: <br> $7-0:$ VID[7:0] | R/W | 1 |

Note:
Registers 19 and 20 (and those corresponding to other ports) serve two purposes: (1) Associated with the ingress untagged packets, and used for egress tagging; (2) Default VID for the ingress untagged or null-VID-tagged packets, and used for address look up.

Register 87 ( $0 \times 57$ ): Reserved Control Register

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Reserved | N/A, don't change | RO | $0 \times 00$ |

## Port Registers (Continued)

Register 25 ( $0 \times 19$ ): Port 1 Status 0
Register 41 ( $0 \times 29$ ): Port 2 Status 0
Register 57 ( $0 \times 39$ ): Port 3 Status 0
Register 73 ( $0 \times 49$ ): Port 4 Status 0
Register 89 ( $0 \times 59$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Hp_mdix | $1=$ HP Auto MDI/MDI-X mode <br> $0=$ Micrel Auto MDI/MDI-X mode | R/W | 1 |
| 6 | Factory Testing | Reserved | RO | 0 |
| 5 | Polrvs | $1=$ Polarity is reversed <br> $0=$ Polarity is not reversed | RO | 0 |
| 4 | Transmit Flow Control <br> Enable | $1=$ Transmit flow control feature is active <br> $0=$ Transmit flow control feature is inactive | RO | 0 |
| 3 | Receive Flow Control <br> Enable | $1=$ Receive flow control feature is active <br> $0=$ Receive flow control feature is inactive | RO | 0 |
| 2 | Operation Speed | $1=$ Link speed is $100 M b p s$ <br> $0=$ Link speed is $10 M b p s$ | RO | 0 |
| 1 | Operation Duplex | $1=$ Link duplex is full <br> $0=$ Link duplex is half | RO | 0 |
| 0 | Reserved | N/A |  | 0 |

Register $26(0 \times 1 \mathrm{~A})$ : Port 1 PHY Special Control/Status
Register 42 ( $0 \times 2 \mathrm{~A}$ ): Port 2 PHY Special Control/Status
Register $58(0 \times 3 A)$ : Port 3 PHY Special Control/Status
Register $74(0 \times 4 \mathrm{~A})$ : Port 4 PHY Special Control/Status
Register 90 ( $0 \times 5 \mathrm{~A}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Vct 10M Short | 1 = less than 10 meter short detected | RO | 0 |
| 6-5 | Vct_result | $00=$ Normal condition <br> 01 = Open condition detected in cable <br> $10=$ Short condition detected in cable <br> 11 = Cable diagnostic test has failed | RO | 00 |
| 4 | Vct_enable | 1 = Enable cable diagnostic test. After VCT test has completed, this bit will be self-cleared. $0=$ Indicate cable diagnostic test (if enabled) has completed and the status information is valid for read. | $\begin{aligned} & \mathrm{R} / \mathrm{W} \\ & \text { (SC) } \end{aligned}$ | 0 |
| 3 | Force_Ink | 1 = Force link pass <br> 0 = Normal Operation | R/W | 0 |
| 2 | Pwrsave | 1 = Enable power saving <br> 0 = Disable power saving | R/W | 0 |
| 1 | Remote Loopback | 1 = Perform Remote loopback, loopback on port 1 as follows: Port 1 (reg. 26, bit 1 = ' 1 ') <br> Start : RXP1/RXM1 (port 1) <br> Loopback: PMD/PMA of port 1's PHY <br> End: TXP1/TXM1 (port 1) <br> Setting reg. $42,58,74,90$, bit $1=$ ' 1 ' will perform remote loopback on port 2, 3, 4, 5. <br> $0=$ Normal Operation. | R/W | 0 |
| 0 | Vct_fault_count [8] | Bits[8] of VCT fault count. | RO | 0 |

## Port Registers (Continued)

Register 27 ( $0 \times 1 \mathrm{~B}$ ): Port 1 LinkMD Result
Register 43 ( $0 \times 2 \mathrm{2B}$ ): Port 2 LinkMD Result
Register 59 (0×3B): Port 3 LinkMD Result
Register 75 ( $0 \times 4 \mathrm{~B}$ ): Port 4 LinkMD Result
Register 91 ( $0 \times 5 \mathrm{~B}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $7-0$ | Vct_fault_count [7:0] | Bits[7:0] of VCT fault count <br> Distance to the fault. <br> It's approximately $0.4 \mathrm{~m}^{*}$ Vct_fault_count [8:0] | RO | 0 |

Register 28 ( $0 \times 1 \mathrm{C}$ ): Port 1 Control 5
Register 44 ( $0 \times 2 \mathrm{C}$ ): Port 2 Control 5
Register $60(0 \times 3 C)$ : Port 3 Control 5
Register $76(0 \times 4 \mathrm{C})$ : Port 4 Control 5
Register 92 ( $0 \times 5 \mathrm{C}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Disable AutoNegotiation | 1, disable auto-negotiation, speed and duplex are decided by bit 6 and 5 of the same register. <br> 0 , auto-negotiation is on. <br> Note: The register bit value is the INVERT of the strap value at the pin. | R/W | For port 3/port 4 only. INVERT of pins LED[2][1]/LED[5][0] strap option. <br> PD(0): Disable AutoNegotiation. <br> PU(1): Enable AutoNegotiation. <br> Note:LED[2][1]/LED[5][0] have internal pull up. |
| 6 | Forced Speed | 1, forced 100BT if AN is disabled (bit 7). 0 , forced 10BT if AN is disabled (bit 7). | R/W | 1 |
| 5 | Forced Duplex | 1, forced full-duplex if (1) AN is disabled or (2) AN is enabled but failed. <br> 0 , forced half-duplex if (1) AN is disabled or (2) AN is enabled but failed (Default). | R/W | For port 3/port 4 only. Pins LED1_0/PCRS strap option. <br> 1. For force half-duplex: LED1_0 pin Pull-up(1) (default) <br> PCRS pin Pull-down (0) (default). 2. For force full-duplex: LED1_0 pin Pull-down(0). <br> PCRS Pull-up (1): <br> Note: LED1_0 has internal pull-up; PCRS have internal pull down. |

## Port Registers (Continued)

Register 28 ( $0 \times 1 \mathrm{C}$ ): Port 1 Control 5
Register 44 ( $0 \times 2 \mathrm{C}$ ): Port 2 Control 5
Register 60 ( $0 \times 3 \mathrm{C}$ ): Port 3 Control 5
Register 76 ( $0 \times 4$ C): Port 4 Control 5
Register 92 ( $0 \times 5 \mathrm{C}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 4 | Advertised Flow Control <br> Capability | 1, advertise flow control capability. <br> 0, suppress flow control capability from transmission to <br> link partner. | R/W | 1 |
| 3 | Advertised 100BT Full- <br> Duplex Capability | 1, advertise 100BT full-duplex capability. <br> 0, suppress 100BT full-duplex capability from <br> transmission to link partner. | R/W | 1 |
| 2 | Advertised 100BT Half- <br> Duplex Capability | 1, advertise 100BT half-duplex capability. <br> 0, suppress 100BT half-duplex capability from <br> transmission to link partner. | R/W | 1 |
| 1 | Advertised 10BT Full- <br> Duplex Capability | 1, advertise 10BT full-duplex capability. <br> 0, suppress 10BT full-duplex capability from <br> transmission to link partner. | R/W | 1 |
| 0 | Advertised 10BT Half- <br> Duplex Capability | 1, advertise 10BT half-duplex capability. <br> 0, suppress 10BT half-duplex capability from <br> transmission to link partner. | R/W | 1 |

Register 29 ( $0 \times 1 \mathrm{D}$ ): Port 1 Control 6
Register 45 ( $0 \times 2 \mathrm{D}$ ): Port 2 Control 6
Register 61 ( $0 \times 3 \mathrm{D}$ ): Port 3 Control 6
Register 77 ( $0 \times 4 \mathrm{D}$ ): Port 4 Control 6
Register 93 ( $0 \times 5 \mathrm{D}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | LED Off | 1, turn off all port's LEDs (LEDx_2, LEDx_1, LEDx_0, <br> where "x" is the port number). These pins will be <br> driven high if this bit is set to one. <br> 0, normal operation. | R/W | 0 |
| 6 | Txids | 1, disable port's transmitter. <br> 0, normal operation. | R/W | 0 |
| 5 | Restart AN | 1, restart auto-negotiation. <br> 0, normal operation. | R/W <br> (SC) | RO |
| 4 | FX reserved | N/A | R/W | 0 |
| 3 | Power Down | 1, power down. <br> 0, normal operation. | 0 |  |
| 2 | Disable Auto MDI/MDI-X | 1, disable auto MDI/MDI-X function. <br> 0, enable auto MDI/MDI-X function. | 0 |  |
| 1 | Forced MDI | 1, if auto MDI/MDI-X is disabled, force PHY into MDI <br> mode. <br> 0, MDI-X mode. | R/W | 0 |

## Port Registers (Continued)

Register 29 ( $0 \times 1 \mathrm{D}$ ): Port 1 Control 6
Register 45 ( $0 \times 2 \mathrm{D}$ ): Port 2 Control 6
Register 61 ( $0 \times 3 \mathrm{D}$ ): Port 3 Control 6
Register 77 ( $0 \times 4 \mathrm{D}$ ): Port 4 Control 6
Register 93 ( $0 \times 5 \mathrm{D}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :--- | :--- |
|  |  | 1 = Perform MAC loopback, loop back path as follows: <br> E.g. set port 1 MAC Loopback (reg. 29, bit 0 = '1'), use <br> port 2 as monitor port. The packets will transfer <br> Start: Port 2 receiving (also can start to receive <br> packets from port 3, 4, 5). <br> Loop-back: Port 1's MAC. <br> End: Port 2 transmitting (also can end at port 3, 4, | R/W |  |
| MAC Loopback |  | respectively). <br> Setting reg. 45, 61, 77, 93, bit 0 = '1' will perform MAC <br> loopback on port 2, 3, 4, 5 respectively. <br> $0=$ Normal Operation. | 0 |  |

Register 30 ( $0 \times 1 \mathrm{E}$ ): Port 1 Status 1
Register 46 ( $0 \times 2 \mathrm{E}$ ): Port 2 Status 1
Register 62 ( $0 \times 3 \mathrm{E}$ ): Port 3 Status 1
Register 78 ( $0 \times 4 \mathrm{E}$ ): Port 4 Status 1
Register 94 ( $0 \times 5 \mathrm{E}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | MDIX Status | 1, MDI. <br> 0, MDI-X. | RO | 0 |
| 6 | AN Done | 1, AN done. <br> 0, AN not done. | RO | 0 |
| 5 | Link Good | 1, link good. <br> 0, link not good. | RO | 0 |
| 4 | Partner Flow Control <br> Capability | 1, link partner flow control capable. <br> 0, link partner not flow control capable. | RO | 0 |
| 3 | Partner 100BT Full- <br> Duplex Capability | 1, link partner 100BT full-duplex capable. <br> 0, link partner not 100BT full-duplex capable. | RO | 0 |
| 2 | Partner 100BT Half- <br> Duplex Capability | 1, link partner 100BT half-duplex capable. <br> 0, link partner not 100BT half-duplex capable. | RO | 0 |
| 1 | Partner 10BT Full-Duplex <br> Capability | 1, link partner 10BT full-duplex capable. <br> 0, link partner not 10BT full-duplex capable. | RO | 0 |
| 0 | Partner 10BT Half-Duplex <br> Capability | 1, link partner 10BT half-duplex capable. <br> 0, link partner not 10BT half-duplex capable. | 0 |  |

## Port Registers (Continued)

Register 31 ( $0 \times 1 \mathrm{~F}$ ): Port 1 Control 7 and Status 2
Register 47 ( $0 \times 2 \mathrm{~F}$ ): Port 2 Control 7 and Status 2
Register 63 ( $0 \times 3 \mathrm{~F}$ ): Port 3 Control 7 and Status 2
Register 79 ( $0 \times 4 \mathrm{~F}$ ): Port 4 Control 7 and Status 2
Register 95 ( $0 \times 5 \mathrm{~F}$ ): Reserved

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | PHY Loopback | 1 = Perform PHY loopback, loop back path as follows: E.g. set port 1 PHY Loopback (reg. 31, bit 7 = '1') <br> Use the port 2 as monitor port. The packets will transfer <br> Start: Port 2 receiving (also can start from port 3, 4, <br> 5). <br> Loopback: PMD/PMA of port 1's PHY <br> End: Port 2 transmitting (also can end at port 3, 4, 5 respectively). <br> Setting reg. 47, 63, 79, 95, bit $7=$ ' 1 ' will perform PHY loopback on port 2, 3, 4, 5 respectively. <br> $0=$ Normal Operation. | R/W | 0 |
| 6 | Reserved |  | RO | 0 |
| 5 | PHY Isolate | 1, electrical isolation of PHY from MII and TX+/TX-. 0 , normal operation. | R/W | 0 |
| 4 | Soft Reset | 1, PHY soft reset. This bit is self-clear. 0, normal operation. | $\begin{aligned} & \text { R/W } \\ & \text { (SC) } \end{aligned}$ | 0 |
| 3 | Force Link | 1, force link in the PHY. <br> 0 , normal operation | R/W | 0 |
| 2-0 | Port Operation Mode Indication | Indicate the current state of port operation mode: <br> [000] = Reserved <br> [001] = Still in auto-negotiation <br> [010] = 10BASE-T half duplex <br> [011] = 100BASE-TX/FX half duplex <br> [100] = Reserved <br> [101] = 10BASE-T full duplex <br> [110] = 100BASE-TX/FX full duplex <br> [111] = Reserved | RO | 001 |

Note:
Port Control 12 and 13, 14 and Port Status 1, 2 contents can be accessed by MIIM (MDC/MDIO) interface via the standard MIIM register definition.

## Advanced Control Registers

Registers 104 to 109 define the switching engine's MAC address. This 48 -bit address is used as the source address in MAC pause control frames.

Register 104 (0×68): MAC Address Register 0

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[47:40] |  | R/W | $0 \times 00$ |

Register 105 ( $0 \times 69$ ): MAC Address Register 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[39:32] |  | R/W | $0 \times 10$ |

Register $106(0 \times 6 A)$ : MAC Address Register 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[31:24] |  | R/W | 0xA1 |

Register 107 ( $0 \times 6 \mathrm{~B}$ ): MAC Address Register 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[23:16] |  | R/W | 0xff |

Register 108 ( $0 \times 6 \mathrm{C}$ ): MAC Address Register 4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[15:8] |  | R/W | 0xff |

Register 109 (0×6D): MAC Address Register 5

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | MACA[7:0] |  | R/W | 0xff |

## Advanced Control Registers (Continued)

Use registers 110 and 111 to read or write data to the static MAC address table, VLAN table, dynamic address table, or the MIB counters.

Register 110 ( $0 \times 6 \mathrm{E}$ ): Indirect Access Control 0

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-5$ | Reserved | Reserved. | R/W | 000 |
| 4 | Read High Write Low | 1, read cycle. <br> 0, write cycle. | R/W | 0 |
| $3-2$ | Table Select | $00=$ Static MAC address table selected. <br> $01=$ VLAN table selected. <br> $10=$ Dynamic address table selected. <br> $11=$ MIB counter selected. | R/W | 0 |
| $1-0$ | Indirect Address High | Bit $9-8$ of indirect address. | R/W | 00 |

Register 111 ( $0 \times 6 \mathrm{~F}$ ): Indirect Access Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Indirect Address Low | Bit $7-0$ of indirect address. | R/W | 00000000 |

Note:
Write to Register 111 will actually trigger a command. Read or write access will be decided by bit 4 of Register 110.

Register 112 ( $0 \times 70$ ): Indirect Data Register 8

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $68-64$ | Indirect Data | Bit $68-64$ of indirect data. | R/W | 00000 |

Register 113 (0×71): Indirect Data Register 7

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $63-56$ | Indirect Data | Bit $63-56$ of indirect data. | R/W | 00000000 |

Register 114 ( $0 \times 72$ ): Indirect Data Register 6

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $55-48$ | Indirect Data | Bit $55-48$ of indirect data. | R/W | 00000000 |

Register 115 (0×73): Indirect Data Register 5

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $47-40$ | Indirect Data | Bit $47-40$ of indirect data. | R/W | 00000000 |

Register 116 ( $0 \times 74$ ): Indirect Data Register 4

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $39-32$ | Indirect Data | Bit $39-32$ of indirect data. | R/W | 00000000 |

## Advanced Control Registers (Continued)

Use registers 110 and 111 to read or write data to the static MAC address table, VLAN table, dynamic address table, or the MIB counters.

Register 117 ( $0 \times 75$ ): Indirect Data Register 3

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $31-24$ | Indirect Data | Bit of $31-24$ of indirect data | R/W | 00000000 |

Register 118 ( $0 \times 76$ ): Indirect Data Register 2

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $23-16$ | Indirect Data | Bit $23-16$ of indirect data. | R/W | 00000000 |

Register 119 ( $0 \times 77$ ): Indirect Data Register 1

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $15-8$ | Indirect Data | Bit $15-8$ of indirect data. | R/W | 00000000 |

Register 120 ( $0 \times 78$ ): Indirect Data Register 0

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Indirect Data | Bit $7-0$ of indirect data. | R/W | 00000000 |

Register 124 (0x7C): Interrupt Status Register

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-5 | Reserved | Reserved | RO | 000 |
| 4 | Reserved | Reserved | RO | 0 |
| 3 | Port 4 Interrupt Status | 1, Port 4 interrupt request <br> 0 , normal <br> Note: This bit is set by port 4 link change. Write a " 1 " to clear this bit | RO | 0 |
| 2 | Port 3 Interrupt Status | 1, Port 3 interrupt request <br> 0 , normal <br> Note: This bit is set by port 3 link change. Write a " 1 " to clear this bit | RO | 0 |
| 1 | Port 2 Interrupt Status | 1, Port 2 interrupt request <br> 0 , normal <br> Note: This bit is set by port 2 link change. Write a " 1 " to clear this bit | RO | 0 |
| 0 | Port 1 Interrupt Status | 1, Port 1 interrupt request <br> 0 , normal <br> Note: This bit is set by port 1 link change. Write a " 1 " to clear this bit | RO | 0 |

## Advanced Control Registers (Continued)

Use registers 110 and 111 to read or write data to the static MAC address table, VLAN table, dynamic address table, or the MIB counters.

Register 125 (0x7D): Interrupt Mask Register

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-5$ | Reserved | Reserved. | RO | 000 |
| 4 | Reserved | Reserved | RO | 0 |
| 3 | Port 4 Interrupt Mask | 1, Port 4 interrupt mask <br> 0, normal | R/W | 0 |
| 2 | Port 3 Interrupt Mask | 1, Port 3 interrupt mask <br> 0, normal | R/W | 0 |
| 1 | Port 2 Interrupt Mask | 1, Port 2 interrupt mask <br> 0, normal | R/W | 0 |
| 0 | Port 1 Interrupt Mask | 1, Port 1 interrupt mask <br> 0, normal | R/W | 0 |

The registers 128,129 can be used to map from 802.1 p priority field $0-7$ to switch's four priority queues $0-3$, $0 \times 3$ is highest priority queues as priority $3,0 x 0$ is lowest priority queues as priority 0.

Register 128 (0x80): Global Control 12

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :--- | :---: |
| $7-6$ | Tag_0x3 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x3 | R/W | $0 \times 1$ |
| $5-4$ | Tag_0x2 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x2 | R/W | $0 \times 1$ |
| $3-2$ | Tag_0x1 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x1 | R/W | $0 \times 0$ |
| $1-0$ | Tag_0x0 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x0 | R/W | $0 \times 0$ |

## Register 129 (0x81): Global Control 13

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | Tag_0x7 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x7 | R/W | $0 \times 3$ |
| $5-4$ | Tag_0x6 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x6 | R/W | $0 \times 3$ |
| $3-2$ | Tag_0x5 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x5 | R/W | $0 \times 2$ |
| $1-0$ | Tag_0x4 | IEEE 802.1p mapping. The value in this field is <br> used as the frame's priority when its IEEE 802.1p <br> tag has a value of 0x4 | R/W | $0 \times 2$ |

## Advanced Control Registers (Continued)

Register 130 (0x82): Global Control 14

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-6 | Pri_2Q[1:0] <br> (Note that program Prio_2Q[1:0] = 01 is not supported and should be avoided) | When the 2 Queue configuration is selected, these Pri_2Q[1:0] bits are used to map the 2-bit result of IEEE 802.1p from register 128/129 or TOS/DiffServ from register 144-159 mapping (for 4 Queues) into two queues low/high priorities. <br> 2-bit result of IEEE 802.1p or TOS/DiffServ <br> $00(0)=$ map to Low priority queue <br> 01 (1) = Prio_2Q[0] map to Low/High priority queue <br> 10 (2) = Prio_2Q[1] map to Low/High priority queue <br> 11 (3) = map to High priority queue <br> Pri_2Q[1:0] = <br> 00: Result 0, 1, 2 are low priority. 3 is high priority. <br> 10: Result 0, 1 are low priority. 2, 3 are high priority (default). <br> 11: Result 0 is low priority. 1, 2, 3 are high priority. | R/W | 10 |
| 5 | Reserved | N/A, don't change | RO | 0 |
| 4 | Reserved | N/A, don't change | RO | 0 |
| 3-2 | Reserved | N/A, don't change | RO | 01 |
| 1 | Reserved | N/A, don't change | RO | 0 |
| 0 | Reserved | N/A, don't change | RO | 0. |

Register 131 (0x83): Global Control 15

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Reserved | N/A | RO | 1 |
| 6 | Reserved | N/A | RO | 0 |
| 5 | Unknown unicast packet forward | 1 = enable supporting unknown unicast packet forward $0 \text { = disable }$ | R/W | 0 |
| 4-0 | Unknown unicast packet forward port map | 00000 = filter unknown unicast packet <br> 00001 = forward unknown unicast packet to port 1 <br> 00011 = forward unknown unicast packet to port 1, port 2 <br> 11111 = broadcast unknown unicast packet to all ports | R/W | 00000 |

## Advanced Control Registers (Continued)

Register 132 (0x84): Global Control 16

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| $7-6$ | Chip I/O output drive strength select[1:0] | Output drive strength select[1:0] = <br> $00=4 \mathrm{~mA}$ drive strength <br> $01=8 \mathrm{~mA}$ drive strength (default) <br> $10=12 \mathrm{~mA}$ drive strength <br> $11=16 \mathrm{~mA}$ drive strength <br> Note: <br> bit[1] value is the INVERT of the strap value at the pin. <br> bit[0] value is the SAME of the strap value at the pin | R/W | Pin LED[3][0] strap option. Pulldown (0): Select 12mA drive strength. Pull-up (1): Select 8 mA drive strength. Note: LED[3][0] has internal pullup. |
| 5 | Unknown multicast packet forward (not including IP multicast packet) | 1 = enable supporting unknown multicast packet forward $0 \text { = disable }$ | R/W | 0 |
| 4-0 | Unknown multicast packet forward port map | $00000=$ filter unknown multicast packet <br> 00001 = forward unknown multicast packet to port 1 <br> 00011 = forward unknown multicast packet to port 1, port 2 <br> 11111 = broadcast unknown multicast packet to all ports | R/W | 00000 |

Register 133(0x85): Global Control 17

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-6 | Reserved |  | RO | 00 |
| 5 | Unknown VID packet forward | 1 = enable supporting unknown VID packet forward $0=$ disable | R/W | 0 |
| 4-0 | Unknown VID packet forward port map | ```00000 = filter unknown VID packet 00001 = forward unknown VID packet to port 1 00011 = forward unknown VID packet to port 1, port 2 11111 = broadcast unknown VID packet to all ports``` | R/W | 00000 |

## Advanced Control Registers (Continued)

Register 134 (0x86): Global Control 18

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Reserved | N/A | RO | 0 |
| 6 | Self-Address Filter Enable | 1 = Enable filtering of self-address unicast and multicast packet <br> 0 = Do not filter self-address packet <br> Note: The self-address filtering will filter packets on the egress port, self MAC address is assigned in the register 104-109. | R/W | 0 |
| 5 | Unknown IP multicast packet forward | 1 = enable supporting unknown IP multicast packet forward $0=\text { disable }$ | R/W | 0 |
| 4-0 | Unknown IP multicast packet forward port map | 00000 = filter unknown IP multicast packet <br> 00001 = forward unknown IP multicast packet to port 1 <br> 00011 = forward unknown IP multicast packet to port <br> 1, port 2 <br> 11111 = broadcast unknown IP multicast packet to all ports | R/W | 00000 |

Register 135 (0x87): Global Control 19

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved | N/A, don't change | RO | 0 |
| 6 | Reserved | N/A, don't change | RO | 0 |
| $5-4$ | Ingress Rate Limit Period | The unit period for calculating Ingress Rate Limit <br> $00=16 \mathrm{~ms}$ <br> $01=64 \mathrm{~ms}$ <br> $1 x=256 \mathrm{~ms}$ | R/W | 01 |
| 3 | Queue-based Egress Rate <br> Limit Enabled | Enable Queue-based Egress Rate Limit <br> $0=$ port-base Egress Rate Limit (default) <br> $1=$ queue-based Egress Rate Limit | R/W | 0 |
| 2 | Insertion Source Port PVID <br> Tag Selection Enable | $1=$ enable source port PVID tag insertion or non- <br> insertion option on the egress port for each source port <br> PVID based on the ports registers control 8. <br> $0=$ disable, all packets from any ingress port will be <br> inserted PVID based on port register control 0 bit 2. | R/W | 0 |
| $1-0$ | Reserved | N/A, don't change | RO | 0 |

## Advanced Control Registers (Continued)

## Register 144 ( $0 \times 90$ ): TOS Priority Control Register 0

The IPv4/IPv6 TOS priority control registers implement a fully decoded 64 bit differentiated services code point (DSCP) register used to determine priority from the 6 bit TOS field in the IP header. The most significant 6 bits of the TOS field are fully decoded into 64 possibilities, and the singular code that results is mapped to the value in the corresponding bit in the DSCP register.

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :--- | :---: |
| $7-6$ | DSCP[7:6] | IPv4 and IPv6 mapping <br> The value in this field is used as the frame's priority <br> when bits[7:2] of the frame's IP TOS/DiffServ/Traffic <br> Class value is 0x0C | R/W | 00 |
| $5-4$ | DSCP[5:4] | IPv4 and IPv6 mapping <br> The value in this field is used as the frame's priority <br> when bits[7:2] of the frame's IP TOS/DiffServ/Traffic <br> Class value is 0x08 | R/W | 00 |
| $3-2$ | DSCP[3:2] | IPv4 and IPv6 mapping <br> The value in this field is used as the frame's priority <br> when bits[7:2] of the frame's IP TOS/DiffServ/Traffic <br> Class value is 0x04 | R/W | 00 |
| $1-0$ | DSCP[1:0] | IPv4 and IPv6 mapping <br> The value in this field is used as the frame's priority <br> when bits[7:2] of the frame's IP TOS/DiffServ/Traffic <br> Class value is 0x00 | R/W | 00 |

Register 145 (0x91): TOS Priority Control Register 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[15:14] | IPv4 and IPv6 mapping_for value 0x1C | R/W | 00 |
| $5-4$ | DSCP[13:12] | IPv4 and IPv6 mapping_for value 0x18 | R/W | 00 |
| $3-2$ | DSCP[11:10] | IPv4 and IPv6 mapping_for value 0x14 | R/W | 00 |
| $1-0$ | DSCP[9:8] | IPv4 and IPv6 mapping_for value 0x10 | R/W | 00 |

## Register 146 (0x92): TOS Priority Control Register 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[23:22] | IPv4 and IPv6 mapping_for value 0x2C | R/W | 00 |
| $5-4$ | DSCP[21:20] | IPv4 and IPv6 mapping_for value 0x28 | R/W | 00 |
| $3-2$ | DSCP[19:18] | IPv4 and IPv6 mapping_for value 0x24 | R/W | 00 |
| $1-0$ | DSCP[17:16] | IPv4 and IPv6 mapping_for value 0x20 | R/W | 00 |

Register 147 (0x93): TOS Priority Control Register 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[31:30] | IPv4 and IPv6 mapping_for value 0x3C | R/W | 00 |
| $5-4$ | DSCP[29:28] | IPv4 and IPv6 mapping_for value 0x38 | R/W | 00 |
| $3-2$ | DSCP[27:26] | IPv4 and IPv6 mapping_for value 0x34 | R/W | 00 |
| $1-0$ | DSCP[25:24] | IPv4 and IPv6 mapping_for value 0x30 | R/W | 00 |

## Advanced Control Registers (Continued)

Register 148 (0x94): TOS Priority Control Register 4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[39:38] | IPv4 and IPv6 mapping_for value 0x4C | R/W | 00 |
| $5-4$ | DSCP[37:36] | IPv4 and IPv6 mapping__for value 0x48 | R/W | 00 |
| $3-2$ | DSCP[35:34] | IPv4 and IPv6 mapping_for value 0x44 | R/W | 00 |
| $1-0$ | DSCP[33:32] | IPv4 and IPv6 mapping_for value 0x40 | R/W | 00 |

Register 149 (0x95): TOS Priority Control Register 5

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[47:46] | IPv4 and IPv6 mapping_for value 0x5C | R/W | 00 |
| $5-4$ | DSCP[45:44] | IPv4 and IPv6 mapping_for value 0x58 | R/W | 00 |
| $3-2$ | DSCP[43:42] | IPv4 and IPv6 mapping_for value 0x54 | R/W | 00 |
| $1-0$ | DSCP[41:40] | IPv4 and IPv6 mapping_for value 0x50 | R/W | 00 |

Register 150 (0x96): TOS Priority Control Register 6

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[55:54] | IPv4 and IPv6 mapping_for value 0x6C | R/W | 00 |
| $5-4$ | DSCP[53:52] | IPv4 and IPv6 mapping_for value 0x68 | R/W | 00 |
| $3-2$ | DSCP[51:50] | IPv4 and IPv6 mapping_for value 0x64 | R/W | 00 |
| $1-0$ | DSCP[49:48] | IPv4 and IPv6 mapping_for value 0x60 | R/W | 00 |

## Register 151 (0x97): TOS Priority Control Register 7

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[63:62] | IPv4 and IPv6 mapping_for value 0x7C | R/W | 00 |
| $5-4$ | DSCP[61:60] | IPv4 and IPv6 mapping_for value 0x78 | R/W | 00 |
| $3-2$ | DSCP[59:58] | IPv4 and IPv6 mapping_for value 0x74 | R/W | 00 |
| $1-0$ | DSCP[57:56] | IPv4 and IPv6 mapping_for value 0x70 | R/W | 00 |

Register 152 (0x98): TOS Priority Control Register 8

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[71:70] | IPv4 and IPv6 mapping_for value 0x8C | R/W | 00 |
| $5-4$ | DSCP[69:68] | IPv4 and IPv6 mapping_for value 0x88 | R/W | 00 |
| $3-2$ | DSCP[67:66] | IPv4 and IPv6 mapping_for value 0x84 | R/W | 00 |
| $1-0$ | DSCP[65:64] | IPv4 and IPv6 mapping_for value 0x80 | R/W | 00 |

## Advanced Control Registers (Continued)

Register 153 (0x99): TOS Priority Control Register 9

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[79:78] | IPv4 and IPv6 mapping_for value 0x9C | R/W | 00 |
| $5-4$ | DSCP[77:76] | IPv4 and IPv6 mapping_for value 0x98 | R/W | 00 |
| $3-2$ | DSCP[75:74] | IPv4 and IPv6 mapping_for value 0x94 | R/W | 00 |
| $1-0$ | DSCP[73:72] | IPv4 and IPv6 mapping_for value 0x90 | R/W | 00 |

## Register 154 (0x9A): TOS Priority Control Register 10

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[87:86] | IPv4 and IPv6 mapping_for value 0xAC | R/W | 00 |
| $5-4$ | DSCP[85:84] | IPv4 and IPv6 mapping_for value 0xA8 | R/W | 00 |
| $3-2$ | DSCP[83:82] | IPv4 and IPv6 mapping_for value 0xA4 | R/W | 00 |
| $1-0$ | DSCP[81:80] | IPv4 and IPv6 mapping_for value 0xA0 | R/W | 00 |

## Register 155 (0x9B): TOS Priority Control Register 11

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[95:94] | IPv4 and IPv6 mapping_for value 0xBC | R/W | 00 |
| $5-4$ | DSCP[93:92] | IPv4 and IPv6 mapping_for value 0xB8 | R/W | 00 |
| $3-2$ | DSCP[91:90] | IPv4 and IPv6 mapping_for value 0xB4 | R/W | 00 |
| $1-0$ | DSCP[89:88] | IPv4 and IPv6 mapping_for value 0xB0 | R/W | 00 |

Register 156 (0x9C): TOS Priority Control Register 12

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[103:102] | IPv4 and IPv6 mapping_for value 0xCC | R/W | 00 |
| $5-4$ | DSCP[101:100] | IPv4 and IPv6 mapping_for value 0xC8 | R/W | 00 |
| $3-2$ | DSCP[99:98] | IPv4 and IPv6 mapping_for value 0xC4 | R/W | 00 |
| $1-0$ | DSCP[97:96] | IPv4 and IPv6 mapping_for value 0xC0 | R/W | 00 |

## Register 157 (0x9D): TOS Priority Control Register 13

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[111:110] | IPv4 and IPv6 mapping_for value 0xDC | R/W | 00 |
| $5-4$ | DSCP[109:108] | IPv4 and IPv6 mapping_for value 0xD8 | R/W | 00 |
| $3-2$ | DSCP[107:106] | IPv4 and IPv6 mapping_for value 0xD4 | R/W | 00 |
| $1-0$ | DSCP[105:104] | IPv4 and IPv6 mapping_for value 0xD0 | R/W | 00 |

## Advanced Control Registers (Continued)

Register 158 (0x9E): TOS Priority Control Register 14

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[119:118] | IPv4 and IPv6 mapping_for value 0xEC | R/W | 00 |
| $5-4$ | DSCP[117:116] | IPv4 and IPv6 mapping_for value 0xE8 | R/W | 00 |
| $3-2$ | DSCP[115:114] | IPv4 and IPv6 mapping_for value 0xE4 | R/W | 00 |
| $1-0$ | DSCP[113:112] | IPv4 and IPv6 mapping_for value 0xE0 | R/W | 00 |

## Register 159 (0x9F): TOS Priority Control Register 15

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-6$ | DSCP[127:126] | IPv4 and IPv6 mapping_for value 0xFC | R/W | 00 |
| $5-4$ | DSCP[125:124] | IPv4 and IPv6 mapping_for value 0xF8 | R/W | 00 |
| $3-2$ | DSCP[123:122] | IPv4 and IPv6 mapping_for value 0xF4 | R/W | 00 |
| $1-0$ | DSCP[121:120] | IPv4 and IPv6 mapping_for value 0xF0 | R/W | 00 |

Register 176 (0xBO): Port 1 Control 8 Register 192 (0xCO): Port 2 Control 8 Register 208 (0xD0): Port 3 Control 8 Register 224 (0xE0): Port 4 Control 8
Register 240 (0xF0): Port 5 Control 8

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-4 | Reserved |  | RO | 0000 |
| 3 | Insert Source Port PVID for Untagged Packet Destination to Highest Egress Port <br> Note: Enabled by the register 135 bit 2 | Register 176: insert source port 1 PVID for untagged frame at egress port 5 <br> Register 192: insert source port 2 PVID for untagged frame at egress port 5 <br> Register 208: insert source port 3 PVID for untagged frame at egress port 5 <br> Register 224: insert source port 4 PVID for untagged frame at egress port 5 <br> Register 240: insert source port 5 PVID for untagged frame at egress port 4 | R/W | 0 |
| 2 | Insert Source Port PVID for Untagged Packet Destination to Second Highest Egress Port <br> Note: Enabled by the register 135 bit 2 | Register 176: insert source port 1 PVID for untagged frame at egress port 4 <br> Register 192: insert source port 2 PVID for untagged frame at egress port 4 <br> Register 208: insert source port 3 PVID for untagged frame at egress port 4 <br> Register 224: insert source port 4 PVID for untagged frame at egress port 3 <br> Register 240: insert source port 5 PVID for untagged frame at egress port 3 | R/W | 0 |

## Advanced Control Registers (Continued)

| Register 176 (0xBO): Port 1 Control 8 |
| :--- |
| Register 192 (0xCO): Port 2 Control 8 |
| Register 208 (0xDO): Port 3 Control 8 |
| Register 224 (0xEO): Port 4 Control 8 |
| Register 240 (0xFO): Port 5 Control 8 |


| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 1 | Insert Source Port PVID for Untagged Packet Destination to Second Lowest Egress Port <br> Note: Enabled by the register 135 bit 2 | Register 176: insert source port 1 PVID for untagged frame at egress port 3 <br> Register 192: insert source port 2 PVID for untagged frame at egress port 3 <br> Register 208: insert source port 3 PVID for untagged frame at egress port 2 <br> Register 224: insert source port 4 PVID for untagged frame at egress port 2 <br> Register 240: insert source port 5 PVID for untagged frame at egress port 2 | R/W | 0 |
| 0 | Insert Source Port PVID for Untagged Packet Destination to Lowest Egress Port <br> Note: Enabled by the register 135 bit 2 | Register 176: insert source port 1 PVID for untagged frame at egress port 2 <br> Register 192: insert source port 2 PVID for untagged frame at egress port 1 <br> Register 208: insert source port 3 PVID for untagged frame at egress port 1 <br> Register 224: insert source port 4 PVID for untagged frame at egress port 1 <br> Register 240: insert source port 5 PVID for untagged frame at egress port 1 | R/W | 0 |

Register 177 (0xB1): Port 1 Control 9
Register 193 (0xC1): Port 2 Control 9
Register 209 (0xD1): Port 3 Control 9
Register 225 (0xE1): Port 4 Control 9
Register 241 (0xF1): Port 5 Control 9

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-2$ | Reserved |  | RO | 0000000 |
| 1 | 4 Queue Split Enable | This bit in combination with Register16/32/48/64/80 bit <br> 0 will select the split of $1 / 2 / 4$ queues: <br> \{Register177 bit 1, Register16 bit 0\}= <br> 11, reserved. <br> 10, the port output queue is split into four priority <br> queues or if map 802.1p to priority 0-3 mode. <br> 01, the port output queue is split into two priority <br> queues or if map 802.1p to priority 0-3 mode. <br> 00, single output queue on the port. There is no priority <br> differentiation even though packets are classified into <br> high and low priority | R/W | 0 |
| 0 | Enable Dropping Tag | 0= disable tag drop <br> $1=$ enable tag drop | R/W | 0 |

## Advanced Control Registers (Continued)

Register 178 (0xB2): Port 1 Control 10
Register 194 (0xC2): Port 2 Control 10
Register 210 (0xD2): Port 3 Control 10
Register 226 (0xE2): Port 4 Control 10
Register 242 (0xF2): Port 5 Control 10

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Enable Port Transmit Queue 3 <br> Ratio | 0, strict priority, will transmit all the packets from this <br> priority queue 3 before transmit lower priority queue. <br> 1, bit[6:0] reflect the packet number allow to transmit <br> from this priority queue 3 within a certain time | R/W | 1 |
| $6-0$ | Port Transmit Queue 3 <br> Ratio[6:0] | Packet number for Transmit Queue 3 for highest <br> priority packets in four queues mode | R/W | 0001000 |

Register 179 (0xB3): Port 1 Control 11
Register 195 (0xC3): Port 2 Control 11
Register 211 (0xD3): Port 3 Control 11
Register 227 (0xE3): Port 4 Control 11
Register 243 (0xF3): Port 5 Control 11

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Enable Port Transmit Queue 2 <br> Ratio | 0, strict priority, will transmit all the packets from this <br> priority queue 2 before transmit lower priority queue. <br> 1, bit[6:0] reflect the packet number allow to transmit <br> from this priority queue 1 within a certain time | R/W | 1 |
| $6-0$ | Port Transmit Queue 2 <br> Ratio[6:0] | Packet number for Transmit Queue 2 for high/low <br> priority packets in high/low priority packets in four <br> queues mode | R/W | 0000100 |

Register 180 (0xB4): Port 1 Control 12
Register 196 (0xC4): Port 2 Control 12
Register 212 (0xD4): Port 3 Control 12
Register 228 (0xE4): Port 4 Control 12
Register 244 (0xF4): Port 5 Control 12

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Enable Port Transmit Queue 1 <br> Rate | 0, strict priority, will transmit all the packets from this <br> priority queue 1 before transmit lower priority queue. <br> 1, bit[6:0] reflect the packet number allow to transmit <br> from this priority queue 1 within a certain time | R/W | 1 |
| $6-0$ | Port Transmit Queue 1 <br> Ratio[6:0] | Packet number for Transmit Queue 1 for low/high <br> priority packets in four queues mode and high priority <br> packets in two queues mode | R/W | 00000010 |

## Advanced Control Registers (Continued)

Register 181 (0xB5): Port 1 Control 13
Register 197 (0xC5): Port 2 Control 13
Register 213 (0xD5): Port 3 Control 13
Register 229 (0xE5): Port 4 Control 13
Register 245 (0xF5): Port 5 Control 13

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Enable Port Transmit Queue 0 <br> Rate | 0, strict priority, will transmit all the packets from this <br> priority queue 0 before transmit lower priority queue. <br> 1, bit[6:0] reflect the packet number allow to transmit <br> from this priority queue 0 within a certain time | R/W | 1 |
| $6-0$ | Port Transmit Queue 0 <br> Ratio[6:0] | packet number for Transmit Queue 0 for lowest priority <br> packets in four queues mode and low priority packets <br> in two queues mode | R/W | 00000001 |

Register 182 (0xB6): Port 1 Rate Limit Control
Register 198 (0xC6): Port 2 Rate Limit Control
Register 214 (0xD6): Port 3 Rate Limit Control
Register 230 (0xE6): Port 4 Rate Limit Control
Register 246 (0xF6): Port 5 Rate Limit Control

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7-5 | Reserved |  | RO | 000 |
| 4 | Ingress Rate Limit Flow Control Enable | 1 = Flow Control is asserted if the port's receive rate is exceeded <br> 0 = Flow Control is not asserted if the port's receive rate is exceeded | R/W | 0 |
| $3-2$ | Limit Mode | Ingress Limit Mode <br> These bits determine what kinds of frames are limited and counted against ingress rate limiting. <br> $=00$, limit and count all frames <br> = 01, limit and count Broadcast, Multicast, and flooded unicast frames <br> $=10$, limit and count Broadcast and Multicast frames only <br> = 11, limit and count Broadcast frames only | R/W | 00 |
| 1 | Count IFG | Count IFG bytes <br> = 1, each frame's minimum inter frame gap (IFG) bytes (12 per frame) are included in Ingress and Egress rate limiting calculations. <br> $=0$, IFG bytes are not counted. | R/W | 0 |
| 0 | Count Pre | Count Preamble bytes = 1, each frame's preamble bytes (8 per frame) are included in Ingress and Egress rate limiting calculations. <br> $=0$, preamble bytes are not counted. | R/W | 0 |

## Advanced Control Registers (Continued)

Register 183 (0xB7): Port 1 Priority 0 Ingress Limit Control 1
Register 199 (0xC7): Port 2 Priority 0 Ingress Limit Control 1
Register 215 (0xD7): Port 3 Priority 0 Ingress Limit Control 1
Register 231 (0xE7): Port 4 Priority 0 Ingress Limit Control 1
Register 247 (0xF7): Port 5 Priority 0 Ingress Limit Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved | Port-Based Priority 0 Ingress <br> Limit | Ingress data rate limit for priority 0 frames <br> Ingress traffic from this port is shaped according to the <br> Data Rate Selected Table. See the table follow the <br> end of Egress limit control registers | R/W |$\quad 00000000$|  |
| :--- |

Register 184 (0xB8): Port 1 Priority 1 Ingress Limit Control 2
Register 200 (0xC8): Port 2 Priority 1 Ingress Limit Control 2
Register 216 (0xD8): Port 3 Priority 1 Ingress Limit Control 2
Register 232 (0xE8): Port 4 Priority 1 Ingress Limit Control 2
Register 248 (0xF8): Port 5 Priority 1 Ingress Limit Control 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port-Based Priority 1 Ingress <br> Limit | Ingress data rate limit for priority 1 frames <br> Ingress traffic from this port is shaped according to the <br> Data Rate Selected Table. See the table follow the <br> end of Egress limit control registers | R/W | 0000000 |

Register 185 (0xB9): Port 1 Priority 2 Ingress Limit Control 3
Register 201 (0xC9): Port 2 Priority 2 Ingress Limit Control 3
Register 217 (0xD9): Port 3 Priority 2 Ingress Limit Control 3
Register 233 (0xE9): Port 4 Priority 2 Ingress Limit Control 3
Register 249 (0xF9): Port 5 Priority 2 Ingress Limit Control 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port-Based Priority 2 Ingress <br> Limit | Ingress data rate limit for priority 2 frames <br> Ingress traffic from this port is shaped according to the <br> Data Rate Selected Table. See the table follow the <br> end of Egress limit control registers | R/W | 0000000 |

## Advanced Control Registers (Continued)

Register 186 (0xBA): Port 1 Priority 3 Ingress Limit Control 4
Register 202 ( $0 x C A$ ): Port 2 Priority 3 Ingress Limit Control 4
Register 218 (0xDA): Port 3 Priority 3 Ingress Limit Control 4
Register 234 (0xEA): Port 4 Priority 3 Ingress Limit Control 4
Register 250 (0xFA): Port 5 Priority 3 Ingress Limit Control 4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port-Based Priority 3 Ingress <br> Limit | Ingress data rate limit for priority 3 frames <br> Ingress traffic from this port is shaped according to the <br> Data Rate Selected Table. See the table follow the <br> end of Egress limit control registers | R/W | 0000000 |

Register 187 (0xBB): Port 1 Queue 0 Egress Limit Control 1
Register 203 (0xCB): Port 2 Queue 0 Egress Limit Control 1
Register 219 (0xDB): Port 3 Queue 0 Egress Limit Control 1
Register 235 (0xEB): Port 4 Queue 0 Egress Limit Control 1
Register 251 (0xFB): Port 5 Queue 0 Egress Limit Control 1

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port Queue 0 Egress Limit | Egress data rate limit for priority 0 frames <br> Egress traffic from this priority queue is shaped <br> according to the Data Rate Selected Table. See the <br> table follow the end of Egress limit control registers. <br> In four queues mode, it is lowest priority. <br> In two queues mode, it is low priority. | R/W | 0000000 |

Register 188 (0xBC): Port 1 Queue 1 Egress Limit Control 2
Register 204 (0xCC): Port 2 Queue 1 Egress Limit Control 2
Register 220 (0xDC): Port 3 Queue 1 Egress Limit Control 2
Register 236 (0xEC): Port 4 Queue 1 Egress Limit Control 2
Register 252 (0xFC): Port 5 Queue 1 Egress Limit Control 2

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| 6-0 | Port Queue 1 Egress Limit | Egress data rate limit for priority 1 frames <br> Egress traffic from this priority queue is shaped according to the Data Rate Selected Table. See the table follow the end of Egress limit control registers. In four queues mode, it is low/high priority. In two queues mode, it is high priority. | R/W | 0000000 |

## Advanced Control Registers (Continued)

Register 189 (0xBD): Port 1 Queue 2 Egress Limit Control 3
Register 205 (0xCD): Port 2 Queue 2 Egress Limit Control 3
Register 221 (0xDD): Port 3 Queue 2 Egress Limit Control 3
Register 237 (0xED): Port 4 Queue 2 Egress Limit Control 3
Register 253 (0xFD): Port 5 Queue 2 Egress Limit Control 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port Queue 2 Egress Limit | Egress data rate limit for priority 2 frames <br> Egress traffic from this priority queue is shaped <br> according to the Data Rate Selected Table. See the <br> table follow the end of Egress limit control registers. <br> In four queues mode, it is high/low priority. | R/W | 0000000 |

Register 190 (0xBE): Port 1 Queue 3 Egress Limit Control 4
Register 206 (0xCE): Port 2 Queue 3 Egress Limit Control 4
Register 222 (0xDE): Port 3 Queue 3 Egress Limit Control 4
Register 238 (0xEE): Port 4 Queue 3 Egress Limit Control 4
Register 254 (0xFE): Port 5 Queue 3 Egress Limit Control 4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved |  | RO | 0 |
| $6-0$ | Port Queue 3 Egress Limit | Egress data rate limit for priority 3 frames <br> Egress traffic from this priority queue is shaped <br> according to the Data Rate Selected Table. See the <br> table follow the end of Egress limit control registers. <br> In four queues mode, it is highest priority. | R/W | 0000000 |

## Note:

1. In the port priority 0-3 ingress rate limit mode, need to set all related ingress/egress ports to two queues or four queues mode.
2. In the port queue $0-3$ egress rate limit mode, the highest priority get exact rate limit based on the rate select table, other priorities packets rate are based on the ratio of the port register control 10/11/12/13 when use more than one egress queue per port.

Data Rate Selection Table in 100BT
Table 11. Data Rate Selection in 100BT

| Rate for 100BT Mode <br> 1Mbps <= rate <= 99Mbps Rate $=100 \mathrm{Mbps}$ <br> Less than 1Mbps (see as below) | Priority/Queue 0-3 Ingress/egress <br> Limit Control Register bit[6:0] = decimal rate(decimal integer 1-99) 0 or 100 (decimal), ' 0 ' is default value <br> Decimal |
| :---: | :---: |
| 64 Kbps | 7'd101 |
| 128 Kbps | 7'd102 |
| 192 Kbps | 7'd103 |
| 256 Kbps | 7'd104 |
| 320 Kbps | 7'd105 |
| 384 Kbps | 7'd106 |
| 448 Kbps | 7'd107 |
| 512 Kbps | 7'd108 |
| 576 Kbps | 7'd109 |
| 640 Kbps | 7'd110 |
| 704 Kbps | 7'd111 |
| 768 Kbps | 7'd112 |
| 832 Kbps | 7'd113 |
| 896 Kbps | 7'd114 |
| 960 Kbps | 7'd115 |

Data Rate Selection Table in 10BT
Table 12. Data Rate Selection in 10BT

| Rate for 10BT mode <br> 1Mbps <= rate <= 9Mbps Rate $=10 \mathrm{Mbps}$ <br> Less than 1Mbps (see as below) | Priority/Queue 0-3 Ingress/egress <br> Limit Control Register bit[6:0]= decimal rate(decimal integer 1-9) <br> 0 or $\mathbf{1 0}$ (decimal), ' 0 ' is default value <br> Decimal |
| :---: | :---: |
| 64 Kbps | 7'd101 |
| 128 Kbps | 7'd102 |
| 192 Kbps | 7'd103 |
| 256 Kbps | 7'd104 |
| 320 Kbps | 7'd105 |
| 384 Kbps | 7'd106 |
| 448 Kbps | 7'd107 |
| 512 Kbps | 7'd108 |
| 576 Kbps | 7'd109 |
| 640 Kbps | 7'd110 |
| 704 Kbps | 7'd111 |
| 768 Kbps | 7'd112 |
| 832 Kbps | 7'd113 |
| 896 Kbps | 7'd114 |
| 960 Kbps | 7'd115 |

## Advanced Control Registers (Continued)

Register 191(0xBF): Testing Register

| Address | Name | Description | N/A | Mode |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Reserved | Default |  |  |

Register 207(0xCF): Reserved Control Register

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Reserved | N/A, don't change | RO | $0 \times 15$ |

Register 223(0xDF): Test Register 2

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Reserved |  | R/W | 00000000 |

Register 239(0xEF): Test Register 3

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| 7 | Reserved | N/A, don't change | RO | 0 |
| 6 | Reserved | N/A, don't change | RO | 0 |
| 5 | Reserved | N/A, don't change | RO | 1 |
| $4-0$ | Reserved | N/A, don't change | RO | $0 \times 12$ |

Register 255(0xFF): Testing Register4

| Address | Name | Description | Mode | Default |
| :---: | :--- | :--- | :---: | :---: |
| $7-0$ | Reserved | N/A, don't change | RO | $0 \times 00$ |

## Static MAC Address Table

KSZ8895MLUB has a static and a dynamic address table. When a DA look-up is requested, both tables will be searched to make a packet forwarding decision. When an SA look-up is requested, only the dynamic table is searched for aging, migration, and learning purposes. The static DA look-up result will have precedence over the dynamic DA look-up result. If there are DA matches in both tables, the result from the static table will be used. The static table can only be accessed and controlled by an external SPI master (usually a processor). The entries in the static table will not be aged out by KSZ8895MLUB. An external device does all addition, modification and deletion. Register bit assignments are different for static MAC table reads and static MAC table write, as shown in Table 13 and Table 14.

Table 13. Format of Static MAC Table for Read (32 Entries)

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 63-57 | FID | Filter VLAN ID, representing one of the 128 active VLANs | RO | 0000000 |
| 56 | Use FID | 1, use (FID+MAC) to look-up in static table. 0 , use MAC only to look-up in static table. | RO | 0 |
| 55 | Reserved | Reserved. | RO | N/A |
| 54 | Override | 1, override spanning tree "transmit enable $=0$ " or "receive enable $=0^{*}$ setting. This bit is used for spanning tree implementation. 0 , no override. | RO | 0 |
| 53 | Valid | 1, this entry is valid, the look-up result will be used. 0 , this entry is not valid. | RO | 0 |
| 52-48 | Forwarding Ports | The 5 bits control the forward ports, example: 00001, forward to port 1 00010, forward to port 2 ..... <br> 10000, forward to port 5 <br> 00110, forward to port 2 and port 3 <br> 11111, broadcasting (excluding the ingress port) | RO | 00000 |
| 47-0 | MAC Address | 48-bit MAC address. | RO | 0x0 |

## Examples:

1. Static Address Table Read (read the 2nd entry)

Write to Register 110 with $0 \times 10$ (read static table selected)
Write to Register 111 with $0 \times 1$ (trigger the read operation)

Then

Read Register 113 (63-56)
Read Register 114 (55-48)
Read Register 115 (47-40)
Read Register 116 (39-32)
Read Register 117 (31-24)
Read Register 118 (23-16)
Read Register 119 (15-8)
Read Register 120 ( 7 - 0)

Table 14. Format of Static MAC Table for Writes (32 Entries)

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 62-56 | FID | Filter VLAN ID, representing one of the 128 active VLANs. | W | 0000000 |
| 55 | Use FID | 1, use (FID+MAC) to look-up in static table. 0, use MAC only to look-up in static table. | W | 0 |
| 54 | Override | 1, override spanning tree "transmit enable $=0$ " or "receive enable $=0$ " setting. This bit is used for spanning tree implementation. <br> 0 , no override. | W | 0 |
| 53 | Valid | 1 , this entry is valid, the look-up result will be used. 0 , this entry is not valid. | W | 0 |
| 52-48 | Forwarding Ports | The 5 bits control the forward ports, example: 00001, forward to port 1 00010, forward to port 2 <br> 10000, forward to port 5 <br> 00110, forward to port 2 and port 3 <br> 11111, broadcasting (excluding the ingress port) | W | 00000 |
| 47-0 | MAC Address | 48-bit MAC address. | W | 0x0 |

## Examples:

1. Static Address Table Write (write the 8th entry)

Write to Register 110 with $0 \times 10$ (read static table selected)
Write Register 113 (62-56)
Write Register 114 (55-48)
Write Register 115 (47-40)
Write Register 116 (39-32)
Write Register 117 (31-24)
Write Register 118 (23-16)
Write Register 119 (15-8)
Write Register 120 ( $7-0$ )
Write to Register 110 with $0 \times 00$ (write static table selected)
Write to Register 111 with 0x7 (trigger the write operation)

## VLAN Table

The VLAN table is used for VLAN table look-up. If 802.1 V VLAN mode is enabled (Register 5 bit $7=1$ ), this table is used to retrieve VLAN information that is associated with the ingress packet. There are three fields for FID (filter ID), Valid, and VLAN membership in the VLAN table. The three fields must be initialized before the table is used. There is no VID field because 4096 VIDs are used as a dedicated memory address index into a $1024 \times 52$-bit memory space. Each entry has four VLANs. Each VLAN has 13 bits. Four VLANs need 52 bits. There are a total of 1024 entries to support a total of 4096 VLAN IDs by using dedicated memory address and data bits. Refer to Tables below for details. FID has 7-bits to support 128 active VLANs.

Table 15. Format of Static VLAN Table (Support Max 4096 VLAN ID Entries and 128 Active VLANs)

| Address | Name | Description | Mode | Initial Value <br> suggestion |
| :--- | :--- | :--- | :---: | :---: |
| 12 | Valid | 1, the entry is valid. <br> 0, entry is invalid. | R/W | 0 |
| $11-7$ | Membership | Specify which ports are members of the VLAN. <br> If a DA look-up fails (no match in both static and <br> dynamic tables), the packet associated with this VLAN <br> will be forwarded to ports specified in this field. <br> E.g., 11001 means port 5, port 4 and port 1. | R/W | 11111 |
| $6-0$ | FID | Filter ID. KSZ8895MLUB supports 128 active VLANs <br> represented by these seven bit fields. FID is the <br> mapped ID. If 802.1q VLAN is enabled, the look-up in <br> MAC table will be based on FID+DA and FID+SA. | R/W | 0 |

If $802.1 q$ VLAN mode is enabled, KSZ8895MLUB assigns a VID to every ingress packet when the packet is untagged or tagged with a null VID, the packet is assigned with the default port VID of the ingress port. If the packet is tagged with non-null VID, the VID in the tag is used. The look-up process starts from the VLAN table look-up based on VID number with its dedicated memory address and data bits. If the entry is not valid in the VLAN table, the packet is dropped and no address learning occurs. If the entry is valid, the FID is retrieved. The FID+DA and FID+SA lookups in MAC tables are performed. The FID+DA look-up determines the forwarding ports. If FID+DA fails for look-up in the MAC table, the packet is broadcast to all the members or specified members (excluding the ingress port) based on the VLAN table. If FID+SA fails, the FID+SA is learned. To communicate between different active VLANs, set the same FID; otherwise set a different FID.
The VLAN table configuration is organized as 1024 VLAN sets, each VLAN set consists of four VLAN entries, to support up to 4096 VLAN entries. Each VLAN set has 52 bits and should be read or written at the same time specified by the indirect address.
The VLAN entries in the VLAN set is mapped to indirect data registers as follow:
Entry0[12:0] maps to the VLAN set bits[12 - 0] \{register119[4:0], register120[7:0]\}
Entry1[12:0] maps to the VLAN set bits[25 - 13]\{register117[1:0], register118[7:0], register119[7:5]\}
Entry2[12:0] maps to the VLAN set bits[38 - 26]\{register116[6:0], register117[7:2]\}
Entry3[12:0] maps to the VLAN set bits[51 - 39]\{register114[3:0], register115[7:0], register116[7]\}

In order to read one VLAN entry, the VLAN set is read first and the specific VLAN entry information can be extracted. To update any VLAN entry, the VLAN set is read first then only the desired VLAN entry is updated and the whole VLAN set is written back. Due to FID in VLAN table is 7-bit, so the VLAN table supports unique 128 flow VLAN groups. Each VLAN set address is 10 bits long (Maximum is 1024) in the indirect address register 110 and 111, the bit [9-8] of VLAN set address is at bit [ $1-0$ ] of register 110, and the bit [ $7-0$ ] of VLAN set address is at bit [7-0] of register 111. Each Write and Read can access to four consecutive VLAN entries.

## Examples:

1. VLAN Table Read (read the VID=2 entry)

Write the indirect control and address registers first
Write to Register 110 ( $0 \times 6 \mathrm{E}$ ) with 0x14 (read VLAN table selected)
Write to Register 111 (0x6F) with 0x0 (trigger the read operation for VID=0, 1, 2, 3 entries)
Then read the indirect data registers bits [38-26] for VID=2 entry
Read Register 116 (0x74), (register 116 [6:0] are bits $12-6$ of VLAN VID=2 entry)
Read Register 117 ( $0 \times 75$ ), (register 117 [7:2] are bits $5-0$ of VLAN VID=2 entry)
2. VLAN Table Write (write the VID=10 entry)

Read the VLAN set that contains VID=8, 9, 10, 11.
Write to Register 110 (0x6E) with 0x14 (read VLAN table selected)
Write to Register 111 ( $0 \times 6 \mathrm{~F}$ ) with $0 \times 02$ (trigger the read operation and $\mathrm{VID}=8,9,10,11$ indirect address)
Read the VLAN set first by the indirect data registers $114,115,116,117,118,119,120$.
3. Modify the indirect data registers bits [38-26] by the register 116 bit [6-0] and register 117 bit [ $7-2$ ] as follows:

Write to Register 116 (0x74), (register116 [6:0] are bits $12-6$ of VLAN VID=10 entry)
Write to Register 117 (0x75), (register117 [7:2] are bits 5 - 0 of VLAN VID=10 entry)
4. Then write the indirect control and address registers

Write to Register 110 ( $0 \times 6 \mathrm{E}$ ) with $0 \times 04$ (write VLAN table selected)
Write to Register 111 (0x6F) with 0x02 (trigger the write operation and VID=8, 9, 10, 11 indirect address)

Table 16 shows the relationship of the indirect address/data registers and VLAN ID.

Table 16. VLAN ID and Indirect Registers

| Indirect Address High/Low Bit[9-0] for VLAN Sets | Indirect Data Registers Bits for Each VLAN Entry | VID <br> Numbers | VID bit[12-2] in VLAN Tag | VID bit[1-0] in VLAN Tag |
| :---: | :---: | :---: | :---: | :---: |
| 0 | Bits[12-0] | 0 | 0 | 0 |
| 0 | Bits[25-13] | 1 | 0 | 1 |
| 0 | Bits[38-26] | 2 | 0 | 2 |
| 0 | Bits[51-39] | 3 | 0 | 3 |
| 1 | Bits[12-0] | 4 | 1 | 0 |
| 1 | Bits[25-13] | 5 | 1 | 1 |
| 1 | Bits[38-26] | 6 | 1 | 2 |
| 1 | Bits[51-39] | 7 | 1 | 3 |
| 2 | Bits[12-0] | 8 | 2 | 0 |
| 2 | Bits[25-13] | 9 | 2 | 1 |
| 2 | Bits[38-26] | 10 | 2 | 2 |
| 2 | Bits[51-39] | 11 | 2 | 3 |
| : | : | : | : | . |
| : | : | : | : | : |
| : | : | : | : | . |
| 1023 | Bits[12-0] | 4092 | 1023 | 0 |
| 1023 | Bits[25-13] | 4093 | 1023 | 1 |
| 1023 | Bits[38-26] | 4094 | 1023 | 2 |
| 1023 | Bits[51-39] | 4095 | 1023 | 3 |

## Dynamic MAC Address Table

Table 17 is read only. The contents are maintained by the KSZ8895MLUB only.
Table 17. Format of Dynamic MAC Address Table (1K Entries)

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 71 | MAC Empty | 1, there is no valid entry in the table. <br> 0 , there are valid entries in the table. | RO | 1 |
| 70-61 | No of Valid Entries | Indicates how many valid entries in the table. $0 \times 3$ ff means 1 K entries $0 \times 1$ and bit $71=0$ : means 2 entries $0 \times 0$ and bit $71=0$ : means 1 entry $0 \times 0$ and bit $71=1$ : means 0 entry | RO | 0 |
| 60-59 | Time Stamp | 2-bit counters for internal aging | RO |  |
| 58-56 | Source Port | The source port where FID+MAC is learned. 000 Port 1 <br> 001 Port 2 <br> 010 Port 3 <br> 011 Port 4 <br> 100 Port 5 | RO | 0x0 |
| 55 | Data Ready | 1 , The entry is not ready, retry until this bit is set to 0 . 0 , The entry is ready. | RO |  |
| 54-48 | FID | Filter ID. | RO | 0x0 |
| 47-0 | MAC Address | 48-bit MAC address. | RO | 0x0 |

## Dynamic MAC Address Table Read/Write Examples:

1. Dynamic MAC Address Table Read (read the 1st entry), and retrieve the MAC table size:

Write to Register 110 with $0 \times 18$ (read dynamic table selected)
Write to Register 111 with 0x0 (trigger the read operation) and then
Read Register 112 (71-64)
Read Register 113 ( $63-56$ ); // the above two registers show \# of entries
Read Register 114 ( $55-48$ ) // if bit 55 is 1, restart (reread) from this register
Read Register 115 (47-40)
Read Register 116 (39-32)
Read Register 117 (31-24)
Read Register 118 (23-16)
Read Register 119 (15-8)
Read Register 120 ( 7 - 0)
2. Dynamic MAC Address Table Read (read the 257th entry), without retrieving \# of entries information:

Write to Register 110 with $0 \times 19$ (read dynamic table selected)
Write to Register 111 with $0 \times 1$ (trigger the read operation) and then
Read Register 112 (71-64)
Read Register 113 (63-56)
Read Register 114 ( $55-48$ ) // if bit 55 is 1, restart (reread) from this register
Read Register 115 (47-40)
Read Register 116 (39-32)
Read Register 117 (31-24)
Read Register 118 (23-16)
Read Register 119 (15-8)
Read Register 120 (7-0)

## Management Information Base (MIB) Counters

The Management Information Base (MIB) counters are provided on per port basis. These counters are read using indirect memory access as noted in the following tables:

Port 1 MIB Counter Indirect Memory Offsets

| Offset | Counter Name | Description |
| :---: | :---: | :---: |
| 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 | Rx fragment packets w/bad CRC, symbol errors or alignment errors. |
| 0x4 | RxOversize | Rx oversize packets w/good CRC (max: 1536 or 1522 bytes). |
| 0x5 | RxJabbers | Rx packets longer than 1522B w/either CRC errors, alignment errors, or symbol errors (depends on max packet size setting) or Rx packets longer than 1916B only. |
| 0x6 | RxSymbolError | Rx packets w/ invalid data symbol and legal preamble, packet size. |
| 0x7 | RxCRCerror | Rx packets within $(64,1522)$ bytes w/an integral number of bytes and a bad CRC (upper limit depends on max packet size setting). |
| 0x8 | RxAlignmentError | 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). |
| 0x9 | RxControl8808Pkts | The number of MAC control frames received by a port with 88-08h in EtherType field. |
| 0xA | RxPausePkts | The number of PAUSE frames received by a port. PAUSE frame is qualified with EtherType (8808h), DA, control opcode (00-01), data length (64B min), and a valid CRC. |
| 0xB | RxBroadcast | Rx good broadcast packets (not including errored broadcast packets or valid multicast packets). |
| OxC | RxMulticast | Rx good multicast packets (not including MAC control frames, errored multicast packets or valid broadcast packets). |
| 0xD | RxUnicast | Rx good unicast packets. |
| OxE | Rx64Octets | Total Rx packets (bad packets included) that were 64 octets in length. |
| 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. |
| $0 \times 13$ | Rx1024to1522Octets | Total Rx packets (bad packets included) that are between 1024 and 1522 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 | The number of PAUSE frames transmitted by a port. |
| 0x18 | TxBroadcastPkts | Tx good broadcast packets (not including errored broadcast or valid multicast packets). |

Port 1 MIB Counter Indirect Memory Offsets (Continued)

| Offset | Counter Name | Description |
| :--- | :--- | :--- |
| $0 \times 19$ | TxMulticastPkts | Tx good multicast packets (not including errored multicast packets or valid broadcast packets). |
| $0 \times 1$ A | TxUnicastPkts | Tx good unicast packets. |
| $0 \times 1 B$ | TxDeferred | Tx packets by a port for which the 1st Tx attempt is delayed due to the busy medium. |
| 0x1C | TxTotalCollision | Tx total collision, half-duplex only. |
| 0x1D | TxExcessiveCollision | A count of frames for which Tx fails due to excessive collisions. |
| 0x1E | TxSingleCollision | Successfully Tx frames on a port for which Tx is inhibited by exactly one collision. |
| 0x1F | TxMultipleCollision | Successfully Tx frames on a port for which Tx is inhibited by more than one collision. |

## Format of "Per port" MIB Counter

For Port 2, the Base is 0x20, Same Offset Definition (0x20-0x3f)
For Port 3, the Base is 0x40, Same Offset Definition (0x40-0x5f)
For Port 4, the Base is 0x60, Same Offset Definition (0x60-0x7f)
For Port 5, the Base is 0x80, Same Offset Definition (0x80-0x9f)

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| Format of Per Port MIB Counters (16 entries) | RO | 0 |  |  |
| 31 | Overflow | 1, Counter overflow. <br> 0, No Counter overflow. | RO | 0 |
| 30 | Count Valid | 1, Counter value is valid. <br> 0, Counter value is not valid. | RO | 0 |
| $29-0$ | Counter Values | Counter value. | 0 |  |

Table 18. All Port Dropped Packet MIB Counters

| Offset | Counter Name | Description |
| :--- | :--- | :--- |
| $0 \times 100$ | Port1 Tx Drop Packets | Tx packets dropped due to lack of resources. |
| $0 \times 101$ | Port2 Tx Drop Packets | Tx packets dropped due to lack of resources. |
| $0 \times 102$ | Port3 Tx Drop Packets | Tx packets dropped due to lack of resources. |
| $0 \times 103$ | Port4 Tx Drop Packets | Tx packets dropped due to lack of resources. |
| $0 \times 104$ | Port5 Tx Drop Packets | Tx packets dropped due to lack of resources. |
| $0 \times 105$ | Port1 Rx Drop Packets | Rx packets dropped due to lack of resources. |
| $0 \times 106$ | Port2 Rx Drop Packets | Rx packets dropped due to lack of resources. |
| $0 \times 107$ | Port3 Rx Drop Packets | Rx packets dropped due to lack of resources. |
| $0 \times 108$ | Port4 Rx Drop Packets | Rx packets dropped due to lack of resources. |
| $0 \times 109$ | Port5 Rx Drop Packets | Rx packets dropped due to lack of resources. |

Table 19. Format of All Dropped Packet MIB Counters

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $30-16$ | Reserved | Reserved. | N/A | N/A |
| $15-0$ | Counter Values | Counter value. | RO | 0 |

Note that all port dropped packet MIB counters do not indicate overflow or validity; therefore the application must keep track of overflow and valid conditions.
The KSZ8895MLUB provides total 34 MIB counter per port. These counter are used to monitor the port detail activity for network management and maintenance. These MIB counters are read using indirect memory access as as noted in the following examples:

## Programming Examples:

1. MIB counter read (read port 1 Rx64Octets counter)

Write to Register 110 with 0x1c (read MIB counters selected)
Write to Register 111 with 0xe (trigger the read operation)
Then
Read Register 117 (counter value 31 - 24)
// If bit $31=1$, there was a counter overflow
// If bit $30=0$, restart (reread) from this register
Read Register 118 (counter value 23 -16)
Read Register 119 (counter value 15 - 8)
Read Register 120 (counter value 7 - 0 )
2. MIB counter read (read port 2 Rx64Octets counter)

Write to Register 110 with 0x1c (read MIB counter selected)
Write to Register 111 with 0x2e (trigger the read operation)
Then
Read Register 117 (counter value 31 - 24)
//lf bit $31=1$, there was a counter overflow
//If bit $30=0$, restart (reread) from this register
Read Register 118 (counter value 23-16)
Read Register 119 (counter value 15 - 8)
Read Register 120 (counter value 7 - 0 )
3. MIB counter read (read port 1 tx drop packets)

Write to Register 110 with 0x1d
Write to Register 111 with $0 \times 00$
Then
Read Register 119 (counter value 15-8)
Read Register 120 (counter value 7 - 0 )

Note that to read out all the counters, the best performance over the SPI bus is $(160+3) \times 8 \times 80=104$ us, where there are 160 registers, 3 overhead, 8 clocks per access, at 12.5 MHz . In the heaviest condition, the byte counter will overflow in 2 minutes. It is recommended that the software read all the counters at least every 30 seconds. The per port MIB counters are designed as "read clear." A per port MIB counter will be cleared after it is accessed. All port 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.

## MIIM Registers

All the registers defined in this section can be also accessed via the SPI interface. Note that different mapping mechanisms are used for MIIM and SPI. The "PHYAD" defined in IEEE is assigned as "0x1" for port 1, "0x2" for port 2, " $0 \times 3$ " for port 3 and " $0 \times 4$ " for port 4 . The "REGAD" supported are $0 \times 0-0 \times 5$ ( $0 \mathrm{~h}-5 \mathrm{~h}$ ), $0 \times 1 \mathrm{D}$ ( 1 dh ) and $0 \times 1 \mathrm{~F}$ ( 1 fh ).

Register Oh: MII Control

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 15 | Soft Reset | 1, PHY soft reset. <br> 0, Normal operation. | $\begin{aligned} & \text { R/W } \\ & \text { (SC) } \end{aligned}$ | 0 |
| 14 | Loop Back | 1 = Perform MAC loopback, loop back path as follows: Assume the loop-back is at port 1 MAC, port 2 is the monitor port. <br> Port 1 MAC Loopback (port 1 reg. 0, bit 14 = ' 1 ') <br> Start: RXP2/RXM2 (port 2). Can also start from port 3, 4, 5 <br> Loopback: MAC/PHY interface of port 1's MAC <br> End: TXP2/TXM2 (port 2). Can also end at port 3, <br> 4, 5 respectively <br> Setting address ox3,4,5 reg. 0 , bit $14=$ ' 1 ' will perform MAC loopback on port 3, 4, 5 respectively. 0 = Normal Operation. | R/W | 0 |
| 13 | Force 100 | 1, 100Mbps. <br> 0, 10Mbps. | R/W | 1 |
| 12 | AN Enable | 1, Auto-negotiation enabled. 0, Auto-negotiation disabled. | R/W | 1 |
| 11 | Power Down | 1, Power down. <br> 0, Normal operation. | R/W | 0 |
| 10 | PHY Isolate | 1, Electrical PHY isolation of PHY from Tx+/Tx-. 0 , Normal operation. | R/W | 0 |
| 9 | Restart AN | 1, Restart Auto-negotiation. 0, Normal operation. | R/W | 0 |
| 8 | Force Full Duplex | 1, Full duplex. 0, Half duplex. | R/W | 0 |
| 7 | Collision Test | Not supported. | RO | 0 |
| 6 | Reserved |  | RO | 0 |
| 5 | Hp_mdix | $\begin{aligned} & 1=\text { HP Auto MDI/MDI-X mode } \\ & 0=\text { Micrel Auto MDI/MDI-X mode } \end{aligned}$ | R/W | 1 |
| 4 | Force MDI | 1, Force MDI. <br> 0, Normal operation. | R/W | 0 |
| 3 | Disable Auto MDI/MDI-X | 1, Disable auto MDI/MDI-X. <br> 0, Normal operation. | R/W | 0 |
| 2 | Disable far End fault | 1, Disable far end fault detection. 0, Normal operation. | R/W | 0 |
| 1 | Disable Transmit | 1, Disable transmit. <br> 0, Normal operation. | R/W | 0 |
| 0 | Disable LED | 1, Disable LED. <br> 0, Normal operation. | R/W | 0 |

## MIIM Registers (Continued)

## Register 1h: MII Status

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| 15 | T4 Capable | 0, Not 100 BASET4 capable. | RO | 0 |
| 14 | 100 Full Capable | $1,100 B A S E-T X ~ f u l l-d u p l e x ~ c a p a b l e . ~$ <br> 0, Not capable of 100BASE-TX full-duplex. | RO | 1 |
| 13 | 100 Half Capable | $1,100 B A S E-T X ~ h a l f-d u p l e x ~ c a p a b l e . ~$ <br> 0, Not 100BASE-TX half-duplex capable. | RO | 1 |
| 12 | 10 Full Capable | $1,10 B A S E-T$ full-duplex capable. <br> 0, Not 10BASE-T full-duplex capable. | RO | 1 |
| 11 | 10 Half Capable | $1,10 B A S E-T ~ h a l f-d u p l e x ~ c a p a b l e . ~$ <br> $0,10 B A S E-T ~ h a l f-d u p l e x ~ c a p a b l e . ~$ | RO | 1 |
| $10-7$ | Reserved | Rreamble Suppressed | Not supported. | RO |
| 6 | AN Complete | 1, Auto-negotiation complete. <br> 0, Auto-negotiation not completed. | 0 |  |
| 5 | far End fault | 1, far end fault detected. <br> 0, No far end fault detected. | RO | 0 |
| 4 | AN Capable | 1, Auto-negotiation capable. <br> 0, Not auto-negotiation capable. | RO | 1 |
| 3 | Link Status | 1, Link is up. <br> 0, Link is down. | RO | 0 |
| 1 | Jabber Test | Not supported. | RO | 0 |
| 0 | Extended Capable | 0, Not extended register capable. | 0 |  |

Register 2h: PHYID HIGH

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $15-0$ | Phyid High | High order PHYID bits. | RO | $0 \times 0022$ |

## Register 3h: PHYID LOW

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| $15-0$ | Phyid Low | Low order PHYID bits. | RO | $0 \times 1450$ |

## MIIM Registers (Continued)

Register 4h: Advertisement Ability

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| 15 | Next Page | Not supported. | RO | 0 |
| 14 | Reserved |  | RO | 0 |
| 13 | Remote fault | Not supported. | RO | 0 |
| $12-11$ | Reserved | 1, Advertise pause ability. <br> 0, Do not advertise pause ability. | RO | 0 |
| 10 | Pause | Reserved | 1, Advertise 100 full-duplex ability. <br> 0, Do not advertise 100 full-duplex ability. | 1 |
| 9 | Adv 100 Full | 1, Advertise 100 half-duplex ability. <br> 0, Do not advertise 100 half-duplex ability. | R/W | 0 |
| 8 | Adv 10 Full 100 Half | 1, Advertise 10 full-duplex ability. <br> 0, Do not advertise 10 full-duplex ability. | R/W | 1 |
| 6 | Adv 10 Half | 1, Advertise 10 half-duplex ability. <br> 0, Do not advertise 10 half-duplex ability. | R/W | 1 |
| 5 | Selector Field | 802.3 | R/W | 1 |
| $4-0$ |  | RO | 00001 |  |

Register 5h: Link Partner Ability

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| 15 | Next Page | Not supported. | RO | 0 |
| 14 | LP ACK | Not supported. | RO | 0 |
| 13 | Remote fault | Not supported. | RO | 0 |
| $12-11$ | Reserved |  | RO | 0 |
| 10 | Pause | Reserved | Link partner pause capability. | RO |
| 9 | Adv 100 Half | Link partner 100 full capability. | RO | 0 |
| 8 | Link partner 100 half capability. | RO | 0 |  |
| 7 | Link partner 10 full capability. | RO | 0 |  |
| 6 | Reserved | Link partner 10 half capability. | RO | 0 |
| 5 |  |  | RO | 0 |
| $4-0$ |  |  | RO | 00001 |

## MIIM Registers (Continued)

Register 1dh: LinkMD Control/Status

| Address | Name | Description | Mode | Default |
| :--- | :--- | :--- | :---: | :---: |
| 15 | Vct_enable | $1=$ Enable cable diagnostic. AfterVCT test has <br> completed, this bit will be self-cleared. <br> $0=$ Indicate cable diagnostic test (if enabled) has <br> completed and the status information is valid for read. | R/W <br> (SC) | 0 |
| $14-13$ | Vct_result | $00=$ Normal condition <br> $01=$ Open condition detected in cable <br> $10=$ Short condition detected in cable <br> $11=$ Cable diagnostic test has failed | RO | 00 |
| 12 | Vct 10M Short | $1=$ Less than 10 meter short | RO | 0 |
| $11-9$ | Reserved |  | RO | 0 |
| $8-0$ | Vct_fault_count | Distance to the fault. <br> It's approximately $0.4 m^{*}$ vct_fault_count [8:0] | RO | 0000000000 |

Register 1fh: PHY Special Control/Status

| Address | Name | Description | Mode | Default |
| :---: | :---: | :---: | :---: | :---: |
| 15-11 | Reserved |  | RO | 0000000000 |
| 10-8 | Port Operation Mode Indication | Indicate the current state of port operation mode: <br> [000] = reserved <br> [001] = still in auto-negotiation <br> [010] = 10BASE-T half duplex <br> [011] = 100BASE-TX half duplex <br> [100] = reserved <br> [101] = 10BASE-T full duplex <br> [110] = 100BASE-TX full duplex <br> [111] = PHY/MII isolate | RO | 000 |
| 7-6 | Reserved | N/A, don't change | R/W | XX |
| 5 | Polrvs | $\begin{aligned} & 1=\text { Polarity is reversed } \\ & 0=\text { Polarity is not reversed } \end{aligned}$ | RO | 0 |
| 4 | MDI-X status | $\begin{aligned} & 1=\text { MDI } \\ & 0=\text { MDI-X } \end{aligned}$ | RO | 0 |
| 3 | Force_Ink | $\begin{aligned} & 1=\text { Force link pass } \\ & 0=\text { Normal operation } \end{aligned}$ | R/W | 0 |
| 2 | Pwrsave | 1 = Enable power save <br> 0 = Disable power save | R/W | 0 |

## Register 1fh: PHY Special Control/Status (Continued)

| 1 | Remote Loopback | 1 = Perform Remote loopback, loop back path as follows: <br> Port 1 (PHY ID address 0x1 reg. 1f, bit 1 = ‘ 1 ') <br> Start: RXP1/RXM1 (port 1) <br> Loopback: PMD/PMA of port 1's PHY <br> End: TXP1/TXM1 (port 1) <br> Setting PHY ID address $0 \times 2,3,4,5$ reg. 1 fh , bit $1=$ ' 1 ' <br> will perform remote loopback on port $2,3,4,5$. <br> $0=$ Normal Operation. | R/W | 0 |
| :---: | :---: | :---: | :---: | :---: |
| 0 | Reserved |  | RO | 0 |

## Absolute Maximum Ratings ${ }^{(1)}$

Supply Voltage

Input Voltage ........................................ -0.5 V to +4.0 V
Output Voltage ...................................... -0.5 V to +4.0 V
Lead Temperature (soldering, 10 sec.)............... $260^{\circ} \mathrm{C}$
Storage Temperature ( $\mathrm{T}_{\mathrm{s}}$ )................. $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
HBM ESD Rating ..................................................5KV

## Operating Ratings ${ }^{(2)}$

| Supply Voltage |  |
| :---: | :---: |
| $\left(\mathrm{V}_{\text {DDAR }}, \mathrm{V}_{\text {DDAP }}, \mathrm{V}_{\text {DDC }}\right) \ldots \ldots$. | . +1.14 V to +1.26 V |
| ( $\mathrm{V}_{\text {DDAT }}$ ) | .. +3.135 V to +3.465 V |
| ( $\mathrm{V}_{\text {DIIO @ }}$ 3.3V) | +3.135 V to +3.465 V |
| ( $\mathrm{V}_{\text {DIIO @ }}$ 2.5V). | .. +2.375 V to +2.625 V |
| ( $\mathrm{V}_{\text {DII }}$ @ 1.8 V ). | . +1.710 V to +1.890 V |
| Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ ) |  |
| Industrial/Automotive ........................... $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |  |
| Package Thermal Resistance ${ }^{(3)}$ |  |
| LQFP ( $\theta_{\text {JA }}$ ) No Air Flow . | ...48.22 ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| LQFP ( $\theta_{\text {Jc }}$ ) No Air Flow.. | ......13.95${ }^{\circ} \mathrm{C} / \mathrm{W}$ |

Ambient Temperature ( $\mathrm{T}_{\mathrm{A}}$ )
Industrial/Automotive $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ackage Thermal Resistance ${ }^{(3)}$

LQFP ( $\theta_{\mathrm{Jc}}$ ) No Air Flow.
$13.95^{\circ} \mathrm{C} / \mathrm{W}$

Electrical Characteristics ${ }^{(4,5)}$
$\mathrm{V}_{\mathrm{IN}}=1.2 \mathrm{~V} / 3.3 \mathrm{~V}$ (typ.); $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

| Symbol | Parameter | Condition | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 100BASE-TX Operation-All Ports 100\% Utilization |  |  |  |  |  |  |
| $\mathrm{I}_{\mathrm{DX}}$ | 100BASE-TX (Transmitter) 3.3V Analog | $\mathrm{V}_{\text {DDAT }}$ |  | 86 |  | mA |
| IDda | 100BASE-TX 1.2V Analog | V ${ }_{\text {DDAR }}$ |  | 22 |  | mA |
| $\mathrm{I}_{\text {DDC }}$ | 100BASE-TX 1.2V Digital | V DDC |  | 42 |  | mA |
| IDDIO | 100BASE-TX (Digital IO) Standalone Switch | $V_{\text {DDIO }}$ |  | 2 |  | mA |
| I IDIO | 3.3V Digital IO Port 5 SW5-MII MAC/PHY | $V_{\text {DDIO }}$ |  | 22/38 |  | mA |
| 10BASE-T Operation -All Ports 100\% Utilization |  |  |  |  |  |  |
| $\mathrm{I}_{\mathrm{DX}}$ | 10BASE-T (Transmitter) 3.3V Analog | $V_{\text {DDAT }}$ |  | 107 |  | mA |
| IDda | 10BASE-T 1.2V Analog | V ${ }_{\text {dDAR }}$ |  | 8.6 |  | mA |
| IDDC | 10BASE-T 1.2V Digital | $V_{\text {DDC }}$ |  | 44 |  | mA |
| IdDIo | 10BASE-TX (Digital IO) Standalone Switch | $V_{\text {DDIO }}$ |  | 2 |  | mA |
| I IDIo | 3.3V Digital IO Port 5 SW5-MII MAC/PHY | $V_{\text {DDIO }}$ |  | 5/18 |  | mA |
| Auto-Negotiation Mode |  |  |  |  |  |  |
| $\mathrm{I}_{\mathrm{Dx}}$ | 10BASE-T (Transmitter) 3.3V Analog | $V_{\text {DDAT }}$ |  | 55 |  | mA |
| $\mathrm{I}_{\text {Dda }}$ | 10BASE-T 1.2V Analog | $\mathrm{V}_{\text {DDAR }}$ |  | 22 |  | mA |
| $\mathrm{I}_{\text {EDM }}$ | 10BASE-T 1.2V Digital | $V_{\text {DDC }}$ |  | 46 |  | mA |
| IDDIO | 10BASE-T (Digital IO) Standalone Switch | $V_{\text {DDIO }}$ |  | 1.5 |  | mA |

## Notes:

1. Exceeding the absolute maximum rating may damage the device.
2. The device is not guaranteed to function outside its operating rating. Unused inputs must always be tied to an appropriate logic voltage level (ground or VDD).
3. No heat spreader in package. The thermal junction to ambient $\left(\theta_{\mathrm{JA}}\right)$ and the thermal junction to case $\left(\theta_{\mathrm{Jc}}\right)$ are under air velocity $0 \mathrm{~m} / \mathrm{s}$.
4. Specification for packaged product only. There is no an additional transformer consumption due to use on chip termination technology with internal biasing for 10Bese-T and 100Base-TX.
5. Measurements were taken with operating ratings.

## Electrical Characteristics ${ }^{(4,5)}$ (Continued)

$\mathrm{V}_{\mathrm{IN}}=1.2 \mathrm{~V} / 3.3 \mathrm{~V}$ (typ.); $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Parameter | Condition | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power Management Mode (Standalone) |  |  |  |  |  |  |
| IPSM1 | Power-Saving Mode 3.3V | $\mathrm{V}_{\text {DDAT }}+\mathrm{V}_{\text {DDI }}$ |  | 35 |  | mA |
| IPSM2 | Power-Saving Mode 1.2V | V ${ }_{\text {dDAR }+ \text { VDDC }}$ |  | 55 |  | mA |
| ISPDM1 | Soft Power-Down Mode 3.3V | $V_{\text {DDAT }}+\mathrm{V}_{\text {DDII }}$ |  | 2 |  | mA |
| ISPDM2 | Soft Power-Down Mode 1.2V | V ${ }_{\text {dDAR }+ \text { VDDC }}$ |  | 1.8 |  | mA |
| $\mathrm{I}_{\text {EDM1 }}$ | Energy-Detect Mode + PLL OFF 3.3V | $V_{\text {DDAT }}+\mathrm{V}_{\text {DDI }}$ |  | 5.5 |  | mA |
| IEdm2 | Energy-Detect Mode + PLL OFF 1.2V | V DDAR + VDDC |  | 1.5 |  | mA |
| CMOS Inputs |  |  |  |  |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (VDDIO=3.3/2.5/1.8V) |  | $\begin{gathered} \hline 2.0 / 1.8 \\ \hline 1.3 \\ \hline \end{gathered}$ |  |  | V |
| VIL | Input Low Voltage (VDDIO=3.3/2.5/1.8V) |  |  |  | $\begin{gathered} \hline 0.8 / 0.7 \\ / 0.5 \end{gathered}$ | V |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Current (Excluding Pull-Up/Pull-Down) | $\mathrm{V}_{\text {IN }}=\mathrm{GND} \sim \mathrm{V}_{\text {DDIO }}$ | -10 |  | 10 | $\mu \mathrm{A}$ |
| CMOS Outputs |  |  |  |  |  |  |
| $\mathrm{V}_{\text {OH }}$ | Output High Voltage (VDDIO=3.3/2.5/1.8V) | $\mathrm{I}_{\text {OH }}=-8 \mathrm{~mA}$ | $\begin{gathered} 2.4 / 2.0 \\ / 1.5 \end{gathered}$ |  |  | V |
| Vol | Output Low Voltage (VDDIO=3.3/2.5/1.8V) | $\mathrm{loL}=8 \mathrm{~mA}$ |  |  | $\begin{gathered} 0.4 / 0.4 \\ / 0.3 \end{gathered}$ | V |
| loz | Output Tri-State Leakage | $\mathrm{V}_{\text {IN }}=\mathrm{GND} \sim \mathrm{V}_{\text {DDIO }}$ |  |  | 10 | $\mu \mathrm{A}$ |
| 100BASE-TX Transmit (measured differentially after 1:1 transformer) |  |  |  |  |  |  |
| Vo | Peak Differential Output Voltage | $100 \Omega$ termination on the differential output | 0.95 |  | 1.05 | V |
| Vimb | Output Voltage Imbalance | $100 \Omega$ termination on the differential output |  |  | 2 | \% |
| $t_{r} t_{t}$ | Rise/fall Time |  | 3 |  | 5 | ns |
|  | Rise/fall Time Imbalance |  | 0 |  | 0.5 | ns |
|  | Duty Cycle Distortion |  |  |  | $\pm 0.5$ | ns |
|  | Overshoot |  |  |  | 5 | \% |
|  | Output Jitters | Peak-to-peak | 0 | 0.75 | 1.4 | ns |
| 10BASE-T Receive |  |  |  |  |  |  |
| $V_{S Q}$ | Squelch Threshold | 5 MHz square wave | 300 | 400 | 585 | mV |
| 10BASE-T Transmit (measured differentially after 1:1 transformer) $\mathrm{V}_{\text {DDAT }}=3.3 \mathrm{~V}$ |  |  |  |  |  |  |
| $V_{P}$ | Peak Differential Output Voltage | $100 \Omega$ termination on the differential output | 2.2 | 2.5 | 2.8 | V |
|  | Output Jitters | Peak-to-peak |  | 1.4 | 3.5 | ns |
|  | Rise/fall Times |  |  | 28 | 30 | ns |

## Timing Diagrams

## EEPROM Timing



Figure 13. EEPROM Interface Input Receive Timing Diagram

TRANSMIT TIMING


Figure 14. EEPROM Interface Output Transmit Timing Diagram

Table 20. EEPROM Timing Parameters

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CYC} 1}$ | Clock Cycle |  | 16384 |  | ns |
| $\mathrm{t}_{\mathrm{S} 1}$ | Set-Up Time | 20 |  |  | ns |
| $\mathrm{t}_{\mathrm{H} 1}$ | Hold Time | 20 |  |  | ns |
| tov1 | Output Valid | 4096 | 4112 | 4128 | ns |

## Timing Diagrams (Continued)

## SNI Timing

RECEIVE TIMING


Figure 15. SNI Input Timing


Figure 16. SNI Output Timing

Table 21. SNI Timing Parameters

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CYC} 2}$ | Clock Cycle |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{S} 2}$ | Set-Up Time | 10 |  |  | ns |
| $\mathrm{t}_{\mathrm{H} 2}$ | Hold Time | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{O} 2}$ | Output Valid | 0 | 3 | 6 | ns |

## Timing Diagrams (Continued)

MII Timing


Figure 17. MAC Mode MII Timing - Data Received from MII


Figure 18. MAC Mode MII Timing - Data Transmitted from MII

Table 22. MAC Mode MII Timing Parameters

| Symbol | 10Base-T/100Base-TX |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Units |
| tcyc3 |  |  | $400 / 40$ |  | ns |
| ts3 | Set-Up Time | 10 |  | ns |  |
| th3 | Hold Time | 5 |  | ns |  |
| tov3 | Output Valid | 3 | 9 | 25 | ns |

## Timing Diagrams (Continued)

## MII Timing (Continued)



Figure 19. PHY Mode MII Timing - Data Received from MII


Figure 20. PHY Mode MII Timing - Data Transmitted from MII

Table 23. PHY Mode MII Timing Parameters

| Symbol | Parameter | 10BaseT/100BaseT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Units |
| tcyc4 |  |  | $400 / 40$ |  | ns |
| ts4 | Set-Up Time | 10 |  | ns |  |
| tH4 | Hold Time | 0 |  | ns |  |
| tov4 | Output Valid | 16 | 20 | 25 | ns |

## Timing Diagrams (Continued)

## SPI Timing



Figure 21. SPI Input Timing

Table 24. SPI Input Timing Parameters

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{C}}$ | Clock Frequency |  |  | 25 | MHz |
| $\mathrm{t}_{\text {CHSL }}$ | SPIS_N Inactive Hold Time | 10 |  |  | ns |
| $\mathrm{t}_{\text {SLCH }}$ | SPIS_N Active Set-Up Time | 10 |  |  | ns |
| $\mathrm{t}_{\text {CHSH }}$ | SPIS_N Active Hold Time | 10 |  | ns |  |
| $\mathrm{t}_{\text {SHCH }}$ | SPIS_N Inactive Set-Up Time | 10 |  | ns |  |
| $\mathrm{t}_{\text {SHSL }}$ | SPIS_N Deselect Time | 20 |  |  | ns |
| $\mathrm{t}_{\text {DVCH }}$ | Data Input Set-Up Time | 5 |  |  | ns |
| $\mathrm{t}_{\text {CHDX }}$ | Data Input Hold Time | 5 |  | ns |  |
| $\mathrm{t}_{\text {CLCH }}$ | Clock Rise Time |  |  | 1 | $\mu \mathrm{ss}$ |
| $\mathrm{t}_{\text {CHCL }}$ | Clock fall Time |  |  | 1 | $\mu \mathrm{ss}$ |
| $\mathrm{t}_{\text {DLDH }}$ | Data Input Rise Time |  |  | 1 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\text {DHDL }}$ | Data Input fall Time |  |  | $\mu \mathrm{s}$ |  |

## Timing Diagrams (Continued)

## SPI Timing (Continued)



Figure 22. SPI Output Timing

Table 25. SPI Output Timing Parameters

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{C}}$ | Clock Frequency |  |  | 25 | MHz |
| $\mathrm{t}_{\mathrm{CLQx}}$ | SPIQ Hold Time | 0 |  | 0 | ns |
| $\mathrm{t}_{\mathrm{CLQV}}$ | Clock Low to SPIQ Valid |  |  | 15 | ns |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High Time | 18 |  |  | ns |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low Time | 18 |  |  | ns |
| $\mathrm{t}_{\mathrm{QLQH}}$ | SPIQ Rise Time |  |  | 50 | ns |
| $\mathrm{t}_{\text {QHQL }}$ | SPIQ Fall Time |  |  | 50 | ns |
| $\mathrm{t}_{\text {SHQz }}$ | SPIQ Disable Time |  | 15 | ns |  |

## Timing Diagrams (Continued)

## Auto-Negotiation Timing

## AUTO-NEGOTIATION - FAST LINK PULSE TIMING



Figure 23. Auto-Negotiation Timing

Table 26. Auto-Negotiation Timing Parameters

| Symbols | Parameters | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {BTB }}$ | FLP Burst to FLP Burst | 8 | 16 | 24 | ms |
| $\mathrm{t}_{\text {FLPW }}$ | FLP Burst Width |  | 2 |  | ms |
| $\mathrm{t}_{\text {PW }}$ | Clock/Data Pulse Width |  | 100 |  | ns |
| $\mathrm{t}_{\text {CTD }}$ | Clock Pulse to Data Pulse | 55.5 | 64 | 69.5 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\text {CTC }}$ | Clock Pulse to Clock Pulse | 111 | 128 | 139 | $\mu \mathrm{~s}$ |
|  | Number of Clock/Data Pulse per Burst | 17 |  | 33 |  |

## Timing Diagrams (Continued)

## Reset Timing



Figure 24. Reset Timing

Table 27. Reset Timing Parameters

| Symbol | Parameter | Min. | Typ. | Max. |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{SR}}$ | Stable Supply Voltages to Reset High | 10 |  |  |
| $\mathrm{t}_{\mathrm{Cs}}$ | Configuration Set-Up Time | 50 |  |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Configuration Hold Time | 50 |  | ns |
| $\mathrm{t}_{\mathrm{RC}}$ | Reset to Strap-In Pin Output | 50 |  |  |
| tvr | $3.3 V$ rise time | 100 | ns |  |

## Reset Circuit Diagram

Micrel recommends the following discrete reset circuit as shown in Figure 25 when powering up the KS8895MLUBB device. For the application where the reset circuit signal comes from another device (e.g., CPU, FPGA, etc), we recommend the reset circuit as shown in Figure 26.


Figure 25. Recommended Reset Circuit


Figure 26. Recommended Circuit for Interfacing with CPU/FPGA Reset

At power-on-reset, R, C, and D1 provide the necessary ramp rise time to reset the Micrel device. The reset out RST_OUT_n from CPU/FPGA provides the warm reset after power-up.

## Isolation Transformer Selection

One simple 1:1 isolation transformer is needed at the line interface. An isolation transformer with integrated commonmode choke is recommended for exceeding FCC requirements at line side. Request to separate the center taps of RX/TX at chip side. Table 28 gives recommended transformer characteristics.

Table 28. Transformer Selection Criteria

| Characteristics Name | Value | Test Condition |
| :--- | :--- | :--- |
| Turns Ratio | 1 CT : 1 CT |  |
| Open-Circuit Inductance (min.) | $350 \mu \mathrm{H}$ | $100 \mathrm{mV}, 100 \mathrm{kHz}, 8 \mathrm{~mA}$ |
| Insertion Loss (max.) | 1.1 dB | 0.1 MHz to 100 MHz |
| HIPOT (min.) | 1500 Vrms |  |

Note:

1. The IEEE 802.3 u standard for 100BASE-TX assumes a transformer loss of 0.5 dB . For the transmit line transformer, insertion loss of up to 1.3 dB can be compensated by increasing the line drive current by means of reducing the ISET resistor value.
2. The center taps of RX and TX should be isolated for the low power consumption.

Table 29 provide transformer vendors provide compatible magnetic parts for Micrel's device.

Table 29. Qualified Magnetic Vendors

| Vendors and Parts |  | Auto MDIX | \# of Ports | Vendors and Parts |  | Auto MDIX | \# of Ports |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pulse | H1664NL | Yes |  | Pulse | H1102 | Yes | 1 |
| Pulse | H1164NL | Yes | 4 | Bel Fuse | S558-5999-U7 | Yes | 1 |
| TDK | TLA-6T718A | Yes | 1 | YCL | PT163020 | Yes | 1 |
| LanKom | LF-H41S | Yes | 1 | Transpower | HB726 | Yes | 1 |
| Datatronic | NT79075 | Yes | 1 | Delta | LF8505 | Yes | 1 |

## Reference Crystal Selection

Table 30. Typical Reference Crystal Characteristics

| Characteristics | Value | Units |
| :--- | :---: | :---: |
| Frequency | 25.00000 | MHz |
| Frequency Tolerance (max.) | $<= \pm 50$ | ppm |
| Load Capacitance (max.) | $18-27$ | pF |
| Series Resistance | 40 | $\Omega$ |

## Package Information



128-Pin LQFP Package

## MICREL, INC. 2180 FORTUNE DRIVE SAN JOSE, CA 95131 USA <br> TEL +1 (408) 944-0800 FAX +1 (408) 474-1000 WEB http://www.micrel.com

Micrel makes no representations or warranties with respect to the accuracy or completeness of the information furnished in this data sheet. 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.
© 2011 Micrel, Incorporated.

