

# ET4148-50 Single-Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s Layer 2+ Ethernet Switch

## Features

- Forty-eight 10/100/1000 Mbits/s Ethernet ports:
  - Forty-four-ports supporting 6-pin SGMII interfaces to GbE copper PHYs
  - Four combo ports supporting either SGMII interface or SerDes interface
- Two 10 Gbits/s Ethernet ports with XAUI interfaces:
   Direct SerDes connection to local stacking ports
   Connects to external 10G PHY for longer reach
- Connects to external TOG PHT for longer reach
- Aggregate 104 Mpackets/s switching capacity (wire speed operation)
- 32-bit, 66 MHz PCI<sup>™</sup> processor interface
- Three MDIO interfaces
- Integrated packet buffer memory
- Integrated address table memories:
   8192 Layer 2 MAC addresses
- Full *IEEE*<sup>®</sup> 802.1d<sup>®</sup> bridging
- Extensive VLAN support:
- Port-based VLANs
  - Port-/protocol-based VLANs
  - 4K VLAN IDs, 256 active VLANs
  - Per VLAN rapid-spanning tree
- L2/L3/L4 classification for access control list (ACL) and quality of service (QoS)
- Jumbo frame size up to 16 Kbytes
- Advanced traffic management functions:
  - 802.3x flow control
  - Traffic shaping and scheduling
  - Traffic policing
  - Broadcast/multicast storm control
  - Eight queues per port
- Link aggregation and mirroring across stacking ports (10 Gbits/s ports)
- 717-FCBGA package

## Benefits

- True switch-on-a-chip technology enables system vendors to build competitive 48 + 2 gigabit Ethernet switches
- Integrated memories and SerDes and uplink/stacking ports for lower system power, cost, and PCB area
- Flexible L2/L3/L4 ACL supporting enhanced network security
- Supports native IPv4 and IPv6 prefix and host address matches
- Comprehensive QoS features and wire speed performance supporting enterprise desktop aggregation switching application
- Seamless interface and common API with Agere *TruePHY*<sup>™</sup> multiport PHY

# **Target Applications**

- Fully managed Layer +2 gigabit Ethernet desktop switches
- 48 + 2 gigabit Ethernet switch in stand-alone or stackable configuration
- High-density gigabit Ethernet fabric switches

# **Block Diagram**



Figure 1. Block Diagram

# Description

The ET4148-50 is part of Agere's FMS gigabit Ethernet switch product family. The ET4148-50 is a highly integrated and fully featured Layer 2 Ethernet bridge with integrated MACs, packet buffers, and address tables. When combined with six ET1081 Octal PHYs, the ET4148-50 enables the implementation of a minimal component system that translates to low cost and high reliability. The ET4148-50 contains 48 IEEE 802.3z 10/100/1000 Mbits/s Ethernet MACs. The MACs connect to external ET1081 PHYs via 6-pin LVDS SGMII interfaces. Optionally, four of the MACs can be connected to external fiber PHYs via SerDes interfaces. Two 802.3ae Ethernet MACs provide the ET4148-50 with connectivity to 10 Gbits/s networks, uplinks, and stacking interfaces.

The ET4148-50 features an integrated L2/L3/L4 packet classification engine. The result of each packet classification is used to determine the packet's quality of service treatment and access control. Access to the network by individual desktops can be controlled by L2 MAC address and TCP/IP layer provisioning. Each port supports up to eight traffic class queues. Each packet is assigned to a class queue based on the 802.1p coding or IP TOS/DSCP. Incoming traffic is policed to ensure the optimum use of network resources. Outgoing traffic is scheduled or shaped according to the traffic class and network resource usage.

Integrated address tables and packet buffers enable full bandwidth bridging on all ports with any legitimate frame length. All internal operations are at wire speed.

The integrated XAUI SerDes interface supports direct local stacking ports. Optionally, external 10G PHY such as CX-4 or fiber can be used to extend the stacking and uplink port reach.

A reference system design kit is available for the ET4148-50. For more detailed product and reference design information, please contact Agere's local sales office.

# System Diagram



Figure 2. System Diagram

# **Table of Contents**

### Contents

| Features                                              | 1  |
|-------------------------------------------------------|----|
| Benefits                                              | 1  |
| Target Applications                                   | 1  |
| Block Diagram                                         |    |
| Description                                           |    |
| System Diagram                                        |    |
| Pin Descriptions                                      |    |
| Memory Map                                            |    |
| Functional Description                                |    |
| Packet Reception                                      |    |
| VLAN Assignment                                       |    |
| Access Control                                        |    |
| Bridging                                              |    |
| Flow Identification                                   |    |
| Policing                                              |    |
| Storage                                               |    |
| Retrieval                                             |    |
| VLAN Encapsulation                                    |    |
| Packet Transmission                                   |    |
| Supervisor Packet Reception                           |    |
| Supervisor Packet Transmission                        |    |
| Data Structures                                       |    |
| Supervisor_Rx_Fifo_{07}                               |    |
| Supervisor_Rx_Pilo_{07}                               |    |
| Supervisor_Tx_Packet                                  |    |
| Supervisor_Tx_Descriptor                              |    |
|                                                       |    |
| Supervisor_Tx_Packet<br>Supervisor_Tx_Packet_Segment  |    |
|                                                       |    |
| Electrical Specifications<br>Absolute Maximum Ratings |    |
| 5                                                     |    |
| ESD Protection                                        |    |
| Recommended Operating Conditions                      |    |
| Power Supply Consumption                              |    |
| Thermal Characteristics                               |    |
| PCI I/O Specification                                 |    |
| JTAG I/O Specification                                |    |
| SGMII I/O Transmit Specifications                     |    |
| SGMII I/O Receive Specifications                      |    |
| SFP—1.25 Gbits/s SerDes Specifications                |    |
| 10G—3.125 Gbits/s SerDes Specifications               |    |
| Timing Diagrams                                       |    |
| Physical Dimensions                                   |    |
| Appendix A: Registers                                 |    |
| Registers, Records, and Fields                        |    |
| Instance Numbering                                    |    |
| Line Caching                                          |    |
| Acl_Deny_Packets                                      |    |
| Acl_En                                                |    |
| Acl_lp_Addr_Ace_Map_Index_Table                       |    |
| Acl_lp_Addr_Ace_Map_Table                             |    |
| Acl_lp_Key_Table_0                                    | 76 |

#### Contents

| Ad In Koy Table 1                | 77  |
|----------------------------------|-----|
| Acl_lp_Key_Table_1               |     |
| Acl_Ip_Key_Table_2               |     |
| Acl_lp_Key_Table_3               |     |
| Acl_lp_Key_Table_4               |     |
| Acl_lp_Key_Table_5               |     |
| Acl_lp_Key_Table_6               |     |
| Acl_lp_Key_Table_7               |     |
| Acl_Ip_Key_Table_8               |     |
| Acl_Mode                         |     |
| Acl_Port_Ace_Map_Index_Table     |     |
| Acl_Port_Ace_Map_Table           |     |
| Acl_Priority_Update_En           |     |
| Acl_Protocol_Ace_Map_Index_Table |     |
| Acl_Protocol_Ace_Map_Table       |     |
| Acl_Protocol_Table               |     |
| Acl_Result_Table                 | 93  |
| Acl_Tcp_Key_Table_0              |     |
| Acl_Tcp_Key_Table_1              |     |
| Acl_Tcp_Key_Table_2              | 96  |
| Acl_Tcp_Key_Table_3              | 97  |
| Acl_Tcp_Key_Table_4              | 98  |
| Acl_Vlan_Index_Table             |     |
| Device_Version                   |     |
| Layer_2_Active_Port_Map          |     |
| Layer_2_Aggregation_Mask_Table   |     |
| Layer_2_Blocking_Mask            |     |
| Layer_2_Current_Time             |     |
| Layer_2_Dest_Map_Table           |     |
| Layer_2_Dest_Mirror_Map          |     |
| Layer_2_Flood_Map                |     |
| Layer_2_Global_Mask              |     |
| Layer_2_Igmp_Snooping_Port       | 109 |
| Layer_2_Key_Table_0              |     |
| Layer_2_Key_Table_1              |     |
| Layer_2_Key_Table_1              |     |
| Layer_2_Key_Table_3              |     |
| Layer_2_Key_Table_5              |     |
| Layer_2_Key_Table_5              |     |
|                                  |     |
| Layer_2_Key_Table_6              |     |
| Layer_2_Learning_Mask            |     |
| Layer_2_Learning_Port            |     |
| Layer_2_Logical_Port_Table       |     |
| Layer_2_Mirror_Port              |     |
| Layer_2_Mode                     |     |
| Layer_2_No_Dest_Packets          |     |
| Layer_2_Src_Deny_Mask            |     |
| Layer_2_Src_Mirror_Map           |     |
| Layer_2_Src_Port_Mask_Table      |     |
| Layer_2_Supervisor_Route_Port    |     |
| Layer_2_Time_Stamp_Table         |     |
| Layer_2_User_Port                | 129 |

#### Contents

| Layer_2_User_Port_Snooping_Port                             |       |
|-------------------------------------------------------------|-------|
| Layer_2_Vlan_Mask_Table                                     |       |
| Layer_2_Vlan_Port_State_Table                               |       |
| Mac_Global_Mode                                             |       |
| Mac_Mode_{04}                                               |       |
| Mac_Mode_{56}                                               |       |
| Mac_Status_{04}                                             |       |
| Mdio_Control                                                |       |
| Mdio_Mode                                                   |       |
| Mdio_Status                                                 |       |
| Multicast_Rate_Accumulator                                  |       |
| Multicast_Rate_Decrement_Period                             | . 148 |
| Multicast_Rate_Discard_Mask                                 |       |
| Multicast_Rate_Limit                                        | . 150 |
| Multicast_Rate_Limit_Events                                 | . 151 |
| Multicast_Rate_Mode                                         | . 152 |
| Packet_Buffer_Acl_Deny_Mask                                 | . 153 |
| Packet_Buffer_Acl_Log_Port                                  | . 154 |
| Packet_Buffer_Allocated_Buffer_Count                        | . 155 |
| Packet_Buffer_Channel_Congestion_Threshold                  | . 156 |
| Packet_Buffer_Crc_Error_Mask                                | . 157 |
| Packet_Buffer_Descriptor_Congestion_Threshold               | . 158 |
| Packet Buffer Descriptor Usage Count                        | . 159 |
| Packet Buffer Discard Mask                                  | . 160 |
| Packet Buffer Free Buffer Control                           | . 161 |
| Packet Buffer Free Buffer Count Even                        | . 162 |
| Packet_Buffer_Free_Buffer_Count_Odd                         |       |
| Packet_Buffer_Free_Descriptor_Control                       |       |
| Packet_Buffer_Global_Congestion_Threshold                   |       |
| Packet_Buffer_Ind                                           |       |
| Packet Buffer Mode                                          |       |
| Packet_Buffer_Packet_Drop_Count                             |       |
| Packet_Buffer_Parity_Error_Info                             |       |
| Packet_Buffer_Port_Speed                                    |       |
| Packet_Buffer_Priority_Table                                |       |
| Packet_Buffer_Queue_Buffer_Limit (Revision C Only)          |       |
| Packet_Buffer_Queue_Buffers_{03} (Revision C Only)          | .175  |
| Packet_Buffer_Queue_Depth_{03} (Revision C Only)            |       |
| Packet_Buffer_Queue_Limit (Revision C Only)                 |       |
| Packet_Buffer_Queue_Management_Thresholds (Revision C Only) | 180   |
| Packet_Buffer_Queue_Status                                  |       |
| Packet_Buffer_Queue_Weight                                  |       |
| Packet_Buffer_Scrub                                         |       |
| Packet_Buffer_Shaper_Accumulator_Even                       | 184   |
| Packet_Buffer_Shaper_Accumulator_Odd                        |       |
| Packet_Buffer_Shaper_Delta_Even                             |       |
| Packet_Buffer_Shaper_Delta_Odd                              |       |
| Packet_Buffer_Shaper_Limit                                  |       |
| Policer_Accumulator_Table_{04}                              |       |
| Policer_Accumulator_Table_{04}                              |       |
| Policer_Delta_Table_{04}                                    |       |
|                                                             | . 131 |

#### Contents

| Policer_Delta_Table_{56}              |     |
|---------------------------------------|-----|
| Policer_Flow_Id_Table_{04}            | 194 |
| Policer_Flow_Id_Table_{56}            | 195 |
| Policer_Flow_Mode_Table_{04}          | 196 |
| Policer_Flow_Mode_Table_{56}          | 197 |
| Policer_Limit_Table_{04}              | 198 |
| Policer_Limit_Table_{56}              | 199 |
| Policer_Mode_{04}                     | 200 |
| Policer_Mode_{56}                     | 201 |
| Policer_Statistics_{0.4}              | 202 |
| Policer_Statistics_{56}               |     |
| Port_Mode_{04}                        |     |
| Port_Mode_{56}                        |     |
| Priority_Decode_Table_{04}            |     |
| Priority_Decode_Table_{56}            |     |
| Priority_Encode_Table_{04}            |     |
| Priority_Encode_Table_{56}            |     |
| Rx_Bytes                              |     |
| Rx_Error_Packets                      |     |
| Rx_Length_Histogram                   |     |
| Rx_Packets                            |     |
| Serdes_Control_{4}                    |     |
| Serdes_Control_{5}                    |     |
| Supervisor_Endian                     |     |
| Supervisor_Ind                        |     |
| Supervisor_Ind_Mask                   |     |
| Supervisor_Ind_Mask_Clear             |     |
| Supervisor_Ind_Mask_Set               |     |
| Supervisor_Int                        |     |
| Supervisor_Int_Mask                   |     |
| Supervisor_Int_Mask_Clear             |     |
| Supervisor_Int_Mask_Set               |     |
| Supervisor_Invalid_Addr               |     |
| Supervisor_Maximum_Packet_Length      |     |
| Supervisor_Rx_Fifo_Limits             |     |
| Supervisor_Rx_Fifo_Ptr                |     |
| Supervisor_Statistics_Transfer_Addr   |     |
| Supervisor_Statistics_Transfer_Status |     |
| Supervisor_Tx_Fifo_Limits             |     |
| Supervisor_Tx_Fifo_Ptr                |     |
| Tx_Bytes                              |     |
| Tx_Collision_Histogram                |     |
| Tx_Length_Histogram                   |     |
| Tx_Packets                            |     |
| Tx_Total_Collisions                   |     |
| User_Protocol_{04}                    |     |
| User_Protocol_{56}                    |     |
| User_Type_{04}                        |     |
| User_Type_{56}                        |     |
| Vlan_Id_Table_{04}                    |     |
| Vlan_Id_Table_{56}                    |     |
|                                       |     |

#### Contents

| Vlan_Index_Table_{04}         |  |
|-------------------------------|--|
| Vlan_Index_Table_{56}         |  |
| Vlan_Port_Protocol_Table_{04} |  |
| Vlan_Port_Protocol_Table_{56} |  |
| Appendix B: Configuration     |  |
| General                       |  |
| Packet Buffer                 |  |
| Ethernet Interfaces           |  |
| Bridging                      |  |
| Access Control Lists          |  |
| Quality of Service            |  |
| Other Networking Functions    |  |
| Statistics                    |  |
| Other Device Functions        |  |
| Ordering Information          |  |
| Related Documentation         |  |

# **Pin Descriptions**

The ET4148-50 pins are summarized in the following series of tables. Each table is dedicated to a single interface type.

#### Table 1. 1 Gbit/s Ethernet SGMII Pins

| Pin Name           | Туре           | Pin #s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Description                                                             |
|--------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| RXCLK(47:00)_(P/N) | LVDS<br>input  | 47{AL13, AL12}, 46{AF13, AF12}, 45{AL11, AL10}, 44{AJ10,<br>AJ9}, 43{AF10, AF9}, 42{AJ7, AJ6}, 41{AF8, AF7},<br>40{AJ5, AJ4}, 39{AK1, AJ1}, 38{AG4, AF4}, 37{AG2, AF2},<br>36{AE4, AD4}, 35{AE1, AD1}, 34{AB2, AA2}, 33{AA5, Y5},<br>32{AA1, Y1}, 31{Y4, W4}, 30{V3, U3}, 29{T3, R3}, 28{R4, P4},<br>27{N4, M4}, 26{N2, M2}, 25{L4, K4}, 24{K1, J1}, 23{J5, H5},<br>22{G2, F2}, 21{H6, G6}, 20{E2, D2}, 19{B3, B4}, 18{D5, D6},<br>17{A4, A5}, 16{D7, D8}, 15{A7, A8}, 14{D10, D11}, 13{A9, A10},<br>12{B12, B13}, 11{E13, E14}, 10{C14, C15}, 09{C16, C17},<br>08{F17, F18}, 07{B19, B20}, 06{F19, F20}, 05{B21, B22},<br>04{C22, C23}, 03{E23, E24}, 02{C25, C26}, 01{D26, D27},<br>00{C27, C28} | SGMII receive<br>clock differential<br>pairs.                           |
| RXSD(47:00)_(P/N)  | LVDS<br>input  | 47(AH13, AH12), 46{AJ12, AJ11}, 45{AH11, AH10}, 44{AL9,<br>AL8}, 43{AH8, AH7}, 42{AL5, AL4}, 41{AH6, AH5},<br>40{AL3, AL2}, 39{AH3, AG3}, 38{AF5, AE5}, 37{AF3, AE3},<br>36{AC6, AB6}, 35{AC3, AB3}, 34{AA3, Y3}, 33{Y6, W6},<br>32{Y2, W2}, 31{V6, U6}, 30{T1, R1}, 29{P1, N1}, 28{R6, P6},<br>27{N6, M6}, 26{M1, L1}, 25{K3, J3}, 24{H1, G1}, 23{K6, J6},<br>22{E1, D1}, 21{G5, F5}, 20{C1, B1}, 19{C4, C5}, 18{F7, F8},<br>17{C6, C7}, 16{F9, F10}, 15{C9, C10}, 14{F12, F13},<br>13{C11, C12}, 12{A13, A14}, 11{F14, F15}, 10{D15, D16},<br>09{D17, D18}, 08{D19, D20}, 07{A20, A21}, 06{D21, D22},<br>05{A22, A23}, 04{B23, B24}, 03{F22, F23}, 02{A27, A28},<br>01{E25, E26}, 00{A29, A30}   | SGMII receive<br>data differential<br>pairs.                            |
| TXSD(47:00)_(P/N)  | LVDS<br>output | 47{AK11, AK12}, 46{AG11, AG12}, 45{AK9, AK10}, 44{AG8,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SGMII transmit<br>data differential<br>pairs.                           |
| REFCLK25_(2:0)     | CMOS<br>input  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Reference clock<br>for SGMII ports.<br>Each should be<br>set to 25 MHz. |

#### Table 2. 1 Gbit/s Ethernet SFP Pins

| Pin Name           | Туре          | Pin #s                                                            | Description                                                                                   |
|--------------------|---------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| RXSSD(47:44)_(P,N) | CML input     | 47{AJ19, AJ20}, 46{AL18, AL19},<br>45{AJ16, AJ17}, 44{AL15, AL16} | SFP SerDes receive differential pair.                                                         |
| TXSSD(47:44)_(P,N) | CML<br>output | 47{AF19, AF20}, 46{AH18, AH19},<br>45{AF16, AF17}, 44{AH15, AH16} | SFP SerDes transmit differential pair.                                                        |
| REFCLK_3_(P,N)     | CML input     | {AJ14, AJ15}                                                      | SFP SerDes differential clock<br>input—LVDS or LVPECL levels<br>compatible. 125 MHz nominal.  |
| RESP_3             | REF           | AK15                                                              | SFP SerDes reference resistor connection. Tie to VSSRESP_3 through a 1.5 k $\Omega$ resistor. |
| VSSRESP_3          | REF           | AK14                                                              | GND connection for RESP_3.                                                                    |

#### Table 3. 10 Gbit/s Ethernet XAUI Pins

| Pin Name           | Туре          | Pin #s                                                    | Description                                                                                              |
|--------------------|---------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------|
| RXSD48_(3:0)_(P,N) | CML input     | 03{U29, T29}, 02{U27, T27}, 01{V31,<br>U31}, 00{V28, U28} | 10 Gbits/s SerDes receive differential pairs. A port consists of four 3.125 Gbits/s pairs.               |
| RXSD49_(3:0)_(P,N) | CML input     | 03{P27, N27}, 02{P29, N29}, 01{R28,<br>P28}, 00{R31, P31} | 10 Gbits/s SerDes receive differential pairs. A port consists of four 3.125 Gbits/s pairs.               |
| TXSD48_(3:0)_(P,N) | CML<br>output | 03{J31, H31}, 02{L29, K29}, 01{M28,<br>L28}, 00{M31, L31} | 10 Gbits/s SerDes transmit differen-<br>tial pairs. A port consists of four 3.125<br>Gbits/s pairs.      |
| TXSD49_(3:0)_(P,N) | CML<br>output | 03{H26, G26}, 02{H29, G29}, 01{J28,<br>H28}, 00{L26, K26} | 10 Gbits/s SerDes transmit differen-<br>tial pairs. A port consists of four 3.125<br>Gbits/s pairs.      |
| REFCLK_4_(P,N)     | CML input     | {Y29, W29}                                                | 10 Gbits/s SerDes differential clock<br>input—LVDS or LVPECL levels com-<br>patible. 156.25 MHz nominal. |
| RESP_4             | REF           | V26                                                       | 10 Gbits/s SerDes reference resistor connection. Tie to VSSRESP_4 through a 1.5 k $\Omega$ resistor.     |
| VSSRESP_4          | REF           | Y27                                                       | GND connection for RESP_4.                                                                               |

#### Table 4. Supervisor PCI Pins

| Pin Name   | Туре                        | Pin #s                                                                                                                                                                                                                                                                                                                                                       | Description                                             |
|------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| PCI_RST_N  | CMOS input                  | AA27                                                                                                                                                                                                                                                                                                                                                         | PCI reset. Active-low.                                  |
| PCI_CLK    | CMOS input                  | AL28                                                                                                                                                                                                                                                                                                                                                         | PCI bus clock.                                          |
| AD(31:0)   | CMOS I/O                    | 31{AB30}, 30{AB28}, 29{AA26},<br>28{AC30}, 27{AC31}, 26{AB26},<br>25{AC27}, 24{AD31}, 23{AC29},<br>22{AD28}, 21{AD27}, 20{AC26},<br>19{AD26}, 18{AE27}, 17{AF31},<br>16{AE29}, 15{AH29}, 14{AJ30},<br>13{AJ31}, 12{AK31}, 11{AL30},<br>10{AK29}, 09{AL29}, 08{AK28},<br>07{AJ28}, 06{AG25}, 05{AK27},<br>04{AF25}, 03{AH27}, 02{AG26},<br>01{AJ27}, 00{AH26} | <i>PCI</i> address and data bus.                        |
| CBE[3:0]_N | CMOS I/O                    | 3{AD30}, 2{AE30}, 1{AH30}, 0{AA29}                                                                                                                                                                                                                                                                                                                           | <i>PCI</i> command and byte-enable signals. Active-low. |
| PAR        | CMOS I/O                    | AG29                                                                                                                                                                                                                                                                                                                                                         | PCI parity signal.                                      |
| FRAME_N    | CMOS I/O                    | AE26                                                                                                                                                                                                                                                                                                                                                         | PCI cycle frame signal. Active-low.                     |
| IRDY_N     | CMOS I/O                    | AF30                                                                                                                                                                                                                                                                                                                                                         | PCI initiator ready signal. Active-low.                 |
| TRDY_N     | CMOS I/O                    | AF29                                                                                                                                                                                                                                                                                                                                                         | PCI target ready signal. Active-low.                    |
| DEVSEL_N   | CMOS I/O                    | AF27                                                                                                                                                                                                                                                                                                                                                         | PCI device select signal. Active-low.                   |
| STOP_N     | CMOS I/O                    | AG28                                                                                                                                                                                                                                                                                                                                                         | PCI stop signal. Active-low.                            |
| PERR_N     | CMOS I/O                    | AG31                                                                                                                                                                                                                                                                                                                                                         | PCI parity error signal. Active-low.                    |
| SERR_N     | CMOS I/O                    | AG30                                                                                                                                                                                                                                                                                                                                                         | PCI system error signal. Active-low.                    |
| IDSEL      | CMOS input                  | AD29                                                                                                                                                                                                                                                                                                                                                         | PCI initialization device select signal.                |
| REQ_N      | CMOS output                 | AB31                                                                                                                                                                                                                                                                                                                                                         | PCI bus request signal. Active-low.                     |
| GNT_N      | CMOS input                  | AB29                                                                                                                                                                                                                                                                                                                                                         | PCI bus grant signal. Active-low.                       |
| INTA_N     | CMOS output<br>(open drain) | AA28                                                                                                                                                                                                                                                                                                                                                         | PCI interrupt. Active-low.                              |
| LOCK_N     | CMOS input                  | AF28                                                                                                                                                                                                                                                                                                                                                         | PCI lock signal. Active-low.                            |

#### Table 5. Miscellaneous Pins

| Pin Name       | Туре                     | Pins #s                                                                                           | Description                                                                                                                                                                                                                                                                                                      |
|----------------|--------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TDI            | CMOS input               | E31                                                                                               | JTAG serial data in.                                                                                                                                                                                                                                                                                             |
| ТСК            | CMOS input               | E30                                                                                               | JTAG clock.                                                                                                                                                                                                                                                                                                      |
| TMS            | CMOS input               | D31                                                                                               | JTAG test mode select.                                                                                                                                                                                                                                                                                           |
| TRST_N         | CMOS input               | E29                                                                                               | JTAG test reset. Active-low. Pull low for normal operation.                                                                                                                                                                                                                                                      |
| TDO            | CMOS output              | C31                                                                                               | JTAG serial data out.                                                                                                                                                                                                                                                                                            |
| MDIO_C22_(1:0) | CMOS I/O<br>(open drain) | 1{AL24}, 0{AK22}                                                                                  | Serial management data I/O signal.<br>Clause 22 compatible.                                                                                                                                                                                                                                                      |
| MDC_C22_(1:0)  | CMOS output              | 1{AH22}, 0{AG22}                                                                                  | Serial management clock signal.<br>Clause 22 compatible.                                                                                                                                                                                                                                                         |
| MDIO_C45       | CMOS I/O<br>(open drain) | AL25                                                                                              | Serial management data I/O signal.<br>Clause 45 compatible.                                                                                                                                                                                                                                                      |
| MDC_C45        | CMOS output              | AK24                                                                                              | Serial management clock signal.<br>Clause 45 compatible.                                                                                                                                                                                                                                                         |
| SE             | CMOS input               | AJ26                                                                                              | Reserved—scan enable. Pull low for normal operation.                                                                                                                                                                                                                                                             |
| TM(2:0)        | CMOS input               | 2{D29}, 1{C30}, 0{B31}                                                                            | Reserved—test mode select. Pull low for normal operation.                                                                                                                                                                                                                                                        |
| TST(9:0)       | CMOS output              | 9{AK25}, 8{AF22}, 7{AJ24},<br>6{AH24}, 5{AJ25}, 4{AL26},<br>3{AG23}, 2{AH23}, 1{AF24},<br>0{AJ23} | Reserved—test mode output. Leave unconnected.                                                                                                                                                                                                                                                                    |
| VM(1:0)        | CMOS output              | 1{Y28}, 0{Y30}                                                                                    | Reserved—voltage monitor output.<br>Leave unconnected.                                                                                                                                                                                                                                                           |
| RREF(2:0)      | REF                      | 2{AF14}, 1{T4}, 0{B16}                                                                            | Bias reference—pull to ground with individual 2.49 k $\Omega$ resistors.                                                                                                                                                                                                                                         |
| VREF           | REF                      | C2                                                                                                | Reference voltage—set to 1.23 V. ± 1%.                                                                                                                                                                                                                                                                           |
| RST_N          | CMOS input               | AA31                                                                                              | Chip reset, active-low. During pow-<br>erup, this signal should be held low<br>for at least 200 ns after power has<br>ramped and REFCLK_CORE<br>(25 MHz) is stable. If the system is<br>already powered up and stable, the<br>signal may be pulsed low for 200 ns<br>or more. See Device Reset in<br>Appendix B. |
| REFCLK_CORE    | CMOS input               | AJ22                                                                                              | Reference clock for the core of the chip. 25 MHz.                                                                                                                                                                                                                                                                |

#### Table 6. Power and Ground

| Pin Name            | Туре | Pin Numbers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description                                            |
|---------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| VDD12_CORE          | PWR  | M15, M13, M11, L20, L18, L16, L14, L12, AA20,<br>AA14, AA12, P13, P11, N20, N18, N16, N14, N12,<br>M21, M19, M17, T15, T13, T11, R18, R16, R14,<br>R12, P19, P17, P15, V17, V15, V13, V11, U18,<br>U16, U14, U12, T19, T17, Y15, Y13, Y11, W20,<br>W18, W16, W14, W12, V21, V19, Y21, Y19                                                                                                                                                                                                                                 | Core power supply. 1.2 V,<br>nominal.                  |
| VSS_CORE            | GND  | AD3, AC28, AB5, AA21, AA19, AA15, AA13, AA11, A6, A26, AK8, Y26, Y20, Y14, Y12, W3, W21, W19, W17, W15, W13, W11, V20, V18, V16, V14, V12, U5, U19, U17, U15, U13, U11, T18, T16, T14, T12, R19, R17, R15, R13, R11, P18, P16, P14, P12, N3, N21, N19, N17, N15, AJ13, AH31, AH28, AH25, AG5, AG10, AF6, AF26, AF23, AF1, C13, B30, B2, B18, AL27, AK30, AK23, AK2, AJ8, AJ3, E22, E15, E10, D4, D28, C8, C3, C29, C24, C19, L17, L15, L13, L11, K5, H3, F6, F1, E5, E27, N13, N11, M20, M18, M16, M14, M12, L21, L2, L19 | Core ground.                                           |
| VDD15L              | PWR  | AF11, AK7, AE2, AA6, T6, L6,<br>J4, D9, D14, B17, F21, B25                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Analog power supply for<br>SGMII I/O. 1.5 V, nominal.  |
| VDD33               | PWR  | D30, AK26, AJ29, AG27, AG24,<br>AF21, AE31, AE28, AB27, AA30                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Power supply. 3.3 V nominal.                           |
| VDD33L              | PWR  | V4, P3, K2, F16, F11, D23,<br>C18, B7, AK13, AH9, AH4, AC4                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Power supply. SGMII I/O.<br>3.3 V, nominal.            |
| AVDD12_PLL          | PWR  | AG14, U1, A15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Analog power supply for<br>SGMII PLLs. 1.2 V, nominal. |
| AGND_PLL            | GND  | AG13, T2, A17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Analog ground for SGMII<br>PLLs.                       |
| AVDD12_PLL_CORE     | PWR  | AL23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Analog power supply for core<br>PLLs. 1.2 V, nominal.  |
| AGND_PLL_CORE       | GND  | AL22                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Analog ground for core PLLs.                           |
| VDDIB_(47:44)       | PWR  | AK20, AK19, AK17, AK16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Analog input buffer power supply. 1.5 V, nominal.      |
| VDDOB_(47:44)       | PWR  | AG20, AG19, AG17, AG16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Analog output buffer power supply. 1.5 V, nominal.     |
| VDDIB_(49:48)_(3:0) | PWR  | N26, N30, P26, P30, T30, T26, U30, U26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Analog input buffer power supply. 1.5 V, nominal.      |
| VDDOB_(49:48)_(3:0) | PWR  | G27, G30, H27, K27, H30, K30, L27, L30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Analog output buffer power supply. 1.5 V, nominal.     |
| VDD_3               | PWR  | AL21, AL14, AJ21, AJ18, AH20, AH14,<br>AG21, AF18, Y17, AA18, AA16                                                                                                                                                                                                                                                                                                                                                                                                                                                        | SFP power supply. 1.2 V, nominal.                      |
| VDD_4               | PWR  | W31, W28, W26, V29, T31, T28, R29, R26, N31,<br>N28, M29, M26, K31, K28, J29, J26, G31, G28,<br>F29, F26, U20, T21, R20, P21                                                                                                                                                                                                                                                                                                                                                                                              | XAUI power supply. 1.2 V, nominal.                     |
| VSS_3               | GND  | AA17, AL20, AL17, AK21, AK18, AH21,<br>AH17, AG18, AG15, Y18, Y16                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SFP ground.                                            |
| VSS_4               | GND  | Y31, W30, W27, V30, V27, R30, R27, M30, M27,<br>J30, J27, F31, F30, F28, F27, E28, U21, T20, R21,<br>P20                                                                                                                                                                                                                                                                                                                                                                                                                  | XAUI ground.                                           |

## **Memory Map**

The following table lists all of the ET4148-50's registers in the order that they appear in the address space allocated to the device. The base addresses listed below must be added to the base address configured for the device in order to arrive at the actual physical address of each register.

#### Table 7. Memory Map

| Base Address | Size   | Register Name                    |
|--------------|--------|----------------------------------|
| 0x0000_0000  | 131072 | Acl_lp_Addr_Ace_Map_Index_Table  |
| 0x0002_0000  | 65536  | Acl_Port_Ace_Map_Index_Table     |
| 0x0003_0000  | 16384  | Acl_lp_Key_Table_8               |
| 0x0003_4000  | 16384  | Acl_Result_Table                 |
| 0x0003_8000  | 16384  | Acl_lp_Key_Table_5               |
| 0x0003_c000  | 8192   | Acl_lp_Addr_Ace_Map_Table        |
| 0x0003_e000  | 4096   | Acl_lp_Key_Table_4               |
| 0x0003_f000  | 4096   | Acl_Tcp_Key_Table_4              |
| 0x0004_0000  | 2048   | Acl_Port_Ace_Map_Table           |
| 0x0004_0800  | 2048   | Acl_lp_Key_Table_7               |
| 0x0004_1000  | 1024   | Acl_Vlan_Index_Table             |
| 0x0004_1400  | 1024   | Acl_Protocol_Ace_Map_Table       |
| 0x0004_1800  | 1024   | Acl_lp_Key_Table_6               |
| 0x0004_1c00  | 1024   | Acl_lp_Key_Table_3               |
| 0x0004_2000  | 512    | Acl_Tcp_Key_Table_3              |
| 0x0004_2200  | 256    | Acl_Protocol_Table               |
| 0x0004_2300  | 64     | Acl_lp_Key_Table_2               |
| 0x0004_2480  | 32     | Acl_lp_Key_Table_1               |
| 0x0004_24c0  | 32     | Acl_Tcp_Key_Table_1              |
| 0x0004_24e0  | 16     | Acl_lp_Key_Table_0               |
| 0x0004_24f0  | 8      | Acl_Tcp_Key_Table_0              |
| 0x0004_24f8  | 4      | Acl_Mode                         |
| 0x0004_2500  | 8      | Acl_En                           |
| 0x0004_2508  | 8      | Acl_Deny_Packets                 |
| 0x0004_2510  | 8      | Acl_Priority_Update_En           |
| 0x0004_2800  | 2048   | Acl_Protocol_Ace_Map_Index_Table |
| 0x0004_3000  | 128    | Acl_Tcp_Key_Table_2              |
| 0x0004_4000  | 2048   | Rx_Length_Histogram              |
| 0x0004_4800  | 2048   | Tx_Length_Histogram              |
| 0x0004_5000  | 1024   | Tx_Collision_Histogram           |
| 0x0004_5400  | 256    | Tx_Total_Collisions              |
| 0x0004_5800  | 1024   | Rx_Error_Packets                 |
| 0x0004_5c00  | 1024   | Rx_Packets                       |
| 0x0004_6000  | 1024   | Tx_Packets                       |
| 0x0004_6400  | 256    | Rx_Bytes                         |
| 0x0004_6500  | 256    | Tx_Bytes                         |
| 0x0004_8000  | 16384  | Vlan_Index_Table_0               |
| 0x0004_c000  | 4096   | Policer_Flow_Id_Table_0          |
| 0x0004_d000  | 1024   | Vlan_Id_Table_0                  |
| 0x0004_d400  | 512    | Policer_Accumulator_Table_0      |

Agere Systems Inc.

#### Table 7. Memory Map (continued)

| Base Address | Size  | Register Name               |
|--------------|-------|-----------------------------|
| 0x0004_d600  | 512   | Policer_Delta_Table_0       |
| 0x0004_d800  | 512   | Policer_Flow_Mode_Table_0   |
| 0x0004_da00  | 512   | Policer_Limit_Table_0       |
| 0x0004_dc00  | 512   | Vlan_Port_Protocol_Table_0  |
| 0x0004_de00  | 256   | Priority_Encode_Table_0     |
| 0x0004_df00  | 128   | Priority_Decode_Table_0     |
| 0x0004_df80  | 64    | Port_Mode_0                 |
| 0x0004_dfc0  | 16    | User_Protocol_0             |
| 0x0004_dfd0  | 16    | User_Type_0                 |
| 0x0004_dfe0  | 4     | Policer_Mode_0              |
| 0x0004_e000  | 1024  | Policer_Statistics_0        |
| 0x0005_0000  | 16384 | Vlan_Index_Table_1          |
| 0x0005_4000  | 4096  | Policer_Flow_Id_Table_1     |
| 0x0005_5000  | 1024  | Vlan_Id_Table_1             |
| 0x0005_5400  | 512   | Policer_Accumulator_Table_1 |
| 0x0005_5600  | 512   | Policer_Delta_Table_1       |
| 0x0005_5800  | 512   | Policer_Flow_Mode_Table_1   |
| 0x0005_5a00  | 512   | Policer_Limit_Table_1       |
| 0x0005_5c00  | 512   | Vlan_Port_Protocol_Table_1  |
| 0x0005_5e00  | 256   | Priority_Encode_Table_1     |
| 0x0005_5f00  | 128   | Priority_Decode_Table_1     |
| 0x0005_5f80  | 64    | Port_Mode_1                 |
| 0x0005_5fc0  | 16    | User_Protocol_1             |
| 0x0005_5fd0  | 16    | User_Type_1                 |
| 0x0005_5fe0  | 4     | Policer_Mode_1              |
| 0x0005_6000  | 1024  | Policer_Statistics_1        |
| 0x0005_8000  | 16384 | Vlan_Index_Table_2          |
| 0x0005_c000  | 4096  | Policer_Flow_Id_Table_2     |
| 0x0005_d000  | 1024  | Vlan_Id_Table_2             |
| 0x0005_d400  | 512   | Policer_Accumulator_Table_2 |
| 0x0005_d600  | 512   | Policer_Delta_Table_2       |
| 0x0005_d800  | 512   | Policer_Flow_Mode_Table_2   |
| 0x0005_da00  | 512   | Policer_Limit_Table_2       |
| 0x0005_dc00  | 512   | Vlan_Port_Protocol_Table_2  |
| 0x0005_de00  | 256   | Priority_Encode_Table_2     |
| 0x0005_df00  | 128   | Priority_Decode_Table_2     |
| 0x0005_df80  | 64    | Port_Mode_2                 |
| 0x0005_dfc0  | 16    | User_Protocol_2             |
| 0x0005_dfd0  | 16    | User_Type_2                 |
| 0x0005_dfe0  | 4     | Policer_Mode_2              |
| 0x0005_e000  | 1024  | Policer_Statistics_2        |
| 0x0006_0000  | 16384 | Vlan_Index_Table_3          |
| 0x0006_4000  | 4096  | Policer_Flow_Id_Table_3     |

#### Table 7. Memory Map (continued)

| Base Address | Size  | Register Name               |
|--------------|-------|-----------------------------|
| 0x0006_5000  | 1024  | Vlan_Id_Table_3             |
| 0x0006_5400  | 512   | Policer_Accumulator_Table_3 |
| 0x0006_5600  | 512   | Policer_Delta_Table_3       |
| 0x0006_5800  | 512   | Policer_Flow_Mode_Table_3   |
| 0x0006_5a00  | 512   | Policer_Limit_Table_3       |
| 0x0006_5c00  | 512   | Vlan_Port_Protocol_Table_3  |
| 0x0006_5e00  | 256   | Priority_Encode_Table_3     |
| 0x0006_5f00  | 128   | Priority_Decode_Table_3     |
| 0x0006_5f80  | 64    | Port_Mode_3                 |
| 0x0006_5fc0  | 16    | User_Protocol_3             |
| 0x0006_5fd0  | 16    | User_Type_3                 |
| 0x0006_5fe0  | 4     | Policer_Mode_3              |
| 0x0006_6000  | 1024  | Policer_Statistics_3        |
| 0x0006_8000  | 16384 | Vlan_Index_Table_4          |
| 0x0006_c000  | 4096  | Policer_Flow_Id_Table_4     |
| 0x0006_d000  | 1024  | Vlan_Id_Table_4             |
| 0x0006_d400  | 512   | Policer_Accumulator_Table_4 |
| 0x0006_d600  | 512   | Policer_Delta_Table_4       |
| 0x0006_d800  | 512   | Policer_Flow_Mode_Table_4   |
| 0x0006_da00  | 512   | Policer_Limit_Table_4       |
| 0x0006_dc00  | 512   | Vlan_Port_Protocol_Table_4  |
| 0x0006_de00  | 256   | Priority_Encode_Table_4     |
| 0x0006_df00  | 128   | Priority_Decode_Table_4     |
| 0x0006_df80  | 64    | Port_Mode_4                 |
| 0x0006_dfc0  | 16    | User_Protocol_4             |
| 0x0006_dfd0  | 16    | User_Type_4                 |
| 0x0006_dfe0  | 4     | Policer_Mode_4              |
| 0x0006_e000  | 1024  | Policer_Statistics_4        |
| 0x0007_0000  | 16384 | Vlan_Index_Table_5          |
| 0x0007_4000  | 4096  | Policer_Flow_Id_Table_5     |
| 0x0007_5000  | 1024  | Vlan_Id_Table_5             |
| 0x0007_5400  | 512   | Policer_Accumulator_Table_5 |
| 0x0007_5600  | 512   | Policer_Delta_Table_5       |
| 0x0007_5800  | 512   | Policer_Flow_Mode_Table_5   |
| 0x0007_5a00  | 512   | Policer_Limit_Table_5       |
| 0x0007_5c00  | 32    | Vlan_Port_Protocol_Table_5  |
| 0x0007_5e00  | 256   | Priority_Encode_Table_5     |
| 0x0007_5f00  | 128   | Priority_Decode_Table_5     |
| 0x0007_5f80  | 4     | Port_Mode_5                 |
| 0x0007_5fc0  | 16    | User_Protocol_5             |
| 0x0007_5fd0  | 16    | User_Type_5                 |
| 0x0007_5fe0  | 4     | Policer_Mode_5              |
| 0x0007_6000  | 1024  | Policer_Statistics_5        |

Agere Systems Inc.

### Table 7. Memory Map (continued)

| Base Address | Size   | Register Name                  |
|--------------|--------|--------------------------------|
| 0x0007_8000  | 16384  | Vlan_Index_Table_6             |
| 0x0007_c000  | 4096   | Policer_Flow_Id_Table_6        |
| 0x0007_d000  | 1024   | Vlan_Id_Table_6                |
| 0x0007_d400  | 512    | Policer_Accumulator_Table_6    |
| 0x0007_d600  | 512    | Policer_Delta_Table_6          |
| 0x0007_d800  | 512    | Policer_Flow_Mode_Table_6      |
| 0x0007_da00  | 512    | Policer_Limit_Table_6          |
| 0x0007_dc00  | 32     | Vlan_Port_Protocol_Table_6     |
| 0x0007_de00  | 256    | Priority_Encode_Table_6        |
| 0x0007_df00  | 128    | Priority_Decode_Table_6        |
| 0x0007_df80  | 4      | Port_Mode_6                    |
| 0x0007_dfc0  | 16     | User_Protocol_6                |
| 0x0007_dfd0  | 16     | User_Type_6                    |
| 0x0007_dfe0  | 4      | Policer_Mode_6                 |
| 0x0007_e000  | 1024   | Policer_Statistics_6           |
| 0x0008_0000  | 131072 | Layer_2_Key_Table_6            |
| 0x000a_0000  | 65536  | Layer_2_Vlan_Port_State_Table  |
| 0x000b_0000  | 32768  | Layer_2_Key_Table_5            |
| 0x000b_8000  | 32768  | Layer_2_Time_Stamp_Table       |
| 0x000c_0000  | 8192   | Layer_2_Key_Table_4            |
| 0x000c_2000  | 4096   | Layer_2_Dest_Map_Table         |
| 0x000c_3000  | 2048   | Layer_2_Key_Table_3            |
| 0x000c_3800  | 2048   | Layer_2_Vlan_Mask_Table        |
| 0x000c_4000  | 512    | Layer_2_Key_Table_2            |
| 0x000c_4200  | 512    | Layer_2_Src_Port_Mask_Table    |
| 0x000c_4400  | 128    | Layer_2_Key_Table_1            |
| 0x000c_4480  | 64     | Layer_2_Aggregation_Mask_Table |
| 0x000c_4500  | 256    | Layer_2_Logical_Port_Table     |
| 0x000c_4600  | 32     | Layer_2_Key_Table_0            |
| 0x000c_4620  | 8      | Layer_2_Active_Port_Map        |
| 0x000c_4628  | 8      | Layer_2_Blocking_Mask          |
| 0x000c_4630  | 8      | Layer_2_Dest_Mirror_Map        |
| 0x000c_4638  | 8      | Layer_2_Flood_Map              |
| 0x000c_4640  | 8      | Layer_2_Global_Mask            |
| 0x000c_4648  | 8      | Layer_2_Learning_Mask          |
| 0x000c_4650  | 8      | Layer_2_Src_Deny_Mask          |
| 0x000c_4658  | 8      | Layer_2_Src_Mirror_Map         |
| 0x000c_4660  | 4      | Layer_2_Current_Time           |
| 0x000c_4664  | 4      | Layer_2_Igmp_Snooping_Port     |
| 0x000c_4668  | 4      | Layer_2_Learning_Port          |
| 0x000c_466c  | 4      | Layer_2_Mirror_Port            |
| 0x000c_4674  | 4      | Layer_2_Supervisor_Route_Port  |
| 0x000c_4678  | 4      | Layer_2_User_Port              |

#### Table 7. Memory Map (continued)

| Base Address | Size | Register Name                              |
|--------------|------|--------------------------------------------|
| 0x000c_467c  | 4    | Layer_2_User_Port_Snooping_Port            |
| 0x000c_4680  | 4    | Layer_2_No_Dest_Packets                    |
| 0x000c_4700  | 244  | Layer_2_Mode                               |
| 0x000c_4800  | 8    | Multicast_Rate_Discard_Mask                |
| 0x000c_4808  | 4    | Multicast_Rate_Limit                       |
| 0x000c_480c  | 4    | Multicast_Rate_Decrement_Period            |
| 0x000c_4810  | 4    | Multicast_Rate_Limit_Events                |
| 0x000c_4814  | 4    | Multicast_Rate_Accumulator                 |
| 0x000c_4818  | 4    | Multicast_Rate_Mode                        |
| 0x000c_8000  | 64   | Mac_Mode_0                                 |
| 0x000c_8050  | 4    | Mac_Status_0                               |
| 0x000c_8080  | 64   | Mac_Mode_1                                 |
| 0x000c_80d0  | 4    | Mac_Status_1                               |
| 0x000c_8100  | 64   | Mac_Mode_2                                 |
| 0x000c_8150  | 4    | Mac_Status_2                               |
| 0x000c_8180  | 64   | Mac_Mode_3                                 |
| 0x000c_81d0  | 4    | Mac_Status_3                               |
| 0x000c_8200  | 64   | Mac_Mode_4                                 |
| 0x000c_8240  | 12   | Serdes_Control_4                           |
| 0x000c_8250  | 4    | Mac_Status_4                               |
| 0x000c_8280  | 16   | Serdes_Control_5                           |
| 0x000c_8290  | 4    | Mac_Mode_5                                 |
| 0x000c_82d0  | 4    | Mac_Mode_6                                 |
| 0x000c_8300  | 4    | Mdio_Control                               |
| 0x000c_8304  | 4    | Mdio_Status                                |
| 0x000c_8308  | 4    | Mdio_Mode                                  |
| 0x000c_8310  | 16   | Mac_Global_Mode                            |
| 0x000c_8320  | 4    | Device_Version                             |
| 0x000c_a000  | 2048 | Packet_Buffer_Queue_Weight                 |
| 0x000c_a800  | 1024 | Packet_Buffer_Shaper_Accumulator_Even      |
| 0x000c_ac00  | 1024 | Packet_Buffer_Shaper_Accumulator_Odd       |
| 0x000c_b000  | 1024 | Packet_Buffer_Shaper_Delta_Even            |
| 0x000c_b400  | 1024 | Packet_Buffer_Shaper_Delta_Odd             |
| 0x000c_b800  | 256  | Packet_Buffer_Channel_Congestion_Threshold |
| 0x000c_b900  | 256  | Packet_Buffer_Allocated_Buffer_Count       |
| 0x000c_ba00  | 256  | Packet_Buffer_Queue_Status                 |
| 0x000c_bb00  | 64   | Packet_Buffer_Packet_Drop_Count            |
| 0x000c_bb40  | 32   | Packet_Buffer_Ind                          |
| 0x000c_bb60  | 16   | Packet_Buffer_Descriptor_Usage_Count       |
| 0x000c_bb70  | 4    | Packet_Buffer_Free_Buffer_Control          |
| 0x000c_bb74  | 4    | Packet_Buffer_Free_Descriptor_Control      |
| 0x000c_bb78  | 4    | Packet_Buffer_Parity_Error_Info            |
| 0x000c_bb80  | 4    | Packet_Buffer_Scrub                        |

Agere Systems Inc.

#### Table 7. Memory Map (continued)

| Base Address    | Size | Register Name                                               |
|-----------------|------|-------------------------------------------------------------|
| 0x000c_bb84     | 4    | Packet_Buffer_Free_Buffer_Count_Even                        |
| 0x000c_bb88     | 4    | Packet_Buffer_Free_Buffer_Count_Odd                         |
| 0x000c_bc00     | 64   | Packet_Buffer_Priority_Table                                |
| 0x000c_bc40     | 8    | Packet_Buffer_Acl_Deny_Mask                                 |
| 0x000c_bc48     | 8    | Packet_Buffer_Crc_Error_Mask                                |
| 0x000c_bc50     | 8    | Packet_Buffer_Discard_Mask                                  |
| 0x000c_bc58     | 4    | Packet_Buffer_Acl_Log_Port                                  |
| 0x000c_bc5c     | 4    | Packet_Buffer_Descriptor_Congestion_Threshold               |
| 0x000c_bc60     | 4    | Packet_Buffer_Global_Congestion_Threshold                   |
| 0x000c_bc64     | 4    | Packet_Buffer_Mode                                          |
| 0x000c_bc68     | 4    | Packet_Buffer_Shaper_Limit                                  |
| 0x000c_bd00     | 192  | Packet_Buffer_Port_Speed                                    |
| 0x000c_c400     | 64   | Supervisor_Rx_Fifo_Ptr                                      |
| 0x000c_c440     | 8    | Supervisor_Tx_Fifo_Ptr                                      |
| 0x000c_c448     | 4    | Supervisor_Ind                                              |
| 0x000c_c44c     | 4    | Supervisor_Ind_Mask                                         |
| 0x000c_c450     | 4    | Supervisor_Ind_Mask_Clear                                   |
| 0x000c_c454     | 4    | Supervisor_Ind_Mask_Set                                     |
| 0x000c_c458     | 4    | Supervisor_Int                                              |
| 0x000c_c45c     | 4    | Supervisor_Int_Mask                                         |
| 0x000c_c460     | 4    | Supervisor_Int_Mask_Clear                                   |
| 0x000c_c464     | 4    | Supervisor_Int_Mask_Set                                     |
| 0x000c_c468     | 4    | Supervisor_Invalid_Addr                                     |
| 0x000c_c46c     | 4    | Supervisor_Statistics_Transfer_Addr                         |
| 0x000c_c470     | 4    | Supervisor_Statistics_Transfer_Status                       |
| 0x000c_c480     | 128  | Supervisor_Rx_Fifo_Limits                                   |
| 0x000c_c500     | 32   | Supervisor_Tx_Fifo_Limits                                   |
| 0x000c_c520     | 4    | Supervisor_Endian                                           |
| 0x000c_c540     | 32   | Supervisor_Maximum_Packet_Length                            |
| 0x000c_d000     | 428  | Packet_Buffer_Queue_Depth_0 (revision C only)               |
| 0x000c_d200     | 428  | Packet_Buffer_Queue_Depth_1 (revision C only)               |
| 0x000c_d400     | 428  | Packet_Buffer_Queue_Depth_2 (revision C only)               |
| 0x000c_d600     | 428  | Packet_Buffer_Queue_Depth_3 (revision C only)               |
| 0x000c_da00     | 424  | Packet_Buffer_Queue_Buffer_0 (revision C only)              |
| 0x000c_dc00     | 424  | Packet_Buffer_Queue_Buffer_1 (revision C only)              |
| 0x000c_de00     | 424  | Packet_Buffer_Queue_Buffer_2 (revision C only)              |
| 0x000c_e000     | 424  | Packet_Buffer_Queue_Buffer_3 (revision C only)              |
| 0x000c_e200     | 4    | Packet_Buffer_Queue_Buffer_Limit (revision C only)          |
| <br>0x000c_e204 | 4    | Packet_Buffer_Queue_Limit (revision C only)                 |
| 0x000c_e208     | 4    | Packet_Buffer_Queue_Management_Thresholds (revision C only) |

## **Functional Description**

This chapter describes the packet-handling processes embedded within the ET4148-50.

#### Packet Reception

The packet reception process quite simply receives packets from the attached network, immediately processes control packets, parses the remaining packets, and delivers the received packets to the next process.



Figure 3. Packet Reception Process

The packet reception process is rather straight forward. If a receive packet is a flow-control packet and flow control is enabled, an indication is provided to the MAC's corresponding transmit function that causes it to cease transmitting for a specified period of time. All other packets are parsed and then passed along to the VLAN assignment process.

The following figure shows the various packet formats that are supported by the ET4148-50's parser function.

### Packet Reception (continued)



**Figure 4. Packet Formats** 

The packet reception process automatically restarts after each packet.

#### **VLAN Assignment**

All packets received by the ET4148-50 are assigned to a VLAN. Some packets are received with a VLAN tag in place. For the remainder of the packets, other aspects of the packets must be used to determine to which VLAN the packet is to be assigned.



Figure 5. VLAN Assignment Process—Revisions B and B1

In version B and B1, VLAN tagged packets may only be received by those Ethernet ports that are configured as trunk ports. If a tagged packet is received via an access port, it is discarded. In version C, VLAN tagged packets may be received by either access-configured or trunk-configured Ethernet ports. The VLAN identifiers in tagged packets must also exist in the ET4148-50's VLAN index table. Packets with invalid VLAN tags may be optionally discarded. If packets with invalid VLAN tags are not discarded, they are treated as if they are untagged packets.

For untagged packets, an attempt is made to assign the packet to a VLAN based on its combination of receive port and ethertype. If the combination found in the receive packet is not present in the port/protocol tables, then the receive port's default VLAN identifier is used for the receive packet.

Upon completion of the VLAN assignment process, the packet is delivered to the access control process.

## VLAN Assignment (continued)



Figure 6. VLAN Assignment Process—Revision C

### Access Control

The access control process examines certain fields within each receive packet and determines whether or not the packets should be granted access to the ET4148-50 and its attached networks.



Figure 7. Access Control Process

### Access Control (continued)

Receive packets are associated with access control lists (ACLs) based on either their receive port or the VLAN to which they've been assigned. If the ACL associated with a receive packet is empty, then the packet is automatically permitted to be received and processed normally. No further action is taken by the ACL process in this case.

For a nonempty ACL, each of the packet's fields that make up the ACL 5-tuple are submitted to a look-up, which ultimately results in the gathering of five access control entry (ACE) map values. These ACE maps indicate which of the ACEs that make up the ACL have criteria that are satisfied by the corresponding field in the receive packet.

For example, a TCP destination port value of 3,027 may satisfy one rule that stipulates a range of 3,000 to 4,000 and another that specifies all values less than 7,000. In this example, 2 bits in the corresponding ACE map are asserted with each bit indicating which ACE has matching criteria.

Once all five ACE maps have been retrieved, they are ANDed together in a bitwise fashion to indicate those ACEs where all five criteria are satisfied by the fields in the receive packet. The leftmost bit in the resulting ACE map indicates the first ACE in the ACL that matches all of the criteria. In the case where multiple ACEs match the against the receive packet, it is the one that appears first in the ACL that is applied to the receive packet.

The actions that may be carried out as a result of a matching ACE are as follows:

- 1. Packet denial or permission
- 2. Packet logging
- 3. Priority reassignment

The ET4148-50 may also be configured to automatically log all denied packets.

### Bridging

The ET4148-50's bridging process utilizes Layer 2 information from the packet as a primary means for determining the destination or destinations of a receive packet.



Figure 8. Bridging Process (Part 1)

#### Bridging (continued)



Figure 9. Bridging Process (Part 2)

Agere Systems Inc.

#### Bridging (continued)

The bridging process starts with both the Layer 2 destination and source addresses being submitted for a look-up. The principal information returned is the destination map and the source port associated with the packet's source address. Other information returned includes the match/fail result status for each look-up, flow identifying tags, (used in the flow identification process described below) and a Layer 2 access control flag.

The destination map provides a per-port indication of which ports are destinations for the packet. An asserted bit in the map implies that the corresponding port is an intended destination. The look-up of the destination address returns an initial destination map. This map is then modified through the application of various maps (adding destinations) and masks (deleting destinations). The final resulting destination map is used in concert with the packet's priority information to identify the queues into which references to the receive packet are deposited.

First, the spanning tree state of the receive port/VLAN combination is used to modify the packet's destination. The blocking mask disables all destinations that should be unreachable to a receive port that is in the blocking state.

Note: The ET4148-50 treats the blocking and listening states as being functionally equivalent.

The learning mask deletes those destinations that should be unreachable to a receive port that is in the learning state. If the receive packet's source address is unknown or its receive port does not match the receive port associated with the source address in the address table, the ET4148-50's learning queue is added to the packet's list of destinations.

**Note:** The link aggregation function makes it possible for a source address to appear on multiple receive ports within a very short time span. Ordinarily, these varying source ports would cause many unnecessary copies of the packet to be forwarded to the learning queue. The use of a logical port number that groups together the ports associated with an aggregate together under a single label eliminates these unnecessary learning operations. Refer to Link Aggregation on page 269 for more information regarding the configuration of link aggregates.

If the source address of the receive packet does exist in the address table, and the stored receive port number matches the port number via which the packet was received, then the address table's time stamp value for the source address must be updated. This is a simple matter of writing the current time value to the time stamp table location that corresponds to the current source address of the receive packet.

IGMP and user port snooping are performed next. For IGMP snooping, if the receive packet is an IGMP packet and IGMP snooping is enabled, then the IGMP snooping queue is added to the destination map. Similarly, if the TCP or UDP destination port number matches the user-defined snooping port number, then the user-port snooping queue is added to the packet's destination map.

If the VLAN associated with the receive packet does not match the VLANs associated with any of the destination ports indicated in the destination map so far, then the packet is not going to be forwarded due to VLAN filtering. However, if so enabled, the supervisor may receive these VLAN-filtered packet so that it may apply routing operations to these packets and allow them to communicate across VLAN boundaries. The supervisor's routing queue is used for this purpose.

The following three masks are applied unconditionally:

- 1. VLAN mask
- 2. Port aggregation mask
- 3. Source port mask

The VLAN mask is applied to delete all of the destinations in the destination map that are not members of the receive packet's VLAN.

### Bridging (continued)

The port aggregation mask is one of eight masks that are applied to all destination maps, regardless of a packet's receive port or its intended destinations. It is presumed that all ports are a member of an aggregate. An aggregate may be as small as a single port. In this case, the single port in the aggregate would never be eliminated by any of the aggregation masks. For multiport aggregates, each aggregate mask eliminates all but one destination port for all of the aggregates configured in the device. For example, for a 4-port aggregate, two of the eight aggregation masks are configured to allow a particular port to remain in the destination map while the remaining six are configured to delete that same port.

The source port mask is used to disallow the communication between a receive port and an arbitrary collection of transmit ports. This capability enables features such as private VLANs. A private VLAN exists when an access port and its related trunk are allowed to communicate with one another, but the various access ports associated with a trunk port are not allowed to communicate. This has the effect of allowing only client/server communication and disallowing client/client communication.

Next, a series of denial tests are applied. If the source address is unknown and the port is configured to deny packets with unknown source addresses, the denial mask is applied to the destination map. If the receive port is not a member of the receive packet's VLAN, the denial mask is applied. Finally, if the source permit flag for the source address is false, the denial mask is applied to the destination map.

If port mirroring is enabled for either the receive port or any of the destination ports, then the designated mirror port is added to the packet's destination map.

If the receive packet is a multicast packet and the rate at which multicast packets are being received exceeds a configured limit, then a multicast rate mask is applied. This mask is typically configured to avoid masking BPDU packets and other protocol-conveying multicast packets.

Finally, a global destination mask is applied to unconditionally eliminate desired destinations.

#### **Flow Identification**



Figure 10. Flow Identification Process

All receive packets are assigned to one flow or another. Packets received via one of the 10/100/1000 Mbits/s Ethernet ports are assigned to one of eight flows per port. Packets received via one of the 10 Gbits/s ports are assigned to one of eighty flows per port. Each flow is associated with a policer that may be configured to limit the total bandwidth of the flows.

By default, IP packets utilize Layer 3 information to identify the flow to which the packet is assigned while non-IP packets utilize Layer 2 information. However, each port may be placed in a mode where Layer 2 information is utilized for flow classification for all packets; including IP packets.

If Layer 2 information is being utilized and the receive packet is VLAN tagged, then the CoS field from the VLAN tag is used to set the packet's priority. Otherwise, the receive port's default priority is used.

The result of the ACL processing for the receive packet has the ability to override any priority information that may be embedded in the packet or implied by its receive port.

Finally, the combination of the source, destination, and priority information is used to identify a single flow.

## Policing

The ET4148-50 includes a series of policer functions that serve to limit the amount of ingress bandwidth permitted for any particular packet flow.



Figure 11. Policing Processes

Two processes run in parallel for each policer. The first process simply performs the leak function for the accumulator. The second process starts with each receive packet and determines if the receive packet is out of profile and, if so, which action to take.

The leaky bucket accumulator uses two parameters to regulate the leak rate. The first parameter is a delay interval. This delay interval is proportional to the operating speed of the associated receive port. i.e., the interval for a 10 Mbits/s port is 100 times that of a 1 Gbit/s port. This automatic proportional behavior means that the delta that is periodically applied to the accumulator can be reasonably thought of as a percentage of available bandwidth. The delta is adjusted as desired during configuration to establish the maximum receive bandwidth allowed for the associated traffic flow.

#### **Policing** (continued)

The accumulation process is triggered with each receive packet. The length (byte count) of each receive packet within the associated flow is added to the policer's accumulator. If the aggregate byte rate is greater than the bandwidth permitted by the leak delta, then the value in the accumulator will tend to increase. The traffic flow is not considered out of profile until the value in the accumulator exceeds the user-defined accumulator limit. The setting of this limit establishes the policer's strictness. In other words, a higher limit means that the policer will tolerate a longer out-of-profile burst before declaring the flow out-of-profile.

Once the flow is declared out-of-profile, several options are available for dealing with individual packets within the flow. The ET4148-50 may be configured to discard all out-of-profile traffic. In this case, every packet in the flow is discarded for as long as the accumulator is greater than the limit.

Alternately, the ET4148-50 may be configured to only discard out-of-profile traffic if the packet buffer is indicating that it is congested. This congestion may be either global in nature (the total number of allocated buffers is greater than the global congestion threshold) or local (the number of buffers allocated to the associated receive port is greater that its congestion threshold).

Finally, the ET4148-50 has the ability to change the priority level of the receive packets for those flows that are out of profile. The priority demotion takes place during egress processing immediately prior to transmission.

### Storage

During the storage process, packet buffer storage space is allocated to a receive packet. References to the packet are deposited onto the queues identified by the bridging and ACL processes.



Figure 12. Storage Process

The first step in storing a receive packet is to ensure that sufficient storage resources are available to accommodate a maximum length packet. If insufficient resources are available, then the packet is discarded.

If sufficient storage space is available, the space is allocated to the packet. This allocation may result in the packet buffer entering into a congested state, either globally or locally. If either condition is true, the appropriate indication is provided to the ingress policers and/or Ethernet MACs.

The remainder of the storage process entails the actual storage of the packet into the allocated buffers, mapping the packet's priority level (16 levels) to one of the eight queues that exist per transmit port. Finally, the queue mapping and the destination map are used to identify the various individual queues into which a reference to the stored packet is deposited.

#### Retrieval

Two processes per queue operate in parallel during packet retrieval. One process manages a bandwidth shaper function while the other performs arbitration and actually retrieves the stored packet.



Figure 13. Retrieval Processes

#### Retrieval (continued)

A token bucket method is used for transmit bandwidth management. On a periodic basis, credit is applied to an accumulator. The period is set to be proportional to the port speed. In other words, the period of accumulation for a 10 Mbits/s Ethernet port is 100 times greater than the period for 1 Gbit/s Ethernet port. Hence, the credit applied each period is equivalent to a percentage of the total bandwidth available on a port. An accumulator limit is established that is used to set a maximum amount of credit that may be accumulated.

Whenever the accumulator is greater than zero, the associated queue is enabled to arbitrate against the other queues of the same transmit port. Each successful arbitration causes the length (byte count) of the transmit packet to be subtracted from the accumulator. The accumulator limit establishes the longest burst of transmit packet bytes that is allowed.

Packets may be destined for multiple queues or ports. This being the case, not every packet retrieval results in the deallocation of the buffer used for packet storage. Only after the completion of the last retrieval of a packet may its buffers be deallocated and made available for future storage operations.

The deallocation of buffers may result in the crossing of a congestion threshold towards the uncongested side. If this is the case, the appropriate congestion indications are removed.

### **VLAN Encapsulation**

Prior to transmission, the VLAN encapsulation of the packet is updated as necessary. VLAN tags may be added, removed, or modified. Similarly, if a packet had its priority demoted by an ingress policer, its priority values (CoS and DSCP) may need to be replaced prior to transmission.

An optional mode is available whereby the VLAN encapsulation of the packet is not updated. If the packet is not updated, the packet will be transmitted with the same layer-2 header. If the packet was tagged, it will be transmitted with the same VLAN tag, and the COS will not be updated. If the packet was untagged, it will be transmitted without a VLAN tag. In both cases, the IP DSCP will not be updated.



Figure 14. VLAN Encapsulation Process

### VLAN Encapsulation (continued)

The VLAN encapsulation process operates in one of two fundamentally different ways depending on whether the transmit port is configured as a trunk port or an access port.

Access ports may only transmit packets that have no VLAN tags. Hence, if the packet was received with a VLAN tag, it must be removed from the packet prior to transmission.

The behavior of a trunk port is a bit more complex. An optional mode is available for the ET4148-50 whereby packets are transmitted on a trunk port without a VLAN tag if the VLAN that the packet belongs to matches the default VLAN ID of the transmit (trunk) port. If this mode is not in use, all packets transmitted by a trunk port are transmitted with a VLAN tag.

If the packet was received without a VLAN tag, then one must be added. If the packet was received with a VLAN tag, then its current tag is replaced with a new one. For typical configurations, the replacement VLAN tag is the same as the one that the packet was received with and the replacement of the tag has no effect on the contents of the packet.

Finally, if the transmit packet is an IP packet, its DSCP value is updated prior to transmission. If the packet was marked for priority demotion during ingress policing, the new priority value reflects a reduction in priority. The nature of this reduction in priority depends on the configuration of the priority decode table.

### **Packet Transmission**

The packet transmission process merges the regular network transmit packets with the full-duplex flow control packets and delivers the packets to the attached network.



Figure 15. Packet Transmission Processes

Full-duplex flow control packets are given equal priority to normal transmit packets and are simply merged into the transmit flow on a round-robin basis. Flow control packets are only sent when the packet buffer is congested, and even then, they are not sent very often relative to the rate that normal packets may be transmitted.

If a packet was modified during its traversal of the ET4148-50, a new CRC value is computed by the transmitting Ethernet MAC. Otherwise, the CRC received with the packet is used for transmission.

# **Supervisor Packet Reception**

Eight of the ET4148-50's 408 internal queues are dedicated to supervisor use. The normal bridging processes result in certain packets being forwarded to these queues. Typically, each queue is dedicated to a single purpose (e.g., source address learning) or a limited range of purposes.

The Layer 2 address tables may be configured to forward or copy any arbitrary MAC destination address to the supervisor. Also, certain types of packets are generally forwarded or copied to the supervisor. These packet types include those with unknown MAC source addresses, IGMP packets, ACL logged packets, and others. Generally, each of the supervisor's eight queues are dedicated to only a very limited number of traffic types.

The packet queuing and buffering space within the ET4148-50 is limited, and the supervisor's ability to keep up with certain types of traffic may be very unlikely. Hence, the ET4148-50 transfers packets from its internal buffers to buffers created within the supervisor's memory system across the ET4148-50's *PCI* bus. The ET4148-50 does this as a *PCI* initiator.



Figure 16. Supervisor Packet Reception Structures

Figure 16 shows how eight transmit queues are dedicated to the supervisor. These eight particular transmit queues (ports 50 through 57) are associated in a one-to-one relationship with eight receive FIFOs that are established in the supervisor's memory space.

### Supervisor Packet Reception (continued)

#### Data Structures

The receive structures established within the supervisor's memory system consist of a series of circular FIFOs. The starting and ending locations of the FIFOs are defined through a series of registers within the ET4148-50 (Supervisor\_Rx\_Fifo\_Limits\_{0..7}). These starting and ending locations of each FIFO remain static once configured by the supervisor.

Read and write pointers (Supervisor\_Rx\_Fifo\_Ptr\_{0..7}) are used during the operation of the FIFOs. The ET4148-50 advances the write pointers as packet data is stored in the FIFO space, and the supervisor advances the read pointer as it processes and discards the packets.

All packets transferred into the supervisor's receive queues are treated integrally. In other words, if the space remaining in the FIFO before its physical endpoint (not to be confused with its logical endpoint) is not sufficient to accommodate a maximum length packet, then the packet is stored at the beginning of the FIFO's physical range.





The discontinuity caused by the gap left at the end of the physical range of the FIFO is handled by means of a 32-bit pointer that is written to the FIFO as the first word of the packet's data structure. The 32-bit pointer (Supervisor\_Rx\_Packet.packet\_start\_ptr[31:2]) points to where the packet can actually be found. Normally, this pointer points to the very next 32-bit word (as in the case of contiguously spaced receive packets). However, when a discontinuity is introduced as a consequence of keeping packets integral, the pointer points to the start of the FIFO's physical range rather than the next 32-bit word location.

# Supervisor Packet Reception (continued)

### **Packet Reception Process**

Packets received by the physical Ethernet interfaces may be forwarded or copied to one or more of the queues dedicated to the supervisor. These forwarding and copying decisions are based on the contents of the packets.

These supervisor queues are serviced in a normal manner. However, rather than being directed to Ethernet ports, these packets are directed to the supervisor via the *PCI* bus.

The identity of each packet's source queue accompanies the packet data as it is retrieved and forwarded to the supervisor. This identifying information is used to determine which of the eight receive FIFOs in supervisor memory are to receive the packets.



Figure 18. Supervisor Packet Reception Process (Hardware Actions)

### Supervisor Packet Reception (continued)

#### Hardware Actions.

1. Check if close to end of FIFO physical limit.

The first step taken by the ET4148-50 is to determine if the space remaining between the logical end of a receive FIFO and its physical end (refer to Figure 18 on page 40 for a depiction of the terms) is great enough to accommodate a maximum length packet. The following equation is used to make this determination:

( Supervisor\_Rx\_Fifo\_Limits\_{0..7}.rx\_fifo\_end\_ptr[31:0] Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2] ) >=
Supervisor\_Mode.maximum\_packet\_length[13:0]

If the preceding equation is true, then proceed to step 2. Otherwise, proceed to step 3.

2. Set start-of-packet pointer in packet data structure to the subsequent location.

```
Here, Supervisor_Rx_Packet.packet_start_ptr[31:2] is set equal to
Supervisor_Rx_Fifo_Ptr_{0..7}.wr_ptr[31:2] + 4 (i.e., the next memory location).
Supervisor_Rx_Packet.packet_start_ptr[31:2] is then written to the supervisor memory location
pointed to by Supervisor_Rx_Fifo_Ptr_{0..7}.wr_ptr[31:2] and the write pointer is advanced<sup>1</sup> by 4.
```

Go to step 4.

3. Set start-of-packet pointer in packet data structure to the start of the FIFO.

```
If the preceding equation is false, then Supervisor_Rx_Packet.packet_start_ptr[31:2] is set equal to Supervisor_Rx_Fifo_Limits_{0..7}.rx_fifo_start_ptr[31:2].
Supervisor_Rx_Packet.packet_start_ptr[31:2] is then written to the supervisor memory location pointed to by Supervisor_Rx_Fifo_Ptr_{0..7}.wr_ptr[31:2] and the write pointer is set equal to Supervisor_Rx_Fifo_Limits_{0..7}.rx_fifo_start_ptr[31:0].
```

Continue with step 4.

4. Check FIFO capacity.

The last check is to determine if there is sufficient room between

Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2] and

```
Supervisor_Rx_Fifo_Limits_\{0..7\}.rx_fifo_first_ptr[31:2] to store a maximum length packet. The following equation is used to make this determination<sup>2</sup>:
```

( Supervisor\_Rx\_Fifo\_Limits\_{0..7}.rx\_fifo\_first\_ptr[31:2] -Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2] ) >= Supervisor\_Maximum\_Packet\_Length.maximum\_packet\_length[13:0]

If the preceding equation is false, wait. Otherwise, proceed to step 5.

5. Write packet data.

If the preceding equation is true, then there is sufficient room for a maximum length packet and the packet transfer commences. Supervisor\_Rx\_Packet[4..<end of packet>] is written to sequential 32-bit words of supervisor memory with Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2] advancing after each write. At the completion of the transfer, Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.last\_ptr[31:2] is set equal to the value that Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2] held prior to any writes. This last step marks the first 32-bit word of the last packet in the receive FIFO.

Whenever Supervisor\_Rx\_Fifo\_Limts\_{0..7}.first\_ptr[31:2] and

Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.last\_ptr[31:2] are not equal, then the FIFO is not empty and an indication to that effect is provided to the supervisor via Supervisor\_Rx\_Fifo\_Status\_{0..7}.not\_empty.

<sup>1.</sup> The write pointer (Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2]) may never be advanced by the hardware to be equal to the first pointer (Supervisor\_Rx\_Fifo\_Limits\_{0..7}.rx\_fifo\_first\_ptr[31:2]). If advancing the first pointer would cause such a situation, the advancement of the write pointer is delayed until the software has moved the first pointer.

<sup>2.</sup> If the difference computed in this equation is negative, then the equation is considered to be true.

# Supervisor Packet Reception (continued)



### Figure 19. Supervisor Packet Reception Process (Supervisor Actions

Supervisor Actions. Upon detecting that Supervisor\_Rx\_Fifo\_Status\_{0..7}.not\_empty is true, the supervisor reads Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.first\_ptr[31:2] in order to determine the location of the start of the first packet in the receive FIFO.

Reading the memory location pointed to by Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.first\_ptr[31:2] returns Supervisor\_Rx\_Packet.packet\_start\_ptr[31:2], the pointer to the remainder of the packet. The supervisor then begins reading the remainder of the packet starting at the indicated location.

When the supervisor has finished working with the current packet, it writes the address of the first 32-bit word beyond the end of the packet to Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.first\_ptr[31:2]. This has the effect of allowing the ET4148-50 to overwrite the packet.

# **Supervisor Packet Transmission**

The ET4148-50 supervisor processor performs packet transmissions by faking packet receptions.

The supervisor presents a packet to the ET4148-50's receive packet processing as if it were a normal receive packet. However, rather than using look-up results derived from the packet's contents, the Layer 2 and ACL look-up operations use look-up results that have been queued by the supervisor in advance of reception of the packet. These faked look-up results are used to direct the packet to the queues associated with the transmit ports desired by the supervisor.

Because of this requirement to preload the look-up results, the transmit packet data structure is headed by a series of fields that hold such information as a transmit port map, priority level, and the like.

Two independent queues are available to the supervisor for packet transmission. The two queues have a strict priority relationship. Whenever the high-priority queue is not empty, it preempts the operations of the low-priority queue.

#### **Data Structures**

The following three sets of information stored in the supervisor's memory are necessary for packet transmission:

- 1. Packet transmission FIFO.
- 2. Packet descriptor blocks.
- 3. Packet segments.



Figure 20. Supervisor Packet Transmission Data Structures

# Supervisor Packet Transmission (continued)

### Packet Transmission Queue

Two packet transmission queues are maintained within supervisor memory. Each queue consists of a series of 32-bit words that are pointers to packet descriptor blocks. One queue entry and, consequently, one packet descriptor block, corresponds to a single packet. A single packet descriptor block may have more than one reference in the packet transmission queues.

The physical limits of the packet transmission queues as well as their read and write pointers are defined by a series of registers.

**Packet Descriptor Blocks.** Packet descriptor blocks are variable length lists of pointers and byte counts that identify the packet segments to be gathered up to form a transmit packet. By allowing packets to be segmented into several pieces, the supervisor has the option of having catalogs of look-up result headers, Layer 2 headers, and Layer 3 headers that can be concatenated to form a packet's header. Packet bodies may also be cataloged and warehoused in this fashion.

Each packet descriptor block consists of a one or more pairs of 32-bit words. The first 32-bit word is a pointer to a packet segment. The second 32-bit word contains a byte count for the segment and a flag that indicates whether or not the current segment is the last segment for the packet. The processing of these descriptor block records continues until a last flag is encountered.

**Packet Segments**. Packet segments are simple byte strings that make up the actual packet data. Packet segments may range in size from a single byte to 16 Kbytes.

### Supervisor Packet Transmission (continued)



### Figure 21. Supervisor Packet Transmission Process (Hardware Actions)

#### Packet Transmission Process

The supervisor must examine the state of the transmit FIFO in order to determine the setting for Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.last[31:2]. If the current location pointed to by Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.last[31:2] is one location behind Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.rd\_ptr[31:2], then the FIFO is full and the supervisor must wait until space has been made available.

If Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.last[31:2] is equal to
Supervisor\_Tx\_Fifo\_Limits\_{0..1}.end[31:2], then the supervisor must make the location pointed to by
Supervisor\_Tx\_Fifo\_Limits\_{0..1}.start[31:2] as the next FIFO location utilized.

The supervisor then sets up the packet's data structures as shown in Figure 16 on page 38. It then sets  $Supervisor_Tx_Fifo_Ptr_{0..1}.last[31:2]$  to point to the new entry in Supervisor\_Tx\_Fifo.

The ET4148-50 detects that <code>Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.rd\_ptr[31:2]</code> and <code>Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.last[31:2]</code> are no longer equal and advances <code>Supervisor\_Tx\_Fifo\_Ptr\_{0..1}.rd\_ptr[31:2]</code> to the next location within <code>Supervisor\_Tx\_Fifo.This</code> location is then read by the ET4148-50 to gather the pointer to the transmit packet's descriptor block.

# Supervisor Packet Transmission (continued)

### Packet Transmission Process (continued)

Pairs of 32-bit words are read from Supervisor\_Tx\_Descriptor in order to determine the location and byte count of each of the packet's segments. If Supervisor\_Tx\_Descriptor.last is asserted, then the current segment is the last segment of the packet.

The ET4148-50 reads the packet segments in the order in that their descriptors appear in

Supervisor\_Tx\_Descriptor. The first segment of every transmit packet contains the destination port map and priority information for the packet.

The packet segments are stored as a contiguous packet within the ET4148-50 in the normal manner and queued for transmission utilizing the supplied destination information.

# **Data Structures**

# Supervisor\_Rx\_Fifo\_{0..7}

Description: An assortment of receive packets.

#### Table 8. Supervisor\_Rx\_Fifo\_{0..7} Register Parameters

| Parameter           | Value                                                                                        |
|---------------------|----------------------------------------------------------------------------------------------|
| Base Address        | Supervisor_Rx_Fifo_Limits_{01}.start[31:2]                                                   |
| Structure Size      | Supervisor_Rx_Fifo_Limits_{01}.end[31:2] -<br>Supervisor_Rx_Fifo_Limits_{01}.start[31:2] + 4 |
| Structure Instances | 8                                                                                            |
| Structure Spacing   | Variable                                                                                     |



### Figure 22. Supervisor\_Rx\_Fifo\_{0..7} Data Structure

This data structure is a collection of Supervisor\_Rx\_Packet data structures.

The physical extent of Supervisor\_Rx\_Fifo{0..7} is defined by Supervisor\_Rx\_Fifo\_Limits\_{0..7}.

### Supervisor\_Rx\_Packet

Description: The form of received packets in supervisor memory space.

#### Table 9. Supervisor\_Rx\_Packet Register Parameters

| Parameter           | Value                                                   |
|---------------------|---------------------------------------------------------|
| Base Address        | One 32-bit word after the previous Supervisor_Rx_Packet |
| Structure Size      | Variable                                                |
| Structure Instances | Variable                                                |
| Structure Spacing   | Variable                                                |

|   | 0                                                              | 1                      | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----------------------------------------------------------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31                                                             | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |                                                                | packet_start_ptr[31:2] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4 | vlan_index[7:0] priority[3:0] rx_port[5:0] packet_length[13:0] |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 8 | packet_data{0(packet_length[13:0] - 1)}                        |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|   | •                                                              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|   |                                                                |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Figure 23. Supervisor\_Rx\_Packet Data Structure

### Supervisor\_Rx\_Packet (continued)

#### Table 10. Supervisor\_Rx\_Packet Field Parameters

| Field Name             | Parameters                 | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| packet_start_ptr[31:2] | Mode = RO<br>Offset = 0.0  | Points to the status word of the associated receive packet. Ordinarily,<br>packet_start_pointer[31:2] and {rx_port[5:0],<br>packet_length[13:0]} are adjacent. However, in order to maintain<br>integral packets, these two words may be nonadjacent near the end of<br>the physical extent of a supervisor's receive FIFO.<br>This value is written by the ET4148-50 and read by the supervisor. |
| truncated              | Mode = RO<br>Offset = 0.30 | If a receive packet is truncated because its length exceeds that set in Supervisor_Maximum_Packet_Length, then this bit is asserted.                                                                                                                                                                                                                                                              |
| parity_error           | Mode = RO<br>Offset = 4.0  | This bit is asserted if an internal parity error is detected at any time dur-<br>ing the transfer of a packet from the ET4148-50 across the <i>PCI</i> bus to<br>the supervisor.                                                                                                                                                                                                                  |
| vlan_index[7:0]        | Mode = RO<br>Offset = 4.0  | The VLAN index assigned to a packet during reception.                                                                                                                                                                                                                                                                                                                                             |
| priority[3:0]          | Mode = RO<br>Offset = 4.8  | The priority value assigned to a packet during reception.                                                                                                                                                                                                                                                                                                                                         |
| rx_port[5:0]           | Mode = RO<br>Offset = 4.12 | This value identifies the physical port via which the packet was received.<br>This value is written by the ET4148-50 and read by the supervisor.                                                                                                                                                                                                                                                  |
| packet_length[13:0]    | Mode = RO<br>Offset = 4.18 | The length of a received packet. packet_length[13:0] is limited by Supervisor_Maximum_Packet_Length. If packet_length[13:0] equals Supervisor_Maximum_Packet_Length, then the packet may have been truncated during the transfer.<br>This value is written by the ET4148-50 and read by the supervisor.                                                                                           |
| packet_data            | Mode = RO<br>Offset = 8.0  | The packet data. Packet data is arranged in a big-endian fashion. The last 32-bit word may contain zero or more pad bytes. This value is written by the ET4148-50 and read by the supervisor.                                                                                                                                                                                                     |

This data structure is used to present received packets to the supervisor. Zero or more of these data structures are arranged within a FIFO structure maintained within the supervisor's memory. The first word of Supervisor\_Rx\_Packet always immediately follows the last word of the previous instance.

The first word of this data structure is a pointer to the remainder of the data structure. Ordinarily, these structures are arranged contiguously. If the space at the end of  $Supervisor_Rx_Fifo{0..7}$  is insufficient to accommodate a maximum length packet, then  $Supervisor_Rx_Packet.packet_start_ptr[31:2]$  is used to point to the start of  $Supervisor_Rx_Fifo{0..7}$ .

If there is insufficient space to accommodate a maximum length packet anywhere in Supervisor\_Rx\_Fifo{0..7}, then the FIFO is considered full even though a smaller packet may fit.

If Supervisor\_Rx\_Fifo{0..7} is empty, then Supervisor\_Rx\_Packet is placed at Supervisor\_Rx\_Fifo\_Ptr\_{0..7}.wr\_ptr[31:2].

### Supervisor\_Tx\_Descriptor

Description: A list of descriptors of supervisor transmit packet segments.

#### Table 11. Supervisor\_Tx\_Descriptor Register Parameters

| Parameter           | Value                                                      |
|---------------------|------------------------------------------------------------|
| Base Address        | <pre>Supervisor_Tx_Fifo_{01}.tx_descriptor_ptr[31:2]</pre> |
| Structure Size      | Variable                                                   |
| Structure Instances | Variable                                                   |
| Structure Spacing   | Variable                                                   |





| Field Name              | Parameters                  | Description                                                                                                                                                           |
|-------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_segment_ptr[31:0]    | Mode = R/W<br>Offset = 0.0  | A pointer to a supervisor transmit packet segment.                                                                                                                    |
| last                    | Mode = R/W<br>Offset = 4.0  | When asserted, this descriptor is a packet's last descriptor.                                                                                                         |
| indicate                | Mode = R/W<br>Offset = 4.1  | When asserted by the supervisor, the tx_packet indication is asserted in Supervisor_Ind upon completion of the transfer of the corresponding transmit packet segment. |
| tx_segment_length[13:0] | Mode = R/W<br>Offset = 4.18 | The size of a packet segment.                                                                                                                                         |

This data structure is a list of descriptors of packet segments. Each packet segment requires its own descriptor. The descriptors are processed in the order in which they are encountered in <code>Supervisor\_Tx\_Descriptor</code>. Each packet requires a <code>Supervisor\_Tx\_Descriptor</code> structure with at least one record.

Transmit packet processing is terminated upon the completion of processing of the record whose **last** bit is asserted.

 $tx\_segment\_ptr[31:0]$  is able to address segments on any arbitrary byte boundary. Each segment may also be of any arbitrary byte length. The ET4148-50 ensures that packet segments are stitched together correctly.

The physical extent of Supervisor\_Tx\_Descriptor is defined by Supervisor\_Tx\_Fifo\_Limits\_{0..1}.

# Supervisor\_Tx\_Fifo\_{0..1}

Descriptions: FIFO list of transmit descriptor block pointers.

#### Table 13. Supervisor\_Tx\_Fifo\_{0..1} Register Parameters

| Parameter           | Value                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------|
| Base Address        | Supervisor_Tx_Fifo_Limits_{01}.start_ptr[31:2]                                                       |
| Structure Size      | Supervisor_Tx_Fifo_Limits_{01}.end_ptr[31:2] -<br>Supervisor_Tx_Fifo_Limits_{01}.start_ptr[31:2] + 4 |
| Structure Instances | 2                                                                                                    |
| Structure Spacing   | Variable                                                                                             |



# Figure 25. Supervisor\_Tx\_Fifo\_{0..1} Data Structure

### Table 14. Supervisor\_Tx\_Fifo\_{0..1}

| Field Name              | Parameters                 | Description                                                 |
|-------------------------|----------------------------|-------------------------------------------------------------|
| tx_descriptor_ptr[31:2] | Mode = R/W<br>Offset = 0.0 | A pointer to a supervisor transmit packet descriptor block. |

This data structure is a collection of pointers to transmit descriptor blocks.

The physical extent of Supervisor\_Tx\_Fifo{0..1} is defined by Supervisor\_Tx\_Fifo\_Limits\_{0..1}.

### Supervisor\_Tx\_Packet

Description: A string of transmit packet data bytes.

#### Table 15. Supervisor\_Tx\_Packet Register Parameters

| Parameter           | Value                    |  |  |  |  |
|---------------------|--------------------------|--|--|--|--|
| Base Address        | Variable (multiple of 4) |  |  |  |  |
| Structure Size      | Variable                 |  |  |  |  |
| Structure Instances | Variable                 |  |  |  |  |
| Structure Spacing   | Variable                 |  |  |  |  |

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31



Figure 26. Supervisor\_Tx\_Packet Data Structure

#### **Field Name Parameters** Description Mode = R/Wpriority[3:0] The packet's priority value. Offset = 0.0Mode = R/Wdest map[57:0] The packet's destination map. Asserted bits corre-Offset = 0.6spond to selected transmit ports. Mode = R/W<packet bytes> The transmit packet data bytes. Offset = 8.0

### Table 16. Supervisor\_Tx\_Packet

This data structure is a single transmit packet. Every transmit packet is preceded by a priority[3:0] value and a dest\_map[57:0] vector. The packet data bytes start at byte offset 8 and continue from there. The byte located at offset 8 must always be the first byte of packet's 48-bit Layer 2 destination address field.

The supervisor must not included a CRC value with the packet. A CRC is automatically calculated and appended during the transmission process.

### Supervisor\_Tx\_Packet\_Segment

Description: A segment of a transmit packet.

#### Table 17. Supervisor\_Tx\_Packet\_Segment Register Parameters

| Parameter           | Value                                            |
|---------------------|--------------------------------------------------|
| Base Address        | Supervisor_Tx_Descriptor.tx_segment_ptr[31:0]    |
| Structure Size      | Supervisor_Tx_Descriptor.tx_segment_length[13:0] |
| Structure Instances | Variable                                         |
| Structure Spacing   | Variable                                         |



### Figure 27. Supervisor\_Tx\_Packet\_Segment Data Structure

This data structure is a single segment of a packet. One or more segments are used to assemble transmit packets.

# **Electrical Specifications**

# **Absolute Maximum Ratings**

Stresses in excess of the absolute maximum ratings can cause permanent damage to the device. These are absolute stress ratings only. Functional operation of the device is not implied at these or any other conditions in excess of those given in the operations sections of the data sheet. Exposure to absolute maximum ratings for extended periods can adversely affect device reliability.

### Table 18. Absolute Maximum Ratings

| Parameter                 | Symbol          | Max | Unit |
|---------------------------|-----------------|-----|------|
| Core Supply Voltage       | VDD12_CORE      | 1.7 | V    |
| Core PLL Voltage          | AVDD12_PLL_CORE | 1.7 | V    |
| SGMII Termination Voltage | VDD15L          | 4.6 | V    |
| SGMII I/O Voltage         | VDD33L          | 4.6 | V    |
| SGMII PLL Voltage         | AVDD12_PLL      | 1.7 | V    |
| SFP Output Buffer Voltage | VDDOB[47:44]    | 1.7 | V    |
| SFP Core Voltage          | VDD_3           | 1.7 | V    |
| SFP Input Buffer Voltage  | VDDIB[47:44]    | 1.7 | V    |
| 10G Output Buffer Voltage | VDDOB[49:48]    | 1.7 | V    |
| 10G Core Voltage          | VDD_4           | 1.7 | V    |
| 10G Input Buffer Voltage  | VDDIB[49:48]    | 1.7 | V    |
| PCI I/O Voltage           | VDD33           | 4.6 | V    |
| Storage Temperature       | Tstg            | 125 | ٥C   |

### **ESD** Protection

### Table 19. ESD Protection

| Parameter       | Value         | Unit |  |  |  |  |  |  |
|-----------------|---------------|------|--|--|--|--|--|--|
| High-Speed Pins |               |      |  |  |  |  |  |  |
| НВМ             | 1.5           | kV   |  |  |  |  |  |  |
| CDM             | 250           | V    |  |  |  |  |  |  |
| Lo              | ow-Speed Pins |      |  |  |  |  |  |  |
| НВМ             | 2.0           | kV   |  |  |  |  |  |  |
| CDM             | 500           | V    |  |  |  |  |  |  |

# **Recommended Operating Conditions**

### Table 20. Recommended Operating Conditions\*

| Parameter                     | Symbol          | Min   | Тур | Max   | Unit |
|-------------------------------|-----------------|-------|-----|-------|------|
| Core Supply Voltage           | VDD12_CORE      | 1.14  | 1.2 | 1.26  | V    |
| Core PLL Voltage              | AVDD12_PLL_CORE | 1.14  | 1.2 | 1.26  | V    |
| SGMII Termination Voltage     | VDD15L          | 1.425 | 1.5 | 1.575 | V    |
| SGMII I/O Voltage             | VDD33L          | 3.135 | 3.3 | 3.465 | V    |
| SGMII PLL Voltage             | AVDD12_PLL      | 1.14  | 1.2 | 1.26  | V    |
| SFP Output Buffer Voltage     | VDDOB[47:44]    | 1.425 | 1.5 | 1.575 | V    |
| SFP Core Voltage              | VDD_3           | 1.14  | 1.2 | 1.26  | V    |
| SFP Input Buffer Voltage      | VDDIB[47:44]    | 1.425 | 1.5 | 1.575 | V    |
| 10G Output Buffer Voltage     | VDDOB[49:48]    | 1.425 | 1.5 | 1.575 | V    |
| 10G Core Voltage              | VDD_4           | 1.14  | 1.2 | 1.26  | V    |
| 10G Input Buffer Voltage      | VDDIB[49:48]    | 1.425 | 1.5 | 1.575 | V    |
| PCI I/O Voltage               | VDD33           | 3.135 | 3.3 | 3.465 | V    |
| Ambient Operating Temperature | Та              | 0     |     | 70    | °C   |

\* All voltages are ±5%.

# **Power Supply Consumption**

### Table 21. Power Supply Consumption

| Power Supply    | Maximum Current Consumption per Supply |  |  |  |  |  |  |
|-----------------|----------------------------------------|--|--|--|--|--|--|
| 1.2 V Supply    |                                        |  |  |  |  |  |  |
| VDD12_CORE      | 7800 mA                                |  |  |  |  |  |  |
| AVDD12_PLL      |                                        |  |  |  |  |  |  |
| AVDD12_PLL_CORE |                                        |  |  |  |  |  |  |
| VDD_3           |                                        |  |  |  |  |  |  |
| VDD_4           |                                        |  |  |  |  |  |  |
|                 | 1.5 V Supply                           |  |  |  |  |  |  |
| VDD15L          | 690 mA                                 |  |  |  |  |  |  |
| VDDIB_(49:44)   |                                        |  |  |  |  |  |  |
| VDDOB_(49:44)   |                                        |  |  |  |  |  |  |
|                 | 3.3 V Supply                           |  |  |  |  |  |  |
| VDD33L          | 560 mA                                 |  |  |  |  |  |  |
| VDD33           |                                        |  |  |  |  |  |  |

# **Thermal Characteristics**

### **Table 22. Thermal Characteristics**

| Parameter                                   | Symbol | Min | Тур  | Max | Unit |
|---------------------------------------------|--------|-----|------|-----|------|
| Junction Temperature                        | TJ     | _   | 112  | 125 | °C   |
| Theta Junction to Case                      | θJC    | _   | 0.42 | —   | °C/W |
| Theta Case to Ambient Required by Heat Sink | θCA    | _   | 2.91 | —   | °C/W |

# **PCI I/O Specification**

### Table 23. dc Electrical Specification—PCI

| Parameter           | Symbol | Pin Type | Conditions         | Min               | Мах             | Unit |
|---------------------|--------|----------|--------------------|-------------------|-----------------|------|
| Input High Voltage  | Vih    | I        | _                  | 0.5 x<br>VDD33_IO | VDD33_IO + 0.5  | V    |
| Input Low Voltage   | VIL    | I        | —                  | -0.5              | 0.35 x VDD33_IO | V    |
| Input High Current  | Іін    | I        | —                  |                   |                 |      |
| Input Low Current   | lı∟    | I        | —                  |                   | —               |      |
| Output High Voltage | Vон    | 0        | Iон = -0.5 mA      | 0.9 x<br>VDD33_IO | _               | V    |
| Output Low Voltage  | Vol    | 0        | IOL = 1.5 mA       |                   | 0.1 x VDD33_IO  | V    |
| Tristate Leakage    | loz    | 0        | 0 < VIN < VDD33_IO | -10               | 10              | μA   |
| Input Leakage       | lız    | I        | 0 < VIN < VDD33_IO | -1                | 1               | μA   |

# JTAG I/O Specification

### Table 24. dc Electrical Specification—JTAG

| Parameter *                | Symbol | Pin<br>Type | Conditions         | Min | Тур  | Max | Unit |
|----------------------------|--------|-------------|--------------------|-----|------|-----|------|
| Maximum Input High Voltage | VIMAX  | Ι           | —                  |     | —    | 5.5 | V    |
| Minimum Input Low Voltage  | VILMAX | Ι           | —                  | 0.0 | —    | —   | V    |
| Input High Voltage         | Viн    | Ι           | —                  | 1.3 | 1.55 | 2.0 | V    |
| Input Low Voltage          | VIL    | I           | —                  | 0.8 | 1.20 | 1.5 | V    |
| Input Hysteresis           | VHYS   | Ι           | —                  | 0.3 | 0.35 | 0.4 | V    |
| Output High Voltage        | Vон    | 0           | —                  | 2.4 | —    | —   | V    |
| Output Low Voltage         | Vol    | 0           | —                  | 0.4 | —    | —   | V    |
| Output High Current        | Іон    | 0           | —                  |     | 10   | —   | mA   |
| Output Low Current         | IOL    | 0           | —                  |     | 10   | _   | mA   |
| Tristate Leakage Current   | —      | 0           | VIN = 0 V to 5.5 V | -10 | ±1   | 10  | μA   |
| Output Resistance          | Ro     | 0           | —                  | 16  | 21   | 34  | Ω    |

\* All parameters measured at RLOAD = 100  $\Omega$  ± 1%.

# **SGMII I/O Transmit Specifications**

### Table 25. SGMII I/O Transmit Specifications

| Parameter                                                                  | Symbol   | Pin Type | Min  | Тур | Max  | Unit |
|----------------------------------------------------------------------------|----------|----------|------|-----|------|------|
| High Output Voltage                                                        | Vон      | 0        |      | —   | 1525 | mV   |
| Low Output Voltage                                                         | Vol      | 0        | 875  | —   | —    | mV   |
| Peak-to-peak Output Differential Voltage                                   | Vod      | 0        | 150  | —   | 400  | mV   |
| Output Offset Voltage (common-mode voltage)                                | Vos      | 0        | 1075 | —   | 1325 | mV   |
| Output Overshoot/Undershoot                                                | VRING    | 0        | _    | —   | 10   | %    |
| Output Resistance (single-ended)                                           | Ro       | 0        | 40   | —   | 140  | Ω    |
| Mismatch of Output Resistance Within a Differential<br>Pair                | DRo      | 0        | _    | _   | 10   | %    |
| Change in VOD Between Low and High Output Voltage                          | Dvod     | 0        | _    | —   | 25   | mV   |
| Change in VOS Between Low and High Output Voltage                          | Dvos     | 0        |      | —   | 25   | mV   |
| Output Short-circuit Current Between an Output and Ground                  | ISA, ISB | 0        | _    | _   | 12   | mA   |
| Output Short-circuit Current Between the Sides of a Dif-<br>ferential Pair | ISAB     | 0        | _    | _   | 10   | mA   |
| Powerdown Leakage Current                                                  | _        | 0        | _    | —   | 10   | mA   |
| Output Rise and Fall Time (20%—80%)                                        | tR, tF   | 0        | 100  | —   | 200  | ps   |
| Differential Skew                                                          | Tskew    | 0        |      |     | 20   | ps   |

# SGMII I/O Receive Specifications

### Table 26. SGMII I/O Receive Specifications

| Parameter                             | Symbol | Pin Type | Min | Тур | Max  | Unit |
|---------------------------------------|--------|----------|-----|-----|------|------|
| Input Voltage Range                   | Vid    | I        | 675 | _   | 1725 | mV   |
| Differential Input Voltage Threshold  | Vidth  | Ι        | -50 | _   | 50   | mV   |
| Receive Input Differential Resistance | Rı     | I        | 80  |     | 120  | Ω    |

# SFP—1.25 Gbits/s SerDes Specifications

### Table 27. RX Serial Buffer Input Electrical Specification—1.25 Gbits/s SerDes I/O

| Parameter                      | Symbol   | Pin Type | Conditions | Min | Тур | Max   | Unit |
|--------------------------------|----------|----------|------------|-----|-----|-------|------|
| Differential Input<br>Voltage  | Vid      | I        |            | 175 | _   | 2000  | mV   |
| Common-mode Input<br>Voltage   | Vic      | I        |            | 0.5 | —   | Vddib | V    |
| Input Resistance               | Rı       | I        | —          | _   | 50  | _     | Ω    |
| Receiver Rise and<br>Fall Time | tri, tri | I        | 20%—80%    | —   | —   | 160   | ps   |
| Input Return Loss              | S11I     | I        | _          | 10  |     |       | dB   |



Figure 28. Receiver Eye Diagram

| Table 28. Receiver | Eye | Diagram | Values |
|--------------------|-----|---------|--------|
|--------------------|-----|---------|--------|

| Symbol               | Receiver HDIN P-N Pair | Unit  |
|----------------------|------------------------|-------|
| X1                   | 0.275                  | Ulp∗  |
| X2                   | 0.400                  | Ulp   |
| A1                   | 100                    | mVp   |
| A2                   | 800                    | mVp   |
| Deterministic Jitter | 0.47                   | Ulp-p |
| Total Jitter         | 0.65                   | Ulp-p |

\* UI = 800 ps.

# SFP—1.25 Gbits/s SerDes Specifications (continued)

# Table 29. TX Serial Buffer Output Electrical Specification—1.25 Gbits/s SerDes I/O

| Parameter                              | Symbol   | Pin Type | Conditions                                                        | Min        | Тур                      | Max        | Unit |
|----------------------------------------|----------|----------|-------------------------------------------------------------------|------------|--------------------------|------------|------|
| Transmit Differential<br>Voltage Swing | VODAC    | 0        | All power settings<br>(min—max),<br>ac coupled<br>VDDOB = 1.5     | 203        | _                        | 864        | mV   |
| Transmit Differential<br>Voltage Swing | VODDC    | 0        | All power settings<br>(min—max),<br>direct coupled<br>VDDOB = 1.5 | 191        | _                        | 906        | mV   |
| Transmit Differential<br>Voltage Swing | VODAC    | 0        | All power settings<br>(min—max),<br>ac coupled<br>VDDOB = 1.2     | 221        | _                        | 1134       | mV   |
| Transmit Differential<br>Voltage Swing | VODDC    | 0        | All power settings<br>(min—max),<br>direct coupled<br>VDDOB = 1.2 | 191        |                          | 1208       | mV   |
| Transmit Common-<br>mode Voltage       | VCMAC    | 0        | ac coupled                                                        | Тур – 0.15 | VDDOB/2                  | Тур + 0.15 | V    |
| Transmit Common-<br>mode Voltage       | VCMDC    | 0        | dc coupled                                                        | Тур – 0.15 | Vddob –<br>[Vout(p-p)/4] | Тур + 0.10 | mV   |
| Output Resistance                      | Ro       | 0        | _                                                                 | 42         | 50                       | 58         | Ω    |
| Transmitter Rise and<br>Fall Time      | tro, tro | 0        | 20%—80%                                                           | 60         | 80                       | 100        | ps   |
| Short Circuit Current                  | losc     | 0        | —                                                                 | —          | 20                       | 35         | mA   |
| Output Return Loss                     | S110     | 0        | _                                                                 |            | 10                       | _          | dB   |

# SFP-1.25 Gbits/s SerDes Specifications (continued)

#### Table 30. Clocking and Timing Specifications

| Parameter                                    | Min | Тур | Max  | Unit  |
|----------------------------------------------|-----|-----|------|-------|
| Transmitter Output Jitter in Half-Rate Mode: |     |     |      | Ulp-p |
| Deterministic                                | —   | —   | 0.08 |       |
| Random                                       | _   | —   | 0.12 |       |
| Total*                                       | —   | _   | 0.2  |       |

\* Does not include in-band reference-clock jitter, which must be added to this. In-band jitter is defined as jitter with spectral content within the 3 dB closed-loop bandwidth of the PPL.



Figure 29. Transmitter Eye Diagram

#### Table 31. Transmitter Eye Diagram Values

| Symbol               | Transmitter HDOUT P-N Pair | Unit  |
|----------------------|----------------------------|-------|
| X1                   | 0.175                      | Ulp*  |
| X2                   | 0.390                      | Ulp   |
| A1                   | 400                        | mVp   |
| A2                   | 800                        | mVp   |
| Deterministic Jitter | 0.17                       | Ulp-p |
| Total Jitter         | 0.35                       | Ulp-p |

\* UI = 800 ps.

# 10G—3.125 Gbits/s SerDes Specifications

### Table 32. RX Serial Buffer Input Electrical Specification—3.125 Gbits/s SerDes I/O

| Parameter                      | Symbol   | Pin Type | Conditions | Min | Тур | Max   | Unit |
|--------------------------------|----------|----------|------------|-----|-----|-------|------|
| Differential Input<br>Voltage  | Vid      | I        |            | 175 | —   | 2000  | mV   |
| Common-mode Input<br>Voltage   | Vic      | I        |            | 0.5 | —   | Vddib | V    |
| Input Resistance               | Rı       | I        | —          | —   | 50  | —     | Ω    |
| Receiver Rise and<br>Fall Time | tri, tri | I        | 20%—80%    | —   | —   | 160   | ps   |
| Input Return Loss              | S11I     | I        | _          | 10  |     | _     | dB   |



Figure 30. Receiver Eye Diagram

| Symbol               | Receiver HDIN P-N Pair | Unit  |
|----------------------|------------------------|-------|
| X1                   | 0.275                  | Ulp∗  |
| X2                   | 0.400                  | Ulp   |
| A1                   | 100                    | mVp   |
| A2                   | 800                    | mVp   |
| Deterministic Jitter | 0.47                   | Ulp-p |
| Total Jitter         | 0.65                   | Ulp-p |

\* UI = 320 ps.

# 10G—3.125 Gbits/s SerDes Specifications (continued)

### Table 34. TX Serial Buffer Output Electrical Specification—3.125 Gbits/s SerDes I/O

| Parameter                              | Symbol   | Pin Type | Conditions                                                        | Min        | Тур                      | Мах        | Unit |
|----------------------------------------|----------|----------|-------------------------------------------------------------------|------------|--------------------------|------------|------|
| Transmit Differential<br>Voltage Swing | VODAC    | 0        | All power settings<br>(min—max),<br>ac coupled<br>VDDOB = 1.5     | 203        | _                        | 864        | mV   |
| Transmit Differential<br>Voltage Swing | VODDC    | 0        | All power settings<br>(min—max),<br>direct coupled<br>VDDOB = 1.5 | 191        | _                        | 906        | mV   |
| Transmit Differential<br>Voltage Swing | VODAC    | 0        | All power settings<br>(min—max),<br>ac coupled<br>VDDOB = 1.2     | 221        | _                        | 1134       | mV   |
| Transmit Differential<br>Voltage Swing | VODDC    | 0        | All power settings<br>(min—max),<br>direct coupled<br>VDDOB = 1.2 | 191        | _                        | 1208       | mV   |
| Transmit Common-<br>mode Voltage       | VCMAC    | 0        | ac coupled                                                        | Тур – 0.15 | VDDOB/2                  | Тур + 0.15 | V    |
| Transmit Common-<br>mode Voltage       | VCMDC    | 0        | dc coupled                                                        | Тур – 0.15 | Vddob –<br>[Vout(p-p)/4) | Тур + 0.10 | mV   |
| Output Resistance                      | Ro       | 0        | _                                                                 | 42         | 50                       | 58         | Ω    |
| Transmitter Rise and<br>Fall Time      | tro, tro | 0        | 20%—80%                                                           | 60         | 80                       | 100        | ps   |
| Short Circuit Current                  | losc     | 0        | —                                                                 | —          | 20                       | 35         | mA   |
| Output Return Loss                     | S110     | 0        | —                                                                 | —          | 10                       |            | dB   |

### 10G-3.125 Gbits/s SerDes Specifications (continued)

#### **Table 35. Clocking and Timing Specifications**

| Parameter                                    | Min | Тур | Мах  | Unit  |
|----------------------------------------------|-----|-----|------|-------|
| Transmitter Output Jitter in Half-Rate Mode: |     |     |      | Ulp-p |
| Deterministic                                | —   | —   | 0.10 |       |
| Random                                       | —   | —   | 0.14 |       |
| Total*                                       | —   | —   | 0.24 |       |

\* Does not include in-band reference-clock jitter, which must be added to this. In-band jitter is defined as jitter with spectral content within the 3 dB closed-loop bandwidth of the PPL.



### Figure 31. Transmitter Eye Diagram

#### Table 36. Transmitter Eye Diagram Values

| Symbol               | Transmitter HDOUT P-N Pair | Unit  |
|----------------------|----------------------------|-------|
| X1                   | 0.175                      | Ulp*  |
| X2                   | 0.390                      | Ulp   |
| A1                   | 400                        | mVp   |
| A2                   | 800                        | mVp   |
| Deterministic Jitter | 0.17                       | Ulp-p |
| Total Jitter         | 0.35                       | Ulp-p |

\* UI = 320 ps.

# **Timing Diagrams**

SGMII



### Figure 32. SGMII ac Setup and Hold Timing Diagram

#### Table 37. SGMII I/O Receive Timing Specification

| Parameter  | Symbol         | Min | Тур | Max | Unit |
|------------|----------------|-----|-----|-----|------|
| Setup Time | <b>t</b> SETUP | 100 | _   | _   | ps   |
| Hold Time  | thold          | 100 | _   |     | ps   |

PCI





#### Table 38. 3.3 V PCI Clock ac Specification

| Parameter           | Symbol | Min | Тур | Max  | Unit |
|---------------------|--------|-----|-----|------|------|
| Clock Cycle Time    | tcyc   | 15  | _   | 30   | ns   |
| Clock High Time     | thigh  | 6   | —   | _    | ns   |
| Clock Low Time      | t∟ow   | 6   | —   | _    | ns   |
| Clock Slew Rate     | _      | 1   | —   | 4    | V/ns |
| Rise and Fall Time* | tR, tF | 1.8 |     | 5.84 | ns   |

\* Test conditions, 30%—60%, 10 pF load plus pad and package C, 140  $\Omega$  to VDD33\_IO, and 140  $\Omega$  to Vss.

# Timing Diagrams (continued)

PCI (continued)





#### Table 39. 3.3 V PCI Clock ac Specification

| Parameter             | Symbol | Min | Тур | Max | Unit |
|-----------------------|--------|-----|-----|-----|------|
| Clock-to-signal Valid | tval   | 2   | —   | 6   | ns   |
| Float-to-active Delay | tON    | 2   | —   | _   | ns   |
| Active-to-float Delay | tOFF   | —   | —   | 14  | ns   |
| Setup Time            | tSETUP | 3   | —   | _   | ns   |
| Hold Time             | thold  | 0   | —   |     | ns   |

Timing Diagrams (continued)

### SFP SerDes I/O Clock Input Specification

### Table 40. SFP SerDes Reference Clock Specifications

| Parameter                         | Symbol | Min   | Тур   | Мах           | Unit          |
|-----------------------------------|--------|-------|-------|---------------|---------------|
| Clock Frequency—SFP (REFCLK_3)    |        | _     | 125.0 | _             | MHz           |
| Frequency Stability               | _      | -100  |       | 100           | ppm           |
| Duty Cycle                        | _      | 40    | 50    | 60            | %             |
| Rise Time and Fall Time (20%—80%) | tR, tF |       | —     | 1.2           | ns            |
| Differential Amplitude            | Vod    | 600   | —     | 2 x VDD_3     | mVp-p         |
| Single-ended Amplitude            | VSE    | 300   | —     | VDD_3         | mVp-p         |
| Common-mode Level                 | VCM    | VSE/2 | —     | VDD_3 – VSE/2 | V             |
| PLL Bandwidth                     | _      | _     | —     | 12            | MHz           |
| Input Capacitance                 | CI     | _     | —     | 2.0           | pF            |
| Skew, REFCLK_3_(P,N)              | _      | -75   | —     | 75            | ps            |
| Jitter (peak-to-peak)             |        | _     | —     | 100           | <b>ps</b> p-p |

### XAUI SerDes I/O Clock Input Specification

### Table 41. XAUI SerDes Reference Clock Specifications

| Parameter                         | Symbol | Min   | Тур    | Мах           | Unit              |
|-----------------------------------|--------|-------|--------|---------------|-------------------|
| Clock Frequency—XAUI (REFCLK_4)   | _      | _     | 156.25 | _             | MHz               |
| Frequency Stability               |        | -100  |        | 100           | ppm               |
| Duty Cycle                        | _      | 40    | 50     | 60            | %                 |
| Rise Time and Fall Time (20%—80%) | tR, tF |       | —      | 1.2           | ns                |
| Differential Amplitude            | Vod    | 600   | —      | 2 x VDD_4     | mVp-p             |
| Single-ended Amplitude            | VSE    | 300   | —      | VDD_4         | mVp-p             |
| Common-mode Level                 | VCM    | VSE/2 | —      | VDD_4 – VSE/2 | V                 |
| PLL Bandwidth                     | _      |       | —      | 12            | MHz               |
| Input Capacitance                 | CI     | _     | —      | 2.0           | pF                |
| Skew, REFCLK_4_(P,N)              | —      | -75   | —      | 75            | ps                |
| Jitter (peak-to-peak)             |        |       | —      | 100           | ps <sub>p-p</sub> |

### Timing Diagrams (continued)

#### **Core Clock Input Specifications**

This pertains to signals named REFCLK\_CORE and the supporting PLL voltage pins, AVDD\_PLL\_CORE and AGND\_PLL\_CORE.

#### Table 42. Core Clock Input Specifications

| Parameter                         | Symbol  | Min  | Тур    | Max | Unit          |
|-----------------------------------|---------|------|--------|-----|---------------|
| Maximum Input Voltage             | Vih,max | —    |        | 5.5 | V             |
| Minimum Input Voltage             | VIL,MIN | -0.5 | _      | _   | V             |
| Input High Voltage                | Viн     | 1.3  | 1.55   | 2.0 | V             |
| Input Low Voltage                 | VIL     | 0.8  | 1.20   | 1.5 | V             |
| Input Hysteresis                  | VHYS    | 0.3  | 0.35   | 0.4 | V             |
| Input Frequency                   | FCORE   | —    | 25.000 | _   | MHz           |
| Input Frequency Stability         | _       | -100 | _      | 100 | ppm           |
| Rise Time and Fall Time (20%—80%) | tR, tF  | —    | —      | 1.2 | ns            |
| Jitter (peak-to-peak)             | _       | —    | _      | 100 | <b>рs</b> p-р |

Timing Diagrams (continued)

### SGMII PLL Timing and Clocking Specification

### Table 43. SGMII PLL Timing and Clocking Specification

| Parameter                 | Symbol  | Pin Type | Min  | Тур  | Max | Unit |
|---------------------------|---------|----------|------|------|-----|------|
| Maximum Input Voltage     | VIH,MAX | _        | —    | _    | 5.5 | V    |
| Minimum Input Voltage     | VIL,MIN | —        | -0.5 | _    | _   | V    |
| Input High Voltage        | Vih     | —        | 1.3  | 1.55 | 2.0 | V    |
| Input Low Voltage         | VIL     | —        | 0.8  | 1.20 | 1.5 | V    |
| Input Hysteresis          | VHYS    | —        | 0.3  | 0.35 | 0.4 | V    |
| Clock Duty Cycle          | tDC     | I        | 48   | _    | 5.5 | %    |
| Clock Jitter              | tJCC    | I        | —    | _    | 50  | ps   |
| Input Frequency           | F       | I        | —    | 25   | —   | MHz  |
| Input Frequency Stability | —       | I        | -100 |      | 100 | ppm  |

### Serial Management Interface Timing



Figure 35. Serial Management Interface Timing

### Table 44. Serial Management Interface Timing

| Parameter         | Min | Тур | Мах | Unit |
|-------------------|-----|-----|-----|------|
| MDIO Setup to MDC | 10  | —   | _   | ns   |
| MDIO Hold to MDC  | 10  | —   | _   | ns   |
| MDC to MDIO Delay |     |     | 20  | ns   |

# Timing Diagrams (continued)

### JTAG Timing





### Table 45. JTAG Timing

| Parameter             | Min | Тур | Мах | Unit |
|-----------------------|-----|-----|-----|------|
| TCK Period            | 40  |     |     | ns   |
| TCK High              | 20  | —   | —   | ns   |
| TCK Low               | 20  | —   | —   | ns   |
| TDI, TMS to TCK Setup | 15  | —   | —   | ns   |
| TDI, TMS to TCK Hold  | 15  | —   | —   | ns   |
| TCK to TDO Delay      | 0   | —   | 30  | ns   |

April 2006

# **Physical Dimensions**



| B, B1, C           | 3.22 MAX | 1.08 NOM | 2.46 ± 0.30 |  |  |
|--------------------|----------|----------|-------------|--|--|
| Revision           | DIM "A"  | DIM "B"  | DIM "C"     |  |  |
| THICKNESS SCHEDULE |          |          |             |  |  |

Figure 37. ET4148-50 Physical Dimensions

# Appendix A: Registers

This chapter contains detailed descriptions of all of the registers embodied within the ET4148-50. The register definitions are arranged alphabetically for easy reference.

Each definition consists of a register parameters table, a register diagram, and a field parameters table.

The register parameters table defines the parameters that apply to the registers as a whole. These parameters include such items as a register's base address and size.

The register diagram is a graphical depiction of the layout of the register's fields. Where space permits, the name of the field is inserted into its position in the diagram. Unused bits are represented by gray blocks. These unused areas return zeros when read and are nonreactive to writes.

The field parameters table provides parameters and descriptions for all of the various fields that may make up a particular register.

# **Registers, Records, and Fields**

A hierarchy exists in the arrangement and presentation of fields within a register. Fields are grouped together into records. Records are grouped together into registers. Multiple instances of any field, record, or register may be implemented. When multiple instances do exist, the spacing between the instances is specified. The spacing parameter counts bits from the leftmost bit of one instance to the leftmost bit of the next instance.

Offsets are measured from the beginning of a record. This measurement is depicted in a bytes.bits format. For example, the value 8.3 means 8 bytes and 3 bits.

### **Instance Numbering**

Instance numbering ranges are depicted by a pair of numbers within curly braces, for example: {0..5}. These ranges correspond to instance parameters. For the present example, this range corresponds to an instances parameter of 6.

When multiple range values are present in a field name, it implies that multiple nested instance numbering ranges apply. The hierarchy: register -> record -> field is used. An empty set of braces indicates that the corresponding instance numbering range does not appear in the object's name.

The end result of this numbering method is that the actual names of the objects contain numbers from within the specified ranges and do not include any curly braces.

### **Line Caching**

The records for certain tables are wider than the supervisor's 32-bit data bus, and it is imperative that records be updated in a single operation in order to ensure reliable table operation. Therefore, the ET4148-50 includes an automatic line cache for use with these registers. Proper operation of the line cache depends upon the data being written to a register's wide record in a particular order: from offset zero to the last 32-bit word of the record. When the supervisor performs a write to the last offset of the record, the line cache is automatically written to the desired register record as a single, wide word.

# Appendix A: Registers (continued)

# Acl\_Deny\_Packets

Description: The number of packets denied access by the ACL function.

#### Table 46. Acl\_Deny\_Packets Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2508 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 38. Acl\_Deny\_Packets Diagram

### Table 47. Acl\_Deny\_Packets Field Parameters

| Field Name             | Parameters                                  | Description                                                                                                                                                                                                                                                                                                        |
|------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| acl_deny_packets[27:0] | Mode = R/W<br>Offset = 0.4<br>Instances = 1 | This counter is incremented each time a packet is<br>denied by the ACL function. This counter does not<br>stick at its maximum value, nor is any indication of<br>a rollover provided to the supervisor. Therefore, the<br>supervisor must sample this register often enough<br>to prevent an undetected rollover. |

### Acl\_En

Description: Enables the individual ACLs.

#### Table 48. Acl\_En Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2500 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14  | 15    | 16    | 17  | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|-------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16    | 15    | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | acl | _en   | [63:3 | 82] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ac  | :l_en | [31:  | 0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 39. Acl\_En Register Diagram

#### Table 49. Acl\_En Field Parameters

| Field Name   | Parameters                                  | Description                                                                                                                                                                    |
|--------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| acl_en[63:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 1 | Each bit of this field corresponds to an ACL. An ACL is enabled when its bit is asserted. If an ACL is disabled, it is considered to be empty, and a permit action is implied. |





G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT

### SU = SUPERVISOR

### Figure 40. Port Numbering Scheme

### Acl\_lp\_Addr\_Ace\_Map\_Index\_Table

Description: This table converts an IP address index into an ACE map index.

#### Table 50. Acl\_lp\_Addr\_Ace\_Map\_Index\_Table Register Parameters

| Parameter                  | Value                            |                                     |
|----------------------------|----------------------------------|-------------------------------------|
| Base Address               | 0x0000_0000                      |                                     |
| Register Size              | 131072                           |                                     |
| Register Instances         | 1                                |                                     |
| Register Spacing           | NA                               |                                     |
| Record Size                | 4                                |                                     |
| Record Instances           | 32K                              |                                     |
| Record Spacing             | 4                                |                                     |
|                            |                                  |                                     |
| 0 1 2 3 4 5 6 7 8          | 9 10 11 12 13 14 15 16 17 18 19  | 20 21 22 23 24 25 26 27 28 29 30 31 |
| 31 30 29 28 27 26 25 24 23 | 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0           |
| 0                          |                                  | ip_addr_ace_map_index[9:0]          |

#### Figure 41. Acl\_lp\_Addr\_Ace\_Map\_Index\_Table Register Diagram

#### Table 51. Acl\_lp\_Addr\_Ace\_Map\_Index\_Table Field Parameter

| Field Name                 | Parameters                  | Description              |
|----------------------------|-----------------------------|--------------------------|
| ip_addr_ace_map_index[9:0] | Mode = R/W<br>Offset = 0.22 | The ACE map index value. |

This table is addressed by the concatenation of the acl\_index[5:0] value and the IP address look-up result (ip\_addr\_index[8:0]). Each entry in this table is a 10-bit index into Acl\_Ip\_Addr\_Ace\_Map\_Table.

This table allows the 512 IP addresses appearing in 64 ACLs to address as many as 1,024 ACE maps. The following figure shows where this table fits in the processing pipeline.



Figure 42. ACL Processing Pipeline

### Acl\_lp\_Addr\_Ace\_Map\_Table

Description: This table converts ACE map index values into ACE maps.

#### Table 52. Acl\_lp\_Addr\_Ace\_Map\_Table System Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_c000 |
| Register Size      | 8192        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1K          |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13   | 14   | 15   | 16   | 17    | 18   | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 1 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   | 15   | 14    | 13   | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    | ip_a | ddr_ | ace  | _ma  | p[63  | :32] |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    |    |    |    |    |    |    |    | ip_a | addr | _ace | e_ma | ap[3′ | 1:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 43. Acl\_lp\_Addr\_Ace\_Map\_Table Register Diagram

#### Table 53. Acl\_lp\_Addr\_Ace\_Map\_Table Field Parameters

| Field Name            | Parameters                 | Description        |
|-----------------------|----------------------------|--------------------|
| ip_addr_ace_map[63:0] | Mode = R/W<br>Offset = 0.0 | The ACE map value. |

This table is addressed by Acl\_Ip\_Addr\_Ace\_Map\_Index\_Table.ip\_addr\_ace\_map\_index[9:0] and returns the 64-bit ACE map value for the associated IP address. An ACE map is a vector that identifies all of the ACEs for which the associated IP address generates a match.

The following figure shows where this table fits in the ACL processing pipeline.



Figure 44. ACL Processing Pipeline

### Acl\_lp\_Key\_Table\_0

Description: This table performs the first stage of IP address look-up.

### Table 54. Acl\_lp\_Key\_Table\_0 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_24e0 |
| Register Size      | 16          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|    | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12   | 13   | 14    | 15     | 16     | 17   | 18    | 19   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|-------|--------|--------|------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|
|    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17    | 16     | 15     | 14   | 13    | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |    |    |    |    |    |    |    |    |    |    |    | ip | /4_k | ey_  | 0[31  | :0] o  | or ipv | 6_k  | ey[12 | 27:9 | 6] |    |    |    |    |    |    |    |    |    |    |    |
| 4  |    |    |    |    |    |    |    |    |    |    |    | ip | v4_l | key_ | 1[3′  | 1:0] ( | or ip  | v6_k | ey[9  | 5:64 | 4] |    |    |    |    |    |    |    |    |    |    |    |
| 8  |    |    |    |    |    |    |    |    |    |    |    | ip | v4_l | key_ | _2[3′ | 1:0] ( | or ip  | v6_k | ey[6  | 3:32 | 2] |    |    |    |    |    |    |    |    |    |    |    |
| 12 |    |    |    |    |    |    |    |    |    |    |    |    |      |      | ipv   | 6_ke   | ey[31  | :0]  |       |      |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 45. Acl\_lp\_Key\_Table\_0 Register Diagram

| Field Name          | Parameters                                                   | Description                                                                                                                                                                                                                    |
|---------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key_{02}[31:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 4.0 | A set of 32-bit IPv4 address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |
| ipv6_key[127:0]     | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up.                 |

This first stage of IP address look-up utilizes just a single record. Either three IPv4 address keys or one IPv6 address key is stored here. The comparisons result in an index computation. For IPv4, one of four index values are chosen. For IPv6, one of two index values are chosen. In both cases, these index values are used to address records in the next stage of the look-up.

### Acl\_lp\_Key\_Table\_1

Description: This table performs the second stage of IP address look-up.

#### Table 56. Acl\_lp\_Key\_Table\_1 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2480 |
| Register Size      | 64          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 4           |
| Record Spacing     | 16          |

|    | 0                                   | 1                                    | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|-------------------------------------|--------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | 31                                  | 30                                   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |                                     | ipv4_key_0[31:0] or ipv6_key[127:96] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4  | ipv4_key_1[31:0] or ipv6_key[95:64] |                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 8  |                                     | ipv4_key_2[31:0] or ipv6_key[63:32]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 12 |                                     | ipv6_key[31:0]                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 46. Acl\_lp\_Key\_Table\_1 Register Diagram

### Table 57. Acl\_lp\_Key\_Table\_1 Field Parameters

| Field Name            | Parameters                                                   | Description                                                                                                                                                                                                                    |
|-----------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key_{}{02}[31:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 4.0 | A set of 32-bit IPv4 address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |
| ipv6_key[127:0]       | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up.                 |

This second stage of IP address look-up utilizes two records for IPv4/IPv6 or four records for IPv4-only.

### Acl\_lp\_Key\_Table\_2

Description: This table performs the third stage of IP address look-up.

### Table 58. Acl\_lp\_Key\_Table\_2 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2300 |
| Register Size      | 256         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 16          |
| Record Spacing     | 16          |

#### 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 0 1 2 3 4 5 6 7 0 ipv4\_key\_0[31:0] or ipv6\_key[127:96] ipv4\_key\_1[31:0] or ipv6\_key[95:64] 4 ipv4\_key\_2[31:0] or ipv6\_key[63:32] 8 ipv6\_key[31:0] 12

### Figure 47. Acl\_lp\_Key\_Table\_2 Register Diagram

#### Table 59. Acl\_lp\_Key\_Table\_2 Field Parameters

| Field Name          | Parameters                                                   | Description                                                                                                                                                                                                                    |
|---------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key_{02}[31:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 4.0 | A set of 32-bit IPv4 address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |
| ipv6_key[127:0]     | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up.                 |

This third stage of IP address look-up utilizes four records for IPv4/IPv6 or 16 records for IPv4-only.

### Acl\_lp\_Key\_Table\_3

Description: This table performs the fourth stage of IP address look-up.

### Table 60. Acl\_lp\_Key\_Table\_3 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_1c00 |
| Register Size      | 1024        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 64          |
| Record Spacing     | 16          |



### Figure 48. Acl\_lp\_Key\_Table\_3 Register Diagram

#### Table 61. Acl\_lp\_Key\_Table\_3 Field Parameters

| Field Name          | Parameters                                                   | Description                                                                                                                                                                                                                    |
|---------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key_{02}[31:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 4.0 | A set of 32-bit IPv4 address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |
| ipv6_key[127:0]     | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up.                 |

This fourth stage of IP address look-up utilizes eight records for IPv4/IPv6 or 64 records for IPv4-only.

### Acl\_lp\_Key\_Table\_4

Description: This table performs the fifth stage of IP address look-up.

### Table 62. Acl\_lp\_Key\_Table\_4 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_e000 |
| Register Size      | 4096        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 256         |
| Record Spacing     | 16          |



#### Figure 49. Acl\_lp\_Key\_Table\_4 Register Diagram

#### Table 63. Acl\_lp\_Key\_Table\_4 Field Parameters

| Field Name          | Parameters                                                   | Description                                                                                                                                                                                                                    |
|---------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key_{02}[31:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 4.0 | A set of 32-bit IPv4 address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |
| ipv6_key[127:0]     | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up.                 |

This fifth stage of IP address look-up utilizes 16 records for IPv4/IPv6 or 256 records for IPv4-only.

### Acl\_lp\_Key\_Table\_5

Description: This table performs the sixth stage of IP address look-up.

### Table 64. Acl\_lp\_Key\_Table\_5 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_8000 |
| Register Size      | 16384       |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 1024        |
| Record Spacing     | 16          |

|    | 0                                                      | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12   | 13  | 14    | 15   | 16    | 17  | 18    | 19   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|--------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|------|-----|-------|------|-------|-----|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|
|    | 31                                                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18  | 17    | 16   | 15    | 14  | 13    | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |                                                        |    |    |    |    |    |    |    |    |    |    | ij | ov6_ | key | [127  | :96] | or ip | v4_ | key[3 | 31:0 | ]  |    |    |    |    |    |    |    |    |    |    |    |
| 4  | ipv6_key[95:88] ipv6_key[87:64] or ipv4_result_0[23:0] |    |    |    |    |    |    |    |    |    |    |    |      |     |       |      |       |     |       |      |    |    |    |    |    |    |    |    |    |    |    |    |
| 8  | ipv6_key[63:56] ipv6_key[55:32] or ipv4_result_1[23:0] |    |    |    |    |    |    |    |    |    |    |    |      |     |       |      |       |     |       |      |    |    |    |    |    |    |    |    |    |    |    |    |
| 12 |                                                        |    |    |    |    |    |    |    |    |    |    | ij | ov6_ | key | [31:0 | D]   |       |     |       |      |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 50. Acl\_lp\_Key\_Table\_5 Register Diagram

### Table 65. Acl\_lp\_Key\_Table\_5 Field Parameters

| Field Name             | Parameters                                                   | Description                                                                                                                                                                                                    |
|------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_key[31:0]         | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 32-bit IPv4 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two result<br>values.                                          |
| ipv4_result_{01}[23:0] | Mode = R/W<br>Offset = 4.8<br>Instances = 2<br>Spacing = 4.0 | One of these 24-bit result values is returned as the final result of an IPv4 address look-up.                                                                                                                  |
| ipv6_key[127:0]        | Mode = R/W<br>Offset = 0.0<br>Instances = 1                  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up. |

This sixth stage of IP address look-up marks the end of processing for IPv4 addresses. This stage utilizes 32 records for IPv4/IPv6 or 1,024 records for IPv4-only.

ipv4\_result\_{0..1}[23:0] utilizes the following format:

{ ip\_src\_addr\_index\_{0..1}[8:0], ip\_src\_addr\_flow\_id\_{0..1}[2:0],

 $ip_dest_addr_index_{0..1}[8:0], ip_dest_addr_flow_id_{0..1}[2:0]$ 

### Acl\_lp\_Key\_Table\_6

Description: This table performs the seventh stage of IP address look-up.

### Table 66. Acl\_lp\_Key\_Table\_6 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_1800 |
| Register Size      | 1024        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 64          |
| Record Spacing     | 16          |

|    | 0               | 1                | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|-----------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | 31              | 30               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |                 | ipv6_key[127:96] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4  | ipv6_key[95:64] |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 8  | ipv6_key[63:32] |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 12 |                 | ipv6_key[31:0]   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 51. Acl\_lp\_Key\_Table\_6 Register Diagram

#### Table 67. Acl\_lp\_Key\_Table\_6 Field Parameters

| Field Name      | Parameters                                  | Description                                                                                                                                                                                                    |
|-----------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv6_key[127:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 1 | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two index<br>values for use in the next stage of the look-up. |

This seventh stage of IP address look-up operates only on IPv6 addresses. This stage utilizes 64 records for IPv6.

### Acl\_lp\_Key\_Table\_7

Description: This table performs the eighth stage of IP address look-up.

#### Table 68. Acl\_lp\_Key\_Table\_7 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_0800 |
| Register Size      | 2048        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 128         |
| Record Spacing     | 16          |

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0 ipv6\_key[127:96] 4 ipv6\_key[95:64] 8 ipv6\_key[31:0]

### Figure 52. Acl\_lp\_Key\_Table\_7 Register Diagram

### Table 69. Acl\_lp\_Key\_Table\_7 Field Parameters

| Field Name      | Parameters                                  | Description                                                                                                                                                                                                     |
|-----------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv6_key[127:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 1 | A 128-bit IPv6 address value. This value is<br>compared against the search argument. The<br>result of this comparison is used to select one<br>of two index values for use in the next stage of<br>the look-up. |

This eighth stage of IP address look-up operates only on IPv6 addresses. This stage utilizes 128 records for IPv6.

### Acl\_lp\_Key\_Table\_8

Description: This table performs the ninth and final stage of IP address look-up.

### Table 70. Acl\_lp\_Key\_Table\_8 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_0000 |
| Register Size      | 16384       |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 44          |
| Record Instances   | 256         |
| Record Spacing     | 64          |

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|            | 31 30 29 28 27 26 25 24                            | 23 22 21 20 19 18 17 16 15 | 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |  |  |  |  |
|------------|----------------------------------------------------|----------------------------|------------------------------------|--|--|--|--|--|--|--|--|--|--|
| 0          |                                                    | ipv6_key_0[127:96]         |                                    |  |  |  |  |  |  |  |  |  |  |
| 4          |                                                    | ipv6_key_0[95:64]          |                                    |  |  |  |  |  |  |  |  |  |  |
| 8          | ipv6_key_0[63:32]                                  |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 2          | ipv6_key_0[31:0]                                   |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 6          | ipv6_key_1[127:96]                                 |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 20         | ipv6_key_1[95:64]                                  |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| <u>2</u> 4 | ipv6_key_1[63:32]                                  |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 28         | ipv6_key_1[31:0]                                   |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 32         | ip_src_addr_index_0[8:0] ip_dest_addr_index_0[8:0] |                            |                                    |  |  |  |  |  |  |  |  |  |  |
| 36         |                                                    | ip_src_addr_index_1[8:0]   | ip_dest_addr_index_1[8:0]          |  |  |  |  |  |  |  |  |  |  |
| 10         |                                                    | ip_src_addr_index_2[8:0]   | ip_dest_addr_index_2[8:0]          |  |  |  |  |  |  |  |  |  |  |

Figure 53. Acl\_lp\_Key\_Table\_8 Register Diagram

### Acl\_lp\_Key\_Table\_8 (continued)

### Table 71. Acl\_lp\_Key\_Table\_8 Field Parameters

| Field Name                   | Parameters                                                     | Description                                                                                                                                                                                                        |
|------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv6_key_{01}[127:0]         | Mode = R/W<br>Offset = 0.0<br>Instances = 2<br>Spacing = 16.0  | A 128-bit IPv6 address value. This value is com-<br>pared against the search argument. The result of<br>this comparison is used to select one of two<br>index values for use in the next stage of the look-<br>up. |
| ip_src_addr_index_{02}[8:0]  | Mode = R/W<br>Offset = 32.8<br>Instances = 3<br>Spacing = 4.0  | This value is used in conjunction with the ACL index to select one of 1,024 ACE maps for the corresponding IP source address.                                                                                      |
| ip_src_flow_id_{02}[2:0]     | Mode = R/W<br>Offset = 32.17<br>Instances = 3<br>Spacing = 4.0 | This field identifies a flow associated with the matching IP source address.                                                                                                                                       |
| ip_dest_addr_index_{02}[8:0] | Mode = R/W<br>Offset = 32.20<br>Instances = 3<br>Spacing = 4.0 | This value is used in conjunction with the ACL index to select one of 1,024 ACE maps for the corresponding IP destination address.                                                                                 |
| ip_dest_flow_id_{02}[2:0]    | Mode = R/W<br>Offset = 32.29<br>Instances = 3<br>Spacing = 4.0 | This field identifies a flow associated with the matching IP destination address.                                                                                                                                  |

This final stage of IP address look-up operates only on IPv6 addresses. This stage utilizes 256 records of two IPv6 addresses each. Each record contains three possible sets of result values.

### Acl\_Mode

Description: Global operating modes for the ACL look-up function.

### Table 72. Acl\_Mode Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|--|--|
| Base Address       | 0x0004_24f8 |  |  |  |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |  |  |



### Figure 54. Acl\_Mode Register Diagram

#### Table 73. Acl\_Mode Register Field Parameters

| Field Name       | Parameters                                                | Description                                                                                                                                                                                                                                 |
|------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ipv4_only        | Mode = R/W<br>Offset = 0.29<br>Instances = 1<br>Reset = 0 | When asserted, this bit implies that only 32-bit IPv4<br>address values may be accommodated by the IP<br>address tables. When deasserted, a mix of 128-bit<br>IPv6 and zero-prefixed, right-justified 32-bit IPv4<br>addresses may be used. |
|                  |                                                           | The IPv4-only table capacity is 512 addresses. For<br>a mix of IPv4 and IPv6 addresses, that capacity<br>drops to 128.                                                                                                                      |
| port_based_acls  | Mode = R/W<br>Offset = 0.30<br>Instances = 1<br>Reset = 0 | This bit is asserted to direct the system to use a packet's receive port to identify its ACL. If this bit is deasserted, then the receive packet's VLAN index is used instead.                                                              |
|                  |                                                           | Note: The maximum number of VLANs supported is 256 yet the maximum number of ACLs is 50.<br>Acl_Vlan_Index_Table is used to map VLAN indexes to ACL numbers.                                                                                |
| auto_deny_log_en | Mode = R/W<br>Offset = 0.31<br>Instances = 1<br>Reset = 0 | If a packet is denied access because a matching<br>ACE was not found, then the packet is logged if this<br>bit is asserted. If deasserted, then a packet that fails<br>to match any ACE is simply discarded.                                |

This register provides a series of general configuration and mode bits for the ACL look-up function.

### Acl\_Port\_Ace\_Map\_Index\_Table

Description: This table converts a port number range index into an ACE map index.

#### Table 74. Acl\_Port\_Ace\_Map\_Index\_Table Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|--|--|--|
| Base Address       | 0x0002_0000 |  |  |  |  |  |  |  |  |  |
| Register Size      | 65536       |  |  |  |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |  |  |  |
| Record Instances   | 16384       |  |  |  |  |  |  |  |  |  |
| Record Spacing     | 4           |  |  |  |  |  |  |  |  |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24   | 25   | 26    | 27   | 28   | 29    | 30    | 31    |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|-------|------|------|-------|-------|-------|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6    | 5     | 4    | 3    | 2     | 1     | 0     |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | prot | ocol | _port | _ace | e_ma | ap_ir | ndex[ | [7:0] |

### Figure 55. Acl\_Port\_Ace\_Map\_Index\_Table Register Diagram

#### Table 75. Acl\_Port\_Ace\_Map\_Index\_Table Field Parameters

| Field Name                       | Parameters                  | Description              |
|----------------------------------|-----------------------------|--------------------------|
| protocol_port_ace_map_index[7:0] | Mode = R/W<br>Offset = 0.24 | The ACE map index value. |

This table is addressed by the concatenation of the acl\_index[5:0] value and the TCP port look-up result (tcp\_src\_port\_index[7:0] or tcp\_dest\_port\_index[7:0]). Each entry in this table is an 8-bit index into Acl\_Protocol\_Port\_Ace\_Map\_Table.

This table allows the 256 TCP port ranges appearing in 64 ACLs to address as many as 256 ACE maps. The following figure shows where this table fits in the processing pipeline.



Figure 56. ACL Processing Pipeline

### Acl\_Port\_Ace\_Map\_Table

Description: This table converts ACE map index values derived from TCP port indexes into ACE maps.

|     |      | F              | Para | me   | ete | er |    |    |    |      |     |      | V     | alue | •   |    |    |    | ]  |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
|-----|------|----------------|------|------|-----|----|----|----|----|------|-----|------|-------|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|
| Bas | e A  | dd             | ress | 3    |     |    |    |    |    |      |     | 0x   | 000   | )4_( | 000 | 0  |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Reg | iste | er S           | Size |      |     |    |    |    |    | 2048 |     |      |       |      |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Reg | iste | er I           | nsta | inc  | es  | S  |    |    |    |      |     |      |       | 1    |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Reg | iste | er S           | Spac | cing | g   |    |    |    |    |      |     |      |       | NA   |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Rec | ord  | S              | ze   |      |     |    |    |    |    |      |     |      |       | 8    |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Rec | ord  | In             | star | nce  | s   |    |    |    |    |      |     |      | 2     | 256  |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| Rec | ord  | S              | oaci | ng   |     |    |    |    |    |      |     |      |       | 8    |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
|     | 0    | 1              | 2    | 3    |     | 4  | 5  | 6  | 7  | 8    | 9   | 10   | 11    | 12   | 13  | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 5   | 26 | 27 | 28 | 29 | 30 | 31 |
|     | 31   | 30             | ) 29 | 2    | 8   | 27 | 26 | 25 | 24 | 23   | 22  | 21   | 20    | 19   | 18  | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | i _ | 5  | 4  | 3  | 2  | 1  | 0  |
| 0   |      | protocol_ace_m |      |      |     |    |    |    |    |      | _ma | p[63 | 3:32] |      |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |
| 4   |      | protocol_ace_n |      |      |     |    |    |    |    |      |     | e_m  | ap[3  | 1:0] |     |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |

### Figure 57. Acl\_Port\_Ace\_Map\_Table Register Diagram

| Field Name             | Parameters                 | Description        |
|------------------------|----------------------------|--------------------|
| protocol_ace_map[63:0] | Mode = R/W<br>Offset = 0.0 | The ACE map value. |

This table is addressed by Acl\_Port\_Ace\_Map\_Index\_Table.port\_ace\_map\_index[7:0] and returns the 64-bit ACE map value for the associated TCP port. An ACE map is a vector that identifies all of the ACEs for which the associated TCP port number range registers a match.

The following figure shows where this table fits in the ACL processing pipeline.



Figure 58. ACL Processing Pipeline

### Acl\_Priority\_Update\_En

Description: Per-port priority update enables.

#### Table 78. Acl\_Priority\_Update\_En Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2510 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 59. Acl\_Priority\_Update\_En Register Diagram

### Table 79. Acl\_Priority\_Update\_En Field Parameters

| Field Name               | Parameters                                               | Description                                                                                                                                                                                                                                                                           |
|--------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| priority_update_en[60:0] | Mode = R/W<br>Offset = 0.3<br>Instances = 1<br>Reset = 0 | When a bit is asserted in this field, the ACL function is enabled to replace the packet's parser-derived priority value with one that is determined by ACL classification. Bit 0 through 47 correspond to the 1 Gbit/s ports while bits 50 and 60 correspond to the 10 Gbits/s ports. |

This register provides a per-port method for enabling the classification-based replacement of packet priority values.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPEVISOR

#### Figure 60. Port Numbering Scheme

### Acl\_Protocol\_Ace\_Map\_Index\_Table

Description: This table converts a protocol index into an ACE map index.

#### Table 80. Acl\_Protocol\_Ace\_Map\_Index\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2800 |
| Register Size      | 2048        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 512         |
| Record Spacing     | 4           |

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 protocol\_ace\_map\_index[6:0]

#### Figure 61. Acl\_Protocol\_Ace\_Map\_Index\_Table Register Diagram

#### Table 81. Acl\_Protocol\_Ace\_Map\_Index\_Table Field Parameters

| Field Name                  | Parameters                  | Description              |
|-----------------------------|-----------------------------|--------------------------|
| protocol_ace_map_index[6:0] | Mode = R/W<br>Offset = 0.24 | The ACE map index value. |

This table is addressed by the concatenation of the acl\_index[5:0] value and a protocol index value (acl\_protocol\_index[2:0]). Each entry in this table is a 7-bit index into Acl\_Protocol\_Port\_Ace\_Map\_Table.

This table allows the eight protocol indexes appearing in 64 ACLs to address as many as 256 ACE maps. The following figure shows where this table fits in the processing pipeline.



Figure 62. ACL Processing Pipeline

### Acl\_Protocol\_Ace\_Map\_Table

Description: This table converts ACE map index values derived from protocol indexes into ACE maps.

#### Table 82. Acl\_Protocol\_Ace\_Map\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_1400 |
| Register Size      | 1024        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 128         |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3               | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13   | 14   | 15   | 16  | 17   | 18   | 19              | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|-----------------|----|----|----|----|----|----|----|----|----|------|------|------|-----|------|------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 <sub> </sub> | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   | 15  | 14   | 13   | 12 <sub> </sub> | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |                 |    |    |    |    |    |    |    |    | pr | iori | ty_a | ace_ | _ma | p[6  | 3:32 | 2]              |    |    |    |    |    |    |    |    |    |    |    |    |
| 4 |    |    |    |                 |    |    |    |    |    |    |    |    | р  | rior | ity_ | ace  | _ma | ap[3 | 31:0 | ]               |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 63. Acl\_Protocol\_Ace\_Map\_Table Register Diagram

| Field Name             | Parameters                 | Description        |
|------------------------|----------------------------|--------------------|
| priority_ace_map[63:0] | Mode = R/W<br>Offset = 0.0 | The ACE map value. |

This table is addressed by Acl\_Protocol\_Ace\_Map\_Index\_Table.protocol\_ace\_map\_index[6:0] and returns the 64-bit ACE map value for the associated packet protocol. An ACE map is a vector that identifies all of the ACEs for which the associated protocol registers a match.

The following figure shows where this table fits in the ACL processing pipeline.



Figure 64. ACL Processing Pipeline

### Acl\_Protocol\_Table

Description: This table encodes a packet's Ethertype and IP protocol indexes into a compact protocol index.

### Table 84. Acl\_Protocol\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2200 |
| Register Size      | 256         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 64          |
| Record Spacing     | 4           |



### Figure 65. Acl\_Protocol\_Table Register Diagram

#### Table 85. Acl\_Protocol\_Table Field Parameters

| Field Name        | Parameters                                   | Description                                                                             |
|-------------------|----------------------------------------------|-----------------------------------------------------------------------------------------|
| acl_protocol[2:0] | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | An index value that is representative of the packet's Ethertype and IP protocol values. |

This table is addressed by a concatenation of ethertype\_index[2:0] (derived from the packet's Layer 2 type field) and ip\_protocol\_index[2:0] (derived from the packet's Layer 3 protocol field).

ethertype\_index[2:0] makes up the most significant portion of the table's address. This 6-bit concatenation is shifted left two bits in order to address 32-bit words.

### Table 86. ethertype\_index[2:0] and ip\_protocol\_index[2:0] Defined

| ethertype_index[2:0] | Ethertype   | protocol_index[2:0] | Protocol        |
|----------------------|-------------|---------------------|-----------------|
| 0                    | IPv4        | 0                   | ICMP            |
| 1                    | IPv6        | 1                   | IGMP            |
| 2                    | ARP         | 2                   | TCP             |
| 3                    | RARP        | 3                   | UDP             |
| 4                    | user_type_0 | 4                   | user_protocol_0 |
| 5                    | user_type_1 | 5                   | user_protocol_1 |
| 6                    | user_type_2 | 6                   | user_protocol_2 |
| 7                    | unknown     | 7                   | unknown         |

### Acl\_Result\_Table

Description: This register returns a priority adjustment command based on the ACL number and ACE number.

| Table 87. | Acl | Result | Table | Register   | Parameters |
|-----------|-----|--------|-------|------------|------------|
| 14010 011 |     |        |       | i togiotoi |            |

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_4000 |
| Register Size      | 16384       |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 4096        |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20              | 21 | 22 | 23 | 24 | 25 | 26 | 27   | 28    | 29    | 30  | 31    |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|------|-------|-------|-----|-------|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 <sub> </sub> | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2     | 1   | 0     |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |    |    |    |    |    | acl_ | prior | ity_c | ode | [4:0] |

### Figure 66. Acl\_Result\_Table Register Diagram

| Table 88. Acl_Res | ult_Table Field | Parameters |
|-------------------|-----------------|------------|
|-------------------|-----------------|------------|

| Field Name             | Parameters                                   | Description                                                                                                                                         |
|------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| acl_permit             | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | When asserted, the packet is permitted access to<br>the switching system. Otherwise, the denial mask is<br>applied to the packet's destination map. |
| acl_log                | Mode = R/W<br>Offset = 0.26<br>Instances = 1 | When asserted, the supervisor's ACL logging port<br>is added to the packet's destination map. Logging<br>and packet denial are independent.         |
| acl_priority_code[4:0] | Mode = R/W<br>Offset = 0.27<br>Instances = 1 | The ACL priority opcode and priority value.                                                                                                         |

acl\_priority\_code[4] defines the action taken by the ACL function. These functions are defined below:

0 = preserve packet's priority value

1 = replace packet's priority value with acl\_priority\_code[3:0]

This table is addressed by a concatenation of acl\_index[5:0] (that identifies a particular ACL) and ace\_index[5:0] (that identifies a particular ACE). acl\_index[5:0] occupies the upper portion of the concatenated address word.

ace\_index[5:0] is an internal value (not accessible to the supervisor) that is derived from the priority encoding of the bitwise **and** of all of the ACE maps retrieved for a particular packet, hence, identifying the matching ACE.

### Acl\_Tcp\_Key\_Table\_0

Description: This table performs the first stage of TCP port number look-up.

### Table 89. Acl\_Tcp\_Key\_Table\_0 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_24f0 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6    | 7    | 8    | 9    | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22   | 23   | 24   | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|------|------|------|------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   | 23   | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7    | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    | t  | cp_k | key_ | 0_0[ | 15:0 | ]  |    |    |    |    |    |    |    |    |    |    | t  | cp_ł | key_ | 0_1[ | 15:0 | ]  |    |    |    |    |    |
| 4 |    |    |    |    |    | t  | cp_k | key_ | 0_2[ | 15:0 | ]  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |    |    |    |    |    |    |

### Figure 67. Acl\_Tcp\_Key\_Table\_0 Register Diagram

### Table 90. Acl\_Tcp\_Key\_Table\_0 Field Parameters

| Field Name           | Parameters                                                   | Description                                                                                                                                                                                                              |
|----------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcp_key_0_{02}[15:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 2.0 | A set of 16-bit TCP port number values. These values are compared against the search argument.<br>The results of these comparisons are used to select one of four index values for use in the next stage of the look-up. |

This first stage of TCP port number look-up utilizes just a single record. Three TCP port number keys are stored here. The comparisons between the search argument and the keys result in a selection of one of four index values. These index values are used to address records in the next stage of the look-up.

### Acl\_Tcp\_Key\_Table\_1

Description: This table performs the second stage of TCP port number look-up.

### Table 91. Acl\_Tcp\_Key\_Table\_1 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_24c0 |
| Register Size      | 32          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 4           |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5    | 6   | 7    | 8   | 9    | 10   | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21   | 22  | 23   | 24  | 25   | 26   | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|------|-----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|------|-----|------|-----|------|------|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26   | 25  | 24   | 23  | 22   | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8    | 7   | 6    | 5    | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    | tcp_ | key | _1_{ | 03} | _0[1 | 5:0] |    |    |    |    |    |    |    |    |    |    | tcp_ | key | _1_{ | 03} | _1[1 | 5:0] |    |    |    |    |    |
| 4 |    |    |    |    |    | tcp_ | key | _1_{ | 03} | _2[1 | 5:0] |    |    |    |    |    |    |    |    |    |    |      |     |      |     |      |      |    |    |    |    |    |

### Figure 68. Acl\_Tcp\_Key\_Table\_1 Register Diagram

### Table 92. Acl\_Tcp\_Key\_Table\_1 Field Parameters

| Field Name               | Parameters                                                   | Description                                                                                                                                                                                                              |
|--------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcp_key_1_{03}{02}[15:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 2.0 | A set of 16-bit TCP port number values. These values are compared against the search argument.<br>The results of these comparisons are used to select one of four index values for use in the next stage of the look-up. |

This second stage of TCP port number look-up utilizes four records. Three TCP port number keys are stored in each record. The comparisons between the search argument and the keys result in a selection of one of four index values. These index values are used to address records in the next stage of the look-up.

### Acl\_Tcp\_Key\_Table\_2

Description: This table performs the third stage of TCP port number look-up.

### Table 93. Acl\_Tcp\_Key\_Table\_2 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_3000 |
| Register Size      | 128         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 16          |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6    | 7   | 8    | 9    | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22   | 23  | 24   | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24  | 23   | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8   | 7    | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    | tcp_ | key | _0[1 | 5:0] |    |    |    |    |    |    |    |    |    |    |    |    | tcp_ | key | _1[1 | 5:0] |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    | tcp_ | key | _2[1 | 5:0] |    |    |    |    |    |    |    |    |    |    |    |    |      |     |      |      |    |    |    |    |    |    |

### Figure 69. Acl\_Tcp\_Key\_Table\_2 Register Diagram

### Table 94. Acl\_Tcp\_Key\_Table\_2 Field Parameters

| Field Name         | Parameters                                                   | Description                                                                                                                                                                                                              |
|--------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcp_key_{02}[15:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 2.0 | A set of 16-bit TCP port number values. These values are compared against the search argument.<br>The results of these comparisons are used to select one of four index values for use in the next stage of the look-up. |

This third stage of TCP port number look-up utilizes 16 records. Three TCP port number keys are stored in each record. The comparisons between the search argument and the keys result in a selection of one of four index values. These index values are used to address records in the next stage of the look-up.

### Acl\_Tcp\_Key\_Table\_3

Description: This table performs the fourth stage of TCP port number look-up.

### Table 95. Acl\_Tcp\_Key\_Table\_3 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_2000 |
| Register Size      | 512         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 64          |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6    | 7   | 8    | 9    | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22   | 23   | 24   | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|------|-----|------|------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24  | 23   | 22   | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7    | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    | tcp_ | key | _0[1 | 5:0] |    |    |    |    |    |    |    |    |    |    |    |    | tcp_ | _key | _1[1 | 5:0] |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    | tcp_ | key | _2[1 | 5:0] |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |    |    |    |    |    |    |

### Figure 70. Acl\_Tcp\_Key\_Table\_3 Register Diagram

### Table 96. Acl\_Tcp\_Key\_Table\_3 Field Parameters

| Field Name         | Parameters                                                   | Description                                                                                                                                                                                                              |
|--------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcp_key_{02}[15:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 3<br>Spacing = 2.0 | A set of 16-bit TCP port number values. These values are compared against the search argument.<br>The results of these comparisons are used to select one of four index values for use in the next stage of the look-up. |

This fourth stage of TCP port number look-up utilizes 64 records. Three TCP port number keys are stored in each record. The comparisons between the search argument and the keys result in a selection of one of four index values. These index values are used to address records in the next stage of the look-up.

### Acl\_Tcp\_Key\_Table\_4

Description: This table performs the fifth and final stage of TCP port number look-up.

Table 97. Acl\_Tcp\_Key\_Table\_4 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0003_f000 |
| Register Size      | 4096        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 12          |
| Record Instances   | 256         |
| Record Spacing     | 16          |

#### 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

|   | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8                      | 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |
|---|-------------------------|-------------------------|--------------------------------------------|-----------------|--|--|--|--|--|--|
| 0 | tcp_key                 | _0[15:0]                | tcp_key_1[15:0]                            |                 |  |  |  |  |  |  |
| 4 | tcp_src_result_0[7:0]   | tcp_dest_result_0[7:0]  | tcp_src_result_1[7:0] tcp_dest_result_1[7: |                 |  |  |  |  |  |  |
| 8 | tcp_src_result_2[7:0]   | tcp_dest_result_2[7:0]  |                                            |                 |  |  |  |  |  |  |

### Figure 71. Acl\_Tcp\_Key\_Table\_4 Register Diagram

#### Table 98. Acl\_Tcp\_Key\_Table\_4 Field Parameters

| Field Name                | Parameters                                                   | Description                                                                                                                                                                                                              |
|---------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tcp_key_{01}[15:0]        | Mode = R/W<br>Offset = 0.0<br>Instances = 2<br>Spacing = 2.0 | A set of 16-bit TCP port number values. These values are compared against the search argument.<br>The results of these comparisons are used to select one of four index values for use in the next stage of the look-up. |
| tcp_src_result_{03}[7:0]  | Mode = R/W<br>Offset = 4.0<br>Instances = 3<br>Spacing = 2.0 | These 8-bit result values are returned as the final output from the look-up process. These results correspond to source port look-ups.                                                                                   |
| tcp_dest_result_{03}[7:0] | Mode = R/W<br>Offset = 4.8<br>Instances = 3<br>Spacing = 2.0 | These 8-bit result values are returned as the final output from the look-up process. These results correspond to destination port look-ups.                                                                              |

This fifth and final stage of TCP port number look-up utilizes 256 records. Two TCP port number keys are stored in each record. The comparisons between the search argument and the keys result in a selection of one of three result values. These are returned as the final output of the look-up process.

### Acl\_Vlan\_Index\_Table

Description: This table is used to map the 8-bit VLAN index to one of 64 ACL numbers.

#### Table 99. Acl\_Vlan\_Index\_Table Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x0004_1000 |  |  |  |  |  |
| Register Size      | 1024        |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |
| Record Instances   | 256         |  |  |  |  |  |
| Record Spacing     | 4           |  |  |  |  |  |



#### Figure 72. Acl\_Vlan\_Index\_Table Register Diagram

#### Table 100. Acl\_Vlan\_Index\_Table Field Parameters

| Field Name     | Parameters                                   | Description           |
|----------------|----------------------------------------------|-----------------------|
| acl_index[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1 | The ACL index number. |

The 8-bit VLAN index assigned to the receive packet is used as an address into this table. The addressed value is used as the ACL index for the packet. Essentially, this table provides a 256 to 64 mapping function.

### **Device\_Version**

Description: This register returns version number for the device.

#### Table 101. Device\_Version Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x000c_8320 |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |



#### Figure 73. Device\_Version Register Diagram

#### Table 102. Device\_Version Field Parameters

| Field Name           | Parameters                                  | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| major_revision[11:0] | Mode = RO<br>Offset = 0.4<br>Instances = 1  | The device's major revision number. The major revision number<br>reflects the iteration from one all-layer spin to the next. This field<br>returns a value in a binary-coded decimal form (each decimal digit<br>occupies a 4-bit space). In binary-coded format, the value of this<br>field for the various versions is:<br>Revision B: 002<br>Revision B1: 002<br>Revision C: 003           |
| minor_revision[15:0] | Mode = RO<br>Offset = 0.16<br>Instances = 1 | The device's minor revision number. The minor revision number<br>reflects the iteration from one metal layer-only spin to the next. This<br>field returns a value in a binary-coded decimal form (each decimal<br>digit occupies a 4-bit space). In binary-coded format, the value of<br>this field for the various versions is:<br>Revision B: 0000<br>Revision B1: 0001<br>Revision C: 0000 |

### Layer\_2\_Active\_Port\_Map

Defines which ports are enabled for the normal forwarding of traffic.

#### Table 103. Layer\_2\_Active\_Port\_Map Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4620 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 74. Layer\_2\_Active\_Port\_Map Register Diagram

### Table 104. Layer\_2\_Active\_Port\_Map Field Parameters

| Field Name            | Parameters                                  | Description                                                                                                       |
|-----------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| active_port_map[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The active port map value. Each bit in the map corresponds to an Ethernet port or one of the supervisor's queues. |

This field is used to identify those ports that are enabled to forward Ethernet traffic in a normal manner. This information is used in determining whether or not a packet has been prevented from being forwarded due to VLAN mismatches.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 75. Port Numbering Scheme

### Layer\_2\_Aggregation\_Mask\_Table

Description: Enables the selection of a port from within an aggregate of ports.

### Table 105. Layer\_2\_Aggregation\_Mask\_Table Register Parameters

| Parameter                     | Value                         |                                       |
|-------------------------------|-------------------------------|---------------------------------------|
| Base Address                  | 0x000c_4480                   |                                       |
| Register Size                 | 64                            |                                       |
| Register Instances            | 1                             |                                       |
| Register Spacing              | NA                            |                                       |
| Record Size                   | 8                             |                                       |
| Record Instances              | 8                             |                                       |
| Record Spacing                | 8                             |                                       |
|                               |                               |                                       |
| 0 1 2 3 4 5 6 7 8 9           | 10 11 12 13 14 15 16 17 18 19 | 9 20 21 22 23 24 25 26 27 28 29 30 31 |
| 31 30 29 28 27 26 25 24 23 22 | 21 20 19 18 17 16 15 14 13 12 | 2 11 10 9 8 7 6 5 4 3 2 1 0           |
| 0                             | aggregation_m                 | ask[57:32]                            |
| 4                             | aggregation_mask[31:0]        |                                       |

### Figure 76. Layer\_2\_Aggregation\_Mask\_Table Register Diagram

#### Table 106. Layer\_2\_Aggregation\_Mask\_Table Field Parameters

| Field Name             | Parameters                                  | Description                                                                                                         |
|------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| aggregation_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The aggregation mask value. Each bit in the mask corresponds to an Ethernet port or one of the supervisor's queues. |

Through a series of addition reductions, the receive packet's MAC destination and MAC source addresses are reduced to a 3-bit index. Any particular combination of MAC address values always reduces to the same 3-bit index. This index is used to select one of eight mask values from this table.

When the look-up on a packet's destination address indicates that its destination port is part of an aggregation of ports, then all of the ports in that aggregate are enabled by the initial destination map. The mask value retrieved from this table is used to select one of the ports from within the aggregate.

This set of eight aggregate masks is shared among all of the aggregates configured in the system.

| PORT      | SU7 | SU6 | SU1    | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | G3 | G2 | G1 | G0 |
|-----------|-----|-----|--------|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|
| REFERENCE | 57  | 56  | <br>51 | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3  | 2  | 1  | 0  |

PORT NUMBERING SCHEME

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT

#### Figure 77. Port Numbering Scheme

SU = SUPERVISOR

### Layer\_2\_Blocking\_Mask

Description: Disables those ports that should not receive packets when a receive port is in blocking mode.

#### Table 107. Layer\_2\_Blocking\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4628 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 78. Layer\_2\_Blocking\_Mask Register Diagram

#### Table 108. Layer\_2\_Blocking\_Mask Field Parameters

| Field Name          | Parameters                                  | Description                                                                                                      |
|---------------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| blocking_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The blocking mask value. Each bit in the mask corresponds to an Ethernet port or one of the supervisor's queues. |

This mask is applied to the destination port map if the packet's source port or VLAN is in the blocking state according to spanning tree rules. Bits asserted in blocking\_mask[57:0] have the effect of disabling the corresponding destinations.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 79. Port Numbering Scheme

### Layer\_2\_Current\_Time

Description: The time value used for MAC source address time stamp updates.

#### Table 109. Layer\_2\_Current\_Time Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4660 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28   | 29    | 30   | 31     |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|------|--------|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2     | 1    | 0      |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | curi | rent_ | time | e[3:0] |

### Figure 80. Layer\_2\_Current\_Time Register Diagram

#### Table 110. Layer\_2\_Current\_Time Field Parameters

| Field Name        | Parameters                                   | Description                     |
|-------------------|----------------------------------------------|---------------------------------|
| current_time[3:0] | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | The current time stamp setting. |

When a known source address is received, its timestamp is updated in Layer\_2\_Time\_Stamp\_Table. The value written to that table is Layer\_2\_Current\_Time.current\_time[3:0].

### Layer\_2\_Dest\_Map\_Table

Description: The table of initial destination port maps.

#### Table 111. Layer\_2\_Dest\_Map\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_2000 |
| Register Size      | 4096        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 512         |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14  | 15   | 16   | 17   | 18  | 19   | 20    | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|------|-----|------|-------|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   | 15   | 14   | 13  | 12   | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |      | dest | _ma | p[57 | 7:32] |    |    |    |    |    |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | des | t_ma | ap[3 | 1:0] |     |      |       |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 81. Layer\_2\_Dest\_Map\_Table Register Diagram

#### Table 112. Layer\_2\_Dest\_Map\_Table Field Parameters

| Field Name     | Parameters                                  | Description                       |
|----------------|---------------------------------------------|-----------------------------------|
| dest_map[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The initial destination port map. |

This table is addressed by the layer\_2\_dest\_map\_index[8:0] value returned as part of the associated data from the destination MAC address look-up. The value retrieved from this table is a destination port map. Bits are asserted in these map values to indicate destinations for the packet. This initial port map is adjusted through several steps of masking (eliminating destinations) and mapping (adding destinations).

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 82. Port Numbering Scheme

### Layer\_2\_Dest\_Mirror\_Map

Description: A map of the destination ports configured to be mirrored.

#### Table 113. Layer\_2\_Dest\_Mirror\_Map Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4630 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 83. Layer\_2\_Dest\_Mirror\_Map Register Diagram

#### Table 114. Layer\_2\_Dest\_Mirror\_Map Field Parameters

| Field Name            | Parameters                                               | Description                         |
|-----------------------|----------------------------------------------------------|-------------------------------------|
| dest_mirror_map[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The destination mirroring port map. |

If a packet is being forwarded to a port that corresponds to a bit asserted in dest\_mirror\_map[57:0], then that packet is copied to the system's mirror port.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 84. Port Numbering Scheme

### Layer\_2\_Flood\_Map

Description: Identifies the ports to which unknown destination packets are flooded.

#### Table 115. Layer\_2\_Flood\_Map Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4638 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 85. Layer\_2\_Flood\_Map Register Diagram

#### Table 116. Layer\_2\_Flood\_Map Field Parameters

| Field Name      | Parameters                                               | Description    |
|-----------------|----------------------------------------------------------|----------------|
| flood_map[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The flood map. |

When a receive packet's destination address is not found in the Layer 2 address table, this flood map is used as the initial destination map.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 86. Port Numbering Scheme

### Layer\_2\_Global\_Mask

Description: Disables destination ports.

| Table 117. Layer_2_Global | _Mask Register Parameters |
|---------------------------|---------------------------|
|---------------------------|---------------------------|

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4640 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 87. Layer\_2\_Global\_Mask Register Diagram

#### Table 118. Layer\_2\_Global\_Mask Field Parameters

| Field Name        | Parameters                                               | Description                  |
|-------------------|----------------------------------------------------------|------------------------------|
| global_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The global destination mask. |

Setting a bit in this register disables packets from being forwarded to the corresponding port. Supervisor transmissions are not affected by Layer\_2\_Global\_Mask.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 88. Port Numbering Scheme

### Layer\_2\_lgmp\_Snooping\_Port

Description: Identifies the port to be used for IGMP snooping.

#### Table 119. Layer\_2\_Igmp\_Snooping\_Port Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4664 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |





#### Table 120. Layer\_2\_Igmp\_Snooping\_Port Field Parameters

| Field Name              | Parameters                                                | Description                             |
|-------------------------|-----------------------------------------------------------|-----------------------------------------|
| igmp_snooping_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The port number used for IGMP snooping. |

When so enabled, IGMP packets are copied to the port number specified here.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 90. Port Numbering Scheme

### Layer\_2\_Key\_Table\_0

Description: The first stage of a MAC address look-up is performed by this table.

### Table 121. Layer\_2\_Key\_Table\_0 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4600 |
| Register Size      | 24          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 24          |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 91. Layer\_2\_Key\_Table\_0 Register Diagram

### Table 122. Layer\_2\_Key\_Table\_0 Field Parameters

| Field Name             | Parameters                                                    | Description                                                                                                                                                                                                                     |
|------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These<br>values are compared against the search argu-<br>ment. The results of these comparisons are<br>used to select one of four index values for use<br>in the next stage of the look-up. |

This first stage of a MAC address look-up involves the use of a single record containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_1

Description: The second stage of a MAC address look-up is performed by this table.

#### Table 123. Layer\_2\_Key\_Table\_1 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4400 |
| Register Size      | 128         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 24          |
| Record Instances   | 4           |
| Record Spacing     | 32          |



#### Figure 92. Layer\_2\_Key\_Table\_1 Register Diagram

#### Table 124. Layer\_2\_Key\_Table\_1 Field Parameters

| Field Name               | Parameters                                                    | Description                                                                                                                                                                                                                   |
|--------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{}{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |

This second stage of a MAC address look-up involves the use of four records, each containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_2

Description: The third stage of a MAC address look-up is performed by this table.

### Table 125. Layer\_2\_Key\_Table\_2 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4000 |
| Register Size      | 512         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 24          |
| Record Instances   | 16          |
| Record Spacing     | 32          |



### Figure 93. Layer\_2\_Key\_Table\_2 Register Diagram

### Table 126. Layer\_2\_Key\_Table\_2 Field Parameters

| Field Name             | Parameters                                                    | Description                                                                                                                                                                                                                   |
|------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |

This third stage of a MAC address look-up involves the use of 16 records, each containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_3

Description: The fourth stage of a MAC address look-up is performed by this table.

### Table 127. Layer\_2\_Key\_Table\_3 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_3000 |
| Register Size      | 2048        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 32          |
| Record Instances   | 64          |
| Record Spacing     | 32          |



### Figure 94. Layer\_2\_Key\_Table\_3 Register Diagram

### Table 128. Layer\_2\_Key\_Table\_3 Field Parameters

| Field Name             | Parameters                                                    | Description                                                                                                                                                                                                                   |
|------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |

This fourth stage of a MAC address look-up involves the use of 64 records, each containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_4

Description: The fifth stage of a MAC address look-up is performed by this table.

### Table 129. Layer\_2\_Key\_Table\_4 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_0000 |
| Register Size      | 8192        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 32          |
| Record Instances   | 256         |
| Record Spacing     | 32          |



### Figure 95. Layer\_2\_Key\_Table\_4 Register Diagram

### Table 130. Layer\_2\_Key\_Table\_4 Field Parameters

| Field Name             | Parameters                                                    | Description                                                                                                                                                                                                                   |
|------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select<br>one of four index values for use in the next stage of<br>the look-up. |

This fifth stage of a MAC address look-up involves the use of 256 records, each containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_5

Description: The sixth stage of a MAC address look-up is performed by this table.

### Table 131. Layer\_2\_Key\_Table\_5 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000b_0000 |
| Register Size      | 32768       |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 32          |
| Record Instances   | 1024        |
| Record Spacing     | 32          |



### Figure 96. Layer\_2\_Key\_Table\_5 Register Diagram

### Table 132. Layer\_2\_Key\_Table\_5 Field Parameters

| Field Name             | Parameters                                                    | Description                                                                                                                                                                                                                   |
|------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_key_{02}[47:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 3<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of four index values for use in the next stage of the<br>look-up. |

This sixth stage of a MAC address look-up involves the use of 1,024 records, each containing three keys. The three keys are compared against the search argument. The results of these comparisons serve to select one of the four index values for use in the next stage of the look-up.

### Layer\_2\_Key\_Table\_6

Description: The seventh and final stage of a MAC address look-up is performed by this table.

### Table 133. Layer\_2\_Key\_Table\_6 Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0008_0000 |
| Register Size      | 131072      |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 24          |
| Record Instances   | 4096        |
| Record Spacing     | 32          |

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

|    | 31 | 30 29 28 27 26 25 24 23 | 22 21 20 19 18 17       | 16 15 14  | 4 13   | 12 11 10 9 8 7 6 5 4 3 2      | 1 0 |  |  |  |  |
|----|----|-------------------------|-------------------------|-----------|--------|-------------------------------|-----|--|--|--|--|
| 0  |    |                         |                         |           |        | layer_2_key_0[47:32]          |     |  |  |  |  |
| 4  |    |                         | laye                    | r_2_key_0 | [31:0] |                               |     |  |  |  |  |
| 8  | 3  |                         |                         |           |        | layer_2_key_1[47:32]          |     |  |  |  |  |
| 2  |    |                         | laye                    | r_2_key_1 | [31:0] |                               |     |  |  |  |  |
| 6  |    |                         | layer_2_src_port_0[5:0] |           |        | layer_2_dest_map_index_0[8:0] |     |  |  |  |  |
| 20 |    |                         | layer_2_src_port_1[5:0] |           |        | layer_2_dest_map_index_1[8:0] |     |  |  |  |  |

### Figure 97. Layer\_2\_Key\_Table\_6 Register Diagram

### Table 134. Layer\_2\_Key\_Table\_6 Field Parameters

| Field Name              | Parameters                                                    | Description                                                                                                                                                                                                                                                                  |
|-------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| key_valid_{01}          | Mode = R/W<br>Offset = 0.0<br>Instances = 2<br>Spacing = 8.0  | This bit is asserted to indicate that the correspond-<br>ing key table entry is valid. If an invalid key is found<br>at the end of a look-up, then a look-up miss indica-<br>tion is returned in the same manner as if a valid<br>entry had not matched the search argument. |
| layer_2_key_{01}[47:0]  | Mode = R/W<br>Offset = 0.16<br>Instances = 2<br>Spacing = 8.0 | A set of 48-bit MAC address values. These values<br>are compared against the search argument. The<br>results of these comparisons are used to select one<br>of two associated data values.                                                                                   |
| layer_2_src_permit_{01} | Mode = R/W<br>Offset = 16.8<br>Instances = 2<br>Spacing = 4.0 | This bit must be asserted for a packet whose source address matches a valid associated key to be forwarded.                                                                                                                                                                  |

### Layer\_2\_Key\_Table\_6 (continued)

### Table 134. Layer\_2\_Key\_Table\_6 Field Parameters (continued)

| Field Name                       | Parameters                                                     | Description                                                                                                                                                                                                                                                                                                      |
|----------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_src_port_{01}[5:0]       | Mode = R/W<br>Offset = 16.9<br>Instances = 2<br>Spacing = 4.0  | This field identifies the port via which the associ-<br>ated address was learned. If the logical receive port<br>number of a packet with a matching source address<br>does not match this field, then the attached source<br>device has moved from one port to another and the<br>address table must be updated. |
| layer_2_src_flow_id_{01}[2:0]    | Mode = R/W<br>Offset = 16.15<br>Instances = 2<br>Spacing = 4.0 | This field forms part of a flow identifier. This value is used for policing purposes.                                                                                                                                                                                                                            |
| layer_2_src_log_{01}             | Mode = R/W<br>Offset = 16.18<br>Instances = 2<br>Spacing = 4.0 | If this bit is set for a packet whose source address<br>matches the associated key, then the packet is cop-<br>ied to the supervisor's logging queue.                                                                                                                                                            |
| layer_2_dest_map_index_{01}[8:0] | Mode = R/W<br>Offset = 16.19<br>Instances = 2<br>Spacing = 4.0 | This field is used to select one of the shared desti-<br>nation port map values.                                                                                                                                                                                                                                 |
| layer_2_dest_flow_id_{01}[2:0]   | Mode = R/W<br>Offset = 16.28<br>Instances = 2<br>Spacing = 4.0 | A flow identifier based on a packet's destination<br>address. This value is used for policing purposes.                                                                                                                                                                                                          |
| layer_2_dest_log_{01}            | Mode = R/W<br>Offset = 16.31<br>Instances = 2<br>Spacing = 4.0 | If this bit is set for a packet whose destination<br>address matches the associated key, then the<br>packet is copied to the supervisor's logging queue.                                                                                                                                                         |

This seventh and final stage of a MAC address look-up involves the use of 4,096 records, each containing two keys and two associated data values. The two keys are compared against the search argument. The results of these comparisons serve to select one of the two associated data values as the final output of the look-up.

### Layer\_2\_Learning\_Mask

Description: Disables those ports that should not transmit packets received via a port in the learning mode.

| Table 135. | Layer_2 | _Learning_ | Mask Register | Parameters |
|------------|---------|------------|---------------|------------|
|------------|---------|------------|---------------|------------|

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4648 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 98. Layer\_2\_Learning\_Mask Register Diagram

### Table 136. Layer\_2\_Learning\_Mask Field Parameters

| Field Name          | Parameters                                  | Description                                                                                                                |
|---------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| learning_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The learning mask value. Each bit in the mask cor-<br>responds to an Ethernet port or one of the supervi-<br>sor's queues. |

This mask is applied to the destination port map if the packet's source port or VLAN is in the learning state according to spanning tree rules. Bits asserted in learning\_mask[57:0] have the effect of disabling the corresponding destinations.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 99. Port Numbering Scheme

### Layer\_2\_Learning\_Port

Description: Identifies the port to be used for MAC source address learning.

#### Table 137. Layer\_2\_Learning\_Port Register Parameters

| Value       |  |  |  |  |  |
|-------------|--|--|--|--|--|
| 0x000c_4668 |  |  |  |  |  |
| 4           |  |  |  |  |  |
| 1           |  |  |  |  |  |
| NA          |  |  |  |  |  |
| 4           |  |  |  |  |  |
| 1           |  |  |  |  |  |
| NA          |  |  |  |  |  |
|             |  |  |  |  |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 100. Layer\_2\_Learning\_Port Register Diagram

### Table 138. Layer\_2\_Learning\_Port Field Parameters

| Field Name         | Parameters                                                | Description                                           |
|--------------------|-----------------------------------------------------------|-------------------------------------------------------|
| learning_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The port number used for MAC source address learning. |

When a packet is received whose MAC source address is not found in the address table or whose source port listed in the address table does not match the logical port through which it was received, it is copied to the port number specified here.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 101. Port Numbering Scheme

### Layer\_2\_Logical\_Port\_Table

Description: Translates physical port numbers to logical port numbers.

### Table 139. Layer\_2\_Logical\_Port\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4500 |
| Register Size      | 256         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 52          |
| Record Spacing     | 4           |
|                    |             |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 102. Layer\_2\_Logical\_Port\_Table Register Diagram

### Table 140. Layer\_2\_Logical\_Port\_Table Field Parameters

| Field Name              | Parameters                                                | Description                                                             |
|-------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------|
| logical_port_{051}[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The logical port number to be used for a par-<br>ticular physical port. |

The physical receive port number of a packet is used as an index into this table to determine the packet's logical receive port. Logical port numbers are used to allow multiple physical ports to share a single identity. This capability reduces learning thrashing when packets are received on ports that are members of an aggregate.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 103. Port Numbering Scheme

### Layer\_2\_Mirror\_Port

Description: Identifies the system's mirror port.

#### Table 141. Layer\_2\_Mirror\_Port Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_466c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 104. Layer\_2\_Mirror\_Port Register Diagram

#### Table 142. Layer\_2\_Mirror\_Port Field Parameters

| Field Name       | Parameters                                                | Description             |
|------------------|-----------------------------------------------------------|-------------------------|
| mirror_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The mirror port number. |

When mirroring is enabled and a packet is received or transmitted via a port that is being mirrored, that packet is also copied to the port identified by this register.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 105. Port Numbering Scheme

### Layer\_2\_Mode

Description: Assorted mode bits for Layer 2 processing.

### Table 143. Layer\_2\_Mode Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4700 |
| Register Size      | 244         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 61          |
| Record Spacing     | 4           |





### Table 144. Layer\_2\_Mode Field Parameters

| Field Name             | Parameters        | Description                                                            |
|------------------------|-------------------|------------------------------------------------------------------------|
| discard_unknown_src_en | Mode = R/W        | This bit enables the discarding of packet's whose source addresses are |
|                        | Offset = $0.28$ , | not present in the address table.                                      |
|                        | Instances = 1     |                                                                        |
|                        | Reset = 0         |                                                                        |
| supervisor_route_en    | Mode = R/W        | When this bit is asserted, packets whose destination addresses are     |
|                        | ffset = 0.29      | known (even though there is a mismatch between the source's VLAN       |
|                        | Instances = 1     | and the destination's) are forwarded to the supervisor for routing     |
|                        | Reset = 0         | between the VLANs. Otherwise, such packets are not forwarded to nor-   |
|                        |                   | mal transmit ports.                                                    |
| user_port_snoop_en     | Mode = R/W        | Asserting this bit enables the snooping of a user-defined TCP destina- |
|                        | Offset = $0.30$ , | tion port.                                                             |
|                        | Instances = 1     |                                                                        |
|                        | Reset = 0         |                                                                        |
| igmp_snoop_en          | Mode = R/W        | Asserting this bit enables the copying of IGMP packets to the supervi- |
|                        | Offset = 0.31     | sor's IGMP snooping port. When deasserted, such packets are not cop-   |
|                        | Instances = 1     | ied to the supervisor.                                                 |
|                        | Reset = 0         |                                                                        |

This register contains an assortment of Layer 2 processing mode bits and fields. There is one record for each physical Ethernet port.

#### PORT NUMBERING SCHEME (TABLE INDEXING)

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | ( | G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|---|----|----|----|----|------------------------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  |   | 3  | 2  | 1  | 0  | SU = SUPERVISOR                                      |

### Figure 107. Port Numbering Scheme (Table Indexing)

### Layer\_2\_No\_Dest\_Packets

Description: A count of the number of packets with a null destination map.

#### Table 145. Layer\_2\_No\_Dest\_Packets Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x000c_4680 |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |



### Figure 108. Layer\_2\_No\_Dest\_Packets Register Diagram

#### Table 146. Layer\_2\_No\_Dest\_Packets Field Parameters

| Field Name            | Parameters                                               | Description                                          |
|-----------------------|----------------------------------------------------------|------------------------------------------------------|
| no_dest_packets[27:0] | Mode = R/W<br>Offset = 0.4<br>Instances = 1<br>Reset = 0 | The number of packets whose destination map in null. |

If a packet's destination map is null (i.e., no destinations), then this counter is incremented.

### Layer\_2\_Src\_Deny\_Mask

Description: Identifies those ports to be eliminated as destinations based on a source address denial.

| Table 147. Layer_2_Src_Der | ny_Mask Register Parameters |
|----------------------------|-----------------------------|
|----------------------------|-----------------------------|

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x000c_4650 |  |  |  |  |  |
| Register Size      | 8           |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 8           |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |



### Figure 109. Layer\_2\_Src\_Deny\_Mask Register Diagram

### Table 148. Layer\_2\_Src\_Deny\_Mask Field Parameters

| Field Name          | Parameters                                               | Description             |
|---------------------|----------------------------------------------------------|-------------------------|
| src_deny_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The source denial mask. |

If the MAC source address look-up returns a source deny indication, then the ports identified by this mask are eliminated as destinations for the packet. Asserted bits in  $src_deny_mask[57:0]$  identify those ports that are eliminated (masked) by this function. Deasserted bits in  $src_deny_mask[57:0]$  have no effect on the packet's destination port map.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

 $\label{eq:G} \begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

### Figure 110. Port Numbering Scheme

# Layer\_2\_Src\_Mirror\_Map

Description: Identifies those ports whose receive traffic is to be mirrored.

#### Table 149. Layer\_2\_Src\_Mirror\_Map Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x000c_4658 |  |  |  |  |  |
| Register Size      | 8           |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 8           |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |



### Figure 111. Layer\_2\_Src\_Mirror\_Map Register Diagram

#### Table 150. Layer\_2\_Src\_Mirror\_Map Field Parameters

| Field Name           | Parameters                                               | Description            |
|----------------------|----------------------------------------------------------|------------------------|
| src_mirror_map[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The source mirror map. |

This port map identifies those ports whose receive traffic is to be copied to the mirror port. If a packet's receive port's corresponding bit in src\_mirror\_map[57:0] is asserted, then the packet is copied to the mirror port.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 112. Port Numbering Scheme

### Layer\_2\_Src\_Port\_Mask\_Table

Description: Enables the limiting of destinations based on source port.

#### Table 151. Layer\_2\_Src\_Port\_Mask\_Table Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x000c_4200 |  |  |  |  |  |
| Register Size      | 400         |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |
| Record Size        | 8           |  |  |  |  |  |
| Record Instances   | 50          |  |  |  |  |  |
| Record Spacing     | 8           |  |  |  |  |  |



### Figure 113. Layer\_2\_Src\_Port\_Mask\_Table Register Diagram

#### Table 152. Layer\_2\_Src\_Port\_Mask\_Table Field Parameters

| Field Name          | Parameters                                                 | Description           |
|---------------------|------------------------------------------------------------|-----------------------|
| src_port_mask[57:0] | Mode = $R/W$<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The source port mask. |

Source port masking is used to limit the destination ports reachable from each source port. There is a mask in the table for each of the system's source ports.

#### PORT NUMBERING SCHEME (MASK BITS)

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

#### PORT NUMBERING SCHEME (TABLE INDEXING)

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT

XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 114. Port Numbering Scheme (Mask Bits and Table Indexing)

### Layer\_2\_Supervisor\_Route\_Port

Description: Identifies the supervisor's route port.

#### Table 153. Layer\_2\_Supervisor\_Route\_Port Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4674 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |





#### Table 154. Layer\_2\_Supervisor\_Route\_Port Field Parameters

| Field Name                 | Parameters                                                | Description                       |
|----------------------------|-----------------------------------------------------------|-----------------------------------|
| supervisor_route_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The supervisor route port number. |

When a receive packet's MAC source address is found in the address table but the source VLAN and destination VLAN do not match and supervisor routing is enabled, this port is added to the packet's destination port map.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |



### Figure 116. Port Numbering Scheme

### Layer\_2\_Time\_Stamp\_Table

Description: The MAC address table's time stamps.

### Table 155. Layer\_2\_Time\_Stamp\_Table Register Parameters

| Parameter          | Value       |  |
|--------------------|-------------|--|
| Base Address       | 0x000b_8000 |  |
| Register Size      | 32768       |  |
| Register Instances | 1           |  |
| Register Spacing   | NA          |  |
| Record Size        | 4           |  |
| Record Instances   | 8192        |  |
| Record Spacing     | 4           |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28   | 29    | 30  | 31    |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|-----|-------|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2     | 1   | 0     |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | time | e_sta | mp[ | [3:0] |

### Figure 117. Layer\_2\_Time\_Stamp\_Table Register Diagram

### Table 156. Layer\_2\_Time\_Stamp\_Table Field Parameters

| Field Name      | Parameters                                   | Description                                                    |
|-----------------|----------------------------------------------|----------------------------------------------------------------|
| time_stamp[3:0] | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | The time stamp value for the corresponding MAC source address. |

This table holds the time stamps for the MAC address table. Whenever an address in the MAC address table is seen in a received packet as a source address and the received packet's source port matches the source port information in the address table, the time stamp value in this table that corresponds to that MAC address table entry is updated with the current time value. The current time value is established by Layer\_2\_Current\_Time.

### Layer\_2\_User\_Port

Description: A user-specified TCP destination port for snooping purposes.

#### Table 157. Layer\_2\_User\_Port Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4678 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23    | 24    | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|-------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7     | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | use | er_po | ort[1 | 5:0] |    |    |    |    |    |    |

### Figure 118. Layer\_2\_User\_Port Register Diagram

### Table 158. Layer\_2\_User\_Port Field Parameters

| Field Name      | Parameters                                   | Description                                            |
|-----------------|----------------------------------------------|--------------------------------------------------------|
| user_port[15:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The user-specified TCP destination port to be snooped. |

A single TCP destination port may be specified for snooping purposes. If so enabled, any packet with a TCP destination port value that matches the value here is copied to the port specified by Layer\_2\_User\_Port\_Snooping\_Port.

### Layer\_2\_User\_Port\_Snooping\_Port

Description: Specifies the supervisor port (queue) to which user-port snooped packets are forwarded.

### Table 159. Layer\_2\_User\_Port\_Snooping\_Port Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_467c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26    | 27    | 28   | 29    | 30   | 31     |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|------|-------|------|--------|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 4     | 3    | 2     | 1    | 0      |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | user_ | _port | _sno | oping | _por | t[5:0] |

### Figure 119. Layer\_2\_User\_Port\_Snooping\_Port Register Diagram

### Table 160. Layer\_2\_User\_Port\_Snooping\_Port Field Parameters

| Field Name                   | Parameters                                   | Description                                                                                 |
|------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------|
| user_port_snooping_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1 | The port to which packets with a user-speci-<br>fied TCP destination port value are copied. |

If the TCP destination port number of the received packet matches the value in Layer\_2\_User\_Port and Layer\_2\_Mode.user\_port\_snoop\_en is asserted, then the port specified by the value in user\_port\_snooping\_port[5:0] is added to the packet's destination port map.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3  | 2  | 1  | 0  |

| G = 10/100/1000 MBITS/S PORT |  |
|------------------------------|--|
| XG = 10 GBITS/S PORT         |  |
| SU = SUPERVISOR              |  |

### Figure 120. Port Numbering Scheme

### Layer\_2\_Vlan\_Mask\_Table

Description: Enables the limiting of destinations based on source VLAN.

#### Table 161. Layer\_2\_Vlan\_Mask\_Table Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_3800 |
| Register Size      | 2048        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 256         |
| Record Spacing     | 8           |



#### Figure 121. Layer\_2\_Vlan\_Mask\_Table Register Diagram

#### Table 162. Layer\_2\_Vlan\_Mask\_Table Field Parameters

| Field Name      | Parameters                                  | Description    |
|-----------------|---------------------------------------------|----------------|
| vlan_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The VLAN mask. |

The received packet's 8-bit VLAN index is used to retrieve a port mask from this table. This mask is then used to eliminate destinations from the packet's destination port map.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |



### Figure 122. Port Numbering Scheme

### Layer\_2\_Vlan\_Port\_State\_Table

Description: Maintains the spanning tree state on a per-port and per-VLAN basis.

### Table 163. Layer\_2\_Vlan\_Port\_State\_Table Register Parameters

| Parameter          | Value                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Base Address       | gister Size 62464<br>gister Instances 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register Size      |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register Instances |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Register Spacing   | NA                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Record Size        | 4                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Record Instances   | 15616                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Record Spacing     | 4                                       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                    |                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 1 2 3 4 5 6 7    | 8 9 10 11 12 13 14 15 16 17 18          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0

### Figure 123. Layer\_2\_Vlan\_Port\_State\_Table Register Diagram

### Table 164. Layer\_2\_Vlan\_Port\_State\_Table Field Parameters

| Field Name     | Parameters                                   | Description                                                                                        |
|----------------|----------------------------------------------|----------------------------------------------------------------------------------------------------|
| stp_state[1:0] | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | The port/VLAN STP state.<br>002 = blocking<br>012 = learning<br>102 = forwarding<br>112 = disabled |

In order to support per VLAN spanning tree, the spanning tree state of each port must be maintained on a per-VLAN basis. This table provides this information to the bridging function.

This table is addressed by a concatenation of the packet's receive port and the packet's VLAN index: address[13:0] = { rx\_port[5:0], vlan\_index[7:0] }

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 124. Port Numbering Scheme

0

### Mac\_Global\_Mode

Description: Sets basic shared operating modes for the Ethernet MACs.

### Table 165. Mac\_Global\_Mode Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8310 |
| Register Size      | 16          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 1           |
| Record Spacing     | NA          |

#### 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31. 30. 29. 28. 27. 26. 25. 24. 23. 22. 21. 20. 19. 18. 17. 16. 15. 14. 13. 12. 11. 10. 9. 8. 7. 6. 5. 4. 3. 2. 1. 0.

|    | 31 30 | mac_pause_quanta[15:0] |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 15 | 14 | 113 | ~  | <br>10 | 9    | 0    | '    | 0  | 5 | 4  | 3    | 2     | <u> </u> | 0 |
|----|-------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----|----|-----|----|--------|------|------|------|----|---|----|------|-------|----------|---|
| 0  |       |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    |    |     | ma | ac_s   | rc_a | ddr[ | 47:3 | 2] |   |    |      |       |          |   |
| 4  |       | mac_src_addr[31:6]     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    |    |     |    |        |      |      |      |    |   |    |      |       |          |   |
| 8  |       |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    |    |     |    |        |      |      |      |    |   | rp | orog | [5:0] |          |   |
| 12 |       |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |    |    |     |    |        |      |      |      |    |   |    |      |       |          |   |

### Figure 125. Mac\_Global\_Mode Register Diagram

### Table 166. Mac\_Global\_Mode Field Parameters

| Field Name                       | Parameters                                   | Description                                                                                                                                                                                                                               |
|----------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mac_pause_quanta[15:0]           | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | The pause quanta value to be inserted into pause control packets.                                                                                                                                                                         |
| mac_src_addr[47:6]               | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The upper 42 bits of the MAC source addresses. The least significant 6 bits are hardwired per port.                                                                                                                                       |
| termination_compensation_disable | Mode = R/W<br>Offset = 8.15<br>Instances = 1 | Asserting this bit disables the SGMII termination compensation function for all channels. For normal operation, this bit is deasserted.                                                                                                   |
| auto_negotiation_speed_up        | Mode = R/W<br>Offset = 8.16<br>Instances = 1 | Asserting this bit causes the SGMII autonegotiation<br>process to be sped up. For normal operation, this bit<br>is deasserted. This bit has no effect on the autonego-<br>tiation process executed by the external PHY on the<br>network. |
| prbs_en                          | Mode = R/W<br>Offset = 8.17<br>Instances = 1 | This bit is asserted to enable the PRBS test mode for<br>all SGMII channels. The PRBS test runs for as long<br>as this bit is asserted. For normal operation, this bit is<br>deasserted.                                                  |

### Mac\_Global\_Mode (continued)

### Table 166. Mac\_Global\_Mode Field Parameters (continued)

| Field Name                             | Parameters                                                     | Description                                                                                                                                                                                                                                                               |
|----------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inject_offset_polarity                 | Mode = R/W<br>Offset = 8.18<br>Instances = 1                   | This bit establishes the polarity of the offset specified<br>by inject_offset{02}.<br>0 = positive polarity offset.<br>1 = negative polarity offset.                                                                                                                      |
| loopback_delay_select[1:0]             | Mode = R/W<br>Offset = 8.19<br>Instances = 1                   | Selects a delay value when the SGMII is operating in<br>a serial loop back mode.<br>002 = 400  ps.<br>012 = 100  ps.<br>102 = -100  ps.                                                                                                                                   |
| loopback_amplitude_select              | Mode = R/W<br>Offset = 8.21<br>Instances = 1                   | This bit selects one of two amplitudes for serial loop<br>back of the SGMII channels.<br>0 = 400  mV.<br>1 = 100  mV.                                                                                                                                                     |
| inject_offset_2                        | Mode = R/W<br>Offset = 8.22<br>Instances = 1                   | Asserting this bit causes an offset current of level 2 to be injected into the SGMII data.                                                                                                                                                                                |
| inject_offset_1                        | Mode = R/W<br>Offset = 8.23<br>Instances = 1                   | Asserting this bit causes an offset current of level 1 to be injected into the SGMII data.                                                                                                                                                                                |
| inject_offset_0                        | Mode = R/W<br>Offset = 8.24<br>Instances = 1                   | Asserting this bit causes an offset current of level 0 to be injected into the SGMII data.                                                                                                                                                                                |
| sw_reset_control                       | Mode = R/W<br>Offset = 8.25<br>Instances = 1                   | Provides a software reset control to the device.                                                                                                                                                                                                                          |
| rprog[5:0]                             | Mode = R/W<br>Offset = 8.26<br>Instances = 1                   | PLL parameter. Bits 4, 2, 1, and 0 of this value are<br>inverted between the register and the PLL. This is<br>done so that the reset value of 0 appears at the PLL<br>as 01_01112.                                                                                        |
| set_resistor_value_{02}[2:0]           | Mode = R/W<br>Offset = 12.9<br>Instances = 3<br>Spacing = 0.8  | This value is used in the SGMII termination block if<br>the corresponding force_resistor bit is asserted.<br>There are three independent termination control<br>groups serving the 48 SGMII ports.                                                                        |
| force_resistor_{02}                    | Mode = R/W<br>Offset = 12.12<br>Instances = 3<br>Spacing = 0.8 | When the SGMII termination compensation function<br>is disabled, a high on this bit enables the application<br>of the termination value specified in<br>set_resistor_value[2:0]. There are three independent<br>termination control groups serving the 48 SGMII<br>ports. |
| resistor_compensation_status_{02}[2:0] | Mode = RO<br>Offset = 12.13<br>Instances = 3<br>Spacing = 0.8  | This field returns the resistor compensation results.<br>There are three independent termination control<br>groups serving the 48 SGMII ports.                                                                                                                            |

### Mac\_Mode\_{0..4}

Description: Sets basic operating modes for the Ethernet MACs.

### Table 167. Mac\_Mode\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8000 |
| Register Size      | 40          |
| Register Instances | 5           |
| Register Spacing   | 128         |
| Record Size        | 4           |
| Record Instances   | 10          |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 126. Mac\_Mode\_{0..4} Register Diagram

### Table 168. Mac\_Mode\_{0..4} Field Parameters

| Field Name                         | Parameters                                   | Description                                                                                                                                                                                                             |
|------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| port_en_{}{09}                     | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Enables the corresponding Ethernet port. When a port_en bit is false, all activity of the associated Ethernet port is disabled.                                                                                         |
| good_link_{}{09}                   | Mode = RO<br>Offset = 0.13<br>Instances = 1  | This read-only bit is asserted whenever a good link status<br>exists for the corresponding SGMII channel. Forcing a<br>good link status by asserting force_good_link also<br>causes good_link to be asserted.           |
| full_duplex_{}{09}                 | Mode = RO<br>Offset = 0.14<br>Instances = 1  | This read-only bit is asserted whenever a full duplex sta-<br>tus exists for the corresponding SGMII channel. Forcing a<br>full duplex status by asserting force_full_duplex<br>also causes full_duplex to be asserted. |
| offset_compensation_disable_{}{09} | Mode = R/W<br>Offset = 0.15<br>Instances = 1 | This bit is asserted to disable the SGMII offset compen-<br>sation circuitry. For normal operation, this bit is deas-<br>serted.                                                                                        |
| power_down_{}{09}                  | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | Asserting this bit powers down the associated SGMII interface module. For normal operation, this bit is deas-serted.                                                                                                    |

### Mac\_Mode\_{0..4} (continued)

### Table 168. Mac\_Mode\_{0..4} Field Parameters (continued)

| Field Name                      | Parameters                                   | Description                                                                                                                                                                                                                                                                                                   |
|---------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| input_select_{}{09}[1:0]        | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | This field is used to select the source of receive data and receive clocks for those Ethernet ports that support both SGMII and SerDes interfaces. This field is encoded as follows:                                                                                                                          |
|                                 |                                              | <ul> <li>002 = data disabled, SGMII clock.</li> <li>012 = SGMII data and clock.</li> <li>102 = SerDes data and clock.</li> <li>112 = data disabled, SGMII clock.</li> </ul>                                                                                                                                   |
| speed_mode_force_{}{09}[1:0]    | Mode = R/W<br>Offset = 0.19<br>Instances = 1 | Causes the speed mode of the associated<br>1 Gbit/s link to be forced to the specified setting. This field<br>is only valid when good_link_force is asserted.<br>speed_mode_force[1:0] is defined as follows:                                                                                                 |
|                                 |                                              | 002 = 10 Mbits/s.<br>012 = 100 Mbits/s.<br>102 = 1 Gbit/s.<br>112 = reserved.                                                                                                                                                                                                                                 |
| good_link_force_{}{09}          | Mode = R/W<br>Offset = 0.21<br>Instances = 1 | When asserted, associated link is forced to operate as if<br>it has detected a valid link signal. The assertion of this bit<br>also enables <code>speed_mode_force[1:0]</code> and<br><code>full_duplex_force</code> .                                                                                        |
| full_duplex_force_{}{09}        | Mode = R/W<br>Offset = 0.22<br>Instances = 1 | When asserted, the associated PHY is forced into a full-<br>duplex mode of operation. This signal is only valid when<br>good_link_force is asserted.                                                                                                                                                          |
| auto_negotiate_en_{}{09}        | Mode = R/W<br>Offset = 0.23<br>Instances = 1 | When asserted, autonegotiation is enabled for the associate PHY.                                                                                                                                                                                                                                              |
| restart_auto_negotiation_{}{09} | Mode = R/W<br>Offset = 0.24<br>Instances = 1 | Autonegotiation may be forced to be restarted by assert-<br>ing and then immediately deasserting this bit. The rising<br>edge (0-to-1 transition) is detected in order to force a sin-<br>gle autonegotiation.                                                                                                |
| gmac_tx_flush_{}{09}            | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | When asserted, the associated PHY accepts transmit<br>data from packet_buffer at the maximum data rate<br>and then discards it without transmitting it. Changes to<br>this mode bit only take effect between transmit packets.                                                                                |
| gmac_port_speed_{}{09}[1:0]     | Mode = RO<br>Offset = 0.26<br>Instances = 1  | Indicates the port speed of the associated PHY.<br>002 = 10 Mbits/s.<br>012 = 100 Mbits/s.<br>102 = 1 Gbit/s.<br>112 = reserved.                                                                                                                                                                              |
| gmac_port_loopback_en_{}{09}    | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | When asserted, all transmit packets are looped back to<br>the receive path by the associated SGMII interface. Net-<br>work reception is disabled during loopback. Changes to<br>this mode bit take effect immediately. This may cause the<br>transmission or reception of one or more defective pack-<br>ets. |

Mac\_Mode\_{0..4} (continued)

### Table 168. Mac\_Mode\_{0..4} Field Parameters (continued)

| Field Name                           | Parameters                                   | Description                                                                                                                                                                                                                                                            |
|--------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gmac_rx_en_{}{09}                    | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | Enables the reception of Ethernet packets. When false, only MAC control packets are received.                                                                                                                                                                          |
| gmac_flow_control_initiate_en_{}{09} | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | This bit enables the initiation of flow control actions on<br>the part of the Ethernet MAC in response to flow control<br>indications from packet_buffer. If this bit is deas-<br>serted, then the corresponding Ethernet MAC never<br>takes any flow control actions. |
|                                      |                                              | <pre>In revision C, when input_select_{}{09}[1:0] = 0x2 and auto_negotiate_en_{}{09} = 1, this field becomes the ASM_DIR (PS2) bit for 1000BASE-X autonegotiation.</pre>                                                                                               |
| gmac_rx_pause_en_{}{09}              | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | This bit must be asserted for the corresponding Ethernet MAC to react to the reception of MAC flow control packets.                                                                                                                                                    |
|                                      |                                              | In revision C, when input_select_{} $\{09\}[1:0] = 0x2$ and auto_negotiate_en_{} $\{09\} = 1$ , this field becomes the PAUSE (PS1) bit for 1000BASE-X autonegotiation.                                                                                                 |

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | Γ | G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT            |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|---|----|----|----|----|-----------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  |   | 3  | 2  | 1  | 0  | XG = 10 Gbits/s PORT<br>SU = SUPERVISOR |

| Figure 127. Port Numbering Sche | ne |
|---------------------------------|----|
|---------------------------------|----|

### Mac\_Mode\_{5..6}

Description: Sets basic operating modes for the Ethernet MACs.

### Table 169. Mac\_Mode\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8290 |
| Register Size      | 4           |
| Register Instances | 2           |
| Register Spacing   | 64          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 128. Mac\_Mode\_{5..6} Register Diagram

### Table 170. Mac\_Mode\_{5..6} Field Parameters

| Field Name                 | Parameters                                   | Description                                                                                                                                                                                                                                              |
|----------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| port_en                    | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Enables the corresponding Ethernet port. When a port_en bit is false, all activity of the associated Ethernet port is disabled.                                                                                                                          |
| xgxs_time_out_limit[4:0]   | Mode = R/W<br>Offset = 0.2<br>Instances = 1  | _                                                                                                                                                                                                                                                        |
| xgxs_queue_time_limit[4:0] | Mode = R/W<br>Offset = 0.7<br>Instances = 1  | _                                                                                                                                                                                                                                                        |
| xgxs_init_fill_limit[3:0]  | Mode = R/W<br>Offset = 0.12<br>Instances = 1 | _                                                                                                                                                                                                                                                        |
| deficit_idle_counter_en    | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | This bit is asserted to enable the deficit idle counter.<br>When enabled, this counter maintains the number<br>of idles between packets to an average minimum of<br>12 bytes. When disabled, the minimum number of<br>idles increases to 16 to 20 bytes. |
| xgmac_tx_flush             | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | When asserted, the associate PHY accepts trans-<br>mit data from packet_buffer at the maximum data<br>rate and then discards it without transmitting it.<br>Changes to this mode bit only take effect between<br>transmit packets.                       |

Mac\_Mode\_{5..6} (continued)

### Table 170. Mac\_Mode\_{5..6} Field Parameters (continued)

| Field Name                     | Parameters                                   | Description                                                                                                                                                                                                                                                          |
|--------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| less_aggress_mode              | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | When asserted, the minimum interframe gap for the corresponding 10G port will always have a value from 12 bytes to 15 bytes. When deasserted, the interframe gap will be the average of 12 bytes $\pm$ 3 bytes.                                                      |
| xgmac_rx_en                    | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | Enables the reception of Ethernet packets. When false, only MAC control packets are received.                                                                                                                                                                        |
| xgmac_flow_control_initiate_en | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | This bit enables the initiation of flow control actions<br>on the part of the Ethernet MAC in response to flow<br>control indications from packet_buffer. If this<br>bit is deasserted, then the corresponding Ethernet<br>MAC never takes any flow control actions. |
| xgmac_rx_pause_en              | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | This bit must be asserted for the corresponding<br>Ethernet MAC to react to the reception of MAC flow<br>control packets.                                                                                                                                            |

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 129. Port Numbering Scheme

### Mac\_Status\_{0..4}

Description: Indicates fundamental status for the Ethernet MACs.

| Value       |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
|-------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 0x000c_8050 |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| 4           |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| 5           |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| 128         |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| 4           |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| 1           |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
| NA          |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
|             |                                                                                        |                                                                                                                                   |                                                                                                                                         |                                                                            |                                                                                      |                                                                                                                                                    |                                                                                      |                                                                                                  |
|             |                                                                                        |                                                                                                                                   |                                                                                                                                         | 26<br>E                                                                    |                                                                                      |                                                                                                                                                    |                                                                                      | 31                                                                                               |
|             | + 13 12 11 10 9                                                                        | 0 /                                                                                                                               | 0                                                                                                                                       | 5                                                                          | 4、                                                                                   | , 2                                                                                                                                                |                                                                                      | C                                                                                                |
|             | 0x000c_8050           4           5           128           4           1           NA | 0x000c_8050         4         5         128         4         1         NA         6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | 0x000c_8050         4         5         128         4         1         NA         6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | 0x000c_8050         4         5         128         4         1         NA | 0x000c_8050         4         5         128         4         1         1         NA | 0x000c_8050         4         5         128         4         1         NA         6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 2 | 0x000c_8050         4         5         128         4         1         1         NA | 0x000c_8050         4         5         128         4         128         4         1         NA |

### Figure 130. Mac\_Status\_{0..4} Register Diagram

### Table 172. Mac\_Status\_{0..4} Field Parameters

| Field Name        | Parameters                                                     | Description                                                                                                                                                                                                      |
|-------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| prbs_error_{09}{} | Mode = R/W<br>Offset = 0.22<br>Instances = 10<br>Spacing = 0.1 | This bit is asserted to indicate that an error has<br>occurred during PRBS testing of the corresponding<br>SGMII channel. This bit is cleared by writing a one<br>to its location. Writing a zero has no effect. |

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 



# Mdio\_Control

Description: Provides supervisor control of the MDIO interfaces.

### Table 173. Mdio\_Control Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8300 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6    | 7    | 8      | 9      | 10    | 11  | 12   | 13     | 14     | 15   | 16 | 17 | 18 | 19 | 20 | 21 | 22    | 23    | 24   | 25   | 26  | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|------|------|--------|--------|-------|-----|------|--------|--------|------|----|----|----|----|----|----|-------|-------|------|------|-----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   | 23     | 22     | 21    | 20  | 19   | 18     | 17     | 16   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7    | 6    | 5   | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    | mdio | _dev | vice_s | select | [4:0] | mdi | o_po | ort_se | elect[ | 4:0] |    |    |    |    |    | md | dio_a | addr_ | _dat | a[15 | :0] |    |    |    |    |    |

### Figure 132. Mdio\_Control Register Diagram

### Table 174. Mdio\_Control Field Parameters

| Field Name        | Parameters                                  | Description                                                                                                                                                                                                                    |
|-------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mdio_busy         | Mode = RO<br>Offset = 0.0<br>Instances = 1  | This bit is asserted during the period that a previously initiated MDIO access cycle is running. mdio_busy is asserted by a write of the access cycle's addressing parameters.                                                 |
|                   |                                             | If a read cycle was posted, then the read data is valid immediately after<br>the deassertion of mdio_busy. Reads of mdio_data[15:0] and<br>writes to any field of Mdio_Control are not allowed while<br>mdio_busy is asserted. |
| suppress_preamble | Mode = R/W<br>Offset = 0.1<br>Instances = 1 | When asserted, the MDIO controller suppresses the preamble that nor-<br>mally precedes an MDIO command packet.                                                                                                                 |
| mdio_clause_45    | Mode = R/W<br>Offset = 0.2<br>Instances = 1 | If mdio_interface_select is asserted, then this bit is used to select between the clause 45 MDIO (interface 2) and the clause 22 MDIO (interface 1).                                                                           |

### Mdio\_Control (continued)

### Table 174. Mdio\_Control Field Parameters (continued)

| Field Name              | Parameters                                   | Description                                                                                                                                                                                                                                                                                               |
|-------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mdio_opcode[1:0]        | Mode = R/W<br>Offset = 0.3<br>Instances = 1  | This field defines the type of operation being carried out by a write to<br>this register. The opcodes are defined as follows:<br>002 = address<br>012 = write<br>102 = read incremental<br>112 = read<br>Address:<br>This opcode is utilized to establish the cycle's parameters.                        |
|                         |                                              | Write:<br>The supervisor uses the 012 opcode to indicated that a write cycle is to<br>be initiated. The write data is written to mdio_addr_data[15:0].                                                                                                                                                    |
|                         |                                              | Read Incremental:<br>This read operation initiates a read from the next (+1) address; the cur-<br>rent address having been established by a preceding address opera-<br>tion. Aside from the autoincrement of the read address, this operation is<br>identical to a normal read operation (opcode = 112). |
|                         |                                              | Read:<br>Reads are initiated by writing the read address information and the 112<br>opcode to this register. The resulting read data is made available via<br><i>mdio_addr_data</i> [15:0] after <i>mdio_busy</i> is deasserted by the MDIO inter-<br>face controller.                                    |
| mdio_interface_select   | Mode = R/W<br>Offset = 0.5<br>Instances = 1  | Selects interface zero when deasserted. When<br>mdio_interface_select is asserted, then mdio_clause_45 is<br>used to select between interfaces one and two.                                                                                                                                               |
| mdio_device_select[4:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1  | Selects one of 32 devices on the selected MDIO interface.                                                                                                                                                                                                                                                 |
| mdio_port_select[4:0]   | Mode = R/W<br>Offset = 0.11<br>Instances = 1 | Selects one of 32 ports on the selected MDIO device.                                                                                                                                                                                                                                                      |
| mdio_addr_data[15:0]    | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The register address or data portal.                                                                                                                                                                                                                                                                      |

MDIO registers on the attached Ethernet PHY devices are accessed in two stages. The first stage sets up the cycle's parameters (addresses, device selects, modes, etc.) and the second stage accomplishes the data transfer.

For writes, the write data is simply written to offset 0 of this register with an opcode of 012. The initiation of a write causes mdio\_busy to be asserted by the MDIO interface controller. This signal is deasserted automatically upon completion of the MDIO access cycle. No further MDIO access cycles may be initiated while mdio\_busy is asserted.

For reads, the cycle's address parameters are written to initiate the access cycle. This action causes the assertion of mdio\_busy. Once the read cycle is complete, mdio\_busy is deasserted and the read data is posted to mdio\_addr\_data[15:0] where it may be accessed by the supervisor.

### Mdio\_Control (continued)

There are three MDIO interfaces on the ET4148-50 device. The following table defines how the interfaces are selected and how the interfaces are used in a system.

### Table 175. MDIO Interface Selection

| MDIO | mdio_interface_select | mdio_clause_45 | Application                                 |
|------|-----------------------|----------------|---------------------------------------------|
| 0    | 0                     | Х              | 10/100/1000 Mbits/s SGMII & SFP (clause 22) |
| 1    | 1                     | 0              | 10/100/1000 Mbits/s SGMII & SFP (clause 22) |
| 2    | 1                     | 1              | 10 Gbits/s XAUI (clause 45)                 |

# Mdio\_Mode

Description: Defines the basic mode for the MDIO interfaces.

### Table 176. Mdio\_Mode Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|
| Base Address       | 0x000c_8308 |  |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18     | 19   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27  | 28   | 29  | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|------|----|----|----|----|----|----|----|-----|------|-----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13     | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3    | 2   | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ip | orog[3 | 3:0] |    |    |    |    |    |    |    | kpr | og[2 | :0] |    |    |

### Figure 133. Mdio\_Mode Register Diagram

### Table 177. Mdio\_Mode Field Parameters

| Field Name           | Parameters                                   | Description                                                                                                                                                                                   |
|----------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| enbwp                | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | PLL parameter.                                                                                                                                                                                |
| iprog[3:0]           | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | PLL parameter. iprog[2] is inverted between this register and the PLL so that the default reset value is 01002.                                                                               |
| mdio_clk_offset[2:0] | Mode = R/W<br>Offset = 0.21<br>Instances = 1 | This field establishes the delay between the active edge of the MDIO clock and data.                                                                                                          |
| mdio_clk_period[7:5] | Mode = R/W<br>Offset = 0.24<br>Instances = 1 | This field defines the half-clock period of the MDIO clock. mdio_clk_period[4:0] is hardwired to be equal to 31.                                                                              |
| kprog[2:0]           | Mode = R/W<br>Offset = 0.27<br>Instances = 1 | PLL parameter. kprog[0] is inverted between this register and the PLL.This has the effect of making the after-reset value equal to 01002.                                                     |
| accept_jumbo_frames  | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | When this bit is set, all ports may receive frames greater than 1522 bytes.                                                                                                                   |
| short_ifg_mode       | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | When this bit is set, 10 Mbits/s and 100 Mbits/s<br>ports will transmit frames with an interframe gap of<br>11 bytes instead of 12 bytes. This bit should be<br>cleared for normal operation. |

### Mdio\_Mode (continued)

This register is used to define the characteristics of the MDIO clock. The period of the MDIO clock is established by mdio\_clk\_period[7:0]. The value of this field establishes a terminal count which, in turn, defines the half-clock period for the MDIO clock. A free-running counter counts up until reaching mdio\_clk\_period[7:0]. When this value is reached, the free-running counter is reset to zero and the MDIO clock signal is toggled. Larger values of mdio\_clk\_period[7:0] result in lower MDIO clock frequencies. For example, based on a 250 MHz core clock frequency, an mdio\_clk\_period[7:0] value of 25 results in an MDIO clock frequency of 5 MHz. mdio\_clk\_period[7:0] must be set to a minimum value of 1.

mdio\_clk\_offset[7:0] is used to establish a delay between the active edge of the MDIO clock and any transition on or sampling of MDIO data. When the free-running counter defined above is equal to mdio\_clk\_offset[7:0], a data transition or sample occurs. mdio\_clk\_offset[7:0] must be set to a value that is less than or equal to mdio\_clk\_period[7:0].

### Mdio\_Status

0

Description: Provides supervisor control of the MDIO interfaces.

#### Table 178. Mdio\_Status Register Parameters

| Parameter            | Value                        |                                           |
|----------------------|------------------------------|-------------------------------------------|
| Base Address         | 0x000c_8304                  |                                           |
| Register Size        | 4                            |                                           |
| Register Instances   | 1                            |                                           |
| Register Spacing     | NA                           |                                           |
| Record Size          | 4                            |                                           |
| Record Instances     | 1                            |                                           |
| Record Spacing       | NA                           |                                           |
|                      |                              |                                           |
| 0 1 2 3 4 5 6        | 8 9 10 11 12 13 14 15 16     | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
| 31 30 29 28 27 26 25 | 4 23 22 21 20 19 18 17 16 15 | 14 13 12 11 10 9 8 7 6 5 4 3 2 1          |

Figure 134. Mdio\_Status Register Diagram

#### Table 179. Mdio\_Status Field Parameters

| Field Name | Parameters                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mdio_busy  | Mode = RO<br>Offset = 0.0<br>Instances = 1  | This bit is asserted during the period that a previ-<br>ously initiated MDIO access cycle is running.<br>mdio_busy is asserted by a write of the access<br>cycle's addressing parameters.<br>If a read cycle was posted, then the read data is<br>valid immediately after the deassertion of<br>mdio_busy. Reads of mdio_data[15:0] and<br>writes to any field of Mdio_Control are not allowed<br>while mdio_busy is asserted. |
| mdio_done  | Mode = R/W<br>Offset = 0.1<br>Instances = 1 | This bit is asserted at the completion of an MDIO access cycle. The supervisor must write a zero to this bit's position in order to clear the indication.                                                                                                                                                                                                                                                                      |

This register provides basic status regarding MDIO access cycles.

mdio\_busy provides the same information as the signal of the same name in Mdio\_Control.

mdio\_done is automatically asserted upon completion of an MDIO access cycle. This signal is also used as an interrupt-generating indication to the supervisor. The supervisor must write a zero to this bit's position to deassert the bit and cancel the indication.

### Multicast\_Rate\_Accumulator

Description: Counts multicast and broadcast packets.

#### Table 180. Multicast\_Rate\_Accumulator Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4814 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25        | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|
| 0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 |    |    |    |    |    |    | 6<br>mult |    |    | 3  | 2  | 1  | 0  |

#### Figure 135. Multicast\_Rate\_Accumulator Register Diagram

#### Table 181. Multicast\_Rate\_Accumulator Field Parameters

| Field Name                       | Parameters                                   | Description                                                                                                                                                                                                                               |
|----------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| multicast_rate_accumulator[15:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The multicast accumulator. Each multicast or<br>broadcast packet received causes this counter in<br>increment by one. This counter is decrement peri-<br>odically by one with a period established by<br>Multicast_Rate_Decrement_Period. |

This leaky bucket counter is incremented by the reception of multicast and broadcast packets and is decremented by one on a fixed interval. That interval is defined by the contents of the Multicast\_Rate\_Decrement\_Period register. Whenever the value of multicast\_rate\_accumulator[15:0] exceeds Multicast\_Rate\_Limit, the mask in Multicast\_Rate\_Discard\_Mask is applied to the receive packet's destination map.

Multicast\_Rate\_Accumulator is never decremented through zero nor allowed to exceed Multicast\_Rate\_Limit by more than one.

### Multicast\_Rate\_Decrement\_Period

Description: Defines the period between decrements of Multicast\_Rate\_Accumulator.

#### Table 182. Multicast\_Rate\_Decrement\_Period Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_480c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 136. Multicast\_Rate\_Decrement\_Period Register Diagram

#### Table 183. Multicast\_Rate\_Decrement\_Period Field Parameters

| Field Name                            | Parameters                                   | Description                                                                  |
|---------------------------------------|----------------------------------------------|------------------------------------------------------------------------------|
| multicast_rate_decrement_period[19:0] | Mode = R/W<br>Offset = 0.12<br>Instances = 1 | Establishes the rate that<br>Multicast_Rate_Accumulator is decre-<br>mented. |

This register specifies the number of 8 ns periods between decrements of Multicast\_Rate\_Accumulator. The minimum value of one results in a decrement once every 8 ns, or a total multicast/broadcast packet rate of 125,000,000 per second. This register's maximum value of 1,048,575 results in a total multicast/broadcast packet rate of 119 per second.

### Multicast\_Rate\_Discard\_Mask

Description: Disables those ports that should not receive packets that exceed the permitted multicast rate.

#### Table 184. Multicast\_Rate\_Discard\_Mask Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|
| Base Address       | 0x000c_4800 |  |  |  |  |  |  |
| Register Size      | 8           |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |
| Record Size        | 8           |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |



#### Figure 137. Multicast\_Rate\_Discard\_Mask Register Diagram

#### Table 185. Multicast\_Rate\_Discard\_Mask Field Parameters

| Field Name                        | Parameters                                  | Description                                                                                                                    |
|-----------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| multicast_rate_discard_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1 | The multicast rate discard mask value. Each bit in the mask corresponds to an Ethernet port or one of the supervisor's queues. |

This mask is applied to the destination port map if the value of Multicast\_Rate\_Accumulator is greater than Multicast\_Rate\_Limit. This mask is only applied to multicast and broadcast packets.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |



#### Figure 138. Port Numbering Scheme

### Multicast\_Rate\_Limit

Description: Establishes the maximum value allowed in Multicast\_Rate\_Accumulator.

#### Table 186. Multicast\_Rate\_Limit Register Parameters

| Parameter          | Value                         |                                                 |
|--------------------|-------------------------------|-------------------------------------------------|
| Base Address       | 0x000c_4808                   |                                                 |
| Register Size      | 4                             |                                                 |
| Register Instances | 1                             |                                                 |
| Register Spacing   | NA                            |                                                 |
| Record Size        | 4                             |                                                 |
| Record Instances   | 1                             |                                                 |
| Record Spacing     | NA                            |                                                 |
|                    |                               |                                                 |
| 0 1 2 3 4 5        | 6 7 8 9 10 11 12 13 14 15     | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
| 31 30 29 28 27 26  | 25 24 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |
| 0                  |                               | multicast_rate_limit[15:0]                      |

### Figure 139. Multicast\_Rate\_Limit Register Diagram

### Table 187. Multicast\_Rate\_Limit Field Parameters

| Field Name                 | Parameters                                   | Description                                                 |
|----------------------------|----------------------------------------------|-------------------------------------------------------------|
| multicast_rate_limit[15:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The upper limit permitted by<br>Multicast_Rate_Accumulator. |

This register establishes the maximum value permitted in Multicast\_Rate\_Accumulator. If Multicast\_Rate\_Accumulator is greater than Multicat\_Rate\_Limit, then the discarding of multicast packets is enabled. The maximum value allowed in Multcast\_Rate\_Limit is FFFE16.

The actual multicast rate is established via the Multicast\_Rate\_Decrement\_Period register. Multicast\_Rate\_Limit merely establishes this function's tolerance of bursts of multicast and broadcast packets. A larger value of multicast\_rate\_limit[15:0] allows longer bursts of multicast and broadcast packet before the discarding of these packets kicks in.

### Multicast\_Rate\_Limit\_Events

Description: An accounting of the number of occurrences of multicast discards.

#### Table 188. Multicast\_Rate\_Limit\_Events Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4810 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 140. Multicast\_Rate\_Limit\_Events Register Diagram

#### Table 189. Multicast\_Rate\_Limit\_Events Field Parameters

| Field Name                        | Parameters                                   | Description                                         |
|-----------------------------------|----------------------------------------------|-----------------------------------------------------|
| multicast_rate_limit_events[21:0] | Mode = R/W<br>Offset = 0.10<br>Instances = 1 | A statistics counter that track multicast discards. |

This counter is incremented by one each time a multicast packet is received while

Multicast\_Rate\_Accumulator is greater than Multicast\_Rate\_Limit and Multicast\_Rate\_Limit is greater than zero.

Note: The application of the multicast rate discard mask may not result in the reduction of the number of destinations for a multicast packet. For example, BPDU packets ordinarily should not be discarded by this function and Multicast\_Rate\_Discard\_Mask is normally configured to avoid masking the supervisor's BPDU queue. However, the reception of a BPDU packet (a multicast packet) may cause the application of the mask (to no effect) and the incrementing of this counter.

### Multicast\_Rate\_Mode

Description: Mode bits for the multicast rate limiting function.

#### Table 190. Multicast\_Rate\_Mode Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_4818 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 141. Multicast\_Rate\_Mode Register Diagram

| Field Name              | Parameters                                   | Description                                                                                                                                                                                                                                                                  |
|-------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| broadcast_rate_limit_en | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | When asserted, the multicast rate-limiting function is<br>enabled and applied to broadcast packets. When this bit<br>is deasserted,<br>Multicast_Rate_Limit_Discard_Mask is never<br>applied and Multicast_Rate_Limit_Events is<br>never incremented for broadcast packets.  |
| multicast_rate_limit_en | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | When asserted, the multicast rate-limiting function is<br>enabled and applied to multicast packets. When this bit is<br>deasserted,Multicast_Rate_Limit_Discard_Mask<br>is never applied and<br>Multicast_Rate_Limit_Events is never incre-<br>mented for multicast packets. |

### Packet\_Buffer\_Acl\_Deny\_Mask

Description: Identifies those ports to be eliminated as destinations based on an ACL denial.

#### Table 192. Packet\_Buffer\_Acl\_Deny\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bc40 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 142. Packet\_Buffer\_Acl\_Deny\_Mask Register Diagram

#### Table 193. Packet\_Buffer\_Acl\_Deny\_Mask Field Parameters

| Field Name          | Parameters                                               | Description          |
|---------------------|----------------------------------------------------------|----------------------|
| acl_deny_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The ACL denial mask. |

If the ACL look-up returns a deny indication, then the ports identified by this mask are eliminated as destinations for the packet. Asserted bits in  $acl_deny_mask[57:0]$  identify those ports that are eliminated (masked) by this function. Deasserted bits in  $acl_deny_mask[57:0]$  have no effect on the packet's destination port map.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51      | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 143. Port Numbering Scheme

## Packet\_Buffer\_Acl\_Log\_Port

Description: Identifies the ACL logging port.

### Table 194. Packet\_Buffer\_Acl\_Log\_Port Register Parameters

| Parameter                  | Value                          |                                                                                                                            |
|----------------------------|--------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Base Address               | 0x000c_bc58                    |                                                                                                                            |
| Register Size              | 4                              |                                                                                                                            |
| Register Instances         | 1                              |                                                                                                                            |
| Register Spacing           | NA                             |                                                                                                                            |
| Record Size                | 4                              |                                                                                                                            |
| Record Instances           | 1                              |                                                                                                                            |
| Record Spacing             | NA                             |                                                                                                                            |
|                            |                                | -                                                                                                                          |
| 0 1 2 3 4 5 6 7 8          | 9 10 11 12 13 14 15 16 17 18   | 3 19 20 21 22 23 24 25 26 27 28 29 30 31                                                                                   |
| 31 30 29 28 27 26 25 24 23 | _22_21_20_19_18_17_16 15_14_13 | 3   12   11   10   9   8   7 <sub> </sub> 6   5 <sub> </sub> 4 <sub> </sub> 3 <sub> </sub> 2 <sub> </sub> 1 <sub> </sub> 0 |
| 0                          |                                | acl_log_port[5:0]                                                                                                          |

### Figure 144. Packet\_Buffer\_Acl\_Log\_Port Register Diagram

#### Table 195. Packet\_Buffer\_Acl\_Log\_Port Field Parameters

| Field Name        | Parameters                                                | Description                  |
|-------------------|-----------------------------------------------------------|------------------------------|
| acl_log_port[5:0] | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | The ACL logging port number. |

If the ACL look-up returns a log indication, then the port identified by this value is added to the packet's destination port map. Most typically, one of the supervisor's queues (ports 50 through 57) are designated as the ACL logging port.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | 51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 145. Port Numbering Scheme

### Packet\_Buffer\_Allocated\_Buffer\_Count

Description: Provides a real-time indication of the number of allocated buffers.

#### Table 196. Packet\_Buffer\_Allocated\_Count Register Parameters

| Parameter          | Value       |  |
|--------------------|-------------|--|
| Base Address       | 0x000c_b900 |  |
| Register Size      | 208         |  |
| Register Instances | 1           |  |
| Register Spacing   | NA          |  |
| Record Size        | 4           |  |
| Record Instances   | 52          |  |
| Record Spacing     | 4           |  |



### Figure 146. Packet\_Buffer\_Allocated\_Buffer\_Count Register Diagram

#### Table 197. Packet\_Buffer\_Allocated\_Buffer\_Count Field Parameters

| Field Name                   | Parameters                                   | Description                                                     |
|------------------------------|----------------------------------------------|-----------------------------------------------------------------|
| allocated_buffer_count[13:0] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | The number of buffers allocated to the corre-<br>sponding port. |

This register provides a real-time indication of the number of buffers that are allocated per port.

PORT NUMBERING SCHEME (TABLE INDEXING)

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 147. Port Numbering Scheme

## Packet\_Buffer\_Channel\_Congestion\_Threshold

Description: Per-channel congestion thresholds.

### Table 198. Packet\_Buffer\_Channel\_Congestion\_Threshold Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_b800 |
| Register Size      | 208         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 52          |
| Record Spacing     | 4           |

|   | 0  | 1  | 2    | 3    | 4     | 5    | 6     | 7     | 8     | 9     | 10   | 11 | 12 | 13 | 14 | 15 | 16 | 17   | 18    | 19  | 20   | 21   | 22   | 23    | 24    | 25   | 26    | 27   | 28 | 29 | 30 | 31 |
|---|----|----|------|------|-------|------|-------|-------|-------|-------|------|----|----|----|----|----|----|------|-------|-----|------|------|------|-------|-------|------|-------|------|----|----|----|----|
|   | 31 | 30 | 29   | 28   | 27    | 26   | 25    | 24    | 23    | 22    | 21   | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13    | 12  | 11   | 10   | 9    | 8     | 7     | 6    | 5     | 4    | 3  | 2  | 1  | 0  |
| 0 |    | ma | ac_c | hanr | nel_a | cong | estic | on_th | nresl | hold[ | 14:4 | ]  | 0  | 0  | 0  | 0  |    | poli | icer_ | cha | nnel | _coi | nges | tion_ | _thre | esho | ld[14 | 1:4] | 0  | 0  | 0  | 0  |

### Figure 148. Packet\_Buffer\_Channel\_Congestion\_Threshold Register Diagram

### Table 199. Packet\_Buffer\_Channel\_Congestion\_Threshold Field Parameters

| Field Name                                 | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                                       |
|--------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mac_channel_congestion_threshold[14:4]     | Mode = R/W<br>Offset = 0.1<br>Instances = 1  | When the number of buffers allocated to the cor-<br>responding channel equals or exceeds this<br>value, the channel is considered congested. The<br>number of buffers allocated must drop below<br>congestion_threshold[14:4] minus<br>global_congestion_hysteresis[9:4] for<br>the channel's state to change from congested to<br>not congested. |
|                                            |                                              | The results of this congestion test are provided to the Ethernet MACs.                                                                                                                                                                                                                                                                            |
| policer_channel_congestion_threshold[14:4] | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | When the number of buffers allocated to the cor-<br>responding channel equals or exceeds this<br>value, the channel is considered congested. The<br>number of buffers allocated must drop below<br>congestion_threshold[14:4] minus<br>global_congestion_hysteresis[9:4] for<br>the channel's state to change from congested to<br>not congested. |
|                                            |                                              | The results of this congestion test are provided<br>to the policers within the packet_processor<br>modules.                                                                                                                                                                                                                                       |

## Packet\_Buffer\_Crc\_Error\_Mask

Description: Identifies those ports to be eliminated as destinations in the event of a receive CRC error.

#### Table 200. Packet\_Buffer\_Crc\_Error\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bc48 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 149. Packet\_Buffer\_Crc\_Error\_Mask Register Diagram

#### Table 201. Packet\_Buffer\_Crc\_Error\_Mask Field Parameters

| Field Name           | Parameters                                               | Description         |
|----------------------|----------------------------------------------------------|---------------------|
| crc_error_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The CRC error mask. |

If the packet is received with a CRC error (or some other form of receive error that indicates corrupted or unreliable packet data), then the ports identified by this mask are eliminated as destinations for the packet. Asserted bits in crc\_error\_mask[57:0] identify those ports that are eliminated (masked) by this function. Deasserted bits in crc\_error\_mask[57:0] have no effect on the packet's destination port map.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 150. Port Numbering Scheme

## Packet\_Buffer\_Descriptor\_Congestion\_Threshold

Description: Global descriptor congestion thresholds.

### Table 202. Packet\_Buffer\_Descriptor\_Congestion\_Threshold Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bc5c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2   | 3    | 4     | 5     | 6    | 7     | 8    | 9    | 10    | 11   | 12 | 13 | 14 | 15 | 16 | 17 | 18    | 19   | 20    | 21     | 22   | 23    | 24   | 25    | 26    | 27    | 28 | 29 | 30 | 31 |
|---|----|----|-----|------|-------|-------|------|-------|------|------|-------|------|----|----|----|----|----|----|-------|------|-------|--------|------|-------|------|-------|-------|-------|----|----|----|----|
|   | 31 | 30 | 29  | 28   | 27    | 26    | 25   | 24    | 23   | 22   | 21    | 20   | 19 | 18 | 17 | 16 | 15 | 14 | 13    | 12   | 11    | 10     | 9    | 8     | 7    | 6     | 5     | 4     | 3  | 2  | 1  | 0  |
| 0 |    |    | mac | _des | scrip | tor_c | cong | estio | n_th | resh | old[1 | 3:4] | 0  | 0  | 0  | 0  |    |    | polic | er_d | escri | iptor_ | _con | gesti | on_t | hresl | nold[ | 13:4] | 0  | 0  | 0  | 0  |

### Figure 151. Packet\_Buffer\_Descriptor\_Congestion\_Threshold Register Diagram

### Table 203. Packet\_Buffer\_Descriptor\_Congestion\_Threshold Field Parameters

| Field Name                                    | Parameters                                   | Description                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mac_descriptor_congestion_threshold[13:4]     | Mode = R/W<br>Offset = 0.2<br>Instances = 1  | When the number of descriptors allocated equals or<br>exceeds this value, the packet buffer is considered<br>congested. The number of descriptors allocated<br>must drop below<br>congestion_threshold[13:4] minus<br>global_congestion_hysteresis[9:4] for the<br>state to change from congested to not congested. |
|                                               |                                              | The results of this congestion test are provided to the Ethernet MACs.                                                                                                                                                                                                                                              |
|                                               |                                              | <b>Note:</b> For proper operation, the maximum value for this field should be 0x1E0 or less.                                                                                                                                                                                                                        |
| policer_descriptor_congestion_threshold[13:4] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | congested. The number of descriptors allocated<br>must drop below<br>congestion_threshold[13:4] minus<br>global_congestion_hysteresis[9:4] for the<br>state to change from congested to not congested.                                                                                                              |
|                                               |                                              | The results of this congestion test are provided to the policers within the packet_processor mod-<br>ules.                                                                                                                                                                                                          |
|                                               |                                              | <b>Note:</b> For proper operation, the maximum value for this field should be 0x1E0 or less.                                                                                                                                                                                                                        |

Packet descriptors are managed in four groups. The global thresholds defined by this register apply to all four groups. If any one of the four groups exceed an allocation threshold, then the threshold is considered crossed by all four groups.

### Packet\_Buffer\_Descriptor\_Usage\_Count

Description: Provides a real-time indication of the number of descriptors allocated to each port group.

#### Table 204. Packet\_Buffer\_Descriptor\_Usage\_Count Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bb60 |
| Register Size      | 16          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 4           |
| Record Spacing     | NA          |



### Figure 152. Packet\_Buffer\_Descriptor\_Usage\_Count Register Diagram

| Table 205. Packet_Buffer_Descri | ptor_Usage_Count Field Parameters |
|---------------------------------|-----------------------------------|
|---------------------------------|-----------------------------------|

| Field Name                   | Parameters                                   | Description                                                               |
|------------------------------|----------------------------------------------|---------------------------------------------------------------------------|
| descriptor_usage_count[13:0] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | The number of descriptors allocated to the corre-<br>sponding port group. |

This register provides a real-time indication of the number of descriptors that have been allocated to one of four port groups. Ports are grouped together as follows:

#### Table 206. Port/Group Associations

| Group | Ports                                            |
|-------|--------------------------------------------------|
| 0     | 0, 4, 8, 12, 16, 20, 24, 28, 32, 36, 40, 44, 50  |
| 1     | 1, 5, 9, 13, 17, 21, 25, 29, 33, 37, 41, 45, 50  |
| 2     | 2, 6, 10, 14, 18, 22, 26, 30, 34, 38, 42, 46, 60 |
| 3     | 3, 7, 11, 15, 19, 23, 27, 31, 35, 39, 43, 47, 60 |

### Packet\_Buffer\_Discard\_Mask

Description: Identifies those ports to be eliminated as destinations in the event of a discard indication.

### Table 207. Packet\_Buffer\_Discard\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bc50 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 153. Packet\_Buffer\_Discard\_Mask Register Diagram

#### Table 208. Packet\_Buffer\_Discard\_Mask Field Parameters

| Field Name         | Parameters                                               | Description       |
|--------------------|----------------------------------------------------------|-------------------|
| discard_mask[57:0] | Mode = R/W<br>Offset = 0.6<br>Instances = 1<br>Reset = 0 | The discard mask. |

If the packet is marked for discard by some ingress process, then the ports identified by this mask are eliminated as destinations for the packet. Asserted bits in discard\_mask[57:0] identify those ports that are eliminated (masked) by this function. Deasserted bits in discard\_mask[57:0] have no effect on the packet's destination port map.

#### PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 154. Port Numbering Scheme

# Packet\_Buffer\_Free\_Buffer\_Control

Description: Free buffer list initialization controls.

#### Table 209. Packet\_Buffer\_Free\_Buffer\_Control Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bb70 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |





| Field Name                       | Parameters                                  | Description                                                                                                                                     |
|----------------------------------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| free_buffer_initialization_start | Mode = WO<br>Offset = 0.30<br>Instances = 1 | Writing a one to this bit starts the initialization pro-<br>cess for the free buffer list.                                                      |
| free_buffer_initialization_done  | Mode = RO<br>Offset = 0.31<br>Instances = 1 | This bit indicates that the initialization of the free<br>buffer list is complete. This bit is deasserted during<br>the initialization process. |

Free buffer list initialization controls.

## Packet\_Buffer\_Free\_Buffer\_Count\_Even

Description: Provides a real-time indication of the number of free buffers.

#### Table 211. Packet\_Buffer\_Free\_Buffer\_Count\_Even Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bb84 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15   | 16   | 17    | 18   | 19    | 20   | 21   | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|-------|------|-------|------|------|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   | 15   | 14    | 13   | 12    | 11   | 10   | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | free | _buf | fer_o | coun | it_ev | en[1 | 2:0] |    |    |    |    |    |    |    |    |    |    |

### Figure 156. Packet\_Buffer\_Free\_Buffer\_Count\_Even Register Diagram

| Field Name                   | Parameters                                  | Description                                                |
|------------------------------|---------------------------------------------|------------------------------------------------------------|
| free_buffer_count_even[12:0] | Mode = WO<br>Offset = 0.19<br>Instances = 1 | The number of buffers available for allocation to storage. |

This register provides a real-time indication of the number of buffers that reside on the free list. Smaller numbers read here indicate greater levels of congestion.

This register corresponds to all even-numbered buffers.

## Packet\_Buffer\_Free\_Buffer\_Count\_Odd

Description: Provides a real-time indication of the number of free buffers.

#### Table 213. Packet\_Buffer\_Free\_Buffer\_Count\_Odd Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bb88 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |





| Field Name                  | Parameters                                  | Description                                                |
|-----------------------------|---------------------------------------------|------------------------------------------------------------|
| free_buffer_count_odd[12:0] | Mode = WO<br>Offset = 0.19<br>Instances = 1 | The number of buffers available for allocation to storage. |

This register provides a real-time indication of the number of buffers that reside on the free list. Smaller numbers read here indicate greater levels of congestion.

This register corresponds to all odd-numbered buffers.

## Packet\_Buffer\_Free\_Descriptor\_Control

Description: Free buffer list initialization controls.

### Table 215. Packet\_Buffer\_Free\_Descriptor\_Control Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|--|
| Base Address       | 0x000c_bb74 |  |  |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### Figure 158. Packet\_Buffer\_Free\_Descriptor\_Control Register Diagram

#### Table 216. Packet\_Buffer\_Free\_Descriptor\_Control Field Parameters

| Field Name                           | Parameters                                  | Description                                                                                                                                   |  |  |  |  |  |  |  |  |
|--------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| free_descriptor_initialization_start | Mode = WO<br>Offset = 0.30<br>Instances = 1 | Writing a one to this bit starts the initialization proces for the free descriptor list.                                                      |  |  |  |  |  |  |  |  |
| free_descriptor_initialization_done  | Mode = RO<br>Offset = 0.31<br>Instances = 1 | This bit indicates that the initialization of the free descriptor list is complete. This bit is deasserted during the initialization process. |  |  |  |  |  |  |  |  |

Free descriptor list initialization controls.

# Packet\_Buffer\_Global\_Congestion\_Threshold

Description: Global congestion thresholds.

### Table 217. Packet\_Buffer\_Global\_Congestion\_Threshold Register Parameters

| Parameter          | Value           0x000c_bc60 |  |  |  |  |  |  |  |
|--------------------|-----------------------------|--|--|--|--|--|--|--|
| Base Address       |                             |  |  |  |  |  |  |  |
| Register Size      | 4                           |  |  |  |  |  |  |  |
| Register Instances | 1                           |  |  |  |  |  |  |  |
| Register Spacing   | NA                          |  |  |  |  |  |  |  |
| Record Size        | 4                           |  |  |  |  |  |  |  |
| Record Instances   | 1                           |  |  |  |  |  |  |  |
| Record Spacing     | NA                          |  |  |  |  |  |  |  |

|   | 0  | 1  | 2    | 3     | 4     | 5    | 6     | 7    | 8    | 9     | 10 1 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18    | 19   | 20   | 21  | 22   | 23   | 24    | 25    | 26    | 27 | 28 | 29 | 30 | 31 |
|---|----|----|------|-------|-------|------|-------|------|------|-------|------|----|----|----|----|----|----|----|-------|------|------|-----|------|------|-------|-------|-------|----|----|----|----|----|
|   | 31 | 30 | 29   | 28    | 27    | 26   | 25    | 24   | 23   | 22    | 21 2 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13    | 12   | 11   | 10  | 9    | 8    | 7     | 6     | 5     | 4  | 3  | 2  | 1  | 0  |
| 0 |    | m  | ac_( | globa | al_co | onge | estio | n_th | resh | old[1 | 4:4] |    | 0  | 0  | 0  | 0  |    | ро | licer | _glc | bal_ | con | gest | ion_ | thres | sholo | d[14: | 4] | 0  | 0  | 0  | 0  |

### Figure 159. Packet\_Buffer\_Global\_Congestion\_Threshold Register Diagram

| Field Name                                | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mac_global_congestion_threshold[14:4]     | Mode = R/W<br>Offset = 0.1<br>Instances = 1  | When the total number of buffers allocated (128 bytes)<br>equals or exceeds this value, the packet buffer is con-<br>sidered congested. The number of buffers allocated<br>must drop below congestion_threshold[14:4]<br>minusglobal_congestion_hysteresis[9:4] for<br>the state to change from congested to not congested. |
|                                           |                                              | The results of this congestion test are provided to the Ethernet MACs.                                                                                                                                                                                                                                                      |
|                                           |                                              | <b>Note:</b> For proper operation, the maximum value for this field should be 0x2F8 or less.                                                                                                                                                                                                                                |
| policer_global_congestion_threshold[14:4] | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | When the total number of buffers allocated (128 bytes)<br>equals or exceeds this value, the packet buffer is con-<br>sidered congested. The number of buffers allocated<br>must drop below congestion_threshold[14:4]<br>minusglobal_congestion_hysteresis[9:4] for<br>the state to change from congested to not congested. |
|                                           |                                              | The results of this congestion test are provided to the policers within the packet_processor modules.                                                                                                                                                                                                                       |
|                                           |                                              | <b>Note:</b> For proper operation, the maximum value for this field should be 0x2F8 or less.                                                                                                                                                                                                                                |

Packet buffer congestion thresholds.

## Packet\_Buffer\_Ind

Description: Provides supervisor indications from <code>packet\_buffer</code>.

### Table 219. Packet\_Buffer\_Ind Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|
| Base Address       | 0x000c_bb40 |  |  |  |  |  |  |
| Register Size      | 32          |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |





### Table 220. Packet\_Buffer\_Ind Field Parameters

| Field Name                        | Parameters                                   | Description                                                                                                                                                                                                                                                     |
|-----------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| packet_buffer_parity_error        | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | When a parity error occurs within the packet buffer memory,<br>this indication is asserted. The location of the error is deter-<br>mined by reading Packet_Buffer_Parity_Error_Info.<br>This indication is reset by writing a one to this bit location.         |
| free_buffer_list_parity_error     | Mode = R/W<br>Offset = 0.26<br>Instances = 1 | When a parity error occurs within the free buffer list memory,<br>this indication is asserted. The location of the error is deter-<br>mined by reading<br>Packet_Buffer_Parity_Error_Info. This indication is<br>reset by writing a one to this bit location.   |
| free_descriptor_list_parity_error | Mode = R/W<br>Offset = 0.27<br>Instances = 1 | When a parity error occurs within the free descriptor list<br>memory, this indication is asserted. The location of the error<br>is determined by reading<br>Packet_Buffer_Parity_Error_Info. This indication is<br>reset by writing a one to this bit location. |

## Packet\_Buffer\_Ind (continued)

### Table 220. Packet\_Buffer\_Ind Field Parameters (continued)

| Field Name                        | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| free_buffer_list_empty            | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | If a packet is discarded due to an exhaustion of free buffers,<br>this indication is asserted. This indication is reset by writing a<br>one to this bit location.                                                                                                                                                                                                   |
| free_descriptor_list_empty        | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | If a packet is discarded due to an exhaustion of free descrip-<br>tors, this indication is asserted. This indication is reset by<br>writing a one to this bit location.                                                                                                                                                                                             |
| queue_full                        | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | If a packet is discarded due to full queue, this indication is<br>asserted. The identity of the queue that caused this indica-<br>tion is determined by reading<br>Packet_Buffer_Queue_Full_Info. This indication is<br>reset by writing a one to this bit location.                                                                                                |
| rate_adaptation_fifo_overflow     | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | If a packet is discarded due to an overflow of the rate adapta-<br>tion FIFO (used during multicast replication), this indication is<br>asserted. This indication is reset by writing a one to this bit<br>location.                                                                                                                                                |
| packet_buffer_ind_mask[6:0]       | Mode = RO<br>Offset = 4.25<br>Instances = 1  | This field provides the supervisor with the current settings of<br>the indication mask. Bits asserted in this field prevent the<br>indication bits listed above from becoming asserted. Bits in<br>packet_buffer_ind_mask[6:0] are set and cleared via<br>the fields packet_buffer_ind_mask_set[6:0] and<br>packet_buffer_ind_mask_clear[6:0] below.                |
| packet_buffer_ind_mask_set[6:0]   | Mode = WO<br>Offset = 8.25<br>Instances = 1  | Writing ones to bits in this field causes the corresponding bits to become asserted in packet_buffer_ind_mask[6:0].                                                                                                                                                                                                                                                 |
| packet_buffer_ind_mask_clear[6:0] | Mode = WO<br>Offset = 12.25<br>Instances = 1 | Writing ones to bits in this field causes the corresponding bits to become deasserted in packet_buffer_ind_mask[6:0].                                                                                                                                                                                                                                               |
| packet_buffer_int[6:0]            | Mode = RO<br>Offset = 16.25<br>Instances = 1 | The unmasked indication bits that are also not masked by <pre>packet_buffer_int_mask[6:0]</pre> are revealed to the <pre>supervisor via this field.</pre>                                                                                                                                                                                                           |
| packet_buffer_int_mask[6:0]       | Mode = RO<br>Offset = 20.25<br>Instances = 1 | This field provides the supervisor with the current settings of<br>the indication mask. Bits asserted in this field prevent the<br>interrupt bits in packet_buffer_int[6:0] from becoming<br>asserted. Bits in packet_buffer_int_mask[6:0] are set<br>and cleared via the fields<br>packet_buffer_int_mask_set[6:0] and<br>packet_buffer_int_mask_clear[6:0] below. |
| packet_buffer_int_mask_set[6:0]   | Mode = WO<br>Offset = 24.25<br>Instances = 1 | Writing ones to bits in this field causes the corresponding bits to become asserted in packet_buffer_int_mask[6:0].                                                                                                                                                                                                                                                 |
| packet_buffer_int_mask_clear[6:0] | Mode = WO<br>Offset = 28.25<br>Instances = 1 | Writing ones to bits in this field causes the corresponding bits to become deasserted in packet_buffer_int_mask[6:0].                                                                                                                                                                                                                                               |

Various indications to the supervisor regarding packet\_buffer. These indications may be masked by  ${\tt Packet\_Buffer\_Ind\_Mask}$  .

Agere Systems Inc.

## Packet\_Buffer\_Mode

Description: Mode bits.

### Table 221. Packet\_Buffer\_Mode Register Parameters

| Value                                      |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| 0x000c_bc64                                |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| 4                                          |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| 1                                          |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| NA                                         |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| 4                                          |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| 1                                          |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
| NA                                         |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |
|                                            |                                                                                                                                                                                                           |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 20                                                                                                                                                                                                                                                                                              | 21                                                                                                                                                                                                                                                                     | 22                                                                                                                                                                                                                                                                                                                                             | 23                                                                                                                                                                                                                               | 24                                                                                                                                                                                                                                                                                                                                                                                                                                           | 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                              | 29                                                                                                                                                                                                                                                                                                                    | 30                                                                                                                                                                                                                                                                                                                             |                                                                                                                 |
| 25   24   23   22   21   20   19   18   17 | 16 15                                                                                                                                                                                                     | 14 <sub>1</sub> 1                                                                                                                                                                                                                         | 3 12                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 11                                                                                                                                                                                                                                                                                              | 10                                                                                                                                                                                                                                                                     | 9                                                                                                                                                                                                                                                                                                                                              | 8                                                                                                                                                                                                                                | 7                                                                                                                                                                                                                                                                                                                                                                                                                                            | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 5                                                                                                                                                                                                                                                                                          | 4                                                                                                                                                                                                                                                                                                   | 3                                                                                                                                                                                                                                                                                                            | 2                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                              |                                                                                                                 |
|                                            | 0x000c_bc64           4           1           NA           4           1           NA           6         7           8         9           10         11           12         13           14         14 | 0x000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           9         10         11         12         13         14         15         16 | Ox000c_bc64           4           1           NA           4           1           NA           6           7         8           9         10           11         12           12         13           14         15           15         16           11         12           12         13           14         15           15         16           11         12           12         13           14         15           15         16           16         17 | Ox000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           9         10           11         12           12         13           14         15           15         16           17         18 | Ox000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           8         9           11         12           13         14           15         16           11         12 | Ox000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           8         9           11         12           12         13           14         15           15         16           17         18           18         19           20         21 | 0x000c_bc64         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22 | Ox000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           8         9           11         12           13         14           15         16           11         12           12         13           14         15           15         16           17         18           18         19           20         21         22         23 | Ox000c_bc64           4           1           NA           4           1           NA           4           1           NA           6         7           8         9           10         11           12         13           14         15           15         16           17         18           18         19           20         21         22         23           24         12         13         14         15         16         17         18         19         20         21         22         23         24 | 0x000c_bc64         4         1         NA         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22       23       24       25 | 0x000c_bc64         4         1         NA         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22       23       24       25       26 | 0x000c_bc64         4         1         NA         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22       23       24       25       26       27 | 0x000c_bc64         4         1         NA         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22       23       24       25       26       27       28 | 0x000c_bc64         4         1         NA         4         1         NA         4         1         NA         6       7       8       9       10       11       12       13       14       15       16       17       18       19       20       21       22       23       24       25       26       27       28       29 | 0x000c_bc64           4           1           NA           4           1           NA           NA           NA |

### Figure 161. Packet\_Buffer\_Mode Register Diagram

#### Table 222. Packet\_Buffer\_Mode Field Parameters

| Field Name                        | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| global_congestion_hysteresis[9:4] | Mode = R/W<br>Offset = 22<br>Instances = 1   | This field establishes the congestion hysteresis. The number of allocated buffers must fall below global_congestion_threshold[14:8] minus global_congestion_hysteresis[9:4] for the state to change from congested to not congested. This hysteresis value is shared by all congestion thresholds.                                                                                                                       |
| hol_mode                          | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | When asserted, packet_buffer utilizes queue and buffer<br>thresholds to manage and avoid head-of-line blocking scenarios in<br>the shared resources.<br>When this bit is asserted, the<br>Packet_Buffer_Queue_Management_Threshold,<br>Packet_Buffer_Queue_Limit, and<br>Packet_Buffer_Queue_Buffer_Limit registers may be<br>programmed. This bit is valid only in revision C and is reserved in<br>revisions B and B1. |
| bandwidth_provisioning_en         | Mode = R/W<br>Offset = 30<br>Instances = 1   | This bit is asserted to enable the bandwidth provisioning (traffic shaping) algorithms. When this mode is enabled, a queue must be nonempty <b>and</b> below its bandwidth limit prior to transmission. When this mode is disabled, a queue need only be nonempty to arbitrate for transmission.                                                                                                                         |
| weighted_round_robin_en           | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | When asserted, packet_buffer utilizes a weighted round-robin<br>arbitration method among the queues that are ready to transmit for<br>a particular port. Otherwise, strict priority is used. Readiness for<br>transmission is determined by the traffic-shaping algorithms.                                                                                                                                              |

Various basic mode bits related to packet\_buffer.

## Packet\_Buffer\_Packet\_Drop\_Count

Description: Provides an accounting of various packet drop counts.

#### Table 223. Packet\_Buffer\_Packet\_Drop\_Count Register Parameters

| Parameter                         | Value       |
|-----------------------------------|-------------|
| Base Address                      | 0x000c_bb00 |
| Register Size (revision B and B1) | 52          |
| Register Size (revision C)        | 56          |
| Register Instances                | 1           |
| Register Spacing                  | NA          |
| Record Size (revision B and B1)   | 52          |
| Record Size (revision C)          | 56          |
| Record Instances                  | 1           |
| Record Spacing                    | NA          |

#### 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

| 0  | rxpc_correlator_discard_drop_count[31:0]   |
|----|--------------------------------------------|
| 4  | destination_port_map_zero_drop_count[31:0] |
| 8  | replication_fifo_full_drop_count[31:0]     |
| 12 | pdp_parity_error_drop_count[31:0]          |
| 16 | rxpc_runt_packet_drop_count_0[31:0]        |
| 20 | rxpc_runt_packet_drop_count_1[31:0]        |
| 24 | rxpc_runt_packet_drop_count_2[31:0]        |
| 28 | rxpc_runt_packet_drop_count_3[31:0]        |
| 32 | rxpc_runt_packet_drop_count_4[31:0]        |
| 36 | rxpc_runt_packet_drop_count_5[31:0]        |
| 40 | rxpc_runt_packet_drop_count_6[31:0]        |
| 44 | rxpc_txpc_discard_drop_count[31:0]         |
| 48 | replication_partial_drop_count[31:0]       |
| 52 | port_map_changed_drop_count[31:0]          |

### Figure 162. Packet\_Buffer\_Packet\_Drop\_Count Register Diagram

# Packet\_Buffer\_Packet\_Drop\_Count (continued)

### Table 224. Packet\_Buffer\_Drop\_Count Field Parameters

| Field Name                                 | Parameters                                   | Description                                                                                                                                                               |
|--------------------------------------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rxpc_correlator_discard_drop_count[31:0]   | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | The number of packets dropped because of the correlator function in the rxpc module.                                                                                      |
| destination_port_map_zero_drop_count[31:0] | Mode = R/W<br>Offset = 4.0<br>Instances = 1  | The number of packets dropped because of a null (all zeros) destination map.                                                                                              |
| replication_fifo_full_drop_count[31:0]     | Mode = R/W<br>Offset = 8.0<br>Instances = 1  | The number of packets dropped due to a full replication FIFO.                                                                                                             |
| pdp_parity_error_drop_count[31:0]          | Mode = R/W<br>Offset = 12.0<br>Instances = 1 | The number of packets dropped due to a parity error in the pdp module.                                                                                                    |
| rxpc_runt_packet_drop_count_0[31:0]        | Mode = R/W<br>Offset = 16.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 0.                                                                                                                |
| rxpc_runt_packet_drop_count_1[31:0]        | Mode = R/W<br>Offset = 20.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 1.                                                                                                                |
| rxpc_runt_packet_drop_count_2[31:0]        | Mode = R/W<br>Offset = 24.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 2.                                                                                                                |
| rxpc_runt_packet_drop_count_3[31:0]        | Mode = R/W<br>Offset = 28.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 3.                                                                                                                |
| rxpc_runt_packet_drop_count_4[31:0]        | Mode = R/W<br>Offset = 32.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 4.                                                                                                                |
| rxpc_runt_packet_drop_count_5[31:0]        | Mode = R/W<br>Offset = 36.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 5.                                                                                                                |
| rxpc_runt_packet_drop_count_6[31:0]        | Mode = R/W<br>Offset = 40.0<br>Instances = 1 | The number of runt packets dropped for packet_processor 6.                                                                                                                |
| rxpc_txpc_discard_drop_count[31:0]         | Mode = R/W<br>Offset = 44.0<br>Instances = 1 | The number of packets discarded due to a full packet buffer.                                                                                                              |
| replication_partial_drop_count[31:0]       | Mode = R/W<br>Offset = 48.0<br>Instances = 1 | The number of multicast packets partially enqueued due to full queues.                                                                                                    |
| port_map_changed_drop_count[31:0]          | Mode = R/W<br>Offset =52.0<br>Instances = 1  | The number of multicast packets causing modi-<br>fied port maps due to full queues. This field is<br>valid only in revision C and is reserved in revi-<br>sions B and B1. |

Various basic mode bits related to packet\_buffer.

## Packet\_Buffer\_Parity\_Error\_Info

Description: Provides the location of the occurrence of a parity error.

#### Table 225. Packet\_Buffer\_Parity\_Error\_Info Register Parameters

| Parameter          | Value       |  |
|--------------------|-------------|--|
| Base Address       | 0x000c_bb78 |  |
| Register Size      | 4           |  |
| Register Instances | 1           |  |
| Register Spacing   | NA          |  |
| Record Size        | 4           |  |
| Record Instances   | 1           |  |
| Record Spacing     | NA          |  |





#### Table 226. Packet\_Buffer\_Parity\_Error\_Info Field Parameters

| Field Name         | Parameters                                   | Description                                   |
|--------------------|----------------------------------------------|-----------------------------------------------|
| memory_device[5:0] | Mode = R/W<br>Offset = 0.11<br>Instances = 1 | The device that experienced the parity error. |
| memory_addr[14:0]  | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | The address of the parity error.              |

Upon the first occurrence of a parity error, this register stores and presents a value that identifies which device experienced the error and the address within the device that was being accessed at the time of the error. Further parity errors do not cause changes to the value held by this register. In order to reprime this register for the capture of a subsequent error, all packet\_buffer-related parity error indication bits in Packet\_Buffer\_Ind must first be reset.

## Packet\_Buffer\_Port\_Speed

Description: Provides the port speed information to the traffic shapers.

#### Table 227. Packet\_Buffer\_Port\_Speed Register Parameters

| Parameter                    | Value                                                                                                                               | ]                                                                |       |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-------|
| Base Address                 | 0x000c_bd00                                                                                                                         | 1                                                                |       |
| Register Size                | 192                                                                                                                                 | 1                                                                |       |
| Register Instances           | 1                                                                                                                                   |                                                                  |       |
| Register Spacing             | NA                                                                                                                                  |                                                                  |       |
| Record Size                  | 192                                                                                                                                 |                                                                  |       |
| Record Instances             | 1                                                                                                                                   | -                                                                |       |
| Record Spacing               | NA                                                                                                                                  | -                                                                |       |
|                              |                                                                                                                                     | -                                                                |       |
| 0 1 2 3 4 5 6 7 8 9          | 10 11 12 13 14 15 16 17 1                                                                                                           | 18 19 20 21 22 23 24 25 26 27 28 29 3                            | 30 3  |
| 31 30 29 28 27 26 25 24 23 2 | 2 <sub> </sub> 21 <sub> </sub> 20 <sub> </sub> 19 <sub> </sub> 18 <sub> </sub> 17 <sub> </sub> 16 15 <sub> </sub> 14 <sub> </sub> 1 | 13   12   11   10   9   8   7 <sub> </sub> 6   5   4   3   2   1 | 1   0 |
| 0                            |                                                                                                                                     |                                                                  |       |

### Figure 164. Packet\_Buffer\_Port\_Speed Register Diagram

#### Table 228. Packet\_Buffer\_Port\_Speed Field Parameters

| Field Name            | Parameters                                                     | Description                                                                                                               |
|-----------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| port_speed_{047}[1:0] | Mode = R/W<br>Offset = 0.30<br>Instances = 48<br>Spacing = 4.0 | The speed of the corresponding Ethernet MAC.<br>002 = 10 Mbits/s<br>012 = 100 Mbits/s<br>102 = 1 Gbit/s<br>112 = reserved |

This register provides per-port interface speed information to the traffic shapers. This register does not actually affect the speed of the Ethernet ports; it merely informs the packet buffer of the speed at which each port is operating.

PORT NUMBERING SCHEME

| PORT      | SU7 | SU6 | <br>SU1 | SU0 | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|---------|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 57  | 56  | <br>51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 165. Port Numbering Scheme

## Packet\_Buffer\_Priority\_Table

Description: Maps the 4-bit packet priority value to one of eight transmit queues.

#### Table 229. Packet\_Buffer\_Priority\_Table Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|
| Base Address       | 0x000c_bc00 |  |  |  |  |  |  |
| Register Size      | 64          |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |
| Record Size        | 1           |  |  |  |  |  |  |
| Record Instances   | 16          |  |  |  |  |  |  |
| Record Spacing     | 4           |  |  |  |  |  |  |



### Figure 166. Packet\_Buffer\_Priority\_Table Register Diagram

#### Table 230. Packet\_Buffer\_Priority\_Table Field Parameters

| Field Name                  | Parameters                                   | Description             |
|-----------------------------|----------------------------------------------|-------------------------|
| storage_priority_{015}[2:0] | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | Storage priority value. |

The 16 levels of priority utilized during ingress packet processing are used to select one of eight transmit queues associated with each transmit port. This table is used to map between various priority levels and queues. This table is addressed by the packet's priority level and returns the 3-bit queue selection value: storage\_priority[2:0].

# Packet\_Buffer\_Queue\_Buffer\_Limit (Revision C Only)

Description: Global queue entry limit (in buffers) imposed when queue memory is congested.

### Table 231. Packet\_Buffer\_Queue\_Buffer\_Limit Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000C_E200 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 167. Packet\_Buffer\_Queue\_Buffer\_Limit Register Diagram

| Field Name                          | Parameters                                   | Description             |
|-------------------------------------|----------------------------------------------|-------------------------|
| supervisor_queue_buffer_limit[14:0] | Mode = R/W<br>Offset = 0.1<br>Instances = 1  | Supervisor queue limit. |
| queue_buffer_limit[14:0]            | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | Queue limit.            |

This register defines the number of buffers (128 bytes) that each queue is allowed to use during times of packet buffer congestion. If the buffer memory is congested and the number of buffers used for any supervisor queue exceeds supervisor\_queue\_buffer\_limit[14:0] or the number of queued buffers for any other queue exceeds queue\_buffer\_limit[14:0], then that queue is disabled from receiving further entries. If a queue is in excess of this limit when the packet buffer becomes congested, its excess queue entries are not discarded; only new entries are inhibited from being enqueued.

This register is valid in revision C only, and the hol\_mode bit in the Packet\_Buffer\_Mode register must be asserted to use this register.

## Packet\_Buffer\_Queue\_Buffers\_{0..3} (Revision C Only)

Description: The number of buffers associated with each queue.

#### Table 233. Packet\_Buffer\_Queue\_Buffers\_{0..3} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000C_DA00 |
| Register Size      | 424         |
| Register Instances | 4           |
| Register Spacing   | 512         |
| Record Size        | 4           |
| Record Instances   | 106         |
| Record Spacing     | 4           |



### Figure 168. Packet\_Buffer\_Queue\_Buffers\_{0..3} Register Diagram

|  | Table 234. Packet | Buffer Queue | Buffers {03 | Field Parameters |
|--|-------------------|--------------|-------------|------------------|
|--|-------------------|--------------|-------------|------------------|

| Field Name          | Parameter                                    | Description                                                         |
|---------------------|----------------------------------------------|---------------------------------------------------------------------|
| queue_buffers[14:0] | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | The number of buffers associated with the corre-<br>sponding queue. |

This register provides the supervisor with the number of buffers that are currently associated with each of the queues. The queues are grouped according to the following table.

# Packet\_Buffer\_Queue\_Buffers\_{0..3} (Revision C Only) (continued)

### Table 235. Queue Groups

|        | Group 0 | Group 1 | Group 2 | Group 3 |
|--------|---------|---------|---------|---------|
| Queues | 0—7     | 8—15    | 16—23   | 24—31   |
|        | 32—39   | 40—47   | 48—55   | 56—63   |
|        | 64—71   | 72—79   | 80—87   | 88—95   |
|        | 96—103  | 104—111 | 112—119 | 120—127 |
|        | 128—135 | 136—143 | 144—151 | 152—159 |
|        | 160—167 | 168—175 | 176—183 | 184—191 |
|        | 192—199 | 200—207 | 208—215 | 216—223 |
|        | 224—231 | 232—239 | 240—247 | 248—255 |
|        | 256—263 | 264—271 | 272—279 | 280—287 |
|        | 288—295 | 296—303 | 304—311 | 312—319 |
|        | 320—327 | 328—335 | 336—343 | 344—351 |
|        | 352—359 | 360—367 | 368—375 | 376—383 |
|        | 384—391 | 384—391 | 392—399 | 392—399 |
|        | 400     | 402     | 404     | 406     |
|        | 401     | 403     | 405     | 407     |

#### QUEUE NUMBERING SCHEME

|                              | U7 | SU6 |  | SU1                                                             | SU0 | > | (G1 |  |  | XG0 |  |  | G47 |  |  | G46 |  |  |  | G1 |  |  | G0 |  |
|------------------------------|----|-----|--|-----------------------------------------------------------------|-----|---|-----|--|--|-----|--|--|-----|--|--|-----|--|--|--|----|--|--|----|--|
| REFERENCE 4                  | 07 | 406 |  | 401 400 399   392 391   384 383   376 375   368    15     8   7 |     |   |     |  |  | 0   |  |  |     |  |  |     |  |  |  |    |  |  |    |  |
| G = 10/100/1000 Mbits/s PORT |    |     |  |                                                                 |     |   |     |  |  |     |  |  |     |  |  |     |  |  |  |    |  |  |    |  |

XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 169. Queue Numbering Scheme

## Packet\_Buffer\_Queue\_Depth\_{0..3} (Revision C Only)

Description: The number of entries in each queue.

### Table 236. Packet\_Buffer\_Queue\_Depth\_{0..3} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000C_D000 |
| Register Size      | 428         |
| Register Instances | 4           |
| Register Spacing   | 512         |
| Record Size        | 4           |
| Record Instances   | 107         |
| Record Spacing     | 4           |



### Figure 170. Packet\_Buffer\_Queue\_Depth\_{0..3} Register Diagram

| Field Name        | Parameter                                    | Description                                      |
|-------------------|----------------------------------------------|--------------------------------------------------|
| queue_depth[12:0] | Mode = R/W<br>Offset = 0.19<br>Instances = 1 | The depth of the corresponding queue in packets. |

This register provides the supervisor with the number of buffers that are currently associated with each of the queues. The queues are grouped according to the following table.

# Packet\_Buffer\_Queue\_Depth\_{0..3} (Revision C Only) (continued)

### Table 238. Queue Groups

|        | Group 0 | Group 1 | Group 2 | Group 3 |
|--------|---------|---------|---------|---------|
| Queues | 0—7     | 8—15    | 16—23   | 24—31   |
|        | 32—39   | 40—47   | 48—55   | 56—63   |
|        | 64—71   | 72—79   | 80—87   | 88—95   |
|        | 96—103  | 104—111 | 112—119 | 120—127 |
|        | 128—135 | 136—143 | 144—151 | 152—159 |
|        | 160—167 | 168—175 | 176—183 | 184—191 |
|        | 192—199 | 200—207 | 208—215 | 216—223 |
|        | 224—231 | 232—239 | 240—247 | 248—255 |
|        | 256—263 | 264—271 | 272—279 | 280—287 |
|        | 288—295 | 296—303 | 304—311 | 312—319 |
|        | 320—327 | 328—335 | 336—343 | 344—351 |
|        | 352—359 | 360—367 | 368—375 | 376—383 |
|        | 384—391 | 384—391 | 392—399 | 392—399 |
|        | 400     | 402     | 404     | 406     |
|        | 401     | 403     | 405     | 407     |
|        | Discard | Discard | Discard | Discard |

QUEUE NUMBERING SCHEME

| QUEUE     | SU7                                     | SU6           |  | SU1SU0 XG1 |  |  |  |  | ) | KG0 |   |  | G47 |  | ( | G46 | ; |  |  | G1 |  | G0 |  |  |  |
|-----------|-----------------------------------------|---------------|--|------------|--|--|--|--|---|-----|---|--|-----|--|---|-----|---|--|--|----|--|----|--|--|--|
| REFERENCE | 407                                     | <u>15 8 7</u> |  |            |  |  |  |  |   |     | 0 |  |     |  |   |     |   |  |  |    |  |    |  |  |  |
|           | G = 10/100/1000 Mbits/s PORT            |               |  |            |  |  |  |  |   |     |   |  |     |  |   |     |   |  |  |    |  |    |  |  |  |
|           | XG = 10 Gbits/s PORT<br>SU = SUPERVISOR |               |  |            |  |  |  |  |   |     |   |  |     |  |   |     |   |  |  |    |  |    |  |  |  |

#### Figure 171. Queue Numbering Scheme

## Packet\_Buffer\_Queue\_Limit (Revision C Only)

Description: Global queue entry in buffer limit imposed when queue memory is congested.

#### Table 239. Packet\_Buffer\_Queue\_Limit Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000C_E204 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 172. Packet\_Buffer\_Queue\_Limit Register Diagram

#### Table 240. Packet\_Buffer\_Queue\_Limit Field Parameters

| Field Name                   | Parameters                                   | Description             |
|------------------------------|----------------------------------------------|-------------------------|
| supervisor_queue_limit[12:0] | Mode = R/W<br>Offset = 0.1<br>Instances = 1  | Supervisor queue limit. |
| queue_limit[12:0]            | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | Queue limit.            |

This register defines the number of queue entries in packets that each queue is allowed to have during times of queue memory congestion. If the queue memory is congested and the number of queue entries for any supervisor queue exceeds the supervisor\_queue\_limit[12:0] or for any other queue exceeds the gueue limit[12:0] value, then that queue is disabled from receiving further entries. If a queue is in excess of

queue\_limit[12:0] value, then that queue is disabled from receiving further entries. If a queue is in excess of its limit when the queue memory becomes congested, its excess queue entries are not discarded; only new entries are inhibited from being enqueued.

This register is valid in revision C only, and the hol\_mode bit in the packet\_buffer\_mode register must be asserted to use this register.

## Packet\_Buffer\_Queue\_Management\_Thresholds (Revision C Only)

Description: Global queue congestion thresholds.

### Table 241. Packet\_Buffer\_Queue\_Management\_Thresholds Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000C_E208 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2    | 3    | 4     | 5    | 6     | 7     | 8    | 9     | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17   | 18   | 19   | 20    | 21    | 22   | 23    | 24    | 25   | 26     | 27   | 28 | 29 | 30 | 31 |
|---|----|----|------|------|-------|------|-------|-------|------|-------|----|----|----|----|----|----|----|------|------|------|-------|-------|------|-------|-------|------|--------|------|----|----|----|----|
|   | 31 | 30 | 29   | 28   | 27    | 26   | 25    | 24    | 23   | 22    | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14   | 13   | 12   | 11    | 10    | 9    | 8     | 7     | 6    | 5      | 4    | 3  | 2  | 1  | 0  |
| 0 |    | qı | Jeue | _mas | sk_co | onge | stion | _thre | shol | d[14: | 4] |    | 0  | 0  | 0  | 0  |    | buff | er_q | ueue | e_glo | bal_o | cong | estio | n_thr | eshc | old[14 | 4:4] | 0  | 0  | 0  | 0  |

### Figure 173. Packet\_Buffer\_Queue\_Management\_Thresholds Register Diagram

#### Table 242. Packet\_Buffer\_Management\_Thresholds Field Parameters

| Field Name                                         | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| queue_mask_congestion_<br>threshold[14:4]          | Mode = R/W<br>Offset = 0.1<br>Instances = 1  | When the number of queue entries allocated equals or exceeds<br>this value, the queue memory is considered congested. The<br>number of queue entries allocated must drop below<br>queue_mask_congestion_threshold[14:4] minus<br>global_congestion_hysteresis[9:4] for the state to<br>change from congested to not congested.<br>The results of this congestion test are used in determining which<br>queues to disable for further enqueues. If a queue memory<br>exceeds this threshold, all queues associated with the memory<br>that also exceed packet_buffer_queue_limit are to be<br>masked from further entries.                          |
| buffer_queue_global_congestion_<br>threshold[14:4] | Mode = R/W<br>Offset = 0.17<br>Instances = 1 | When the total number of queued buffers allocated equals or<br>exceeds this value, the packet buffer is considered congested.<br>The number of queued buffers allocated must drop below<br>buffer_queue_global_congestion_threshold[14:4]<br>minus global_congestion_hysteresis[9:4] for the state<br>to change from congested to not congested. The results of this<br>congestion test are used in determining which queues to disable<br>for further enqueues. If a queue memory exceeds this threshold,<br>all queues associated with the memory that also exceed<br>packet_buffer_queue_buffer_limit are to be masked<br>from further entries. |

This register is valid in revision C only, and the hol\_mode bit in the packet\_buffer\_mode register must be asserted to use this register.

## Packet\_Buffer\_Queue\_Status

Description: Provides a queue status overview.

### Table 243. Packet\_Buffer\_Queue\_Status Register Parameters

| Parameter                             | Value       |
|---------------------------------------|-------------|
| Base Address                          | 0x000c_ba00 |
| Register Size (revisions B and B1)    | 208         |
| Register Size (revision C)            | 216         |
| Register Instances                    | 1           |
| Register Spacing                      | NA          |
| Record Size                           | 4           |
| Record Instances (revisions B and B1) | 52          |
| Record Instances (revision C)         | 54          |
| Record Spacing                        | 4           |

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 0 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 0

### Figure 174. Packet\_Buffer\_Queue\_Status Register Diagram

### Table 244. Packet\_Buffer\_Queue\_Status Field Parameters

| Field Name           | Parameters                                  | Description                                                              |
|----------------------|---------------------------------------------|--------------------------------------------------------------------------|
| queue_not_empty[7:0] | Mode = RO<br>Offset = 0.24<br>Instances = 1 | Bits are asserted to indicate that the corresponding queue is not empty. |

Each record of this register corresponds to one of the system's 52 transmit ports (50 Ethernet ports and 2 supervisor ports). Within queue\_not\_empty[7:0], the left-most bit corresponds to queue priority 7 (highest priority), while the right-most bit corresponds to queue priority 0 (lowest priority). When one of queues is not empty, its corresponding bit is asserted. When the queue is empty, its corresponding status bit is deasserted.

Note: For revision C, the 10 Gbits/s Ethernet queues are spread across two entries in this table. XG0 is at references 50 and 52, while XG1 appears at references 51 and 53.

### REVISIONS B AND B1 PORT NUMBERING SCHEME (TABLE INDEXING)

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 51  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

| FURI      | 701 | хGO | 301   | 300   | 647 | 640  | 645   | 644   |             | 65 | 62   | 01 | 60 |
|-----------|-----|-----|-------|-------|-----|------|-------|-------|-------------|----|------|----|----|
| REFERENCE | 51  | 50  | 49    | 48    | 47  | 46   | 45    | 44    |             | 3  | 2    | 1  | 0  |
|           |     | RE  | VISIC | N C F | ORT | NUME | BERIN | G SCI | HEME (TABLE |    | XING | )  |    |



G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 175. Port Numbering Schemes

## Appendix A: Registers (continued)

## Packet\_Buffer\_Queue\_Weight

Description: Per-packet delta (subtract) from token bucket.

### Table 245. Packet\_Buffer\_Queue\_Weight Register Parameters

| Parameter               | Value                           | ]                                        |
|-------------------------|---------------------------------|------------------------------------------|
| Base Address            | 0x000c_a000                     |                                          |
| Register Size           | 1632                            |                                          |
| Register Instances      | 1                               |                                          |
| Register Spacing        | NA                              |                                          |
| Record Size             | 4                               | ]                                        |
| Record Instances        | 408                             | ]                                        |
| Record Spacing          | 4                               |                                          |
|                         |                                 | _                                        |
| 0 1 2 3 4 5 6 7         | 8 9 10 11 12 13 14 15 16 17 14  | 8 19 20 21 22 23 24 25 26 27 28 29 30 31 |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 15 14 1 | 3 12 11 10 9 8 7 6 5 4 3 2 1 0           |
| 0                       |                                 |                                          |

### Figure 176. Packet\_Buffer\_Queue\_Weight Register Diagram

### Table 246. Packet\_Buffer\_Queue\_Weight Field Parameters

| Field Name        | Parameters                                   | Description                             |
|-------------------|----------------------------------------------|-----------------------------------------|
| queue_weight[3:0] | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | The weight for the corresponding queue. |

The weighted round-robin arbitration scheme that is used between groups of four queues is intended to establish ratios of queue service events. These queue service event ratios (i.e., packet dequeue ratios) are achieved by having a certain number of packets dequeue from one queue before moving on in round-robin sequence to the next queue. The number of packets dequeued in each bursts is defined by its corresponding queue\_weight[3:0] value.

For example, if the queue\_weight[3:0] values for a set of four queues is 11, 1, 3, and 6, then 11 packets are dequeued from the first queue before one is dequeued from the next; three from the next after that, and then six from the last queue. The 11-1-3-6 distribution is repeated for as long as all of the queues have at least as many entries as their respective weights.

If a queue is empty, then it is omitted from the sequence. If a queue has fewer entries than its queue weight[3:0] value, then as soon as it is exhausted, control is shifted to the next nonempty queue.

A queue weight [3:0] value of zero disables the corresponding queue.

|           |        |  |     |     |     | QL  | JEUI | = NU | IMBE | RING | SC  | HEME |     |    |    |   |   |    |   |                                                      |
|-----------|--------|--|-----|-----|-----|-----|------|------|------|------|-----|------|-----|----|----|---|---|----|---|------------------------------------------------------|
| QUEUE     | SU7SI  |  | SU1 | SU0 |     | XG1 |      |      | XG0  |      |     | G47  |     |    | G1 |   |   | G0 |   | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
| REFERENCE | 407 40 |  | 401 | 400 | 399 |     | 392  | 391  |      | 3843 | 383 |      | 376 | 15 |    | 8 | 7 |    | 0 | SU = SUPERVISOR                                      |

#### 

### Figure 177. Queue Numbering Scheme

## Packet\_Buffer\_Scrub

Description: Initiates and directs the scrubbing of lost buffers.

### Table 247. Packet\_Buffer\_Scrub Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bb80 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22   | 23   | 24   | 25    | 26   | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|-------|------|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7    | 6     | 5    | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | miss | sing | _buf | fer[1 | 4:0] |    |    |    |    |    |

### Figure 178. Packet\_Buffer\_Scrub Register Diagram

### Table 248. Packet\_Buffer\_Scrub Field Parameters

| Field Name           | Parameters                                  | Description                                                                                                                                   |
|----------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| scrubbing            | Mode = RO<br>Offset = 0.0<br>Instances = 1  | This bit is asserted while the scrubbing function is<br>in progress. No writes are permitted to this register<br>while scrubbing is asserted. |
| missing_buffer[14:0] | Mode = WO<br>Offset = 0.17<br>Instances = 1 | The buffer number of the buffer to be searched for.                                                                                           |

The supervisor writes a buffer number to this register to perform a scrubbing operation. When the buffer is found, it is placed back on the free list.

## Packet\_Buffer\_Shaper\_Accumulator\_Even

Description: Up/down accumulators used for traffic shaping.

### Table 249. Packet\_Buffer\_Shaper\_Accumulator\_Even Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_a800 |
| Register Size      | 816         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 204         |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20   | 21   | 22   | 23     | 24   | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|------|--------|------|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11   | 10   | 9    | 8      | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | S  | hap | er_a | ccur | mula | itor[1 | 5:4] |    |    |    | 0  | 0  | 0  | 0  |

### Figure 179. Packet\_Buffer\_Shaper\_Accumulator\_Even Register Diagram

### Table 250. Packet\_Buffer\_Shaper\_Accumulator\_Even Field Parameters

| Field Name               | Parameters                                   | Description                                                                                                                                               |
|--------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| shaper_accumulator_sign  | Mode = R/W<br>Offset = 0.15<br>Instances = 1 | The sign of the two's complement<br>shaper_accumulator[15:4] value. When<br>asserted, this signal indicates that<br>shaper_accumulator[15:4] is negative. |
| shaper_accumulator[15:4] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The current value of a traffic shaper accumulator.<br>This counter does not count below its negative min-<br>imum or above its positive maximum.          |

The shaper accumulators are used to determine when a particular queue may have one of its packet's scheduled for retrieval and transmission. A queue is considered eligible for scheduling when its corresponding shaper\_accumulator[15:4] value is greater than zero.

There is one shaper\_accumulator[15:4] value per queue.

The byte count of a transmitted packet is subtracted from its queue's associated shaper\_accumulator[15:4] value. Shaper credits are periodically added to shaper\_accumulator[15:4].

QUEUE NUMBERING SCHEME





### Figure 180. Queue Numbering Scheme

## Packet\_Buffer\_Shaper\_Accumulator\_Odd

Description: Up/down accumulators used for traffic shaping.

### Table 251. Packet\_Buffer\_Shaper\_Accumulator\_Odd Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_ac00 |
| Register Size      | 816         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 204         |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19  | 20   | 21   | 22   | 23    | 24   | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|------|------|-------|------|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11   | 10   | 9    | 8     | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | S  | hap | er_a | ccur | nula | tor[1 | 5:4] |    |    |    | 0  | 0  | 0  | 0  |



| Table 252. Packe | Buffer | Shaper | Accumulator | Odd Field Parameters |
|------------------|--------|--------|-------------|----------------------|
|------------------|--------|--------|-------------|----------------------|

| Field Name               | Parameters                                   | Description                                                                                                                                               |
|--------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| shaper_accumulator_sign  | Mode = R/W<br>Offset = 0.15<br>Instances = 1 | The sign of the two's complement<br>shaper_accumulator[15:4] value. When<br>asserted, this signal indicates that<br>shaper_accumulator[15:4] is negative. |
| shaper_accumulator[15:4] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | The current value of a traffic shaper accumulator.<br>This counter does not count below its negative min-<br>imum or above its positive maximum.          |

The shaper accumulators are used to determine when a particular queue may have one of its packet's scheduled for retrieval and transmission. A queue is considered eligible for scheduling when its corresponding shaper\_accumulator[15:4] value is greater than zero.

There is one shaper\_accumulator[15:4] value per queue.

The byte count of a transmitted packet is subtracted from its queue's associated shaper\_accumulator[15:4] value. Shaper credits are periodically added to shaper\_accumulator[15:4].

|                                                                         |     |     |  |     |     |     |     |     | QL                  | JEUE N | IUM | BER | RING S | CHE | ME |  |    |   |  |    |  |
|-------------------------------------------------------------------------|-----|-----|--|-----|-----|-----|-----|-----|---------------------|--------|-----|-----|--------|-----|----|--|----|---|--|----|--|
| QUEUE                                                                   | SU7 | SU6 |  | SU1 | SU0 |     | XG1 |     |                     | XG0    |     |     | G47    |     |    |  | G1 |   |  | G0 |  |
| REFERENCE                                                               | 407 | 406 |  | 401 | 400 | 399 |     | 392 | 392 391 384 383 376 |        |     |     |        |     | 15 |  | 8  | 7 |  | 0  |  |
| G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT<br>SU = SUPERVISOR |     |     |  |     |     |     |     |     |                     |        |     |     |        |     |    |  |    |   |  |    |  |

## Figure 182. Queue Numbering Scheme

## Packet\_Buffer\_Shaper\_Delta\_Even

Description: These values determine a shaper's target byte rate.

### Table 253. Packet\_Buffer\_Shaper\_Delta\_Even Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_b000 |
| Register Size      | 816         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 204         |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23   | 24     | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|--------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7      | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | s  | hap | er_c | lelta[ | 11:4 | ]  |    | 0  | 0  | 0  | 0  |

### Figure 183. Packet\_Buffer\_Shaper\_Delta\_Even Register Diagram

### Table 254. Packet\_Buffer\_Shaper\_Delta\_Even Field Parameters

| Field Name         | Parameters                                   | Description                                              |
|--------------------|----------------------------------------------|----------------------------------------------------------|
| shaper_delta[11:4] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The credit that is periodically added to an accumulator. |

On a periodic basis, the value of shaper\_delta[11:4] is added to its corresponding

Packet\_Buffer\_Shaper\_Accumulator register field. The period of these applications of credit is derived from the system clock and is dependent on the bit rate of the associated interface. If a period of p is assumed for a 10 Gbits/s Ethernet port, then 10p is used for 1 Gbit/s, 100p for 100 Mbits/s, and 1000p for 10 Mbits/s. The nominal value for p is 1.28 µs, or 781,250 credits per second.

When updated 781,250 times per second for a 10 Gbits/s port, a shaper\_delta[11:0] value of 16
(shaper\_delta[11:4] = 0x1) results in a transmit byte rate of 12.5 Mbytes/s; or 100 Mbits/s. This is 1% of 10 Gbits/s.
A shaper\_delta[11:0] value of 1,600 results in a transmit byte rate of 1,250 Mbytes/s, or 10 Gbits/s. This is, of
course, 100% of the interface's rated speed.

For lower-speed interfaces, the credit application rate is reduced proportionately. Therefore, the same values of 16 and 1,600 can be used in shaper\_delta[11:0] as the minimum and maximum data rates.

Port speed is indicated by values set in Packet\_Buffer\_Port\_Speed by the supervisor.



Figure 184. Queue Numbering Scheme

## Packet\_Buffer\_Shaper\_Delta\_Odd

Description: These values determine a shaper's target byte rate.

### Table 255. Packet\_Buffer\_Shaper\_Delta\_Odd Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_b400 |
| Register Size      | 816         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 204         |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22  | 23   | 24    | 25   | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|-------|------|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7     | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | s  | hap | er_d | elta[ | 11:4 | ]  |    | 0  | 0  | 0  | 0  |

### Figure 185. Packet\_Buffer\_Shaper\_Delta\_Odd Register Diagram

### Table 256. Packet\_Buffer\_Shaper\_Delta\_Odd Field Parameters

| ſ | Field Name         | Parameters                                   | Description                                                   |
|---|--------------------|----------------------------------------------|---------------------------------------------------------------|
|   | shaper_delta[11:4] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The credit that is periodically added to an accumula-<br>tor. |

On a periodic basis, the value of shaper\_delta[11:4] is added to its corresponding
Packet\_Buffer\_Shaper\_Accumulator register field. The period of these applications of credit is derived from
the system clock and is dependent on the bit rate of the associated interface. If a period of p is assumed for a
10 Gbits/s Ethernet port, then 10p is used for 1 Gbit/s, 100p for 100 Mbits/s, and 1000p for 10 Mbits/s. The nominal
value for p is 1.28 µs, or 781,250 credits per second.

When updated 781,250 times per second for a 10 Gbits/s port, a shaper\_delta[11:0] value of 16
(shaper\_delta[11:4] = 0x1) results in a transmit byte rate of 12.5 Mbytes/s, or 100 Mbits/s. This is 1% of 10 Gbits/s.
A shaper\_delta[11:0] value of 1,600 results in a transmit byte rate of 1,250 Mbytes/s, or 10 Gbits/s. This is, of
course, 100% of the interface's rated speed.

For lower-speed interfaces, the credit application rate is reduced proportionately. Therefore, the same values of 16 and 1,600 can be used in shaper\_delta[11:0] as the minimum and maximum data rates.

Port speed is indicated by values set in Packet\_Buffer\_Port\_Speed by the supervisor.

|           | SU7 | SU6 | <br>SU1 | SU0 |     | XG1 |         | XG0 |      |    | G47 |     |    | G1 |   |   | G0 |   | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|---------|-----|-----|-----|---------|-----|------|----|-----|-----|----|----|---|---|----|---|------------------------------------------------------|
| REFERENCE | 407 | 406 | <br>401 | 400 | 399 |     | 392 391 |     | 3843 | 83 |     | 376 | 15 |    | 8 | 7 |    | 0 | SU = SUPERVISOR                                      |

### QUEUE NUMBERING SCHEME

### Figure 186. Queue Numbering Scheme

## Packet\_Buffer\_Shaper\_Limit

Description: An upper limit for shaper accumulators.

### Table 257. Packet\_Buffer\_Shaper\_Limit Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_bc68 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20   | 21   | 22    | 23   | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|-------|------|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11   | 10   | 9     | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | \$ | shap | er_l | imit[ | 15:4 | ]  |    |    |    | 0  | 0  | 0  | 0  |

## Figure 187. Packet\_Buffer\_Shaper\_Limit Register Diagram

### Table 258. Packet\_Buffer\_Shaper\_Limit Field Parameters

| Field Name         | Parameters                                   | Description                                                  |
|--------------------|----------------------------------------------|--------------------------------------------------------------|
| shaper_limit[15:4] | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | Establishes an upper limit for each shaper accumu-<br>lator. |

This register is used to establish an upper limit for Packet\_Buffer\_Shaper\_Accumulator.

shaper\_accmulator[15:4]. If a shaper\_accmulator[15:4] value ever equals or exceeds its corresponding shaper\_limit[15:4] value, then no further increases in shaper\_accmulator[15:4] occur. Under no circumstances is shaper\_accmulator[15:0] permitted to exceed FFF016.

## Policer\_Accumulator\_Table\_{0..4}

Description: This table is used to accumulate packet data rates.

### Table 259. Policer\_Accumulator\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_d400 |
| Register Size      | 320         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |





### Table 260. Policer\_Accumulator\_Table\_{0..4} Field Parameters

| Field Name                | Parameters                                                    | Description                                                                                                                                         |
|---------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| port_speed[1:0]           | Mode = R/W<br>Offset = 0.0<br>Instances = 8                   | The speed of the associated port. This field is<br>defined as follows:<br>002 = 1 Gbit/s<br>012 = 100 Mbits/s<br>102 = 10 Mbits/s<br>112 = reserved |
| policer_accumulator[17:0] | Mode = R/W<br>Offset = 0.14<br>Instances = 8<br>Spacing = 4.0 | The policer accumulator. There are eight policers per port.                                                                                         |

Rx\_Packet\_Header.packet\_length[13:0] is added to the policer\_accumulator[17:0] field that corresponds to the packet's policer for each received packet. On regular intervals, policer\_delta[7:0] is subtracted from policer\_accumulator[17:0]. If policer\_accumulator[17:0] exceeds policer\_limit[17:11], then the traffic is considered out of profile.

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

PORT NUMBERING SCHEME

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

Figure 189. Port Numbering Scheme

24 25 26 27 28 29 30 31

0

# Appendix A: Registers (continued)

## Policer\_Accumulator\_Table\_{5..6}

Description: This table is used to accumulate packet data rates.

### Table 261. Policer\_Accumulator\_Table\_{5..6} Register Parameters

| Parameter           | Value                            |            |
|---------------------|----------------------------------|------------|
| Base Address        | 0x0007_5400                      |            |
| Register Size       | 320                              |            |
| Register Instances  | 2                                |            |
| Register Spacing    | 32768                            |            |
| Record Size         | 4                                |            |
| Record Instances    | 80                               |            |
| Record Spacing      | 4                                |            |
|                     |                                  |            |
| 0 1 2 3 4 5 6 7 8 9 | 10 11 12 13 14 15 16 17 18 19 20 | ) 21 22 23 |

|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11    | 10    | 9    | 8    | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 1 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|------|------|-------|------|---|---|---|---|---|---|
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | polic | cer_a | accu | mula | ator[ | 17:0 | ] |   |   |   |   |   |
|   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |       |      |      | -     |      |   |   |   |   |   |   |

### Figure 190. Policer\_Accumulator\_Table\_{5..6} Register Diagram

### Table 262. Policer\_Accumulator\_Table\_{5..6} Field Parameters

| Field Name                | Parameters                                   | Description              |
|---------------------------|----------------------------------------------|--------------------------|
| policer_accumulator[17:0] | Mode = R/W<br>Offset = 0.14<br>Instances = 1 | The policer accumulator. |

Rx\_Packet\_Header.packet\_length[13:0] is added to the policer\_accumulator[17:0] field that corresponds to the packet's policer for each received packet. On regular intervals, policer\_delta[7:0] (or policer\_delta[10:0]) is subtracted from policer\_accumulator[17:0]. If policer\_accumulator[17:0] exceeds policer\_limit[17:12], then the traffic is considered out of profile.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | G3    | G2 | G1 | G0 |   |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-------|----|----|----|---|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3 | 2  | 1  | 0  | Ì |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 191. Port Numbering Scheme

## Policer\_Delta\_Table\_{0..4}

0

Description: This table is used to specify the per-flow leak rates for the channelized packet processors.

### Table 263. Policer\_Delta\_Table\_{0..4} Register Parameters

| Parameter                                                                                         | Value                         |                                           |
|---------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------------------|
| Base Address                                                                                      | 0x0004_d600                   |                                           |
| Register Size                                                                                     | 320                           |                                           |
| Register Instances                                                                                | 5                             |                                           |
| Register Spacing                                                                                  | 32768                         |                                           |
| Record Size                                                                                       | 4                             |                                           |
| Record Instances                                                                                  | 80                            |                                           |
| Record Spacing                                                                                    | 4                             |                                           |
|                                                                                                   |                               | -                                         |
| 0 1 2 3 4 5 6                                                                                     | 7 8 9 10 11 12 13 14 15 16    | 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
| 31 <sub>1</sub> 30 <sub>1</sub> 29 <sub>1</sub> 28 <sub>1</sub> 27 <sub>1</sub> 26 <sub>1</sub> 2 | 24 23 22 21 20 19 18 17 16 15 | 5 14 13 12 11 10 9 8 7 6 5 4 3 2 1        |



### Table 264. Policer Delta Table {0..4} Field Parameters

| Field Name         | Parameters                                   | Description        |
|--------------------|----------------------------------------------|--------------------|
| policer_delta[6:0] | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | The policer delta. |

The product of the policer delta[6:0] value in this table and 16 are subtracted from their corresponding entries in the Policer Accumulator Table  $\{0...4\}$  at a regular interval. The interval is derived from the system clock and varies from policer to policer depending on the data rate of the associated Ethernet receive port.

The nominal service interval for a 1 Gbit/s port is once every 12.8 µs or 78,125 times per second. In addition, the service interval for a 100 Mbits/s port is 1/10 that of a 1 Gbit/s port; and for a 10 Mbits/s port, 1/100 that of a 1 Gbit/s port.

This scaling of service intervals provides the necessary data rate adaptation.

Larger policer delta[6:0] values translate into higher allowed data rates on the corresponding policer.

When subtracted from the Policer\_Accumulator\_Table\_{0..4}, a product of 16 (policer\_delta[6:0] = 0x1) results in a service interval of 1.25 Mbytes/s or 10 Mbits/s. This is 1% of 1 Gbit/s. A product of 1,600 (policer\_delta[6:0] = 0x64) results in a service interval of 125 Mbytes/s or 1 Gbit/s. This is, of course, 100% of the interface's rated speed.

For lower-speed interfaces, the interval is reduced proportionately. Therefore, the same values of 1 and 100 can be used in policer delta[6:0] for the minimum and maximum intervals.

policer\_delta[6:0]

Policer\_Delta\_Table\_{0..4} (continued)

.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |  |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|--|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

Figure 193. Port Numbering Scheme

## Policer\_Delta\_Table\_{5..6}

Description: This table is used to specify the per-flow leak rates for the nonchannelized packet processors.

### Table 265. Policer\_Delta\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5600 |
| Register Size      | 320         |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |



### Figure 194. Policer\_Delta\_Table\_{5..6} Register Diagram

### Table 266. Policer\_Delta\_Table\_{5..6} Field Parameters

| Field Name         | Parameters                                   | Description                  |
|--------------------|----------------------------------------------|------------------------------|
| policer_delta[6:0] | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | The policer flow identifier. |

The product of the policer\_delta[6:0] values in this table and 16 are subtracted from their corresponding entries in Policer\_Accumulator\_Table at a regular interval. This interval is derived from the system clock. The nominal service interval for a 10 Gbit/s port is once every 1.28 µs or 781,250 times per second.

Larger policer\_delta[6:0] values translate into higher allowed data rates on the corresponding policer.

When subtracted from the Policer\_Accumulator\_Table, a product of 16 ( $policer_delta[6:0] = 0x1$ ) results in a service interval of 12.5 Mbytes/s or 100 Mbits/s. This is 1% of 10 Gbits/s. A product of 1,600 ( $policer_delta[6:0] = 0x64$ ) results in a service interval of 1,250 Mbytes/s or 10 Gbits/s. This is, of course, 100% of the interface's rated speed.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |  |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|--|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 195. Port Numbering Scheme

## Policer\_Flow\_Id\_Table\_{0..4}

Description: This table is used to convert a 3-tuple to a single flow identifier.

### Table 267. Policer\_Flow\_Id\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_c000 |
| Register Size      | 4096        |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 1024        |
| Record Spacing     | 4           |

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0

## Figure 196. Policer\_Flow\_Id\_Table\_{0..4} Register Diagram

### Table 268. Policer\_Flow\_Id\_Table\_{0..4} Field Parameters

| Field Name           | Parameters                                   | Description                  |
|----------------------|----------------------------------------------|------------------------------|
| policer_flow_id[2:0] | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | The policer flow identifier. |

A received packet's source address and destination address are each reduced to 3-bit flow identifiers by their respective look-up processes. These two identifiers are concatenated with the packet's encoded 4-bit priority value to form a 10-bit address into this table. The following shows the form of this value:

flow\_id\_table\_addr[9:0] = { dest\_flow\_id[2:0], src\_flow\_id[2:0], priority[3:0] };

The dest\_flow\_id[2:0] and src\_flow\_id[2:0] values are derived from either the packet's Layer 2 address look-up or its Layer 3 address look-up. The Layer 3 values are used if the packet contains a valid IPv4 or IPv6 header and Policer\_Mode.layer\_2\_flow\_id\_override\_en is not asserted.

Otherwise, the packet's Layer 2 destination and source address values are used.

These tables are associated with the 1 gigabit Ethernet ports.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|------------------------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  | SU = SUPERVISOR                                      |

Figure 197. Port Numbering Scheme

## Policer\_Flow\_Id\_Table\_{5..6}

Description: This table is used to convert a 3-tuple to a single flow identifier.

### Table 269. Policer\_Flow\_Id\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_4000 |
| Register Size      | 4096        |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 1024        |
| Record Spacing     | 4           |
|                    |             |



### Figure 198. Policer\_Flow\_Id\_Table\_{5..6} Register Diagram

### Table 270. Policer\_Flow\_Id\_Table\_{5..6} Field Parameters

| Field Name           | Parameters                                   | Description                  |
|----------------------|----------------------------------------------|------------------------------|
| policer_flow_id[6:0] | Mode = R/W<br>Offset = 0.25<br>Instances = 1 | The policer flow identifier. |

A received packet's source address and destination address are each reduced to 3-bit flow identifiers by their respective look-up processes. These two identifiers are concatenated with the packet's encoded 4-bit priority value to form a 10-bit address into this table. The following shows the form of this value:

flow\_id\_table\_addr[9:0] = { dest\_flow\_id[2:0], src\_flow\_id[2:0], priority[3:0] };

The dest\_flow\_id[2:0] and src\_flow\_id[2:0] values are derived from either the packet's Layer 2 address look-up or its Layer 3 address look-up. The Layer 3 values are used if the packet contains a valid IPv4 or IPv6 header and Policer\_Mode.layer\_2\_flow\_id\_override\_en is not asserted.

Otherwise, the packet's Layer 2 destination and source address values are used.

These tables are associated with the 10 gigabit Ethernet ports.

### PORT NUMBERING SCHEME

| REFERENCE 60 50 49 48 47 46 45 44 3 2 1 | PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------------------------------------|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
|                                         | REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT

### SU = SUPERVISOR

### Figure 199. Port Numbering Scheme

## Policer\_Flow\_Mode\_Table\_{0..4}

Description: This table per-flow mode settings.

### Table 271. Policer\_Flow\_Mode\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_d800 |
| Register Size      | 320         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |
|                    |             |

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0



### Table 272. Policer\_Flow\_Mode\_Table\_{0..4} Field Parameters

| Field Name                                   | Parameters                                                     | Description                                                                                                                                                                                                                                                                   |
|----------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| discard_out_of_profile_en                    | Mode = R/W<br>Offset = 0.29<br>Instances = 80<br>Spacing = 4.0 | This bit enables the discarding of packets that are out<br>of profile. A packet is out of profile if its contribution to a<br>flow's short term average bandwidth causes that aver-<br>age to exceed the flow's user-defined limit.                                           |
| discard_out_of_profile_when_<br>congested_en | Mode = R/W<br>Offset = 0.30<br>Instances = 80<br>Spacing = 4.0 | This bit enables the discarding of packets that are out<br>of profile while the switch is congested. The switch is<br>considered congested when the number of available<br>packet buffer, packet queue or packet descriptor<br>resources falls below user-defined thresholds. |
| demote_out_of_profile_en                     | Mode = R/W<br>Offset = 0.31<br>Instances = 80<br>Spacing = 4.0 | This bit enables the demotion of packets that are out of profile. When a packet is demoted, it is transmitted at a lower-priority level.                                                                                                                                      |

This register provides an assortment of flow-specific mode settings. For the channelized packet\_processor modules (numbers 0 through 4), the eighty policer mode sets are allocated eight per channel. Policers 0 through 7 are allocated to channel 0, policers 8 through 15 to channel 1, etc.

For the nonchannelized packet\_processor modules (numbers 5 and 6), all eighty policer mode sets are allocated to the eighty policers of the single channel.

Р

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|------------------------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | З      | 2  | 1  | 0  | SU = SUPERVISOR                                      |

### Figure 201. Port Numbering Scheme

## Policer\_Flow\_Mode\_Table\_{5..6}

Description: This table per-flow mode settings.

### Table 273. Policer\_Flow\_Mode\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5800 |
| Register Size      | 320         |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |





### Table 274. Policer\_Flow\_Mode\_Table\_{5..6} Field Parameters

| Field Name                   | Parameters     | Description                                                  |
|------------------------------|----------------|--------------------------------------------------------------|
| discard_out_of_profile_en    | Mode = R/W     | This bit enables the discarding of packets that are out of   |
|                              | Offset = 0.27  | profile. A packet is out of profile if its contribution to a |
|                              | Instances = 80 | flow's short-term average bandwidth causes that aver-        |
|                              | Spacing = 4.0  | age to exceed the flow's user-defined limit.                 |
| discard_out_of_profile_when_ | Mode = R/W     | This bit enables the discarding of packets that are out of   |
| congested_en                 | Offset = 0.28  | profile while the switch is congested. The switch is con-    |
|                              | Instances = 80 | sidered congested when the number of available packet        |
|                              | Spacing = 4.0  | buffer, packet queue, or packet descriptor resources         |
|                              |                | falls below user-defined thresholds.                         |
| demote_out_of_profile_en     | Mode = R/W     | This bit enables the demotion of packets that are out of     |
|                              | Offset = 0.29  | profile. When a packet is demoted, it is transmitted at a    |
|                              | Instances = 80 | lower-priority level.                                        |
|                              | Spacing = 4.0  |                                                              |

This register provides an assortment of flow-specific mode settings. For the channelized packet\_processor modules (numbers 0 through 4), the eighty policer mode sets are allocated eight per channel. Policers 0 through 7 are allocated to channel 0, policers 8 through 15 to channel 1, etc.

For the nonchannelized packet\_processor modules (numbers 5 and 6), all eighty policer mode sets are allocated to the eighty policers of the single channel.

|           | PORT NUMBERING SCHEME |     |     |     |     |     |     |     |  |    |    |    |    |  |  |
|-----------|-----------------------|-----|-----|-----|-----|-----|-----|-----|--|----|----|----|----|--|--|
| PORT      | XG1                   | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 |  | G3 | G2 | G1 | G0 |  |  |
| REFERENCE | 60                    | 50  | 49  | 48  | 47  | 46  | 45  | 44  |  | 3  | 2  | 1  | 0  |  |  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 203. Port Numbering Scheme

## Policer\_Limit\_Table\_{0..4}

Description: Establishes the bandwidth limit for each flow.

### Table 275. Policer\_Limit\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_da00 |
| Register Size      | 320         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16    | 17    | 18    | 19   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15    | 14    | 13    | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ро | licer | _limi | t[17: | :11] |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## Figure 204. Policer\_Limit\_Table\_{0..4} Register Diagram

### Table 276. Policer\_Limit\_Table\_{0..4} Field Parameters

| Field Name           | Parameters                                   | Description                 |
|----------------------|----------------------------------------------|-----------------------------|
| policer_limit[17:11] | Mode = R/W<br>Offset = 0.14<br>Instances = 1 | The per-flow policer limit. |

If a policer\_accumulator[17:0] value ever exceeds its corresponding policer\_limit[17:11] value, then the flow is considered out of profile.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | G3    | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3 | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 205. Port Numbering Scheme

## Policer\_Limit\_Table\_{5..6}

Description: Establishes the bandwidth limit for each flow.

### Table 277. Policer\_Limit\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5a00 |
| Register Size      | 320         |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16    | 17    | 18    | 19   | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15    | 14    | 13    | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ро | licer | _limi | it[17 | :11] |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### Figure 206. Policer\_Limit\_Table\_{5..6} Register Diagram

### Table 278. Policer\_Limit\_Table\_{5..6} Field Parameters

| Field Na             | ne | Parameters                                   | Description                 |
|----------------------|----|----------------------------------------------|-----------------------------|
| policer_limit[17:11] |    | Mode = R/W<br>Offset = 0.14<br>Instances = 1 | The per-flow policer limit. |

If a policer\_accumulator[17:0] value ever exceeds its corresponding policer\_limit[17:11] value, then the flow is considered out of profile.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47    | G46    | G45  | G44   |         | G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|--------|--------|------|-------|---------|----|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47     | 46     | 45   | 44    |         | 3  | 2  | 1  | 0  |
|           |     |     |     | C   | G = 10 | )/100/ | 1000 | Mbits | /s PORT |    |    |    |    |

XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 207. Port Numbering Scheme

29 30 31 2 1 0

# Appendix A: Registers (continued)

## Policer\_Mode\_{0..4}

Description: Mode bits for the policer function.

### Table 279. Policer\_Mode\_{0..4} Register Parameters

| Parameter               | Value                                                  |       |
|-------------------------|--------------------------------------------------------|-------|
| Base Address            | 0x0004_dfe0                                            |       |
| Register Size           | 4                                                      |       |
| Register Instances      | 5                                                      |       |
| Register Spacing        | 32768                                                  |       |
| Record Size             | 4                                                      |       |
| Record Instances        | 1                                                      |       |
| Record Spacing          | NA                                                     |       |
|                         |                                                        |       |
| 0 1 2 3 4 5 6 7         | 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | 27 28 |
| 31 30 29 28 27 26 25 24 | 3 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5     | 4 3   |
| 0                       |                                                        |       |

### Figure 208. Policer\_Mode\_{0..4} Register Diagram

### Table 280. Policer\_Mode\_{0..4} Field Parameters

| Field Name | Parameters                                                | Description                   |
|------------|-----------------------------------------------------------|-------------------------------|
| policer_en | Mode = R/W<br>Offset = 0.31<br>Instances = 1<br>Reset = 0 | Enables the policer function. |

A collection of per-policer aggregate mode bits.

Each packet\_processor module includes an aggregate policer function. Each aggregate consists of 80 policer functions (eight per port for the 1 Gbit/s Ethernet ports and 80 per port for the 10 Gbits/s Ethernet ports). The mode bits in this register act globally on a policer aggregate, not on individual policers.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | G3    | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3 | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/ PORT SU = SUPERVISOR

### Figure 209. Port Numbering Scheme

## Policer\_Mode\_{5..6}

Description: Mode bits for the policer function.

### Table 281. Policer\_Mode\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5fe0 |
| Register Size      | 4           |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 210. Policer\_Mode\_{5..6} Register Diagram

### Table 282. Policer\_Mode\_{5..6} Field Parameters

| Field Name | Parameters                  | Description                   |  |
|------------|-----------------------------|-------------------------------|--|
| policer_en | Mode = R/W<br>Offset = 0.31 | Enables the policer function. |  |
|            | Instances = 1<br>Reset = 0  |                               |  |

A collection of per-policer aggregate mode bits.

Each packet\_processor module includes an aggregate policer function. Each aggregate consists of 80 policer functions (8 per port for the 1 Gbit/s Ethernet ports and 80 per port for the 10 Gbits/s Ethernet ports). The mode bits in this register act globally on a policer aggregate, not on individual policers.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 211. Port Numbering Scheme

## Policer\_Statistics\_{0..4}

Description: Tracks policer behavior.

### Table 283. Policer\_Statistics\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_e000 |
| Register Size      | 640         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 8           |
| Record Instances   | 80          |
| Record Spacing     | 8           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18  | 19    | 20   | 21   | 22   | 23  | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|------|------|------|-----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13  | 12    | 11   | 10   | 9    | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | pol | icer  | _dis | card | s[21 | :0] |    |    |    |    |    |    |    |    |
| 4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | pol | icer_ | _der | note | s[21 | :0] |    |    |    |    |    |    |    |    |

### Figure 212. Policer\_Statistics\_{0..4} Register Diagram

| Table 284. Policer_ | Statistics_{0. | 4} Field Paramete | rs |
|---------------------|----------------|-------------------|----|
|---------------------|----------------|-------------------|----|

| Field Name             | Parameters                                   | Description                                               |
|------------------------|----------------------------------------------|-----------------------------------------------------------|
| policer_discards[21:0] | Mode = R/W<br>Offset = 0.10<br>Instances = 1 | The count of the number of packets discarded per policer. |
| policer_demotes[21:0]  | Mode = R/W<br>Offset = 4.10<br>Instances = 1 | The count of the number of packets demoted per policer.   |

These statistics counters increment by one for each packet that matches the associated criteria. These counters roll over to zero upon incrementing beyond its maximum value. It is incumbent upon the supervisor to sample these statistics often enough to avoid missing a counter rollover.

There is one pair of counters for each policer. For the multichannel packet\_processor modules, the statistics are arranged such that the statistics type (demote vs. discard) forms the least significant bit of the address. The policer number forms the next most significant 3 bits, and the channel number forms the most significant 4 bits of the statistics selection address.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|------------------------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  | SU = SUPERVISOR                                      |

Figure 213. Port Numbering Scheme

## Policer\_Statistics\_{5..6}

Description: Tracks policer behavior.

### Table 285. Policer\_Statistics\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_6000 |
| Register Size      | 640         |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 8           |
| Record Instances   | 80          |
| Record Spacing     | 8           |



### Figure 214. Policer\_Statistics\_{5..6} Register Diagram

### Table 286. Policer\_Statistics\_{5..6} Field Parameters

| Field Name             | Parameters                                   | Description                                               |
|------------------------|----------------------------------------------|-----------------------------------------------------------|
| policer_discards[21:0] | Mode = R/W<br>Offset = 0.10<br>Instances = 1 | The count of the number of packets discarded per policer. |
| policer_demotes[21:0]  | Mode = R/W<br>Offset = 4.10<br>Instances = 1 | The count of the number of packets demoted per policer.   |

These statistics counters increment by one for each packet that matches the associated criteria. These counters roll over to zero upon incrementing beyond its maximum value. It is incumbent upon the supervisor to sample these statistics often enough to avoid missing a counter rollover.

There is one pair of counters for each policer. For the multichannel packet\_processor modules, the statistics are arranged such that the statistics type (demote vs. discard) forms the least significant bit of the address. The policer number forms the next most significant 3 bits, and the channel number forms the most significant 4 bits of the statistics selection address.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 215. Port Numbering Scheme

## Port\_Mode\_{0..4}

Description: Various port-oriented mode bits and fields for the multichannel packet processors.

### Table 287. Port\_Mode\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_df80 |
| Register Size      | 40          |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 10          |
| Record Spacing     | 4           |

|   | 0  | 1  | 2     | 3    | 4    | 5    | 6     | 7  | 8    | 9     | 10     | 11    | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|-------|------|------|------|-------|----|------|-------|--------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29    | 28   | 27   | 26   | 25    | 24 | 23   | 22    | 21     | 20    | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    | de | fault | _vla | n_in | dex[ | [7:0] |    | defa | ult_p | riorit | y[3:0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## Figure 216. Port\_Mode\_{0..4} Register Diagram

### Table 288. Port\_Mode\_{0..4} Field Parameters

| Field Name                     | Parameters                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| default_vlan_index_{}{09}[7:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 1<br>Reset = 0  | The port's default VLAN index value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| default_priority_{}{09}[3:0]   | Mode = R/W<br>Offset = 0.8<br>Instances = 1<br>Reset = 0  | The port's default priority value. If Layer 3<br>and Layer 2 priority information is not<br>available from the received packet, this<br>default priority value is used instead.                                                                                                                                                                                                                                                                                                                         |
| header_update_disable_{}{09}   | Mode = R/W<br>Offset = 0.14<br>Instances = 1<br>Reset = 0 | This bit is asserted to disable the updating<br>of a packet's Layer 2 header (VLAN tag,<br>CoS) prior to transmission. Set this bit for<br>an egress port if tagged or untagged<br>ingress packets should be transmitted<br>unchanged as tagged or untagged,<br>respectively, regardless of an access or<br>trunk-configured egress port. Also, if a<br>port has been designated as a mirroring<br>port, its header_update_disable bit<br>should be asserted. Otherwise, this bit<br>should be cleared. |

Port\_Mode\_{0..4} (continued)

## Table 288. Port\_Mode\_{0..4} Field Parameters (continued)

| Field Name                            | Parameters                                                | Description                                                                                                                                                                                                                                                 |
|---------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stack_mirror_forward_{}{09}           | Mode = R/W<br>Offset = 0.15<br>Instances = 1<br>Reset = 0 | This bit is asserted to enable the remap-<br>ping of VLAN IDs in support of stack-<br>spanning port mirroring. This bit indicates<br>that the mirroring port may be accessed<br>by transmitting via a port other than the<br>one corresponding to this bit. |
| stack_mirror_reverse_{}{09}           | Mode = R/W<br>Offset = 0.16<br>Instances = 1<br>Reset = 0 | This bit is asserted to enable the remap-<br>ping of VLAN IDs in support of stack-<br>spanning port mirroring. This bit indicates<br>that the mirroring port may be accessed<br>by transmitting via the port corresponding<br>to this bit.                  |
| bad_length_discard_en_{}{09}          | Mode = R/W<br>Offset = 0.17<br>Instances = 1<br>Reset = 0 | If a received packet's length field does not<br>match the length of the packet's data field,<br>and this bit is asserted, then the packet is<br>marked for discard.                                                                                         |
| unknown_encap_discard_en_{}{09}       | Mode = R/W<br>Offset = 0.18<br>Instances = 1<br>Reset = 0 | If a received packet's encapsulation is not<br>Ethernet V2 or SNAP (with or without<br>VLAN tag), and this mode bit is asserted,<br>then the packet is discarded.                                                                                           |
| unknown_ethertype_discard_en_{}{09}   | Mode = R/W<br>Offset = 0.19<br>Instances = 1<br>Reset = 0 | If a received packet's Ethertype field is not<br>IPv4, IPv6, ARP, or RARP, and this mode<br>bit is asserted, then the packet is dis-<br>carded.                                                                                                             |
| unknown_ip_protocol_discard_en_{}{09} | Mode = R/W<br>Offset = 0.20<br>Instances = 1<br>Reset = 0 | If a received packet's IP protocol field is<br>not ICMP, IGMP, TCP or UDP, and this<br>mode bit is asserted, then the packet is<br>discarded.                                                                                                               |
| ipv4_options_discard_en_{}{09}        | Mode = R/W<br>Offset = 0.21<br>Instances = 1<br>Reset = 0 | If an IPv4 packet contains options and this mode bit is asserted, then the packet is discarded.                                                                                                                                                             |
| vlan_tagged_discard_en_{}{09}         | Mode = R/W<br>Offset = 0.22<br>Instances = 1<br>Reset = 0 | If a received packet is tagged with a VLAN identifier, and this mode bit is asserted, then the packet is discarded.                                                                                                                                         |
| vlan_untagged_discard_en_{}{09}       | Mode = R/W<br>Offset = 0.23<br>Instances = 1<br>Reset = 0 | If a received packet is tagged with a VLAN identifier, and this mode bit is asserted, then the packet is discarded.                                                                                                                                         |
| cfi_discard_en_{}{09}                 | Mode = R/W<br>Offset = 0.24<br>Instances = 1<br>Reset = 0 | If a received packet is VLAN tagged and<br>its CFI bit is asserted, and this mode bit is<br>asserted, then the packet is discarded.                                                                                                                         |

## Port\_Mode\_{0..4} (continued)

## Table 288. Port\_Mode\_{0..4} Field Parameters (continued)

| Field Name                          | Parameters                                                | Description                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_priority_override_en_{}{09} | Mode = R/W<br>Offset = 0.25<br>Instances = 1<br>Reset = 0 | This mode bit enables the use of Layer 2<br>priority (CoS) information for establishing<br>the packet's priority level even if Layer 3<br>priority (DSCP) information is available.<br>For normal operation, this bit is deas-<br>serted and Layer 3 priority information is<br>given precedence over Layer 2 priority<br>information. |
| layer_2_flow_override_en_{}{09}     | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | This bit is asserted to force the use of flow<br>identifiers derived from Layer 2 address<br>information regardless of the presence of<br>valid Layer 3 information. When this bit is<br>deasserted, Layer 3 address information<br>is used to derive flow identifiers if valid<br>IPv4 or IPv6 headers are present.                   |
| invalid_vlan_id_discard_en_{}{09}   | Mode = R/W<br>Offset = 0.27<br>Instances = 1<br>Reset = 0 | If a received packet's VLAN ID value is<br>not found in the VLAN index table and this<br>bit is asserted, then the packet is dis-<br>carded.                                                                                                                                                                                           |
| strip_matching_vlan_tag_en_{}{09}   | Mode = R/W<br>Offset = 0.28<br>Instances = 1<br>Reset = 0 | If a transmit packet's VLAN index matches<br>a trunk port's default VLAN index and this<br>bit is asserted, the VLAN identifier is<br>stripped from the packet (if there is one)<br>prior to transmission.                                                                                                                             |
| trunk_port_{}{09}                   | Mode = R/W<br>Offset = 0.29<br>Instances = 1<br>Reset = 0 | This bit is asserted to indicate that a port is a VLAN trunk port.                                                                                                                                                                                                                                                                     |
| update_cos_en_{}{09}                | Mode = R/W<br>Offset = 0.30<br>Instances = 1<br>Reset = 0 | If this mode bit is asserted, then the Layer<br>2 CoS field is updated prior to transmis-<br>sion with the priority value computed dur-<br>ing ingress processing. If this transmit<br>port's trunk_port bits is not set,<br>update_cos_en has no effect.                                                                              |
| update_dscp_en_{}{09}               | Mode = R/W<br>Offset = 0.31<br>Instances = 1<br>Reset = 0 | If this mode bit is asserted and the packet<br>being transmitted is an IPv4 or IPv6<br>packet, then the priority value computed<br>during ingress processing is decoded into<br>a replacement DSCP field and placed in<br>the transmit packet.                                                                                         |

A collection of per-port mode bits.

## Port\_Mode\_{0..4} (continued)

This register description applies to the multichannel packet\_processors (numbers 0 through 4) that service the 1 Gbit/s Ethernet ports. For each instance of this register, there are ten instances of its multifield record. Record zero corresponds to channel zero.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 217. Port Numbering Scheme

## Port\_Mode\_{5..6}

Description: Various port-oriented mode bits and fields for the single-channel packet processors.

### Table 289. Port\_Mode\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5f80 |
| Register Size      | 4           |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



## Figure 218. Port\_Mode\_{5..6} Register Diagram

### Table 290. Port\_Mode\_{5..6} Field Parameters

| Field Name              | Parameters                                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| default_vlan_index[7:0] | Mode = R/W<br>Offset = 0.0<br>Instances = 1<br>Reset = 0  | The port's default VLAN index value.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| default_priority[3:0]   | Mode = R/W<br>Offset = 0.8<br>Instances = 1<br>Reset = 0  | The port's default priority value. If Layer 3 and Layer 2 priority information is not available from the received packet, this default priority value is used instead.                                                                                                                                                                                                                                                                                                                         |
| header_update_disable   | Mode = R/W<br>Offset = 0.14<br>Instances = 1<br>Reset = 0 | This bit is asserted to disable the updating of a<br>packet's Layer 2 header (VLAN tag, CoS) prior to<br>transmission. Set this bit for an egress port if tagged or<br>untagged ingress packets should be transmitted<br>unchanged as tagged or untagged, respectively,<br>regardless of an access or trunk-configured egress<br>port. Also, if a port has been designated as a mirroring<br>port, its header_update_disable bit should be<br>asserted. Otherwise, this bit should be cleared. |
| stack_mirror_forward    | Mode = R/W<br>Offset = 0.15<br>Instances = 1<br>Reset = 0 | This bit is asserted to enable the remapping of VLAN<br>IDs in support of stack-spanning port mirroring. This bit<br>indicates that the mirroring port may be accessed by<br>transmitting via a port other than the one correspond-<br>ing to this bit.                                                                                                                                                                                                                                        |

## Port\_Mode\_{5..6} (continued)

## Table 290. Port\_Mode\_{5..6} Field Parameters (continued)

| Field Name                         | Parameters                                                | Description                                                                                                                                                                                                                                                                                                     |
|------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stack_mirror_reverse               | Mode = R/W<br>Offset = 0.16<br>Instances = 1<br>Reset = 0 | This bit is asserted to enable the remapping of VLAN<br>IDs in support of stack-spanning port mirroring. This bit<br>indicates that the mirroring port may be accessed by<br>transmitting via the port corresponding to this bit.                                                                               |
| bad_length_discard_en              | Mode = R/W<br>Offset = 0.17<br>Instances = 1<br>Reset = 0 | If a received packet's length field does not match the<br>length of the packet's data field, and this bit is<br>asserted, then the packet is marked for discard.                                                                                                                                                |
| unknown_encap_discard_en           | Mode = R/W<br>Offset = 0.18<br>Instances = 1<br>Reset = 0 | If a received packet's encapsulation is not Ethernet V2<br>or SNAP (with or without VLAN tag), and this mode bit<br>is asserted, then the packet is discarded.                                                                                                                                                  |
| unknown_ethertype_discard_en       | Mode = R/W<br>Offset = 0.19<br>Instances = 1<br>Reset = 0 | If a received packet's Ethertype field is not IPv4, IPv6, ARP, or RARP, and this mode bit is asserted, then the packet is discarded.                                                                                                                                                                            |
| unknown_ip_protocol_discard_<br>en | Mode = R/W<br>Offset = 0.20<br>Instances = 1<br>Reset = 0 | If a received packet's IP protocol field is not ICMP,<br>IGMP, TCP, or UDP, and this mode bit is asserted, then<br>the packet is discarded.                                                                                                                                                                     |
| ipv4_options_discard_en            | Mode = R/W<br>Offset = 0.21<br>Instances = 1<br>Reset = 0 | If an IPv4 packet contains options and this mode bit is asserted, then the packet is discarded.                                                                                                                                                                                                                 |
| vlan_tagged_discard_en             | Mode = R/W<br>Offset = 0.22<br>Instances = 1<br>Reset = 0 | If a received packet is tagged with a VLAN identifier<br>and this mode bit is asserted, then the packet is dis-<br>carded.                                                                                                                                                                                      |
| vlan_untagged_discard_en           | Mode = R/W<br>Offset = 0.23<br>Instances = 1<br>Reset = 0 | If a received packet is not tagged with a VLAN identi-<br>fier and this mode bit is asserted, then the packet is<br>discarded.                                                                                                                                                                                  |
| cfi_discard_en                     | Mode = R/W<br>Offset = 0.24<br>Instances = 1<br>Reset = 0 | If a received packet is VLAN tagged and its CFI bit is asserted and this mode bit is asserted, then the packet is discarded.                                                                                                                                                                                    |
| layer_2_priority_override_en       | Mode = R/W<br>Offset = 0.25<br>Instances = 1<br>Reset = 0 | This mode bit enables the use of Layer 2 priority (CoS) information for establishing the packet's priority level even if Layer 3 priority (DSCP) information is available. For normal operation, this bit is deasserted and Layer 3 priority information is given precedence over Layer 2 priority information. |

## Port\_Mode\_{5..6} (continued)

### Table 290. Port\_Mode\_{5..6} Field Parameters (continued)

| Field Name                 | Parameters                                                | Description                                                                                                                                                                                                                                                                                        |
|----------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| layer_2_flow_override_en   | Mode = R/W<br>Offset = 0.26<br>Instances = 1<br>Reset = 0 | This bit is asserted to force the use of flow identifiers derived from Layer 2 address information regardless of the presence of valid Layer 3 information. When this bit is deasserted, Layer 3 address information is used to derive flow identifiers if valid IPv4 or IPv6 headers are present. |
| invalid_vlan_id_discard_en | Mode = R/W<br>Offset = 0.27<br>Instances = 1<br>Reset = 0 | If a received packet's VLAN ID value is not found in the VLAN index table and this bit is asserted, then the packet is discarded.                                                                                                                                                                  |
| strip_matching_vlan_tag_en | Mode = R/W<br>Offset = 0.28<br>Instances = 1<br>Reset = 0 | If a transmit packet's VLAN index matches a trunk<br>port's default VLAN index, and this bit is asserted, the<br>VLAN identifier is stripped from the packet (if there is<br>one) prior to transmission.                                                                                           |
| trunk_port                 | Mode = R/W<br>Offset = 0.29<br>Instances = 1<br>Reset = 0 | This bit is asserted to indicate that a port is a VLAN trunk port.                                                                                                                                                                                                                                 |
| update_cos_en              | Mode = R/W<br>Offset = 0.30<br>Instances = 1<br>Reset = 0 | If this mode bit is asserted, then the Layer 2 CoS field<br>is updated prior to transmission with the priority value<br>computed during ingress processing. If this transmit<br>port's trunk_port bits is not set, update_cos_en<br>has no effect.                                                 |
| update_dscp_en             | Mode = R/W<br>Offset = 0.31<br>Instances = 1<br>Reset = 0 | If this mode bit is asserted and the packet being trans-<br>mitted is an IPv4 or IPv6 packet, then the priority value<br>computed during ingress processing is decoded into a<br>replacement DSCP field and placed in the transmit<br>packet.                                                      |

A collection of per-port mode bits.

This register description applies to the single-channel packet processors (numbers 5 through 6) that service the 10 Gbits/s Ethernet ports. For each instance of this register, there are single instances of its multifield record.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

### Figure 219. Port Numbering Scheme

## Priority\_Decode\_Table\_{0..4}

Description: Decodes the 4-bit encoded priority value prior to transmission.

### Table 291. Priority\_Decode\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_df00 |
| Register Size      | 128         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 32          |
| Record Spacing     | 4           |



### Figure 220. Priority\_Decode\_Table\_{0..4 Register Diagram}

### Table 292. Priority\_Decode\_Table\_{0..4} Field Parameters

| Field Name        | Parameters                                   | Description             |
|-------------------|----------------------------------------------|-------------------------|
| dscp_{}{031}[5:0] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | The decoded DSCP value. |
| cos_{}{031}[2:0]  | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | The decoded CoS value.  |

During packet reception, a 4-bit priority value is assigned to each packet. During packet transmission, this table is used to convert that 4-bit priority value back to either a 3-bit CoS field (for use in the VLAN tag) or a 6-bit DSCP value (for use in the IP header). This table is addressed by the concatenation of the packet's demote status and its priority value computed during ingress processing.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 221. Port Numbering Scheme

## Priority\_Decode\_Table\_{5..6}

Description: Decodes the 4-bit encoded priority value prior to transmission.

### Table 293. Priority\_Decode\_Table\_{5..6} Register Parameters

| Parameter          | Value       |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|
| Base Address       | 0x0007_5f00 |  |  |  |  |  |
| Register Size      | 128         |  |  |  |  |  |
| Register Instances | 2           |  |  |  |  |  |
| Register Spacing   | 32768       |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |
| Record Instances   | 32          |  |  |  |  |  |
| Record Spacing     | 4           |  |  |  |  |  |



### Figure 222. Priority\_Decode\_Table\_{5..6} Register Diagram

### Table 294. Priority\_Decode\_Table\_{5..6} Field Parameters

| Field Name        | Parameters                                   | Description             |
|-------------------|----------------------------------------------|-------------------------|
| dscp_{}{031}[5:0] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | The decoded DSCP value. |
| cos_{}{031}[2:0]  | Mode = R/W<br>Offset = 0.29<br>Instances = 1 | The decoded CoS value.  |

During packet reception, a 4-bit priority value is assigned to each packet. During packet transmission, this table is used to convert that 4-bit priority value back to either a 3-bit CoS field (for use in the VLAN tag) or a 6-bit DSCP value (for use in the IP header). This table is addressed by the concatenation of the packet's demote status and its priority value computed during ingress processing.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | G3    | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|-------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3 | 2  | 1  | 0  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

### Figure 223. Port Numbering Scheme

## Priority\_Encode\_Table\_{0..4}

Description: Encodes the DSCP field to an internal priority representation.

### Table 295. Priority\_Encode\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_de00 |
| Register Size      | 256         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 64          |
| Record Spacing     | 4           |



### Figure 224. Priority\_Encode\_Table\_{0..4} Register Diagram

### Table 296. Priority\_Encode\_Table\_{0..4} Field Parameters

| Field Name    | Parameters                                   | Description                 |
|---------------|----------------------------------------------|-----------------------------|
| priority[3:0] | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | The encoded priority value. |

This table is used to encode the IP header's 6-bit DSCP value. This table is addressed by the DSCP value extracted from the packet's IP header, and the 4-bit encoded priority value is returned.

#### PORT NUMBERING SCHEME



G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 225. Port Numbering Scheme

# Priority\_Encode\_Table\_{5..6}

Description: Encodes the DSCP field to an internal priority representation.

### Table 297. Priority\_Encode\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5e00 |
| Register Size      | 256         |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 64          |
| Record Spacing     | 4           |



## Figure 226. Priority\_Encode\_Table\_{5..6} Register Diagram

### Table 298. Priority\_Encode\_Table\_{5..6} Field Parameters

| Field Name    | Parameters                                   | Description                 |  |  |
|---------------|----------------------------------------------|-----------------------------|--|--|
| priority[3:0] | Mode = R/W<br>Offset = 0.28<br>Instances = 1 | The encoded priority value. |  |  |

This table is used to encode the IP header's 6-bit DSCP value. This table is addressed by the DSCP value extracted from the packet's IP header, and the 4-bit encoded priority value is returned.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 227. Port Numbering Scheme

## **Rx\_Bytes**

Description: Statistics counter.

### Table 299. Rx\_Bytes Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_6400 |
| Register Size      | 200         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 200         |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 228. Rx\_Bytes Register Diagram

### Table 300. Rx\_Bytes Field Parameters

| Field Name     | Parameters                                                    | Description                                                            |
|----------------|---------------------------------------------------------------|------------------------------------------------------------------------|
| rx_bytes[27:0] | Mode = R/W<br>Offset = 0.4<br>Instances = 50<br>Spacing = 4.0 | The number of packet bytes received (including those with CRC errors). |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 229. Port Numbering Scheme

## Rx\_Error\_Packets

Description: Statistics counters.

### Table 301. Rx\_Error\_Packets Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_5800 |
| Register Size      | 800         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 800         |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 230. Rx\_Error\_Packets Register Diagram

### Table 302. Rx\_Error\_Packets Field Parameters

| Field Name                       | Parameters                                                       | Description                                                                                                                                           |
|----------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_alignment_error_packets[21:0] | Mode = R/W<br>Offset = 0.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received with an alignment<br>error (bad CRC and dribble bits) that are at least<br>64 bytes in length.                         |
| rx_crc_error_packets[21:0]       | Mode = R/W<br>Offset = 4.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received with an CRC error,<br>no dribble bits, and are at least 64 bytes in length.                                            |
| rx_code_error_packets[21:0]      | Mode = R/W<br>Offset = 8.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received with a CRC error<br>and a code error. These packets do not have drib-<br>ble bits and are at least 64 bytes in length. |
| rx_fragment_packets[21:0]        | Mode = R/W<br>Offset = 12.10<br>Instances = 50<br>Spacing = 16.0 | The number of packets received with a CRC error<br>and are less than 64 bytes in length. Code errors<br>and dribble bits may also be present.         |

### Rx\_Error\_Packets (continued)

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and to use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

| PORT NUMBERING SCHEME |
|-----------------------|
|-----------------------|

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

Figure 231. Port Numbering Scheme

### Rx\_Length\_Histogram

Description: Statistics counters.

#### Table 303. Rx\_Length\_Histogram Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_4000 |
| Register Size      | 2000        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 2000        |
| Record Instances   | 1           |
| Record Spacing     | NA          |

#### 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31. 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 1

|    | 31 30 29 20 21 20 23 24 23 22 |                                 |
|----|-------------------------------|---------------------------------|
| 0  |                               | rx_64_byte_packets[21:0]        |
| 4  |                               | rx_65_127_byte_packets[21:0]    |
| 8  |                               | rx_128_255_byte_packets[21:0]   |
| 12 |                               | rx_256_511_byte_packets[21:0]   |
| 16 |                               | rx_512_1023_byte_packets[21:0]  |
| 20 |                               | rx_1024_1518_byte_packets[21:0] |
| 24 |                               | rx_1519_1522_byte_packets[21:0] |
| 28 |                               | rx_jumbo_packets[21:0]          |
|    |                               |                                 |

| 1,600 | rx_runt_packets[21:0]      |
|-------|----------------------------|
| 1,604 | rx_oversized_packets[21:0] |

### Figure 232. Rx\_Length\_Histogram Register Diagram

#### Table 304. Rx\_Length\_Histogram Field Parameters

| Field Name                    | Parameters     | Description                                    |
|-------------------------------|----------------|------------------------------------------------|
| rx_64_byte_packets[21:0]      | Mode = R/W     | Packets of all types received without errors   |
|                               | Offset = 0.10  | whose overall length is 64 bytes.              |
|                               | Instances = 50 |                                                |
|                               | Spacing = 32   |                                                |
| rx_65_127_byte_packets[21:0]  | Mode = R/W     | Packets of all types received without errors   |
|                               | Offset = 4.10  | whose overall length is from 65 to 127 bytes.  |
|                               | Instances = 50 |                                                |
|                               | Spacing = 32   |                                                |
| rx_128_255_byte_packets[21:0] | Mode = R/W     | Packets of all types received without errors   |
|                               | Offset = 8.10  | whose overall length is from 128 to 255 bytes. |
|                               | Instances = 50 |                                                |
|                               | Spacing = 32   |                                                |

### Rx\_Length\_Histogram (continued)

#### Table 304. Rx\_Length\_Histogram Field Parameters (continued)

| Field Name                      | Parameters       | Description                                      |
|---------------------------------|------------------|--------------------------------------------------|
| rx_256_511_byte_packets[21:0]   | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 12.10   | whose overall length is from 256 to 511 bytes.   |
|                                 | Instances = 50   |                                                  |
|                                 | Spacing = 32     |                                                  |
| rx_512_1023_byte_packets[21:0]  | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 16.10   | whose overall length is from 512 to 1,023 bytes. |
|                                 | Instances = 50   |                                                  |
|                                 | Spacing = 32     |                                                  |
| rx_1024_1518_byte_packets[21:0] | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 20.10   | whose overall length is from 1,024 to            |
|                                 | Instances = 50   | 1,518 bytes.                                     |
|                                 | Spacing = 32     |                                                  |
| rx_1519_1522_byte_packets[21:0] | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 24.10   | whose overall length is from 1,519 to            |
|                                 | Instances = 50   | 1,522 bytes.                                     |
|                                 | Spacing = 32     |                                                  |
| rx_jumbo_packets[21:0]          | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 28.10   | whose overall length is greater than 1,522 bytes |
|                                 | Instances = 50   | and less than 16,384 bytes.                      |
|                                 | Spacing = 32     |                                                  |
| rx_runt_packets[21:0]           | Mode = R/W       | Packets of all types received without errors     |
|                                 | Offset = 1600.10 | whose overall length is less than 64 bytes.      |
|                                 | Instances = 50   |                                                  |
|                                 | Spacing = 8      |                                                  |
| rx_oversized_packets[21:0]      | Mode = R/W       | Packets of all types whose overall length is     |
|                                 | Offset = 1604.10 | greater than or equal to 16,384 bytes.           |
|                                 | Instances = 50   |                                                  |
|                                 | Spacing = 8      |                                                  |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

 $\label{eq:G} \begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

#### Figure 233. Port Numbering Scheme

### **Rx\_Packets**

Description: Statistics counters.

#### Table 305. Rx\_Packets Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_5c00 |
| Register Size      | 1000        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 1000        |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 234. Rx\_Packets Register Diagram

### Rx\_Packets (continued)

#### Table 306. Rx\_Packets Field Parameters

| Field Name                 | Parameters                                                       | Description                                                                                         |
|----------------------------|------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| rx_unicast_packets[21:0]   | Mode = R/W<br>Offset = 0.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received (without errors) whose destination address is a unicast address.     |
| rx_multicast_packets[21:0] | Mode = R/W<br>Offset = 4.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received (without errors) whose destination address is a multicast address.   |
| rx_broadcast_packets[21:0] | Mode = R/W<br>Offset = 8.10<br>Instances = 50<br>Spacing = 16.0  | The number of packets received (without errors) whose destination address is the broadcast address. |
| rx_pause_packets[21:0]     | Mode = R/W<br>Offset = 12.10<br>Instances = 50<br>Spacing = 16.0 | The number of packets received (without errors) that are pause control packets.                     |
| rx_other_control[21:0]     | Mode = R/W<br>Offset = 800.10<br>Instances = 50<br>Spacing = 4.0 | The number of packets received (without errors) that are control packets other than pause packets.  |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

| PORT                                                                    | XG1 | XG0 | G47 | G46 | G45 | G44 |  | G3 | G2 | G1 | G0 |
|-------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|----|----|----|----|
| REFERENCE                                                               | 49  | 48  | 47  | 46  | 45  | 44  |  | 3  | 2  | 1  | 0  |
| G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT<br>SU = SUPERVISOR |     |     |     |     |     |     |  |    |    |    |    |

PORT NUMBERING SCHEME

#### Figure 235. Port Numbering Scheme

## Serdes\_Control\_{4}

Description: Provides access to SFP SerDes registers.

#### Table 307. Serdes\_Control\_{4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8240 |
| Register Size      | 12          |
| Register Instances | 1           |
| Register Spacing   | 128         |
| Record Size        | 12          |
| Record Instances   | 1           |
| Record Spacing     | NA          |



Figure 236. Serdes\_Control\_{4} Register Diagram

### Serdes\_Control\_{4} (continued)

#### Table 308. Serdes\_Control\_{4} Field Parameters

| Field Name                                        | Parameters                                                                                         | Description                                                                                                                                                                                                                                                                            |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| access_command[2:0]                               | Mode = WO<br>Offset = 0.28<br>Instances = 1                                                        | Defines the type of SerDes register access func-<br>tion to be performed:<br>0002 = 8-bit read (SerDes macro registers)<br>1002 = 8-bit write (SerDes macro registers)<br>0102 = 16-bit read (SerDes PRBS registers)<br>1102 = 16-bit write (SerDes PRBS registers)<br>xx12 = reserved |
| command_start                                     | Mode = WO<br>Offset = 0.31<br>Instances = 1                                                        | Writing a one to this bit causes the execution of the specified access command.                                                                                                                                                                                                        |
| serdes_wr_data[7:0]<br>or<br>serdes_wr_data[15:0] | Mode = R/W<br>Offset = 4.16<br>Instances = 1<br>or<br>Mode = R/W<br>Offset = 4.0<br>Instances = 1  | The 8-bit or 16-bit data word to be written to the specified SerDes register. The width and offset of this field must be consistent with the command issued via access_command[2:0].                                                                                                   |
| serdes_wr_addr[7:0]<br>or<br>serdes_wr_addr[15:0] | Mode = R/W<br>Offset = 4.24<br>Instances = 1<br>or<br>Mode = R/W<br>Offset = 4.16<br>Instances = 1 | The 8-bit or 16-bit address to be used to specify<br>the desired SerDes register. The width and offset<br>of this field must be consistent with the command<br>issued via access_command[2:0].                                                                                         |
| serdes_command_busy                               | Mode = RO<br>Offset = 8.0<br>Instances = 1                                                         | This bit is asserted to indicate that the requested<br>SerDes registers access command is currently<br>being executed. While this bit is asserted, writes<br>to all fields of this register are ignored.                                                                               |
| serdes_command_done                               | Mode = RO<br>Offset = 8.1<br>Instances = 1                                                         | This bit is asserted to indicate that the requested<br>SerDes register access command has completed<br>operation. If the requested command was a read<br>command, then this bit serves as an indication<br>that serdes_rd_data[15:0] is valid.                                         |
| serdes_rd_data[15:0]                              | Mode = RO<br>Offset = 8.16<br>Instances = 1                                                        | Data from read commands is returned via this field. For 8-bit reads, the data occupies the least significant 8 bits of this field (serdes_rd_data[7:0]).                                                                                                                               |

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 237. Port Numbering Scheme

## Serdes\_Control\_{5}

Description: Provides access to XAUI SerDes registers.

#### Table 309. Serdes\_Control\_{5} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_8280 |
| Register Size      | 16          |
| Register Instances | 2           |
| Register Spacing   | 64          |
| Record Size        | 16          |
| Record Instances   | 1           |
| Record Spacing     | NA          |



Figure 238. Serdes\_Control\_{5} Register Diagram

### Serdes\_Control\_{5} (continued)

### Table 310. Serdes\_Control\_{5} Field Parameters

| Field Name                                        | Parameters                                                                                             | Description                                                                                                                                                                                                                                                                            |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| access_command[2:0]                               | Mode = WO<br>Offset = 0.28<br>Instances = 1                                                            | Defines the type of SerDes register access function to be per-<br>formed:<br>0002 = 8-bit read (SerDes macro registers)<br>1002 = 8-bit write (SerDes macro registers)<br>0102 = 16-bit read (SerDes PRBS registers)<br>1102 = 16-bit write (SerDes PRBS registers)<br>xx12 = reserved |
| command_start                                     | Mode = WO<br>Offset = 0.31<br>Instances = 1                                                            | Writing a one to this bit causes the execution of the specified access command.                                                                                                                                                                                                        |
| serdes_wr_data[7:0]<br>or<br>serdes_wr_data[15:0] | Mode = R/W<br>Offset = 4.16<br>Instances = 1<br>or<br>Mode = R/W<br>Offset = 4.0<br>Instances = 1      | The 8- bit or 16-bit data word to be written to the specified Ser-<br>Des register. The width and offset of this field must be consis-<br>tent with the command issued via access_command[2:0].                                                                                        |
| serdes_wr_addr[7:0]<br>or<br>serdes_wr_addr[15:0] | Mode = $R/W$<br>Offset = 4.24<br>Instances = 1<br>or<br>Mode = $R/W$<br>Offset = 4.16<br>Instances = 1 | The 8-bit or 16-bit address to be use to specify the desired Ser-<br>Des register. The width and offset of this field must be consis-<br>tent with the command issued via access_command[2:0].                                                                                         |
| serdes_command_busy                               | Mode = RO<br>Offset = 8.0<br>Instances = 1                                                             | This bit is asserted to indicate that the requested SerDes regis-<br>ters access command is currently being executed. While this bit<br>is asserted, writes to all fields of this register are ignored.                                                                                |
| serdes_command_done                               | Mode = RO<br>Offset = 8.1<br>Instances = 1                                                             | This bit is asserted to indicate that the requested SerDes register access command has completed operation. If the requested command was a read command, then this bit serves as an indication that serdes_rd_data[15:0] is valid.                                                     |
| serdes_rd_data[15:0]                              | Mode = RO<br>Offset = 8.16<br>Instances = 1                                                            | Data from read commands is returned via this field. For 8-bit reads, the data occupies the least significant 8 bits of this field (serdes_rd_data[7:0]).                                                                                                                               |
| local_fault                                       | Mode = RO<br>Offset = 12.24<br>Instances = 1                                                           | Indicates a fault at the local station such as failure to acquire lane synchronization or lane deskew.                                                                                                                                                                                 |
| remote_fault                                      | Mode = RO<br>Offset = 12.25<br>Instances = 1                                                           | Indicates a fault at the far-end station.                                                                                                                                                                                                                                              |
| lanes_not_deskewed                                | Mode = R/W<br>Offset = 12.26<br>Instances = 1                                                          | This bit is asserted upon the detection of a not-deskewed event<br>for any of the lanes. Once such an event is detected, this bit is<br>asserted and remains asserted until cleared. This bit is cleared<br>by writing a 1 to its position.                                            |

### Serdes\_Control\_{5} (continued)

### Table 310. Serdes\_Control\_{5} Field Parameters (continued)

| Field Name     | Parameters                                   | Description                                                                                                                                              |
|----------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| lanes_deskewed | Mode = RO<br>Offset = 12.27<br>Instances = 1 | This bit provides a real-time indication of whether or not all of the associated SerDes lanes are deskewed.                                              |
| lane_sync[3:0] | Mode = RO<br>Offset = 12.28<br>Instances = 1 | Data from read commands is returned via this field. For 8-bit reads, the data occupies the least significant 8 bits of this field (serdes_rd_data[7:0]). |

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 | G = 10/100/1000 Mbits/s PORT<br>XG = 10 Gbits/s PORT |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|------------------------------------------------------|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  | SU = SUPERVISOR                                      |

Figure 239. Port Numbering Scheme

### Supervisor\_Endian

Description: Establishes the endian mode of the PCI interface.

#### Table 311. Supervisor\_Endian Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c520 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 240. Supervisor\_Endian Register Diagram

| Field Name | Parameters                                   | Description                                                                                                                                                            |
|------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| big_endian | Mode = R/W<br>Offset = 0.31<br>Instances = 1 | When asserted, this <i>PCI</i> interface presents data across the <i>PCI</i> bus in a big-endian fashion. Little endian (this bit deasserted) is the default behavior. |

### Supervisor\_Ind

Description: Provides supervisor indications from supervisor\_access.

#### Table 313. Supervisor\_Ind Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c448 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 241. Supervisor\_Ind Register Diagram

#### Table 314. Supervisor\_Ind Field Parameters

| Field Name             | Parameters                                                   | Description                                                                                                                                                                                                                                                                                           |
|------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_fifo_not_empty_{70} | Mode = RO<br>Offset = 0.16<br>Instances = 8<br>Spacing = 0.1 | These bits indicate when the various supervisor receive FIFOs are<br>not empty. Each bit corresponds to a single FIFO. In order to clear<br>one of these bits, its associated FIFO must be emptied by the<br>supervisor.                                                                              |
| invalid_addr           | Mode = R/W<br>Offset = 0.29<br>Instances = 1                 | This bit is asserted to indicate that a recent supervisor access to<br>the ET4148-50 was not addressed to a valid location. The address<br>causing this indication can be determined via<br>Supervisor_Invalid_Addr. invalid_addr is cleared by the<br>supervisor writing a one to this bit location. |
| tx_packet[1:0]         | Mode = R/W<br>Offset = 0.30<br>Instances = 1                 | This bit is asserted to indicate that a marked packet (one whose Supervisor_Tx_Descriptor.indicate bit is asserted) has been transferred to the ET4148-50 for transmission. Bits in tx_packet[1:0] are cleared by the supervisor writing a one to their bit locations.                                |

Various indications to the supervisor regarding supervisor. These indications may be masked by Supervisor\_Ind\_Mask.

### Supervisor\_Ind\_Mask

Description: supervisor\_access related indication mask.

#### Table 315. Supervisor\_Ind\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c44c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 242. Supervisor\_Ind\_Mask Register Diagram

#### Table 316. Supervisor\_Ind\_Mask Field Parameters

| Field Name     | Parameters                                  | Description                   |
|----------------|---------------------------------------------|-------------------------------|
| ind_mask[15:0] | Mode = RO<br>Offset = 0.16<br>Instances = 1 | Various indication mask bits. |

This register shows the current state of the indication mask. Mask bits are set via Supervisor\_Ind\_Mask\_Set and cleared via Supervisor\_Ind\_Mask\_Clear.

For the definitions of the various mask bits, see Supervisor\_Ind, page 228.

### Supervisor\_Ind\_Mask\_Clear

Description: Clears bits in Supervisor\_Ind\_Mask.

#### Table 317. Supervisor\_Ind\_Mask\_Clear Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c450 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



### Figure 243. Supervisor\_Ind\_Mask\_Clear Register Diagram

#### Table 318. Supervisor\_Ind\_Mask\_Clear Field Parameters

| Field Name           | Parameters                                  | Description                         |
|----------------------|---------------------------------------------|-------------------------------------|
| ind_mask_clear[15:0] | Mode = WO<br>Offset = 0.16<br>Instances = 1 | Various indication mask clear bits. |

Writing ones to bit locations in this register causes the corresponding bits in Supervisor\_Ind\_Mask to be cleared. For the definitions of the various mask clear bits, see Supervisor\_Ind, page 228.

### Supervisor\_Ind\_Mask\_Set

Description: Sets bits in Supervisor\_Ind\_Mask.

#### Table 319. Supervisor\_Ind\_Mask\_Set Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c454 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 244. Supervisor\_Ind\_Mask\_Set Register Diagram

#### Table 320. Supervisor\_Ind\_Mask\_Set Field Parameters

| Field Name         | Parameters                                  | Description                       |
|--------------------|---------------------------------------------|-----------------------------------|
| ind_mask_set[15:0] | Mode = WO<br>Offset = 0.16<br>Instances = 1 | Various indication mask set bits. |

Writing ones to bit locations in this register causes the corresponding bits in Supervisor\_Ind\_Mask to be set.

For the definitions of the various mask set bits, see Supervisor\_Ind, page 228.

### Supervisor\_Int

Description: Supervisor related interrupts.

#### Table 321. Supervisor\_Int Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c458 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 245. Supervisor\_Int Register Diagram

#### Table 322. Supervisor\_Int Field Parameters

| Fie       | eld Name | Parameters                                  | Description                    |
|-----------|----------|---------------------------------------------|--------------------------------|
| int[15:0] |          | Mode = RO<br>Offset = 0.16<br>Instances = 1 | Various supervisor interrupts. |

This register presents those indications that have not been masked by Supervisor\_Int\_Mask.

For the definitions of the various interrupt bits, see Supervisor\_Ind, page 228.

### Supervisor\_Int\_Mask

Description: supervisor\_access related interrupt mask.

#### Table 323. Supervisor\_Int\_Mask Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c45c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 246. Supervisor\_Int\_Mask Register Diagram

#### Table 324. Supervisor\_Int\_Mask Field Parameters

| Field Name     | Parameters                                  | Description                  |
|----------------|---------------------------------------------|------------------------------|
| int_mask[15:0] | Mode = RO<br>Offset = 0.16<br>Instances = 1 | Various interrupt mask bits. |

This register shows the current state of the indication mask. Mask bits are set via Supervisor\_Int\_Mask\_Set and cleared via Supervisor\_Int\_Mask\_Clear.

For the definitions of the various mask bits, see Supervisor\_Ind, page 228.

### Supervisor\_Int\_Mask\_Clear

Description: Clears bits in Supervisor\_Int\_Mask.

#### Table 325. Supervisor\_Int\_Mask\_Clear Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c460 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 0

### Figure 247. Supervisor\_Int\_Mask\_Clear Register Diagram

#### Table 326. Supervisor\_Int\_Mask\_Clear Field Parameters

| Field Name           | Parameters                                  | Description                        |
|----------------------|---------------------------------------------|------------------------------------|
| int_mask_clear[15:0] | Mode = WO<br>Offset = 0.16<br>Instances = 1 | Various interrupt mask clear bits. |

Writing ones to bit locations in this register causes the corresponding bits in Supervisor\_Int\_Mask to be cleared. For the definitions of the various mask clear bits, see Supervisor\_Ind, page 228,

### Supervisor\_Int\_Mask\_Set

Description: Sets bits in Supervisor\_Int\_Mask.

#### Table 327. Supervisor\_Int\_Mask\_Set Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c464 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 248. Supervisor\_Int\_Mask\_Set Register Diagram

#### Table 328. Supervisor\_Int\_Mask\_Set Field Parameters

| Field Name         | Parameters                                  | Description                      |
|--------------------|---------------------------------------------|----------------------------------|
| int_mask_set[15:0] | Mode = WO<br>Offset = 0.16<br>Instances = 1 | Various interrupt mask set bits. |

Writing ones to bit locations in this register causes the corresponding bits in Supervisor\_Int\_Mask to be set. For the definitions of the various mask set bits, see Supervisor\_Ind, page 228.

### Supervisor\_Invalid\_Addr

Description: Provides supervisor with the address that resulted in an invalid address indication.

#### Table 329. Supervisor\_Invalid\_Addr Register Parameters

| Parameter          | Value       |  |  |  |  |  |  |  |
|--------------------|-------------|--|--|--|--|--|--|--|
| Base Address       | 0x000c_c468 |  |  |  |  |  |  |  |
| Register Size      | 4           |  |  |  |  |  |  |  |
| Register Instances | 1           |  |  |  |  |  |  |  |
| Register Spacing   | NA          |  |  |  |  |  |  |  |
| Record Size        | 4           |  |  |  |  |  |  |  |
| Record Instances   | 1           |  |  |  |  |  |  |  |
| Record Spacing     | NA          |  |  |  |  |  |  |  |



### Figure 249. Supervisor\_Invalid\_Addr Register Diagram

#### Table 330. Supervisor\_Invalid\_Addr Field Parameters

| Field Name                    | Parameters                                  | Description                                                  |
|-------------------------------|---------------------------------------------|--------------------------------------------------------------|
| supervisor_invalid_addr[31:2] | Mode = R/W<br>Offset = 0.0<br>Instances = 1 | The location of an invalid address access by the supervisor. |

This register captures and presents the address of a supervisor access cycle that failed to address a valid location. Once an address value is captured, this register ignores all future invalid address events until Supervisor\_Ind.invalid\_addr has been cleared.

### Supervisor\_Maximum\_Packet\_Length

Description: Determines the maximum packet length expected to be received by the supervisor.

| Table 331. Supervisor | _Maximum_ | _Packet_L | ength Reg | ister Parameters |
|-----------------------|-----------|-----------|-----------|------------------|
|-----------------------|-----------|-----------|-----------|------------------|

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c540 |
| Register Size      | 32          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 8           |
| Record Spacing     | 4           |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |



#### Table 332. Supervisor\_Maximum\_Packet\_Length Field Parameters

| Fie           | ld Name              | Parameters                                   | Description                                                                                                                |
|---------------|----------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| maximum_packe | et_length_{07}[13:2] | Mode = R/W<br>Offset = 0.18<br>Instances = 1 | Maximum packet length.<br><b>Note:</b> For proper operation, the minimum value<br>for this field should be 0x4 or greater. |

The  $maximum_packet_length_{n}[13:2]$  value is used to determine where to truncate packets and when it is necessary to wrap from the end (or near the end) of a receive FIFO to the start.

If a received packet's length exceeds maximum\_packet\_length[13:2], then the packet is truncated to a length equal to maximum\_packet\_length[13:2] during its transfer from the ET4148-50 to the supervisor's memory system.

Wrapping from the end of a receive FIFO space to the start occurs when the space remaining in a receive FIFO is less than the value of maximum\_packet\_length[13:2].

There are eight records in this register. Each record corresponds to an individual supervisor receive queue according to the following table.

### Supervisor\_Maximum\_Packet\_Length (continued)

#### Table 333. Supervisor Receive Queue and Corresponding Register Records

| Queue | Register Record |
|-------|-----------------|
| 400   | 0               |
| 401   | 1               |
| 402   | 2               |
| 403   | 3               |
| 404   | 4               |
| 405   | 5               |
| 406   | 6               |
| 407   | 7               |

#### QUEUE NUMBERING SCHEME



 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

#### Figure 251. Queue Numbering Scheme

## Supervisor\_Rx\_Fifo\_Limits

Description: Defines the dimensions of the supervisor's receive packet FIFOs.

#### Table 334. Supervisor\_Rx\_Fifo\_Limits Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c480 |
| Register Size      | 128         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 8           |
| Record Spacing     | 16          |

|    | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12  | 13    | 14    | 15    | 16    | 17    | 18   | 19   | 20    | 21    | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|-------|-------|-------|-------|------|------|-------|-------|----|----|----|----|----|----|----|----|----|----|
|    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18    | 17    | 16    | 15    | 14    | 13   | 12   | 11    | 10    | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |    |    |    |    |    |    |    |    |    |    |    |    | rx_ | _fifo | _sta  | rt_pt | r[31: | 2]    |      |      |       |       |    |    |    |    |    |    |    |    | 0  | 0  |
| 4  |    |    |    |    |    |    |    |    |    |    |    |    | ۲x  | _fifo | _en   | d_pti | [31:  | 2]    |      |      |       |       |    |    |    |    |    |    |    |    | 0  | 0  |
| 8  |    |    |    |    |    |    |    |    |    |    |    |    | rx. | _fifo | _firs | t_pti | [31:  | 2]    |      |      |       |       |    |    |    |    |    |    |    |    | 0  | 0  |
| 12 |    |    |    |    |    |    |    |    |    |    |    |    |     |       |       |       | cong  | gesti | on_t | hres | sholo | d[23: | 2] |    |    |    |    |    |    |    | 0  | 0  |

#### Figure 252. Supervisor\_Rx\_Fifo\_Limits Register Diagram

| Table 335. Supervisor Rx | Fifo_Limits Field Parameters |
|--------------------------|------------------------------|
|--------------------------|------------------------------|

| Field Name                      | Parameters                                   | Description                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_fifo_start_ptr_{07}[31:2]    | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Defines the location within supervisor memory of the first 32-bit word of a receive FIFO.                                                                                                                                                                                                                                               |
| rx_fifo_end_ptr_{07}[31:2]      | Mode = R/W<br>Offset = 4.0<br>Instances = 1  | Defines the location within supervisor memory of the last 32-bit word of a receive FIFO.                                                                                                                                                                                                                                                |
| rx_fifo_first_ptr_{07}[31:2]    | Mode = R/W<br>Offset = 8.0<br>Instances = 1  | Defines the location within supervisor memory of<br>the packet that the supervisor is currently using.<br>This value is maintained by the supervisor and<br>interpreted by the ET4148-50. It prevents the<br>ET4148-50 from overwriting packets that are either<br>currently in use or have not yet been examined by<br>the supervisor. |
| congestion_threshold_{07}[23:2] | Mode = R/W<br>Offset = 12.8<br>Instances = 1 | This field is reserved. Program to 0x3FFFFF.                                                                                                                                                                                                                                                                                            |

### Supervisor\_Rx\_Fifo\_Limits (continued)

This register is used to define the physical characteristics of the eight supervisor receive FIFOs. These FIFOs reside within the supervisor's memory space.

There are eight instances of the three-field record diagrammed in Figure 252. The record at offset zero corresponds to receive FIFO zero.

rx\_fifo\_start\_ptr[31:2] identifies the first physical location of the receive FIFO.

rx\_fifo\_end\_ptr[31:2] identifies the last physical location of the receive FIFO.

rx\_fifo\_start\_ptr[31:2] must be less than rx\_fifo\_end\_ptr[31:2]. These values are established during initialization and must be left static during normal operation.

As the supervisor processes each packet, it writes the supervisor memory address of the first 32-bit word of the received packet's data structure to  $rx_fifo_first_ptr[31:2]$ . The first 32-bit word of each packet is  $supervisor_Rx_Packet.packet_start_ptr[31:2]$ .  $rx_fifo_first_ptr[31:2]$  has the effect of protecting this packet from being overwritten by the ET4148-50 (the ET4148-50 checks to make sure that there is sufficient room to fit a maximum length packet into a receive FIFO without overwriting the location pointed to by  $rx_fifo_first_ptr[31:2]$ ).

There are eight records in this register. Each record corresponds to an individual supervisor receive queue according to the following table.

| Queue | Register Record |
|-------|-----------------|
| 400   | 0               |
| 401   | 1               |
| 402   | 2               |
| 403   | 3               |
| 404   | 4               |
| 405   | 5               |
| 406   | 6               |
| 407   | 7               |

#### Table 336. Supervisor Receive Queue and Corresponding Register Records

#### QUEUE NUMBERING SCHEME



G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 253. Queue Numbering Scheme

### Supervisor\_Rx\_Fifo\_Ptr

Description: The pointers used in managing the supervisor's receive packet FIFOs.

#### Table 337. Supervisor\_Rx\_Fifo\_Ptr Register Diagram

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c400 |
| Register Size      | 64          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 8           |
| Record Instances   | 8           |
| Record Spacing     | 8           |

|   | 0                      | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|---|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0 | rx_fifo_last_ptr[31:2] |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 8 | rx_fifo_wr_ptr[31:2]   |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 254. Supervisor\_Rx\_Fifo\_Ptr Register Parameters

#### Table 338. Supervisor\_Rx\_Fifo\_Ptr Field Parameters

| Field Name             | Parameters                                  | Description                                                                                                                                                                                                                                                                             |
|------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_fifo_last_ptr[31:2] | Mode = R/W<br>Offset = 4.0<br>Instances = 1 | Defines the location within supervisor memory of<br>the last complete packet stored by the ET4148-50<br>in supervisor memory. This pointer is maintained by<br>the ET4148-50 and interpreted by the supervisor. It<br>lets the supervisor know which packet is the last in<br>the FIFO. |
| rx_fifo_wr_ptr[31:2]   | Mode = R/W<br>Offset = 8.0<br>Instances = 1 | This register is for informational purposes only and<br>need not be accessed during normal operation.<br>rx_fifo_wr_ptr[31:2] reflects the supervisor<br>address currently or most recently addressed by the<br>ET4148-50 during receive packet transfer opera-<br>tions.               |

### Supervisor\_Rx\_Fifo\_Ptr (continued)

These pointers are used during the operation of the receive FIFOs. There are eight instances of the three-field record diagrammed in Figure 254. The record at offset zero corresponds to receive FIFO zero.

As the ET4148-50 deposits packets into the FIFOs maintained within supervisor memory, it advances  $rx_fifo_last_ptr[31:2]$ . At all times, this pointer identifies the last complete packet deposited into the supervisor's receive FIFOs. This pointer is set to point to the first 32-bit word of a receive packet data structure (Supervisor\_Rx\_Packet.packet\_start\_ptr[31:2]). By interpreting this pointer, the supervisor is able to know which packet is the last one in the FIFO and, hence, when it should cease processing receive packets for the associated FIFO.

Whenever Supervisor\_Rx\_Fifo\_Limits.rx\_fifo\_first\_ptr[31:2] and rx\_fifo\_last\_ptr[31:2] are equal, the corresponding FIFO is empty.

There are eight records in this register. Each record corresponds to an individual supervisor receive queue according to the following table.

| Queue | Register Record |
|-------|-----------------|
| 400   | 0               |
| 401   | 1               |
| 402   | 2               |
| 403   | 3               |
| 404   | 4               |
| 405   | 5               |
| 406   | 6               |
| 407   | 7               |

#### Table 339. Supervisor Receive Queue and Corresponding Register Records







SU = SUPERVISOR

Figure 255. Queue Numbering Scheme

### Supervisor\_Statistics\_Transfer\_Addr

Description: Defines the starting address of the statistics transfer destination.

#### Table 340. Supervisor\_Statistics\_Transfer\_Addr Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c46c |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 256. Supervisor\_Statistics\_Transfer\_Addr Register Diagram

#### Table 341. Supervisor\_Statistics\_Transfer\_Addr Field Parameters

| Field Name                     | Parameters                                  | Description                                                                                                    |
|--------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| statistics_transfer_addr[31:2] | Mode = R/W<br>Offset = 0.0<br>Instances = 1 | Defines the location within supervisor memory to where the Ethernet MAC statistics block is to be transferred. |

This register is used to define the starting location of a block of memory in the supervisor's address space that is used as the destination for Ethernet MAC statistics block transfers. The actual transfer of statistics data is initiated by writing to this register.

### Supervisor\_Statistics\_Transfer\_Status

Description: Indicates the status of a statistics block transfer.

#### Table 342. Supervisor\_Statistics\_Transfer\_Status Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c470 |
| Register Size      | 4           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 257. Supervisor\_Statistics\_Transfer\_Status Register Diagram

#### Table 343. Supervisor\_Statistics\_Transfer\_Status Field Parameters

| Field Name               | Parameters                                   | Description                                                                                                                        |
|--------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| statistics_transfer_done | Mode = R/W<br>Offset = 0.30<br>Instances = 1 | This bit is asserted upon the completion of a statis-<br>tics block transfer. It is reset by writing a one to its<br>bit position. |
| statistics_transfer_busy | Mode = RO<br>Offset = 0.31<br>Instances = 1  | This bit is asserted during the transfer of the statis-<br>tics block to indicate that such a transfer is in pro-<br>cess.         |

This register provides basic status for statistics block transfers. A statistics block transfer is initiated by writing the block's transfer destination address to Supervisor\_Statistics\_Transfer\_Addr. Upon initiation of the transfer, statistics\_transfer\_busy is automatically asserted and remains asserted throughout the duration of the transfer. At the completion of the transfer, statistics\_transfer\_busy is deasserted and statistics\_transfer\_done is asserted. statistics\_transfer\_done is also made available to the supervisor as an interrupt-generating indication. The supervisor must write a one to the bit position of statistics\_transfer\_done in order to deassert the bit and cancel its indication.

## Supervisor\_Tx\_Fifo\_Limits

Description: Defines the dimensions of the supervisor's transmit packet FIFOs.

#### Table 344. Supervisor\_Tx\_Fifo\_Limits Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c500 |
| Register Size      | 32          |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 16          |
| Record Instances   | 2           |
| Record Spacing     | 16          |

|    | 0                        | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  | tx_fifo_start_ptr[31:2]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 4  | 4 tx_fifo_end_ptr[31:2]  |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 8  | 8 tx_fifo_last_ptr[31:2] |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 12 |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### Figure 258. Supervisor\_Tx\_Fifo\_Limits Register Diagram

| Field Name                   | Parameters                                    | Description                                                                                                                                                                                                                                                       |
|------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_fifo_start_ptr_{01}[31:2] | Mode = R/W<br>Offset = 0.0<br>Instances = 1   | Defines the location within supervisor memory of the first 32-bit word of a transmit FIFO.                                                                                                                                                                        |
| tx_fifo_end_ptr_{01}[31:2]   | Mode = R/W<br>Offset = 4.0<br>Instances = 1   | Defines the location within supervisor memory of the last 32-bit word of a transmit FIFO.                                                                                                                                                                         |
| tx_fifo_last_ptr_{01}[31:2]  | Mode = R/W<br>Offset = 8.0<br>Instances = 1   | Defines the location within supervisor memory of<br>the last complete packet transmission FIFO entry.<br>This value is maintained by the supervisor and<br>interpreted by the ET4148-50. It prevents the<br>ET4148-50 from reading beyond the end of the<br>FIFO. |
| tx_en_{01}                   | Mode = R/W<br>Offset = 12.31<br>Instances = 1 | Enables transmission via the corresponding queue.                                                                                                                                                                                                                 |

### Supervisor\_Tx\_Fifo\_Limit (continued)

This register is used to define the physical characteristics of the two supervisor transmit FIFOs. These FIFOs reside within the supervisor's memory space.

There are two instances of the three-field record diagrammed above. The record at offset zero corresponds to transmit FIFO zero. Transmit FIFO zero is the low-priority FIFO. Transmit FIFO one is the high-priority FIFO. If transmit FIFO one is nonempty, it is serviced until empty prior to continuing to service transmit FIFO zero.

 $tx_fifo_start_ptr[31:2]$  identifies the first physical location of a transmit FIFO.  $tx_fifo_end_ptr[31:2]$  identifies the last physical location of a transmit FIFO.  $tx_fifo_start_ptr[31:2]$  must be less than  $tx_fifo_end_ptr[31:2]$ . These values are established during initialization and must be left static during normal operation.

As the user adds entries to a transmit FIFO, it advances  $tx_fifo_last_ptr[31:2]$  to always point to the last FIFO entry. The ET4148-50 interprets this value and uses it to determine when the FIFO is empty, nonempty, or full.

### Supervisor\_Tx\_Fifo\_Ptr

Description: The pointers used in managing the supervisor's transmit packet FIFOs.

#### Table 346. Supervisor\_Tx\_Fifo\_Ptr Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x000c_c440 |
| Register Size      | 8           |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 4           |
| Record Instances   | 2           |
| Record Spacing     | 4           |



#### Figure 259. Supervisor\_Tx\_Fifo\_Ptr Register Diagram

#### Table 347. Supervisor\_Tx\_Fifo\_Ptr Field Parameters

| Field Name           | Parameters                                  | Description                                                                                                                                                                                                  |
|----------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_fifo_rd_ptr[31:2] | Mode = R/W<br>Offset = 4.0<br>Instances = 1 | Defines the location within supervisor memory of<br>the transmit FIFO entry currently being processed<br>by the ET4148-50. This pointer is maintained by the<br>ET4148-50 and interpreted by the supervisor. |

These pointers are used during the operation of the transmit FIFOs. There are two instances of the single-field record diagrammed above. The record at offset zero corresponds to transmit FIFO zero.

As the ET4148-50 processes the packet transmit FIFO, it advances  $tx_fifo_rd_ptr[31:2]$ . The supervisor reads this register to determine if its next FIFO entry might overwrite the end of the FIFO. If the address of the supervisor's next FIFO write location is equal to  $tx_fifo_rd_ptr[31:2]$ , then that FIFO is full. When  $tx_fifo_rd_ptr[31:2]$  and  $supervisor_Tx_Fifo_Limits.tx_fifo_last_ptr[31:2]$  are equal, then the corresponding FIFO is empty.

### Tx\_Bytes

Description: Statistics counter.

#### Table 348. Tx\_Bytes Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_6500 |
| Register Size      | 200         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 200         |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 260. Tx\_Bytes Register Diagram

#### Table 349. Tx\_Bytes Field Parameters

| Field Name     | Parameters                                                  | Description                                   |
|----------------|-------------------------------------------------------------|-----------------------------------------------|
| tx_bytes[27:0] | Mode = R/W<br>Offset = 0.4<br>Instances = 50<br>Spacing = 4 | The total number of packet bytes transmitted. |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor at ten times per second without risk of missing a rollover event.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR



### Tx\_Collision\_Histogram

Description: Statistics counters.

#### Table 350. Tx\_Collision\_Histogram Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_5000 |
| Register Size      | 1000        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 1000        |
| Record Instances   | 1           |
| Record Spacing     | NA          |



#### Figure 262. Tx\_Collision\_Histogram Register Diagram

### Tx\_Collision\_Histogram (continued)

### Table 351. Tx\_Collision\_Histogram Field Parameters

| Field Name                           | Parameters                                                       | Description                                                                                                                                                                          |
|--------------------------------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_single_collision_packets[15:0]    | Mode = R/W<br>Offset = 0.16<br>Instances = 50<br>Spacing = 16.0  | The number of packets successfully transmit-<br>ted after experiencing one collision.                                                                                                |
| tx_multiple_collision_packets[15:0]  | Mode = R/W<br>Offset = 4.16<br>Instances = 50<br>Spacing = 16.0  | The number of packets successfully transmit-<br>ted after experiencing multiple collisions.                                                                                          |
| tx_excessive_collision_packets[15:0] | Mode = R/W<br>Offset = 8.16<br>Instances = 50<br>Spacing = 16.0  | The number of packets that fail to be transmit-<br>ted due to excessive collisions.                                                                                                  |
| tx_late_collision_packets[15:0]      | Mode = R/W<br>Offset = 12.16<br>Instances = 50<br>Spacing = 16.0 | The number of packets that fail to be transmit-<br>ted due to a late collision. Such packets may<br>have experienced one or more normal colli-<br>sions prior to the late collision. |
| tx_deferred_packets[17:0]            | Mode = R/W<br>Offset = 800.14<br>Instances = 50<br>Spacing = 4.0 | A count of all packets that had to defer to<br>either traffic on the network (half-duplex<br>mode) or to an active pause timer (full-duplex<br>mode).                                |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor at ten times per second without risk of missing a rollover event.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR



### Tx\_Length\_Histogram

Description: Statistics counters.

#### Table 352. Tx\_Length\_Histogram Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_4800 |
| Register Size      | 1600        |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 1600        |
| Record Instances   | 1           |
| Record Spacing     | NA          |

# 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31

|    | 31 30 29 28 27 26 25 24 23 22 21 |                                 |  |  |  |  |  |
|----|----------------------------------|---------------------------------|--|--|--|--|--|
| 0  |                                  | tx_64_byte_packets[21:0]        |  |  |  |  |  |
| 4  |                                  | tx_65_127_byte_packets[21:0]    |  |  |  |  |  |
| 8  |                                  | tx_128_255_byte_packets[21:0]   |  |  |  |  |  |
| 12 |                                  | tx_256_511_byte_packets[21:0]   |  |  |  |  |  |
| 16 |                                  | tx_512_1023_byte_packets[21:0]  |  |  |  |  |  |
| 20 |                                  | tx_1024_1518_byte_packets[21:0] |  |  |  |  |  |
| 24 |                                  | tx_1519_1522_byte_packets[21:0] |  |  |  |  |  |
| 28 |                                  | tx_jumbo_packets[21:0]          |  |  |  |  |  |

### Figure 264. Tx\_Length\_Histogram Register Diagram

#### Table 353. Tx\_Length\_Histogram Field Parameters

| Field Name                    | Parameters                                                    | Description                                                                                    |  |  |
|-------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|--|
| tx_64_byte_packets[21:0]      | Mode = R/W<br>Offset = 0.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors whose overall length is 64 bytes.              |  |  |
| tx_65_127_byte_packets[21:0]  | Mode = R/W<br>Offset = 4.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors whose overall length is from 65 to 127 bytes.  |  |  |
| tx_128_255_byte_packets[21:0] | Mode = R/W<br>Offset = 8.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors whose overall length is from 128 to 255 bytes. |  |  |

### Tx\_Length\_Histogram (continued)

#### Table 353. Tx\_Length\_Histogram Field Parameters (continued)

| Field Name                      | Parameters                                                     | Description                                                                                              |  |  |  |
|---------------------------------|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--|--|--|
| tx_256_511_byte_packets[21:0]   | Mode = R/W<br>Offset = 12.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors whose overall length is from 256 to 511 bytes.           |  |  |  |
| tx_512_1023_byte_packets[21:0]  | Mode = R/W<br>Offset = 16.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors whose overall length is from 512 to 1,023 bytes.         |  |  |  |
| tx_1024_1518_byte_packets[21:0] | Mode = R/W<br>Offset = 20.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors<br>whose overall length is from 1,024 to<br>1,518 bytes. |  |  |  |
| tx_1519_1522_byte_packets[21:0] | Mode = R/W<br>Offset = 24.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors<br>whose overall length is from 1,519 to<br>1,522 bytes. |  |  |  |
| tx_jumbo_packets[21:0]          | Mode = R/W<br>Offset = 28.10<br>Instances = 50<br>Spacing = 32 | Packets of all types transmitted without errors<br>whose overall length is greater than<br>1,522 bytes.  |  |  |  |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR



# Tx\_Packets

Description: Statistics counters.

### Table 354. Tx\_Packets Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_6000 |
| Register Size      | 800         |
| Register Instances | 1           |
| Register Spacing   | NA          |
| Record Size        | 800         |
| Record Instances   | 1           |
| Record Spacing     | NA          |

|    | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18   | 19    | 20    | 21   | 22    | 23   | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-------|-------|------|-------|------|----|----|----|----|----|----|----|----|
|    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13   | 12    | 11    | 10   | 9     | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | tx_u | nica  | ist_p | acke | ets[2 | 1:0] |    |    |    |    |    |    |    |    |
| 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | t  | x_m  | ultic | ast_  | pack | (ets[ | 21:0 | ]  |    |    |    |    |    |    |    |
| 8  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | tx | _bro | bado  | cast_ | pac  | kets  | 21:0 | ]  |    |    |    |    |    |    |    |
| 12 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | tx_p | baus  | e_p   | acke | ets[2 | 1:0] |    |    |    |    |    |    |    |    |

### Figure 266. Tx\_Packets Register Diagram

#### Table 355. Tx\_Packets Field Parameters

| Field Name                 | Parameters      | Description                                      |
|----------------------------|-----------------|--------------------------------------------------|
| tx_unicast_packets[21:0]   | Mode = R/W      | The number of unicast packets transmitted.       |
|                            | Offset = $0.10$ |                                                  |
|                            | Instances = 50  |                                                  |
|                            | Spacing = 16.0  |                                                  |
| tx_multicast_packets[21:0] | Mode = R/W      | The number of multicast packets transmitted.     |
|                            | Offset = $4.10$ |                                                  |
|                            | Instances = 50  |                                                  |
|                            | Spacing = 16.0  |                                                  |
| tx_broadcast_packets[21:0] | Mode = R/W      | The number of broadcast packets transmitted.     |
|                            | Offset = 8.10   |                                                  |
|                            | Instances = 50  |                                                  |
|                            | Spacing = 16.0  |                                                  |
| tx_pause_packets[21:0]     | Mode = R/W      | The number of pause control packets transmitted. |
|                            | Offset = 12.10  |                                                  |
|                            | Instances = 50  |                                                  |
|                            | Spacing = 16.0  |                                                  |

## Tx\_Packets (continued)

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where *n* is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|----|----|----|----|
|           |     |     |     |     |     |     |    |    |    |    |
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | 3  | 2  | 1  | 0  |
|           |     |     |     |     |     |     |    |    |    |    |

PORT NUMBERING SCHEME



Figure 267. Port Numbering Scheme

## Tx\_Total\_Collisions

Description: Statistics counters.

#### Table 356. Tx\_Total\_Collisions Register Parameters

| Value       |
|-------------|
| 0x0004_5400 |
| 200         |
| 1           |
| NA          |
| 200         |
| 1           |
| NA          |
|             |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25         | 26 | 27 | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|
| 0 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 |    | 1  |    |    | 1  | 6<br>ns[15 |    | 4  | 3  | 2  | 1  | 0  |

### Figure 268. Tx\_Total\_Collisions Register Diagram

#### Table 357. Tx\_Total\_Collisions Field Parameters

| Field Name                | Parameters                                                     | Description                                                               |
|---------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------|
| tx_total_collisions[15:0] | Mode = R/W<br>Offset = 0.16<br>Instances = 50<br>Spacing = 4.0 | A count of the total number of collisions experi-<br>enced by all packets |

Statistics counters roll over from their maximum count to zero without warning or indication that a rollover has occurred. It is expected that the supervisor sample these counters often and to use the delta from a previous sample to the current sample to determine the overall count delta. If the current sample has a smaller value than the previous sample (indicating a rollover), then  $2^n$  (where n is the number of bits in the statistics counter) is added to the delta to determine the actual delta. All statistics counters' widths are scaled to allow for sampling by the supervisor ten times per second without risk of missing a rollover event.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 269. Port Numbering Scheme

## User\_Protocol\_{0..4}

Description: User-specified IP Protocol values.

### Table 358. User\_Protocol\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_dfc0 |
| Register Size      | 12          |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 3           |
| Record Spacing     | 4           |



### Figure 270. User\_Protocol\_{0..4} Register Diagram

#### Table 359. User\_Protocol\_{0..4} Field Parameters

| Field Name                       | Parameters                                   | Description                                 |
|----------------------------------|----------------------------------------------|---------------------------------------------|
| user_protocol_entry_valid_{}{02} | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Must be asserted for comparison to be made. |
| user_protocol_{}{02}[7:0]        | Mode = R/W<br>Offset = 0.24<br>Instances = 1 | User-specified protocol value.              |

If a received packet's IP protocol value matches one of the three in this table, then its protocol is encoded as USER\_TYPE\_0, USER\_TYPE\_1 or USER\_TYPE\_2, depending on which record is matched.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

 $\begin{array}{l} G = 10/100/1000 \mbox{ Mbits/s PORT} \\ XG = 10 \mbox{ Gbits/s PORT} \\ SU = SUPERVISOR \end{array}$ 

#### Figure 271. Port Numbering Scheme

## User\_Protocol\_{5..6}

Description: User-specified IP Protocol values.

### Table 360. User\_Protocol\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5fc0 |
| Register Size      | 12          |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 3           |
| Record Spacing     | 4           |



### Figure 272. User\_Protocol\_{5..6} Register Diagram

### Table 361. User\_Protocol\_{5..6} Field Parameters

| Field Name                       | Parameters                                   | Description                                 |
|----------------------------------|----------------------------------------------|---------------------------------------------|
| user_protocol_entry_valid_{}{02} | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Must be asserted for comparison to be made. |
| user_protocol_{}{02}[7:0]        | Mode = R/W<br>Offset = 0.24<br>Instances = 1 | User-specified protocol value.              |

If a received packet's IP protocol value matches one of the three in this table, then its protocol is encoded as USER\_TYPE\_0, USER\_TYPE\_1 or USER\_TYPE\_2, depending on which record is matched.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | <br>3  | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

### Figure 273. Port Numbering Scheme

## User\_Type\_{0..4}

Description: User-specified Ethertype values.

### Table 362. User\_Type\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_dfd0 |
| Register Size      | 12          |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 3           |
| Record Spacing     | 4           |



### Figure 274. User\_Type\_{0..4} Register Diagram

#### Table 363. User\_Type\_{0..4} Field Parameters

| Field Name                   | Parameters                                   | Description                                 |
|------------------------------|----------------------------------------------|---------------------------------------------|
| user_type_entry_valid_{}{02} | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Must be asserted for comparison to be made. |
| user_type_{}{02}[15:0]       | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | User-specified Ethertype value.             |

If a received packet's Ethertype value matches one of the three in this table, then its Ethertype is encoded as USER\_TYPE\_0, USER\_TYPE\_1 or USER\_TYPE\_2, depending on which record is matched.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 275. Port Numbering Scheme

## User\_Type\_{5..6}

Description: User-specified Ethertype values.

#### Table 364. User\_Type\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5fd0 |
| Register Size      | 12          |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 3           |
| Record Spacing     | 4           |



### Figure 276. User\_Type\_{5..6} Register Diagram

#### Table 365. User\_Type\_{5..6} Field Parameters

| Field Name                   | Parameters                                   | Description                                 |
|------------------------------|----------------------------------------------|---------------------------------------------|
| user_type_entry_valid_{}{02} | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | Must be asserted for comparison to be made. |
| user_type_{}{02}[15:0]       | Mode = R/W<br>Offset = 0.16<br>Instances = 1 | User-specified Ethertype value.             |

If a received packet's Ethertype value matches one of the three in this table, then it's Ethertype is encoded as USER\_TYPE\_0, USER\_TYPE\_1 or USER\_TYPE\_2, depending on which record is matched.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 277. Port Numbering Scheme

## Vlan\_ld\_Table\_{0..4}

Description: This table converts VLAN indexes into VLAN identifiers.

### Table 366. Vlan\_ld\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_d000 |
| Register Size      | 1024        |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 256         |
| Record Spacing     | 4           |



### Figure 278. Vlan\_Id\_Table\_{0..4} Register Diagram

#### Table 367. Vlan\_Id\_Table\_{0..4} Field Parameters

| Field Name    | Parameters                                   | Description                                        |
|---------------|----------------------------------------------|----------------------------------------------------|
| vlan_id[11:0] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN identifier as selected by the VLAN index. |

One of 256 VLAN indexes are assigned to each packet during ingress processing. This table is used to convert the 8-bit index back into a 12-bit VLAN identifier immediately prior to transmission.

PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 279. Port Numbering Scheme

## Vlan\_Id\_Table\_{5..6}

Description: This table converts VLAN indexes into VLAN identifiers.

#### Table 368. Vlan\_Id\_Table\_{5..6} Register Parameters

| Parameter          | Value       |   |  |  |  |
|--------------------|-------------|---|--|--|--|
| Base Address       | 0x0007_5000 | - |  |  |  |
| Register Size      | 1024        | - |  |  |  |
| Register Instances | 2           | - |  |  |  |
| Register Spacing   | 32768       | - |  |  |  |
| Record Size        | 4           | - |  |  |  |
| Record Instances   | 256         | 1 |  |  |  |
| Record Spacing     | 4           | 1 |  |  |  |

|   | 0  | 1  | 2  | 3  | 4  | 5  | 6  | 7  | 8  | 9  | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24  | 25    | 26    | 27  | 28 | 29 | 30 | 31 |
|---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-------|-------|-----|----|----|----|----|
|   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6     | 5     | 4   | 3  | 2  | 1  | 0  |
| 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | vla | an_io | d[11: | :0] |    |    |    |    |

### Figure 280. Vlan\_ld\_Table\_{5..6} Register Diagram

#### Table 369. Vlan\_Id\_Table\_{5..6} Field Parameters

| Field Name    | Parameters                                   | Description                                        |
|---------------|----------------------------------------------|----------------------------------------------------|
| vlan_id[11:0] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN identifier as selected by the VLAN index. |

One of 256 VLAN indexes are assigned to each packet during ingress processing. This table is used to convert the 8-bit index back into a 12-bit VLAN identifier immediately prior to transmission.



Figure 281. Port Numbering Scheme

## Vlan\_Index\_Table\_{0..4}

Description: This table converts VLAN identifiers into VLAN indexes.

#### Table 370. Vlan\_Index\_Table\_{0..4} Register Parameters

| Parameter          | Value       |   |
|--------------------|-------------|---|
| Base Address       | 0x0004_8000 | 1 |
| Register Size      | 16384       | 1 |
| Register Instances | 5           | 1 |
| Register Spacing   | 32768       | 1 |
| Record Size        | 4           | 1 |
| Record Instances   | 4096        | 1 |
| Record Spacing     | 4           | 1 |

|   | 31 | 30 29 28 | 27 26 | 25 24 | 1 23 | 22 21 | 20 | 19 | 18 <sub>1</sub> 1 | 7 <sub>1</sub> 16 | 15 | 14 | 13 | 12 | 11 <sub> </sub> 1 | 0 | 9 | 8 | 7 | 6 | 5    | 4     | 3     | 2    | 1 | 0 |
|---|----|----------|-------|-------|------|-------|----|----|-------------------|-------------------|----|----|----|----|-------------------|---|---|---|---|---|------|-------|-------|------|---|---|
| 0 |    |          |       |       |      |       |    |    |                   |                   |    |    |    |    |                   |   |   |   |   |   | vlar | n_inc | dex[7 | 7:0] |   |   |

### Figure 282. Vlan\_Index\_Table\_{0..4} Register Diagram

### Table 371. Vlan\_Index\_Table\_{0..4} Field Parameters

| Field Name       | Parameters                                   | Description                                                                                                      |
|------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| vlan_index_valid | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | This bit is asserted to indicate that the submitted VLAN identifier value has a valid index stored in the table. |
| vlan_index[7:0]  | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN index as selected by the VLAN identifier.                                                               |

This table is used to convert the 11-bit VLAN identifier extracted from the received packet into an 8-bit VLAN index for use throughout the remainder of ingress processing. This table is addressed by the VLAN value extracted from the received packets.

The VLAN identifier space consists of 4,094 values (4,095 for revisions B1 and C). Only 256 of them may be utilized simultaneously by the ET4148-50 system. Consequently, only as many as 256 entries in this table may be marked as valid through the assertion of vlan\_index\_valid. All remaining table entries must have this bit deasserted. If vlan\_index\_valid is false, vlan\_index[7:0] is invalid.

Care must be taken when configuring this table to ensure consistency from one packet processor to the next.



Figure 283. Port Numbering Scheme

## Vlan\_Index\_Table\_{5..6}

Description: This table converts VLAN identifiers into VLAN indexes.

#### Table 372. Vlan\_Index\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_0000 |
| Register Size      | 16384       |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 4096        |
| Record Spacing     | 4           |



### Figure 284. Vlan\_Index\_Table\_{5..6} Register Diagram

### Table 373. Vlan\_Index\_Table\_{5..6} Field Parameters

| Field Name       | Parameters                                   | Description                                                                                                      |
|------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| vlan_index_valid | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | This bit is asserted to indicate that the submitted VLAN identifier value has a valid index stored in the table. |
| vlan_index[7:0]  | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN index as selected by the VLAN identifier.                                                               |

This table is used to convert the 11-bit VLAN identifier extracted from the received packet into an 8-bit VLAN index for use throughout the remainder of ingress processing. This table is addressed by the VLAN value extracted from the received packets.

The VLAN identifier space consists of 4,094 values (4,095 for revisions B1 and C). Only 256 of them may be utilized simultaneously by the ET4148-50 system. Consequently, only as many as 256 entries in this table may be marked as valid through the assertion of  $vlan_index_valid$ . All remaining table entries must have this bit deasserted. If  $vlan_index_valid$  is false,  $vlan_index[7:0]$  is invalid.

Care must be taken when configuring this table to ensure consistency from one packet processor to the next.

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|-----|-----|-----|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  | 3      | 2  | 1  | 0  |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

Figure 285. Port Numbering Scheme

# Vlan\_Port\_Protocol\_Table\_{0..4}

Description: This table converts port numbers and protocol indexes into VLAN indexes.

### Table 374. Vlan\_Port\_Protocol\_Table\_{0..4} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0004_dc00 |
| Register Size      | 320         |
| Register Instances | 5           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 80          |
| Record Spacing     | 4           |



### Figure 286. Vlan\_Port\_Protocol\_Table\_{0..4} Register Diagram

### Table 375. Vlan\_Port\_Protocol\_Table\_{0..4} Field Parameters

| Field Name      | Parameters                                   | Description                                                                     |
|-----------------|----------------------------------------------|---------------------------------------------------------------------------------|
| entry_valid     | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | This bit is asserted to indicate that the associated VLAN index value is valid. |
| vlan_index[7:0] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN identifier as selected by the packet's protocol.                       |

A 4-bit port number (range: 0..9) and a 3-bit protocol index are concatenated together to form an address in this table. The value returned is an entry\_valid indication and a VLAN index for use in all ingress and egress packet processing. If entry\_valid is false, vlan\_index[7:0] is invalid.

Care must be taken when configuring this table to ensure consistency from one packet processor to the next (e.g., avoid the accidental or inconsistent reuse of VLAN index values).

This table is addressed by a concatenation of port[5:0] % 10 and ethertype\_index[2:0].

#### PORT NUMBERING SCHEME

| PORT                         | XG1 | XG0 | SU1 | SU0 | G47 | G46 | G45 | G44 |  | G3 | G2 | G1 | G0 |
|------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|--|----|----|----|----|
| REFERENCE                    | 60  | 50  | 49  | 48  | 47  | 46  | 45  | 44  |  | 3  | 2  | 1  | 0  |
| G = 10/100/1000 Mbits/s PORT |     |     |     |     |     |     |     |     |  |    |    |    |    |

XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 287. Port Numbering Scheme

## Vlan\_Port\_Protocol\_Table\_{5..6}

Description: This table converts port numbers and protocol indexes into VLAN indexes.

#### Table 376. Vlan\_Port\_Protocol\_Table\_{5..6} Register Parameters

| Parameter          | Value       |
|--------------------|-------------|
| Base Address       | 0x0007_5c00 |
| Register Size      | 32          |
| Register Instances | 2           |
| Register Spacing   | 32768       |
| Record Size        | 4           |
| Record Instances   | 8           |
| Record Spacing     | 4           |





#### Table 377. Vlan\_Port\_Protocol\_Table\_{5..6} Field Parameters

| Field Name             | Parameters                                   | Description                                                                     |
|------------------------|----------------------------------------------|---------------------------------------------------------------------------------|
| entry_valid_{}{07}     | Mode = R/W<br>Offset = 0.0<br>Instances = 1  | This bit is asserted to indicate that the associated VLAN index value is valid. |
| vlan_index_{}{07}[7:0] | Mode = R/W<br>Offset = 0.20<br>Instances = 1 | The VLAN identifier as selected by the packet's protocol.                       |

A 3-bit ethertype index is used as an address into this table. The value returned is an  $entry_valid$  indication and a VLAN index for use in all ingress and egress packet processing. If  $entry_valid$  is false,  $vlan_index[7:0]$  is invalid.

Care must be taken when configuring this table to ensure consistency from one packet processor to the next (e.g., the accidental or inconsistent reuse of VLAN index values).

This table is addressed by protocol\_index[2:0].

#### PORT NUMBERING SCHEME

| PORT      | XG1 | XG0 | SU1 | SU0 | G47 | G46     | G45  | G44       | <br>G3 | G2 | G1 | G0 |
|-----------|-----|-----|-----|-----|-----|---------|------|-----------|--------|----|----|----|
| REFERENCE | 60  | 50  | 49  | 48  | 47  | 46      | 45   | 44        | <br>3  | 2  | 1  | 0  |
|           |     |     |     |     | 0 4 | 2/4.0.0 | 4000 | N 41- 11- |        |    |    |    |

G = 10/100/1000 Mbits/s PORT XG = 10 Gbits/s PORT SU = SUPERVISOR

#### Figure 289. Port Numbering Scheme

# **Appendix B: Configuration**

This chapter describes the methods for configuring the various features of the ET4148-50.

## General

The supervisor's access to the various registers within the ET4148-50 is via a 32-bit *PCI* bus. Many of the fields and records that must be configured by the supervisor are wider than 32 bits. In general, the updating of a partial word or record may cause unpredictable behavior. To prevent this, the ET4148-50 includes line caches where necessary to ensure that integral records are always written to these registers.

## **Packet Buffer**

The packet buffer in the ET4148-50 is self-configuring. The configuration process is initiated by the supervisor by simply asserting the free\_buffer\_initialization\_start and free\_descriptor\_initialization\_start bits in the Packet\_Buffer\_Free\_Buffer\_Control and Packet\_Buffer\_Free\_Descriptor\_Control registers, respectively. Upon completion of the initialization sequence, the ET4148-50 asserts the free\_buffer\_initialization\_done and free\_descriptor\_initialization\_done bits, accordingly.

### **Ethernet Interfaces**

The ET4148-50 includes multiple instances of two types of Ethernet interfaces: 48 10/100/1000 Mbits/s Ethernet ports and two 10 Gbits/s Ethernet ports. Various aspects of each of these interfaces must be properly configured in order to achieve normal operation.

### **Media Access Controllers**

The media access controllers (MACs) are primarily configured via the Mac\_Mode registers. There are seven such registers. The five registers corresponding to the 10/100/1000 Mbits/s Ethernet ports (Mac\_Mode\_{0..4}) each have 10 records; one for each MAC associated with the a register. The two registers that correspond to the two 10 Gbits/s Ethernet ports (Mac\_Mode\_{5..6}) each have a single record for the single MAC associated with each registers. Certain configuration criteria are associated with just one type of port or the other. Most, however, are common among both types of MACs.

**Port Enable.** Each Ethernet MAC may be completely disabled by deasserting the corresponding port\_en bit in the Mac\_Mode\_{0..6} registers.

**Receive Enable.** The Ethernet MACs are disabled from receiving any network traffic unless their corresponding gmac\_rx\_en\_{0..9} or xgmac\_rx\_en bit is asserted.

**Speed Mode (Multispeed Only).** Generally, the speed of the 10/100/1000 Mbits/s Ethernet ports is established automatically via autonegotiation with the system at the far end of the Ethernet link. The current speed setting is available to the supervisor via  $gmac_port_speed_{0..9}[1:0]$ . The valid values of this field are defined in the following table.

### Ethernet Interfaces (continued)

#### Table 378. Port Speed Indications

| gmac_port_speed_{09}[1:0] | Port Speed  |
|---------------------------|-------------|
| 002                       | 10 Mbits/s  |
| 012                       | 100 Mbits/s |
| 102                       | 1 Gbit/s    |
| 112                       | Reserved    |

Autonegotiation (Multispeed Only). Autonegotiation is used to establish the capabilities of the systems at either end of an Ethernet link. Once the capabilities have been determined, the highest common capability is chosen for the two link partners to share.

In order to enable autonegotiation, the  $auto_negotiate_en_{0..9}$  bit corresponding to the appropriate Ethernet interface must be asserted.

To manually force the link to renegotiate, the restart\_auto\_negotiation\_{0..9} bit is pulsed (asserted and then deasserted). The ET4148-50 detects the rising edge of this signal and immediately initiates an autonegotiation session with the corresponding link partner.

**SFP Autonegotiation.** When ports 44 through 47 are configured to operate in SerDes mode, 1000BASE-X autonegotiation is supported.

For revision C, once the SerDes mode is selected and the appropriate auto\_negotiate\_en\_{0..9} bit is asserted, gmac\_rx\_pause\_en\_{} {0..9} and gmac\_flow\_control\_initiate\_en\_{} {0..9} become the PAUSE (PS1) and ASM\_DIR (PS2) bits, respectively, as defined in Table 37-2 of the *IEEE* Standard *802.3-2002*. Once autonegotiation is complete, the gmac\_rx\_pause\_en\_{} {0..9} and

gmac\_flow\_control\_initiate\_en\_{}{0..9} bits give the pause priority resolution for PAUSE and ASM\_DIR, respectively, as defined in Table 37-4 of the standard.

Autonegotiation Override (Multispeed Only). If desired, autonegotiation may be disabled and overridden with manually prescribed parameters. By asserting good\_link\_force\_{0..9}, the supervisor disables autonegotiation and enables the use of speed\_mode\_force\_{0..9}[1:0] and full\_duplex\_force\_{0..9} to set the port's operating characteristics.

The  $full_duplex_force_{0..9}$  bit is asserted to set the port to operate in full-duplex mode. When deas-serted, this bit causes the port to operate in half duplex.

The speed\_mode\_force\_ $\{0..9\}$  [1:0] field is used to set the corresponding port to a particular operating speed. The valid settings are defined in the following table.

| speed_mode_force_{09}[1:0] | Port Speed  |
|----------------------------|-------------|
| 002                        | 10 Mbits/s  |
| 012                        | 100 Mbits/s |
| 102                        | 1 Gbit/s    |
| 112                        | Reserved    |

#### Table 379. Port Speed Settings

## Ethernet Interfaces (continued)

### Loopback

Loopback enable bits  $(gmac_port_loopback_en_{0..9})$  may be asserted to place a port into a loopback mode. When in this mode, transmit packets are looped back into the device immediately prior to exiting the device via an SGMII interface. During loopback operations, no packets are actually transmitted and all receive traffic is ignored by the affected ports.

**Note:** The ET4148-50 does not attempt to align the transition into and out of the loopback mode with the gap between packets. Therefore, if a port is active during the transition into or out of the loopback mode, one or more transmit or receive packets may become corrupted.

**Flow Control.** There are two flow control actions that may be independently enabled: the initiation of flow control on a link, and the reaction to flow control on a link. The gmac\_flow\_control\_initiate\_en\_{0..9} and xgmac\_flow\_control\_initiate\_en bits enable the respective MACs to transmit flow control packets when directed to do so by the packet buffer's congestion state. If this bit is deasserted, the associated MAC will not transmit flow control packets even if the packet buffer is indicating that it is congested.

For a MAC to react to the reception of a flow control packet, its gmac\_rx\_pause\_en\_{0..9} or xgmac\_rx\_ pause\_en bit must be asserted. If this bit is deasserted, the corresponding MAC ignores all received flow control packets.

Flow control packets transmitted by the ET4148-50 must have a valid MAC source address. These source address values are supplied to the MACs via the  $mac\_src\_addr[47:6]$  field of the Mac\_Global\_Mode register. These upper bits of the MAC source address are shared by all of the MACs. The least significant 6 bits of the 48-bit MAC source address are hardwired to each MAC and are equivalent to the corresponding port number (0 through 47 and 50 and 60).

Finally, the MAC pause quanta must be specified. This value is included in the transmitted flow control packets to tell the far-end system how long to wait prior to resuming transmission. Each unit of pause is equal to 512 bit times at the current port speed. This value is specified via the mac\_pause\_quanta[15:0] in the Mac\_Global\_Mode register.

**Interface Selection.** Ports 44 through 47 (four of the 10/100/1000 Gbits/s Ethernet ports) support both SGMII and SerDes interfaces. During packet transmission, both interfaces are active. However, during packet reception, only one interface may be active at a time for any particular Ethernet MAC. The <code>input\_select[1:0]</code> fields of the  $Mac_Mode_{0..4}$  registers are used to select which interface is to be utilized for packet reception.

**Data Pipeline Flushing**. The gmac\_tx\_flush\_{0..9} and xgmac\_tx\_flush bits in the Mac\_Mode\_{0..6} registers are used to flush any nonempty queues associated with a MAC that has been disabled from transmitting for whatever reason. While in the flush mode, packets are drawn out of the packet buffer in a normal manner and are then discarded prior to transmission. This has the effect of freeing up storage and queue resources that would have otherwise been stalled behind a disabled MAC.

Ideally, the forwarding characteristics of the device are updated to prevent further new queue entries for a disabled port prior to initiating a flush. The Layer\_2\_Global\_Mask register may be used as a quick and effective way to disable new queue entries.

## Ethernet Interfaces (continued)

### PHYs

**MDIO.** The external PHY devices are configured and controlled via three MDIO interfaces. These interfaces are accessed via the Mdio\_Control, Mdio\_Mode, and Mdio\_Status registers.

The Mdio\_Control register is used to issue read and write commands to the ET4148-50's MDIO controller. To issue a write command, the supervisor first sets up the parameters of the command (e.g., MDIO register address, port select, device select, etc.) by writing to Mdio\_Control with an mdio\_opcode[1:0] value of 002. Once the parameters have been established, the write data is then written to Mdio\_Control and the command is automatically executed.

A read command starts off similarly: the supervisor sets up all of the various parameters with an opcode of 11<sub>2</sub>. This opcode results in an immediate initiation of the read command. The  $mdio_busy$  bit remains asserted throughout the execution of the command. Once  $mdio_busy$  is deasserted by the ET4148-50, the read data is available in the  $mdio_addr_data[15:0]$  field.

A separate register, Mdio\_Status, is available for polling the state of the MDIO controller. The mdio\_busy bit in this register has the same meaning as the version of the bit that appears in the Mdio\_Control register. The mdio\_done bit is asserted at the completion of a command. This bit remains asserted until a one is written to its position within Mdio\_Status by the supervisor.

**MDIO** (continued). The Mdio\_Mode register is used to define the characteristics of the MDIO clock. The period of the clock is defined by the mdio\_clk\_period[7:0] field. Larger values of mdio\_clk\_period[7:0] result in lower MDIO clock frequencies. The mdio\_clk\_offset[7:0] is used to establish a delay between the MDIO clock and the transition or sampling of MDIO data.

**SerDes**. The four 1.25 GHz SerDes that make up the four 1 Gbit/s SFP interfaces require a certain amount of attention from the supervisor. Access to the control and status registers within the SFP SerDes is available via the Serdes\_Control\_{4} register.

The eight 3.125 GHz SerDes that make up the two 10 Gbits/s XAUI interfaces require a certain amount of attention from the supervisor. Access to the control and status registers within the XAUI SerDes is available via the Serdes\_Control\_{5} register.

Both 8-bit and 16-bit access commands are available. These two command types share a common 32-bit register location. In other words, the format of the fields at this register offset depends on the type of command being executed. The target SerDes register address for the command and the write data (for write commands) are written to  $serdes\_addr[15:0]$  (or  $serdes\_addr[7:0]$ ) and  $serdes\_wr\_data[15:0]$  (or  $serdes\_wr\_data[7:0]$ ), respectively. Next, the access command code is written to the  $access\_command[2:0]$  field at the same time that the command\\_start bit is asserted.

Setting the command\_start bit initiates the specified command. The serdes\_command\_busy bit is asserted to indicate that the command is being executed. At the completion of the command, serdes\_command\_done is asserted to indicate that read data is valid (in the case of a read command) and that a subsequent command may be issued. The serdes\_command\_done bit remains asserted until the initiation of a subsequent command.

### Link Aggregation

Link aggregation enables multiple, parallel Ethernet links to appear to the ET4148-50 as if they were a single, logical link; thus providing an increase in bandwidth. No more than eight ports may be a part of any one aggregate.

## Ethernet Interfaces (continued)

**Logical Ports**. Link aggregation enables the possibility of a single MAC source address to appear on several physical links nearly simultaneously. Ordinarily, the appearance of a MAC source address on a receive port that is different than the one listed in the address table triggers an address learning event. However, for the ports within an aggregate, all of the ports in that aggregate are valid receive ports for any particular source address. Hence, for address learning purposes, the concept of a logical port is used.

Physical ports are mapped to logic ports through the use of the Layer\_2\_Logical\_Port\_Table register. This table is addressed by the physical receive port number, and it returns a logical port number. For an aggregate of links, all of the physical receive ports that are part of the link should return a common logical port number that is equal to the lowest physical port number of the ports in the aggregate. For those ports that are not part of an aggregate, this table should be configured to return those ports' physical port number. Complying with the preceding recommendation is not essential. Alternate methods of configuring this table may be employed. The only important criterion is that all ports in an aggregate must share a common, logical port number.

**Link Selection.** Packets received on any of the ports that make up a particular aggregate are treated identically by the ET4148-50. Transmit packets may be transmitted by any of the ports of an aggregate, with the actual transmit port being selected arbitrarily. The only requirement for transmit port selection is that all packets that may be part of a particular conversation or flow use a common physical port.

The ET4148-50 uses an arithmetic reduction of the receive packet's MAC destination and source address values to arrive at a 3-bit link selection value; enabling a one-of-eight selection.

**Destination Maps.** In support of link aggregates, the Layer\_2\_Dest\_Map\_Table must be configured appropriately. If an aggregate is the intended destination for a particular address table entry/destination map association, then all of the bits corresponding to the ports in the aggregate must be asserted in the destination map. In other words, the destination map must be set up as if the packet is to be multicast to all of the ports in the aggregate. Aggregate masks are subsequently used to select a single port per aggregate.

**Aggregate Masks**. A total of eight aggregate masks are available via Layer\_2\_Aggregation\_Mask\_Table. These eight masks serve all of the possible aggregates that may be configured in the system.

Every physical transmit port can be thought of as belonging to some form of an aggregate. Conceptually, even a single-port aggregate is supported. The pattern of mask bits programmed into the

Layer\_2\_Aggregation\_Mask\_Table is determined by the number of ports in the aggregate. Membership levels of 1 through 8 ports are allowed, though 1, 2, 4, and 8 are likely to be the most commonly used. The following table shows the entries for aggregates of various port-counts.

| Aggregate Mask Number | Mask Patterns for Various Ports Per Aggregate |         |         |           |  |  |
|-----------------------|-----------------------------------------------|---------|---------|-----------|--|--|
|                       | 1 Port                                        | 2 Ports | 4 Ports | 8 Ports   |  |  |
| 0                     | 02                                            | 012     | 01112   | 011111112 |  |  |
| 1                     | 02                                            | 102     | 10112   | 101111112 |  |  |
| 2                     | 02                                            | 012     | 11012   | 110111112 |  |  |
| 3                     | 02                                            | 102     | 11102   | 111011112 |  |  |
| 4                     | 02                                            | 012     | 01112   | 111101112 |  |  |
| 5                     | 02                                            | 102     | 10112   | 111110112 |  |  |
| 6                     | 02                                            | 012     | 11012   | 111111012 |  |  |
| 7                     | 02                                            | 102     | 11102   | 111111102 |  |  |

### Table 380. Aggregate Mask Patterns

### Ethernet Interfaces (continued)

### VLANs

Every receive packet is associated with one VLAN or another by the ET4148-50 during reception. There are several methods by which such a VLAN association may be made.

1. Directly. The VLAN tag of a received packet is mapped to a VLAN index.

2. Port/protocol. Untagged packets are mapped to a VLAN index based on a per-port protocol table.

3. Port only. Untagged packets adopt the receive port's default VLAN ID.

For the purposes of restricting the forwarding of packets within VLANs, a series of VLAN masks are used.

**Direct Mapping.** Although the *IEEE 802.1q* standard allows up to 4,094 VLAN IDs, the ET4148-50 supports up to 256 active VLANs. The vlan\_Index\_Table\_{0..6} registers are used to map the 12-bit VLAN tag from a receive packet to the 8-bit VLAN identifier that is used internally within the ET4148-50. This table is addressed directly by the receive packet's 12-bit VLAN tag. A vlan\_index\_valid flag in each table entry identifies those entries that are indeed valid. For valid entries, the vlan\_index[7:0] value from the same record is used as the receive packet's VLAN index.

If the receive packet's 12-bit VLAN ID maps to an invalid entry in  $Vlan\_Index\_Table_{0..6}$ , then the packet is either discarded or its VLAN index is chosen by one of the alternate methods listed above and described in more detail below. The invalid\_vlan\_id\_discard\_en bits in the Port\_Mode\_{0..6} registers are used to set this preference on a port-by-port basis.

**Note:** Revisions B1 and C of the ET4148-50 allow up to 4,095 VLAN IDs. VLAN ID 0xFFF is included for nonstandard use.

**Port/Protocol Mapping.** For each receive port, as many as eight Ethertype values may be mapped to VLAN index values. The following ordered list of Ethertypes is used.

| Ethertype   | Ethertype Index |
|-------------|-----------------|
| IPv4        | 0               |
| IPv6        | 1               |
| ARP         | 2               |
| RARP        | 3               |
| User Type 0 | 4               |
| User Type 1 | 5               |
| User Type 2 | 6               |
| Unknown     | 7               |

#### Table 381. Ethertype Index Values

The three user type values are established via the  $User_Type_{0..6}$  registers. Typically, all seven instances of this register are programmed the same way, but it is not necessary to do so.

The Ethertype index is used to select one of the eight VLAN index values from the

Vlan\_Port\_Protocol\_Table\_{0..6} registers. There is an eight-entry table for each receive port.

Valid entries are identified by an asserted entry\_valid bit. If the combination of receive port number and Ethertype index points to a valid entry, then the associated vlan\_index[7:0] value is assigned to the receive packet. Otherwise, the port-only VLAN assignment method (described below) is used.

## Ethernet Interfaces (continued)

For a single-port aggregate (really, a port that is not a part of any aggregate), the bits that correspond to that port are deasserted (not masking) for all of the Layer\_2\_Aggregation\_Mask\_Table entries. In other words, regardless of which table entry is selected by the arithmetic reduction of the packet's MAC destination and source address values, the destination port is never masked by the aggregation mask table.

For an eight-port aggregate, each aggregation mask table entry enables just one of the eight ports (note the marching zero in the table above). Each mask bit in the 8-bit values shown above corresponds to one of the eight ports in the aggregate.

**Note**: Neither the destination maps nor the aggregation masks impose any limits about which ports may be designated to be a member of a particular aggregate. The ports in an aggregate need not be adjacent ports nor need they even be equivalent ports.

**Port Only Mapping.** Should the preceding methods for assigning a VLAN index to a receive packet fail, the receive port's default VLAN index is used. This value is established on a per-port basis via the Port\_Mode\_{0..6} registers.

VLAN Masks. 256 VLAN masks are available that are applied to the 58-bit destination map during the bridging process. (See Destination Maps on page 277.) These masks are configured via the Layer\_2\_Vlan\_Mask\_Table register. The receive packet's VLAN index is used to select the appropriate VLAN mask. The mask is then used to eliminate all destinations that are not members of the packet's VLAN.

### **Port Mirroring**

To aid in the analysis of network behavior, ports may have their receive and transmit activity copied to a designated mirror port.

**Designating a Mirror Port.** A port is designated as the system's mirror port by writing its port number to the Layer\_2\_Mirror\_Port register. When a receive packet is to be mirrored, the designated port is added to the 58-bit destination port map by the ET4148-50.

Designating a port as a mirror port does not automatically prevent that port from being used for normal forwarding purposes. In order to dedicate a port solely to mirroring, it is essential that the address table and/or destination port maps be updated to eliminate the mirror port as a valid destination.

If multiple ports are selected to be mirrored (i.e., their activity is copied to the designated mirror port), it is possible that the aggregate of the mirrored ports' bandwidth may exceed that of the mirror port. If this condition persists for an extended period, the packet buffer may become congested and packets may be discarded. In this case, the inclusion of a mirror port may adversely affect the behavior of the mirrored ports.

If both the transmit and receive ports for a particular packet are being mirrored, only one copy of the packet is sent to the mirror port.

**Receive Mirroring**. To mirror the receive activity of a port, it is merely required that its corresponding bit in Layer\_2\_Src\_Mirror\_Map be asserted. Once this is done, all packets received by the mirrored port are copied to the designated mirror port.

**Transmit Mirroring**. To mirror the transmit activity of a port, it is merely required that its corresponding bit in Layer\_2\_Dest\_Mirror\_Map be asserted. Once this is done, all packets transmitted by the mirrored port are copied to the designated mirror port.

**Note**: The packet transmitted by the mirror port may not exactly match the packet transmitted by a mirrored port if the VLAN modes and configurations of the two ports differ.

### Ethernet Interfaces (continued)

**Remote Mirroring**. By asserting the stack\_mirror\_reverse or stack\_mirror\_forward bits in the Port\_Mode register, mirroring across a network connection may be enabled. Though any port may be designated to convey mirrored traffic across a stacking link to a mirroring port, typically one of the 10 Gbits/s Ethernet ports is used.

## Bridging

Bridging refers to the forwarding of Ethernet packets through the use of Layer 2 information as defined by the *IEEE 802.1d* standard. Fundamental to the bridging process is the configuration of the Layer 2 address tables.

### Layer 2 Look-Up Method

The ET4148-50 utilizes binary and 4-ary (collectively referred to as "*k*-ary") search algorithms in its table look-up functions. For bridging look-ups, specifically, a 4-ary search algorithm is used.

The 4-ary search algorithm is implemented in a series of pipelined, cascaded key tables. Every search starts at Layer\_2\_Key\_Table\_0 with the comparison of the search argument (one of the Layer 2 address fields from the receive packet) against the three keys stored in this register. These three keys have the effect of dividing up the overall table into four regions. Hence, the next stage of the search has the search argument being compared against one of four sets of three keys in Layer\_2\_Key\_Table\_1. This process continues until Layer\_2\_Key\_Table\_7 is reached.

At this last stage, there is a pair of keys against which an exact match comparison is performed. If  $layer_2_key_0[47:0]$  matches the search argument, then the search results associated with key 0 are returned. If  $layer_2_key_1[47:0]$  matches the search argument, then the search results associated with key 1 are returned. If neither keys match the search argument, then a look-up failed indication is returned.

The associated data returned from a look-up operation consist of:

- A Layer 2 source address permit/deny indication.
- The receive port number associated with the matching address value when used as a source address.
- A 3-bit flow identifier for use when the matching address value is used as a source address.
- A 3-bit flow identifier for use when the matching address value is used as a destination address.
- A source log indication that causes the packet to be copied to the logging queue when the matching address value is used as a source address.
- A 9-bit destination map index that identifies one of 512 initial distribution patterns for the packet. This initial distribution pattern is subject to extensive modification during the remainder of bridging processing.

### Adding and Deleting Table Entries

For the search algorithms to work properly, the keys must be placed in the tables in a numerically sorted manner. Consequently, if the two existing keys between which a new key must be added are not separated by one or more empty locations, then the table's contents must be shifted in order to open up such an empty location. This is done through a series of swaps of adjacent values. In other words, a form of bubble sort is performed.

For the sake of clarity, a binary table example is presented below. The methods described here are easily extended to the 4-ary case.

## Bridging (continued)

**Swapping Binary Table Keys**. Depending on which pair of table leaf nodes need to be swapped, the operation could involve the updating of nodes a every level of the tree's hierarchy. Consider the following figure.



Figure 290. Updating a Binary Tree Structure (Step 1)

## Bridging (continued)

Since it is only permissible to swap occupied leaf nodes with empty leaf nodes, it is easy to see how swapping two leaf nodes that share a common immediate ancestor would be quite simple.

For example, presume that node 4.0 is empty and 4.1 contains a valid key, say 327. The first step is to copy the key in 4.1 to node 4.0. Since 3.0 hasn't been updated yet, its current value of, say 320, continues to direct searches looking for 327 to node 4.1. The search could, however, now obtain the same results by branching to 4.0. Therefore, it is safe to update node 3.0 to, say 330, so that search arguments of 327 result in a branch to 4.0. At this point, node 4.1 may be marked as invalid.

The updated structure is shown in the following figure.



Figure 291. Updating a Binary Tree Structure (Step 2)

Continuing with the example, let's presume that we now want to swap nodes 4.1 and 4.2. Since node 4.1 is empty, the contents of node 4.2 may be freely copied into node 4.1. Currently, a search argument value of 350 causes a branch to the right at node 2.0. By depositing a value greater than 350, say 360, into node 2.0, future searches for 350 branch left at node 2.0 and then branch right at node 3.0. Node 4.2 may then be marked as invalid.

The binary tree examples presented above may be extended to 4-ary trees by bearing in mind that each node contains three keys so as to provide for a 4-way branch. This means that node n.0 depends on the first key in the parent node; node n.1 depends on the first and second key; node n.2 on the second and third key; while node n.3depends on just the third key. Therefore, when nodes are being updated, it is important that all of the keys that are associated with a branch in their direction be properly updated as well.





Figure 292. Updating a 4-ary Tree Structure

## Bridging (continued)

**Populating Upper Levels of Tree Hierarchy**. Since the ET4148-50 uses physically distinct memory systems for each level of hierarchy in its address table tree structures, it is not necessary to use actual address table key values in the upper levels of the tree structure. All that matters is that a value is in place that causes a comparison to result in a branch in the correct direction. Consider the example in the following figure.



Figure 293. Populating Upper Levels of a Binary Tree Structure

For this example, the leaf nodes have been populated with a sorted list of arbitrary values. Three of the leaf nodes have been left empty. The values in the upper nodes are simply integer averages of the two leaf nodes directly below. These leaf nodes are identified by the dotted lines descending from the upper nodes. The two leaf node keys to use to form the average are the two immediately to the left and right of the dotted line. In the case of an empty leaf node, continue to scan left or right (as is appropriate) until reaching a nonempty leaf node. In the example, node 2.2 used nodes 4.8 and 4.11 for the key values to average (as did nodes 3.4 and 3.5). If the end of the table is reached before encountering a nonempty node, then a minimum or maximum constant is used instead, as is appropriate.

Note that the only instance where an actual leaf key value is used in an upper-level node is for node 3.2. This is so because its two leaf nodes are consecutive and an integer average is guaranteed to be equal to the lesser of the two values. Even though an exact match with a search argument may occur in node 3.2, the searching continues until node 4.4.

If the value 300 were deposited into node 4.7, then node 3.3 would be updated to (276 + 300)/2 = 288. This will cause the appropriate branching to occur. For the sake of consistency, node 0.0 would also be updated. Its new value would be (300 + 444)/2 = 372. Note that making this change to node 0.0 does not affect table behavior.

However, if node 4.7 were updated to 400, then changing node 3.3 to (276 + 400)/2 = 338 would have no effect but the changing of node 0.0 to (444 + 600)/2 = 522 causes the new leaf node to be found properly.

Now consider the swapping of node 4.7 and 4.8. This requires only the changing of node 0.0 to (444 + 600)/2 = 522, which then results in the correct behavior of the table.

## Bridging (continued)

**Identifying Upper Nodes.** The method for identifying which upper node is associated with any particular pair of adjacent leaf nodes is to first identify the appropriate level of hierarchy and then the node within that level. The hierarchy level is identified by taking the exclusive OR of the index values of the two leaf nodes under consideration and then counting the number of ones in the result. The number of ones indicates the number of levels that much be traversed from the leaf node level.

For example, the upper node associated with nodes 4.9 and 4.10 is identified by the XOR of 9 (1001<sub>2</sub>) and 10 (1010<sub>2</sub>) = 0011<sub>2</sub>. The two asserted bits means that the upper-level node is two levels above the leaf node level (level 2). To identify the index at that level, use the smaller of the two leaf node index values (9, in this example) and shift it to the right by the number of levels that must be traversed upwards (2, in this example).  $1001_2 >> 2 = 10_2 = 2$ . Hence, the upper-level node associated with leaf nodes 4.9 and 4.10 is node 2.2.

### Address Aging

An address aging table (Layer\_2\_Time\_Stamp\_Table) is used to keep track of the time that has elapsed since the observation of each MAC source address. Source addresses that have not been seen in a receive packet for a certain period of time may be deleted from the address table by the supervisor.

When a Layer 2 source address matches an entry in the address table, its corresponding entry in Layer\_2\_Time\_Stamp\_Table is updated with the current value of Layer\_2\_Current\_Time.

Periodically, the supervisor scans through the time stamp table, looking for entries that are equal to the next value of Layer\_2\_Current\_Time. These entries correspond to address table entries that are set to expire upon the next incrementing of Layer\_2\_Current\_Time. Once the supervisor has deleted these entries, it may increment Layer\_2\_Current\_Time.

**Note:** There is a one-to-one correlation between address table entries and aging table entries. As entries in the address table are swapped to allow for the sorting of new entries, the same swap operations must be performed on the time stamp table.

#### **Destination Maps**

A 58-bit wide vector is used to specify the destinations for forwarded packets. The least significant (right-most) 50 bits each correspond to one of the ET4148-50's Ethernet ports. Bits 0 through 47 correspond to the 48 10/100/1000 Mbits/s Ethernet ports whereas bits 48 and 49 correspond to the two 10 Gbits/s Ethernet ports.

The most significant 8 bits (bits 50 through 57) of the 58-bit vector correspond to the eight queues that are dedicated to the supervisor. Each of these queues may be dedicated to a particular purpose (e.g., address learning, logging, BPDU reception, etc.).

The initial destination map is retrieved from the Layer\_2\_Dest\_Map\_Table register. This table is addressed by the  $dest_map_index_{0..1}[8:0]$  value retrieved from the Layer\_2\_Key\_Table\_6 record that contains a key that matches the destination address of the receive packet.

For unicast packets (i.e., a single destination port), only one bit in the destination map is asserted. For multicast packets, multiple bits may be asserted. Each asserted bit represents an intended destination.

Certain subsequent filtering and processing steps that follow the establishment of the initial destination map may serve to add or delete (assert or deassert, respectively) destinations to or from the bit map.

### Bridging (continued)

### Packet Flooding

According to the *IEEE 802.1d* standard, a packet whose destination address is unknown (i.e., not present in the Layer 2 address table) must be flooded to all potential destination ports. If a destination address look-up results in a look-up failure, then the port map contained in Layer\_2\_Flood\_Map is used as the initial destination port map rather than a value from Layer\_2\_Dest\_Map\_Table. The flood map is subject to pruning by such functions as VLANs.

### Address Learning

If the look-up on the receive packet's source address indicates that the value is not present in the Layer 2 address table, then the learning of the source address value is called for. The supervisor is responsible for carrying out the actual addition of the address value to the Layer 2 address table. The ET4148-50 merely recognizes that a particular source address is unknown, forwards a copy of the packet to the supervisor, and then allows the supervisor to determine where (if anywhere) in the table the entry belongs.

The supervisor queue designated to be the learning queue is specified via the Layer\_2\_Learning\_Port register. Ports 50 through 57 correspond to the supervisor's eight receive queues.

**Note:** Each supervisor queue may be independently configured to truncate receive packets. This feature may be beneficial for the address learning function if packet data beyond the MAC header is of no interest to the supervisor.

#### Layer 2 Access Control

Each Layer 2 address table entry includes an access control flag bit as part of an address value's associated data. This flag bit acts as an access control indicator. The flag is examined when the address being submitted for a lookup is a source address. Namely, this flag is the layer\_2\_src\_permit\_{0..1} bits of the Layer\_2\_Key\_Table\_6 register. There is one flag for key 0 and one for key 1 in each record.

If the flag bit for a particular source address is deasserted, the affected receive packet is denied access to the device. This denial does not necessarily imply that the packet is discarded. Rather, the mask stored in Layer\_2\_Src\_Deny\_Mask is applied to the destination map for the packet. Certain destinations such as supervisor queues may remain enabled for logging or other purposes.

Access control based on a packet's destination address is simply a matter of using a layer\_2\_dest\_map\_index\_{0..1}[8:0] value in Layer\_2\_Key\_Table\_6 that points to a destination map whose pattern of asserted bits is appropriate for a Layer 2 denial (e.g., all bits deasserted).

#### Spanning Tree States

The *IEEE 802.1d* spanning tree protocol requires that the various ports transition through a series of states; each state implying a certain per-port behavior. These states are listed in the following table.

#### Table 382. Spanning Tree states

| State      | Receive? | Learn? | Forward? |
|------------|----------|--------|----------|
| Disabled   | No       | No     | No       |
| Blocking   | Yes      | No     | No       |
| Listening  | Yes      | No     | No       |
| Learning   | Yes      | Yes    | No       |
| Forwarding | Yes      | Yes    | Yes      |

.Note: Operationally, there is no real difference between the blocking and listening states. Hence, they are combined into a single state called blocking for the purposes of explaining how to configure the ET4148-50

## Bridging (continued)

**Disabled State**. In this state, all reception is disabled. To accomplish this for all receive traffic on a particular port, the simplest method is to deassert the  $gmac_rx_en$  or  $xgmac_rx_en$  bit in the appropriate  $Mac_Mode_{0..6}$  register. Transmissions via a particular port are easily disabled by configuring Layer\_2\_Global\_Mask to eliminate that port from the destination map.

To disable all reception on a particular VLAN, it is a matter of setting the stp\_state[1:0] value that corresponds to the VLAN of interest in the Layer\_2\_Vlan\_Port\_State\_Table register. When a port/VLAN combination is in the disabled state, then the Layer\_2\_Src\_Deny\_Mask register's value is applied to the packet's destination map by the Layer 2 look-up function. The code for the spanning tree port disabled state is 112.

**Blocking State**. In the blocking state, BPDU packets may be forwarded to the supervisor, but all other receive packets are discarded and no packets other than BPDUs are transmitted via the port. A port/VLAN combination is placed in the blocking state by making an appropriate entry in the Layer\_2\_Vlan\_Port\_State\_Table register.

The table embodied in this register is addressed by a concatenation of the receive port number and the receive packet's VLAN index. Each entry in the table is a 2-bit spanning tree state code. The code for the blocking state is 002.

During the bridging process, the state of the port/VLAN combination is tested. If the blocking state is detected, then the Layer\_2\_Blocking\_Mask is applied to the destination bit map. This mask is typically configured to eliminate all destinations except for the supervisor queue that has been designated to receive all BPDU packets. Hence, all non-BPDU packets are discarded. Other exceptions to the application of this mask may be configured as desired.

The prevention of transmissions from a blocked port/VLAN combination is achieved through the proper configuration of the various VLAN masks; essentially eliminating the port from VLANs on which it is blocked.

Learning State. In the learning state, unknown source addresses are expected to be added to the Layer 2 address table. However, the general forwarding of packets is not permitted. A port/VLAN combination is placed in the learning state by making an appropriate entry in the Layer\_2\_Vlan\_Port\_State\_Table register.

The table embodied in this register is addressed by a concatenation of the receive port number and the receive packet's VLAN index. Each entry in the table is a 2-bit spanning tree state code. The code for the learning state is 01<sub>2</sub>.

During the bridging process, the state of the port/VLAN combination is tested. If the learning state is detected, then the Layer\_2\_Learning\_Mask is applied to the destination bit map. This mask is typically configured to eliminate all destinations except for the supervisor queues that have been designated to receive all BPDU packets and those packets with unknown source addresses. Hence, all other packets are discarded. Other exceptions to the application of this mask may be configured as desired.

Transmissions from a port/VLAN combination that is in the learning state is disallowed and is achieved through the proper configuration of the various VLAN masks, essentially eliminating the port from VLANs on which it is in the learning state.

Forwarding State. In the forwarding state, packets are forwarded normally. A port/VLAN combination is placed in the forwarding state by making an appropriate entry in the Layer\_2\_Vlan\_Port\_State\_Table register.

The table embodied in this register is addressed by a concatenation of the receive port number and the receive packet's VLAN index. Each entry in the table is a 2-bit spanning tree state code. The code for the forwarding state is 10<sub>2</sub>.

# **Access Control Lists**

Access control lists (ACLs) provide a means for restricting which receive packets are permitted access to the ET4148-50 and which are not. Each port or VLAN is associated with a single ACL. Each ACL consists of a list of access control entries (ACEs). Each ACE consists of a 5-tuple of values that are compared against various fields from the receive packet. These fields are:

1. IPv4/IPv6 source address

2. IPv4/IPv6 destination address

3. Ethertype/protocol

4. TCP/UDP source port

5. TCP/UDP destination port

The comparisons are used to identify the first ACE in an ACL that matches all of the criteria. The action associated with that ACE are then carried out. The possible actions include:

1. Permit

2. Deny

3. Log

4. Adjust Priority

### Enabling ACLs

ACLs are individually enabled or disabled by asserting or deasserting the bits in Acl\_En. An ACL must be enabled in order for it to potentially apply the deny action to a receive packet. A disabled ACL (its corresponding bit in Acl\_En deasserted) implies an automatic permit action to all receive packets mapped to that ACL.

#### ACL Modes

**IPv4 vs. IPv6.** Various basic operating modes of the ACL function are established by Acl\_Mode. The ipv4\_only bit being asserted causes the IP address tables to be restricted to just 32-bit IPv4 addresses. Doing so sets the table's capacity to 512 IP subnets or host addresses.

Deasserting the ipv4\_only bit enables a mix of IPv4 and IPv6 addresses. The trade-off is that the IP address table's capacity is reduced to 128 IP subnets or host addresses.

**Port- vs. VLAN-Based**. When the port\_based\_acls bit is asserted, each port is associated with a single ACL. The receive port number corresponds to the ACL number.

Deasserting the port\_based\_acls bit causes the receive packet's VLAN to be used to associate the packet with a VLAN. Since there are potentially more VLANs (256) than available ACLs (64), a method is provided to map between the two. This mapping is performed by the Acl\_Vlan\_Index\_Table register.

**Logging Denied Packets**. Ordinarily, the logging (copying to the supervisor) and denial of a packet are independent actions. However, it may be desired to log those packets that were denied by default (matched no ACEs). Asserting the auto\_deny\_log\_en bit in the Acl\_Mode register causes all packets denied by default to be copied to the supervisor.

The supervisor queue that is dedicated to ACL logging is chosen by Packet\_Buffer\_Acl\_Log\_Port.

## Access Control Lists (continued)

### **IP and TCP Tables**

The IP and TCP tables utilize a cascaded *k*-ary look-up method. A series of 2-way or 4-way decisions are made via a series of tables arranged as a balanced tree structure.

All *k*-ary tables have a look-up entry point (table 0) and a look-up terminus point. The look-up terminus point varies from table to table and is affected by the type of look-up (binary vs. 4-ary) and the number of keys in the table.

The IP address table operates in either a binary or 4-ary mode, depending on whether it is a mix of IPv4 and IPv6 addresses or exclusively IPv4 addresses being operated on, respectively. For a mix of IPv4 and IPv6, there are a total of nine stages to the look-up process with the final stage holding 256 keys defining 128 prefixes. Hence, this type of look-up starts with Acl\_Ip\_Key\_Table\_0 and ends with Acl\_Ip\_Key\_Table\_8.

For IPv4-only operations, there are a total of six look-up stages with the final stage holding 1,024 keys that define 512 prefixes. Hence, this type of look-up starts with Acl\_Ip\_Key\_Table\_0 and ends with Acl\_Ip\_Key\_Table\_5.

The TCP/UDP port number look-ups operate in a 4-ary mode and require five stages with the final stage holding 512 keys that define 256 ranges. The look-up entry point is Acl\_Tcp\_Key\_Table\_0 and the terminus is Acl\_Tcp\_Key\_Table\_4.

From one look-up stage to the next, there are no pointers embedded in the table that point to the keys to be examined within the next table in sequence. Rather, it is the progression of match results that forms the address used to pull the appropriate keys from the next table. Using a 4-ary look-up as an example, at each stage, the address of the current set of keys is shifted left two bit positions and the results of the current comparisons serve as the new least significant two bits of the address for the next key table. The following table provides an illustration.

| Comparison Results            | New Address Bits |
|-------------------------------|------------------|
| argument <= key_0             | 002              |
| argument > key_0 and <= key_1 | 012              |
| argument > key_1 and <= key_2 | 102              |
| else                          | 112              |

### Table 383. Key Address Formation

The records embodied in the last stage of each of the look-up types contain both key values as well as look-up results. These look-up results are index values that identify which prefix or range (if any) matches the search argument. For the IP address look-ups, source and destination address look-ups return distinct index values for source vs. destination address look-ups as well as flow identifier values that are also distinct for source vs. destination address look-ups.

For details regarding the method used to add and delete table entries, refer to Adding and Deleting Table Entries on page 273.

## Access Control Lists (continued)

### **Index Tables**

A series of tables are used to establish indirections from one stage of ACL processing to the next. These indirections minimize redundancy and provide the opportunity for the sharing of table entries from one ACE to the next. The following figure shows how the various index tables are incorporated into the look-up process.



Figure 294. ACL Processing Structure

VLAN Index Table. When the port-based VLAN mode is selected via Acl\_Mode, there is a simple one-to-one association between a receive port and its associated ACL. Essentially, the port number and the ACL number are the same.

When the ACL function is configured to be VLAN-based, Acl\_Vlan\_Index\_Table is used to establish the mapping between a VLAN index and an ACL. This register is a 256-entry table that is addressed by the receive packet's 8-bit VLAN index. Returned from this table is a 6-bit value (acl\_index[5:0]) that is used to select an individual ACL.

**Note**: There is an important distinction between a VLAN identifier and a VLAN index. A VLAN identifier is the 12-bit value received in a VLAN tagged packet. A VLAN index is the 8-bit value used to represent the VLAN association of the packet within the ET4148-50 device.

The following figure illustrates the relationship between the VLAN identifier, VLAN index and ACL.



Figure 295. VLAN-to-ACL Mapping

## Access Control Lists (continued)

**IP Address ACE Map Index Table.** This table is used to define the relationship between the IP address index (look-up result), ACL number, and ACE map. The IP address index identifies one of 512 address values. This means that there can be, at most, 512 unique IP address look-up results. These results must be shared by all of the ACLs. The 9-bit look-up result is concatenated with the output of Acl\_Vlan\_Index\_Table to form a 15-bit address that is then delivered to Acl\_Ip\_Addr\_Ace\_Map\_Index\_Table.

The output of Acl\_Ip\_Addr\_Ace\_Map\_Index\_Table is a 10-bit value that is used to select one of 1,024 IP address ACE maps. These ACE maps define the patterns of appearance of particular IP address prefixes or host addresses within ACEs. If multiple ACLs happen to share the same pattern of appearance for a particular IP address value, then this table can be used to point the multiple IP address look-up results to a common ACE map.

**TCP Port ACE Map Index Table**. The 8-bit results of the TCP/UDP port look-up are concatenated with the 6-bit ACL index to form a 14-bit address used by Acl\_Protocol\_Ace\_Map\_Index\_Table to retrieve one of 16,384 8-bit ACE map index values.

This index table enables the reuse of ACE maps by the TCP/UDP look-up results. Say, for example, that the TCP destination port range of 100 through 150 appears in ACE number 35 for five different ACLs. It is then a simple matter of having that particular ACE map be pointed to by the five locations in the index table addressed by the appropriate combinations of look-up results and ACL index.

**Protocol ACE Map Index Table**. Up to eight Ethertypes and eight Layer 4 protocols may be grouped into a maximum of eight combinations. This combined Ethertype/protocol index is used to identify the protocol value for this field of the ACE 5-tuple. The Acl\_Protocol\_Ace\_Map\_Index\_Table is used to map the 512 protocol/ACL number combinations to 128 ACE maps.

#### ACE Maps

ACE maps are used to identify those ACEs that have criteria that match the corresponding 5-tuple field from the receive packet. For example, if the receive packet's IP destination address matches the criteria for ACEs 10, 29, and 47 for ACL 18, then that IP address look-up/ACL number combination is mapped (via Acl\_Ip\_Addr\_Ace\_Map\_Index\_Table) to an ACE map wherein bits 10, 29, and 47 are all asserted and the remaining 61 bits are deasserted. This process of selecting ACE maps is repeated for all fields of the 5-tuple. The result is a series of five 64-bit ACE maps, each indicating the ACEs whose criteria are satisfied by the fields of the packet. It is then a simple matter of finding the first (lowest numbered) ACE for which all five ACE maps have the corresponding bit asserted. Figure 296 illustrates this process.

The ACE maps are defined via Acl\_Ip\_Addr\_Ace\_Map\_Table, Acl\_Port\_Ace\_Map\_Table and Acl\_Protocol\_Ace\_Map\_Table.

### **ACL Actions**

Associated with each of the access control entries is a set of actions to be carried out when a receive packet matches a particular ACE. These actions are as follows:

- 1. Permit or deny access.
- 2. Copy packet to logging queue.
- 3. Replace packet's priority.

These actions are specified by the acl\_permit, acl\_log, and acl\_priority\_code[4:0] fields of Acl\_Result\_Table.

## Access Control Lists (continued)



Figure 296. ACE Map Reduction

**Permit/Deny**. All receive packets are associated with one ACL or another. This association is based on either the packet's receive port or its VLAN index. If the associated ACL is empty (i.e., no ACEs), then an automatic permit is implied. If a receive packet fails to match all ACEs in a nonempty ACL, then an automatic deny is implied. Finally, the first matching ACE's acl\_permit bit is used to either permit or deny the packet's access to the ET4148-50 device.

If the acl\_permit bit is set, the packet is received and processed normally. If this bit is deasserted, then the matching packet is denied access. This does not necessarily imply that the packet is discarded. It may still be forwarded to certain destinations such as the supervisor or a mirroring port. The effect of an ACL denial is specified by Packet\_Buffer\_Acl\_Deny\_Mask.

ACL Logging. ACL logging refers to the copying of certain packets to the supervisor that match an ACE whose acl\_log bit is asserted. In general, logging only occurs when explicitly configured to do so, i.e., when an ACE is encountered with acl\_log asserted. The automatic logging of packets denied by default (matched no ACEs) may also be enabled by setting auto\_deny\_log\_en in the Acl\_Mode register. The logging port or queue is identified by the value set in Packet\_Buffer\_Acl\_Log\_Port.

**Priority Replacement.** One of the functions available via access control lists is the ability to override the priority value of a receive packet based on a matching ACE. Every ACE result includes an acl\_priority\_code[4:0] field. If bit 4 of this field is asserted, bits 3:0 are used to overwrite the priority value that had previously been assigned to the receive packet during ingress parsing.

## **Quality of Service**

The ET4148-50 supports both ingress and egress quality of service (QoS) features. In the ingress direction, these features are related to rate limiting policers and queue assignments. In the egress direction, these features are related to rate limiting traffic shapers, queue prioritization, and queue service scheduling.

### **Ingress Policers**

The ingress policers have the ability to limit the receive bandwidth of designated traffic flows. Since there is no appreciable buffering upstream of the policers, they affect their rate limiting by discarding packets as necessary (actually, a discard mask is applied to the packet's destination map).

**Identifying Flows**. Flow are identified by a 3-tuple that consists of a packet's destination address (Layer 2 or 3), source address (Layer 2 or 3) and its priority.

There is a pair of 3-bit flow ID values associated with every IP and MAC address table entry; one flow ID for the address as a source and one for it as a destination. These values are established via the ip\_src\_addr\_flow\_id[2:0] and ip\_dest\_addr\_flow\_id[2:0] fields of Acl\_Ip\_Key\_Table\_5 and Acl\_Ip\_Key\_Table\_8 for IP addresses and via the layer\_2\_src\_flow\_id[2:0] and layer\_2\_dest\_flow\_id[2:0] fields of Layer\_2\_Key\_Table\_6 for MAC addresses.

The priority value of a packet can be derived from a packet's receive port, the Layer 2 CoS field from its *IEEE 802.1p* tag, from the DSCP field of its IP header or from an override value provided by the ACL function.

For Layer 2/CoS, the priority value is mapped directly from the CoS field of the packet (zero extended from 3 bits to 4 bits). If the CoS field is not present, the port's default priority is used.

For the DSCP field, it is mapped via a look-up table from a 6-bit value to a 4-bit value via Priority\_Encode\_Table\_{0..6}.

Layer 3 priority information is ordinarily used for all IP packets while Layer 2 information is used for all non-IP packets. The device can be configured to always use Layer 2 priority information by asserting the layer\_2\_priority\_override\_en bit in the Port\_Mode register.

For an ACL priority override, the priority value is retrieved from the ACE that corresponds to the receive packet. The override priorities are established in the Acl\_Result\_Table register via the acl\_priority\_code[4:0] field. Bit 4 of acl\_priority\_code[4:0] must be asserted for the priority override to take place.

The combining of the source and destination-based flow identifiers and the packet's priority is accomplished by  $Policer_Flow_Id_Table\{0..6\}$ . These tables are addressed by a concatenation of the receive packet's destination flow identifier (3 bits), source flow identifier (3 bits), and its priority value (4 bits).

There are eight policers associated with each of the 48 10/100/1000 Mbits/s Ethernet receive ports. There are 80 such policers associated with each of the two 10 Gbits/s Ethernet receive ports. Hence, Policer\_Flow\_Id\_Table{0..4} returns a 3-bit value while Policer\_Flow\_Id\_Table{5..6} returns a 7-bit value.

**Establishing Flow Bandwidth Limits.** Two parameters are used to establish bandwidth limits on a per-policer basis: the policer delta and limit. These are established in Policer\_Delta\_Table and Policer\_Limit\_Table, respectively.

The policer delta is subtracted from its associated policer accumulator ( $Policer_Accumulator_Table$ ) on a periodic basis. The accumulator will not go negative. The period used to apply the delta is proportional to the configured bandwidth for the port. In other words, the delta is applied 10 times more often for a 1 Gbit/s Ethernet port than it is for a 100 Mbits/s Ethernet port. The port speed for policer purposes is set in the port\_speed[1:0] field in the Policer\_Accumulator\_Table{0..4} registers. Smaller values of this field correspond to smaller delta periods and, hence, higher port speeds.

## Quality of Service (continued)

**Establishing Flow Bandwidth Limits** (continued). Each received packet causes its associated policer accumulator to be incremented by a value that equals the length of the receive packet (as measured in bytes). If the receive byte rate exceeds the rate at which the deltas are being applied, then the value in the accumulator will tend to increase over time. Hence, an increasing accumulator value equates to an out-of-profile flow of traffic.

The limit established for a policer defines the maximum duration of out-of-profile traffic that is tolerated without penalty. In other words, a flow may be allowed to operate in a bursty manner as long as the aggregate data rate for the flow is below the data rate implied by delta value. The value established in Policer\_Limit\_Table defines the maximum tolerated burst or, to put it another way, the promptness with which the policer responds to out-of-profile traffic. A higher value in Policer\_Limit\_Table equates to longer bursts being tolerated or a somewhat slower response by the policer.

**Specifying Actions for Out-of-Profile Traffic**. Once a flow has been identified as being out of profile, the policer may take action on the packets associated with the flow. These actions are defined by the Policer\_Flow\_Mode\_Table registers.

Each policer can be configured to do one of the following:

- 1. Ignore out-of-profile traffic
- 2. Discard all out-of-profile traffic
- 3. Discard all out-of-profile traffic only when the packet buffer is congested

Additionally, each policer can be configured to demote the priority of all out-of-profile traffic that is not discarded.

### **Egress Traffic Shapers**

The egress traffic shapers are conceptually similar to the ingress policers in that they serve to limit the bandwidth allowed by each port. They differ, though, in that they don't discard excess traffic but, instead, merely retard it. This is possible because the packet buffer is upstream of the traffic shapers and can absorb sizable bursts of traffic whereas the policers have no such upstream buffering.

There is one traffic shaper associated with each transmit queue (recall that there are four such queues for every transmit port).

The traffic shapers are credit-based mechanisms. On a periodic basis, the delta value programmed into Packet\_Buffer\_Shaper\_Delta is added to a queue's shaper accumulator

(Packet\_Buffer\_Shaper\_Accumulator). The period for this accumulation is dependent upon the speed of the associated port (Packet\_Buffer\_Port\_Speed). Higher port speeds result in proportionally higher delta accumulation rates.

The accumulation of these credits occurs continuously but ceases once the limit established in Packet\_Buffer\_Shaper\_Limit is reached. The higher the limit, the longer the transmit burst that may occur.

Whenever the value of a traffic shaper's accumulator is greater than zero, the associated queue is enabled to arbitrate for transmission. Each successful transmission arbitration causes the byte count of the transmitted packet to be subtracted from the shaper's accumulator. If the accumulator's value goes negative, the queue becomes disabled from arbitrating until sufficient further credit has been accumulated.

## Quality of Service (continued)

### Packet Priority Management

A packet's priority level is a critical characteristic that is taken into account throughout the forwarding process.

**Priority Assignment.** Upon reception, each packet is assigned a priority value. The most basic priority assignment comes from the receive port's default priority. This value is established via the default\_priority[3:0] field of the Port\_Mode\_{0..6} registers. This default value is used whenever Layer 2 (VLAN) and Layer 3 (IP) priority information is not available. The default\_priority[3:0] must be set such that lowest possible priority is represented by the value 0 while the highest priority is represented by the value 15.

VLAN-tagged, non-IP packets utilize the 802.1p priority field directly (zero-extended to 4 bits).

IP packets utilize the DSCP field after having been mapped to 4 bits by the Priority\_Encode\_Table registers. These 64-entry tables are addressed by the 6-bit DSCP field from the IP header. The output of the table is the 4-bit priority value to be assigned to the packet. This table may be configured arbitrarily. However, it is recommended that lower-value entries relate to lower-priority levels.

Finally, if both Layer 2 (VLAN) and Layer 3 (IP) priority information is available in the receive packet, the Layer 3 information takes precedence unless layer\_2\_priority\_override\_en in Port\_Mode\_{0..6} is asserted.

**Priority Reassignment**. The ACL-related look-ups performed on the receive packet may result in a priority reassignment. This is useful if an ACL is effective at identifying a particular class of traffic that should receive a certain type of handling.

Configuring the ET4148-50 to perform this priority reassignment is a matter of establishing an appropriate rule or set of rules as part of the ACL configuration (see Access Control Lists on page 280) and setting the acl\_priority\_code[4:0] field appropriately in the Acl\_Result\_Table register. When an acl\_priority\_code[4:0] value is encountered whose bit 4 is asserted, bits 3 through 0 of that field are used to overwrite the 4-bit priority value assigned to the receive packet.

**Mapping to Queues.** The ET4148-50 supports 16 levels of internal priority representation (as allowed by the 4-bit priority value assigned to each receive packet). However, there are eight queues available for each transmit port. Hence, the 16 packet priority levels must be mapped to the eight queues. This is accomplished via the appropriate programming of the Packet\_Buffer\_Priority\_Table register.

This 16-entry table is addressed by the 4-bit priority value associated with each receive packet. The 3-bit output from this table is used to select one of the eight queues associated with each transmit port. Queue number zero is the lowest priority queue while queue number seven is the highest.

**Priority Remarking**. There are two circumstances under which a packet's embedded priority information may be changed prior to transmission:

1. The priority was reassigned by the ACL function.

2. The ingress policer identified the packet as being out of profile and moved to demote its priority.

A 32-entry table (Priority\_Decode\_Table) is used to establish new priority values for transmit packets. This table is addressed by a concatenation of a demote flag and the 4-bit priority value associated with the packet. The demote flag serves as the most significant bit of the table's address. Hence, the table can be thought of as having two halves. The lower half is the normal priority mapping while the upper half (addressed by an asserted demote flag) represents the demoted or lowered priority values for the transmit packet.

This table returns both a 6-bit DSCP value for the IP header as well as a 3-bit CoS field for the VLAN tag. These return values are used as is appropriate depending on the form of the transmit packet.

## Quality of Service (continued)

### Packet Buffer Congestion Management

The central packet buffer is a limited resource that must be shared among all users ("users" being defined as receive ports). Various congestion thresholds are used to limit the number of buffers that may be allocated to each user.

Two forms of ingress flow control are available: policer and MAC. The policers may be configured to discard out-ofprofile traffic at all times or only when the packet buffer is congested. Hence, the policers may be made responsive to the congestion state of the interface. The policers are configured for the type of action to take during congestion via the Policer\_Flow\_Mode\_Table register. Setting the discard\_out\_of\_profile\_when\_congested bit makes the respective policer responsive to the congestion state.

The MAC flow control utilizes *IEEE 802.3x* flow control packets to prevent the other end of a full-duplex Ethernet link from transmitting for a limited period of time. This form of flow control is not flow based and has the effect of shutting down all receive traffic on a port regardless of its priority or destination.

The congestion thresholds for these two flow control mechanisms are set via the

Packet\_Buffer\_Global\_Congestion\_Threshold and Packet\_Buffer\_Channel\_Congestion\_Threshold registers. As the name implies, the global threshold is applied globally (affects all ports or channels) and is sensitive to the total allocation of buffers. The channel (or port) congestion threshold is applied to only a single group of ports and is sensitive to the number of buffers allocated to that receive group.

Each type of threshold (global or per-port) has two subtypes: policer or MAC.

Whenever the total number of buffers allocated exceeds a threshold set in Packet\_Buffer\_Global\_Congestion\_Threshold, the appropriate congestion indication (policer or MAC) is provided to all ports simultaneously.

If the global congestion threshold has not been exceeded, then when a per-port congestion threshold is exceeded, the appropriate indication (policer or MAC) is provided to only the affected port.

The congestion thresholds are typically set as follows:

- The policer thresholds should be lower than the MAC thresholds.
- The sum of the per-channel thresholds should be greater than the global threshold.

Queue Management (Revision C Only). In revision C, some new registers are added to create maximum queue sizes. To enable these new registers, hol\_mode in the Packet\_Buffer\_Mode register must be asserted.

To create the maximum queue size, two sets of queue limits are configured. One set limits the number of packets that may occupy a queue during packet buffer congestion, and the second set limits the number of buffers (128 bytes) that may be occupied by each queue during packet buffer congestion. Each set of limits has a corresponding congestion threshold used to determine when the packet buffer is considered congested for these limits.

The supervisor\_queue\_limit[12:0] and queue\_limit[12:0] fields in the Packet\_Buffer\_Queue\_Limit register are global limits used to restrict the number of packets that may occupy a queue during packet buffer congestion. For these limits, the packet buffer is considered congested if queue\_mask\_congestion\_threshold[14:4] in the Packet\_Buffer\_Queue\_Management\_Thresholds register is exceeded.

When this global threshold is reached and a queue is over its allocated packet limit, the ET4148-50 prevents further enqueues to that queue until the packet buffer is no longer congested or until the number of packets occupying the queue drops below its allocated limit. The packet buffer is no longer considered congested for these limits when the total number of queue entries drops below queue\_mask\_congestion\_threshold[14:4] minus global\_congestion\_hysteresis[9:4].

## Quality of Service (continued)

Likewise, the supervisor\_queue\_buffer\_limit[14:0] and queue\_buffer\_limit[14:0] fields in the Packet\_Buffer\_Queue\_Buffer\_Limit register are global limits used to restrict the number of buffers (128 bytes) that a queue may occupy during packet buffer congestion. For these limits, the packet buffer is considered congested, if buffer\_queue\_global\_congestion\_threshold[14:4] in the Packet\_Buffer\_Queue\_Management\_Thresholds register is exceeded.

When this global threshold is reached and a queue is occupying more buffers than its allocated limit, the ET4148-50 prevents further enqueues to that queue until the packet buffer is no longer congested or until the number of buffers occupied by the queue goes below its allocated limit. The packet buffer is no longer considered congested for these limits when the total number of buffers used by the queue drops below buffer\_queue\_global\_congestion\_threshold[14:4] minus global\_congestion\_hysteresis[9:4].

### Multicast/Broadcast Rate Limiting

The ET4148-50 has the ability to track the rate at which it is forwarding multicast and/or broadcast packets. If that rate exceeds a configurable maximum, the excess multicast and/or broadcast packets are discarded. A single rate-limiting function is shared by all Ethernet ports.

This packet rate limiting may be applied to either multicast packets or broadcast packets exclusively, or it may be applied to both multicast and broadcast packets. Multicast rate limiting is enabled by asserting the multicast\_rate\_limit\_en bit in the Multicast\_Rate\_Mode register. Broadcast rate limiting is enabled by asserting the broadcast\_rate\_limit\_en bit in the same register.

A leaky bucket style rate limiting function is used to measure the global rate of multicast packets and compare that rate against a configurable limit. If that limit is exceeded, a mask is applied to the destination bit map for all multicast and/or broadcast packets for as long as the condition persists.

The maximum multicast rate is established via the Multicast\_Rate\_Decrement\_Period register. This register determines how often the Multicast\_Rate\_Accumulator is decremented. The period is calibrated in eight nano-second units. So, setting this register to a value of one enables a multicast packet rate of 125,000,000 per second. A value of F\_FFF16 results in maximum rate of 119 multicast packets per second.

The Multicast\_Rate\_Limit register is used to establish the ET4148-50's multicast burst tolerance. A higher value in this register implies a higher tolerance for bursts of multicast packets. Once the value in Multicast\_Rate\_Accumultor exceeds that of Multicast\_Rate\_Limit, the multicast packet rate is determined to be in excess of the established limit.

When this condition is true, the mask in Multicast\_Rate\_Discard\_Mask is applied during bridging operations to all received multicast packets. This mask is typically configured to exclude certain destinations from the masking operation. An example of such a destination is the supervisor queue that has been configured to be dedicated to the reception of BPDU packets.

## **Other Networking Functions**

This section describes the configuration requirements of a variety of additional packet handling methods supported by the ET4148-50.

### **IGMP Snooping**

IGMP snooping enables the copying of IGMP packets to the supervisor for processing. These snooped packets are otherwise forwarded normally.

Each port may be individually enabled for IGMP snooping. This is accomplished by asserting the <code>igmp\_snoop\_en</code> bit in the <code>Layer\_2\_Mode</code> register that corresponds to the receive port of interest. Once a port has been enabled to have its receive traffic snooped for IGMP packets, all IGMP packets that are received have the port identified by the <code>Layer\_2\_Igmp\_Snooping\_Port</code> added to the packet's destination map. Typically, <code>Layer\_2\_Igmp\_Snooping\_Port</code> is configured to identify one of the supervisor's receive queues as the IGMP snooping port.

### User-Port Snooping

User-port snooping makes it possible for the supervisor to receive copies of packets that are destined for a designated TCP or UDP destination port.

The TCP/UDP destination port number of interest is programmed into the Layer\_2\_User\_Port register. Individual Ethernet receive ports are enabled for user-port snooping by asserting their corresponding user\_port\_snoop\_en bits in the Layer\_2\_Mode register.

Packets received on the correctly enabled ports whose TCP or UDP destination port number matches the value in Layer\_2\_User\_Port are copied to the port identified by the Layer\_2\_User\_Port\_Snooping\_Port register in addition to being forwarded normally. Ordinarily, the user-port snooping port is chosen to be one of the supervisor's receive queues.

### **Cross-VLAN Routing**

Communicating between VLANs typically requires the Layer 3 services of a router. The ET4148-50 includes the capability to detect that a packet has been disallowed from being forwarded due to VLAN restrictions.

Individual ports may be enabled to support the cross-VLAN routing feature. This is done by asserting the supervisor\_route\_en bits in the Layer\_2\_Mode register that correspond to the desired ports.

When a packet is received that ordinarily would have been forwarded to a transmit port if the destinations had not been inhibited by VLAN restrictions, the supervisor route port is added to the packet's destination map. This port is designated via the Layer\_2\_Supervisor\_Route\_Port register.

Packets forwarded to the supervisor route port are expected to be routed by the supervisor to their appropriate destinations.

## Other Networking Functions (continued)

### Supervisor Packet Transmission

The ET4148-50 initiates *PCI* transfer cycles in order to read data structures stored within the supervisor's memory space that describe and contain packets to be transmitted onto one or more of the ET4148-50's Ethernet ports. The figure below shows the relationship between these various data structures.



Figure 297. Supervisor Packet Transmission Data Structures

The following sections describe how to configure these various data structures and their related registers within the ET4148-50.

**Transmit FIFOs**. Two independent transmit FIFOs are supported. A strict priority relationship exists between the two with FIFO 1 being of higher priority than FIFO 0. Whenever FIFO 1 is nonempty, it preempts the servicing of FIFO 0.

These FIFOs contain lists of transmit descriptor pointers. One such pointer occupies each 32-bit word in a FIFO. These FIFOs reside in the supervisor's memory and are accessed automatically by the ET4148-50 via the *PCI* bus.

The physical boundaries of the FIFOs are defined by the start\_ptr[31:2] and end\_ptr[31:2] fields of the Supervisor\_Tx\_Fifo\_Limits register. There are two instances of each of these fields; one for each FIFO.

The ET4148-50 starts processing a transmit FIFO at the location specified by the  $start_ptr[31:2]$  field and continues until reaching the location pointed to by the  $last_ptr[31:2]$  field. This field identifies the last valid entry in the respective transmit FIFO. The  $last_ptr[31:2]$  value is updated by the supervisor and interpreted by the ET4148-50. As the supervisor adds new entries to a transmit FIFO, it advances the value of  $last_ptr[31:2]$  to always point to the last valid entry in the FIFO. The advancement of this pointer causes the ET4148-50 to process the new FIFO contents.

The end\_ptr[31:2] value defines the end of the physical block of memory containing the FIFO. Once the location indicated by end\_ptr[31:2] has been used, operation of the FIFO continues at the location indicated by the value of start\_ptr[31:2].

Refer to the Supervisor\_Tx\_Fifo\_{0..1} data structure description on page 51 for further information.

## Other Networking Functions (continued)

**Transmit Descriptors.** Each entry in the transmit FIFOs is a pointer to a transmit descriptor. Each transmit descriptor is a list of one or more 2-word (32-bit words) records that identify the various segments that make up a transmit packet.

Each 2-word structure consists of a pointer to a transmit segment, a segment length value, and a pair of flag bits: last and indicate.

The last flag is asserted if the current record is the last record of the packet descriptor. Once a record is encountered with its last flag asserted, packet descriptor processing is terminated and the last byte of the associate transmit segment is considered to be the last byte of the packet.

The indicate flag is asserted if it is desired to have an interrupt generated at the completion of packet transfer. This function is used to enable the supervisor to keep track of the transmission process. Interrupts enabled by this flag occur when the corresponding segment has completed its transfer across the *PCI* bus from the supervisor's memory to the ET4148-50's internal memory. This event may precede the actual transmission of the packet by a significant amount of time. In fact, the successful transfer of the packet (and its accompanying interrupt to the supervisor) is no assurance that the packet has been or ever will be transmitted. Certain events such as MAC flow control or maximum collisions on a half-duplex link may significantly delay or even prevent transmission.

Refer to the Supervisor\_Tx\_Descriptor\_{0..1} data structure description on page 50 for further information.

**Transmit Packet Segments**. The transmit segments are simply contiguous bytes that are to be gathered up by the ET4148-50 as part of a transmit packet. The transmit packets must utilize a format that conforms to that shown for the Supervisor\_Tx\_Packet data structure. See page 52 for more details.

Refer to the Supervisor\_Tx\_Packet\_Segment\_{0..1} data structure description on page 53 and for further information.

### **Supervisor Packet Reception**

Eight of the 408 queues within the ET4148-50 are dedicated to the supervisor for packet reception purposes. These eight queues correspond to bits 50 through 57 of the 58-bit destination map that is computed as part of the bridging process.

There is a one-to-one correlation between these eight internal queues and the eight receive FIFOs that are maintained by the ET4148-50 in the supervisor's memory space across the *PCI* bus.

## Other Networking Functions (continued)

**Defining the FIFOs.** The Supervisor\_Rx\_Fifo\_Limits register is used to establish the physical extent of the eight packet receive FIFOs in the supervisor memory space. The rx\_fifo\_start\_ptr[31:2] and rx\_fifo\_end\_ptr[31:2] fields point to the first and last 32-bit words of each receive FIFO. The ET4148-50 deposits receive packets into contiguous locations between these two limits.

The  $rx\_fifo\_first\_ptr[31:2]$  field is used by the supervisor to protect receive packets that have been transferred across the *PCI* bus into the supervisor's memory and which the supervisor has not yet finished using. The supervisor sets  $rx\_fifo\_first\_ptr[31:2]$  to point to the first word of the packet that it is currently working with. The ET4148-50 will not advance its write pointer beyond the point identified by  $rx\_fifo\_first\_ptr[31:2]$ , thus preventing the overrunning of FIFO data.

**Managing the FIFOs**. As packets are transferred into a supervisor's receive FIFO, two pointers are advanced by the ET4148-50 to inform the supervisor of the state of the receive transfer process. These pointers reside in the Supervisor\_Rx\_Fifo\_Ptr register. There is one set of pointers for each of the eight queues.

The rx\_fifo\_wr\_ptr[31:2] value indicates the location of supervisor memory currently being addressed during write operations. This pointer is for informational purposes only and need not be monitored during normal operation.

The rx\_fifo\_last\_ptr[31:2] value points to the start of the newest complete packet in the corresponding receive FIFO. Once the supervisor has processed the packet identified by this pointer, the FIFO is considered empty.

# Statistics

The extent to which statistics require any configuration is that they must be reset to zero or some other starting value prior to normal operation of the device. When any of the ET4148-50's statistics counters reach their maximum value, they roll over to zero without notification and continue counting. Consequently, the statistics counters must be sampled often enough such that the sample period is always less than the counters' minimum roll over period.

# **Other Device Functions**

### **Device Reset**

If possible, the ET4148-50 should be supplied with a reset signal (RST\_N) that is separate from the powerup reset for the rest of the system so that the ET4148-50 may be independently reset. If the device is powered up and the core clock (REFCLK\_CORE) is stable, a low going pulse of 200 ns or greater is sufficient to reset the device. During powerup, the reset signal should be held low for at least 200 ns after power has ramped and REFCLK\_CORE is stable. Figure 298 illustrates the desired reset operation. In this figure, RST\_N is represented as both a continuously low signal and a low-going pulse. The continuously low signal represents the reset during power up. The pulse is representative of a reset when the device is powered up and REFCLK\_CORE is stable.





### Table 384. RST\_N Timing

| Parameter   | Description                                                 | Value            |
|-------------|-------------------------------------------------------------|------------------|
| Tclk_stable | Period needed for core clock stabilization                  | System Dependent |
| Trst        | Period needed after power ramps and core<br>clock is stable | ≥200 ns          |

## Other Device Functions (continued)

### **PCI** Initialization

For the PCI configuration space, the first 16 bytes are defined the same for all device types. In the ET4148-50, the Header Type (offset 0x0E) is hardcoded to 0x00 and indicates that the configuration space header is type 0. This type 0 header is represented in Figure 299.

| 31                         |        | 16          | 15            |                | 0    |
|----------------------------|--------|-------------|---------------|----------------|------|
|                            | Devi   | ce ID       | Vend          | 0x00           |      |
|                            | Sta    | itus        | Com           | mand           | 0x04 |
|                            |        | Class Code  |               | Revision ID    | 0x08 |
| BIST                       |        | Header Type | Latency Timer | Cacheline Size | 0x0C |
|                            |        | Base Addre  | ss Registers  |                | 0x10 |
|                            |        |             |               |                | 0x14 |
|                            |        |             |               |                | 0x18 |
|                            |        |             |               |                | 0x1C |
|                            |        |             |               |                | 0x20 |
|                            |        |             |               |                | 0x24 |
|                            |        | Cardbus C   | CIS Pointer   |                | 0x28 |
|                            | Subsys | stem ID     | Subsystem     | n Vendor ID    | 0x2C |
| Expansion ROM Base Address |        |             |               |                | 0x30 |
| Reserved Capabilities      |        |             |               |                | 0x34 |
| Reserved                   |        |             |               |                | 0x38 |
| Max_Lat                    |        | Min_Gnt     | Interrupt Pin | Interrupt Line | 0x3C |

### Figure 299. Type 0 Configuration Space Header

The PCI specification requires implementation of five read-only fields. These include device ID, vendor ID, revision ID, header type, and class code. Class code consists of three fields: base class code, subclass code, and programming interface code. As mentioned above, the value of the header type field is 0x00. The values of these remaining fields are as follows:

- Device ID (offset 0x02) = 0x1107
- Vendor ID (offset 0x00) = 0x0700
- Revision ID (offset 0x08) = 0x01
- Class code
  - Base class code (offset 0x09) = 0x06
  - Subclass code (offset 0x0A) = 0x00
  - Programming interface code (offset 0x0B) = 0x00

For initialization of the configuration space, program the command field (offset 0x04) to 0x0006. In addition, program the base address register (offset 0x10) to support a 1 Mbyte memory space using a value of 0xXXX00000, where **X** represents any arbitrary hexadecimal value. The least-significant nibble of the base address field has a read-only value of 0xC, which specifies that the base address is prefetchable and maps into memory space.

Initially, per the specification, the PCI bus is little-endian; however, the ET4148-50 allows the reprogramming of the bus to big-endian after PCI initialization. See the Supervisor Endian section below for information on reprogramming the endianness. For more information on the PCI bus, see the PCI Local Bus Specification Rev. 3.0, February 3, 2004.

## Other Device Functions (continued)

### Supervisor Endian

The supervisor's *PCI* bus can operate in either a big-endian or a little-endian fashion. This operating mode is set via the big\_endian bit in the Supervisor\_Endian register. Clearing this bit to zero places the *PCI* bus in its normal operating mode: little endian. Setting the bit causes the *PCI* bus to operate in big-endian manner.

It is recommended that 0000\_000016 or FFFF\_FFF16 be written to this register and to not bother with 8000\_000016 or 0000\_000116. Doing so guarantees that the big\_endian bit is set as desired.

#### Interrupts

On-chip events may result in indications to the supervisor. These indications may, in turn, result in a hardware interrupt. This hierarchy of events, indications, and interrupts is presented via a series of registers, records, and fields that control which events may become indications and, in turn, which indications may become interrupts.



Figure 300. Indications and Interrupts

Signals that indicate the occurrence of the various events must pass through a mask before being presented to an indication status register that is readable by the supervisor. This mask uses two write-only registers to set and clear the mask bits. This technique of manipulating mask bits is done to make it possible to turn on or off a single bit or a subset of bits with an atomic operation that cannot be interrupted.

The unmasked indication bits are then passed through an interrupt mask. This mask is managed in much the same manner as the indication masks. Those indications that pass through the interrupt masks are presented via the interrupt status registers to the supervisor. Bits asserted in the interrupt status register are also ORed together to form a hardware interrupt to the supervisor.

### Packet Buffer Scrubbing

To guard against the possibility of a buffer within the packet buffer becoming lost from the free list and, hence, no longer available for packet storage operations, the ET4148-50 includes a packet scrubbing mechanism. This mechanism is activated by writing the buffer number of a presumed-missing buffer into the missing\_buffer[14:0] field of the Packet\_Buffer\_Scrub register. The ET4148-50 takes that buffer number and determines if it exists on the free list or any of the transmit queues or descriptors. If the buffer cannot be found, it is added to the free list as a new entry. During the searching operation, the scrubbing bit is asserted by the ET4148-50 in the Packet\_Buffer\_Scrub register.

# **Ordering Information**

### Table 385. Ordering Information

| Device    | Description                                                                                    | Part Number      | Comcode   |
|-----------|------------------------------------------------------------------------------------------------|------------------|-----------|
| ET4148-50 | Single-Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision B            | ET4148-50B-DB    | 700079713 |
| ET4148-50 | Single-Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision B1           | ET4148-50B1-DB   | 700084141 |
| ET4148-50 | Single-Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision C            | ET4148-50C-DB    | 711002433 |
| ET4148-50 | Lead-Free Single Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision B  | L-ET4148-50B-DB  | 700079856 |
| ET4148-50 | Lead-Free Single Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision B1 | L-ET4148-50B1-DB | 711006781 |
| ET4148-50 | Lead-Free Single Chip 48 x 1 Gbit/s + 2 x 10 Gbits/s<br>Layer 2+ Ethernet Switch – Revision C  | L-ET4148-50C-DB  | 711006776 |

# **Related Documentation**

### Table 386. Related Documentation

| Device    | Description                                                        | Document Type                  |
|-----------|--------------------------------------------------------------------|--------------------------------|
| ET1011    | Gigabit Ethernet Transceiver                                       | Product Brief                  |
| ET1310    | Gigabit Ethernet Controller                                        | Data Sheet<br>Application Note |
| ET1081    | Gigabit Ethernet Octal PHY                                         | Product Brief<br>Data Sheet    |
| ET4028-50 | Single-Chip 28 x 1 Gbit/s Layer 2+ Ethernet Switch                 | Product Brief                  |
| ET4048-50 | Single-Chip 48 x 1 Gbit/s Layer 2+ Ethernet Switch                 | Data Sheet                     |
| ET4128-50 | Single-Chip 28 x 1 Gbit/s + 2x 10 Gbits/s Layer 2+ Ethernet Switch | Application Note               |
| ET3028-50 | Single-Chip 28 x 1 Gbit/s Layer 2 Ethernet Switch                  |                                |
| ET3048-50 | Single-Chip 48 x 1 Gbit/s Layer 2 Ethernet Switch                  |                                |

*PCI* is a trademark of PCI-SIG Corporation. *IEEE* and *802* are registered trademarks of the Institute of Electrical and Electronics Engineers, Inc.

 For additional information, contact your Agere Systems Account Manager or the following:

 INTERNET:
 Home: http://www.agere.com Sales: http://www.agere.com/sales

 E-MAIL:
 docmaster@agere.com

 N. AMERICA:
 Agere Systems Inc., Lehigh Valley Central Campus, Room 10A-301C, 1110 American Parkway NE, Allentown, PA 18109-9138

 1-800-372-2447, FAX 610-712-4106 (In CANADA: 1-800-553-2448, FAX 610-712-4106)

 ASIA:
 CHINA: (86) 21-54614688 (Shanghai), (86) 755-25881122 (Shenzhen), (86) 10-65391096 (Beijing)

 JAPAN: (81) 3-5421-1600 (Tokyo), KOREA: (82) 2-767-1850 (Seoul), SINGAPORE: (65) 6741-9855, TAIWAN: (886) 2-2725-5858 (Taipei)

 EUROPE:
 Tel. (44) 1344 865 900

Agere Systems Inc. reserves the right to make changes to the product(s) or information contained herein without notice. No liability is assumed as a result of their use or application. Agere, Agere Systems, and the Agere logo are registered trademarks of Agere Systems Inc. *TruePHY* is a trademark of Agere Systems Inc.

Copyright © 2006 Agere Systems Inc. All Rights Reserved



