# 10G/25G High Speed Ethernet Subsystem v4.1

# **Product Guide**

**Vivado Design Suite** 

PG210 (v4.1) October 19, 2022

Xilinx is creating an environment where employees, customers, and partners feel welcome and included. To that end, we're removing non-inclusive language from our products and related collateral. We've launched an internal initiative to remove language that could exclude people or reinforce historical biases, including terms embedded in our software and IPs. You may still find examples of non-inclusive language in our older products as we work to make these changes and align with evolving industry standards. Follow this <a href="link">link</a> for more information.





# **Table of Contents**

| Chapter 1: Introduction                               |     |
|-------------------------------------------------------|-----|
| Features                                              | 5   |
| IP Facts                                              | 6   |
| Chapter 2: Overview                                   |     |
| Navigating Content by Design Process                  |     |
| Subsystem Overview                                    |     |
| Feature Summary                                       |     |
| Applications                                          | 11  |
| Licensing and Ordering                                | 11  |
| Chapter 3: Product Specification                      |     |
| Standards                                             |     |
| Performance and Resource Utilization                  | 16  |
| Latency                                               | 17  |
| Port Descriptions – MAC+PCS Variant                   | 17  |
| Port Descriptions – PCS Variant                       | 44  |
| Port Descriptions – 10G Ethernet MAC (64-bit) Variant | t49 |
| Register Space                                        | 63  |
| Chapter 4: Designing with the Subsystem               | 121 |
| Clocking                                              |     |
| Resets                                                | 128 |
| LogiCORE Example Design Clocking and Resets           | 130 |
| Support for IEEE Standard 1588v2                      | 134 |
| RS-FEC Support                                        | 144 |
| Ethernet Datapath Parity                              | 148 |
| 802.1cm Preemption Feature                            | 149 |
| Status/Control Interface                              | 154 |
| Pause Processing                                      | 155 |
| Auto-Negotiation                                      | 159 |
| Link Training                                         | 162 |



| Chapter 5: Design Flow Steps                        | 167         |
|-----------------------------------------------------|-------------|
| Customizing and Generating the Subsystem            | 167         |
| Constraining the Subsystem                          | 176         |
| Simulation                                          | 177         |
| Synthesis and Implementation                        | 179         |
| Chapter 6: Example Design                           | 180         |
| Overview                                            | 180         |
| Example Design Hierarchy (GT in Example Design)     | 183         |
| User Interface                                      | 187         |
| Core xci Top Level Port List                        | 190         |
| Duplex Mode of Operation                            | 236         |
| Runtime Switchable                                  | 236         |
| Shared Logic Implementation                         | 238         |
| AXI4-Lite Interface Implementation                  | 240         |
| IEEE Clause 108 (RS-FEC) Integration                | 245         |
| PTP 1588 Timer Syncer Block                         | 246         |
| Chapter 7: Batch Mode Test Bench                    | 260         |
| Appendix A: Upgrading                               | <b>26</b> 1 |
| Changes from v2.3 to v2.4                           | 261         |
| Changes from v2.3 (10/04/2017) to v2.3 (12/20/2017) | 263         |
| Changes from v2.2 to v2.3                           | 264         |
| Changes from v2.1 to v2.2                           | 265         |
| Changes from v2.0 to v2.1                           | 265         |
| Changes from v2.0 (10/05/2016) to v2.0 (11/30/2016) | 267         |
| Migrating from the Legacy XGEMAC                    | 271         |
| Appendix B: Debugging                               | 283         |
| Finding Help on Xilinx.com                          |             |
| Debug Tools                                         |             |
| Simulation Debug                                    |             |
| Hardware Debug                                      |             |
| Protocol Interface Debug                            |             |
| Annondia C. Additional Decourage and Level Notices  |             |
| Appendix C: Additional Resources and Legal Notices  | 296         |



| Documentation Navigator and Design Hubs | 296 |
|-----------------------------------------|-----|
| References                              | 297 |
| Revision History                        | 297 |
| Please Read: Important Legal Notices    | 304 |





# Introduction

The Xilinx® 10G/25G High Speed Ethernet Subsystem implements the 25G Ethernet Media Access Controller (MAC) with a Physical Coding Sublayer (PCS) as specified by the 25G Ethernet Consortium. MAC and physical coding sublayer/physical medium attachment (PCS/PMA) or PCS/PMA alone are available. Legacy operation at 10 Gb/s is supported.

#### **Features**

- Designed to the Ethernet requirements for 10/25 Gb/s operation specified by IEEE 802.3 Clause 49, IEEE 802.3 by, and the 25G Ethernet Consortium
- Includes complete Ethernet MAC and PCS/PMA functions or standalone PCS/PMA for 25 Gb/s operation
- Includes complete Ethernet MAC and PCS/PMA functions, standalone MAC or standalone PCS/PMA for 10 Gb/s operation. Includes standalone 64-bit Ethernet MAC
- Simple packet-oriented user interface
- Comprehensive statistics gathering
- Status signals for all major functional indicators
- Delivered with a top-level wrapper including functional transceiver wrapper, IP netlist, sample test scripts, and Vivado® Design Suite tools compile scripts
- BASE-R PCS sublayer operating at 10.3125 Gb/s or 25.78125 Gb/s
- Optional clause 74 BASE-KR FEC sublayer
- Optional Auto-Negotiation/Link Training
- Optional clause 108 25G Reed-Solomon
- Forward Error Correction (RS-FEC) sublayer (Soft RS-FEC TX, Hard RS-FEC RX option to reduce logic utilization by leveraging the embedded 100G RS-FEC function that exists within the CMAC block in UltraScale+™ devices).
- Custom Preamble mode
- Optional IEEE 1588 1-step and 2-step timestamping
- Runtime switchable between 10G and 25G



- Optional fee-based Time Sensitive Networking (TSN) feature designed to IEEE standard 802.1
   CM
  - Supports interspersing express traffic with low priority traffic
  - Supports frame preemption

## **IP Facts**

|                                                         | Facts Table                                                                 |  |  |  |  |  |
|---------------------------------------------------------|-----------------------------------------------------------------------------|--|--|--|--|--|
| Subsystem Specifics                                     |                                                                             |  |  |  |  |  |
| Supported Device Family <sup>1</sup>                    | Versal® ACAP                                                                |  |  |  |  |  |
|                                                         | Zynq® UltraScale+™ RFSoC                                                    |  |  |  |  |  |
|                                                         | Zynq® UltraScale+™ MPSoC                                                    |  |  |  |  |  |
|                                                         | Virtex® UltraScale+™                                                        |  |  |  |  |  |
|                                                         | Kintex® UltraScale+™                                                        |  |  |  |  |  |
|                                                         | Virtex® UltraScale™                                                         |  |  |  |  |  |
|                                                         | Kintex UltraScale                                                           |  |  |  |  |  |
|                                                         | Artix® UltraScale+                                                          |  |  |  |  |  |
| Supported User Interfaces                               | AXI4-Stream for variants with MAC                                           |  |  |  |  |  |
|                                                         | XGMII or 25GMII for PCS-only variants                                       |  |  |  |  |  |
| Resources Performance and Resource Utilization web page |                                                                             |  |  |  |  |  |
|                                                         | Provided with Subsystem                                                     |  |  |  |  |  |
| Design Files                                            | Encrypted register transfer level (RTL)                                     |  |  |  |  |  |
| Example Design                                          | Verilog                                                                     |  |  |  |  |  |
| Test Bench                                              | Verilog                                                                     |  |  |  |  |  |
| Constraints File                                        | Xilinx Design Constraints (XDC)                                             |  |  |  |  |  |
| Simulation Model                                        | Verilog                                                                     |  |  |  |  |  |
| Supported S/W Driver                                    | Linux                                                                       |  |  |  |  |  |
|                                                         | Tested Design Flows <sup>2</sup>                                            |  |  |  |  |  |
| Design Entry                                            | Vivado Design Suite                                                         |  |  |  |  |  |
| Simulation                                              | For supported simulators, see the Xilinx Design Tools: Release Notes Guide. |  |  |  |  |  |
| Synthesis                                               | Synopsys or Vivado Synthesis                                                |  |  |  |  |  |
|                                                         | Support                                                                     |  |  |  |  |  |
| Release Notes and Known Issues                          | Master Answer Record: 64710                                                 |  |  |  |  |  |
| All Vivado IP Change Logs                               | Master Vivado IP Change Logs: 72775                                         |  |  |  |  |  |
|                                                         | Xilinx Support web page                                                     |  |  |  |  |  |

#### Notes:

- 1. For a complete list of supported devices, see the Vivado IP catalog.
- 2. For the supported versions of third-party tools, see the Xilinx Design Tools: Release Notes Guide.

Note: To access the 25G specification, go to the 25G Ethernet Consortium website.



# Overview

# **Navigating Content by Design Process**

Xilinx<sup>®</sup> documentation is organized around a set of standard design processes to help you find relevant content for your current development task. All Versal<sup>®</sup> ACAP design process Design Hubs and the Design Flow Assistant materials can be found on the Xilinx.com website. This document covers the following design processes:

- Hardware, IP, and Platform Development: Creating the PL IP blocks for the hardware platform, creating PL kernels, functional simulation, and evaluating the Vivado® timing, resource use, and power closure. Also involves developing the hardware platform for system integration. Topics in this document that apply to this design process include:
  - Port Descriptions MAC+PCS Variant
  - Port Descriptions PCS Variant
  - Port Descriptions 10G Ethernet MAC (64-bit) Variant
  - Register Space
  - Clocking
  - Resets
  - Customizing and Generating the Subsystem
  - Chapter 6: Example Design

## **Subsystem Overview**

This document details the features of the 10G/25G Ethernet Subsystem as defined by the 25G Ethernet Consortium. PCS functionality is defined by IEEE Standard 802.3, 2015, Clause 49, Physical Coding Sublayer (PCS) for 64B/66B, type 10GBASE-R. For 25G operation, clock frequencies are increased to provide a serial interface operating at 25.78125 Gb/s to leverage the latest high-speed serial transceivers. The low latency design is optimized for UltraScale™ architecture devices.



# **Feature Summary**

See the following table for compatibility of options with the different variants of the LogiCORE IP subsystem.

## **25G Supported Features**

- Complete Ethernet MAC and PCS functions
- Designed to Schedule 3 of the 25G Consortium
- Statistics and diagnostics
- 66-bit serializer/deserializer (SerDes) interface using the Xilinx® GTY transceiver operating with Asynchronous Gearbox enabled
- Pause Processing including IEEE std. 802.3 Annex 31D (Priority based Flow Control)
- Low latency
- Custom preamble and adjustable Inter Frame Gap
- Configurable for operation at 10.3125 Gb/s (Clause 49)
- Optional Clause 73 Auto-negotiation
- Optional Clause 72.6.10 Link Training
- Optional Clause 74 FEC shortened cyclic code (2112, 2080)
- Forward Error Correction (RS-FEC) sublayer (Soft RS-FEC TX, Hard RS-FEC RX option to reduce logic utilization by leveraging the embedded 100G RS-FEC function that exists within the CMAC block in UltraScale+ devices).
- Optional Clause 108 RS FEC (25 Gb/s operation only)
- PCS only version with 25GMII Interface
- 64-bit AXI4-Stream Interface
- Optional AXI4-Lite control and status interface
- Supports 802.1CM (802.3br/802.1bu) preemption feature for MAC+PCS/PMA 64-bit Base-R

## **10G Supported Features**

- Complete MAC and PCS functions
- Base-KR mode based on IEEE 802.3 Clause 49
- Pause Processing
- Optional 64-bit or 32-bit AXI4-Stream user interfaces



- Optional Standalone MAC with 64-bit AXI4-Stream interface and XGMII pin out
- Optional Clause 73 Auto-negotiation
- Optional Clause 72.6.10 Link Training
- Optional Clause 74 FEC shortened cyclic code (2112, 2080)
- PCS only version with XGMII Interface
- Optional AXI4-Lite control and status interface
- Statistics and diagnostics
- 66-bit SerDes interface
- Custom preamble and adjustable Inter Frame Gap
- Supports 802.1CM (802.3br/802.1bu) preemption feature for MAC+PCS/PMA 64-bit Base-R

## 10G/25G Runtime Switchable IP features

- Complete MAC and PCS features
- Base-KR mode based on IEEE 802.3 Clause 49
- Statistics and Diagnostics
- 66-bit SerDes interface using Xilinx GTY transceiver
- Custom preamble and adjustable InterFrame Gap
- Pause Processing
- 64-bit AXI4-Stream interface
- Optional Clause 73 Auto-negotiation
- Optional Clause 72 Link Training
- Optional Clause 74 FEC

#### Table 1: Feature Compatibility Matrix (GTY)

| Variant                         | User<br>Interface      | МАС | PCS | Pause<br>Processing | Auto-<br>Negotiation<br>and Link<br>Training <sup>3</sup> | Clause<br>74 FEC | Clause 108<br>RS-FEC | IEEE<br>1588<br>Time<br>Stamp |
|---------------------------------|------------------------|-----|-----|---------------------|-----------------------------------------------------------|------------------|----------------------|-------------------------------|
| 10G MAC with PCS                | 64-bit AXI4-<br>Stream | Х   | Х   | Х                   | Х                                                         | Х                |                      | Х                             |
| Low Latency 10G<br>MAC with PCS | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      |                               |
| Low Latency 10G<br>MAC with PCS | 32-bit AXI4-<br>Stream | Х   | Х   |                     | X <sup>2</sup>                                            |                  |                      |                               |
| Low Latency 25G<br>MAC with PCS | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      |                               |



Table 1: Feature Compatibility Matrix (GTY) (cont'd)

| Variant                                  | User<br>Interface      | МАС | PCS | Pause<br>Processing | Auto-<br>Negotiation<br>and Link<br>Training <sup>3</sup> | Clause<br>74 FEC | Clause 108<br>RS-FEC | IEEE<br>1588<br>Time<br>Stamp |
|------------------------------------------|------------------------|-----|-----|---------------------|-----------------------------------------------------------|------------------|----------------------|-------------------------------|
| 25G MAC with PCS                         | 64-bit AXI4-<br>Stream | Х   | Х   | Х                   | Х                                                         | Х                | Х                    | Х                             |
| Runtime<br>switchable<br>10G/25G MAC+PCS | 64-bit AXI4-<br>Stream | Х   | Х   | Х                   | Х                                                         | Х                | Х                    | Х                             |
| 10G PCS-only                             | XGMII                  |     | Х   |                     | Х                                                         | Х                |                      | X 1                           |
| 25G PCS-only                             | 25GMII                 |     | Х   |                     | Х                                                         | Х                | Х                    | X 1                           |
| Runtime<br>switchable 10/25G<br>PCS-only | XGMII/<br>25GMII       |     | Х   |                     | Х                                                         | Х                | Х                    | X 1                           |
| 10G MAC-only                             | 64-bit AXI4-<br>Stream | Х   |     | Х                   |                                                           |                  |                      |                               |
| Preemption<br>(802.1CM)<br>10G/25G only  | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      | Х                             |

#### Notes:

- 1. Only 2-step timestamping is supported with the PCS-only configurations.
- 2. Only auto-negotiation logic.
- 3. Auto-Negotiation and Link Training is not supported for Versal device family.

Table 2: Feature Compatibility Matrix (GTM)

| Variant                                | User<br>Interface      | МАС | PCS | Pause<br>Processing | Auto-<br>Negotiation<br>and Link<br>Training <sup>2</sup> | Clause<br>74 FEC | Clause 108<br>RS-FEC | IEEE<br>1588<br>Time<br>Stamp |
|----------------------------------------|------------------------|-----|-----|---------------------|-----------------------------------------------------------|------------------|----------------------|-------------------------------|
| 10G MAC with PCS                       | 64-bit AXI4-<br>Stream | Х   | Х   | Х                   |                                                           | Х                |                      | Х                             |
| Low Latency 10G<br>MAC with PCS        | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      |                               |
| Low Latency 25G<br>MAC with PCS        | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      |                               |
| 25G MAC with PCS                       | 64-bit AXI4-<br>Stream | Х   | Х   | Х                   |                                                           | Х                | Х                    | Х                             |
| 10G PCS-only                           | XGMII                  |     | Х   |                     |                                                           | Х                |                      | X 1                           |
| 25G PCS-only                           | 25GMII                 |     | Х   |                     |                                                           | Х                | Х                    | X 1                           |
| Preemption<br>(802.CM) 10G/25G<br>only | 64-bit AXI4-<br>Stream | Х   | Х   |                     |                                                           |                  |                      | Х                             |

#### Notes:

- 1. Only 2-step timestamping is supported with the PCS-only configurations.
- 2. Auto-Negotiation and Link Training is not supported for Versal device family.



# **Applications**

IEEE Std 802.3 enables several different Ethernet speeds for Local Area Network (LAN) applications, and 25 Gb/s is the latest addition to the standard. The capability to interconnect devices at 25 Gb/s Ethernet rates becomes especially relevant for next-generation data center networks where:

- To keep up with increasing CPU and storage bandwidth, rack or blade servers need to support
  aggregate throughputs faster than 10 Gb/s (single lane) or 20 Gb/s (dual lane) from their
  Network Interface Card (NIC) or LAN-on-Motherboard (LOM) networking ports;
- Given the increased bandwidth to endpoints, uplinks from Top-of-Rack (TOR) or Blade switches need to transition from 40 Gb/s (four lanes) to 100 Gb/s (four lanes) while ideally maintaining the same per-lane breakout capability;
- (Due to the expected adoption of 100GBASE-CR4/KR4/SR4/LR4, SerDes and cabling technologies are already being developed and deployed to support 25 Gb/s per physical lane, twisted pair, or fiber.

# **Licensing and Ordering**

#### License Checkers

If the IP requires a license key, the key must be verified. The Vivado<sup>®</sup> design tools have several license checkpoints for gating licensed IP through the flow. If the license check succeeds, the IP can continue generation. Otherwise, generation halts with an error. License checkpoints are enforced by the following tools:

- Vivado Synthesis
- Vivado Implementation
- write bitstream (Tcl command)



**IMPORTANT!** IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.



## **License Type**

#### 10G/25G Ethernet PCS/PMA (10G/25G BASE-R)

This Xilinx IP module is provided at no additional cost with the Xilinx Vivado Design Suite under the terms of the Xilinx End User License. Information about this and other Xilinx IP modules is available at the Xilinx Intellectual Property page. For information about pricing and availability of other Xilinx IP modules and tools, contact your local Xilinx sales representative. For more information, visit the 10G/25G Ethernet Subsystem page.

# Standalone 10G/25G Ethernet MAC and PCS/PMA (10G/25G MAC + 10G/25G BASE-R/KR), 10G/25G BASE-KR and 10G TSN IEEE802.1CM

**Note:** The 10G/25G Ethernet MAC + BASE-R, 10GBASE-KR/25GBASE-KR and 10G TSN IP features require separate fee-based licensing.

These Xilinx IP module is provided under the terms of the Xilinx Core License Agreement. The module is shipped as part of the Vivado Design Suite. For full access to all core functionalities in simulation and in hardware, you must purchase one or more licenses for the core. Contact your local Xilinx sales representative for information about pricing and availability. For more information, visit the 10G/25G Ethernet Subsystem page.

## **Ordering Information**

To purchase any of these IP cores, contact your local Xilinx Sales Representative referencing the appropriate part number(s) in the following table:

Table 3: Ordering Information

| Description                                                                                                   | Part Number                                                                                                                                                                                                           | License Key                  |
|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|
| <ul> <li>10G/25G Ethernet MAC + BASE-R PCS/PMA (64-bit)</li> <li>10E MAC + BASE-R PCS/PMA (32-bit)</li> </ul> | EF-DI-25GEMAC-PROJ <sup>1</sup><br>EF-DI-25GEMAC-SITE <sup>1</sup>                                                                                                                                                    | xxv_eth_mac_pcs<br>x_eth_mac |
|                                                                                                               | <b>Note:</b> These part numbers do not include the BASE-KR/CR/SR functionality which is comprised of FEC and AN/LT. To include support for this feature, please order EF-DI-25GBASE-KR-PROJ or EF-DI-25GBASE-KR-SITE. |                              |



Table 3: Ordering Information (cont'd)

| Description                                                                                                                                         | Part Number                                                                                                                                                                                                                 | License Key                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| <ul> <li>25GBASE-KR PCS/PMA (CL108 RS-FEC, CL74 FEC, AN) <sup>2</sup></li> <li>10GBASE-KR PCS/PMA (CL74 FEC, AN) Standalone PCS/PMA only</li> </ul> | EF-DI-25GBASE-KR-PROJ<br>2,3<br>EF-DI-25GBASE-KR-SITE<br>2,3<br><b>Note:</b> The 10G/25G Ethernet MAC<br>is sold separately. To include the<br>Xilinx MAC, also order the EF-<br>DI-25GEMAC-PROJ or EF-<br>DI-25GEMAC-SITE. | xxv_eth_basekr<br>ieee802d3_25g_rs_fec_full<br>ieee802d3_25g_rs_fec_only <sup>4</sup>                                 |
| All of the configurations in row 1 and 2 are included plus 10G/25G Ethernet MAC + BASE-KR PCS/PMA (64-bit).                                         | EF-DI-25GEMAC-PROJ <sup>1</sup> EF-DI-25GEMAC-SITE <sup>1</sup> and EF-DI-25GBASE-KR-PROJ <sup>2,3</sup> EF-DI-25GBASE-KR -SITE <sup>2,3</sup>                                                                              | xxv_eth_mac_pcs<br>x_eth_mac<br>xxv_eth_basekr<br>ieee802d3_25g_rs_fec_full<br>ieee802d3_25g_rs_fec_only <sup>4</sup> |
| <ul> <li>25G/10GBASE-R PCS/PMA only</li> <li>10GBASE-R PCS/PMA only</li> <li>Switchable 25G and 10G BASE-R PCS/PMA</li> </ul>                       | Included with the Vivado design tools. No purchase necessary.                                                                                                                                                               | No license key                                                                                                        |
| 25G/10G Ethernet MAC+PCS/PMA     10G/25G Ethernet TSN 802.1CM (Preemption) Feature                                                                  | EF-DI-25G-TSN-802-1-CM-PROJ  Note: Bundle includes Ethernet MAC IP. Current support in Vivado is for 10GE TSN only. For 25G inquiries, please email ethernet_mgmt@xilinx.com.                                               | xxv_tsn_802d1cm<br>xxv_eth_mac_pcs<br>x_eth_mac                                                                       |

#### Notes:

- Includes access to legacy 10 Gigabit Ethernet Media Access Controller 10GEMAC for 7 series and UltraScale™ devices (key name: ten\_gig\_eth\_mac).
- 2. Used for 25GBASE-CR, 25GBASE-KR, or 25GBASE-SR applications.
- 3. Includes access to 10 Gigabit Ethernet PCS/PMA with FEC/Auto-Negotiation 10GBASE-KR for 7 series and UltraScale devices (key name: ten\_gig\_eth\_pcs\_pma\_basekr).
- 4. iee802d3\_25g\_rs\_fec\_only license key enables transcode bypass mode for custom applications only. For more information, refer to the 25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide (PG217) (registration required). To request access, email ethernet\_mgmt@xilinx.com. If you do not require a custom standalone FEC only implementation without MAC and/or PCS, ignore the ieee802d3\_25g\_rs\_fec\_only license key warning message in Vivado.





# **Product Specification**

The following figures show the block diagrams of the 10G/25G High Speed Ethernet Subsystem, respectively.

Note: GT transceivers are not shown.



Figure 1: 10 Gb/s Core Block Diagram





Figure 2: 25 Gb/s Core Block Diagram

A PCS-only variant of the core is also available. The block diagram is shown in the following figure.



Figure 3: Block Diagram of PCS-Only Core Variant



Additionally, you can optionally generate a 64-bit standalone version of the MAC for 10 Gb/s operation. The block diagram is shown in the following figure.



Figure 4: 64-bit Standalone Version of the MAC for 10 Gb/s Operation

## **Standards**

The 10G/25G Ethernet Subsystem is designed to the standard specified in the 25G and 50G Ethernet Consortium and the IEEE Std 802.3.

## **Performance and Resource Utilization**

For full details about performance and resource utilization, visit the Performance and Resource Utilization web page.



## Latency

The following table provides the measured latency information for the 10G/25G Ethernet Subsystem. This is the combined RX and TX latency for the core in the default configuration and does not include latency in the transceiver.

Table 4: Latency

| Core              | Total Latency<br>(ns) | TX Latency (ns) | RX Latency<br>(ns) | User Bus Width<br>(bits) | Core Clock<br>Frequency<br>(MHz) |
|-------------------|-----------------------|-----------------|--------------------|--------------------------|----------------------------------|
| 10GE MAC + PCS    | 188.82                | 67.2            | 121.62             | 64                       | 156.25                           |
| 25GE MAC + PCS    | 80.41                 | 29.58           | 50.83              | 64                       | 390.625                          |
| 10G PCS (BASE-KR) | 332.8                 | 172.8           | 160                | 64                       | 156.25                           |
| 25G PCS           | 138.25                | 71.68           | 66.57              | 64                       | 390.625                          |
| 10G PCS (BASE-R)  | 179.2                 | 19.2            | 160                | 64                       | 156.25                           |
| 10GE MAC + PCS    | 54.4                  | 28.8            | 25.6               | 32                       | 312.5                            |
| 10GE PCS          | 48                    | 19.2            | 28.8               | 32                       | 312.5                            |

#### Notes:

# **Port Descriptions - MAC+PCS Variant**

The following tables list the ports for the 10G/25G Ethernet Subsystem with integrated MAC and PCS. These signals are usually found at the wrapper.v hierarchy. These ports are applicable for both the 64-bit integrated MAC+PCS for 25 Gb/s and 10 Gb/s line rates and the low-latency 32-bit integrated MAC+PCS for the 10 Gb/s line rate. When the AXI register interface is included, some of these ports are accessed using the registers instead of the broadside bus.

#### **Transceiver Interface**

The following table shows the transceiver I/O ports for the 10G/25G Ethernet Subsystem. See Clocking for details on each clock domain.

Table 5: Transceiver I/O

| Name        | I/O | Description                                | Clock Domain |
|-------------|-----|--------------------------------------------|--------------|
| gt_tx_reset | I   | Reset for the gigabit transceiver (GT) TX. | Async        |
| gt_rx_reset | I   | GT RX reset.                               | Async        |

<sup>1.</sup> These numbers include both RX and TX fabric logic, but do not include the GT.



Table 5: Transceiver I/O (cont'd)

| Name              | I/O | Description                                                                                                                                                                               | Clock Domain  |
|-------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| ctl_gt_reset_all  | I   | Active-High asynchronous reset for the transceiver startup Finite State Machine (FSM). Note that this signal also initiates the reset sequence for the entire 10G/25G Ethernet Subsystem. | Async         |
| refclk_n0         | I   | Differential reference clock input for the SerDes, negative phase.                                                                                                                        | See Clocking. |
| refclk_p0         | I   | Differential reference clock input for the SerDes, positive phase.                                                                                                                        | See Clocking. |
| rx_serdes_data_n0 | Ι   | Serial data from the line; negative phase of the differential signal                                                                                                                      | See Clocking. |
| rx_serdes_data_p0 | Ι   | Serial data from the line; positive phase of the differential signal                                                                                                                      | See Clocking. |
| tx_serdes_data_n0 | 0   | Serial data to the line; negative phase of the differential signal.                                                                                                                       | See Clocking. |
| tx_serdes_data_p0 | 0   | Serial data to the line; positive phase of the differential signal.                                                                                                                       | See Clocking. |
| tx_serdes_clk     | 0   | When present, same as tx_clk_out.                                                                                                                                                         | See Clocking. |

#### **AXI4-Stream Interface**

The 10G/25G High Speed Ethernet Subsystem IP core provides an option of 32-bit and 64-bit AXI4-Stream interface for systems operating at 10G and 64-bit only for systems operating at 25G. For 10G systems, 32 and 64-bit interfaces are provided. For 25G systems, only a 64-bit interface is provided.

#### **AXI4-Stream Clocks and Resets**

Table 6: AXI4-Stream Interface Clock/Reset Signals

| Name        | I/O | Description                                                                                                                                                                                                                                                             | Clock Domain  |
|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| rx_clk_out  | 0   | rx_serdes_clk. Clocks RX interface between GT and the core. When in low latency buffer bypass mode this clock also clocks the AXI4-Stream RX interface.                                                                                                                 | See Clocking. |
| tx_clk_out  | 0   | Clocks TX AXI4-Stream Interface and full TX datapath.                                                                                                                                                                                                                   | See Clocking. |
| rx_reset    | I   | Reset for the RX circuits. This signal is active-High (1 = reset) and must be held High until clk is stable. The core handles synchronizing the rx_reset input to the appropriate clock domains within the core.                                                        | Async         |
| tx_reset    | I   | Reset for the TX circuits. This signal is active-High (1 = reset) and must be held High until clk is stable. The core handles synchronizing the tx_reset input to the appropriate clock domains within the core.                                                        | Async         |
| rx_core_clk | I   | The rx_core_clk signal is used to clock the receive AXI4-Stream interface. When FIFO is not included, it must be driven by rx_clk_out. When FIFO is included, rx_core_clk can be driven by tx_clk_out, rx_clk_out, or another asynchronous clock at the same frequency. | rx_core_clk   |



#### Transmit AXI4-Stream Interface

The following table shows the AXI4-Stream transmit interface signals.

**Table 7: AXI4-Stream Transmit Interface Signals** 

| Signal                    | I/O | Description                                                                                                                      | Clock Domain |
|---------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------|--------------|
| tx_axis_tdata[63 or 31:0] | I   | AXI4-Stream data. 32-bit and 64-bit interfaces are available. Bus width depends on the selection of 64-bit or 32-bit interfaces. | tx_clk_out   |
| tx_axis_tkeep[7:0 or 3:0] | I   | AXI4-Stream Data Control. Bus width depends on selection of 64-bit or 32-bit interfaces.                                         | tx_clk_out   |
| tx_axis_tvalid            | I   | AXI4-Stream Data Valid input                                                                                                     | tx_clk_out   |
| tx_axis_tuser             | I   | AXI4-Stream User Sideband interface.  1 indicates a bad packet  indicates a good packet                                          | tx_clk_out   |
| tx_axis_tlast             | I   | AXI4-Stream signal indicating End of Ethernet Packet.                                                                            | tx_clk_out   |
| tx_parityin[7:0]          | I   | AXI4-Stream user-generated parity. Follows the same data lane mapping as tx_axis_tkeep.                                          | tx_clk_out   |
| tx_axis_tready            | 0   | AXI4-Stream acknowledge signal to indicate to start the Data transfer.                                                           | tx_clk_out   |

#### **Data Lane Mapping - TX**

For transmit data  $tx_axis_tdata$ , the port is logically divided into lane 0 to lane 3 for the 32-bit interface, or lane 0 to lane 7 for the 64-bit interface with the corresponding bit of the  $tx_axis_tkeep$  word signifying valid data on  $tx_axis_tdata$ .

Table 8: tx\_axis\_tdata Lanes - 32-bits

| Lane/ tx_axis_tkeep | tx_axis_tdata[31:0] |
|---------------------|---------------------|
| 0                   | 7:0                 |
| 1                   | 15:8                |
| 2                   | 23:16               |
| 3                   | 31:24               |

Table 9: tx\_axis\_tdata Lanes - 64-bits

| Lane/ tx_axis_tkeep | tx_axis_tdata[63:0] |
|---------------------|---------------------|
| 0                   | 7:0                 |
| 1                   | 15:8                |
| 2                   | 23:16               |
| 3                   | 31:24               |
| 4                   | 39:32               |
| 5                   | 47:40               |
| 6                   | 55:48               |



Table 9: tx axis tdata Lanes - 64-bits (cont'd)

| Lane/ tx_axis_tkeep | tx_axis_tdata[63:0] |  |
|---------------------|---------------------|--|
| 7                   | 63:56               |  |

#### **Normal Transmission**

The timings for a normal frame transfer are shown in the following figures for the 32-bit and 64-bit variants respectively. When the client wants to transmit a frame, it asserts the  $tx\_axis\_tvalid$  and places the data and control in  $tx\_axis\_tdata$  and  $tx\_axis\_tkeep$  in the same clock cycle. When this data is accepted by the core, indicated by  $tx\_axis\_tready$  being asserted, the client must provide the next cycle of data. If  $tx\_axis\_tready$  is not asserted by the core, the client must hold the current valid data value until it is. The end of packet is indicated to the core by  $tx\_axis\_tlast$  asserted for one cycle. The bits of  $tx\_axis\_tkeep$  are set appropriately to indicate the number of valid bytes in the final data transfer.  $tx\_axis\_tuser$  is also asserted to indicate a bad packet.

After  $tx_axis_tlast$  is deasserted, any data and control is deemed invalid until  $tx_axis_tvalid$  is next asserted.

tready tdata[7:0] DA DA SA SA DA SA SA DA L/T D D DA L/T D tdata[15:8] D D SA SA tdata[31:24] DA SA SA D SA X SA D D D D tlast

Figure 5: Normal Frame Transfer - 32-bit







#### **Back-to-Back Continuous Transfers**

Continuous data transfer on the transmit AXI4-Stream interface is possible, because the  $tx_axis_tvalid$  signal can remain continuously High, with packet boundaries defined solely by the  $tx_axis_tlast$  signal asserted for the end of the Ethernet packet. However, the core can deassert the  $tx_axis_tready$  acknowledgment signal to throttle the client data rate as required. See the following two figures. The client data logic can update the AXI4-Stream interface with valid data while the core has deasserted the  $tx_axis_tready$  acknowledgment signal. However, after valid is asserted and new data has been placed on the AXI4-Stream, it should remain there until the core has asserted the  $tx_axis_tready$  signal.

| Naild | Nail

Figure 7: Back-to-Back Continuous Transfer on Transmit Client Interface—32-bit





#### **Aborting a Transmission**

The aborted transfer of a packet on the client interface is called an underrun. This can happen if a FIFO in the AXI Transmit client interface empties before a frame is completed.

This is indicated to the core in one of two ways:

- An explicit error in which a frame transfer is aborted by asserting tx\_axis\_tuser High while tx\_axis\_tlast is High.
- An implicit underrun, in which a frame transfer is aborted by deasserting tx\_axis\_tvalid without asserting tx\_axis\_tlast.



When either of the two scenarios occurs during a frame transmission, the core inserts error codes into the data stream to flag the current frame as an errored frame. It remains the responsibility of the client to re-queue the aborted frame for transmission, if necessary.

#### Receive AXI4-Stream Interface

Table 10: AXI4-Stream Receive Interface Signals

| Signal                    | I/O | Description                                                                                                                     | Clock Domain |
|---------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------|--------------|
| rx_axis_tdata[63 or 31:0] | 0   | AXI4-Stream Data to upper layer. Bus width depends on 64-bit or 32-bit selection.                                               | rx_core_clk  |
| rx_axis_tkeep[7 or 3:0]   | 0   | AXI4-Stream Data Control to upper layer. Bus width depends on 64-bit or 32-bit selection.                                       | rx_core_clk  |
| rx_axis_tvalid            | 0   | AXI4-Stream Data Valid                                                                                                          | rx_core_clk  |
| rx_axis_tuser             | 0   | AXI4-Stream User Sideband interface.  1 indicates a bad packet has been received.  0 indicates a good packet has been received. | rx_core_clk  |
| rx_axis_tlast             | 0   | AXI4-Stream signal indicating an end of packet.                                                                                 | rx_core_clk  |
| rx_parityout[7:0]         | 0   | AXI4-Stream core-generated parity. Follows the same data lane mapping as rx_axis_tkeep.                                         | rx_core_clk  |

#### **Data Lane Mapping - RX**

For receive data  $rx_axis_tdata$ , the port is logically divided into lane 0 to lane 3 for the 32-bit interface or lane 0 to lane 7 for the 64-bit interface with the corresponding bit of the  $rx_axis_tkeep$  word signifying valid data on  $rx_axis_tdata$ .

Table 11: rx\_axis\_tdata Lanes - 32-bits

| Lane/rx_axis_tkeep | rx_axis_tdata[31:0] bits |
|--------------------|--------------------------|
| 0                  | 7:0                      |
| 1                  | 15:8                     |
| 2                  | 23:16                    |
| 3                  | 31:24                    |

Table 12: rx\_axis\_tkeep Lanes - 64-bits

| Lane/ rx_axis_tkeep | rx_axis_tdata Bits |
|---------------------|--------------------|
| 0                   | 7:0                |
| 1                   | 15:8               |
| 2                   | 23:16              |
| 3                   | 31:24              |
| 4                   | 39:32              |
| 5                   | 47:40              |
| 6                   | 55:48              |



Table 12: rx\_axis\_tkeep Lanes - 64-bits (cont'd)

| Lane/ rx_axis_tkeep | rx_axis_tdata Bits |
|---------------------|--------------------|
| 7                   | 63:56              |

#### **Normal Frame Reception**

The client must be prepared to accept data at any time; there is no buffering within the core to allow for latency in the receive client.

During frame reception,  $rx_axis_tvalid$  is asserted to indicate that valid frame data is being transferred to the client on  $rx_axis_tdata$ . All bytes are always valid throughout the frame, as indicated by all  $rx_axis_tkeep$  bits being set to 1, except during the final transfer of the frame when  $rx_axis_tlast$  is asserted. During this final transfer of data for a frame,  $rx_axis_tkeep$  bits indicate the final valid bytes of the frame using the mapping from above. The valid bytes of the final transfer always lead out from  $rx_axis_tdata[7:0]$  ( $rx_axis_tkeep[0]$ ) because Ethernet frame data is continuous and is received least significant byte first.

The  $rx_axis_tlast$  is asserted and  $rx_axis_tuser$  is deasserted, along with the final bytes of the transfer, only after all frame checks are completed. This is after the frame check sequence (FCS) field has been received. The core keeps the  $rx_axis_tuser$  signal deasserted to indicate that the frame was successfully received and that the frame should be analyzed by the client. This is also the end of packet signaled by  $rx_axis_tlast$  asserted for one cycle.

tvalid D tdata[7:0] DA DA SA L/T D D D DA DA SA L/T SA DA SA L/T D D DA L/T tdata[15:8] DA D D D D tdata[23:16] DA D D D D D SA SA D tdata[31:24] D D D SA SA D SA D D tkeep[3:0] 0x3 0x7 tlast

Figure 9: Normal Frame Reception - 32-bits





Figure 10: Normal Frame Reception - 64-bits

#### Frame Reception with Errors

An unsuccessful frame reception might take the form of a runt frame or a frame with an incorrect FCS. In this case, the bad frame is received and the signal  $rx_axis_tuser$  is asserted to the client at the end of the frame. It is then the responsibility of the client to drop the data already transferred for this frame.

The following conditions cause the assertion of  $rx_axis_tlast$  along with  $rx_axis_tuser$  = 1 signifying a bad\_frame:

- FCS errors occur.
- Packets are shorter than 64 bytes (undersize or fragment frames).
- Frames of length greater than the maximum transmission unit (MTU) size programmed are received.
- Any control frame that is received is not exactly the minimum frame length.
- The XGMII data stream contains error codes.





Figure 11: Frame Reception with Errors - 32-bits

Figure 12: Frame Reception with Errors - 64-bits



#### **AXI4-Stream Control and Status Ports**

Table 13: AXI4-Stream Interface - TX Path Control/Status Signals

| Name                          | I/O | Description                                                                                                                 | Clock<br>Domain |
|-------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_tx_custom_preamble_enable | I   | When asserted, this signals enables the use of tx_preamblein as a custom preamble instead of inserting a standard preamble. | tx_clk_out      |



Table 13: AXI4-Stream Interface - TX Path Control/Status Signals (cont'd)

| Name                       | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Clock<br>Domain |
|----------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| tx_preamblein [55:0]       | I   | This is the custom preamble which is a separate input port rather than being in-line with the data. It should be valid during the start of packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                           | tx_clk_out      |
| ctl_tx_ipg_value[3:0]      | I   | This signal can be optionally present. The ctl_tx_ipg_value defines the target average minimum Inter Packet Gap (IPG, in bytes) inserted between AXI4-Stream packets. Valid values are 8 to 12. The ctl_tx_ipg_value can be programmed to a value in the 0 to 7 range, but in that case, it is interpreted as 8 (the minimum valid value).                                                                                                                                                                                                                                                                   | tx_clk_out      |
| ctl_tx_enable              | I   | TX Enable. This signal is used to enable the transmission of data when it is sampled as a 1. When sampled as a 0, only idles are transmitted by the core. This input should not be set to 1 until the receiver it is sending data to (that is, the receiver in the other device) is fully synchronized and ready to receive data (that is, the other device is not sending a remote fault condition). Otherwise, loss of data can occur. If this signal is set to 0 while a packet is being transmitted, the current packet transmission is completed and then the core stops transmitting any more packets. | tx_clk_out      |
| ctl_tx_send_rfi            | I   | Transmit Remote Fault Indication (RFI) code word. If this input is sampled as a 1, the TX path only transmits Remote Fault code words. This input should be set to 1 until the RX path is fully synchronized and is ready to accept data from the link partner.                                                                                                                                                                                                                                                                                                                                              | tx_clk_out      |
| ctl_tx_send_lfi            | I   | Transmit Local Fault Indication (LFI) code word. Takes precedence over Remote Fault Indication (RFI).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | tx_clk_out      |
| ctl_tx_send_idle           | I   | Transmit Idle code words. If this input is sampled as a 1, the TX path only transmits Idle code words. This input should be set to 1 when the partner device is sending RFI code words.                                                                                                                                                                                                                                                                                                                                                                                                                      | tx_clk_out      |
| ctl_tx_fcs_ins_enable      | I   | Enable FCS insertion by the TX core. If this bit is set to 0, the core does not add FCS to packet. If this bit is set to 1, the core calculates and adds the FCS to the packet. This input cannot be changed dynamically between packets.                                                                                                                                                                                                                                                                                                                                                                    | tx_clk_out      |
| ctl_tx_ignore_fcs          | I   | Enable FCS error checking at the AXI4-Stream interface by the TX core. This input only has effect when ctl_tx_fcs_ins_enable is Low. If this input is Low and a packet with bad FCS is being transmitted, it is not binned as good. If this input is High, a packet with bad FCS is binned as good.  The error is flagged on the signals stat_tx_bad_fcs and stomped_fcs, and the packet is transmitted as it was received.  Note: Statistics are reported as if there was no FCS error.                                                                                                                     | tx_clk_out      |
| ctl_tx_parity_err_response | I   | Parity error response by the TX Core. If this bit is set to 0, the core does not take any action if any parity errors are detected. If this bit is set to 1, the core stomps the outgoing FCS (i.e., bit-wise inverse) and asserts stat_tx_bad_fcs. The stat_tx_bad_parity output is asserted when parity errors are detected regardless of the ctl_tx_parity_err_response configuration.                                                                                                                                                                                                                    | tx_clk_out      |



Table 14: AXI4-Stream Interface - RX Path Control/Status Signals

| Name                        | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Clock<br>Domain |
|-----------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| rx_preambleout [55:0]       | 0   | This is the preamble, and now a separate output instead of inline with data as was done with previous releases.                                                                                                                                                                                                                                                                                                                                                          | rx_core_clk     |
| ctl_rx_enable               | I   | RX Enable. For normal operation, this input must be set to 1. When this input is set the to 0, after the RX completes the reception of the current packet (if any), it stops receiving packets by keeping the PCS from decoding incoming data. In this mode, there are no statistics reported and the AXI4-Stream interface is idle.                                                                                                                                     | rx_clk_out      |
| ctl_rx_check_preamble       | I   | When asserted, this input causes the MAC to check the preamble of the received frame.                                                                                                                                                                                                                                                                                                                                                                                    | rx_clk_out      |
| ctl_rx_check_sfd            | I   | When asserted, this input causes the MAC to check the Start of Frame Delimiter of the received frame.                                                                                                                                                                                                                                                                                                                                                                    | rx_clk_out      |
| ctl_rx_force_resync         | I   | RX force resynchronization input. This signal is used to force the RX path to reset and re-synchronize. A value of 1 forces the reset operation. A value of 0 allows normal operation. Note that this input should normally be Low and should only be pulsed (1 cycle minimum pulse).                                                                                                                                                                                    | rx_clk_out      |
| ctl_rx_delete_fcs           | I   | Enable FCS removal by the RX core. If this bit is set to 0, the core does not remove the FCS of the incoming packet. If this bit is set to 1, the core deletes the FCS to the received packet. Note that FCS is not deleted for packets that are less than or equal to 8 bytes long. This input should only be changed while the corresponding reset input is asserted.                                                                                                  | rx_clk_out      |
| ctl_rx_ignore_fcs           | I   | Enable FCS error checking at the AXI4-Stream interface by the RX core. If this bit is set to 0, a packet received with an FCS error is sent with the rx_axis_tuser pin asserted during the last transfer (rx_axis_tuser and rx_axis_tlast sampled as 1). If this bit is set to 1, the core does not flag an FCS error at the AXI4-Stream interface.  Note: The statistics are reported as if the packet is good. The signal stat_rx_bad_fcs, however, reports the error. | rx_clk_out      |
| ctl_rx_max_packet_len[14:0] | I   | Any packet longer than this value is considered to be oversized. If a packet has a size greater than this value, the packet is truncated to this value and the rx_axis_tuser signal is asserted along with the rx_axis_tlast signal. Packets less than 4 bytes are dropped.  ctl_rx_max_packet_len[14] is reserved and must be set to 0.                                                                                                                                 | rx_clk_out      |
| ctl_rx_min_packet_len[7:0]  | I   | Any packet shorter than this value is considered to be undersized. If a packet has a size less than this value, the rx_axis_tuser signal is asserted during the rx_axis_tlast asserted cycle. Packets less than 4 bytes are dropped.  The ctl_rx_min_packet_len[7:0] value should be >=64B.                                                                                                                                                                              | rx_clk_out      |
| stat_rx_framing_err[1:0]    | 0   | The RX sync header bits framing error is a bus that indicates how many sync header errors were received. The value of the bus is only valid when stat_rx_framing_err_valid is a 1. The values can be updated at any time and are intended to be used as increment values for sync header error counters.                                                                                                                                                                 | rx_clk_out      |
| stat_rx_framing_err_valid   | 0   | Valid indicator for stat_rx_framing_err. When sampled as a 1, the value on stat_rx_framing_err is valid.                                                                                                                                                                                                                                                                                                                                                                 | rx_clk_out      |



Table 14: AXI4-Stream Interface - RX Path Control/Status Signals (cont'd)

| Name                          | I/O | Description                                                                                                                                                                                                                                                                                                                      | Clock<br>Domain |
|-------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_rx_local_fault           | 0   | This output is High when stat_rx_internal_local_fault or stat_rx_received_local_fault is asserted. This output is level sensitive.                                                                                                                                                                                               | rx_clk_out      |
| stat_rx_status                | 0   | Indicates current status of the link.                                                                                                                                                                                                                                                                                            | rx_clk_out      |
| stat_rx_block_lock            | 0   | Block lock status. A value of 1 indicates that block lock is achieved as defined in Clause 49.2.14 and MDIO register 3.32.0 This output is level sensitive.                                                                                                                                                                      | rx_clk_out      |
| stat_rx_remote_fault          | 0   | Remote fault indication status. If this bit is sampled as a 1, it indicates a remote fault condition was detected. If this bit is sampled as a 0, remote fault condition does not exist. This output is level sensitive.                                                                                                         | rx_clk_out      |
| stat_rx_bad_fcs[1:0]          | 0   | Bad FCS indicator. The value on this bus indicates packets received with a bad FCS, but not a stomped FCS during a cycle. A stomped FCS is defined as the bitwise inverse of the expected good FCS. This output is pulsed for one clock cycle to indicate an error condition. Note that pulses can occur in back-to-back cycles. | rx_clk_out      |
| stat_rx_stomped_fcs[1:0]      | 0   | Stomped FCS indicator. The value on this bus indicates the packets were received with a stomped FCS. A stomped FCS is defined as the bitwise inverse of the expected good FCS. This output is pulsed for one clock cycle to indicate the stomped condition. Note that pulses can occur in back to back cycles.                   | rx_clk_out      |
| stat_rx_truncated             | 0   | Packet truncation indicator. A value of 1 indicates that the current packet in flight is truncated due to its length exceeding ctl_rx_max_packet_len[14:0]. This output is pulsed for one clock cycle to indicate the truncated condition. Note that pulses can occur in back to back cycles.                                    | rx_clk_out      |
| stat_rx_internal_local_fault  | 0   | High when an internal local fault is generated due to<br>any one of the following: test pattern generation or<br>high bit error rate. Note that this signal remains High as<br>long as the fault condition persists.                                                                                                             | rx_clk_out      |
| stat_rx_received_local_fault  | 0   | High when enough local fault words are received from the link partner to trigger a fault condition as specified by the IEEE fault state machine. Remains High as long as the fault condition persists.                                                                                                                           | rx_clk_out      |
| stat_rx_hi_ber                | 0   | High Bit Error Rate (BER) indicator. When set to 1, the BER is too high as defined by IEEE Std. 802.3. Corresponds to MDIO register bit 3.32.1 as defined in Clause 49.2.14. This output is level sensitive.                                                                                                                     | rx_clk_out      |
| ctl_rx_custom_preamble_enable | I   | When asserted, this signal causes the side band of a packet presented on the AXI4-Stream to be the preamble as it appears on the line.                                                                                                                                                                                           | rx_clk_out      |

# **Miscellaneous Status/Control Signals**

The following table shows the miscellaneous status and control I/O signals.



**Table 15: Miscellaneous Status/Control Ports** 

| Name                             | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Clock<br>Domain |
|----------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| dclk                             | I   | Dynamic Reconfiguration Port (DRP) clock input. The required frequency is set by providing the value in the GT DRP Clock field in the Vivado® Integrated Design Environment (IDE) GT Selection and Configuration tab. This must be a free running input clock.                                                                                                                                                                                               | See Clocking.   |
| stat_rx_valid_ctrl_code          | 0   | Indicates that a PCS block with a valid control code was received.                                                                                                                                                                                                                                                                                                                                                                                           | rx_clk_out      |
| stat_rx_got_signal_os            | 0   | Signal OS indication. If this bit is sampled as a 1, it indicates that a Signal OS word was received. Note that Signal OS should not be received in an Ethernet network.                                                                                                                                                                                                                                                                                     | rx_clk_out      |
| ctl_rx_process_lfi               | I   | When this input is set to 1, the RX core expects and processes LF control codes coming in from the transceiver. When set to 0, the RX core ignores LF control codes coming in from the transceiver.                                                                                                                                                                                                                                                          | rx_clk_out      |
| ctl_rx_test_pattern              | I   | Test pattern checking enable for the RX core. A value of<br>1 enables test mode as defined in Clause 49.<br>Corresponds to MDIO register bit 3.42.2 as defined in<br>Clause 45. Checks for scrambled idle pattern.                                                                                                                                                                                                                                           | rx_clk_out      |
| ctl_tx_test_pattern              | I   | Scrambled idle test-pattern generation enable for the TX core. A value of 1 enables test mode as defined in Clause 49. Corresponds to MDIO register bit 3.42.7 as defined in Clause 45.                                                                                                                                                                                                                                                                      | tx_clk_out      |
| stat_rx_test_pattern_mismatch    | 0   | Test pattern mismatch increment. A non-zero value in any cycle indicates how many mismatches occurred for the test pattern in the RX core. This output is only active when ctl_rx_test_pattern is set to a 1. This output can be used to generate MDIO register as defined in Clause 45. This output is pulsed for one clock cycle.  **Note: This signal will be present when 802cm Preemption is enabled or when the core type is MAC +PCS/PMA 32-bit type. | rx_clk_out      |
| ctl_rx_data_pattern_select       | I   | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                                                                                             | rx_clk_out      |
| ctl_rx_test_pattern_enable       | I   | Test pattern enable for the RX core. A value of 1 enables test mode.  Corresponds to MDIO register bit 3.42.2 as defined in Clause 45. Takes second precedence.                                                                                                                                                                                                                                                                                              | rx_clk_out      |
| ctl_tx_data_pattern_select       | I   | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                                                                                             | tx_clk_out      |
| ctl_tx_test_pattern_enable       | I   | Test pattern generation enable for the TX core. A value of 1 enables test mode.  Corresponds to MDIO register bit 3.42.3 as defined in Clause 45. Takes second precedence.                                                                                                                                                                                                                                                                                   | tx_clk_out      |
| ctl_tx_test_pattern_seed_a[57:0] | I   | Corresponds to MDIO registers 3.34 through to 3.37 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                                                                                  | tx_clk_out      |
| ctl_tx_test_pattern_seed_b[57:0] | I   | Corresponds to MDIO registers 3.38 through to 3.41 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                                                                                  | tx_clk_out      |
| ctl_tx_test_pattern_select       | I   | Corresponds to MDIO register bit 3.42.1 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                                                                                             | tx_clk_out      |



## **Statistics Interface Ports**

The following tables show the Statistics interface I/O ports.

**Table 16: Statistics Interface - RX Path** 

| Name                           | I/O | Description                                                                                                                                       | Clock<br>Domain |
|--------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_rx_total_bytes[3:0]       | 0   | Increment for the total number of bytes received.                                                                                                 | rx_clk_out      |
| stat_rx_total_packets[1:0]     | 0   | Increment for the total number of packets received.                                                                                               | rx_clk_out      |
| stat_rx_total_good_bytes[13:0] | 0   | Increment for the total number of good bytes received. This value is only non-zero when a packet is received completely and contains no errors.   | rx_clk_out      |
| stat_rx_total_good_packets     | 0   | Increment for the total number of good packets received. This value is only non-zero when a packet is received completely and contains no errors. | rx_clk_out      |
| stat_rx_packet_bad_fcs         | 0   | Increment for packets between 64 and ctl_rx_max_packet_len bytes that have Frame Check Sequence (FCS) errors.                                     | rx_clk_out      |
| stat_rx_packet_64_bytes        | 0   | Increment for good and bad packets received that contain 64 bytes.                                                                                | rx_clk_out      |
| stat_rx_packet_65_127_bytes    | 0   | Increment for good and bad packets received that contain 65 to 127 bytes.                                                                         | rx_clk_out      |
| stat_rx_packet_128_255_bytes   | 0   | Increment for good and bad packets received that contain 128 to 255 bytes.                                                                        | rx_clk_out      |
| stat_rx_packet_256_511_bytes   | 0   | Increment for good and bad packets received that contain 256 to 511 bytes.                                                                        | rx_clk_out      |
| stat_rx_packet_512_1023_bytes  | 0   | Increment for good and bad packets received that contain 512 to 1,023 bytes.                                                                      | rx_clk_out      |
| stat_rx_packet_1024_1518_bytes | 0   | Increment for good and bad packets received that contain 1,024 to 1,518 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_1519_1522_bytes | 0   | Increment for good and bad packets received that contain 1519 to 1522 bytes.                                                                      | rx_clk_out      |
| stat_rx_packet_1523_1548_bytes | 0   | Increment for good and bad packets received that contain 1,523 to 1,548 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_1549_2047_bytes | 0   | Increment for good and bad packets received that contain 1,549 to 2,047 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_2048_4095_bytes | 0   | Increment for good and bad packets received that contain 2,048 to 4,095 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_4096_8191_bytes | 0   | Increment for good and bad packets received that contain 4,096 to 8,191 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_8192_9215_bytes | 0   | Increment for good and bad packets received that contain 8,192 to 9,215 bytes.                                                                    | rx_clk_out      |
| stat_rx_packet_small           | 0   | Increment for all packets that are less than 64 bytes long. Packets that are less than four bytes are dropped.                                    | rx_clk_out      |
| stat_rx_packet_large           | 0   | Increment for all packets that are more than 9,215 bytes long.                                                                                    | rx_clk_out      |
| stat_rx_unicast                | 0   | Increment for good unicast packets.                                                                                                               | rx_clk_out      |
| stat_rx_multicast              | 0   | Increment for good multicast packets.                                                                                                             | rx_clk_out      |



Table 16: Statistics Interface - RX Path (cont'd)

| Name                 | I/O | Description                                                                                                                                                                                                                                                                                                                               | Clock<br>Domain |
|----------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_rx_broadcast    | 0   | Increment for good broadcast packets.                                                                                                                                                                                                                                                                                                     | rx_clk_out      |
| stat_rx_oversize     | 0   | Increment for packets longer than ctl_rx_max_packet_len with good FCS.                                                                                                                                                                                                                                                                    | rx_clk_out      |
| stat_rx_toolong      | 0   | Increment for packets longer than ctl_rx_max_packet_len with good and bad FCS.                                                                                                                                                                                                                                                            | rx_clk_out      |
| stat_rx_undersize    | 0   | Increment for packets shorter than ctl_rx_min_packet_len with good FCS.                                                                                                                                                                                                                                                                   | rx_clk_out      |
| stat_rx_fragment     | 0   | Increment for packets shorter than ctl_rx_min_packet_len with bad FCS.                                                                                                                                                                                                                                                                    | rx_clk_out      |
| stat_rx_vlan         | 0   | Increment for good 802.1Q tagged VLAN packets.                                                                                                                                                                                                                                                                                            | rx_clk_out      |
| stat_rx_inrangeerr   | 0   | Increment for packets with Length field error but with good FCS.                                                                                                                                                                                                                                                                          | rx_clk_out      |
| stat_rx_jabber       | 0   | Increment for packets longer than ctl_rx_max_packet_len with bad FCS.                                                                                                                                                                                                                                                                     | rx_clk_out      |
| stat_rx_pause        | 0   | Increment for 802.3x MAC Pause packet with good FCS                                                                                                                                                                                                                                                                                       | rx_clk_out      |
| stat_rx_user_pause   | 0   | Increment for priority based pause packets with good FCS.                                                                                                                                                                                                                                                                                 | rx_clk_out      |
| stat_rx_bad_code     | 0   | Increment for 64B/66B code violations. This signal indicates that the RX PCS receive state machine is in the RX_E state as specified by IEEE Std. 802.3. This output can be used to generate MDIO register as defined in Clause 45.                                                                                                       | rx_clk_out      |
| stat_rx_bad_sfd      | 0   | Increment bad SFD. This signal indicates if the Ethernet packet received was preceded by a valid SFD. A value of 1 indicates that an invalid SFD was received.  **Note:** When an invalid SFD is detected, the stat_rx_bad_sfd signal is asserted regardless of the setting of the ctl_rx_check_sfd signal.                               | rx_clk_out      |
| stat_rx_bad_preamble | 0   | Increment bad preamble. This signal indicates if the Ethernet packet received was preceded by a valid preamble. A value of 1 indicates that an invalid preamble was received.  **Note:** When an invalid preamble is detected, the stat_rx_bad_preamble signal is asserted regardless of the setting of the ctl_rx_check_preamble signal. | rx_clk_out      |

**Table 17: Statistics Interface - TX Path** 

| Name                     | I/O | Description                                                                                                                                                  | Clock<br>Domain |
|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_tx_total_bytes[3:0] | 0   | Increment for the total number of bytes transmitted.  The signal width for stat_tx_total_bytes will be [2:0] when the 32-bit AXI4-Stream option is selected. | tx_clk_out      |



Table 17: Statistics Interface - TX Path (cont'd)

| Name                           | I/O | Description                                                                                                                                           | Clock<br>Domain |
|--------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_tx_total_packets          | 0   | Increment for the total number of packets transmitted.                                                                                                | tx_clk_out      |
| stat_tx_total_good_bytes[13:0] | 0   | Increment for the total number of good bytes transmitted. This value is only non-zero when a packet is transmitted completely and contains no errors. | tx_clk_out      |
| stat_tx_total_good_packets     | 0   | Increment for the total number of good packets transmitted.                                                                                           | tx_clk_out      |
| stat_tx_bad_fcs                | 0   | Increment for packets greater than 64 bytes that have FCS errors.                                                                                     | tx_clk_out      |
| stat_tx_packet_64_bytes        | 0   | Increment for good and bad packets transmitted that contain 64 bytes.                                                                                 | tx_clk_out      |
| stat_tx_packet_65_127_bytes    | 0   | Increment for good and bad packets transmitted that contain 65 to 127 bytes.                                                                          | tx_clk_out      |
| stat_tx_packet_128_255_bytes   | 0   | Increment for good and bad packets transmitted that contain 128 to 255 bytes.                                                                         | tx_clk_out      |
| stat_tx_packet_256_511_bytes   | 0   | Increment for good and bad packets transmitted that contain 256 to 511 bytes.                                                                         | tx_clk_out      |
| stat_tx_packet_512_1023_bytes  | 0   | Increment for good and bad packets transmitted that contain 512 to 1,023 bytes.                                                                       | tx_clk_out      |
| stat_tx_packet_1024_1518_bytes | 0   | Increment for good and bad packets transmitted that contain 1,024 to 1,518 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_1519_1522_bytes | 0   | Increment for good and bad packets transmitted that contain 1,519 to 1,522 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_1523_1548_bytes | 0   | Increment for good and bad packets transmitted that contain 1,523 to 1,548 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_1549_2047_bytes | 0   | Increment for good and bad packets transmitted that contain 1,549 to 2,047 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_2048_4095_bytes | 0   | Increment for good and bad packets transmitted that contain 2,048 to 4,095 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_4096_8191_bytes | 0   | Increment for good and bad packets transmitted that contain 4,096 to 8,191 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_8192_9215_bytes | 0   | Increment for good and bad packets transmitted that contain 8,192 to 9,215 bytes.                                                                     | tx_clk_out      |
| stat_tx_packet_small           | 0   | Increment for all packets that are less than 64 bytes long.                                                                                           | tx_clk_out      |
| stat_tx_packet_large           | 0   | Increment for all packets that are more than 9,215 bytes long.                                                                                        | tx_clk_out      |
| stat_tx_unicast                | 0   | Increment for good unicast packets.                                                                                                                   | tx_clk_out      |
| stat_tx_multicast              | 0   | Increment for good multicast packets.                                                                                                                 | tx_clk_out      |
| stat_tx_broadcast              | 0   | Increment for good broadcast packets.                                                                                                                 | tx_clk_out      |
| stat_tx_vlan                   | 0   | Increment for good 802.1Q tagged VLAN packets.                                                                                                        | tx_clk_out      |
| stat_tx_pause                  | 0   | Increment for 802.3x MAC Pause packet with good FCS.                                                                                                  | tx_clk_out      |
| stat_tx_user_pause             | 0   | Increment for priority based pause packets with good FCS.                                                                                             | tx_clk_out      |



Table 17: Statistics Interface - TX Path (cont'd)

| Name                | I/O | Description                                                                                                                                   | Clock<br>Domain |
|---------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_tx_frame_error | 0   | Increment for packets with tx_axis_tuser set to indicate an End of Packet (EOP) abort or frames aborted by de-asserting tvalid without tlast. | tx_clk_out      |
| stat_tx_bad_parity  | 0   | Increment on any clock cycle where the user-<br>generated parity is calculated as incorrect by the<br>TX parity checking logic.               | tx_clk_out      |

## **Pause Interface**

The following tables show the Pause interface I/O ports.

**Table 18: Pause Interface - Control Ports** 

| Name                     | I/O | Description                                                                                                                                                                                                       | Clock<br>Domain |
|--------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_rx_pause_enable[8:0] | I   | RX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority. Note that this signal only affects the RX user interface, not the pause processing logic. | rx_clk_out      |
| ctl_tx_pause_enable[8:0] | I   | TX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority. This signal gates transmission of pause packets.                                          | tx_clk_out      |

Table 19: Pause Interface - RX Path

| Name                        | I/O | Description                                                                   | Clock<br>Domain |
|-----------------------------|-----|-------------------------------------------------------------------------------|-----------------|
| ctl_rx_enable_gcp           | I   | A value of 1 enables global control packet processing.                        | rx_clk_out      |
| ctl_rx_check_mcast_gcp      | I   | A value of 1 enables global control multicast destination address processing. | rx_clk_out      |
| ctl_rx_check_ucast_gcp      | I   | A value of 1 enables global control unicast destination address processing.   | rx_clk_out      |
| ctl_rx_pause_da_ucast[47:0] | I   | Unicast destination address for pause processing.                             | rx_clk_out      |
| ctl_rx_check_sa_gcp         | I   | A value of 1 enables global control source address processing.                | rx_clk_out      |
| ctl_rx_pause_sa[47:0]       | I   | Source address for pause processing.                                          | rx_clk_out      |
| ctl_rx_check_etype_gcp      | I   | A value of 1 enables global control ethertype processing.                     | rx_clk_out      |
| ctl_rx_check_opcode_gcp     | I   | A value of 1 enables global control opcode processing.                        | rx_clk_out      |
| ctl_rx_opcode_min_gcp[15:0] | I   | Minimum global control opcode value.                                          | rx_clk_out      |
| ctl_rx_opcode_max_gcp[15:0] | I   | Maximum global control opcode value.                                          | rx_clk_out      |
| ctl_rx_etype_gcp[15:0]      | I   | Ethertype field for global control processing.                                | rx_clk_out      |



Table 19: Pause Interface - RX Path (cont'd)

| Name                        | I/O | Description                                                                     | Clock<br>Domain |
|-----------------------------|-----|---------------------------------------------------------------------------------|-----------------|
| ctl_rx_enable_pcp           | I   | A value of 1 enables priority control packet processing.                        | rx_clk_out      |
| ctl_rx_check_mcast_pcp      | I   | A value of 1 enables priority control multicast destination address processing. | rx_clk_out      |
| ctl_rx_check_ucast_pcp      | I   | A value of 1 enables priority control unicast destination address processing.   | rx_clk_out      |
| ctl_rx_pause_da_mcast[47:0] | I   | Multicast destination address for pause processing.                             | rx_clk_out      |
| ctl_rx_check_sa_pcp         | I   | A value of 1 enables priority control source address processing.                | rx_clk_out      |
| ctl_rx_check_etype_pcp      | I   | A value of 1 enables priority control ethertype processing.                     | rx_clk_out      |
| ctl_rx_etype_pcp[15:0]      | I   | Ethertype field for priority control processing.                                | rx_clk_out      |
| ctl_rx_check_opcode_pcp     | I   | A value of 1 enables priority control opcode processing.                        | rx_clk_out      |
| ctl_rx_opcode_min_pcp[15:0] | I   | Minimum priority control opcode value.                                          | rx_clk_out      |
| ctl_rx_opcode_max_pcp[15:0] | I   | Maximum priority control opcode value.                                          | rx_clk_out      |
| ctl_rx_enable_gpp           | I   | A value of 1 enables global pause packet processing.                            | rx_clk_out      |
| ctl_rx_check_mcast_gpp      | I   | A value of 1 enables global pause multicast destination address processing.     | rx_clk_out      |
| ctl_rx_check_ucast_gpp      | I   | A value of 1 enables global pause unicast destination address processing.       | rx_clk_out      |
| ctl_rx_check_sa_gpp         | I   | A value of 1 enables global pause source address processing.                    | rx_clk_out      |
| ctl_rx_check_etype_gpp      | I   | A value of 1 enables global pause ethertype processing.                         | rx_clk_out      |
| ctl_rx_etype_gpp[15:0]      | I   | Ethertype field for global pause processing.                                    | rx_clk_out      |
| ctl_rx_check_opcode_gpp     | I   | A value of 1 enables global pause opcode processing.                            | rx_clk_out      |
| ctl_rx_opcode_gpp[15:0]     | I   | Global pause opcode value.                                                      | rx_clk_out      |
| ctl_rx_enable_ppp           | I   | A value of 1 enables priority pause packet processing.                          | rx_clk_out      |
| ctl_rx_check_mcast_ppp      | I   | A value of 1 enables priority pause multicast destination address processing.   | rx_clk_out      |
| ctl_rx_check_ucast_ppp      | I   | A value of 1 enables priority pause unicast destination address processing.     | rx_clk_out      |
| ctl_rx_check_sa_ppp         | I   | A value of 1 enables priority pause source address processing.                  | rx_clk_out      |
| ctl_rx_check_etype_ppp      | I   | A value of 1 enables priority pause ethertype processing.                       | rx_clk_out      |
| ctl_rx_etype_ppp[15:0]      | I   | Ethertype field for priority pause processing.                                  | rx_clk_out      |
| ctl_rx_check_opcode_ppp     | I   | A value of 1 enables priority pause opcode processing.                          | rx_clk_out      |
| ctl_rx_opcode_ppp[15:0]     | I   | Priority pause opcode value.                                                    | rx_clk_out      |



Table 19: Pause Interface - RX Path (cont'd)

| Name                            | I/O | Description                                                                                                                                                                                                                    | Clock<br>Domain |
|---------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_rx_pause_req[8:0]          | 0   | Pause request signal. When the RX receives a valid pause frame, it sets the corresponding bit of this bus to a 1 and keep it at 1 until the pause packet has been processed.                                                   | rx_clk_out      |
| ctl_rx_pause_ack[8:0]           | I   | Pause acknowledge signal. This bus is used to acknowledge the receipt of the pause frame from the user logic.                                                                                                                  | rx_clk_out      |
| ctl_rx_check_ack                | I   | Wait for acknowledge. If this input is set to 1, the core uses the ctl_rx_pause_ack[8:0] bus for pause processing. If this input is set to 0, ctl_rx_pause_ack[8:0] is not used.                                               | rx_clk_out      |
| ctl_rx_forward_control          | I   | A value of 1 indicates that the core forwards control packets. A value of 0 causes core to drop control packets.                                                                                                               | rx_clk_out      |
| stat_rx_pause_valid[8:0]        | 0   | Indicates that a pause packet was received and the associated quanta on the stat_rx_pause_quanta[8:0][15:0] bus is valid and must be used for pause processing. If an 802.3x MAC Pause packet is received, bit[8] is set to 1. | rx_clk_out      |
| stat_rx_pause_quanta[8:0][15:0] | 0   | These nine buses indicate the quanta received for each of the eight priorities in priority based pause operation and global pause operation. If an 802.3x MAC Pause packet is received, the quanta is placed in value [8].     | rx_clk_out      |

Table 20: Pause Interface - TX Path

| Name                                   | I/O | Description                                                                                                                                                                                                                                                                                              | Clock Domain |
|----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| ctl_tx_pause_req[8:0]                  | I   | If a bit of this bus is set to 1, the core transmits a pause packet using the associated quanta value on the ctl_tx_pause_quanta[8:0][15:0] bus. If bit[8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted.                            | tx_clk_out   |
| ctl_tx_pause_quanta[8:0][15:0]         | I   | These nine buses indicate the quanta to be transmitted for each of the eight priorities in priority based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.               | tx_clk_out   |
| ctl_tx_pause_refresh_timer [8:0][15:0] | I   | These nine buses set the retransmission time of pause packets for each of the eight priorities in priority based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. | tx_clk_out   |
| ctl_tx_da_gpp[47:0]                    | I   | Destination address for transmitting global pause packets.                                                                                                                                                                                                                                               | tx_clk_out   |
| ctl_tx_sa_gpp[47:0]                    | I   | Source address for transmitting global pause packets.                                                                                                                                                                                                                                                    | tx_clk_out   |
| ctl_tx_ethertype_gpp[15:0]             | I   | Ethertype for transmitting global pause packets.                                                                                                                                                                                                                                                         | tx_clk_out   |



Table 20: Pause Interface - TX Path (cont'd)

| Name                       | I/O | Description                                                                                                                                                                                                                                                                                    | Clock Domain |
|----------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| ctl_tx_opcode_gpp[15:0]    | I   | Opcode for transmitting global pause packets.                                                                                                                                                                                                                                                  | tx_clk_out   |
| ctl_tx_da_ppp[47:0]        | I   | Destination address for transmitting priority pause packets.                                                                                                                                                                                                                                   | tx_clk_out   |
| ctl_tx_sa_ppp[47:0]        | I   | Source address for transmitting priority pause packets.                                                                                                                                                                                                                                        | tx_clk_out   |
| ctl_tx_ethertype_ppp[15:0] | I   | Ethertype for transmitting priority pause packets.                                                                                                                                                                                                                                             | tx_clk_out   |
| ctl_tx_opcode_ppp[15:0]    | I   | Opcode for transmitting priority pause packets.                                                                                                                                                                                                                                                | tx_clk_out   |
| ctl_tx_resend_pause        | I   | Retransmit pending pause packets. When this input is sampled as 1, all pending pause packets are retransmitted as soon as possible (that is, after the current packet in flight is completed) and the retransmit counters are reset. This input should be pulsed to 1 for one cycle at a time. | tx_clk_out   |
| stat_tx_pause_valid[8:0]   | 0   | If a bit of this bus is set to 1, the core has transmitted a pause packet. If bit[8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted.                                                                                        | tx_clk_out   |

## **Auto-Negotiation Ports**

The following table shows the additional ports used for Auto-Negotiation. These signals are found at the \*wrapper.v hierarchy file.

**Table 21: Additional Ports for Auto-Negotiation** 

| Port Name              | I/O | Description                                                                                                                                                                                                                                                                              | Clock<br>Domain       |
|------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| an_clk                 | I   | Input Clock for the auto-negotiation circuit. The required frequency is indicated in the readme file for the release. It should be a free running clock. This clock is set by Vivado Integrated Design Environment (IDE) to same frequency as the GT drp CLK setting entered in the GUI. | Refer to<br>Clocking. |
| an_reset               | I   | Asynchronous active-High reset.                                                                                                                                                                                                                                                          | Async                 |
| ctl_autoneg_enable     | I   | Enable signal for auto-negotiation.                                                                                                                                                                                                                                                      | an_clk                |
| ctl_autoneg_bypass     | I   | Input to disable auto-negotiation and bypass the auto-<br>negotiation function. If this input is asserted, then auto-<br>negotiation is turned off, but the PCS is connected to<br>the outputs to allow operation.                                                                       | an_clk                |
| ctl_an_nonce_seed[7:0] | I   | 8-bit seed to initialize the nonce field Polynomial generator.  This input should always be set to a unique non-zero value for every instance of the auto-negotiator.                                                                                                                    | an_clk                |
| ctl_an_pseudo_sel      | I   | Selects the polynomial generator for the bit 49 random BitGenerator. If this input is 1, then the polynomial is x7+x6+1. If this input is zero, then the polynomial is x7+x3+1.                                                                                                          | an_clk                |



*Table 21:* Additional Ports for Auto-Negotiation (cont'd)

| Port Name                          | I/O       | Description                                                                                                                                                                                                                                           | Clock<br>Domain |  |
|------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|
| ctl_restart_negotiation            | I         | This input is used to trigger a restart of the autonegotiation, regardless of what state the circuit is currently in.                                                                                                                                 | an_clk          |  |
| ctl_an_local_fault                 | I         | This input signal is used to set the remote_fault bit of the transmit link codeword.                                                                                                                                                                  | an_clk          |  |
|                                    | Signals L | Ised for Pause Ability Advertising                                                                                                                                                                                                                    |                 |  |
| ctl_an_pause                       | I         | This input signal is used to set the PAUSE bit, (C0), of the transmit link codeword. This signal might not be present if the core does not support pause.                                                                                             | an_clk          |  |
| ctl_an_asmdir                      | I         | This input signal is used to set the ASMDIR bit, (C1), of the transmit link codeword. This signal might not be present if the core does not support pause.                                                                                            | an_clk          |  |
|                                    | •         | Ability Signal Inputs                                                                                                                                                                                                                                 |                 |  |
| ctl_an_ability_1000base_kx         | I         | These inputs identify the Ethernet protocol abilities that                                                                                                                                                                                            | an_clk          |  |
| ctl_an_ability_100gbase_cr10       | I         | is advertised in the transmit link codeword to the link partner. A value of 1 indicates that the interface                                                                                                                                            | an_clk          |  |
| ctl_an_ability_100gbase_cr4        | I         | advertises that it supports the protocol.                                                                                                                                                                                                             | an_clk          |  |
| ctl_an_ability_100gbase_kp4        | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_100gbase_kr4        | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_10gbase_kr          | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_10gbase_kx4         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_25gbase_cr          | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_25gbase_cr1         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_25gbase_kr          | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_25gbase_kr1         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_40gbase_cr4         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_40gbase_kr4         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_50gbase_cr2         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_50gbase_kr2         | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_ability_2_5gbase_kx         | I         | Training Pattern Selection:                                                                                                                                                                                                                           | an_clk          |  |
| ctl_an_ability_5gbase_kr           | I         | 0=>25BASE-CR/KR, 50GBASE-CR2/KR2,100GBASE-CR10/<br>KR10                                                                                                                                                                                               | an_clk          |  |
| ctl_an_ability_50gbase_krcr        | I         | 1=>100GBASE-CR4/KR4                                                                                                                                                                                                                                   | an_clk          |  |
| ctl_an_ability_100gbase_kr2cr2     | I         | 2=>50GBASE-CR/KR, 100GBASE-CR2/KR2, 200GBASE-                                                                                                                                                                                                         | an_clk          |  |
| stat_an_lp_ability_200gbase_kr4cr4 | I         | CR4/KR4                                                                                                                                                                                                                                               | an_clk          |  |
| ctl_lt_polynomial_select [1:0]     | I         |                                                                                                                                                                                                                                                       | an_clk          |  |
| ctl_an_fec_request                 | I         | Used to control the clause 74 FEC request bit in the transmit link codeword. This signal might not be present if the IP core does not support clause 74 FEC.                                                                                          | an_clk          |  |
| ctl_an_fec_ability_override        | I         | Used to control the clause 74 FEC ability bit in the transmit link codeword. If this input is set, then the FEC ability bit in the transmit link codeword is cleared. This signal might not be present if the IP core does not support clause 74 FEC. | an_clk          |  |
| ctl_an_cl91_fec_ability            | I         | This bit is used to indicate clause 91 FEC ability.                                                                                                                                                                                                   | an_clk          |  |



*Table 21:* Additional Ports for Auto-Negotiation (cont'd)

| Port Name                              | I/O | Description                                                                                                                            | Clock<br>Domain |
|----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_an_cl91_fec_request                | I   | This bit is used to request clause 91 FEC.                                                                                             | an_clk          |
| stat_an_link_cntl_1000base_kx[1:0]     | 0   | Link Control outputs from the auto-negotiation                                                                                         | an_clk          |
| stat_an_link_cntl_100gbase_cr10[1:0]   | 0   | controller for the various Ethernet protocols. Settings are as follows:                                                                | an_clk          |
| stat_an_link_cntl_100gbase_cr4[1:0]    | 0   | 00: DISABLE; PCS is disconnected                                                                                                       | an_clk          |
| stat_an_link_cntl_100gbase_kp4[1:0]    | 0   | 01: SCAN_FOR_CARRIER; RX is connected to PCS                                                                                           | an_clk          |
| stat_an_link_cntl_100gbase_kr4[1:0]    | 0   | 11: ENABLE; PCS is connected for mission mode operation                                                                                | an_clk          |
| stat_an_link_cntl_10gbase_kr[1:0]      | 0   | 10: not used                                                                                                                           | an_clk          |
| stat_an_link_cntl_10gbase_kx4[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_25gbase_cr[1:0]      | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_25gbase_cr1[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_25gbase_kr[1:0]      | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_25gbase_kr1[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_40gbase_cr4[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_40gbase_kr4[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_50gbase_cr2[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_50gbase_kr2[1:0]     | 0   |                                                                                                                                        | an_clk          |
| stat_an_link_cntl_2_5gbase_kx[1:0]     | 0   | Link Control outputs from the auto-negotiation                                                                                         |                 |
| stat_an_link_cntl_5gbase_kr[1:0]       | 0   | controller for the various Ethernet protocols. Settings are as follows:                                                                |                 |
| stat_an_link_cntl_50gbase_krcr[1:0]    | 0   | 00: DISABLE; PCS is disconnected                                                                                                       |                 |
| stat_an_link_cntl_100gbase_kr2cr2[1:0] | 0   | 01: SCAN_FOR_CARRIER; RX is connected to PCS                                                                                           |                 |
| stat_an_link_cntl_200gbase_kr4cr4[1:0] | 0   | 11: ENABLE; PCS is connected for mission mode operation 10: not used                                                                   |                 |
| stat_an_fec_enable                     | 0   | Used to enable the use of clause 74 FEC on the link.                                                                                   | an_clk          |
| stat_an_rs_fec_enable                  | 0   | Used to enable the use of clause 91 FEC on the link.                                                                                   | an_clk          |
| stat_an_tx_pause_enable                | 0   | Used to enable station-to-station (global) pause packet generation in the transmit path to control data flow in the receive path.      | an_clk          |
| stat_an_rx_pause_enable                | 0   | Used to enable station-to-station (global) pause packet interpretation in the receive path, to control data flow from the transmitter. | an_clk          |
| stat_an_autoneg_complete               | 0   | Indicates the auto-negotiation is complete and RX link status from the PCS has been received.                                          | an_clk          |
| stat_an_parallel_detection_fault       | 0   | Indicated a parallel detection fault during autonegotiation.                                                                           | an_clk          |



*Table 21:* Additional Ports for Auto-Negotiation (cont'd)

| Port Name                          | I/O | Description                                                                                                                                                                                                                           | Clock<br>Domain |
|------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_an_lp_ability_1000base_kx     | 0   | These signals indicate the advertised protocol from the                                                                                                                                                                               | an_clk          |
| stat_an_lp_ability_100gbase_cr10   | 0   | link partner. They all become valid when the output signal stat_AN_lp_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner.                                             | an_clk          |
| stat_an_lp_ability_100gbase_cr4    | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_100gbase_kp4    | 0   | the link partiter.                                                                                                                                                                                                                    | an_clk          |
| stat_an_lp_ability_100gbase_kr4    | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_10gbase_kr      | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_10gbase_kx4     | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_25gbase_cr      | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_25gbase_kr      | 0   | ]                                                                                                                                                                                                                                     | an_clk          |
| stat_an_lp_ability_40gbase_cr4     | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_40gbase_kr4     | 0   |                                                                                                                                                                                                                                       | an_clk          |
| stat_an_lp_ability_2_5gbase_kx     | 0   | These signals indicate the advertised protocol from the                                                                                                                                                                               | an_clk          |
| stat_an_lp_ability_5gbase_kr       | 0   | link partner. They all become valid when the output signal stat_AN_lp_Ability_Valid is asserted. A value of 1                                                                                                                         | an_clk          |
| stat_an_lp_ability_50gbase_krcr    | 0   | indicates that the protocol is advertised as supported by the link partner.                                                                                                                                                           | an_clk          |
| stat_an_lp_ability_100gbase_kr2cr2 | 0   | the link partner.                                                                                                                                                                                                                     | an_clk          |
| stat_an_lp_ability_200gbase_kr4cr4 | 0   | ]                                                                                                                                                                                                                                     | an_clk          |
| stat_an_lp_ability_25gbase_cr1     | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_AN_lp_Extended_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. | an_clk          |
| stat_an_lp_ability_25gbase_kr1     | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_AN_lp_Extended_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. | an_clk          |
| stat_an_lp_ability_50gbase_cr2     | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_AN_lp_Extended_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. | an_clk          |
| stat_an_lp_ability_50gbase_kr2     | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_AN_lp_Extended_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. | an_clk          |
| stat_an_lp_pause                   | 0   | This signal indicates the advertised value of the PAUSE bit, (C0), in the receive link codeword from the link partner. It becomes valid when the output signal stat_AN_lp_Ability_Valid is asserted.                                  | an_clk          |
| stat_an_lp_asm_dir                 | 0   | This signal indicates the advertised value of the ASMDIR bit, (C1), in the receive link codeword from the link partner. It becomes valid when the output signal stat_AN_lp_Ability_Valid is asserted.                                 | an_clk          |
| stat_an_lp_fec_ability             | 0   | This signal indicates the advertised value of the FEC ability bit in the receive link codeword from the link partner. It becomes valid when the output signal stat_AN_lp_Ability_Valid is asserted.                                   | an_clk          |



*Table 21:* Additional Ports for Auto-Negotiation (cont'd)

| Port Name                            | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Clock<br>Domain |  |
|--------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|
| stat_an_lp_fec_request               | 0   | This signal indicates the advertised value of the FEC Request bit in the receive link codeword from the link partner. It becomes valid when the output signal stat_AN_lp_Ability_Valid is asserted.                                                                                                                                                                                                                                                                                                  | an_clk          |  |
| stat_an_lp_autoneg_able              | 0   | This output signal indicates that the link partner is able to perform auto-negotiation. It becomes valid when the output signal stat_AN_lp_Ability_Valid is asserted.                                                                                                                                                                                                                                                                                                                                | an_clk          |  |
| stat_an_lp_ability_valid             | 0   | This signal indicates when all of the link partner advertisements become valid.                                                                                                                                                                                                                                                                                                                                                                                                                      | an_clk          |  |
| an_loc_np_data[47:0]                 | I   | Local Next Page codeword. This is the 48-bit codeword used if the loc_np input is set. In this data field, the bits NP, ACK, and T, bit positions 15, 14, 12, and 11, are not transferred as part of the next page codeword. These bits are generated in the Auto-Negotiation Intellectual Property Core (ANIPC). However, the Message Protocol bit, MP, in bit position 13, is transferred.                                                                                                         | an_clk          |  |
| an_lp_np_data[47:0]                  | 0   | Link Partner Next Page Data. This 48-bit word is driven by the ANIPC with the 48-bit next page codeword from the remote link partner.                                                                                                                                                                                                                                                                                                                                                                | an_clk          |  |
| ctl_an_loc_np                        | I   | Local Next Page indicator. If this bit is 1, the ANIPC transfers the next page word at input loc_np_data to the remote link partner. If this bit is 0, the ANIPC does not initiate the next page protocol. If the link partner has next pages to send, and the loc_np bit is clear, the ANIPC transfers null message pages.                                                                                                                                                                          | an_clk          |  |
| ctl_an_lp_np_ack                     | I   | Link Partner Next Page Acknowledge. This is used to signal the ANIPC that the next page data from the remote link partner at output pin lp_np_data has been read by the local host. When this signal goes High, the ANIPC acknowledges reception of the next page codeword to the remote link partner and initiate transfer of the next codeword. During this time, the ANIPC will remove the lp_np signal until the new next page information is available.                                         | an_clk          |  |
| stat_an_loc_np_ack                   | 0   | This signal is used to indicate to the local host that the local next page data, presented at input pin loc_np_data, has been taken. This signal pulses High for 1 clock period when the ANIPC samples the next page data on input pin loc_np_data. When the local host detects this signal High, it must replace the 48-bit next page codeword at input pin loc_np_data with the next 48-bit codeword to be sent. If the local host has no more next pages to send, it must clear the loc_np input. | an_clk          |  |
| stat_an_lp_np                        | 0   | Link Partner Next Page. This signal is used to indicate that there is a valid 48-bit next page codeword from the remote link partner at output pin lp_np_data. This signal is driven Low when the lp_np_ack input signal is driven High, indicating that the local host has read the next page data. It remains Low until the next codeword becomes available on the lp_np_data output pin, the lp_np output is driven High again.                                                                   | an_clk          |  |
| stat_an_lp_ability_extended_fec[1:0] | 0   | This output indicates the extended FEC abilities as defined in Schedule 3.                                                                                                                                                                                                                                                                                                                                                                                                                           | an_clk          |  |
| stat_an_lp_extended_ability_valid    | 0   | When this bit is 1, it indicates that the detected extended abilities are valid.                                                                                                                                                                                                                                                                                                                                                                                                                     | an_clk          |  |



*Table 21:* Additional Ports for Auto-Negotiation (cont'd)

| Port Name                   | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Clock<br>Domain |
|-----------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_an_lp_rf               | 0   | This bit indicates link partner remote fault.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | an_clk          |
| stat_an_start_tx_disable    | 0   | When ctl_autoneg_enable is High and ctl_autoneg_bypass is Low, this signal, stat_an_start_tx_disable, cycles High for 1 clock cycle at the very start of the TX_DISABLE phase of autonegotiation. That is, when auto-negotiation enters state TX_DISABLE, this output will cycle High for 1 clock period. It effectively signals the start of autonegotiation.                                                                                                                                                                                                            | an_clk          |
| stat_an_start_an_good_check | 0   | When ctl_autoneg_enable is High and ctl_autoneg_bypass is Low, this signal, stat_an_start_an_good_check, cycles High for 1 clock cycle at the very start of the AN_GOOD_CHECK phase of auto-negotiation. That is, when auto-negotiation enters the state AN_GOOD_CHECK, this output will cycle High for 1 clock period. It effectively signals the start of link training. However, if link training is not enabled, that is, if the input ctl_lt_training_enable is Low, the stat_an_start_an_good_check output effectively signals the start of mission-mode operation. | an_clk          |

# **Link Training Ports**

The following table shows the Link Training ports.

**Table 22: Link Training Ports** 

| Port Name               | I/O | Description                                                                                                                                                                                                                | Clock<br>Domain |
|-------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_lt_training_enable  | I   | Enables link training. When link training is disabled, all PCS lanes function in mission mode.                                                                                                                             | tx_serdes_clk   |
| ctl_lt_restart_training | I   | This signal triggers a restart of link training regardless of the current state.                                                                                                                                           | tx_serdes_clk   |
| ctl_lt_rx_trained       | I   | This signal is asserted to indicate that the receiver finite impulse response (FIR) filter coefficients have all been set, and that the receiver portion of training is complete.                                          | tx_serdes_clk   |
| stat_lt_signal_detect   | 0   | This signal indicates when the respective link training state machine has entered the SEND_DATA state, in which normal PCS operation can resume.                                                                           | tx_serdes_clk   |
| stat_lt_training        | 0   | This signal indicates when the respective link training state machine is performing link training.                                                                                                                         | tx_serdes_clk   |
| stat_lt_training_fail   | 0   | This signal is asserted during link training if the corresponding link training state machine detects a time-out during the training period.                                                                               | tx_serdes_clk   |
| stat_lt_frame_lock      | 0   | When link training has begun, these signals are asserted, for each physical medium dependent (PMD) lane, when the corresponding link training receiver is able to establish a frame synchronization with the link partner. | rx_serdes_clk   |



Table 22: Link Training Ports (cont'd)

| Port Name                     | I/O | Description                                                                                                                                                       | Clock<br>Domain |  |
|-------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--|
| stat_lt_preset_from_rx        | 0   | This signal reflects the value of the preset control bit received in the control block from the link partner.                                                     | rx_serdes_clk   |  |
| stat_lt_initialize_from_rx    | 0   | This signal reflects the value of the initialize control bit received in the control block from the link partner.                                                 | rx_serdes_clk   |  |
| stat_lt_k_p1_from_rx0[1:0]    | 0   | This 2-bit field indicates the update control bits for the k +1 coefficient, as received from the link partner in the control block.                              | rx_serdes_clk   |  |
| stat_lt_k0_from_rx0[1:0]      | 0   | This 2-bit field indicates the update control bits for the k0 coefficient, as received from the link partner in the control block.                                | rx_serdes_clk   |  |
| stat_lt_k_m1_from_rx0[1:0]    | 0   | This 2-bit field indicates the update control bits for the k-1 coefficient, as received from the link partner in the control block.                               | rx_serdes_clk   |  |
| stat_lt_stat_p1_from_rx0[1:0] | 0   | This 2-bit field indicates the update status bits for the k +1 coefficient, as received from the link partner in the status block.                                | rx_serdes_clk   |  |
| stat_lt_stat0_from_rx0[1:0]   | 0   | This 2-bit field indicates the update status bits for the k0 coefficient, as received from the link partner in the status block.                                  | rx_serdes_clk   |  |
| stat_lt_stat_m1_from_rx0[1:0] | 0   | This 2-bit field indicates the update status bits for the k-1 coefficient, as received from the link partner in the status block.                                 | rx_serdes_clk   |  |
| ctl_lt_pseudo_seed0[10:0]     | I   | This 11-bit signal seeds the training pattern generator.                                                                                                          | tx_serdes_clk   |  |
| ctl_lt_preset_to_tx           | I   | This signal is used to set the value of the preset bit that is transmitted to the link partner in the control block of the training frame.                        | tx_serdes_clk   |  |
| ctl_lt_initialize_to_tx       | I   | This signal is used to set the value of the initialize bit that is transmitted to the link partner in the control block of the training frame.                    | tx_serdes_clk   |  |
| ctl_lt_k_p1_to_tx0[1:0]       | I   | This 2-bit field is used to set the value of the k+1 coefficient update field that is transmitted to the link partner in the control block of the training frame. | tx_serdes_clk   |  |
| ctl_lt_k0_to_tx0[1:0]         | I   | This 2-bit field is used to set the value of the k0 coefficient update field that is transmitted to the link partner in the control block of the training frame.  | tx_serdes_clk   |  |
| ctl_lt_k_m1_to_tx0[1:0]       | I   | This 2-bit field is used to set the value of the k-1 coefficient update field that is transmitted to the link partner in the control block of the training frame. | tx_serdes_clk   |  |
| ctl_lt_stat_p1_to_tx0[1:0]    | I   | This 2-bit field is used to set the value of the k+1 coefficient update status that is transmitted to the link partner in the status block of the training frame. | tx_serdes_clk   |  |
| ctl_lt_stat0_to_tx0[1:0]      | I   | This 2-bit field is used to set the value of the k0 coefficient update status that is transmitted to the link partner in the status block of the training frame.  | tx_serdes_clk   |  |
| ctl_lt_stat_m1_to_tx0[1:0]    | I   | This 2-bit field is used to set the value of the k-1 coefficient update status that is transmitted to the link partner in the status block of the training frame. | tx_serdes_clk   |  |
| stat_lt_rx_sof[1-1:0]         | 0   | This output is High for 1 RX SerDes clock cycle to indicate the start of the link training frame.                                                                 | rx_serdes_clk   |  |



## **IEEE 802.3 Clause 74 FEC Interface**

The following table shows the IEEE 802.3 Clause 74 FEC Control/Status and Statistics signals.

Table 23: IEEE 802.3 Clause 74 FEC Interface Control/Status/Statistics Signals

| Signal                               | I/O | Clock         | Description                                                                                                                                                                      |
|--------------------------------------|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_fec_tx_enable                    | I   | tx_serdes_clk | Asserted to enable the clause 74 FEC encoding on the transmitted data                                                                                                            |
| ctl_fec_rx_enable                    | I   | rx_serdes_clk | Asserted to enable the clause 74 FEC decoding of the received data                                                                                                               |
| ctl_fec_enable_error_to_pcs          | I   | rx_serdes_clk | Clause 74 FEC enable error to PCS                                                                                                                                                |
| stat_fec_inc_correct_count[3:0]      | 0   | rx_serdes_clk | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected and corrected a bit errors in the corresponding frame. |
| stat_fec_inc_cant_correct_count[3:0] | 0   | rx_serdes_clk | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected bit.                                                   |
| stat_fec_lock_error[3:0]             | 0   | rx_serdes_clk | This signal is asserted if the FEC decoder has been unable to detect the frame boundary after about 5 ms. It is cleared when the frame boundary is detected.                     |
| stat_fec_rx_lock[3:0]                | 0   | rx_serdes_clk | This signal is asserted while the ctl_fec_rx_enable is asserted when the FEC decoder detects the frame boundary.                                                                 |

### **IEEE 802.3 Clause 108 RS-FEC Interface**

The following table shows the IEEE 802.3 Clause 108 RS-FEC Control/Status and Statistics signals.

Table 24: IEEE 802.3 Clause 108 (RS-FEC) Control/Status/Statistics Signals

| Signal                               | I/O | Clock         | Description                                                                                                          |
|--------------------------------------|-----|---------------|----------------------------------------------------------------------------------------------------------------------|
| ctl_rx_rsfec_enable_correction       | I   | rx_serdes_clk | Equivalent to MDIO register 1.200.0                                                                                  |
|                                      |     |               | 0: Decoder performs error detection without error correction (see IEEE 802.3by Clause 91.5.3.3).                     |
|                                      |     |               | 1: Decoder also performs error correction.                                                                           |
| ctl_rx_rsfec_enable_indication       | I   | rx_serdes_clk | Equivalent to MDIO register 1.200.1                                                                                  |
|                                      |     |               | 0: Bypass the error indication function (see IEEE Std 802.3by Clause 91.5.3.3).                                      |
|                                      |     |               | 1: Decoder indicates errors to the PCS sublayer.                                                                     |
| ctl_rsfec_enable                     | I   | rx_serdes_clk | Enable RS-FEC function.                                                                                              |
|                                      |     |               | Some variants of the 10G/25G Ethernet IP Subsystem can have separate TX and RX enable signals.                       |
| ctl_rsfec_ieee_error_indication_mode | I   | rx_serdes_clk | This signal indicates that the core conforms to the IEEE RS-FEC specification                                        |
|                                      |     |               | 1: Core conforms to the IEEE RS-FEC specification.                                                                   |
|                                      |     |               | 0: If ctl_rx_rsfec_enable_correction and ctl_rx_rsfec_enable_indication are set to zero, the RS decoder is bypassed. |



Table 24: IEEE 802.3 Clause 108 (RS-FEC) Control/Status/Statistics Signals (cont'd)

| Signal                              | I/O | Clock         | Description                                                                                                |
|-------------------------------------|-----|---------------|------------------------------------------------------------------------------------------------------------|
| ctl_rsfec_consortium_25g            | I   | rx_serdes_clk | This signal switches between IEEE Clause 108 and 25G<br>Ethernet Consortium modes                          |
|                                     |     |               | 1 = 25G Consortium specification mode.                                                                     |
|                                     |     |               | 0 = IEEE 802.3 by mode.                                                                                    |
|                                     |     |               | Some variants of the 10G/25G Subsystem can have individual RX and TX consortium signals.                   |
| stat_rx_rsfec_hi_ser                | 0   | rx_serdes_clk | Indicates high symbol error.                                                                               |
|                                     |     |               | Set to 1 if the number of RS-FEC symbol errors in a window of 8192 codewords exceeds the threshold of 417. |
|                                     |     |               | Set to 0 otherwise.                                                                                        |
| stat_rx_rsfec_lane_alignment_status | 0   | rx_serdes_clk | A value of 1 indicates that the RX RS-FEC block has achieved alignment on the data from the transceiver.   |
| stat_rx_rsfec_corrected_cw_inc      | 0   | rx_serdes_clk | Increment for corrected errors.                                                                            |
| stat_rx_rsfec_uncorrected_cw_inc    | 0   | rx_serdes_clk | Increment for uncorrected errors.                                                                          |
| stat_rx_rsfec_err_count0_inc[2:0]   | 0   | rx_serdes_clk | Increment for detected errors.                                                                             |
| stat_tx_rsfec_lane_alignment_status | 0   | tx_serdes_clk | A value of 1 indicates that the TX RS-FEC block has achieved alignment on the incoming PCS data.           |

# **Port Descriptions - PCS Variant**

This section shows the 10G/25G PCS core ports. These are the ports when the PCS-only option is provided. There are no FCS functions. The PCS does not contain the Pause and Flow Control ports. The system interface is XGMII/25GMII. The following table shows the PCS variant I/O ports.

Table 25: PCS Variant I/O Ports

| Name                              | I/O | Clock<br>Domain | Description                                                                                                                                                          |
|-----------------------------------|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_tx_local_fault               | 0   | tx_mii_clk      | A value of 1 indicates the transmit encoder state machine is in the TX_INIT state. This output is level sensitive.                                                   |
| ctl_rx_prbs31_test_pattern_enable | I   | rx_clk_out      | Corresponds to MDIO register bit 3.42.5 as defined in Clause 45. Takes first precedence.                                                                             |
| ctl_rx_test_pattern_enable        | I   | rx_clk_out      | Test pattern enable for the RX core. A value of 1 enables test mode.<br>Corresponds to MDIO register bit 3.42.2 as defined in Clause 45.<br>Takes second precedence. |
| ctl_rx_data_pattern_select        | I   | rx_clk_out      | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45.                                                                                                     |
| ctl_rx_test_pattern               | I   | rx_clk_out      | Test pattern enable for the RX core to receive scrambled idle pattern. Takes third precedence.                                                                       |
| ctl_tx_prbs31_test_pattern_enable | I   | tx_mii_clk      | Corresponds to MDIO register bit 3.42.4 as defined in Clause 45. Takes first precedence.                                                                             |



Table 25: PCS Variant I/O Ports (cont'd)

| Name                             | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|-----|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_test_pattern_enable       | I   | tx_mii_clk      | Test pattern generation enable for the TX core. A value of 1 enables test mode.  Corresponds to MDIO register bit 3.42.3 as defined in Clause 45. Takes second precedence.                                                                                                                                                                                                           |
| ctl_tx_test_pattern_select       | I   | tx_mii_clk      | Corresponds to MDIO register bit 3.42.1 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                     |
| ctl_tx_data_pattern_select       | I   | tx_mii_clk      | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45.                                                                                                                                                                                                                                                                                                                     |
| ctl_tx_test_pattern_seed_a[57:0] | I   | tx_mii_clk      | Corresponds to MDIO registers 3.34 through to 3.37 as defined in Clause 45.                                                                                                                                                                                                                                                                                                          |
| ctl_tx_test_pattern_seed_b[57:0] | I   | tx_mii_clk      | Corresponds to MDIO registers 3.38 through to 3.41 as defined in Clause 45.                                                                                                                                                                                                                                                                                                          |
| ctl_tx_test_pattern              | I   | tx_mii_clk      | Scrambled idle Test pattern generation enable for the TX core. A value of 1 enables test mode. Corresponds to MDIO register bit 3.42.7 as defined in Clause 45. Takes third precedence.                                                                                                                                                                                              |
| stat_tx_fifo_error               | 0   | tx_mii_clk      | Transmit clock compensation FIFO error indicator. A value of 1 indicates the clock compensation FIFO under or overflowed.  If this output is sampled as a 1 in any clock cycle, the corresponding port must be reset to resume proper operation.                                                                                                                                     |
| stat_rx_fifo_error               | 0   | rx_clk_out      | Receive clock compensation FIFO error indicator. A value of 1 indicates the clock compensation FIFO under or overflowed. This condition only occurs if the PPM difference between the recovered clock and the local reference clock is greater than ±200 ppm.  If this output is sampled as a 1 in any clock cycle, the corresponding port must be reset to resume proper operation. |
| stat_rx_local_fault              | 0   | rx_clk_out      | A value of 1 indicates the receive decoder state machine is in the RX_INIT state. This output is level sensitive.                                                                                                                                                                                                                                                                    |
| stat_rx_hi_ber                   | 0   | rx_clk_out      | High Bit Error Rate (BER) indicator. When set to 1, the BER is too high as defined by the 802.3.  Corresponds to MDIO register bit 3.32.1 as defined in Clause 45.  This output is level sensitive.                                                                                                                                                                                  |
| stat_rx_block_lock               | 0   | rx_clk_out      | Block lock status for each PCS lane. A value of 1 indicates the corresponding lane has achieved a block lock as defined in Clause 49. Corresponds to MDIO register bit 3.50.7:0 and 3.51.11:0 as defined in Clause 45.  This output is level sensitive.                                                                                                                              |
| stat_rx_error                    | 0   | rx_clk_out      | Test pattern mismatch increment. A non-zero value in any cycle indicates how many mismatches occurred for the test pattern in the RX core.  This output is only active when ctl_rx_test_pattern is set to a 1.  This output can be used to generate MDIO register 3.43.15:0 as defined in Clause 45.  This output is pulsed for one clock cycle.                                     |
| stat_rx_valid_ctrl_code          | 0   | rx_clk_out      | Indicates that a PCS block with a valid control code was received.                                                                                                                                                                                                                                                                                                                   |
| stat_rx_error_valid              | 0   | rx_clk_out      | Increment valid indicator. If this signal is a 1 in any clock cycle, the value of stat_rx_error_valid[0:0] is valid.                                                                                                                                                                                                                                                                 |



Table 25: PCS Variant I/O Ports (cont'd)

| Name                      | I/O | Clock<br>Domain | Description                                                                                                                                                                 |
|---------------------------|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_bad_code          | 0   | rx_clk_out      | Increment for 64B/66B code violations. This signal indicates the number of 64b/66b words received with an invalid block or if a wrong 64b/66b block sequence was detected.  |
|                           |     |                 | This output can be used to generate MDIO register 3.33:7:0 as defined in Clause 45.                                                                                         |
| stat_rx_bad_code_valid    | 0   | rx_clk_out      | Increment valid indicator. If this signal is a 1 in any clock cycle, the value of stat_rx_bad_code[0:0] is valid.                                                           |
| stat_rx_framing_err       | 0   | rx_clk_out      | Increment value for number of bad sync header bits detected. The value of this bus is only valid in the same cycle that the corresponding stat_rx_framing_err_valid is a 1. |
| stat_rx_framing_err_valid | 0   | rx_clk_out      | Increment valid indicator. If this signal is a 1 in any clock cycle, the value of stat_rx_framing_err[0:0] is valid.                                                        |

## **Transceiver Interface Ports**

The following table shows the transceiver I/O ports.

Table 26: Transceiver I/O

| Name              | I/O | Clock<br>Domain    | Description                                                                                                                                         |
|-------------------|-----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| GT_reset          | I   | Async              | Active-High reset for the transceiver startup FSM. Note that this signal also initiates the reset sequence for the entire 10G/25G Ethernet IP core. |
| refclk_n0         | I   | Refer to Clocking. | Differential reference clock input for the SerDes, negative phase.                                                                                  |
| refclk_p0         | I   | Refer to Clocking. | Differential reference clock input for the SerDes, negative phase.                                                                                  |
| rx_serdes_data_n0 | I   | Refer to Clocking. | Serial data from the line; negative phase of the differential signal.                                                                               |
| rx_serdes_data_p0 | I   | Refer to Clocking. | Serial data from the line; positive phase of the differential signal.                                                                               |
| tx_serdes_data_n0 | 0   | Refer to Clocking. | Serial data to the line; negative phase of the differential signal.                                                                                 |
| tx_serdes_data_p0 | 0   | Refer to Clocking. | Serial data to the line; positive phase of the differential signal.                                                                                 |
| tx_serdes_clkout  | 0   | Refer to Clocking. | When present, same as tx_clk_out.                                                                                                                   |

# **XGMII/25GMII Interface Ports**

The following table shows the XGMII/25GMII I/O ports.



Table 27: XGMII/25GMII Interface Ports

| Name                       | I/O | Clock<br>Domain    | Description                                                                                       |
|----------------------------|-----|--------------------|---------------------------------------------------------------------------------------------------|
| rx_mii_d[63:0]             | 0   | rx_mii_clk         | Receive XGMII/25GMII Data bus.                                                                    |
| rx_mii_c[7:0]              | 0   | rx_mii_clk         | Receive XGMII/25GMII Control bus.                                                                 |
| rx_mii_clk                 | I   | Refer to Clocking. | Receive XGMII/25GMII Clock input.                                                                 |
| tx_mii_d[63:0]             | I   | tx_mii_clk         | Transmit XGMII/25GMII Data bus.                                                                   |
| tx_mii_c[7:0]              | I   | tx_mii_clk         | Transmit XGMII/25GMII Control bus.                                                                |
| rx_clk_out                 | 0   | Refer to Clocking. | This is the reference clock for RX PCS stats.                                                     |
| tx_clk_out (or tx_mii_clk) | 0   | Refer to Clocking. | This output is used to clock the TX MII bus. Data is clocked on the positive edge of this signal. |
| rx_mii_reset               | I   | Async              | Reset input for the RX MII interface.                                                             |
| tx_mii_reset               | I   | Async              | Reset input for the TX MII interface.                                                             |

# **Miscellaneous Status/Control Ports**

The following table shows the miscellaneous status/control ports.

**Table 28: Miscellaneous Status/Control Ports** 

| Name | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                           |
|------|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dclk | I   |                 | Dynamic Reconfiguration Port (DRP) clock input. The required frequency is set by providing the value in the <b>GT DRP Clock</b> field in the Vivado® IDE GT Selection and Configuration tab. This must be a free running input clock. |

### **IEEE 802.3 Clause 74 FEC Interface**

The following table shows the IEEE 802.3 Clause 74 FEC Control/Status and Statistics signals.

Table 29: IEEE 802.3 Clause 74 FEC Interface Control/Status/Statistics Signals

| Signal                          | I/O | Clock         | Description                                                                                                                                                                      |
|---------------------------------|-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_fec_tx_enable               | I   | tx_serdes_clk | Asserted to enable the clause 74 FEC encoding on the transmitted data.                                                                                                           |
| ctl_fec_rx_enable               | I   | rx_serdes_clk | Asserted to enable the clause 74 FEC decoding of the received data.                                                                                                              |
| ctl_fec_enable_error_to_pcs     | I   | rx_serdes_clk | Clause 74 FEC enable error to PCS.                                                                                                                                               |
| stat_fec_inc_correct_count[3:0] | 0   | rx_serdes_clk | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected and corrected a bit errors in the corresponding frame. |



Table 29: IEEE 802.3 Clause 74 FEC Interface Control/Status/Statistics Signals (cont'd)

| Signal                               | I/O | Clock         | Description                                                                                                                                                  |
|--------------------------------------|-----|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_fec_inc_cant_correct_count[3:0] | 0   | rx_serdes_clk | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected bit.                               |
| stat_fec_lock_error[3:0]             | 0   | rx_serdes_clk | This signal is asserted if the FEC decoder has been unable to detect the frame boundary after about 5 ms. It is cleared when the frame boundary is detected. |
| stat_fec_rx_lock[3:0]                | 0   | rx_serdes_clk | This signal is asserted while the ctl_fec_rx_enable is asserted when the FEC decoder detects the frame boundary.                                             |

## **IEEE 802.3 Clause 108 RS-FEC Interface**

The following table shows the IEEE 802.3 Clause 108 RS-FEC Control/Status and Statistics signals.

Table 30: IEEE 802.3 Clause 108 (RS-FEC) Control/Status/Statistics Signals

| Signal                                | I/O | Clock         | Description                                                                                                          |
|---------------------------------------|-----|---------------|----------------------------------------------------------------------------------------------------------------------|
| ctl_rx_rsfec_enable_correction        | I   | rx_serdes_clk | Equivalent to MDIO register 1.200.0                                                                                  |
|                                       |     |               | 0: Decoder performs error detection without error correction (see IEEE 802.3by Clause 91.5.3.3).                     |
|                                       |     |               | 1: the decoder also performs error correction.                                                                       |
| ctl_rx_rsfec_enable_indication        | I   | rx_serdes_clk | Equivalent to MDIO register 1.200.1                                                                                  |
|                                       |     |               | 0: Bypass the error indication function(see IEEE Std 802.3by Clause 91.5.3.3).                                       |
|                                       |     |               | 1: Decoder indicates errors to the PCS sublayer                                                                      |
| ctl_rsfec_enable                      | I   | rx_serdes_clk | Enable RS-FEC function.                                                                                              |
|                                       |     |               | <b>Note:</b> Some variants of the 10G/25G Ethernet IP Subsystem can have separate TX and RX enable signals.          |
| ctl_rsfec_ieee_error_indication_mod e | I   | rx_serdes_clk | This signal indicates that the core conforms to the IEEE RS-FEC specification.                                       |
|                                       |     |               | • 1: Core conforms to the IEEE RS-FEC specification.                                                                 |
|                                       |     |               | 0: If ctl_rx_rsfec_enable_correction and ctl_rx_rsfec_enable_indication are set to zero, the RS decoder is bypassed. |
| ctl_rsfec_consortium_25g              | I   | rx_serdes_clk | This signal switches between IEEE Clause 108 and 25G Ethernet Consortium modes                                       |
|                                       |     |               | • 1 = 25G Consortium specification mode;                                                                             |
|                                       |     |               | • 0 = IEEE 802.3 by mode                                                                                             |
|                                       |     |               | <b>Note:</b> Some variants of the 10G/25G Subsystem can have individual RX and TX consortium signals.                |



Table 30: IEEE 802.3 Clause 108 (RS-FEC) Control/Status/Statistics Signals (cont'd)

| Signal                                  | I/O | Clock         | Description                                                                                                                                                |
|-----------------------------------------|-----|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_rsfec_hi_ser                    | 0   | rx_serdes_clk | Indicates high symbol error. Set to 1 if the number of RS-FEC symbol errors in a window of 8192 codewords exceeds the threshold of 417. Set to 0 otherwise |
| stat_rx_rsfec_lane_alignment_statu<br>s | 0   | rx_serdes_clk | A value of 1 indicates that the RX RS-FEC block has achieved alignment on the data from the transceiver.                                                   |
| stat_rx_rsfec_corrected_cw_inc          | 0   | rx_serdes_clk | Increment for corrected errors                                                                                                                             |
| stat_rx_rsfec_uncorrected_cw_inc        | 0   | rx_serdes_clk | Increment for uncorrected errors                                                                                                                           |
| stat_rx_rsfec_err_count0_inc[2:0]       | 0   | rx_serdes_clk | Increment for detected errors                                                                                                                              |
| stat_tx_rsfec_lane_alignment_status     | 0   | tx_serdes_clk | A value of 1 indicates that the TX RS-FEC block has achieved alignment on the incoming PCS data.                                                           |

# Port Descriptions – 10G Ethernet MAC (64-bit) Variant

### **MII Interface**

This interface is used to connect to the physical layer, where this is a separate device or implemented in the FPGA beside the Ethernet MAC core. The following table shows the port associated with this interface.

Table 31: MII Interface

| Name                          | I/O | Clock<br>Domain | Description                             |
|-------------------------------|-----|-----------------|-----------------------------------------|
| rx_mac_mii_d[63:0]/rx_mii_d   | I   | rx_mii_clk      | Receive Data from PHY                   |
| rx_mac_mii_c[7:0]/rx_mii_c    | I   | rx_mii_clk      | Receive Control from PHY                |
| rx_mac_mii_clk/rx_mii_clk     | I   |                 | Received clock connected from PHY       |
| rx_mac_mii_reset/rx_mii_reset | I   | rx_mii_clk      | Reset signal received from PHY          |
| tx_mac_mii_d[63:0]/tx_mii_d   | 0   | tx_mii_clk      | Transmit Data to PHY                    |
| tx_mac_mii_c[7:0]/tx_mii_c    | 0   | tx_mii_clk      | Transmit Control to PHY                 |
| tx_mac_mii_clk/tx_mii_clk     | 0   |                 | XGMII output clock sent to external PHY |
| tx_mac_mii_reset/tx_mii_reset | 0   | tx_mii_clk      | Reset signal sent to external PHY       |

## **AXI4-Stream Interface**

The AXI4-Stream interface clock and reset signals are shown in the following table.



Table 32: AXI4-Stream - Clocks and Resets

| Name     | I/O | Clock<br>Domain | Description                                                                                                                                                                                                               |
|----------|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_reset | I   | Async           | Reset for the RX circuits. This signal is active-High (1=Reset) and must be held High until the clock, clk is stable. The core handles synchronizing the rx_reset input to the appropriate clock domains within the core. |
| tx_reset | I   | Async           | Reset for the TX circuits. This signal is active-High (1=Reset) and must be held High until the clock, clk is stable. The core handles synchronizing the tx_reset input to the appropriate clock domains within the core. |
| clk      | I   |                 | All signals between the 10G/25G High Speed Ethernet<br>Subsystem and the user-side logic are synchronized to<br>the positive edge of this signal.                                                                         |

# AXI4-Stream Interface - TX

The following table shows the AXI4-Stream transmit interface signals.

Table 33: AXI4-Stream Transmit Interface Signal

| Name                | I/O | Clock<br>Domain | Description                                                                                    |
|---------------------|-----|-----------------|------------------------------------------------------------------------------------------------|
| tx_axis_tdata[63:0] | I   | clk             | AXI4-Stream Data                                                                               |
| tx_axis_tkeep[7:0]  | I   | clk             | AXI4-Stream Data Control.                                                                      |
| tx_axis_tlast       | I   | clk             | AXI4-Stream signal indicating End of Packet.                                                   |
| tx_axis_tvalid      | I   | clk             | AXI4-Stream Data Valid.                                                                        |
| tx_axis_tuser       | I   | clk             | AXI4-Stream User Sideband interface signal. 1 indicates a bad packet 0 indicates a good packet |
| tx_axis_tready      | 0   | clk             | AXI4-Stream acknowledge signal to indicate to start the Data transfer                          |
| tx_parityin[7:0]    | I   | clk             | AXI4-Stream user-generated parity. Follows the same data lane mapping as tx_axis_tkeep.        |

#### **Data Lane Mapping - TX**

For transmit data,  $tx_axis_tdata[63:0]$ , the port is logically divided into lane 0 to lane 7. See the following table.

Table 34: tx\_axis\_tdata Lanes

| Lane/tx_axis_tkeep | tx_axis_tdata[63:0] bits |
|--------------------|--------------------------|
| 0                  | 7:0                      |
| 1                  | 15:8                     |
| 2                  | 23:16                    |
| 3                  | 31:24                    |



Table 34: tx axis tdata Lanes (cont'd)

| Lane/tx_axis_tkeep | tx_axis_tdata[63:0] bits |
|--------------------|--------------------------|
| 4                  | 39:32                    |
| 5                  | 47:40                    |
| 6                  | 55:48                    |
| 7                  | 63:56                    |

#### **Normal Transmission**

The timing of a normal frame transfer is shown in the following figure. When the client wants to transmit a frame, it asserts the  $tx_axis_tvalid$  and places the data and control in  $tx_axis_tdata$  and  $tx_axis_ttkeep$  in the same clock cycle. When this data is accepted by the core, indicated by  $tx_axis_tready$  being asserted, the client must provide the next cycle of data. If  $tx_axis_tready$  is not asserted by the core, the client must hold the current valid data value until it is. The end of the packet is indicated to the core by  $tx_axis_tlast$  asserted for 1 cycle. The bits of  $tx_axis_tkeep$  are set appropriately to indicate the number of valid bytes in the final data transfer.  $tx_axis_tuser$  is also asserted to indicate a bad packet. After  $tx_axis_tlast$  is deasserted, any data and control is deemed invalid until  $tx_axis_tvalid$  is next asserted.

tvalid tready D D DA SA D D FCS SA D D D FCS DA D tdata[7:0] tdata[15:8] DA SA D D D FCS DA SA D D D D FCS tdata[23:16] DA SA D D D D D D tdata[31:24] D D D DA SA D D DA L/T D D tdata[39:32] DA L/T D D D D D tdata[47:40] DA L/T D D D D D DA L/T D D D D tdata[55:48] SA D D D FCS SA D D D D D D D D FCS SA D D D FCS SA D D D D tdata[63:56] tkeep[7:0] 0xFF 0xFF

Figure 13: Normal Frame Transfer - 64-bits

#### **Aborting a Transmission**

The aborted transfer of a packet on the client interface is called an underrun. This can happen if a FIFO in the AXI Transmit client interface empties before a frame is completed.

This is indicated to the core in one of two ways:



- An explicit error in which a frame transfer is aborted by deasserting tx\_axis\_tuser High while tx\_axis\_tlast is High. [see AXI4-Stream Interface]
- An implicit underrun in which a frame transfer is aborted by deasserting  $tx_axis_tvalid$  without asserting  $tx_axis_tvalid$ .

### AXI4-Stream Interface - RX

The following table shows the AXI4-Stream receive interface signals.

Table 35: AXI4-Stream Receive Interface Signals

| Name                | I/O | Clock<br>Domain | Description                                                                                                               |
|---------------------|-----|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| rx_axis_tdata[63:0] | 0   | clk             | AXI4-Stream Data to upper layer                                                                                           |
| rx_axis_tkeep[7:0]  | 0   | clk             | AXI4-Stream Data Control to upper layer                                                                                   |
| rx_axis_tlast       | 0   | clk             | AXI4-Streamsignal indicating an end of packet                                                                             |
| rx_axis_tvalid      | 0   | clk             | AXI4-Stream Data Valid                                                                                                    |
| rx_axis_tuser       | 0   | clk             | AXI4-StreamUser Sideband interface 1 indicates a bad packet has been received 0 indicates a good packet has been received |
| rx_parityout[7:0]   | 0   | clk             | AXI4-Stream core-generated parity. Follows the same data lane mapping as rx_axis_tkeep.                                   |

#### **Data Lane Mapping - RX**

For receive data,  $rx_axis_tdata[63:0]$ , the port is logically divided into lane 0 to lane 7. See the following table.

Table 36: rx\_axis\_tdata Lanes

| Lane/rx_axis_tkeep | rx_axis_tdata[63:0] bits |
|--------------------|--------------------------|
| 0                  | 7:0                      |
| 1                  | 15:8                     |
| 2                  | 23:16                    |
| 3                  | 31:24                    |
| 4                  | 39:32                    |
| 5                  | 47:40                    |
| 6                  | 55:48                    |
| 7                  | 63:56                    |

#### **Normal Frame Reception**

The timing of a normal inbound frame transfer is represented in the following figures. The client must be prepared to accept data at any time; there is no buffering within the core to allow for latency in the receive client.



During frame reception,  $rx_axis_tvalid$  is asserted to indicate that valid frame data is being transferred to the client on  $rx_axis_tdata$ . All bytes are always valid throughout the frame, as indicated by all  $rx_axis_tkeep$  bits being set to 1, except during the final transfer of the frame when  $rx_axis_tlast$  is asserted. During this final transfer of data for a frame,  $rx_axis_tkeep$  bits indicate the final valid bytes of the frame using the mapping from above. The valid bytes of the final transfer always lead out from  $rx_axis_tdata[7:0]$  ( $rx_axis_tkeep[0]$ ) because Ethernet frame data is continuous and is received least significant byte first.

The  $rx_axis_tlast$  is asserted and  $rx_axis_tuser$  is deasserted, along with the final bytes of the transfer, only after all the frame checks are completed. This is after the frame check sequence (FCS) field has been received. The core keeps the  $rx_axis_tuser$  signal deasserted to indicate that the frame was successfully received and that the frame should be analyzed by the client. This is also the end of the packet signaled by  $rx_axis_tlast$  asserted for one cycle.



Figure 14: Normal Frame Reception - 64-bits

### Frame Reception with Errors

The case of an unsuccessful frame reception (for example, a runt frame or a frame with an incorrect FCS) are shown in the following figures for 32-bit and 64-bit. In this case the bad frame is received and the signal  $rx_axis_tuser$  is asserted to the client at the end of the frame. It is then the responsibility of the client to drop the data already transferred for this frame.

The following conditions cause the assertion of  $rx_axis_tlast$  along with  $rx_axis_tuser$  = 1 signifying a bad frame:

- FCS errors occur
- Packets are shorter than 64 bytes (undersize or fragment frames)
- Frames of length greater than the maximum transmission unit (MTU) size programmed are received



- Any control frame that is received is not exactly the minimum frame length
- The XGMII data stream contains error codes

#### AXI4-Stream Control and Status Ports - TX

Table 37: AXI4-Stream Interface - TX Path Control/Status Signals

| Name                          | I/O   | Clock<br>Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------|-------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_enable                 | I     | clk             | TX Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                               |       |                 | When sampled as a 1, this signal is used to enable the transmission of data.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                               |       |                 | When sampled as a 0, only IDLEs are transmitted by the core.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                               |       |                 | This input should not be set to 1 until the receiver it is sending data to is fully synchronized and ready to receive data. (that is, the receiver on the link partner is not sending a remote fault condition.) Otherwise, loss of data can occur. If this signal is set to 0 while a packet is being transmitted, the current packet transmission is completed and then the core stops transmitting any more packets.                                                                                     |
| ctl_tx_custom_preamble_enable | I     | clk             | When asserted, this signal enables the use of tx_preamblein as a custom preamble instead of inserting a standard preamble.                                                                                                                                                                                                                                                                                                                                                                                  |
| tx_preamblein[55:0]           | I     | clk             | This is the custom preamble which is a separate input port rather than being in-line with the data. It should be valid during the start of the packet.                                                                                                                                                                                                                                                                                                                                                      |
| ctl_tx_ipg_value[3:0]         | I     | clk             | The ctl_tx_ipg_value defines the target average minimum Inter Packet Gap (IPG, in bytes) inserted between packets. Typical value is 12. The ctl_tx_ipg_value can also be programmed to a value in the 0 to 7 range, but in that case, it is interpreted as meaning "minimal IPG", so only Terminate code word IPG is inserted; no Idles are ever added in that case and that produces an average IPG of around four bytes when random-size packets are transmitted.  This signal can be optionally present. |
| ctl_tx_fcs_ins_enable         | I     | clk             | Enable FCS insertion by the TX core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                               |       |                 | If set to 0, the core does not add FCS to the packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                               |       |                 | If set to 1, the core calculates and adds FCS to the packet.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                               |       |                 | This input cannot be dynamically changed between packets                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ctl_tx_send_lfi               | I     | clk             | Transmit Local Fault Indication (LFI) code word.<br>Takes precedence over Remote Fault Indication<br>(RFI).                                                                                                                                                                                                                                                                                                                                                                                                 |
| ctl_tx_send_rfi               | Input | clk             | Transmit Remote Fault Indication (RFI) code word.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                               |       |                 | If sampled as a 1, the TX path transmits only RFI code words.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                               |       |                 | This input should be set to 1 until the RX path is fully synchronized and is ready to accept data from the link partner.                                                                                                                                                                                                                                                                                                                                                                                    |



Table 37: AXI4-Stream Interface - TX Path Control/Status Signals (cont'd)

| Name                       | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                         |
|----------------------------|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_send_idle           | I   | clk             | Transmit IDLE code words.                                                                                                                                                                                                                           |
|                            |     |                 | If sampled as a 1, the TX path only transmits IDLE code words.                                                                                                                                                                                      |
|                            |     |                 | This input should be set to 1 when the partner is sending RFI code words.                                                                                                                                                                           |
| ctl_tx_ignore_fcs          | I   | clk             | Enable FCS error checking at the AXI4-Stream interface by the TX core. This input only has effect when ctl_tx_fcs_ins_enable is Low.                                                                                                                |
|                            |     |                 | If set to 0 and a packet with bad FCS is being transmitted, it is not binned as good.                                                                                                                                                               |
|                            |     |                 | If set to 1, a packet with bad FCS is binned as good.                                                                                                                                                                                               |
|                            |     |                 | The error is flagged on the signals stat_tx_bad_fcs and stomped_fcs and the packet is transmitted as it was received.                                                                                                                               |
|                            |     |                 | <b>Note:</b> Statistics are reported as if there was no FCS error.                                                                                                                                                                                  |
| ctl_tx_parity_err_response | I   | clk             | Parity error response by the TX Core. If this bit is set to 0, the core does not take any action if any parity errors are detected. If this bit is set to 1, the core stomps the outgoing FCS (i.e., bit-wise inverse) and asserts stat_tx_bad_fcs. |

### AXI4-Stream Control and Status Ports - RX

Table 38: AXI4-Stream Interface - RX Path Control/Status Signals

| Name                          | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                                                                  |
|-------------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_enable                 | I   | clk             | RX enable. For normal operation this input must be set to 1. When set to 0, after the RX completes the reception of the current packet (if any), it stops receiving packets by keeping the PCS from decoding incoming data. In this mode, there are no statistics reported and the AXI4-Stream interface is idle.            |
| ctl_rx_custom_preamble_enable | I   | clk             | When asserted, this signal causes the side band of a packet presented on the AXI4-Stream to be the preamble as it appears on the line.                                                                                                                                                                                       |
| rx_preambleout[55:0]          | 0   | clk             | This is the preamble, and now a separate output instead of inline with data.                                                                                                                                                                                                                                                 |
| ctl_rx_delete_fcs             | I   | clk             | Enable FCS removal by the RX core.  If set to 0, the core does not remove the FCS of the incoming packet.  If set to 1, the core deletes the FCS to the received packet.  FCS is not deleted for packets that are less than eight bytes.  This input should only be changed while the corresponding reset input is asserted. |



Table 38: AXI4-Stream Interface - RX Path Control/Status Signals (cont'd)

| Name                        | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                              |
|-----------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_ignore_fcs           | I   | clk             | Enable FCS error checking at the AXI4-Stream interface by the RX core.                                                                                                                                                                                                                   |
|                             |     |                 | If set to 0, a packet received with an FCS error is indicated as an errored frame (rx_axis_tuser=1 when rx_axis_tlast=1)                                                                                                                                                                 |
|                             |     |                 | If set to 1, the core does not flag an FCS error at the AXI4-<br>Stream Interface.                                                                                                                                                                                                       |
|                             |     |                 | The statistics are reported as if the packet is good. The signal stat_rx_bad_fcs, however reports the error.                                                                                                                                                                             |
| ctl_rx_max_packet_len[14:0] | I   | clk             | Any packet longer than this value is considered to be oversized. If a packet has a size greater than this value, it is truncated to this value and the rx_axis_tuser signal is asserted along with the rx_axis_tlast signal. ctl_rx_max_packet_len[14] is reserved and must be set to 0. |
| ctl_rx_min_packet_len[7:0]  | I   | clk             | Any packet shorter than this value is considered to be undersized. If a packet has a size shorter than this value, the rx_axis_tuser signal is asserted along with the rx_axis_tlast signal. Packets less than four bytes are dropped.                                                   |
| ctl_rx_check_sfd            | I   | clk             | When asserted, this input causes the MAC to check the Start of Frame Delimiter (SFD) of the received frame.                                                                                                                                                                              |
| ctl_rx_check_preamble       | I   | clk             | When asserted, this input causes the MAC to check the preamble of the received frame.                                                                                                                                                                                                    |
| stat_rx_local_fault         | 0   | clk             | This output is High when stat_rx_internal_local_fault or stat_rx_received_local_fault is asserted. This output is level sensitive.                                                                                                                                                       |
| stat_rx_remote_fault        | 0   | clk             | Remote fault indication status. If this bit is sampled as 1, indicates a remote fault condition was detected. If this bit is sampled as 0, remote fault condition does not exist. This output is level sensitive.                                                                        |

# **Miscellaneous Status/Control Signals**

The following table shows the miscellaneous status and control signals.

Table 39: Miscellaneous Status/Control Signals

| Name                               | I/O | Clock<br>Domain | Description                                                                                                                                                                                          |
|------------------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_process_lfi                 | I   | clk             | When this input is set to 1, the RX core expects and processes LF control codes coming in from the transceiver.  When set to 0, the RX core ignores LF control codes coming in from the transceiver. |
| stat_tx_gmii_fifo_unf <sup>1</sup> | 0   | clk             | TX FIFO underflow                                                                                                                                                                                    |
| stat_tx_gmii_fifo_ovf <sup>1</sup> | 0   | clk             | TX FIFO overflow                                                                                                                                                                                     |

#### Notes:

1. Available only in 10G MAC-only variant.



# **Statistics Interface Ports**

The following tables show the statistics interface ports for the RX and TX paths respectively.

Table 40: Statistics Interface Ports - RX

| Name                           | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                         |
|--------------------------------|-----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_bad_code               | 0   | clk             | Increment for 64B/66B code violations. This signal indicates that the RX PCS receive state machines is in the RX_E state as specified by IEEE Std 802.3. This output can be used to generate MDIO register as defined in Clause 45. |
| stat_rx_total_packets[1:0]     | 0   | clk             | Increment for the total number of packets received.                                                                                                                                                                                 |
| stat_rx_total_good_packets     | 0   | clk             | Increment for the total number of good packets received. This value is non-zero only when a packet is received completely and contains no errors.                                                                                   |
| stat_rx_total_bytes[3:0]       | 0   | clk             | Increment for the total number of bytes received.                                                                                                                                                                                   |
| stat_rx_total_good_bytes[13:0] | 0   | clk             | Increment for the total number of good bytes received.<br>This value is non-zero only when a packet is received<br>completely and contains no errors.                                                                               |
| stat_rx_packet_small           | 0   | clk             | Increment for all packets that are less than 64 bytes long. Packets that are less than 4 bytes are dropped.                                                                                                                         |
| stat_rx_jabber                 | 0   | clk             | Increment for packets longer than ctl_rx_max_packet_len with bad FCS.                                                                                                                                                               |
| stat_rx_packet_large           | 0   | clk             | Increment for all packets that are more than 9215 bytes long.                                                                                                                                                                       |
| stat_rx_oversize               | 0   | clk             | Increment for packets longer than ctl_rx_max_packet_len with good FCS.                                                                                                                                                              |
| stat_rx_undersize              | 0   | clk             | Increment for packets shorter than ctl_rx_min_packet_len with good FCS                                                                                                                                                              |
| stat_rx_toolong                | 0   | clk             | Increment for packets longer than ctl_rx_max_packet_len with good and bad FCS                                                                                                                                                       |
| stat_rx_fragment               | 0   | clk             | Increment for packets shorter than ctl_rx_min_packet_len with bad FCS                                                                                                                                                               |
| stat_rx_packet_64_bytes        | 0   | clk             | Increment for good and bad packets received that contain 64 bytes.                                                                                                                                                                  |
| stat_rx_packet_65_127_bytes    | 0   | clk             | Increment for good and bad packets received that contain between 65 and 127 bytes.                                                                                                                                                  |
| stat_rx_packet_128_255_bytes   | 0   | clk             | Increment for good and bad packets received that contain between 128 and 255 bytes.                                                                                                                                                 |
| stat_rx_packet_256_511_bytes   | 0   | clk             | Increment for good and bad packets received that contain between 256 and 511 bytes.                                                                                                                                                 |
| stat_rx_packet_512_1023_bytes  | 0   | clk             | Increment for good and bad packets received that contain between 512 and 1023 bytes.                                                                                                                                                |
| stat_rx_packet_1024_1518_bytes | 0   | clk             | Increment for good and bad packets received that contain between 1024 and 1518 bytes.                                                                                                                                               |
| stat_rx_packet_1519_1522_bytes | 0   | clk             | Increment for good and bad packets received that contain between 1519 and 1522 bytes.                                                                                                                                               |
| stat_rx_packet_1523_1548_bytes | 0   | clk             | Increment for good and bad packets received that contain between 1523 and 1548 bytes.                                                                                                                                               |



Table 40: Statistics Interface Ports - RX (cont'd)

| Name                           | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_packet_1549_2047_bytes | 0   | clk             | Increment for good and bad packets received that contain between 1549 and 2047 bytes.                                                                                                                                                                                                                                                                                                                                                                                                          |
| stat_rx_packet_2048_4095_bytes | 0   | clk             | Increment for good and bad packets received that contain between 2048 and 4095 bytes.                                                                                                                                                                                                                                                                                                                                                                                                          |
| stat_rx_packet_4096_8191_bytes | 0   | clk             | Increment for good and bad packets received that contain between 4096 and 8191 bytes.                                                                                                                                                                                                                                                                                                                                                                                                          |
| stat_rx_packet_8192_9215_bytes | 0   | clk             | Increment for good and bad packets received that contain between 8192 and 9215 bytes.                                                                                                                                                                                                                                                                                                                                                                                                          |
| stat_rx_bad_fcs [1:0]          | 0   | clk             | When this signal is positive, it indicates that the error detection logic has identified mismatches between the expected and received value of CRC32 in the received packet.  When a CRC32 error is detected, the received packet is marked as containing an error and is sent with rx_axis_tuser asserted during the last transfer (the cycle with rx_axis_tlast asserted), unless ctl_rx_ignore_fcs is asserted. This signal is asserted for one clock period for each CRC32 error detected. |
| stat_rx_packet_bad_fcs         | 0   | clk             | Increment for packets between 64 and ctl_rx_max_packet_len bytes that have Frame Check Sequence (FCS) errors.                                                                                                                                                                                                                                                                                                                                                                                  |
| stat_rx_stomped_fcs [1:0]      | 0   | clk             | Stomped FCS indicator. The value on this bus indicates the packets received with a stomped FCS. A stomped FCS is defined as the bitwise inverse of the expected good FCS. This output is pulsed for one clock cycle to indicate the stomped condition. Note that pulses can occur in back to back cycles.                                                                                                                                                                                      |
| stat_rx_unicast                | 0   | clk             | Increment for good unicast packets                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| stat_rx_multicast              | 0   | clk             | Increment for good multicast packets                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| stat_rx_broadcast              | 0   | clk             | Increment for good broadcast packets                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| stat_rx_vlan                   | 0   | clk             | Increment for good 802.1Q tagged VLAN packets.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| stat_rx_pause                  | 0   | clk             | Increment for 802.3x MAC Pause Packet with good FCS.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| stat_rx_user_pause             | 0   | clk             | Increment for priority based pause packets with good FCS.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| stat_rx_inrangeerr             | 0   | clk             | Increment for packets with Length field error but with good FCS.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| stat_rx_bad_preamble           | 0   | clk             | Increment for packets received with bad preamble. This signal indicates if the Ethernet packet received was preceded by a valid preamble. A value of 1 indicates that an invalid preamble was received.  When an invalid preamble is detected, the stat_rx_bad_preamble signal is asserted regardless of the setting of the ctl_rx_check_preamble signal.                                                                                                                                      |
| stat_rx_bad_sfd                | 0   | clk             | Increment for packets received with bad SFD. This signal indicates if the Ethernet packet received was preceded by a valid SFD. A value of 1 indicates that an invalid SFD was received.  When an invalid SFD is detected, the stat_rx_bad_sfd signal is asserted regardless of the setting of the ctl_rx_check_sfd signal.                                                                                                                                                                    |



Table 40: Statistics Interface Ports - RX (cont'd)

| Name                  | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                         |
|-----------------------|-----|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_got_signal_os | 0   | clk             | Signal OS indication. If this bit is sampled as a 1, it indicates that a signal OS word was received.  Note: Signal OS should not be received in an Ethernet network.                                                                                                               |
| stat_rx_truncated     | 0   | clk             | Packet truncation indicator. A value of 1 indicates that the current packet in flight is truncated due to its length exceeding ctl_rx_max_packet_len[14:0]. This output is pulsed for one clock cycle to indicate the truncated condition. Pulses can occur in back to back cycles. |

**Table 41: Statistics Interface - TX Path** 

| Name                           | I/O | Clock<br>Domain | Description                                                                                                                                               |
|--------------------------------|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_tx_total_packets          | 0   | clk             | Increment for total number of packets transmitted.                                                                                                        |
| stat_tx_total_bytes[2:0]       | 0   | clk             | Increment for total number of bytes transmitted.                                                                                                          |
| stat_tx_total_good_packets     | 0   | clk             | Increment for the total number of good packets transmitted.                                                                                               |
| stat_tx_total_good_bytes[13:0] | 0   | clk             | Increment for the total number of good bytes transmitted. This is signal is non-zero only when a packet is transmitted completely and contains no errors. |
| stat_tx_packet_64_bytes        | 0   | clk             | Increment for good and bad packets transmitted that contain 64 bytes.                                                                                     |
| stat_tx_packet_65_127_bytes    | 0   | clk             | Increment for good and bad packets transmitted that contain between 65 and 127 bytes.                                                                     |
| stat_tx_packet_128_255_bytes   | 0   | clk             | Increment for good and bad packets transmitted that contain between 128 and 255 bytes.                                                                    |
| stat_tx_packet_256_511_bytes   | 0   | clk             | Increment for good and bad packets transmitted that contain between 256 and 511 bytes.                                                                    |
| stat_tx_packet_512_1023_bytes  | 0   | clk             | Increment for good and bad packets transmitted that contain between 512 and 1023 bytes.                                                                   |
| stat_tx_packet_1024_1518_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 1024 and 1518 bytes.                                                                  |
| stat_tx_packet_1519_1522_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 1519 and 1522 bytes.                                                                  |
| stat_tx_packet_1523_1548_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 1523 and 1548 bytes.                                                                  |
| stat_tx_packet_1549_2047_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 1549 and 2047 bytes.                                                                  |
| stat_tx_packet_2048_4095_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 2048 and 4095 bytes.                                                                  |
| stat_tx_packet_4096_8191_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 4096 and 8191 bytes.                                                                  |
| stat_tx_packet_8192_9215_bytes | 0   | clk             | Increment for good and bad packets transmitted that contain between 8192 and 9215 bytes.                                                                  |



Table 41: Statistics Interface - TX Path (cont'd)

| Name                 | I/O | Clock<br>Domain | Description                                                                                                                                  |
|----------------------|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| stat_tx_packet_small | 0   | clk             | Increment for all packets that are less than 64 bytes long.                                                                                  |
| stat_tx_packet_large | 0   | clk             | Increment for all packets that are more than 9215 bytes long.                                                                                |
| stat_tx_unicast      | 0   | clk             | Increment for good unicast packets.                                                                                                          |
| stat_tx_multicast    | 0   | clk             | Increment for good multicast packets.                                                                                                        |
| stat_tx_broadcast    | 0   | clk             | Increment for good broadcast packets.                                                                                                        |
| stat_tx_vlan         | 0   | clk             | Increment for good 802.1Q tagged VLAN packets.                                                                                               |
| stat_tx_pause        | 0   | clk             | Increment for 802.3x MAC Pause Packet with good FCS                                                                                          |
| stat_tx_user_pause   | 0   | clk             | Increment for Priority based pause packets with good FCS.                                                                                    |
| stat_tx_bad_fcs      | 0   | clk             | Increment for packets greater than 64 bytes that have FCS errors.                                                                            |
| stat_tx_frame_error  | 0   | clk             | Increment for packets with tx_axis_tuser set to indicate an End of Packet (EOP) abort or frames aborted by deasserting tvalid without tlast. |
| stat_tx_local_fault  | 0   | clk             | A value of 1 indicates the receive decoder state machine is in the TX_INIT state. This output is level sensitive.                            |
| stat_tx_bad_parity   | 0   | clk             | Increment on any clock cycle where the user-generated parity is calculated as incorrect by the TX parity checking logic.                     |

# **Pause Interface**

The following tables show the Pause interface I/O ports.

**Table 42: Pause Interface - Control Ports** 

| Name                     | I/O | Clock<br>Domain | Description                                                                                                                                                                                                      |
|--------------------------|-----|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_pause_enable[8:0] | I   | clk             | RX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority.  Note: This signal only affects the RX user interface and not the pause processing logic |
| ctl_tx_pause_enable[8:0] | I   | clk             | TX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority. This signal gates transmission of pause packets.                                         |



Table 43: Pause Interface - TX Path

| Name                                  | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                                                                                               |
|---------------------------------------|-----|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_pause_req[8:0]                 | I   | clk             | If a bit of this bus is set to 1, the core transmits a pause packet using the associated quanta value on the ctl_tx_pause_quanta[8:0][15:0] bus. If bit[8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted.                             |
| ctl_tx_resend_pause                   | I   | clk             | Retransmit pending pause packets. When this input is sampled as 1, all pending pause packets are retransmitted as soon as possible (that is, after the current packet in flight is completed) and the retransmit counters are reset. This input should be pulsed to 1 for one cycle at a time.            |
| ctl_tx_pause_quanta[8:0][15:0]        | I   | clk             | These nine buses indicate the quanta to be transmitted for each of the eight priorities in priority based and global pause operations. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority based pause operation.                             |
| ctl_tx_pause_refresh_timer[8:0][15:0] | I   | clk             | These nine buses set the retransmission time of pause packets for each of the eight priorities in priority based pause operation and the global pause operation. The values for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_da_gpp[47:0]                   | I   | clk             | Destination address for transmitting global pause packets.                                                                                                                                                                                                                                                |
| ctl_tx_sa_gpp[47:0]                   | I   | clk             | Source address for transmitting global pause packets.                                                                                                                                                                                                                                                     |
| ctl_tx_ethertype_gpp[15:0]            | I   | clk             | Ethertype for transmitting global pause packets.                                                                                                                                                                                                                                                          |
| ctl_tx_opcode_gpp[15:0]               | I   | clk             | Opcode for transmitting global pause packets.                                                                                                                                                                                                                                                             |
| ctl_tx_da_ppp[47:0]                   | I   | clk             | Destination address for transmitting priority pause packets.                                                                                                                                                                                                                                              |
| ctl_tx_sa_ppp[47:0]                   | I   | clk             | Source address for transmitting priority pause packets.                                                                                                                                                                                                                                                   |
| ctl_tx_ethertype_ppp[15:0]            | I   | clk             | Ethertype for transmitting priority pause packets.                                                                                                                                                                                                                                                        |
| ctl_tx_opcode_ppp[15:0]               | I   | clk             | Opcode for transmitting priority pause packets.                                                                                                                                                                                                                                                           |
| stat_tx_pause_valid[8:0]              | 0   | clk             | If a bit of this bus is set to 1, the core has transmitted a pause packets. If bit [8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted.                                                                                                 |



Table 44: Pause Interface - RX

| Name                        | I/O | Clock<br>Domain | Description                                                                                                                                                                      |
|-----------------------------|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_pause_ack[8:0]       | I   | clk             | Pause acknowledge signal. This bus is used to acknowledge the receipt of the pause frame from the user logic.                                                                    |
| ctl_rx_check_ack            | I   | clk             | Wait for acknowledge. IF this input is set to 1, the core uses the ctl_rx_pause_ack[8:0] bus for pause processing. If this input is set to 0, ctl_rx_pause_ack[8:0] is not used. |
| ctl_rx_enable_gcp           | I   | clk             | A value of 1 enables global control packet processing.                                                                                                                           |
| ctl_rx_check_mcast_gcp      | I   | clk             | A value of 1 enables global control multicast destination address processing.                                                                                                    |
| ctl_rx_check_ucast_gcp      | I   | clk             | A value of 1 enables global control unicast destination address processing.                                                                                                      |
| ctl_rx_pause_da_ucast[47:0] | I   | clk             | Unicast destination address for pause processing.                                                                                                                                |
| ctl_rx_check_sa_gcp         | I   | clk             | A value of 1 enables global control source address processing.                                                                                                                   |
| ctl_rx_pause_sa[47:0]       | I   | clk             | Source address for pause processing.                                                                                                                                             |
| ctl_rx_check_etype_gcp      | I   | clk             | A value of 1 enables global control ethertype processing.                                                                                                                        |
| ctl_rx_etype_gcp[15:0]      | I   | clk             | Ethertype field for global control processing                                                                                                                                    |
| ctl_rx_check_opcode_gcp     | I   | clk             | A value of 1 enables global control opcode processing.                                                                                                                           |
| ctl_rx_opcode_min_gcp[15:0] | I   | clk             | Minimum global control opcode value                                                                                                                                              |
| ctl_rx_opcode_max_gcp[15:0] | I   | clk             | Maximum global control opcode value                                                                                                                                              |
| ctl_rx_enable_pcp           | I   | clk             | A value of 1 enables priority control packet processing                                                                                                                          |
| ctl_rx_check_mcast_pcp      | I   | clk             | A value of 1 enables priority control multicast destination address processing                                                                                                   |
| ctl_rx_check_ucast_pcp      | I   | clk             | A value of 1 enables priority control unicast destination address processing                                                                                                     |
| ctl_rx_pause_da_mcast[47:0] | I   | clk             | Multicast destination address for pause processing.                                                                                                                              |
| ctl_rx_check_sa_pcp         | I   | clk             | A value of 1 enables priority control source address processing                                                                                                                  |
| ctl_rx_check_etype_pcp      | I   | clk             | A value of 1 enables priority control ethertype processing                                                                                                                       |
| ctl_rx_etype_pcp[15:0]      | I   | clk             | Ethertype field for priority control processing                                                                                                                                  |
| ctl_rx_check_opcode_pcp     | I   | clk             | A value of 1 enables priority control opcode processing                                                                                                                          |
| ctl_rx_opcode_min_pcp[15:0] | I   | clk             | Minimum priority control opcode value                                                                                                                                            |
| ctl_rx_opcode_max_pcp[15:0] | I   | clk             | Maximum priority control opcode value                                                                                                                                            |
| ctl_rx_enable_gpp           | I   | clk             | A value of 1 enables global pause packet processing                                                                                                                              |
| ctl_rx_check_mcast_gpp      | I   | clk             | A value of 1 enables global pause multicast destination address processing                                                                                                       |
| ctl_rx_check_ucast_gpp      | I   | clk             | A value of 1 enables global pause unicast destination address processing                                                                                                         |
| ctl_rx_check_sa_gpp         | I   | clk             | A value of 1 enables global pause source address processing.                                                                                                                     |
| ctl_rx_check_etype_gpp      | I   | clk             | A value of 1 enables global pause ethertype processing                                                                                                                           |
| ctl_rx_etype_gpp[15:0]      | I   | clk             | Ethertype field for global pause processing                                                                                                                                      |
| ctl_rx_check_opcode_gpp     | I   | clk             | A value of 1 enables global pause opcode processing.                                                                                                                             |



Table 44: Pause Interface - RX (cont'd)

| Name                             | I/O | Clock<br>Domain | Description                                                                                                                                                                                                                      |
|----------------------------------|-----|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_opcode_gpp[15:0]          | I   | clk             | Global pause opcode value.                                                                                                                                                                                                       |
| ctl_rx_enable_ppp                | I   | clk             | A value of 1 enables priority pause packet processing                                                                                                                                                                            |
| ctl_rx_check_mcast_ppp           | I   | clk             | A value of 1 enables priority pause multicast destination address processing                                                                                                                                                     |
| ctl_rx_check_ucast_ppp           | I   | clk             | A value of 1 enables priority pause unicast destination address processing                                                                                                                                                       |
| ctl_rx_check_sa_ppp              | I   | clk             | A value of 1 enables priority pause source address processing                                                                                                                                                                    |
| ctl_rx_check_etype_ppp           | I   | clk             | A value of 1 enables priority pause ethertype processing                                                                                                                                                                         |
| ctl_rx_etype_ppp[15:0]           | I   | clk             | Ethertype field for priority pause processing                                                                                                                                                                                    |
| ctl_rx_check_opcode_ppp          | I   | clk             | A value of 1 enables priority pause opcode processing                                                                                                                                                                            |
| ctl_rx_opcode_ppp[15:0]          | I   | clk             | Priority pause opcode value                                                                                                                                                                                                      |
| ctl_rx_forward_control           | I   | clk             | A value of 1 indicates that the core forwards control packets.  A value of 0 causes core to drop control packets.                                                                                                                |
| stat_rx_pause_valid [8:0]        | 0   | clk             | Indicates that a pause packet was received and the associated quanta on the stat_rx_pause_quanta[8:0] [15:0] bus is valid and must be used for pause processing. If an 802.3x MAC Pause packet is received, bit [8] is set to 1. |
| stat_rx_pause_quanta[8:0] [15:0] | 0   | clk             | These nine buses indicate the quanta received for each of the eight priorities in priority based pause operation and global pause operation. If an 802.3x MAC Pause packet is received, the quanta is placed in value[8].        |
| stat_rx_pause_req [8:0]          | 0   | clk             | Pause request signal. When the RX receives a valid pause frame, it sets the corresponding bit of this bus to 1 and keep it at 1 until the pause packet has been processed.                                                       |

# **Register Space**

The 10G/25G Ethernet Subsystem can be optionally configured with AXI4-Lite registers to access the configuration and status signals.

## **AXI4-Lite Ports**

The following table describes the port list for the AXI processor interface.

Table 45: AXI Ports

| Signal     | I/O | Description                                       |
|------------|-----|---------------------------------------------------|
| s_axi_aclk | I   | AXI4-Lite clock. Range between 10 MHz and 300 MHz |



Table 45: AXI Ports (cont'd)

| Signal             | I/O | Description                                                                                                |  |
|--------------------|-----|------------------------------------------------------------------------------------------------------------|--|
| s_axi_aresetn      | I   | Asynchronous active-Low reset                                                                              |  |
| s_axi_awaddr[31:0] | I   | Write address Bus                                                                                          |  |
| s_axi_awvalid      | I   | Write address valid                                                                                        |  |
| s_axi_awready      | 0   | Write address acknowledge                                                                                  |  |
| s_axi_wdata[31:0]  | I   | Write data bus                                                                                             |  |
| s_axi_wstrb[3:0]   | I   | Strobe signal for the data bus byte lane                                                                   |  |
| s_axi_wvalid       | 0   | Write data valid                                                                                           |  |
| s_axi_wready       | 0   | Write data acknowledge                                                                                     |  |
| s_axi_bresp[1:0]   | 0   | Write transaction response                                                                                 |  |
| s_axi_bvalid       | 0   | Write response valid                                                                                       |  |
| s_axi_bready       | I   | Write response acknowledge                                                                                 |  |
| s_axi_araddr[31:0] | I   | Read address bus                                                                                           |  |
| s_axi_arvalid      | I   | Read address valid                                                                                         |  |
| s_axi_arready      | 0   | Read address acknowledge                                                                                   |  |
| s_axi_rdata[31:0]  | 0   | Read data output                                                                                           |  |
| s_axi_rresp[1:0]   | 0   | Read data response                                                                                         |  |
| s_axi_rvalid       | 0   | Read data/response valid                                                                                   |  |
| s_axi_rready       | I   | Read data acknowledge                                                                                      |  |
| pm_tick            | I   | Top level signal to read statistics counters; requires MODE_REG[30] (i.e., tick_reg_mode_sel) be set to 0. |  |

Additional information for the operation of the AXI4 bus is found in "Xilinx AXI Memory-Mapped Protocol Version 1.8".

As noted previously, the top level signal  $pm\_tick$  can be used to read statistics counters instead of the configuration register, TICK\_REG. In this case, configuration register MODE\_REG bit 30 (i.e.,  $tick\_reg\_mode\_sel$ ) should be set to 0. If  $tick\_reg\_mode\_sel$  set to 1,  $tick\_reg$  is used to read the statistics counters.

# **Configuration and Status Register Map**

## Configuration Register Map 10G/25G Ethernet Subsystem

The configuration space provides software with the ability to configure the IP core for various use cases. Certain features are optional and the assigned register might not exist in a particular variant, in which case the applicable registers are considered RESERVED.



**Table 46:** Configuration Register Map

| Hex<br>Address | Register Name                                        | Notes                                         |
|----------------|------------------------------------------------------|-----------------------------------------------|
| 0x0000         | GT_RESET_REG: 0000                                   |                                               |
| 0x0004         | RESET_REG: 0004                                      |                                               |
| 0x0008         | MODE_REG: 0008                                       |                                               |
| 0x000C         | CONFIGURATION_TX_REG1: 000C                          |                                               |
| 0x0014         | CONFIGURATION_RX_REG1: 0014                          |                                               |
| 0x0018         | CONFIGURATION_RX_MTU: 0018                           | Only in MAC+PCS variant and MAC-only variants |
| 0x001C         | CONFIGURATION_VL_LENGTH_REG: 001C                    |                                               |
| 0x0020         | TICK_REG: 0020                                       |                                               |
| 0x0024         | CONFIGURATION_REVISION_REG: 0024                     |                                               |
| 0x0028         | CONFIGURATION_TX_TEST_PAT_SEED_A_LSB: 0028           | Only in MAC+PCS and PCS-only variants         |
| 0x002C         | CONFIGURATION_TX_TEST_PAT_SEED_A_MSB: 002C           | Only in MAC+PCS and PCS-only variants         |
| 0x0030         | CONFIGURATION_TX_TEST_PAT_SEED_B_LSB: 0030           | Only in MAC+PCS and PCS-only variants         |
| 0x0034         | CONFIGURATION_TX_TEST_PAT_SEED_B_MSB: 0034           | Only in MAC+PCS and PCS-only variants         |
| 0x0038         | CONFIGURATION_1588_REG: 0038                         | Only in MAC+PCS variant                       |
| 0x0040         | CONFIGURATION_TX_FLOW_CONTROL_REG1: 0040             | Only in MAC+PCS and MAC-only variants         |
| 0x0044         | CONFIGURATION_TX_FLOW_CONTROL_REFRESH_REG1: 0044     | Only in MAC+PCS and MAC-only variants         |
| 0x0048         | CONFIGURATION_TX_FLOW_CONTROL_REFRESH_REG2: 0048     | Only in MAC+PCS and MAC-only variants         |
| 0x004C         | CONFIGURATION_TX_FLOW_CONTROL_REFRESH_REG3: 004C     | Only in MAC+PCS and MAC-only variants         |
| 0x0050         | CONFIGURATION_TX_FLOW_CONTROL_REFRESH_REG4: 0050     | Only in MAC+PCS and MAC-only variants         |
| 0x0054         | CONFIGURATION_TX_FLOW_CONTROL_REFRESH_REG5: 0054     | Only in MAC+PCS and MAC-only variants         |
| 0x0058         | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG1: 0058      | Only in MAC+PCS and MAC-only variants         |
| 0x005C         | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG2: 005C      | Only in MAC+PCS and MAC-only variants         |
| 0x0060         | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG3: 0060      | Only in MAC+PCS and MAC-only variants         |
| 0x0064         | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG4: 0064      | Only in MAC+PCS and MAC-only variants         |
| 0x0068         | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG5: 0068      | Only in MAC+PCS and MAC-only variants         |
| 0x006C         | CONFIGURATION_TX_FLOW_CONTROL_PPP_ETYPE_OP_REG: 006C | Only in MAC+PCS and MAC-only variants         |
| 0x0070         | CONFIGURATION_TX_FLOW_CONTROL_GPP_ETYPE_OP_REG: 0070 | Only in MAC+PCS and MAC-only variants         |
| 0x0074         | CONFIGURATION_TX_FLOW_CONTROL_GPP_DA_REG_LSB: 0074   | Only in MAC+PCS and MAC-only variants         |
| 0x0078         | CONFIGURATION_TX_FLOW_CONTROL_GPP_DA_REG_MSB: 0078   | Only in MAC+PCS and MAC-only variants         |
| 0x007C         | CONFIGURATION_TX_FLOW_CONTROL_GPP_SA_REG_LSB: 007C   | Only in MAC+PCS and MAC-only variants         |
| 0x0080         | CONFIGURATION_TX_FLOW_CONTROL_GPP_SA_REG_MSB: 0080   | Only in MAC+PCS and MAC-only variants         |
| 0x0084         | CONFIGURATION_TX_FLOW_CONTROL_PPP_DA_REG_LSB: 0084   | Only in MAC+PCS and MAC-only variants         |
| 0x0088         | CONFIGURATION_TX_FLOW_CONTROL_PPP_DA_REG_MSB: 0088   | Only in MAC+PCS and MAC-only variants         |
| 0x008C         | CONFIGURATION_TX_FLOW_CONTROL_PPP_SA_REG_LSB: 008C   | Only in MAC+PCS and MAC-only variants         |
| 0x0090         | CONFIGURATION_TX_FLOW_CONTROL_PPP_SA_REG_MSB: 0090   | Only in MAC+PCS and MAC-only variants         |
| 0x0094         | CONFIGURATION_RX_FLOW_CONTROL_REG1: 0094             | Only in MAC+PCS and MAC-only variants         |
| 0x0098         | CONFIGURATION_RX_FLOW_CONTROL_REG2: 0098             | Only in MAC+PCS and MAC-only variants         |



*Table 46:* **Configuration Register Map** (cont'd)

| Hex<br>Address | Register Name                                        | Notes                                                                     |
|----------------|------------------------------------------------------|---------------------------------------------------------------------------|
| 0x009C         | CONFIGURATION_RX_FLOW_CONTROL_PPP_ETYPE_OP_REG: 009C | Only in MAC+PCS and MAC-only variants                                     |
| 0x00A0         | CONFIGURATION_RX_FLOW_CONTROL_GPP_ETYPE_OP_REG: 00A0 | Only in MAC+PCS and MAC-only variants                                     |
| 0x00A4         | CONFIGURATION_RX_FLOW_CONTROL_GCP_PCP_TYPE_REG: 00A4 | Only in MAC+PCS and MAC-only variants                                     |
| 0x00A8         | CONFIGURATION_RX_FLOW_CONTROL_PCP_OP_REG: 00A8       | Only in MAC+PCS and MAC-only variants                                     |
| 0x00AC         | CONFIGURATION_RX_FLOW_CONTROL_GCP_OP_REG: 00AC       | Only in MAC+PCS and MAC-only variants                                     |
| 0x00B0         | CONFIGURATION_RX_FLOW_CONTROL_DA_REG1_LSB: 00B0      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00B4         | CONFIGURATION_RX_FLOW_CONTROL_DA_REG1_MSB: 00B4      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00B8         | CONFIGURATION_RX_FLOW_CONTROL_DA_REG2_LSB: 00B8      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00BC         | CONFIGURATION_RX_FLOW_CONTROL_DA_REG2_MSB: 00BC      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00C0         | CONFIGURATION_RX_FLOW_CONTROL_SA_REG1_LSB: 00C0      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00C4         | CONFIGURATION_RX_FLOW_CONTROL_SA_REG1_MSB: 00C4      | Only in MAC+PCS and MAC-only variants                                     |
| 0x00D0         | CONFIGURATION_RSFEC_REG: 00D0                        | Only in MAC+PCS and PCS-only variants                                     |
| 0x00D4         | CONFIGURATION_FEC_REG: 00D4                          | Only in MAC+PCS and PCS-only variants                                     |
| 0x00E0         | CONFIGURATION_AN_CONTROL_REG1: 00E0                  | Only in MAC+PCS and PCS-only variants                                     |
| 0x00E4         | CONFIGURATION_AN_CONTROL_REG2: 00E4                  | Only in MAC+PCS and PCS-only variants                                     |
| 0x00F8         | CONFIGURATION_AN_ABILITY: 00F8                       | Only in MAC+PCS and PCS-only variants                                     |
| 0x0100         | CONFIGURATION_LT_CONTROL_REG1: 0100                  | Only in MAC+PCS and PCS-only variants                                     |
| 0x0104         | CONFIGURATION_LT_TRAINED_REG: 0104                   | Only in MAC+PCS and PCS-only variants                                     |
| 0x0108         | CONFIGURATION_LT_PRESET_REG: 0108                    | Only in MAC+PCS and PCS-only variants                                     |
| 0x010C         | CONFIGURATION_LT_INIT_REG: 010C                      | Only in MAC+PCS and PCS-only variants                                     |
| 0x0110         | CONFIGURATION_LT_SEED_REG0: 0110                     | Only in MAC+PCS and PCS-only variants                                     |
| 0x0130         | CONFIGURATION_LT_COEFFICIENT_REG0: 0130              | Only in MAC+PCS and PCS-only variants                                     |
| 0x0134         | USER_REG_0: 0134                                     |                                                                           |
| 0x0138         | SWITCH_CORE_SPEED_REG: 0138                          |                                                                           |
| 0x013C         | CONFIGURATION_1588_32BIT_REG: 0x013C                 | Only for MAC+PCS/PMA 32-bit variant<br>1588 variants                      |
| 0x0140         | TX_CONFIGURATION_1588_REG:0x0140                     | Only for MAC+PCS/PMA 32-bit variant<br>1588 variants                      |
| 0x0144         | RX_CONFIGURATION_1588_REG: 0x0144                    | Only for MAC+PCS/PMA 32-bit variant<br>1588 variants                      |
| 0x019C         | CONFIGURATION_TSN_REG: 0x019C                        | Only when Preemption Feature is enabled.                                  |
| 0x014C         | VERSAL_CHANNEL_NUM_REG: 0x014C                       | Only for MAC+PCS/PMA 32-bit with timestamp enabled for Versal® platforms. |
| 0x0154         | GT_WIZ_CONTROL_REG                                   | Versal only                                                               |

## Status Register Map for 10G/25G Ethernet Subsystem

The status registers provide an indication of the health of the system. These registers are Read-Only and a read operation clears the register.



Status registers are cleared according to the following conditions:

- Applying s\_axi\_aresetn clears both TX and RX status registers
- When a particular status register is read (clear on read)
- Applying rx\_reset clears the RX status registers only
- Applying tx\_reset clears the TX status registers only

**Table 47: Status Register Map** 

| Hex<br>Address | Register Name                   | Notes                                         |
|----------------|---------------------------------|-----------------------------------------------|
| 0x0400         | STAT_TX_STATUS_REG1: 0400       |                                               |
| 0x0404         | STAT_RX_STATUS_REG1: 0404       |                                               |
| 0x0408         | STAT_STATUS_REG1: 0408          | Only in MAC+PCS and PCS-only variants         |
| 0x040C         | STAT_RX_BLOCK_LOCK_REG: 040C    | Only in MAC+PCS and PCS-only variants         |
| 0x043C         | STAT_RX_RSFEC_STATUS_REG: 043C  | Only in MAC+PCS and PCS-only variants         |
| 0x0448         | STAT_RX_FEC_STATUS_REG: 0448    | Only in MAC+PCS and PCS-only variants         |
| 0x044C         | STAT_TX_RSFEC_STATUS_REG: 044C  | Only in MAC+PCS and PCS-only variants         |
| 0x0450         | STAT_TX_FLOW_CONTROL_REG1: 0450 | Only in MAC+PCS variant and MAC-only variants |
| 0x0454         | STAT_RX_FLOW_CONTROL_REG1: 0454 | Only in MAC+PCS variant and MAC-only variants |
| 0x0458         | STAT_AN_STATUS: 0458            | Only in MAC+PCS and PCS-only variants         |
| 0x045C         | STAT_AN_ABILITY: 045C           | Only in MAC+PCS and PCS-only variants         |
| 0x0460         | STAT_AN_LINK_CTL: 0460          | Only in MAC+PCS and PCS-only variants         |
| 0x09F0         | STAT_AN_LINK_CTL2: 09F0         | Only in MAC+PCS and PCS-only variants         |
| 0x0464         | STAT_LT_STATUS_REG1: 0464       | Only in MAC+PCS and PCS-only variants         |
| 0x0468         | STAT_LT_STATUS_REG2: 0468       | Only in MAC+PCS and PCS-only variants         |
| 0x046C         | STAT_LT_STATUS_REG3: 046C       | Only in MAC+PCS and PCS-only variants         |
| 0x0470         | STAT_LT_STATUS_REG4: 0470       | Only in MAC+PCS and PCS-only variants         |
| 0x0474         | STAT_LT_COEFFICIENT0_REG: 0474  | Only in MAC+PCS and PCS-only variants         |
| 0x0494         | STAT_RX_VALID_CTRL_CODE: 0494   | Only in MAC+PCS and PCS-only variants         |
| 0x0498         | STAT_CORE_SPEED_REG: 0498       |                                               |
| 0x049C         | STAT_TSN_REG: 0x049C            | Only when 802.1cm Preemption feature enabled  |
| 0x04A0         | STAT_GT_WIZ_REG                 |                                               |

### **Statistics Counters**

The statistics counters provide histograms of the classification of traffic and error counts. These counters can be read either by a 1 on  $pm\_tick$  or by writing a 1 to the TICK\_REG register, depending on the value of MODE\_REG[30] (tick\_reg\_mode\_sel). The  $pm\_tick$  signal is used when MODE\_REG[30] = 0 and TICK\_REG is used when MODE\_REG[30] = 1 (1 = default).



The counters employ an internal accumulator. A write to the TICK\_REG register causes the accumulated counts to be pushed to the readable STAT\_\*\_MSB/LSB registers and simultaneously clear the accumulators. The STAT\_\*\_MSB/LSB registers can then be read. In this way, all values stored in the statistics counters represent a snap-shot over the same time interval.

**Note:** These readable STAT\_\*\_MSB/LSB registers are not resettable. This can result in unknown data being present after reset but prior to a TICK\_REG write.

The STAT\_CYCLE\_COUNT\_MSB/LSB register contains a count of the number of RX core clock cycles between TICK REG writes. This allows for easy time-interval based statistics.

Statistic counter registers are cleared according to the following conditions:

- Applying s\_axi\_aresetn clears both TX and RX statistics counter registers
- Applying pm\_tick clears both TX and RX statistics counter registers
- Applying rx\_reset clears the RX statistics counter registers only
- Applying tx\_reset clears the TX statistics counter registers only

*Table 48:* **Statistics Counters** 

| Hex<br>Address | Register Name                              | Notes                                  |
|----------------|--------------------------------------------|----------------------------------------|
| 0x0500         | STATUS_CYCLE_COUNT_LSB: 0500               |                                        |
| 0x0504         | STATUS_CYCLE_COUNT_MSB: 0504               |                                        |
| 0x0648         | STAT_RX_FRAMING_ERR_LSB: 0648              | Only in MAC+PCS and PCS-only variants  |
| 0x064C         | STAT_RX_FRAMING_ERR_MSB: 064C              | Only in MAC+PCS and PCS-only variants  |
| 0x0660         | STAT_RX_BAD_CODE_LSB: 0660                 |                                        |
| 0x0664         | STAT_RX_BAD_CODE_MSB: 0664                 |                                        |
| 0x0668         | STAT_RX_ERROR_LSB: 0668                    | Only in PCS variant                    |
| 0x066C         | STAT_RX_ERROR_MSB: 066C                    | Only in PCS variant                    |
| 0x0670         | STAT_RX_RSFEC_CORRECTED_CW_INC_LSB: 0670   | Only in MAC+PCS and PCS-only variants  |
| 0x0674         | STAT_RX_RSFEC_CORRECTED_CW_INC_MSB: 0674   | Only in MAC+PCS and PCS-only variants  |
| 0x0678         | STAT_RX_RSFEC_UNCORRECTED_CW_INC_LSB: 0678 | Only in MAC+PCS and PCS-only variants  |
| 0x067C         | STAT_RX_RSFEC_UNCORRECTED_CW_INC_MSB: 067C | Only in MAC+PCS and PCS-only variants  |
| 0x0680         | STAT_RX_RSFEC_ERR_COUNT0_INC_LSB: 0680     | Only in MAC+PCS and PCS-only variants  |
| 0x0684         | STAT_RX_RSFEC_ERR_COUNT0_INC_MSB: 0684     | Only in MAC+PCS and PCS-only variants  |
| 0x06A0         | STAT_TX_FRAME_ERROR_LSB: 06A0              |                                        |
| 0x06A4         | STAT_TX_FRAME_ERROR_MSB: 06A4              | Only in MAC+PCS and PCS-only variants  |
| 0x0700         | STAT_TX_TOTAL_PACKETS_LSB: 0700            | Only in MAC+PCS and PCS-only variants  |
| 0x0704         | STAT_TX_TOTAL_PACKETS_MSB: 0704            | Only in MAC+PCS and PCS-only variants  |
| 0x0708         | STAT_TX_TOTAL_GOOD_PACKETS_LSB: 0708       | Only in MAC+PCS and PCS-only variants  |
| 0x070C         | STAT_TX_TOTAL_GOOD_PACKETS_MSB: 070C       | Only in MAC+ PCS and MAC-only variants |
| 0x0710         | STAT_TX_TOTAL_BYTES_LSB: 0710              | Only in MAC+ PCS and MAC-only variants |



*Table 48:* **Statistics Counters** *(cont'd)* 

| Hex<br>Address | Register Name                            | Notes                                  |
|----------------|------------------------------------------|----------------------------------------|
| 0x0714         | STAT_TX_TOTAL_BYTES_MSB: 0714            | Only in MAC+ PCS and MAC-only variants |
| 0x0718         | STAT_TX_TOTAL_GOOD_BYTES_LSB: 0718       | Only in MAC+ PCS and MAC-only variants |
| 0x0720         | STAT_TX_PACKET_64_BYTES_LSB: 0720        | Only in MAC+ PCS and MAC-only variants |
| 0x0724         | STAT_TX_PACKET_64_BYTES_MSB: 0724        | Only in MAC+ PCS and MAC-only variants |
| 0x0728         | STAT_TX_PACKET_65_127_BYTES_LSB: 0728    | Only in MAC+ PCS and MAC-only variants |
| 0x072C         | STAT_TX_PACKET_65_127_BYTES_MSB: 072C    | Only in MAC+ PCS and MAC-only variants |
| 0x0730         | STAT_TX_PACKET_128_255_BYTES_LSB: 0730   | Only in MAC+ PCS and MAC-only variants |
| 0x0734         | STAT_TX_PACKET_128_255_BYTES_MSB: 0734   | Only in MAC+ PCS and MAC-only variants |
| 0x0738         | STAT_TX_PACKET_256_511_BYTES_LSB: 0738   | Only in MAC+ PCS and MAC-only variants |
| 0x073C         | STAT_TX_PACKET_256_511_BYTES_MSB: 073C   | Only in MAC+ PCS and MAC-only variants |
| 0x0740         | STAT_TX_PACKET_512_1023_BYTES_LSB: 0740  | Only in MAC+ PCS and MAC-only variants |
| 0x0744         | STAT_TX_PACKET_512_1023_BYTES_MSB: 0744  | Only in MAC+ PCS and MAC-only variants |
| 0x0748         | STAT_TX_PACKET_1024_1518_BYTES_LSB: 0748 | Only in MAC+ PCS and MAC-only variants |
| 0x074C         | STAT_TX_PACKET_1024_1518_BYTES_MSB: 074C | Only in MAC+ PCS and MAC-only variants |
| 0x0750         | STAT_TX_PACKET_1519_1522_BYTES_LSB: 0750 | Only in MAC+ PCS and MAC-only variants |
| 0x0754         | STAT_TX_PACKET_1519_1522_BYETS_MSB: 0754 | Only in MAC+ PCS and MAC-only variants |
| 0x0758         | STAT_TX_PACKET_1523_1548_BYTES_LSB: 0758 | Only in MAC+ PCS and MAC-only variants |
| 0x075C         | STAT_TX_PACKET_1523_1548_BYTES_MSB: 075C | Only in MAC+ PCS and MAC-only variants |
| 0x0760         | STAT_TX_PACKET_1549_2047_BYTES_LSB: 0760 | Only in MAC+ PCS and MAC-only variants |
| 0x0764         | STAT_TX_PACKET_1549_2047_BYTES_MSB: 0764 | Only in MAC+ PCS and MAC-only variants |
| 0x0768         | STAT_TX_PACKET_2048_4095_BYTES_LSB: 0768 | Only in MAC+ PCS and MAC-only variants |
| 0x076C         | STAT_TX_PACKET_2048_4095_BYTES_MSB: 076C | Only in MAC+ PCS and MAC-only variants |
| 0x0770         | STAT_TX_PACKET_4096_8191_BYTES_LSB: 0770 | Only in MAC+ PCS and MAC-only variants |
| 0x0774         | STAT_TX_PACKET_4096_8191_BYTES_MSB: 0774 | Only in MAC+ PCS and MAC-only variants |
| 0x0778         | STAT_TX_PACKET_8192_9215_BYTES_LSB: 0778 | Only in MAC+ PCS and MAC-only variants |
| 0x077C         | STAT_TX_PACKET_8192_9215_BYTES_MSB: 077C | Only in MAC+ PCS and MAC-only variants |
| 0x0780         | STAT_TX_PACKET_LARGE_LSB:0780            | Only in MAC+ PCS and MAC-only variants |
| 0x0784         | STAT_TX_PACKET_LARGE_MSB: 0784           | Only in MAC+ PCS and MAC-only variants |
| 0x0788         | STAT_TX_PACKET_SMALL_LSB: 0788           | Only in MAC+ PCS and MAC-only variants |
| 0x078C         | STAT_TX_PACKET_SMALL_MSB:078C            | Only in MAC+ PCS and MAC-only variants |
| 0x07B8         | STAT_TX_BAD_FCS_LSB: 07B8                | Only in MAC+ PCS and MAC-only variants |
| 0x07BC         | STAT_TX_BAD_FCS_MSB: 07BC                | Only in MAC+ PCS and MAC-only variants |
| 0x07D0         | STAT_TX_UNICAST_LSB: 07D0                | Only in MAC+ PCS and MAC-only variants |
| 0x07D4         | STAT_TX_UNICAST_MSB: 07D4                | Only in MAC+ PCS and MAC-only variants |
| 0x07D8         | STAT_TX_MULTICAST_LSB: 07D8              | Only in MAC+ PCS and MAC-only variants |
| 0x07DC         | STAT_TX_MULTICAST_MSB: 07DC              | Only in MAC+ PCS and MAC-only variants |
| 0x07E0         | STAT_TX_BROADCAST_LSB: 07E0              | Only in MAC+ PCS and MAC-only variants |
| 0x07E4         | STAT TX BROADCAST MSB: 07E4              | Only in MAC+ PCS and MAC-only variants |



*Table 48:* **Statistics Counters** *(cont'd)* 

| Hex<br>Address | Register Name                            | Notes                                  |
|----------------|------------------------------------------|----------------------------------------|
| 0x07E8         | STAT_TX_VLAN_LSB: 07E8                   | Only in MAC+ PCS and MAC-only variants |
| 0x07EC         | STAT_TX_VLAN_LSB: 07EC                   | Only in MAC+ PCS and MAC-only variants |
| 0x07F0         | STAT_TX_PAUSE_LSB: 07F0                  | Only in MAC+ PCS and MAC-only variants |
| 0x07F4         | STAT_TX_PAUSE_MSB: 07F4                  | Only in MAC+ PCS and MAC-only variants |
| 0x07F8         | STAT_TX_USER_PAUSE_LSB: 07F8             | Only in MAC+ PCS and MAC-only variants |
| 0x07FC         | STAT_TX_USER_PAUSE_MSB: 07FC             | Only in MAC+ PCS and MAC-only variants |
| 0x0808         | STAT_RX_TOTAL_PACKETS_LSB: 0808          | Only in MAC+ PCS and MAC-only variants |
| 0x080C         | STAT_RX_TOTAL_PACKETS_MSB: 080C          | Only in MAC+ PCS and MAC-only variants |
| 0x0810         | STAT_RX_TOTAL_GOOD_PACKETS_LSB: 0810     | Only in MAC+ PCS and MAC-only variants |
| 0x0814         | STAT_RX_TOTAL_GOOD_PACKETS_MSB: 0814     | Only in MAC+ PCS and MAC-only variants |
| 0x0818         | STAT_RX_TOTAL_BYTES_LSB: 0818            | Only in MAC+ PCS and MAC-only variants |
| 0x081C         | STAT_RX_TOTAL_BYTES_MSB: 081C            | Only in MAC+ PCS and MAC-only variants |
| 0x0820         | STAT_RX_TOTAL_GOOD_BYTES_LSB: 0820       | Only in MAC+ PCS and MAC-only variants |
| 0x0824         | STAT_RX_TOTAL_GOOD_BYTES_MSB: 0824       | Only in MAC+ PCS and MAC-only variants |
| 0x0828         | STAT_RX_PACKET_64_BYTES_LSB: 0828        | Only in MAC+ PCS and MAC-only variants |
| 0x082C         | STAT_RX_PACKET_64_BYTES_MSB: 082C        | Only in MAC+ PCS and MAC-only variants |
| 0x0830         | STAT_RX_PACKET_65_127_BYTES_LSB: 0830    | Only in MAC+ PCS and MAC-only variants |
| 0x0834         | STAT_RX_PACKET_65_127_BYTES_MSB: 0834    | Only in MAC+ PCS and MAC-only variants |
| 0x0838         | STAT_RX_PACKET_128_255_BYTES_LSB: 0838   | Only in MAC+ PCS and MAC-only variants |
| 0x083C         | STAT_RX_PACKET_128_255_BYTES_MSB: 083C   | Only in MAC+ PCS and MAC-only variants |
| 0x0840         | STAT_RX_PACKET_256_511_BYTES_LSB: 0840   | Only in MAC+ PCS and MAC-only variants |
| 0x0844         | STAT_RX_PACKET_256_511_BYTES_MSB: 0844   | Only in MAC+ PCS and MAC-only variants |
| 0x0848         | STAT_RX_PACKET_512_1023_BYTES_LSB: 0848  | Only in MAC+ PCS and MAC-only variants |
| 0x084C         | STAT_RX_PACKET_512_1023_BYTES_MSB: 084C  | Only in MAC+ PCS and MAC-only variants |
| 0x0850         | STAT_RX_PACKET_1024_1518_BYTES_LSB: 0850 | Only in MAC+ PCS and MAC-only variants |
| 0x0854         | STAT_RX_PACKET_1024_1518_BYTES_MSB: 0854 | Only in MAC+ PCS and MAC-only variants |
| 0x0858         | STAT_RX_PACKET_1519_1522_BYTES_LSB: 0858 | Only in MAC+ PCS and MAC-only variants |
| 0x085C         | STAT_RX_PACKET_1519_1522_BYTES_MSB: 085C | Only in MAC+ PCS and MAC-only variants |
| 0x0860         | STAT_RX_PACKET_1523_1548_BYTES_LSB: 0860 | Only in MAC+ PCS and MAC-only variants |
| 0x0864         | STAT_RX_PACKET_1523_1548_BYTES_MSB: 0864 | Only in MAC+ PCS and MAC-only variants |
| 0x0868         | STAT_RX_PACKET_1549_2047_BYTES_LSB: 0868 | Only in MAC+ PCS and MAC-only variants |
| 0x086C         | STAT_RX_PACKET_1549_2047_BYTES_MSB: 086C | Only in MAC+ PCS and MAC-only variants |
| 0x0870         | STAT_RX_PACKET_2048_4095_BYTES_LSB: 0870 | Only in MAC+ PCS and MAC-only variants |
| 0x0874         | STAT_RX_PACKET_2048_4095_BYTES_MSB: 0874 | Only in MAC+ PCS and MAC-only variants |
| 0x0878         | STAT_RX_PACKET_4096_8191_BYTES_LSB: 0878 | Only in MAC+ PCS and MAC-only variants |
| 0x087C         | STAT_RX_PACKET_4096_8191_BYTES_MSB: 087C | Only in MAC+ PCS and MAC-only variants |
| 0x0880         | STAT_RX_PACKET_8192_9215_BYTES_LSB: 0880 | Only in MAC+ PCS and MAC-only variants |
| 0x0884         | STAT_RX_PACKET_8192_9215_BYTES_MSB: 0884 | Only in MAC+ PCS and MAC-only variants |



*Table 48:* **Statistics Counters** *(cont'd)* 

| Hex<br>Address | Register Name                           | Notes                                  |
|----------------|-----------------------------------------|----------------------------------------|
| 0x0888         | STAT_RX_PACKET_LARGE_LSB: 0888          | Only in MAC+ PCS and MAC-only variants |
| 0x088C         | STAT_RX_PACKET_LARGE_MSB: 088C          | Only in MAC+ PCS and MAC-only variants |
| 0x0890         | STAT_RX_PACKET_SMALL_LSB: 0890          | Only in MAC+ PCS and MAC-only variants |
| 0x0894         | STAT_RX_PACKET_SMALL_MSB: 0894          | Only in MAC+ PCS and MAC-only variants |
| 0x0898         | STAT_RX_UNDERSIZE_LSB: 0898             | Only in MAC+ PCS and MAC-only variants |
| 0x089C         | STAT_RX_UNDERSIZE_MSB: 089C             | Only in MAC+ PCS and MAC-only variants |
| 0x08A0         | STAT_RX_FRAGMENT_LSB: 08A0              | Only in MAC+ PCS and MAC-only variants |
| 0x08A4         | STAT_RX_FRAGMENT_MSB: 08A4              | Only in MAC+ PCS and MAC-only variants |
| 0x08A8         | STAT_RX_OVERSIZE_LSB: 08A8              | Only in MAC+ PCS and MAC-only variants |
| 0x08AC         | STAT_RX_OVERSIZE_MSB: 08AC              | Only in MAC+ PCS and MAC-only variants |
| 0x08B0         | STAT_RX_TOOLONG_LSB: 08B0               | Only in MAC+ PCS and MAC-only variants |
| 0x08B4         | STAT_RX_TOOLONG_MSB: 08B4               | Only in MAC+ PCS and MAC-only variants |
| 0x08B8         | STAT_RX_JABBER_LSB: 08B8                | Only in MAC+ PCS and MAC-only variants |
| 0x08BC         | STAT_RX_JABBER_MSB: 08BC                | Only in MAC+ PCS and MAC-only variants |
| 0x08C0         | STAT_RX_BAD_FCS_LSB: 08C0               | Only in MAC+ PCS and MAC-only variants |
| 0x08C4         | STAT_RX_BAD_FCS_MSB: 08C4               | Only in MAC+ PCS and MAC-only variants |
| 0x08C8         | STAT_RX_PACKET_BAD_FCS_LSB: 08C8        | Only in MAC+ PCS and MAC-only variants |
| 0x08CC         | STAT_RX_PACKET_BAD_FCS_MSB: 08CC        | Only in MAC+ PCS and MAC-only variants |
| 0x08D0         | STAT_RX_STOMPED_FCS_LSB: 08D0           | Only in MAC+ PCS and MAC-only variants |
| 0x08D4         | STAT_RX_STOMPED_FCS_MSB: 08D4           | Only in MAC+ PCS and MAC-only variants |
| 0x08D8         | STAT_RX_UNICAST_LSB: 08D8               | Only in MAC+ PCS and MAC-only variants |
| 0x08DC         | STAT_RX_UNICAST_MSB: 08DC               | Only in MAC+ PCS and MAC-only variants |
| 0x08E0         | STAT_RX_MULTICAST_LSB: 08E0             | Only in MAC+ PCS and MAC-only variants |
| 0x08E4         | STAT_RX_MULTICAST_MSB: 08E4             | Only in MAC+ PCS and MAC-only variants |
| 0x08E8         | STAT_RX_BROADCAST_LSB: 08E8             | Only in MAC+ PCS and MAC-only variants |
| 0x08EC         | STAT_RX_BROADCAST_MSB: 08EC             | Only in MAC+ PCS and MAC-only variants |
| 0x08F0         | STAT_RX_VLAN_LSB: 08F0                  | Only in MAC+ PCS and MAC-only variants |
| 0x08F4         | STAT_RX_VLAN_MSB: 08F4                  | Only in MAC+ PCS and MAC-only variants |
| 0x08F8         | STAT_RX_PAUSE_LSB: 08F8                 | Only in MAC+ PCS and MAC-only variants |
| 0x08FC         | STAT_RX_PAUSE_MSB: 08FC                 | Only in MAC+ PCS and MAC-only variants |
| 0x0900         | STAT_RX_USER_PAUSE_LSB: 0900            | Only in MAC+ PCS and MAC-only variants |
| 0x0904         | STAT_RX_USER_PAUSE_MSB: 0904            | Only in MAC+ PCS and MAC-only variants |
| 0x0908         | STAT_RX_INRANGEERR_LSB: 0908            | Only in MAC+ PCS and MAC-only variants |
| 0x090C         | STAT_RX_INRANGEERR_MSB: 090C            | Only in MAC+ PCS and MAC-only variants |
| 0x0910         | STAT_RX_TRUNCATED_LSB: 0910             | Only in MAC+ PCS and MAC-only variants |
| 0x0914         | STAT_RX_TRUNCATED_MSB: 0914             | Only in MAC+ PCS and MAC-only variants |
| 0x0918         | STAT_RX_TEST_PATTERN_MISMATCH_LSB: 0918 | Only in MAC+PCS variant                |
| 0x091C         | STAT_RX_TEST_PATTERN_MISMATCH_MSB: 91C  | Only in MAC+PCS variant                |



Table 48: Statistics Counters (cont'd)

| Hex<br>Address | Register Name                             | Notes                                 |
|----------------|-------------------------------------------|---------------------------------------|
| 0x0920         | STAT_FEC_INC_CORRECT_COUNT_LSB: 0920      | Only in MAC+PCS and PCS-only variants |
| 0x0924         | STAT_FEC_INC_CORRECT_COUNT_MSB: 0924      | Only in MAC+PCS and PCS-only variants |
| 0x0928         | STAT_FEC_INC_CANT_CORRECT_COUNT_LSB: 0928 | Only in MAC+PCS and PCS-only variants |
| 0x092C         | STAT_FEC_INC_CANT_CORRECT_COUNT_MSB: 092C | Only in MAC+PCS and PCS-only variants |
| 0x0980         | STAT_TX_MM_STATUS_LSB: 0x0980             | MAC+PCS with TSN                      |
| 0x0984         | STAT_TX_MM_STATUS_MSB: 0x0984             | MAC+PCS with TSN                      |
| 0x0988         | STAT_TX_MM_STATUS_LSB: 0x0988             | MAC+PCS with TSN                      |
| 0x098C         | STAT_TX_MM_FRAGMENT_MSB: 0x098C           | MAC+PCS with TSN                      |
| 0x0990         | STAT_TX_MM_HOLD_LSB: 0x0990               | MAC+PCS with TSN                      |
| 0x0994         | STAT_TX_MM_HOLD_MSB: 0x0994               | MAC+PCS with TSN                      |
| 0x0998         | STAT_RX_MM_ASSEMBLY_ERROR_LSB: 0x0998     | MAC+PCS with TSN                      |
| 0x099C         | STAT_RX_MM_ASSEMBLY_ERROR_MSB: 0x099C     | MAC+PCS with TSN                      |
| 0x09A0         | STAT_RX_MM_FRAME_SMD_ERROR_LSB: 0x09A0    | MAC+PCS with TSN                      |
| 0x09A4         | STAT_RX_MM_FRAME_SMD_ERROR_MSB: 0x09A4    | MAC+PCS with TSN                      |
| 0x09A8         | STAT_RX_MM_FRAME_ASSEMBLY_OK_LSB: 0x09A8  | MAC+PCS with TSN                      |
| 0x09AC         | STAT_RX_MM_FRAME_ASSEMBLY_OK_MSB: 0x09AC  | MAC+PCS with TSN                      |
| 0x09B0         | STAT_RX_MM_FRAGMENT_LSB: 0x09B0           | MAC+PCS with TSN                      |
| 0x09B4         | STAT_RX_MM_FRAGMENT_MSB: 0x09B4           | MAC+PCS with TSN                      |

These statistics counters will be available for MAC+PCS/PMA-64-bit variants without enabling TX/RX flow control GUI option. For MAC+PCS/PMA 32-bit, Ethernet MAC-64-bit and Preemption variants counters will update only when the TX/RX flow control is enabled in the GUI.

# **Register Descriptions**

This section contains descriptions of the configuration registers. In the cases where the features described in the bit fields are not present in the IP core, the bit field reverts to RESERVED.

## Configuration Registers for 10G/25G Ethernet Subsystem

The following tables define the bit assignments for the configuration registers.

Registers or bit fields within registers can be accessed for Read-Write (RW), Write-Only (WO), or Read-Only (RO). Default values shown are decimal values and take effect after a s\_axi\_aresetn.

A description of each signal is found in Port Descriptions - MAC+PCS Variant.



GT\_RESET\_REG: 0000

Table 49: GT\_RESET\_REG: 0000

| Bits | Default | Туре | Signal                                              |
|------|---------|------|-----------------------------------------------------|
| 0    | 0       | RW   | ctl_gt_reset_all This is a clear on write register. |
| 1    | 0       | RW   | ctl_gt_rx_reset                                     |
| 2    | 0       | RW   | ctl_gt_tx_reset                                     |

RESET\_REG: 0004

*Table 50:* **RESET\_REG: 0004** 

| Bits | Default | Туре | Signal                                                                                                                                     |
|------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0       | RW   | rx_serdes_reset                                                                                                                            |
| 28   | 0       | RW   | ctl_an_reset                                                                                                                               |
|      |         |      | <b>Note:</b> This is a clear on write register.  This is available only when the Auto Negotiation/Link Training Logic feature is selected. |
| 29   | 0       | RW   | tx_serdes_reset                                                                                                                            |
| 30   | 0       | RW   | rx_reset                                                                                                                                   |
| 31   | 0       | RW   | tx_reset                                                                                                                                   |

MODE\_REG: 0008

*Table 51:* **MODE\_REG: 0008** 

| Bits | Default | Туре | Signal                  |
|------|---------|------|-------------------------|
| 0    | 1       | RW   | en_wr_slverr_indication |
| 1    | 1       | RW   | en_rd_slverr_indication |
| 30   | 1       | RW   | tick_reg_mode_sel       |
| 31   | 0       | RW   | ctl_local_loopback      |

#### Notes

1. The 0th and 1st bit of mode\_reg register provides the flexibility to disable and enable the slv error. The user can write '0' to these bits to suppress the reporting of slv error.

**CONFIGURATION\_TX\_REG1: 000C** 

Table 52: CONFIGURATION\_TX\_REG1: 000C

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 0    | 1       | RW   | ctl_tx_enable <sup>1</sup>         |
| 1    | 1       | RW   | ctl_tx_fcs_ins_enable <sup>1</sup> |



Table 52: CONFIGURATION\_TX\_REG1: 000C (cont'd)

| Bits  | Default | Туре | Signal                                         |
|-------|---------|------|------------------------------------------------|
| 2     | 0       | RW   | ctl_tx_ignore_fcs <sup>1</sup>                 |
| 3     | 0       | RW   | ctl_tx_send_lfi <sup>1</sup>                   |
| 4     | 0       | RW   | ctl_tx_send_rfi <sup>1</sup>                   |
| 5     | 0       | RW   | ctl_tx_send_idle <sup>1</sup>                  |
| 13:10 | 12      | RW   | ctl_tx_ipg_value <sup>1</sup>                  |
| 14    | 0       | RW   | ctl_tx_test_pattern                            |
| 15    | 0       | RW   | ctl_tx_test_pattern_enable                     |
| 16    | 0       | RW   | ctl_tx_test_pattern_select                     |
| 17    | 0       | RW   | ctl_tx_data_pattern_select                     |
| 18    | 0       | RW   | ctl_tx_custom_preamble_enable <sup>1</sup>     |
| 23    | 0       | RW   | ctl_tx_prbs31_test_pattern_enable <sup>2</sup> |

#### Notes:

- 1. Only in MAC+PCS variant.
- 2. Only in PCS variant.

# CONFIGURATION\_RX\_REG1: 0014

Table 53: CONFIGURATION\_RX\_REG1: 0014

| Bits | Default | Туре | Signal                                         |
|------|---------|------|------------------------------------------------|
| 0    | 1       | RW   | ctl_rx_enable <sup>1</sup>                     |
| 1    | 1       | RW   | ctl_rx_delete_fcs <sup>1</sup>                 |
| 2    | 0       | RW   | ctl_rx_ignore_fcs <sup>1</sup>                 |
| 3    | 0       | RW   | ctl_rx_process_lfi <sup>1</sup>                |
| 4    | 1       | RW   | ctl_rx_check_sfd <sup>1</sup>                  |
| 5    | 1       | RW   | ctl_rx_check_preamble <sup>1</sup>             |
| 6    | 0       | RW   | ctl_rx_force_resync <sup>1</sup>               |
| 7    | 0       | RW   | ctl_rx_test_pattern                            |
| 8    | 0       | RW   | ctl_rx_test_pattern_enable                     |
| 9    | 0       | RW   | ctl_rx_data_pattern_select                     |
| 10   | -       | -    | Reserved                                       |
| 11   | 0       | RW   | ctl_rx_custom_preamble_enable                  |
| 12   | 0       | RW   | ctl_rx_prbs31_test_pattern_enable <sup>2</sup> |

#### Notes:

- 1. Only in MAC+PCS variant
- 2. Only in PCS variant



# **CONFIGURATION\_RX\_MTU: 0018**

Table 54: CONFIGURATION\_RX\_MTU: 0018

| Bits  | Default | Туре | Signal                |
|-------|---------|------|-----------------------|
| 7:0   | 64      | RW   | ctl_rx_min_packet_len |
| 30:16 | 9,600   | RW   | ctl_rx_max_packet_len |

# CONFIGURATION\_VL\_LENGTH\_REG: 001C

Table 55: CONFIGURATION\_VL\_LENGTH\_REG: 001C

|   | Bits  | Default | Type | Signal                  |
|---|-------|---------|------|-------------------------|
|   | 15:0  | 20,479  | RW   | ctl_tx_vl_length_minus1 |
| Ī | 31:16 | 20,479  | RW   | ctl_rx_vl_length_minus1 |

TICK\_REG: 0020

*Table 56:* **TICK\_REG: 0020** 

| Bits | Default | Туре | Signal                                         |
|------|---------|------|------------------------------------------------|
| 0    | 0       | WO   | tick_reg<br>This is a clear on write register. |

# CONFIGURATION\_REVISION\_REG: 0024

Table 57: CONFIGURATION\_REVISION\_REG: 0024

| Bits  | Default | Туре | Signal    |
|-------|---------|------|-----------|
| 7:0   | 3       | RO   | major_rev |
| 15:8  | 0       | RO   | minor_rev |
| 31:24 | 0       | RO   | patch_rev |

# CONFIGURATION\_TX\_TEST\_PAT\_SEED\_A\_LSB: 0028

Table 58: CONFIGURATION\_TX\_TEST\_PAT\_SEED\_A\_LSB: 0028

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 31:0 | 0       | RW   | ctl_tx_test_pattern_seed_a[31:0] |



# CONFIGURATION\_TX\_TEST\_PAT\_SEED\_A\_MSB: 002C

Table 59: CONFIGURATION\_TX\_TEST\_PAT\_SEED\_A\_MSB: 002C

| Bits | Default | Туре | Signal                            |
|------|---------|------|-----------------------------------|
| 25:0 | 0       | RW   | ctl_tx_test_pattern_seed_a[57:32] |

# CONFIGURATION\_TX\_TEST\_PAT\_SEED\_B\_LSB: 0030

#### Table 60: CONFIGURATION\_TX\_TEST\_PAT\_SEED\_B\_LSB: 0030

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 31:0 | 0       | RW   | ctl_tx_test_pattern_seed_b[31:0] |

# **CONFIGURATION TX TEST PAT SEED B MSB: 0034**

#### Table 61: CONFIGURATION\_TX\_TEST\_PAT\_SEED\_B\_MSB: 0034

| Bits | Default | Туре | Signal                            |
|------|---------|------|-----------------------------------|
| 25:0 | 0       | RW   | ctl_tx_test_pattern_seed_b[57:32] |

# CONFIGURATION\_1588\_REG: 0038

Table 62: CONFIGURATION 1588 REG: 0038

| Bits  | Default | Туре | Signal                    |
|-------|---------|------|---------------------------|
| 0     | 0       | RW   | ctl_tx_ptp_1step_enable   |
| 2     | 0       | RW   | ctl_ptp_transpclk_mode    |
| 26:16 | 0       | RW   | ctl_tx_ptp_latency_adjust |

#### CONFIGURATION\_TX\_FLOW\_CONTROL\_REG1: 0040

Table 63: CONFIGURATION\_TX\_FLOW\_CONTROL\_REG1: 0040

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 8:0  | 0       | RW   | ctl_tx_pause_enable |

#### CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG1: 0044

Table 64: CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG1: 0044

| Bits  | Default | Туре | Signal                      |
|-------|---------|------|-----------------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_refresh_timer0 |
| 31:16 | 0       | RW   | ctl_tx_pause_refresh_timer1 |



#### CONFIGURATION TX FLOW CONTROL REFRESH REG2: 0048

Table 65: CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG2: 0048

| Bits  | Default | Туре | Signal                      |
|-------|---------|------|-----------------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_refresh_timer2 |
| 31:16 | 0       | RW   | ctl_tx_pause_refresh_timer3 |

#### CONFIGURATION TX FLOW CONTROL REFRESH REG3: 004C

#### Table 66: CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG3: 004C

| Bits  | Default | Туре | Signal                      |
|-------|---------|------|-----------------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_refresh_timer4 |
| 31:16 | 0       | RW   | ctl_tx_pause_refresh_timer5 |

#### CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG4: 0050

#### Table 67: CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG4: 0050

| Bits  | Default | Туре | Signal                      |
|-------|---------|------|-----------------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_refresh_timer6 |
| 31:16 | 0       | RW   | ctl_tx_pause_refresh_timer7 |

# **CONFIGURATION TX FLOW CONTROL REFRESH REG5: 0054**

#### Table 68: CONFIGURATION\_TX\_FLOW\_CONTROL\_REFRESH\_REG5: 0054

| Bits | Default | Type | Signal                      |
|------|---------|------|-----------------------------|
| 15:0 | 0       | RW   | ctl_tx_pause_refresh_timer8 |

# CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG1: 0058

#### Table 69: CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG1: 0058

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_quanta0 |
| 31:16 | 0       | RW   | ctl_tx_pause_quanta1 |



#### CONFIGURATION TX FLOW CONTROL QUANTA REG2: 005C

Table 70: CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG2: 005C

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_quanta2 |
| 31:16 | 0       | RW   | ctl_tx_pause_quanta3 |

# **CONFIGURATION TX FLOW CONTROL QUANTA REG3: 0060**

Table 71: CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG3: 0060

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_quanta4 |
| 31:16 | 0       | RW   | ctl_tx_pause_quanta5 |

# CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG4: 0064

Table 72: CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG4: 0064

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 0       | RW   | ctl_tx_pause_quanta6 |
| 31:16 | 0       | RW   | ctl_tx_pause_quanta7 |

# **CONFIGURATION TX FLOW CONTROL QUANTA REG5: 0068**

Table 73: CONFIGURATION\_TX\_FLOW\_CONTROL\_QUANTA\_REG5: 0068

| Bits | Default | Type | Signal               |
|------|---------|------|----------------------|
| 15:0 | 0       | RW   | ctl_tx_pause_quanta8 |

# CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_ETYPE\_OP\_REG: 006C

Table 74: CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_ETYPE\_OP\_REG: 006C

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 34824   | RW   | ctl_tx_ethertype_ppp |
| 31:16 | 257     | RW   | ctl_tx_opcode_ppp    |



# CONFIGURATION TX FLOW CONTROL GPP ETYPE OP REG: 0070

### Table 75: CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_ETYPE\_OP\_REG: 0070

| Bits  | Default | Туре | Signal               |
|-------|---------|------|----------------------|
| 15:0  | 34824   | RW   | ctl_tx_ethertype_gpp |
| 31:16 | 1       | RW   | ctl_tx_opcode_gpp    |

#### CONFIGURATION TX FLOW CONTROL GPP DA REG LSB: 0074

#### Table 76: CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_DA\_REG\_LSB: 0074

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 31:0 | 0       | RW   | ctl_tx_da_gpp[31:0] |

#### **CONFIGURATION TX FLOW CONTROL GPP DA REG MSB: 0078**

#### Table 77: CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_DA\_REG\_MSB: 0078

| Bits | Default | Туре | Signal               |
|------|---------|------|----------------------|
| 15:0 | 0       | RW   | ctl_tx_da_gpp[47:32] |

# CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_SA\_REG\_LSB: 007C

#### Table 78: CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_SA\_REG\_LSB: 007C

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 31:0 | 0       | RW   | ctl_tx_sa_gpp[31:0] |

#### CONFIGURATION TX FLOW CONTROL GPP SA REG MSB: 0080

### Table 79: CONFIGURATION\_TX\_FLOW\_CONTROL\_GPP\_SA\_REG\_MSB: 0080

| Bits | Default | Туре | Signal               |
|------|---------|------|----------------------|
| 15:0 | 0       | RW   | ctl_tx_sa_gpp[47:32] |

#### CONFIGURATION TX FLOW CONTROL PPP DA REG LSB: 0084

# Table 80: CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_DA\_REG\_LSB: 0084

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 31:0 | 0       | RW   | ctl_tx_da_ppp[31:0] |



# **CONFIGURATION TX FLOW CONTROL PPP DA REG MSB: 0088**

Table 81: CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_DA\_REG\_MSB: 0088

| Ì | Bits | Default | Туре | Signal               |
|---|------|---------|------|----------------------|
|   | 15:0 | 0       | RW   | ctl_tx_da_ppp[47:32] |

# CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_SA\_REG\_LSB: 008C

Table 82: CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_SA\_REG\_LSB: 008C

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 31:0 | 0       | RW   | ctl_tx_sa_ppp[31:0] |

# **CONFIGURATION TX FLOW CONTROL PPP SA REG MSB: 0090**

Table 83: CONFIGURATION\_TX\_FLOW\_CONTROL\_PPP\_SA\_REG\_MSB: 0090

| Bits | Default | Туре | Signal               |
|------|---------|------|----------------------|
| 15:0 | 0       | RW   | ctl_tx_sa_ppp[47:32] |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_REG1: 0094

Table 84: CONFIGURATION RX FLOW CONTROL REG1: 0094

| Bits | Default | Туре | Signal                 |
|------|---------|------|------------------------|
| 8:0  | 0       | RW   | ctl_rx_pause_enable    |
| 9    | 0       | RW   | ctl_rx_forward_control |
| 10   | 0       | RW   | ctl_rx_enable_gcp      |
| 11   | 0       | RW   | ctl_rx_enable_pcp      |
| 12   | 0       | RW   | ctl_rx_enable_gpp      |
| 13   | 0       | RW   | ctl_rx_enable_ppp      |
| 14   | 0       | RW   | ctl_rx_check_ack       |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_REG2: 0098

Table 85: CONFIGURATION\_RX\_FLOW\_CONTROL\_REG2: 0098

| Bits | Default | Type | Signal                  |
|------|---------|------|-------------------------|
| 0    | 0       | RW   | ctl_rx_check_mcast_gcp  |
| 1    | 0       | RW   | ctl_rx_check_ucast_gcp  |
| 2    | 0       | RW   | ctl_rx_check_sa_gcp     |
| 3    | 0       | RW   | ctl_rx_check_etype_gcp  |
| 4    | 0       | RW   | ctl_rx_check_opcode_gcp |



Table 85: CONFIGURATION\_RX\_FLOW\_CONTROL\_REG2: 0098 (cont'd)

| Bits | Default | Туре | Signal                  |
|------|---------|------|-------------------------|
| 5    | 0       | RW   | ctl_rx_check_mcast_pcp  |
| 6    | 0       | RW   | ctl_rx_check_ucast_pcp  |
| 7    | 0       | RW   | ctl_rx_check_sa_pcp     |
| 8    | 0       | RW   | ctl_rx_check_etype_pcp  |
| 9    | 0       | RW   | ctl_rx_check_opcode_pcp |
| 10   | 0       | RW   | ctl_rx_check_mcast_gpp  |
| 11   | 0       | RW   | ctl_rx_check_ucast_gpp  |
| 12   | 0       | RW   | ctl_rx_check_sa_gpp     |
| 13   | 0       | RW   | ctl_rx_check_etype_gpp  |
| 14   | 0       | RW   | ctl_rx_check_opcode_gpp |
| 15   | 0       | RW   | ctl_rx_check_mcast_ppp  |
| 16   | 0       | RW   | ctl_rx_check_ucast_ppp  |
| 17   | 0       | RW   | ctl_rx_check_sa_ppp     |
| 18   | 0       | RW   | ctl_rx_check_etype_ppp  |
| 19   | 0       | RW   | ctl_rx_check_opcode_ppp |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_PPP\_ETYPE\_OP\_REG: 009C

Table 86: CONFIGURATION\_RX\_FLOW\_CONTROL\_PPP\_ETYPE\_OP\_REG: 009C

| Bits  | Default | Туре | Signal            |
|-------|---------|------|-------------------|
| 15:0  | 34,824  | RW   | ctl_rx_etype_ppp  |
| 31:16 | 257     | RW   | ctl_rx_opcode_ppp |

#### CONFIGURATION\_RX\_FLOW\_CONTROL\_GPP\_ETYPE\_OP\_REG: 00A0

Table 87: CONFIGURATION\_RX\_FLOW\_CONTROL\_GPP\_ETYPE\_OP\_REG: 00A0

| Bits  | Default | Туре | Signal            |
|-------|---------|------|-------------------|
| 15:0  | 34,824  | RW   | ctl_rx_etype_gpp  |
| 31:16 | 1       | RW   | ctl_rx_opcode_gpp |

### CONFIGURATION\_RX\_FLOW\_CONTROL\_GCP\_PCP\_TYPE\_REG: 00A4

Table 88: CONFIGURATION\_RX\_FLOW\_CONTROL\_GCP\_PCP\_TYPE\_REG: 00A4

| Bits  | Default | Туре | Signal           |
|-------|---------|------|------------------|
| 15:0  | 34,824  | RW   | ctl_rx_etype_gcp |
| 31:16 | 34,824  | RW   | ctl_rx_etype_pcp |



# CONFIGURATION\_RX\_FLOW\_CONTROL\_PCP\_OP\_REG: 00A8

Table 89: CONFIGURATION\_RX\_FLOW\_CONTROL\_PCP\_OP\_REG: 00A8

| Bits  | Default | Туре | Signal                |
|-------|---------|------|-----------------------|
| 15:0  | 257     | RW   | ctl_rx_opcode_min_pcp |
| 31:16 | 257     | RW   | ctl_rx_opcode_max_pcp |

#### CONFIGURATION RX FLOW CONTROL GCP OP REG: 00AC

#### Table 90: CONFIGURATION\_RX\_FLOW\_CONTROL\_GCP\_OP\_REG: 00AC

| Bits  | Default | Туре | Signal                |
|-------|---------|------|-----------------------|
| 15:0  | 1       | RW   | ctl_rx_opcode_min_gcp |
| 31:16 | 6       | RW   | ctl_rx_opcode_max_gcp |

#### CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG1\_LSB: 00B0

#### Table 91: CONFIGURATION RX FLOW CONTROL DA REG1 LSB: 00B0

| Bits | Default | Туре | Signal                      |
|------|---------|------|-----------------------------|
| 31:0 | 0       | RW   | ctl_rx_pause_da_ucast[31:0] |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG1\_MSB: 00B4

#### Table 92: CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG1\_MSB: 00B4

|   | Bits | Default | Туре | Signal                       |
|---|------|---------|------|------------------------------|
| ĺ | 15:0 | 0       | RW   | ctl_rx_pause_da_ucast[47:32] |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG2\_LSB: 00B8

#### Table 93: CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG2\_LSB: 00B8

| Bits | Default | Туре | Signal                      |
|------|---------|------|-----------------------------|
| 31:0 | 0       | RW   | ctl_rx_pause_da_mcast[31:0] |

#### CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG2\_MSB: 00BC

#### Table 94: CONFIGURATION\_RX\_FLOW\_CONTROL\_DA\_REG2\_MSB: 00BC

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 15:0 | 0       | RW   | ctl_rx_pause_da_mcast[47:32] |



# CONFIGURATION\_RX\_FLOW\_CONTROL\_SA\_REG1\_LSB: 00C0

Table 95: CONFIGURATION\_RX\_FLOW\_CONTROL\_SA\_REG1\_LSB: 00C0

| ĺ | Bits | Default | Type | Signal                |
|---|------|---------|------|-----------------------|
| ſ | 31:0 | 0       | RW   | ctl_rx_pause_sa[31:0] |

# CONFIGURATION\_RX\_FLOW\_CONTROL\_SA\_REG1\_MSB: 00C4

Table 96: CONFIGURATION\_RX\_FLOW\_CONTROL\_SA\_REG1\_MSB: 00C4

| Bits | Default | Туре | Signal                 |
|------|---------|------|------------------------|
| 15:0 | 0       | RW   | ctl_rx_pause_sa[47:32] |

# **CONFIGURATION\_RSFEC\_REG: 00D0**

*Table 97:* **CONFIGURATION\_RSFEC\_REG: 00D0** 

| Bits | Default | Туре | Signal                               |
|------|---------|------|--------------------------------------|
| 0    | 0       | RW   | ctl_rsfec_enable                     |
| 1    | 0       | RW   | ctl_rsfec_consortium_25g             |
| 2    | 0       | RW   | ctl_rx_rsfec_enable_indication       |
| 3    | 0       | RW   | ctl_rx_rsfec_enable_correction       |
| 5    | 0       | RW   | ctl_rsfec_ieee_error_indication_mode |

# CONFIGURATION\_FEC\_REG: 00D4

Table 98: CONFIGURATION FEC REG: 00D4

| Bits | Default | Туре | Signal                      |
|------|---------|------|-----------------------------|
| 0    | 0       | RW   | ctl_fec_rx_enable           |
| 1    | 0       | RW   | ctl_fec_tx_enable           |
| 2    | 0       | RW   | ctl_fec_enable_error_to_pcs |

# CONFIGURATION\_AN\_CONTROL\_REG1: 00E0

Table 99: CONFIGURATION\_AN\_CONTROL\_REG1: 00E0

| Bits | Default | Type | Signal                          |
|------|---------|------|---------------------------------|
| 0    | 0       | RW   | ctl_autoneg_enable              |
| 1    | 1       | RW   | ctl_autoneg_bypass <sup>1</sup> |
| 9:2  | 0       | RW   | ctl_an_nonce_seed               |
| 10   | 0       | RW   | ctl_an_pseudo_sel               |
| 11   | 0       | RW   | ctl_restart_negotiation         |



Table 99: CONFIGURATION\_AN\_CONTROL\_REG1: 00E0 (cont'd)

| Bits | Default | Type | Signal             |
|------|---------|------|--------------------|
| 12   | 0       | RW   | ctl_an_local_fault |

#### Notes:

# CONFIGURATION\_AN\_CONTROL\_REG2: 00E4

Table 100: CONFIGURATION\_AN\_CONTROL\_REG2: 00E4

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 0    | 0       | RW   | ctl_an_pause                 |
| 1    | 0       | RW   | ctl_an_asmdir                |
| 16   | 0       | RW   | ctl_an_fec_10g_request       |
| 17   | 0       | RW   | ctl_an_fec_ability_override  |
| 18   | 0       | RW   | ctl_an_cl91_fec_request      |
| 19   | 0       | RW   | ctl_an_cl91_fec_ability      |
| 20   | 0       | RW   | ctl_an_fec_25g_rs_request    |
| 21   | 0       | RW   | ctl_an_fec_25g_baser_request |

# **CONFIGURATION\_AN\_ABILITY: 00F8**

Table 101: CONFIGURATION\_AN\_ABILITY: 00F8

| Bits | Default | Туре | Signal                         |
|------|---------|------|--------------------------------|
| 0    | 0       | RW   | ctl_an_ability_1000base_kx     |
| 1    | 0       | RW   | ctl_an_ability_10gbase_kx4     |
| 2    | 0       | RW   | ctl_an_ability_10gbase_kr      |
| 3    | 0       | RW   | ctl_an_ability_40gbase_kr4     |
| 4    | 0       | RW   | ctl_an_ability_40gbase_cr4     |
| 5    | 0       | RW   | ctl_an_ability_100gbase_cr10   |
| 6    | 0       | RW   | ctl_an_ability_100gbase_kp4    |
| 7    | 0       | RW   | ctl_an_ability_100gbase_kr4    |
| 8    | 0       | RW   | ctl_an_ability_100gbase_cr4    |
| 9    | 0       | RW   | ctl_an_ability_25gbase_krcr_s  |
| 10   | 0       | RW   | ctl_an_ability_25gbase_krcr    |
| 11   | 0       | RW   | ctl_an_ability_2_5gbase_kx     |
| 12   | 0       | RW   | ctl_an_ability_5gbase_kr       |
| 13   | 0       | RW   | ctl_an_ability_50gbase_krcr    |
| 14   | 0       | RW   | ctl_an_ability_100gbase_kr2cr2 |
| 15   | 0       | RW   | ctl_an_ability_200gbase_kr4cr4 |

<sup>1.</sup> For simulation, the ctl\_autoneg\_bypass value is written as 1 during reset. To test with the ANLT enabled configuration, write the register with ctl\_autoneg\_enable to 1 and ctl\_autoneg\_bypass to 0.



Table 101: **CONFIGURATION\_AN\_ABILITY: 00F8** (cont'd)

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 16   | 0       | RW   | ctl_an_ability_25gbase_kr1 |
| 17   | 0       | RW   | ctl_an_ability_25gbase_cr1 |
| 18   | 0       | RW   | ctl_an_ability_50gbase_kr2 |
| 19   | 0       | RW   | ctl_an_ability_50gbase_cr2 |

# CONFIGURATION\_LT\_CONTROL\_REG1: 0100

#### Table 102: CONFIGURATION\_LT\_CONTROL\_REG1: 0100

| Bits | Default | Туре | Signal                  |
|------|---------|------|-------------------------|
| 0    | 0       | RW   | ctl_lt_training_enable  |
| 1    | 0       | RW   | ctl_lt_restart_training |

### CONFIGURATION\_LT\_TRAINED\_REG: 0104

Table 103: CONFIGURATION\_LT\_TRAINED\_REG: 0104

| Bits | Default | Туре | Signal            |
|------|---------|------|-------------------|
| 0    | 0       | RW   | ctl_lt_rx_trained |

#### **CONFIGURATION LT\_PRESET\_REG: 0108**

Table 104: CONFIGURATION\_LT\_PRESET\_REG: 0108

| Bits | Default | Type | Signal              |
|------|---------|------|---------------------|
| 0    | 0       | RW   | ctl_lt_preset_to_tx |

#### CONFIGURATION\_LT\_INIT\_REG: 010C

Table 105: CONFIGURATION\_LT\_INIT\_REG: 010C

| Bits | Default | Туре | Signal                  |
|------|---------|------|-------------------------|
| 0    | 0       | RW   | ctl_lt_initialize_to_tx |

### CONFIGURATION\_LT\_SEED\_REG0: 0110

Table 106: CONFIGURATION\_LT\_SEED\_REG0: 0110

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 10:0 | 0       | RW   | ctl_lt_pseudo_seed0 |



# CONFIGURATION\_LT\_COEFFICIENT\_REG0: 0130

Table 107: CONFIGURATION\_LT\_COEFFICIENT\_REG0: 0130

| Bits  | Default | Туре | Signal                |  |
|-------|---------|------|-----------------------|--|
| 1:0   | 0       | RW   | ctl_lt_k_p1_to_tx0    |  |
| 3:2   | 0       | RW   | ctl_lt_k0_to_tx0      |  |
| 5:4   | 0       | RW   | ctl_lt_k_m1_to_tx0    |  |
| 7:6   | 0       | RW   | ctl_lt_stat_p1_to_tx0 |  |
| 9:8   | 0       | RW   | ctl_lt_stat0_to_tx0   |  |
| 11:10 | 0       | RW   | ctl_lt_stat_m1_to_tx0 |  |

USER\_REG\_0: 0134

Table 108: USER\_REG\_0: 0134

|   | Bits | Default | Туре | Signal    |
|---|------|---------|------|-----------|
| ſ | 31:0 | 0       | RW   | user_reg0 |

SWITCH\_CORE\_SPEED\_REG: 0138

Table 109: SWITCH\_CORE\_SPEED\_REG: 0138

| Bits | Default | Туре | Signal                   |
|------|---------|------|--------------------------|
| 0    | 0       | RW   | axi_ctl_core_mode_switch |

For Runtime Switch mode only. A write 1 enables the mode switch between 10G and 25G. This is a clear on the write register. This is an input to the trans debug module that performs the GT DRP operations.

CONFIGURATION\_1588\_32BIT\_REG: 0x013C

Table 110: CONFIGURATION\_1588\_32BIT\_REG: 0x013C

| Bits | Default | Туре | Signal                  |  |
|------|---------|------|-------------------------|--|
| 0    | 0       | RW   | ctl_tx_lat_adj_enb      |  |
| 1    | 0       | RW   | ctl_rx_lat_adj_enb      |  |
| 2    | 0       | RW   | ctl_tx_timstamp_adj_enb |  |
| 3    | 0       | RW   | ctl_rx_timstamp_adj_enb |  |
| 4    | 0       | RW   | ctl_core_speed          |  |



# TX\_CONFIGURATION\_1588\_REG: 0x0140

Table 111: TX\_CONFIGURATION\_1588\_REG: 0x0140

| Bits | Default | Туре | Signal         |
|------|---------|------|----------------|
| 31:0 | 0       | RW   | ctl_tx_latency |

# RX\_CONFIGURATION\_1588\_REG: 0x0144

Table 112: RX\_CONFIGURATION\_1588\_REG: 0x0144

| ĺ | Bits | Default | Туре | Signal         |
|---|------|---------|------|----------------|
|   | 31:0 | 0       | RW   | ctl_rx_latency |

# CONFIGURATION\_TSN\_REG: 0x019C

Table 113: CONFIGURATION\_TSN\_REG: 0x019C

| Bits  | Default | Туре | Signal                |
|-------|---------|------|-----------------------|
| 0     | 1       | RW   | ctl_en_preempt        |
| 1     | 0       | RW   | ctl_hold_request      |
| 2     | 0       | RW   | ctl_disable_verify    |
| 3     | 0       | RW   | ctl_restart_verify    |
| 5:4   | 2'b00   | RW   | ctl_addfrag_size[1:0] |
| 15:8  | 8'h01   | RW   | ctl_verify_time[7:0]  |
| 19:16 | 4'h3    | RW   | ctl_verify_limit[3:0] |

# VERSAL\_CHANNEL\_NUM\_REG: 0x014C

Table 114: VERSAL\_CHANNEL\_NUM\_REG: 0x014C

| Bits | Default | Туре | Signal             |
|------|---------|------|--------------------|
| 1:0  | 2'b0    | RW   | ctl_gtye5_chan_num |

#### GT\_WIZ\_CONTROL\_REG: 0154

**Note:** Applies to Versal devices only.

Table 115: GT\_WIZ\_CONTROL\_REG: 0154

| Bits | Default  | Туре | Signal                |
|------|----------|------|-----------------------|
| 2:0  | 3'b000   | RW   | gtwiz_loopback        |
| 7:3  | 5'b00000 | RW   | gtwiz_txprecursor     |
| 12:8 | 5'b00000 | RW   | gtwiz_txpostprecursor |



Table 115: GT\_WIZ\_CONTROL\_REG: 0154 (cont'd)

| Bits  | Default    | Туре | Signal                |
|-------|------------|------|-----------------------|
| 19:13 | 7'b0000000 | RW   | gtwiz_txmainprecursor |
| 20    | 1'b0       | RW   | gtwiz_rxcdrhold       |

#### Notes:

- Bit description mentioned (for gtwiz\_txprecursor, gtwiz\_txpostcursor, gtwiz\_txmaincursor, gtwiz\_rxcdrhold) is valid for non-GTM Versal devices only.
- 2. For Versal GTM devices, valid bit description is:bits [8:3] for gtwiz\_txprecursor, [14:9] for gtwiz\_txpostcursor, [21:15] for gtwiz txmaincursor, and bit [22] of register is for gtwiz rxcdrhold.
- 3. For more details, refer to Versal ACAP GTY and GTYP Transceivers Architecture Manual (AM002).

# Status Registers for 10G/25G Ethernet Subsystem

The following tables define the bit assignments for the status registers.

Some bits are sticky, that is, latching their value High or Low once set. This is indicated by the type LH (Latched High) or LL (Latched Low).

A description of each signal is found in Port Descriptions - MAC+PCS Variant.

STAT\_TX\_STATUS\_REG1: 0400

Table 116: STAT\_TX\_STATUS\_REG1: 0400

| Bits           | Default | Туре  | Signal                         |
|----------------|---------|-------|--------------------------------|
| 0              | 0       | RO LH | stat_tx_local_fault            |
| 1 <sup>1</sup> | 0       | RO LH | stat_tx_gmii_fifo_ovf_1h_r_out |
| 2 1            | 0       | RO LH | stat_tx_gmii_fifo_unf_1h_r_out |
| 7 <sup>2</sup> | 0       | RO LH | stat_tx_bad_parity             |

#### Notes:

- 1. Bits 1 and 2 are for the 10G MAC-only variant.
- 2. Bit 7 is applicable only for the Datapath Parity Feature.

STAT\_RX\_STATUS\_REG1: 0404

Table 117: STAT\_RX\_STATUS\_REG1: 0404

| Bits | Default | Туре  | Signal                                    |
|------|---------|-------|-------------------------------------------|
| 0    | 0       | RO LL | stat_rx_status                            |
| 4    | 0       | RO LH | stat_rx_hi_ber                            |
| 5    | 0       | RO LH | stat_rx_remote_fault <sup>1</sup>         |
| 6    | 0       | RO LH | stat_rx_local_fault                       |
| 7    | 0       | RO LH | stat_rx_internal_local_fault <sup>1</sup> |
| 8    | 0       | RO LH | stat_rx_received_local_fault <sup>1</sup> |
| 9    | 0       | RO LH | stat_rx_bad_preamble <sup>1</sup>         |



Table 117: STAT\_RX\_STATUS\_REG1: 0404 (cont'd)

| Bits | Default | Туре  | Signal                             |
|------|---------|-------|------------------------------------|
| 10   | 0       | RO LH | stat_rx_bad_sfd <sup>1</sup>       |
| 11   | 0       | RO LH | stat_rx_got_signal_os <sup>1</sup> |

#### Notes:

STAT\_STATUS\_REG1: 0408

Table 118: STAT\_STATUS\_REG1: 0408

| Bits | Default | Туре  | Signal                          |
|------|---------|-------|---------------------------------|
| 0    | 0       | RO LH | stat_tx_fifo_error <sup>1</sup> |
| 4    | 0       | RO LH | stat_tx_ptp_fifo_read_error     |
| 5    | 0       | RO LH | stat_tx_ptp_fifo_write_error    |
| 16   | 0       | RO LH | stat_rx_fifo_error <sup>1</sup> |

#### Notes:

### STAT\_RX\_BLOCK\_LOCK\_REG: 040C

Table 119: STAT\_RX\_BLOCK\_LOCK\_REG: 040C

| Bits | Default | Туре  | Signal             |
|------|---------|-------|--------------------|
| 0    | 1       | RO LL | stat_rx_block_lock |

### STAT\_RX\_RSFEC\_STATUS\_REG: 043C

Table 120: STAT\_RX\_RSFEC\_STATUS\_REG: 043C

| Bits | Default | Туре  | Signal                              |
|------|---------|-------|-------------------------------------|
| 0    | 1       | RO LL | stat_rx_rsfec_lane_alignment_status |
| 1    | 1       | RO LL | stat_rx_rsfec_hi_ser                |

### STAT\_RX\_FEC\_STATUS\_REG: 0448

Table 121: STAT\_RX\_FEC\_STATUS\_REG: 0448

| Bits | Default | Туре  | Signal              |
|------|---------|-------|---------------------|
| 0    | 1       | RO LL | stat_fec_rx_lock    |
| 16   | 1       | RO LL | stat_fec_lock_error |

<sup>1.</sup> Only in MAC+PCS variant.

<sup>1.</sup> Only in PCS variant.



# STAT\_TX\_RSFEC\_STATUS\_REG: 044C

Table 122: STAT\_TX\_RSFEC\_STATUS\_REG: 044C

| Bits | Default | Туре  | Signal                              |
|------|---------|-------|-------------------------------------|
| 0    | 1       | RO LL | stat_tx_rsfec_lane_alignment_status |

# STAT\_TX\_FLOW\_CONTROL\_REG1: 0450

Table 123: STAT\_TX\_FLOW\_CONTROL\_REG1: 0450

|   | Bits | Default | Туре  | Signal              |
|---|------|---------|-------|---------------------|
| Γ | 8:0  | 0       | RO LH | stat_tx_pause_valid |

# STAT\_RX\_FLOW\_CONTROL\_REG1: 0454

Table 124: STAT\_RX\_FLOW\_CONTROL\_REG1: 0454

| Bits | Default | Туре  | Signal              |
|------|---------|-------|---------------------|
| 8:0  | 0       | RO LH | stat_rx_pause_req   |
| 17:9 | 0       | RO LH | stat_rx_pause_valid |

# STAT\_AN\_STATUS: 0458

*Table 125:* **STAT\_AN\_STATUS: 0458** 

| Bits  | Default | Туре  | Signal                            |
|-------|---------|-------|-----------------------------------|
| 0     | 0       | RO    | stat_an_fec_enable                |
| 1     | 0       | RO    | stat_an_rs_fec_enable             |
| 2     | 0       | RO    | stat_an_autoneg_complete          |
| 3     | 0       | RO    | stat_an_parallel_detection_fault  |
| 4     | 0       | RO    | stat_an_tx_pause_enable           |
| 5     | 0       | RO    | stat_an_rx_pause_enable           |
| 6     | 0       | RO LH | stat_an_lp_ability_valid          |
| 7     | 0       | RO    | stat_an_lp_autoneg_able           |
| 8     | 0       | RO    | stat_an_lp_pause                  |
| 9     | 0       | RO    | stat_an_lp_asm_dir                |
| 10    | 0       | RO    | stat_an_lp_rf                     |
| 11    | 0       | RO    | stat_an_lp_fec_10g_ability        |
| 12    | 0       | RO    | stat_an_lp_fec_10g_request        |
| 13    | 0       | RO LH | stat_an_lp_extended_ability_valid |
| 17:14 | 0       | RO    | stat_an_lp_ability_extended_fec   |
| 18    | 0       | RO    | stat_an_lp_fec_25g_rs_request     |



Table 125: STAT\_AN\_STATUS: 0458 (cont'd)

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 19   | 0       | RO   | stat_an_lp_fec_25g_baser_request |

STAT\_AN\_ABILITY: 045C

Table 126: STAT\_AN\_ABILITY: 045C

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 0    | 0       | RO   | stat_an_lp_ability_1000base_kx     |
| 1    | 0       | RO   | stat_an_lp_ability_10gbase_kx4     |
| 2    | 0       | RO   | stat_an_lp_ability_10gbase_kr      |
| 3    | 0       | RO   | stat_an_lp_ability_40gbase_kr4     |
| 4    | 0       | RO   | stat_an_lp_ability_40gbase_cr4     |
| 5    | 0       | RO   | stat_an_lp_ability_100gbase_cr10   |
| 6    | 0       | RO   | stat_an_lp_ability_100gbase_kp4    |
| 7    | 0       | RO   | stat_an_lp_ability_100gbase_kr4    |
| 8    | 0       | RO   | stat_an_lp_ability_100gbase_cr4    |
| 9    | 0       | RO   | stat_an_lp_ability_25gbase_krcr_s  |
| 10   | 0       | RO   | stat_an_lp_ability_25gbase_krcr    |
| 11   | 0       | RO   | stat_an_lp_ability_2_5gbase_kx     |
| 12   | 0       | RO   | stat_an_lp_ability_5gbase_kr       |
| 13   | 0       | RO   | stat_an_lp_ability_50gbase_krcr    |
| 14   | 0       | RO   | stat_an_lp_ability_100gbase_kr2cr2 |
| 15   | 0       | RO   | stat_an_lp_ability_200gbase_kr4cr4 |
| 16   | 0       | RO   | stat_an_lp_ability_25gbase_kr1     |
| 17   | 0       | RO   | stat_an_lp_ability_25gbase_cr1     |
| 18   | 0       | RO   | stat_an_lp_ability_50gbase_kr2     |
| 19   | 0       | RO   | stat_an_lp_ability_50gbase_cr2     |

STAT\_AN\_LINK\_CTL: 0460

Table 127: STAT\_AN\_LINK\_CTL: 0460

| Bits  | Default | Туре | Signal                          |
|-------|---------|------|---------------------------------|
| 1:0   | 0       | RO   | stat_an_link_cntl_1000base_kx   |
| 3:2   | 0       | RO   | stat_an_link_cntl_10gbase_kx4   |
| 5:4   | 0       | RO   | stat_an_link_cntl_10gbase_kr    |
| 7:6   | 0       | RO   | stat_an_link_cntl_40gbase_kr4   |
| 9:8   | 0       | RO   | stat_an_link_cntl_40gbase_cr4   |
| 11:10 | 0       | RO   | stat_an_link_cntl_100gbase_cr10 |
| 13:12 | 0       | RO   | stat_an_link_cntl_100gbase_kp4  |



Table 127: STAT\_AN\_LINK\_CTL: 0460 (cont'd)

| Bits  | Default | Туре | Signal                            |
|-------|---------|------|-----------------------------------|
| 15:14 | 0       | RO   | stat_an_link_cntl_100gbase_kr4    |
| 17:16 | 0       | RO   | stat_an_link_cntl_100gbase_cr4    |
| 19:18 | 0       | RO   | stat_an_link_cntl_25gbase_krcr_s  |
| 21:20 | 0       | RO   | stat_an_link_cntl_25gbase_krcr    |
| 23:22 | 0       | RO   | stat_an_link_cntl_2_5gbase_kx     |
| 25:24 | 0       | RO   | stat_an_link_cntl_5gbase_kr       |
| 27:26 | 0       | RO   | stat_an_link_cntl_50gbase_krcr    |
| 29:28 | 0       | RO   | stat_an_link_cntl_100gbase_kr2cr2 |
| 31:30 | 0       | RO   | stat_an_link_cntl_200gbase_kr4cr4 |

STAT\_AN\_LINK\_CTL2: 09F0

Table 128: STAT\_AN\_LINK\_CTL2: 09F0

| Bits | Default | Туре | Signal                        |
|------|---------|------|-------------------------------|
| 1:0  | 0       | RO   | stat_an_link_cntl_25gbase_kr1 |
| 3:2  | 0       | RO   | stat_an_link_cntl_25gbase_cr1 |
| 5:4  | 0       | RO   | stat_an_link_cntl_50gbase_kr2 |
| 7:6  | 0       | RO   | stat_an_link_cntl_50gbase_cr2 |

STAT\_LT\_STATUS\_REG1: 0464

Table 129: STAT\_LT\_STATUS\_REG1: 0464

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 0    | 0       | RO   | stat_lt_initialize_from_rx |
| 16   | 0       | RO   | stat_lt_preset_from_rx     |

STAT\_LT\_STATUS\_REG2: 0468

Table 130: STAT\_LT\_STATUS\_REG2: 0468

| Bits | Default | Туре | Signal             |
|------|---------|------|--------------------|
| 0    | 0       | RO   | stat_lt_training   |
| 16   | 0       | RO   | stat_lt_frame_lock |



# STAT\_LT\_STATUS\_REG3: 046C

Table 131: STAT\_LT\_STATUS\_REG3: 046C

| Bits | Default | Туре | Signal                |
|------|---------|------|-----------------------|
| 0    | 0       | RO   | stat_lt_signal_detect |
| 16   | 0       | RO   | stat_lt_training_fail |

# STAT\_LT\_STATUS\_REG4: 0470

#### Table 132: STAT\_LT\_STATUS\_REG4: 0470

| Bits | Default | Туре  | Signal         |
|------|---------|-------|----------------|
| 0    | 0       | RO LH | stat_lt_rx_sof |

#### STAT LT COEFFICIENTO REG: 0474

# Table 133: STAT\_LT\_COEFFICIENTO\_REG: 0474

| Bits  | Default | Туре | Signal                   |
|-------|---------|------|--------------------------|
| 1:0   | 0       | RO   | stat_lt_k_p1_from_rx0    |
| 3:2   | 0       | RO   | stat_lt_k0_from_rx0      |
| 5:4   | 0       | RO   | stat_lt_k_m1_from_rx0    |
| 7:6   | 0       | RO   | stat_lt_stat_p1_from_rx0 |
| 9:8   | 0       | RO   | stat_lt_stat0_from_rx0   |
| 11:10 | 0       | RO   | stat_lt_stat_m1_from_rx0 |

### STAT\_RX\_VALID\_CTRL\_CODE: 0494

Table 134: STAT\_RX\_VALID\_CTRL\_CODE: 0494

| Bits | Default | Туре  | Signal                  |
|------|---------|-------|-------------------------|
| 0    | 0       | RO LH | stat_rx_valid_ctrl_code |

### STAT\_CORE\_SPEED\_REG: 0498

Table 135: STAT\_CORE\_SPEED\_REG: 0498

| Bits | Default           | Туре | Signal          |
|------|-------------------|------|-----------------|
| 0    | GUI<br>configured | RO   | stat_core_speed |



Table 135: STAT\_CORE\_SPEED\_REG: 0498 (cont'd)

| Bits | Default           | Туре | Signal             |
|------|-------------------|------|--------------------|
| 1    | GUI<br>configured | RO   | runtime_switchable |

#### Notes:

1. This register will be available only for the 64-bit AXI4-Stream datapath interface.

00 - Standalone 25G

01 - Standalone 10G

10 - Runtime Switchable 25G

11 - Runtime Switchable 10G

STAT\_TSN\_REG: 0x049C

Table 136: STAT\_TSN\_REG: 0x049C

| Bits | Default | Туре | Signal            |
|------|---------|------|-------------------|
| 1:0  | 0       | RO   | stat_tx_mm_verify |

STAT GT WIZ REG: 04A0

Table 137: STAT\_GT\_WIZ\_REG: 04A0

| Bits | Default | Туре | Signal              |
|------|---------|------|---------------------|
| 0    | 0       | RO   | gtwiz_reset_tx_done |
| 1    | 0       | RO   | gtwiz_reset_rx_done |

#### Notes:

- 1. This register indicates that the GT is out of reset and the recovered TX/RX clocks are stable.
- 2. The user needs to first read 0x04A0 register (STAT\_GT\_WIZ\_REG) and wait till the value is 2'b11. Then, perform the next operations such as reading the Block Lock register (0x040C).

### **Statistics Counters**

The following tables define the bit assignments for the statistics counters.

A description of each signal is found in Port Descriptions - MAC+PCS Variant.



# STATUS\_CYCLE\_COUNT\_LSB: 0500

### Table 138: STATUS\_CYCLE\_COUNT\_LSB: 0500

| Bits | Default | Туре    | Signal                 |
|------|---------|---------|------------------------|
| 31:0 | 0       | RO HIST | stat_cycle_count[31:0] |

# STATUS\_CYCLE\_COUNT\_MSB: 0504

#### Table 139: STATUS\_CYCLE\_COUNT\_MSB: 0504

| Bits | Default | Туре    | Signal                  |
|------|---------|---------|-------------------------|
| 15:0 | 0       | RO HIST | stat_cycle_count[47:32] |

# STAT\_RX\_FRAMING\_ERR\_LSB: 0648

# Table 140: STAT\_RX\_FRAMING\_ERR\_LSB: 0648

| Bits | Default | Туре | Signal                          |
|------|---------|------|---------------------------------|
| 31:0 | 0       | HIST | stat_rx_framing_err_count[31:0] |

# STAT RX FRAMING ERR MSB: 064C

### Table 141: STAT\_RX\_FRAMING\_ERR\_MSB: 064C

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 15:0 | 0       | HIST | stat_rx_framing_err_count[48-1:32] |

### STAT\_RX\_BAD\_CODE\_LSB: 0660

#### Table 142: STAT\_RX\_BAD\_CODE\_LSB: 0660

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 31:0 | 0       | HIST | stat_rx_bad_code_count[31:0] |

#### STAT RX BAD CODE MSB: 0664

### Table 143: STAT\_RX\_BAD\_CODE\_MSB: 0664

| Bits | Default | Туре | Signal                        |
|------|---------|------|-------------------------------|
| 15:0 | 0       | HIST | stat_rx_bad_code_count[47:32] |



# STAT\_RX\_ERROR\_LSB: 0668

### Table 144: STAT\_RX\_ERROR\_LSB: 0668

|   | Bits | Default | Туре | Signal                    |
|---|------|---------|------|---------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_error_count[31:0] |

# STAT\_RX\_ERROR\_MSB: 066C

#### Table 145: STAT\_RX\_ERROR\_MSB: 066C

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 15:0 | 0       | HIST | stat_rx_error_count[47:32] |

# STAT RX RSFEC CORRECTED CW INC LSB: 0670

#### Table 146: STAT\_RX\_RSFEC\_CORRECTED\_CW\_INC\_LSB: 0670

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| I | 31:0 | 0       | HIST | stat_rx_rsfec_corrected_cw_inc_count[31:0] |

# STAT\_RX\_RSFEC\_CORRECTED\_CW\_INC\_MSB: 0674

#### Table 147: STAT RX RSFEC CORRECTED CW INC MSB: 0674

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| I | 15:0 | 0       | HIST | stat_rx_rsfec_corrected_cw_inc_count[47:32] |

### STAT\_RX\_RSFEC\_UNCORRECTED\_CW\_INC\_LSB: 0678

# Table 148: STAT\_RX\_RSFEC\_UNCORRECTED\_CW\_INC\_LSB: 0678

|   | Bits | Default | Туре | Signal                                       |
|---|------|---------|------|----------------------------------------------|
| Γ | 31:0 | 0       | HIST | stat_rx_rsfec_uncorrected_cw_inc_count[31:0] |

#### STAT RX RSFEC UNCORRECTED CW INC MSB: 067C

### Table 149: STAT\_RX\_RSFEC\_UNCORRECTED\_CW\_INC\_MSB: 067C

|   | Bits | Default | Туре | Signal                                        |
|---|------|---------|------|-----------------------------------------------|
| ſ | 15:0 | 0       | HIST | stat_rx_rsfec_uncorrected_cw_inc_count[47:32] |



# STAT\_RX\_RSFEC\_ERR\_COUNTO\_INC\_LSB: 0680

### Table 150: STAT\_RX\_RSFEC\_ERR\_COUNTO\_INC\_LSB: 0680

|   | Bits | Default | Туре | Signal                                  |
|---|------|---------|------|-----------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_rsfec_err_count_inc_count[31:0] |

# STAT\_RX\_RSFEC\_ERR\_COUNTO\_INC\_MSB: 0684

#### Table 151: STAT\_RX\_RSFEC\_ERR\_COUNTO\_INC\_MSB: 0684

| Bits | Default | Туре | Signal                                   |
|------|---------|------|------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_rsfec_err_count_inc_count[47:32] |

# STAT\_TX FRAME ERROR LSB: 06A0

#### Table 152: STAT\_TX\_FRAME\_ERROR\_LSB: 06A0

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| Г | 31:0 | 0       | HIST | stat_tx_frame_error_count[31:0] |

# STAT\_TX\_FRAME\_ERROR\_MSB: 06A4

### Table 153: STAT\_TX\_FRAME\_ERROR\_MSB: 06A4

|   | Bits | Default | Туре | Signal                           |
|---|------|---------|------|----------------------------------|
| ſ | 15:0 | 0       | HIST | stat_tx_frame_error_count[47:32] |

### STAT\_TX\_TOTAL\_PACKETS\_LSB: 0700

#### Table 154: STAT\_TX\_TOTAL\_PACKETS\_LSB: 0700

|   | Bits | Default | Туре | Signal                            |
|---|------|---------|------|-----------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_total_packets_count[31:0] |

#### STAT\_TX\_TOTAL\_PACKETS\_MSB: 0704

### Table 155: STAT\_TX\_TOTAL\_PACKETS\_MSB: 0704

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 15:0 | 0       | HIST | stat_tx_total_packets_count[47:32] |



# STAT\_TX\_TOTAL\_GOOD\_PACKETS\_LSB: 0708

### Table 156: STAT\_TX\_TOTAL\_GOOD\_PACKETS\_LSB: 0708

|   | Bits | Default | Туре | Signal                                 |
|---|------|---------|------|----------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_total_good_packets_count[31:0] |

# STAT\_TX\_TOTAL\_GOOD\_PACKETS\_MSB: 070C

#### Table 157: STAT\_TX\_TOTAL\_GOOD\_PACKETS\_MSB: 070C

| Bits | Default | Туре | Signal                                  |
|------|---------|------|-----------------------------------------|
| 15:0 | 0       | HIST | stat_tx_total_good_packets_count[47:32] |

# STAT\_TX\_TOTAL\_BYTES\_LSB: 0710

#### Table 158: STAT\_TX\_TOTAL\_BYTES\_LSB: 0710

| Bits | Default | Туре | Signal                          |
|------|---------|------|---------------------------------|
| 31:0 | 0       | HIST | stat_tx_total_bytes_count[31:0] |

# STAT\_TX\_TOTAL\_BYTES\_MSB: 0714

### Table 159: STAT\_TX\_TOTAL\_BYTES\_MSB: 0714

|   | Bits | Default | Туре | Signal                           |
|---|------|---------|------|----------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_total_bytes_count[47:32] |

### STAT\_TX\_TOTAL\_GOOD\_BYTES\_LSB: 0718

#### Table 160: STAT\_TX\_TOTAL\_GOOD\_BYTES\_LSB: 0718

| Bits | Default | Туре | Signal                               |
|------|---------|------|--------------------------------------|
| 31:0 | 0       | HIST | stat_tx_total_good_bytes_count[31:0] |

#### STAT TX TOTAL GOOD BYTES MSB: 071C

### Table 161: STAT\_TX\_TOTAL\_GOOD\_BYTES\_MSB: 071C

|   | Bits | Default | Туре | Signal                                |
|---|------|---------|------|---------------------------------------|
| - | 15:0 | 0       | HIST | stat_tx_total_good_bytes_count[47:32] |



# STAT\_TX\_PACKET\_64\_BYTES\_LSB: 0720

### Table 162: STAT\_TX\_PACKET\_64\_BYTES\_LSB: 0720

| Bits | Default | Туре | Signal                              |
|------|---------|------|-------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_64_bytes_count[31:0] |

# STAT\_TX\_PACKET\_64\_BYTES\_MSB: 0724

#### Table 163: STAT\_TX\_PACKET\_64\_BYTES\_MSB: 0724

| Bits | Default | Туре | Signal                               |
|------|---------|------|--------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_64_bytes_count[47:32] |

# STAT TX PACKET 65 127 BYTES LSB: 0728

#### *Table 164:* **STAT\_TX\_PACKET\_65\_127\_BYTES\_LSB: 0728**

| Bits | Default | Туре | Signal                                  |
|------|---------|------|-----------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_65_127_bytes_count[31:0] |

# STAT\_TX\_PACKET\_65\_127\_BYTES\_MSB: 072C

# Table 165: STAT\_TX\_PACKET\_65\_127\_BYTES\_MSB: 072C

| Bits | Default | Туре | Signal                                   |
|------|---------|------|------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_65_127_bytes_count[47:32] |

### STAT\_TX\_PACKET\_128\_255\_BYTES\_LSB: 0730

### *Table 166:* **STAT\_TX\_PACKET\_128\_255\_BYTES\_LSB: 0730**

| Bits | Default | Туре | Signal                                   |
|------|---------|------|------------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_128_255_bytes_count[31:0] |

#### STAT TX PACKET 128 255 BYTES MSB: 0734

### Table 167: STAT\_TX\_PACKET\_128\_255\_BYTES\_MSB: 0734

|   | Bits | Default | Туре | Signal                                    |
|---|------|---------|------|-------------------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_packet_128_255_bytes_count[47:32] |



# STAT\_TX\_PACKET\_256\_511\_BYTES\_LSB: 0738

### Table 168: STAT\_TX\_PACKET\_256\_511\_BYTES\_LSB: 0738

|   | Bits | Default | Туре | Signal                                   |
|---|------|---------|------|------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_256_511_bytes_count[31:0] |

# STAT\_TX\_PACKET\_256\_511\_BYTES\_MSB: 073C

#### Table 169: STAT\_TX\_PACKET\_256\_511\_BYTES\_MSB: 073C

| Bits | Default | Туре | Signal                                    |
|------|---------|------|-------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_256_511_bytes_count[47:32] |

# **STAT TX PACKET 512 1023 BYTES LSB: 0740**

#### Table 170: STAT\_TX\_PACKET\_512\_1023\_BYTES\_LSB: 0740

| Bits | Default | Туре | Signal                                    |
|------|---------|------|-------------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_512_1023_bytes_count[31:0] |

# STAT\_TX\_PACKET\_512\_1023\_BYTES\_MSB: 0744

#### Table 171: STAT TX PACKET 512 1023 BYTES MSB: 0744

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_512_1023_bytes_count[47:32] |

### STAT\_TX\_PACKET\_1024\_1518\_BYTES\_LSB: 0748

#### Table 172: STAT\_TX\_PACKET\_1024\_1518\_BYTES\_LSB: 0748

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_1024_1518_bytes_count[31:0] |

#### STAT TX PACKET 1024 1518 BYTES MSB: 074C

### Table 173: STAT\_TX\_PACKET\_1024\_1518\_BYTES\_MSB: 074C

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| Γ | 15:0 | 0       | HIST | stat_tx_packet_1024_1518_bytes_count[47:32] |



# STAT\_TX\_PACKET\_1519\_1522\_BYTES\_LSB: 0750

### Table 174: STAT\_TX\_PACKET\_1519\_1522\_BYTES\_LSB: 0750

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_1519_1522_bytes_count[31:0] |

# STAT\_TX\_PACKET\_1519\_1522\_BYTES\_MSB: 0754

#### Table 175: STAT\_TX\_PACKET\_1519\_1522\_BYTES\_MSB: 0754

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_1519_1522_bytes_count[47:32] |

# STAT\_TX\_PACKET\_1523\_1548\_BYTES\_LSB: 0758

#### *Table 176:* **STAT\_TX\_PACKET\_1523\_1548\_BYTES\_LSB: 0758**

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_1523_1548_bytes_count[31:0] |

# STAT\_TX\_PACKET\_1523\_1548\_BYTES\_MSB: 075C

#### Table 177: STAT TX PACKET 1523 1548 BYTES MSB: 075C

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_1523_1548_bytes_count[47:32] |

### STAT\_TX\_PACKET\_1549\_2047\_BYTES\_LSB: 0760

#### Table 178: STAT\_TX\_PACKET\_1549\_2047\_BYTES\_LSB: 0760

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_1549_2047_bytes_count[31:0] |

#### STAT\_TX\_PACKET\_1549\_2047\_BYTES\_MSB: 0764

#### Table 179: STAT\_TX\_PACKET\_1549\_2047\_BYTES\_MSB: 0764

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| Γ | 15:0 | 0       | HIST | stat_tx_packet_1549_2047_bytes_count[47:32] |



#### **STAT TX PACKET 2048 4095 BYTES LSB: 0768**

### Table 180: STAT\_TX\_PACKET\_2048\_4095\_BYTES\_LSB: 0768

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_2048_4095_bytes_count[31:0] |

# STAT\_TX\_PACKET\_2048\_4095\_BYTES\_MSB: 076C

#### Table 181: STAT\_TX\_PACKET\_2048\_4095\_BYTES\_MSB: 076C

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_2048_4095_bytes_count[47:32] |

# STAT\_TX\_PACKET\_4096\_8191\_BYTES\_LSB: 0770

#### Table 182: STAT\_TX\_PACKET\_4096\_8191\_BYTES\_LSB: 0770

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_4096_8191_bytes_count[31:0] |

# STAT\_TX\_PACKET\_4096\_8191\_BYTES\_MSB: 0774

#### Table 183: STAT TX PACKET 4096 8191 BYTES MSB: 0774

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_4096_8191_bytes_count[47:32] |

### STAT\_TX\_PACKET\_8192\_9215\_BYTES\_LSB: 0778

#### Table 184: STAT\_TX\_PACKET\_8192\_9215\_BYTES\_LSB: 0778

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_8192_9215_bytes_count[31:0] |

#### STAT TX PACKET 8192 9215 BYTES MSB: 077C

#### Table 185: STAT\_TX\_PACKET\_8192\_9215\_BYTES\_MSB: 077C

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| Γ | 15:0 | 0       | HIST | stat_tx_packet_8192_9215_bytes_count[47:32] |



# STAT\_TX\_PACKET\_LARGE\_LSB: 0780

Table 186: STAT\_TX\_PACKET\_LARGE\_LSB: 0780

|   | Bits | Default | Туре | Signal                           |
|---|------|---------|------|----------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_packet_large_count[31:0] |

# STAT\_TX\_PACKET\_LARGE\_MSB: 0784

Table 187: STAT\_TX\_PACKET\_LARGE\_MSB: 0784

| Bits | Default | Туре | Signal                            |
|------|---------|------|-----------------------------------|
| 15:0 | 0       | HIST | stat_tx_packet_large_count[47:32] |

# STAT\_TX\_PACKET\_SMALL\_LSB: 0788

Table 188: STAT\_TX\_PACKET\_SMALL\_LSB: 0788

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 31:0 | 0       | HIST | stat_tx_packet_small_count[31:0] |

# STAT\_TX\_PACKET\_SMALL\_MSB: 078C

Table 189: STAT\_TX\_PACKET\_SMALL\_MSB: 078C

|   | Bits | Default | Туре | Signal                            |
|---|------|---------|------|-----------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_packet_small_count[47:32] |

### STAT\_TX\_BAD\_FCS\_LSB: 07B8

Table 190: STAT\_TX\_BAD\_FCS\_LSB: 07B8

|   | Bits | Default | Туре | Signal                      |
|---|------|---------|------|-----------------------------|
| - | 31:0 | 0       | HIST | stat_tx_bad_fcs_count[31:0] |

### STAT\_TX\_BAD\_FCS\_MSB: 07BC

Table 191: STAT\_TX\_BAD\_FCS\_MSB: 07BC

| ĺ | Bits | Default | Туре | Signal                       |
|---|------|---------|------|------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_bad_fcs_count[47:32] |



# STAT\_TX\_UNICAST\_LSB: 07D0

Table 192: STAT\_TX\_UNICAST\_LSB: 07D0

| Bits | Default | Туре | Signal                      |
|------|---------|------|-----------------------------|
| 31:0 | 0       | HIST | stat_tx_unicast_count[31:0] |

# STAT\_TX\_UNICAST\_MSB: 07D4

Table 193: STAT\_TX\_UNICAST\_MSB: 07D4

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 15:0 | 0       | HIST | stat_tx_unicast_count[47:32] |

# STAT\_TX\_MULTICAST\_LSB: 07D8

Table 194: STAT\_TX\_MULTICAST\_LSB: 07D8

| Bits | Default | Туре | Signal                        |
|------|---------|------|-------------------------------|
| 31:0 | 0       | HIST | stat_tx_multicast_count[31:0] |

# STAT\_TX\_MULTICAST\_MSB: 07DC

Table 195: STAT\_TX\_MULTICAST\_MSB: 07DC

|   | Bits | Default | Туре | Signal                         |
|---|------|---------|------|--------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_multicast_count[47:32] |

### STAT\_TX\_BROADCAST\_LSB: 07E0

Table 196: STAT\_TX\_BROADCAST\_LSB: 07E0

|   | Bits | Default | Туре | Signal                        |
|---|------|---------|------|-------------------------------|
| - | 31:0 | 0       | HIST | stat_tx_broadcast_count[31:0] |

### STAT\_TX\_BROADCAST\_MSB: 07E4

Table 197: STAT\_TX\_BROADCAST\_MSB: 07E4

|   | Bits | Default | Туре | Signal                         |
|---|------|---------|------|--------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_broadcast_count[47:32] |



STAT\_TX\_VLAN\_LSB: 07E8

Table 198: STAT\_TX\_VLAN\_LSB: 07E8

| Bits | Default | Туре | Signal                   |
|------|---------|------|--------------------------|
| 31:0 | 0       | HIST | stat_tx_vlan_count[31:0] |

STAT\_TX\_VLAN\_MSB: 07EC

Table 199: STAT\_TX\_VLAN\_MSB: 07EC

| ĺ | Bits | Default | Туре | Signal                    |
|---|------|---------|------|---------------------------|
|   | 15:0 | 0       | HIST | stat_tx_vlan_count[47:32] |

STAT\_TX\_PAUSE\_LSB: 07F0

Table 200: STAT\_TX\_PAUSE\_LSB: 07F0

|   | Bits | Default | Туре | Signal                    |
|---|------|---------|------|---------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_pause_count[31:0] |

STAT\_TX\_PAUSE\_MSB: 07F4

Table 201: STAT\_TX\_PAUSE\_MSB: 07F4

|   | Bits | Default | Туре | Signal                     |
|---|------|---------|------|----------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_pause_count[47:32] |

STAT\_TX\_USER\_PAUSE\_LSB: 07F8

Table 202: STAT\_TX\_USER\_PAUSE\_LSB: 07F8

|   | Bits | Default | Туре | Signal                         |
|---|------|---------|------|--------------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_user_pause_count[31:0] |

STAT\_TX\_USER\_PAUSE\_MSB: 07FC

Table 203: STAT\_TX\_USER\_PAUSE\_MSB: 07FC

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_tx_user_pause_count[47:32] |



# STAT\_RX\_TOTAL\_PACKETS\_LSB: 0808

### Table 204: STAT\_RX\_TOTAL\_PACKETS\_LSB: 0808

|   | Bits | Default | Туре | Signal                            |
|---|------|---------|------|-----------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_total_packets_count[31:0] |

# STAT\_RX\_TOTAL\_PACKETS\_MSB: 080C

#### Table 205: STAT\_RX\_TOTAL\_PACKETS\_MSB: 080C

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 15:0 | 0       | HIST | stat_rx_total_packets_count[47:32] |

# STAT RX TOTAL GOOD PACKETS LSB: 0810

#### Table 206: STAT\_RX\_TOTAL\_GOOD\_PACKETS\_LSB: 0810

| Bits | Default | Туре | Signal                                 |
|------|---------|------|----------------------------------------|
| 31:0 | 0       | HIST | stat_rx_total_good_packets_count[31:0] |

# STAT RX TOTAL GOOD PACKETS MSB: 0814

### Table 207: STAT\_RX\_TOTAL\_GOOD\_PACKETS\_MSB: 0814

| Bits | Default | Туре | Signal                                  |
|------|---------|------|-----------------------------------------|
| 15:0 | 0       | HIST | stat_rx_total_good_packets_count[47:32] |

### STAT\_RX\_TOTAL\_BYTES\_LSB: 0818

# Table 208: STAT\_RX\_TOTAL\_BYTES\_LSB: 0818

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_total_bytes_count[31:0] |

#### STAT\_RX\_TOTAL\_BYTES\_MSB: 081C

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 15:0 | 0       | HIST | stat_rx_total_bytes_count[47:32] |



#### STAT RX TOTAL GOOD BYTES LSB: 0820

### Table 209: STAT\_RX\_TOTAL\_GOOD\_BYTES\_LSB: 0820

| Bits | Default | Туре | Signal                               |
|------|---------|------|--------------------------------------|
| 31:0 | 0       | HIST | stat_rx_total_good_bytes_count[31:0] |

# STAT\_RX\_TOTAL\_GOOD\_BYTES\_MSB: 0824

#### Table 210: STAT\_RX\_TOTAL\_GOOD\_BYTES\_MSB: 0824

| Bits | Default | Туре | Signal                                |
|------|---------|------|---------------------------------------|
| 15:0 | 0       | HIST | stat_rx_total_good_bytes_count[47:32] |

# STAT RX PACKET 64 BYTES LSB: 0828

#### Table 211: STAT\_RX\_PACKET\_64\_BYTES\_LSB: 0828

| Bits | Default | Туре | Signal                              |
|------|---------|------|-------------------------------------|
| 31:0 | 0       | HIST | stat_rx_packet_64_bytes_count[31:0] |

# STAT\_RX\_PACKET\_64\_BYTES\_MSB: 082C

#### Table 212: STAT RX PACKET 64 BYTES MSB: 082C

| ĺ | Bits | Default | Туре | Signal                               |
|---|------|---------|------|--------------------------------------|
| I | 15:0 | 0       | HIST | stat_rx_packet_64_bytes_count[47:32] |

### STAT\_RX\_PACKET\_65\_127\_BYTES\_LSB: 0830

#### *Table 213:* **STAT\_RX\_PACKET\_65\_127\_BYTES\_LSB: 0830**

|   | Bits | Default | Туре | Signal                                  |
|---|------|---------|------|-----------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_65_127_bytes_count[31:0] |

#### STAT RX PACKET 65 127 BYTES MSB: 0834

### Table 214: STAT\_RX\_PACKET\_65\_127\_BYTES\_MSB: 0834

| Bits | Default | Туре | Signal                                   |
|------|---------|------|------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_65_127_bytes_count[47:32] |



# STAT\_RX\_PACKET\_128\_255\_BYTES\_LSB: 0838

### *Table 215:* **STAT\_RX\_PACKET\_128\_255\_BYTES\_LSB: 0838**

|   | Bits | Default | Туре | Signal                                   |
|---|------|---------|------|------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_128_255_bytes_count[31:0] |

# STAT\_RX\_PACKET\_128\_255\_BYTES\_MSB: 083C

#### Table 216: STAT\_RX\_PACKET\_128\_255\_BYTES\_MSB: 083C

| Bits | Default | Туре | Signal                                    |
|------|---------|------|-------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_128_255_bytes_count[47:32] |

# STAT RX PACKET 256 511 BYTES LSB: 0840

#### Table 217: STAT\_RX\_PACKET\_256\_511\_BYTES\_LSB: 0840

| Bits | Default | Туре | Signal                                   |
|------|---------|------|------------------------------------------|
| 31:0 | 0       | HIST | stat_rx_packet_256_511_bytes_count[31:0] |

# STAT RX PACKET 256 511 BYTES MSB: 0844

#### Table 218: STAT RX PACKET 256 511 BYTES MSB: 0844

|   | Bits | Default | Туре | Signal                                    |
|---|------|---------|------|-------------------------------------------|
| ſ | 15:0 | 0       | HIST | stat_rx_packet_256_511_bytes_count[47:32] |

### STAT\_RX\_PACKET\_512\_1023\_BYTES\_LSB: 0848

### Table 219: STAT\_RX\_PACKET\_512\_1023\_BYTES\_LSB: 0848

|   | Bits | Default | Туре | Signal                                    |
|---|------|---------|------|-------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_512_1023_bytes_count[31:0] |

#### STAT RX PACKET 512 1023 BYTES MSB: 084C

### Table 220: STAT\_RX\_PACKET\_512\_1023\_BYTES\_MSB: 084C

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_512_1023_bytes_count[47:32] |



#### STAT\_RX\_PACKET\_1024\_1518\_BYTES\_LSB: 0850

#### *Table 221:* **STAT\_RX\_PACKET\_1024\_1518\_BYTES\_LSB: 0850**

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_1024_1518_bytes_count[31:0] |

#### STAT\_RX\_PACKET\_1024\_1518\_BYTES\_MSB: 0854

#### Table 222: STAT\_RX\_PACKET\_1024\_1518\_BYTES\_MSB: 0854

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_1024_1518_bytes_count[47:32] |

#### STAT RX PACKET 1519 1522 BYTES LSB: 0858

#### Table 223: STAT\_RX\_PACKET\_1519\_1522\_BYTES\_LSB: 0858

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 31:0 | 0       | HIST | stat_rx_packet_1519_1522_bytes_count[31:0] |

#### STAT\_RX\_PACKET\_1519\_1522\_BYTES\_MSB: 085C

#### Table 224: STAT RX PACKET 1519 1522 BYTES MSB: 085C

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_1519_1522_bytes_count[47:32] |

#### STAT\_RX\_PACKET\_1523\_1548\_BYTES\_LSB: 0860

#### Table 225: STAT\_RX\_PACKET\_1523\_1548\_BYTES\_LSB: 0860

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_1523_1548_bytes_count[31:0] |

#### STAT RX PACKET 1523 1548 BYTES MSB: 0864

#### Table 226: STAT\_RX\_PACKET\_1523\_1548\_BYTES\_MSB: 0864

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| ſ | 15:0 | 0       | HIST | stat_rx_packet_1523_1548_bytes_count[47:32] |



#### **STAT RX PACKET 1549 2047 BYTES LSB: 0868**

#### Table 227: STAT\_RX\_PACKET\_1549\_2047\_BYTES\_LSB: 0868

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_1549_2047_bytes_count[31:0] |

#### STAT\_RX\_PACKET\_1549\_2047\_BYTES\_MSB: 086C

#### Table 228: STAT\_RX\_PACKET\_1549\_2047\_BYTES\_MSB: 086C

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_1549_2047_bytes_count[47:32] |

#### **STAT RX PACKET 2048 4095 BYTES LSB: 0870**

#### Table 229: STAT\_RX\_PACKET\_2048\_4095\_BYTES\_LSB: 0870

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 31:0 | 0       | HIST | stat_rx_packet_2048_4095_bytes_count[31:0] |

#### STAT\_RX\_PACKET\_2048\_4095\_BYTES\_MSB: 0874

#### Table 230: STAT RX PACKET 2048 4095 BYTES MSB: 0874

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_2048_4095_bytes_count[47:32] |

#### STAT\_RX\_PACKET\_4096\_8191\_BYTES\_LSB: 0878

#### Table 231: STAT\_RX\_PACKET\_4096\_8191\_BYTES\_LSB: 0878

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ĺ | 31:0 | 0       | HIST | stat_rx_packet_4096_8191_bytes_count[31:0] |

#### STAT RX PACKET 4096 8191 BYTES MSB: 087C

#### Table 232: STAT\_RX\_PACKET\_4096\_8191\_BYTES\_MSB: 087C

|   | Bits | Default | Туре | Signal                                      |
|---|------|---------|------|---------------------------------------------|
| - | 15:0 | 0       | HIST | stat_rx_packet_4096_8191_bytes_count[47:32] |



#### STAT\_RX\_PACKET\_8192\_9215\_BYTES\_LSB: 0880

#### Table 233: STAT\_RX\_PACKET\_8192\_9215\_BYTES\_LSB: 0880

|   | Bits | Default | Туре | Signal                                     |
|---|------|---------|------|--------------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_8192_9215_bytes_count[31:0] |

#### STAT\_RX\_PACKET\_8192\_9215\_BYTES\_MSB: 0884

#### Table 234: STAT\_RX\_PACKET\_8192\_9215\_BYTES\_MSB: 0884

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_8192_9215_bytes_count[47:32] |

#### STAT RX PACKET LARGE LSB: 0888

#### Table 235: STAT\_RX\_PACKET\_LARGE\_LSB: 0888

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 31:0 | 0       | HIST | stat_rx_packet_large_count[31:0] |

#### STAT RX PACKET LARGE MSB: 088C

#### Table 236: STAT RX PACKET LARGE MSB: 088C

| Bits | Default | Туре | Signal                            |
|------|---------|------|-----------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_large_count[47:32] |

#### STAT\_RX\_PACKET\_SMALL\_LSB: 0890

#### Table 237: STAT\_RX\_PACKET\_SMALL\_LSB: 0890

|   | Bits | Default | Туре | Signal                           |
|---|------|---------|------|----------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_small_count[31:0] |

#### STAT RX PACKET SMALL MSB: 0894

#### Table 238: STAT\_RX\_PACKET\_SMALL\_MSB: 0894

|   | Bits | Default | Туре | Signal                            |
|---|------|---------|------|-----------------------------------|
| - | 15:0 | 0       | HIST | stat_rx_packet_small_count[47:32] |



#### STAT\_RX\_UNDERSIZE\_LSB: 0898

#### Table 239: STAT\_RX\_UNDERSIZE\_LSB: 0898

|   | Bits | Default | Туре | Signal                        |
|---|------|---------|------|-------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_undersize_count[31:0] |

#### STAT\_RX\_UNDERSIZE\_MSB: 089C

#### Table 240: STAT\_RX\_UNDERSIZE\_MSB: 089C

| Bits | Default | Туре | Signal                         |
|------|---------|------|--------------------------------|
| 15:0 | 0       | HIST | stat_rx_undersize_count[47:32] |

#### STAT\_RX\_FRAGMENT\_LSB: 08A0

#### Table 241: STAT\_RX\_FRAGMENT\_LSB: 08A0

|   | Bits | Default | Туре | Signal                       |
|---|------|---------|------|------------------------------|
| ĺ | 31:0 | 0       | HIST | stat_rx_fragment_count[31:0] |

#### STAT\_RX\_FRAGMENT\_MSB: 08A4

#### Table 242: STAT\_RX\_FRAGMENT\_MSB: 08A4

| Bits | Default | Туре | Signal                        |
|------|---------|------|-------------------------------|
| 15:0 | 0       | HIST | stat_rx_fragment_count[47:32] |

#### STAT\_RX\_OVERSIZE\_LSB: 08A8

#### Table 243: STAT\_RX\_OVERSIZE\_LSB: 08A8

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 31:0 | 0       | HIST | stat_rx_oversize_count[31:0] |

#### STAT RX OVERSIZE MSB: 08AC

#### Table 244: STAT\_RX\_OVERSIZE\_MSB: 08AC

|   | Bits | Default | Туре | Signal                        |
|---|------|---------|------|-------------------------------|
| ı | 15:0 | 0       | HIST | stat_rx_oversize_count[47:32] |



#### STAT\_RX\_TOOLONG\_LSB: 08B0

Table 245: STAT\_RX\_TOOLONG\_LSB: 08B0

|   | Bits | Default | Туре | Signal                      |
|---|------|---------|------|-----------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_toolong_count[31:0] |

#### STAT\_RX\_TOOLONG\_MSB: 08B4

Table 246: STAT\_RX\_TOOLONG\_MSB: 08B4

| Bi | ts | Default | Туре | Signal                       |
|----|----|---------|------|------------------------------|
| 15 | :0 | 0       | HIST | stat_rx_toolong_count[47:32] |

#### STAT\_RX\_JABBER\_LSB: 08B8

Table 247: STAT\_RX\_JABBER\_LSB: 08B8

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 31:0 | 0       | HIST | stat_rx_jabber_count[31:0] |

#### STAT\_RX\_JABBER\_MSB: 08BC

Table 248: STAT\_RX\_JABBER\_MSB: 08BC

| Bits | Default | Туре | Signal                      |
|------|---------|------|-----------------------------|
| 15:0 | 0       | HIST | stat_rx_jabber_count[47:32] |

#### STAT\_RX\_BAD\_FCS\_LSB: 08C0

Table 249: STAT\_RX\_BAD\_FCS\_LSB: 08C0

|   | Bits | Default | Туре | Signal                      |
|---|------|---------|------|-----------------------------|
| - | 31:0 | 0       | HIST | stat_rx_bad_fcs_count[31:0] |

#### STAT\_RX\_BAD\_FCS\_MSB: 08C4

Table 250: STAT\_RX\_BAD\_FCS\_MSB: 08C4

| Bits | Default | Туре | Signal                       |
|------|---------|------|------------------------------|
| 15:0 | 0       | HIST | stat_rx_bad_fcs_count[47:32] |



#### STAT\_RX\_PACKET\_BAD\_FCS\_LSB: 08C8

Table 251: STAT\_RX\_PACKET\_BAD\_FCS\_LSB: 08C8

|   | Bits | Default | Туре | Signal                             |
|---|------|---------|------|------------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_packet_bad_fcs_count[31:0] |

#### STAT\_RX\_PACKET\_BAD\_FCS\_MSB: 08CC

#### Table 252: STAT\_RX\_PACKET\_BAD\_FCS\_MSB: 08CC

| Bits | Default | Туре | Signal                              |
|------|---------|------|-------------------------------------|
| 15:0 | 0       | HIST | stat_rx_packet_bad_fcs_count[47:32] |

#### STAT RX STOMPED FCS LSB: 08D0

#### Table 253: STAT\_RX\_STOMPED\_FCS\_LSB: 08D0

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| Γ | 31:0 | 0       | HIST | stat_rx_stomped_fcs_count[31:0] |

#### STAT RX STOMPED FCS MSB: 08D4

#### Table 254: STAT\_RX\_STOMPED\_FCS\_MSB: 08D4

| В | its | Default | Туре | Signal                           |
|---|-----|---------|------|----------------------------------|
| 1 | 5:0 | 0       | HIST | stat_rx_stomped_fcs_count[47:32] |

#### STAT\_RX\_UNICAST\_LSB: 08D8

#### Table 255: STAT\_RX\_UNICAST\_LSB: 08D8

|   | Bits | Default | Туре | Signal                      |
|---|------|---------|------|-----------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_unicast_count[31:0] |

#### STAT\_RX\_UNICAST\_MSB: 08DC

#### Table 256: STAT\_RX\_UNICAST\_MSB: 08DC

| ĺ | Bits | Default | Туре | Signal                       |
|---|------|---------|------|------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_rx_unicast_count[47:32] |



#### STAT\_RX\_MULTICAST\_LSB: 08E0

#### Table 257: STAT\_RX\_MULTICAST\_LSB: 08E0

|   | Bits | Default | Туре | Signal                        |
|---|------|---------|------|-------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_multicast_count[31:0] |

#### STAT\_RX\_MULTICAST\_MSB: 08E4

#### Table 258: STAT\_RX\_MULTICAST\_MSB: 08E4

| Bits | Default | Туре | Signal                         |
|------|---------|------|--------------------------------|
| 15:0 | 0       | HIST | stat_rx_multicast_count[47:32] |

#### STAT\_RX\_BROADCAST\_LSB: 08E8

#### Table 259: STAT\_RX\_BROADCAST\_LSB: 08E8

| Bits | Default | Туре | Signal                        |
|------|---------|------|-------------------------------|
| 31:0 | 0       | HIST | stat_rx_broadcast_count[31:0] |

#### STAT\_RX\_BROADCAST\_MSB: 08EC

#### Table 260: STAT\_RX\_BROADCAST\_MSB: 08EC

|   | Bits | Default | Туре | Signal                         |
|---|------|---------|------|--------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_rx_broadcast_count[47:32] |

#### STAT\_RX\_VLAN\_LSB: 08F0

#### Table 261: STAT\_RX\_VLAN\_LSB: 08F0

| Bits | Default | Туре | Signal                   |
|------|---------|------|--------------------------|
| 31:0 | 0       | HIST | stat_rx_vlan_count[31:0] |

#### STAT\_RX\_VLAN\_MSB: 08F4

#### Table 262: STAT\_RX\_VLAN\_MSB: 08F4

| Bits | Default | Туре | Signal                    |
|------|---------|------|---------------------------|
| 15:0 | 0       | HIST | stat_rx_vlan_count[47:32] |



#### STAT\_RX\_PAUSE\_LSB: 08F8

#### Table 263: STAT\_RX\_PAUSE\_LSB: 08F8

|   | Bits | Default | Туре | Signal                    |
|---|------|---------|------|---------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_pause_count[31:0] |

#### STAT\_RX\_PAUSE\_MSB: 08FC

#### Table 264: STAT\_RX\_PAUSE\_MSB: 08FC

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 15:0 | 0       | HIST | stat_rx_pause_count[47:32] |

#### STAT\_RX\_USER\_PAUSE\_LSB: 0900

#### Table 265: STAT\_RX\_USER\_PAUSE\_LSB: 0900

| Bits | Default | Туре | Signal                         |
|------|---------|------|--------------------------------|
| 31:0 | 0       | HIST | stat_rx_user_pause_count[31:0] |

#### STAT RX USER PAUSE MSB: 0904

#### Table 266: STAT\_RX\_USER\_PAUSE\_MSB: 0904

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| ĺ | 15:0 | 0       | HIST | stat_rx_user_pause_count[47:32] |

#### STAT\_RX\_INRANGEERR\_LSB: 0908

#### Table 267: STAT\_RX\_INRANGEERR\_LSB: 0908

|   | Bits | Default | Туре | Signal                         |
|---|------|---------|------|--------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_inrangeerr_count[31:0] |

#### STAT\_RX\_INRANGEERR\_MSB: 090C

#### Table 268: STAT\_RX\_INRANGEERR\_MSB: 090C

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| ſ | 15:0 | 0       | HIST | stat_rx_inrangeerr_count[47:32] |



#### STAT\_RX\_TRUNCATED\_LSB: 0910

#### Table 269: STAT\_RX\_TRUNCATED\_LSB: 0910

|   | Bits | Default | Туре | Signal                        |
|---|------|---------|------|-------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_truncated_count[31:0] |

#### STAT\_RX\_TRUNCATED\_MSB: 0914

#### Table 270: STAT\_RX\_TRUNCATED\_MSB: 0914

| Bits | Default | Туре | Signal                         |
|------|---------|------|--------------------------------|
| 15:0 | 0       | HIST | stat_rx_truncated_count[47:32] |

#### STAT\_RX\_TEST\_PATTERN\_MISMATCH\_LSB: 0918

#### Table 271: STAT\_RX\_TEST\_PATTERN\_MISMATCH\_LSB: 0918

| Bits | Default | Туре | Signal                                    |
|------|---------|------|-------------------------------------------|
| 31:0 | 0       | HIST | stat_rx_test_pattern_mismatch_count[31:0] |

#### STAT\_RX\_TEST\_PATTERN\_MISMATCH\_MSB: 091C

#### Table 272: STAT RX TEST PATTERN MISMATCH MSB: 091C

| Bits | Default | Туре | Signal                                     |
|------|---------|------|--------------------------------------------|
| 15:0 | 0       | HIST | stat_rx_test_pattern_mismatch_count[47:32] |

#### STAT\_FEC\_INC\_CORRECT\_COUNT\_LSB: 0920

#### Table 273: STAT\_FEC\_INC\_CORRECT\_COUNT\_LSB: 0920

|   | Bits | Default | Туре | Signal                                 |
|---|------|---------|------|----------------------------------------|
| ĺ | 31:0 | 0       | HIST | stat_fec_inc_correct_count_count[31:0] |

#### STAT FEC INC CORRECT COUNT MSB: 0924

#### Table 274: STAT\_FEC\_INC\_CORRECT\_COUNT\_MSB: 0924

|   | Bits | Default | Туре | Signal                                  |
|---|------|---------|------|-----------------------------------------|
| ſ | 15:0 | 0       | HIST | stat_fec_inc_correct_count_count[47:32] |



#### STAT\_FEC\_INC\_CANT\_CORRECT\_COUNT\_LSB: 0928

#### Table 275: STAT\_FEC\_INC\_CANT\_CORRECT\_COUNT\_LSB: 0928

| Bits | Default | Туре | Signal                                      |
|------|---------|------|---------------------------------------------|
| 31:0 | 0       | HIST | stat_fec_inc_cant_correct_count_count[31:0] |

#### STAT\_FEC\_INC\_CANT\_CORRECT\_COUNT\_MSB: 092C

#### Table 276: STAT\_FEC\_INC\_CANT\_CORRECT\_COUNT\_MSB: 092C

| Bits | Default | Туре | Signal                                       |
|------|---------|------|----------------------------------------------|
| 15:0 | 0       | HIST | stat_fec_inc_cant_correct_count_count[47:32] |

#### STAT\_TX MM STATUS LSB: 0x0980

#### Table 277: STAT\_TX\_MM\_STATUS\_LSB: 0x0980

| Bits | Default | Туре | Signal                  |
|------|---------|------|-------------------------|
| 31:0 | 0       | HIST | stat_tx_mm_status[31:0] |

#### STAT\_TX\_MM\_STATUS\_MSB: 0x0984

#### Table 278: STAT TX MM STATUS MSB: 0x0984

| Bits | Default | Туре | Signal                   |
|------|---------|------|--------------------------|
| 15:0 | 0       | HIST | stat_tx_mm_status[47:32] |

#### STAT\_TX\_MM\_STATUS\_LSB: 0x0988

#### Table 279: STAT\_TX\_MM\_STATUS\_LSB: 0x0988

|   | Bits | Default | Туре | Signal                    |
|---|------|---------|------|---------------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_mm_fragment[31:0] |

#### STAT\_TX\_MM\_FRAGMENT\_MSB: 0x098C

#### Table 280: STAT\_TX\_MM\_FRAGMENT\_MSB: 0x098C

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 15:0 | 0       | HIST | stat_tx_mm_fragment[47:32] |



#### STAT\_TX\_MM\_HOLD\_LSB: 0x0990

Table 281: STAT\_TX\_MM\_HOLD\_LSB: 0x0990

|   | Bits | Default | Туре | Signal                |
|---|------|---------|------|-----------------------|
| ſ | 31:0 | 0       | HIST | stat_tx_mm_hold[31:0] |

#### STAT\_TX\_MM\_HOLD\_MSB: 0x0994

Table 282: STAT\_TX\_MM\_HOLD\_MSB: 0x0994

| ĺ | Bits | Default | Туре | Signal                 |
|---|------|---------|------|------------------------|
|   | 15:0 | 0       | HIST | stat_tx_mm_hold[47:32] |

#### STAT\_RX\_MM\_ASSEMBLY\_ERROR\_LSB: 0x0998

Table 283: STAT\_RX\_MM\_ASSEMBLY\_ERROR\_LSB: 0x0998

|   | Bits | Default | Туре | Signal                          |
|---|------|---------|------|---------------------------------|
| ſ | 31:0 | 0       | HIST | stat_rx_mm_assembly_error[31:0] |

#### STAT\_RX\_MM\_ASSEMBLY\_ERROR\_MSB: 0x099C

Table 284: STAT RX MM ASSEMBLY ERROR MSB: 0x099C

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 15:0 | 0       | HIST | stat_rx_mm_assembly_error[47:32] |

#### STAT\_RX\_MM\_FRAME\_SMD\_ERROR\_LSB: 0x09A0

Table 285: STAT\_RX\_MM\_FRAME\_SMD\_ERROR\_LSB: 0x09A0

| Bits | Default | Туре | Signal                           |
|------|---------|------|----------------------------------|
| 31:0 | 0       | HIST | stat_rx_mm_frame_smd_error[31:0] |

#### STAT RX MM FRAME SMD ERROR MSB: 0x09A4

Table 286: STAT\_RX\_MM\_FRAME\_SMD\_ERROR\_MSB: 0x09A4

|   | Bits | Default | Туре | Signal                            |
|---|------|---------|------|-----------------------------------|
| - | 15:0 | 0       | HIST | stat_rx_mm_frame_smd_error[47:32] |



#### STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_LSB: 0x09A8

#### Table 287: STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_LSB: 0x09A8

| Bits | Default | Туре | Signal                             |
|------|---------|------|------------------------------------|
| 31:0 | 0       | HIST | stat_rx_mm_frame_assembly_ok[31:0] |

#### STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_MSB: 0x09AC

#### Table 288: STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_MSB: 0x09AC

| Bits | Default | Туре | Signal                              |
|------|---------|------|-------------------------------------|
| 15:0 | 0       | HIST | stat_rx_mm_frame_assembly_ok[47:32] |

#### STAT\_RX\_MM\_FRAGMENT\_LSB: 0x09B0

#### Table 289: STAT\_RX\_MM\_FRAGMENT\_LSB: 0x09B0

| Bits | Default | Туре | Signal                    |
|------|---------|------|---------------------------|
| 31:0 | 0       | HIST | stat_rx_mm_fragment[31:0] |

#### STAT\_RX\_MM\_FRAGMENT\_MSB: 0x09B4

#### Table 290: STAT\_RX\_MM\_FRAGMENT\_MSB: 0x09B4

| Bits | Default | Туре | Signal                     |
|------|---------|------|----------------------------|
| 15:0 | 0       | HIST | stat_rx_mm_fragment[47:32] |



# Designing with the Subsystem

This chapter includes guidelines and additional information to facilitate designing with the subsystem.

# Clocking

This section describes the clocking for all the 10G/25G configurations at the component support wrapper layer. There are seven fundamentally different clocking architectures depending on the functionality and options:

- PCS/PMA 64-bit Clocking
- PCS/PMA 32-bit Clocking
- 10G/25G MAC with PCS/PMA Clocking
- 10 MAC-only Clocking
- Low Latency 10G/25G MAC with PCS/PMA Clocking
- Low Latency 32-bit 10 Gb/s MAC with PCS
- Auto-Negotiation and Link Training Clocking

# PCS/PMA 64-bit Clocking

The clocking architecture for the 10G/25G PCS is illustrated below. There are three clock domains in the datapath, as illustrated by the dashed lines in the following figure.





Figure 15: PCS/PMA Clocking

- refclk\_p0, refclk\_n0, tx\_serdes\_refclk: The refclk differential pair is required to be an input to the FPGA. The example design includes a buffer to convert this clock to a single-ended signal refclk, which is used as the reference clock for the GT block. The tx\_serdes\_refclk is directly derived from refclk. Note that refclk must be chosen so that the tx\_mii\_clk meets the requirements of 802.3, which is within 100 ppm of 390.625 MHz for 25G and 156.25 MHz for 10G.
- tx\_mii\_clk: The tx\_mii\_clk is an output which is the same as the tx\_serdes\_refclk. The entire TX path is driven by this clock. You must synchronize the TX path mii bus to this clock output. All TX control and status signals are referenced to this clock.
- rx\_serdes\_clk: The rx\_serdes\_clk is derived from the incoming data stream within the GT block. The incoming data stream is processed by the RX core in this clock domain.
- rx\_clk\_out: The rx\_clk\_out output signal is presented as a reference for the RX control and status signals processed by the RX core. It is the same frequency as the rx\_serdes\_clk.
- rx\_mii\_clk: The rx\_mii\_clk input is required to be synchronized to the RX XGMII/25GMII data bus. This clock and the RX XGMII/25GMII bus must be within 100 ppm of the required frequency, which is 390.625 MHz for 25G and 156.25 MHz for 10G.
- dclk: The dclk signal must be a convenient, stable clock. It is used as a reference frequency
  for the GT helper blocks which initiate the GT itself. In the example design, a typical value is
  75 MHz, which is readily derived from the 300 MHz clock available on the VCU107 evaluation
  board. Note that the actual frequency must be known to the GT helper blocks for proper
  operation.



# PCS/PMA 32-bit Clocking

- refclk\_p0, refclk\_n0, rx\_serdes\_refclk: The refclk differential pair is required to be an input to the FPGA. The example design includes a buffer to convert this clock to a single-ended signal refclk, which is used as the reference clock for the GT block. Note that refclk must be chosen so that the tx\_clk\_out meets the requirements of IEEE 802.3, which is within 100 ppm of 312.5 MHz for 10G.
- $tx\_clk\_out$ : The  $tx\_clk\_out$  is an output You must synchronize the TX path mii bus to this clock output. All TX control and status signals are referenced to this clock.
- rx\_serdes\_clk: The rx\_serdes\_clk is derived from the incoming data stream within the GT block. The incoming data stream is processed by the RX core in this clock domain.
- rx\_clk\_out: The rx\_clk\_out output signal is presented as a reference for the RX control and status signals processed by the RX core. It is the same frequency as the rx\_serdes\_clk.
- **dclk:** The dclk signal must be a convenient, stable clock. It is used as a reference frequency for the GT helper blocks which initiate the GT itself. In the example design, a typical value is 100 MHz, which is readily derived from the 300 MHz clock available on the VCU107 evaluation board. Note that the actual frequency must be known to the GT helper blocks for proper operation.

# 10G/25G MAC with PCS/PMA Clocking

The clocking architecture for the 10/25G MAC with PCS/PMA clocking is illustrated below. This version of the subsystem includes FIFOs in the RX. There are three clock domains in the datapath, as illustrated by the dashed lines in the following figure.





Figure 16: 10G/25G MAC with PCS/PMA Clocking

- refclk\_p0, refclk\_n0, tx\_serdes\_refclk: The refclk differential pair is required to be an input to the FPGA. The example design includes a buffer to convert this clock to a single-ended signal refclk, which is used as the reference clock for the GT block. The tx\_serdes\_refclk is directly derived from refclk. Note that refclk must be chosen so that the tx\_serdes\_refclk meets the requirements of 802.3, which is within 100 ppm of 390.625 MHz for 25G, 156.25 MHz for 64-bit 10G, and 312.5 MHz for 32-bit 10G.
- tx\_clk\_out: This clock is used for clocking data into the TX AXI4-Stream Interface and it is also the reference clock for the TX control and status signals. It is the same frequency as tx\_serdes\_refclk.
- rx\_clk\_out: The rx\_clk\_out output signal is presented as a reference for the RX control and status signals processed by the RX core. It is the same frequency as the rx\_serdes\_clk.
- rx\_clk: The rx\_clk is available as rx\_core\_clk is the input clk for RX core. This to you, which you must drive from the example design. You should drive the rx\_core\_clk with frequency that is equal to the tx\_clk. When FIFO is enabled, the most preferred mode of operation for system side datapath is to connect the tx\_clk\_out to rx\_core\_clk. When connected in this manner, the RX AXI4-Stream Interface and the TX AXI4-Stream Interface are on the same clock domain. When FIFO is disabled, rx\_core\_clk must be driven by rx\_clk\_out/rx\_serdes\_clk.



dclk: The dclk signal must be a convenient stable clock. It is used as a reference frequency
for the GT helper blocks which initiate the GT itself. In the example design, a typical value is
75 MHz, which is readily derived from the 300 MHz clock available on the VCU107 evaluation
board.

**Note:** The actual frequency must be known to the GT helper blocks for proper operation.

# 10 MAC-only Clocking

The clocking architecture for the 10G MAC-only configuration is shown in Clocking. There are three clock domains as illustrated by the dashed lines.



Figure 17: Clocking Architecture for the 10G MAC-only Configuration

- rx\_mii\_clk: The rx\_mii\_clk can be driven internally or externally. It is required that the clock be chosen to meet the IEEE 802.3 requirements of 156.25 MHz ± 100 ppm for 10 Gb/s operation.
- tx\_mii\_clk: The tx\_mii\_clk can be driven internally or externally. It is required that the clock be chosen to meet the IEEE 802.3 requirements of 156.25 MHz ± 100 ppm for 10 Gb/s operation.



clk: The clock clk drives all the internal RX and TX core logic including the AXI4-Stream
interface and control and status signals. The clock clk should be run at a frequency greater
than or equal to 156.25 MHz.

# Low Latency 32-bit 10 Gb/s MAC with PCS

The clocking architecture is identical to that of its 64-bit counterpart, except that the clock to the AXI4-Stream interface will now be 312.5 MHz. Refer to the section on Clocking clocking for more details on the clocking architecture.

# Low Latency 10G/25G MAC with PCS/PMA Clocking

The clocking architecture for the Low Latency 10/25G MAC with PCS/PMA clocking is illustrated in the following figure. Low latency is achieved by omitting the RX FIFOs, which results in a different clocking arrangement. There are two clock domains in the datapath, as illustrated by the dashed lines in the following figure.



Figure 18: Low Latency 10G/25G MAC with PCS/PMA Clocking

• refclk\_p0, refclk\_n0, tx\_serdes\_refclk: The refclk differential pair is required to be an input to the FPGA. The example design includes a buffer to convert this clock to a single-ended signal refclk, which is used as the reference clock for the GT block. The tx\_serdes\_refclk is directly derived from refclk. Note that refclk must be chosen so that the tx\_serdes\_refclk meets the requirements of 802.3, which is within 100 ppm of 390.625 MHz for 25G, and 156.25 MHz for 10G.



- tx\_clk\_out: This clock is used for clocking data into the TX AXI4-Stream Interface and it is also the reference clock for the TX control and status signals. It is the same frequency as tx\_serdes\_refclk. Because there is no TX FIFO, you must respond immediately to the tx\_axis\_tready signal.
- rx\_clk\_out: The rx\_clk\_out output signal is presented as a reference for the RX control and status signals processed by the RX core. It is the same frequency as the rx\_serdes\_clk.

  Because there is no RX FIFO, this is also the clock which drives the RX AXI4-Stream Interface. In this arrangement, rx\_clk\_out and tx\_clk\_out are different frequencies and have no defined phase relationship to each other.
- dclk: The dclk signal must be a convenient stable clock. It is used as a reference frequency
  for the GT helper blocks which initiate the GT itself. In the example design, a typical value is
  75 MHz, which is readily derived from the 300 MHz clock available on the VCU107 evaluation
  board. Note that the actual frequency must be known to the GT helper blocks for proper
  operation.

## **Auto-Negotiation and Link Training Clocking**

The clocking architecture for the Auto-Negotiation and Link Training blocks are illustrated in the following figure. Note that these blocks are not included unless the BASE-KR feature is selected. The Auto-Negotiation and Link Training blocks function independently from the MAC and PCS, and therefore they are on different clock domains.



Figure 19: Auto-Negotiation and Link Training Clocking

- rx\_serdes\_clk: The rx\_serdes\_clk drives the RX line side logic for the Auto-Negotiation and Link Training.
- tx\_serdes\_clk: The tx\_serdes\_clk drives the TX line side logic for the Auto-Negotiation and Link Training. The DME frame is generated on this clock domain.



• AN\_clk: The AN\_clk drives the Auto-Negotiation state machine. All ability signals are on this clock domain. The AN\_clk can be any convenient frequency. In the example design, AN\_clk is connected to the dclk input, which has a typical frequency of 75 MHz. The AN\_clk frequency must be known to the Auto-Negotiation state machine because it is the reference for all timers.

This clock is set by the Vivado Integrated Design Environment (IDE) to the frequency as that of the GT DRP CLK setting entered in the GUI.

### Resets

The following figure shows the reset structure for the 10G/25G Ethernet Subsystem MAC with PCS/PMA for non-Versal devices as implemented at the component support wrapper layer. Clocks are not shown for clarity.



Figure 20: Reset Structure (UltraScale/UltraScale+)

For Versal devices, the following figure shows the reset structure for the 10G/25G Ethernet Subsystem MAC with PCS/PMA inplemented at the component support wrapper layer.





Figure 21: Reset Structure (Versal ACAP)

### **Component Support Layer Resets**

In the example design, a single reset is used to reset the entire wrapper layer. Using the external stimulus  $fsm_reset$ , the example\_fsm block issues the signal  $sys_reset$  which is connected to the three  $_wrapper$  resets. Therefore, the example design demonstrates that all three wrapper resets can be released simultaneously and correct operation follows.

## **Wrapper Resets**

The \_wrapper layer of the hierarchy is assumed to be what you instantiate in your own design. There are three resets to be handled as follows:

- GT\_reset
- tx\_reset
- rx reset

Timing of the reset signals is handled by the reset sequencer block.

• **GT\_reset:** The GT\_reset is the asynchronous active-High reset input to the GT. The internal resets of the GT are handled by the GT helper blocks.



- tx\_reset: The tx\_reset is the asynchronous active-High reset for the TX path logic of the 10G/25G Ethernet Subsystem. While it is connected to the GT reset in the example design, this reset can be asserted at any time to reset the TX path independently without disturbing the RX path.
- rx\_reset: The rx\_reset is the asynchronous active-High reset for the RX path logic of the 10G/25G Ethernet Subsystem. While it is connected to the GT reset in the example design, this reset can be asserted at any time to reset the RX path independently without disturbing the TX path.

# LogiCORE Example Design Clocking and Resets



# Detailed Diagram of Single Core - Asynchronous Clock Mode (UltraScale/UltraScale+)

drpclk\_common\_in gtwiz\_reset\_clk\_freerun\_in xxv\_ethernet\_0\_top.v GT\_0 gt\_refolk\_p GT\_Lane\_0

Figure 22: Detailed Diagram of Single Core - Asynchronous Clock Mode

x\_usrdk2\_out\_0



# Detailed Diagram of Multiple Cores - Asynchronous Clock Mode (UltraScale/UltraScale+)

Figure 23: Detailed Diagram of Multiple Cores - Asynchronous Clock Mode





# **Detailed Diagram of Single Core (Versal)**

xxv\_ethernet\_0\_top.v gt\_quad\_base gt\_refclk\_p gt\_refclk GT\_REFCLK0 PKT\_GEN\_MON\_0 util ds buff gt\_refclk\_n \_\_ tv\_clk · tx\_reset\_axi tx serdes refolk - rx clk PKT GEN at\_txusrclk2\_0 mst tx resetdone 0 Ch0 txmstresetdone MAC/PCS Ch1\_txmstresetdone Ch2\_txmstresetdone rx serdes reset axi Ch3\_txmstresetdone \_rx\_serdes\_reset tx reset ChO rxmstresetdone EXAMPLE\_FSM Ch1\_rxmstresetdone Ch2\_rxmstresetdone rx\_resetdone\_out\_0 E delk Ch3\_rxmstresetdone tx\_serdes\_refclk\_reset Ch0\_txpmaresetdone tx pma resetdone ( rx reset Ch2 txpmaresetdone Ch3\_txpmaresetdone rx\_pma\_resetdone\_0 Ch0\_rxpmaresetdone Ch1\_rxpmaresetdone Ch2\_rxpmaresetdone Ch3\_rxpmaresetdone PKT\_MON \_\_tx\_mii\_reset - rx\_mii\_clk PCS rx\_mii\_rese gt\_reset\_controller rx mii reset Ch1 txmstreset svs rese tx\_reset\_axi tx\_serdes\_refclk\_rese Ch3\_txmstreset Ch0\_rxmstreset mst\_rx\_reset\_ Ch1 rxmstreset rx\_serdes\_reset\_axi delk Ch2\_rxmstreset Ch3\_rxmstreset Ch0\_txuserrdy txuserrdy\_out\_0 rx\_mii\_clk ◀ Ch1 txuserrdy (B) Ch2\_txuserrdy s axi aclk — s axi aclk Ch3 txuserrdy s\_axi\_aresent - s\_axi\_aresent rxuserrdy\_out\_0 Ch0\_rxuserrdy s axi aresetn - s axi aresetn 0 Ch1\_rxuserrdy ctl\_gt\_reset\_all Ch2\_rxuserrdy ctl\_gt\_tx\_reset Ch3\_rxuserrdy ▶ gtwiz\_reset\_tx\_datapath\_in ctl\_gt\_rx\_reset gtwiz\_reset\_rx\_datapath\_in tx\_reset\_axi\_\_\_\_\_ Ch0\_txoutclk rx\_reset\_axi \*\_axi\_if\_top Ch1\_txoutclk Ch2\_txoutclk tx\_serdes\_reset\_axi Ch3\_txoutclk rx\_serdes\_reset\_axi tx\_clk | tx\_clk / tx\_serdes\_refclk bufg\_gt Ch0 txusrell Ch1\_txusrclk Ch2\_txusrclk tx\_reset | tx\_reset / tx\_serdes\_refclk\_reset rx\_clk - rx\_serdes\_clk Ch3\_txusrclk rx\_reset ◀ — rx\_reset / rx\_serdes\_reset Ch0\_rxoutclk Ch1\_rxoutclk Ch2\_rxoutclk Ch3\_rxoutclk tx\_clk/ tx\_serdes\_refclk rx serdes clk ◀── rx\_serdes\_clk bufg\_gt XXV\_ethemet\_\*\_ANLT\_ tx\_reset / tx\_serdes\_refclk\_reset rx\_serdes\_reset\_axi rx\_serdes\_reset

Figure 24: Detailed Diagram of Single Core

X23975-120720



# **Support for IEEE Standard 1588v2**

#### **Overview**

This section details the packet timestamping function of the 10G/25G Ethernet Subsystem when the MAC layer is included. The timestamping option must be specified at the time of generating the subsystem from the IP catalog or ordering the IP Core asynchronously. This feature provides one-step and two-step IEEE 1588v2 functionality.

If you select the IEEE PTP 1588v2 operation mode as "Two Step", then only the two-step related ports will be populated and the core will perform only the two-step time stamping functionality. If you select the IEEE PTP 1588v2 operation mode as "One Step", then all the ports related to one-step and two-step will be populated and both one-step and two-step core functionality will be available.

Ethernet frames are timestamped at both ingress and egress. The option can be used for implementing all kinds of IEEE 1588v2 clocks: Ordinary, Transparent, and Boundary. It can also be used for the generic timestamping of packets at the ingress and egress ports of a system. While this feature can be used for a variety of packet timestamping applications, the rest of this section assumes that you are also implementing the IEEE 1588v2 Precision Time Protocol (PTP).

IEEE 1588v2 defines a protocol for performing timing synchronization across a network. A 1588 network has a single master clock timing reference, usually selected through a best master clock algorithm. Periodically, this master samples its system timer reference counter, and transmits this sampled time value across the network using defined packet formats. This timer should be sampled (a timestamp) when the start of a 1588 timing packet is transmitted. Therefore, to achieve high synchronization accuracy over the network, accurate timestamps are required. If this sampled timer value (the timestamp) is placed into the packet that triggered the timestamp, this is known as one-step operation. Alternatively, the timestamp value can be placed into a follow up packet; this is known as two-step operation.

Other timing slave devices on the network receive these timing reference packets from the network timing master and attempt to synchronize their own local timer references to it. This mechanism relies on these Ethernet ports also taking timestamps (samples of their own local timer) when the 1588 timing packets are received. Further explanation of the operation of 1588 is out of scope of this document. This document now describes the 1588 hardware timestamping features of the subsystem.

The 1588 timer provided to the subsystem and the consequential timestamping taken from it are available in one of two formats which are selected during subsystem generation.

• **Time-of-Day (ToD) format:** IEEE 1588-2008 format consisting of an unsigned 48-bit second field and a 32-bit nanosecond field.



• Correction Field format: IEEE 1588-2008 numerical format consisting of a 64-bit signed field representing nanoseconds multiplied by 216 (see IEEE 1588 clause 13.3.2.7). This timer should count from 0 through the full range up to 264 -1 before wrapping around.

#### **Egress**

Figure 25: Egress



As seen in the preceding figure, timestamping logic exists in two locations depending on whether 1-step or 2-step operation is desired. 1-step operation requires the user datagram protocol (UDP) checksum and FCS updates and therefore the FCS core logic is used.

The TS references are defined as follows:

- **TS1:** The output timestamp signal when a 1-step operation is selected.
- TS2: The output timestamp signal when a 2-step operation is selected.
- TS2': The plane to which both timestamps are corrected.



TS2 always has a correction applied so that it is referenced to the TS2' plane. TS1 might or might not have the TS2' correction applied, depending on the value of the signal  $ctl_tx_ptp_latency_adjust[10:0]$ .

Based on rate and clock mode (Ordinary or Transparent), the suggested default values of the ctl\_tx\_ptp\_latency\_adjust[10:0] signal are as follows:

- 25G Ordinary Clock = 370
- 25G Transparent Clock = 449
- 10G Ordinary Clock = 925
- 10G Transparent Clock = 1132

On the transmit side, a command field is provided by the client to the subsystem in parallel with the frame sent for transmission. This indicates, on a frame-by-frame basis, the 1588 function to perform (either no-operation, 1-step, or 2-step) and also indicates, for 1-step frames, whether there is a UDP checksum field to update.

If using the ToD format, then for both 1-step and 2-step operation, the full captured 80-bit ToD timestamp is returned to the client logic using the additional ports defined in Port Descriptions.

If using the Correction Field format, then for both 1-step and 2-step operation, the full captured 64-bit timestamp is returned to the client logic using the additional ports defined in Port Descriptions (with the upper bits of data set to zero as defined in the table).

If using the ToD format, then for 1-step operation, the full captured 80-bit ToD timestamp is inserted into the frame. If using the Correction Field format, then for 1-step operation, the captured 64-bit timestamp is summed with the existing Correction Field contained within the frame and the summed result is overwritten into the original Correction Field of the frame. Supported frame types for 1-step timestamping are:

- Raw Ethernet
- UDP/IPv4
- UDP/IPv6 For 1-step UDP frame types, the UDP checksum is updated in accordance with IETF RFC 1624. For all 1-step frames, the Ethernet Frame Check Sequence (FCS) field is calculated after all frame modifications have been completed. For 2-step transmit operation, all Precision Time Protocol (PTP) frame types are supported.

#### Frame-by-Frame Timestamping Operation

The operational mode of the egress timestamping function is determined by the settings on the 1588 command port. The information contained within the command port indicates one of the following:

• No operation: the frame is not a PTP frame and no timestamp action should be taken.



- Two-step operation is required and a tag value (user-sequence ID) is provided as part of the
  command field; the frame should be timestamped, and the timestamp made available to the
  client logic, along with the provided tag value for the frame. The additional MAC transmitter
  ports provide this function.
- 1-step operation is required.
  - For the ToD timer and timestamp format a timestamp offset value is provided as part of the command port; the frame should be timestamped, and the timestamp should be inserted into the frame at the provided offset (number of bytes) into the frame.
  - For the Correction Field format, a Correction Field offset value is provided as part of the command port; the frame should be timestamped, and the captured 64-bit Timestamp is summed with the existing Correction Field contained within the frame and the summed result is overwritten into original Correction Field of the frame. For 1-step operation, following the frame modification, the cyclic redundancy check (CRC) value of the frame should also be updated/recalculated. For UDP IPv4 and IPv6 PTP formatted frames, the checksum value in the header of the frame needs to be updated/recalculated.
- For 1-step UDP frame types, the UDP checksum is updated in accordance with IETF RFC 1624.
  - If using the ToD format, in order for this update function to work correctly, the original checksum value for the frame sent for transmission should be calculated using a zero value for the timestamp data. This particular restriction does not apply when using the Correction Field format.
  - If using the Correction Field format, a different restriction does apply; the separation between the UDP Checksum field and the Correction Field within the 1588 PTP frame header is a fixed interval of bytes, supporting the 1588 PTP frame definition. This is a requirement to minimize the latency through the MAC since both the checksum and the correction field must both be fully contained in the MAC pipeline in order for the checksum to be correctly updated. This particular restriction does not apply to the ToD format because the original timestamp data is calculated as a zero value; consequently the checksum and timestamp position can be independently located within the frame.



#### **Ingress**

Figure 26: Ingress



X23834-072321

The ingress logic does not parse the ingress packets to search for 1588 (PTP) frames. Instead, it takes a timestamp for every received frame and outputs this value to the user logic. The feature is always enabled, but the timestamp output can be ignored if you do not require this function.

Timestamps are filtered after the PCS decoder to retain only those timestamps corresponding to an Start of Packet (SoP). These 80-bit timestamps are output on the system side. The timestamp is valid during the SoP cycle.

The accuracy of the 1588 timestamping of Ethernet frames is dependent on several factors, some of which are outside of the scope of this IP core:

timestamp error = (10/25G IP Core 1588 timestamp error) + (external timestamp sampling error) + (error due to system clock jitter, transceiver uncertainty, other factors)

10/25G IP Core 1588 timestamp error:



- Ordinary Clock mode: +/- 1 ns (due to granularity of ToD format)
- Transparent Clock mode: +/- 1 SerDes clock bit time

Factors that influence timestamp accuracy:

- This IP core requires the user to sample the system timer input and to retime it to the specified clock domain (TX SerDes or RX SerDes). A simple sampling circuit will introduce a +/- 1 SerDes clock error. Greater accuracy can be achieved if the customer implements a custom synchronization design.
- No compensation for external delays (e.g., transceivers) is done inside the IP core. These delays can be determined and added as an offset.
- For IP cores with RSFEC, the timing plane is assumed to be outside the RSFEC, and so any variation due to transcoding and checksum insertion on TX is removed by the inverse function on RX. Refer to 802.3-2018 Clause 90.7.
- For MAC+PCS IP cores with RSFEC, the core compensates for the effects of rate adaptation due to AM insertion.
- 64b IP cores compensate for half block starts (64B/66B blocks with S4).

## **Port Descriptions**

The following table details the additional signals present when the packet timestamping feature is included.

Table 291: 1588v2 Port List and Descriptions

| Name                         | I/O | Description                                                                                                                                                                                                                                                                                                                                                  | Clock<br>Domain |
|------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|                              | IE  | EE 1588 Interface – TX Path                                                                                                                                                                                                                                                                                                                                  |                 |
| ctl_tx_systemtimerin[80-1:0] | I   | System timer input for the TX. In normal clock mode, the 32 LSBs carry nsec and the 48 MSBs carry seconds. In transparent clock mode, bit 63 is expected to be zero, bits 62:16 carry nanoseconds, and bits 15:0 carry fractional nanoseconds. Refer to IEEE 1588v2 for the representational definitions.  This input must be in the TX SerDes clock domain. | tx_serdes_clk   |
| tx_ptp_tstamp_valid_out      | 0   | This bit indicates that a valid timestamp is being presented on the TX system interface.                                                                                                                                                                                                                                                                     | tx_clk_out      |
| tx_ptp_tstamp_tag_out[15:0]  | 0   | Tag output corresponding to tx_ptp_tag_field_in[15:0]                                                                                                                                                                                                                                                                                                        | tx_clk_out      |
| tx_ptp_tstamp_out[80-1:0]    | 0   | Timestamp for the transmitted packet SOP corresponding to the time at which it passed the capture plane. Used for 2-step 1588 operation. Time format is the same as timer input.                                                                                                                                                                             | tx_clk_out      |



*Table 291:* **1588v2 Port List and Descriptions** (cont'd)

| Name                      | I/O | Description                                                                                                                                                                                                                                                                                                                                        | Clock<br>Domain |
|---------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| tx_ptp_1588op_in[1:0]     | I   | The signal should be valid on the first cycle of the packet. For PCS cores, the first cycle corresponds with the first data word of the packet.                                                                                                                                                                                                    | tx_clk_out      |
|                           |     | 2'b00 – No operation: no timestamp will be taken and the frame will not be modified.                                                                                                                                                                                                                                                               |                 |
|                           |     | 2'b01 – 1-step: a timestamp should be taken and inserted into the frame.                                                                                                                                                                                                                                                                           |                 |
|                           |     | 2'b10 – 2-step: a timestamp should be taken and returned to the client using the additional ports of 2-step operation. The frame itself will not be modified.                                                                                                                                                                                      |                 |
|                           |     | 2'b11 – Reserved: act as No operation.                                                                                                                                                                                                                                                                                                             |                 |
| ctl_tx_ptp_1step_enable   | I   | When set to 1, this bit enables 1-step operation.                                                                                                                                                                                                                                                                                                  | tx_clk_out      |
| tx_ptp_upd_chksum_in      |     | See IEEE 1588 TX/RX Interface Control/Status/Statistics Signals.                                                                                                                                                                                                                                                                                   | tx_clk_out      |
| tx_ptp_chksum_offset_in   |     | See IEEE 1588 TX/RX Interface Control/Status/Statistics Signals.                                                                                                                                                                                                                                                                                   | tx_clk_out      |
| tx_ptp_tstamp_offset_in_* |     | See IEEE 1588 TX/RX Interface Control/Status/Statistics Signals.                                                                                                                                                                                                                                                                                   | tx_clk_out      |
| ctl_ptp_transpclk_mode    | I   | When set to 1, this input places the timestamping logic into transparent clock mode. In this mode, the system timer input is interpreted as a correction value. The TX will add the correction value to the TX timestamp according to the process defined in IEEE 1588v2. The sign bit of the correction value is assumed to be 0 (positive time). | tx_clk_out      |
|                           |     | It is expected that the corresponding incoming PTP packet correction field has already been adjusted with the proper RX timestamp.                                                                                                                                                                                                                 |                 |
| tx_ptp_tag_field_in[15:0] | I   | The usage of this field is dependent on the 1588 operation. The signal should be valid on the first cycle of the packet.                                                                                                                                                                                                                           | tx_clk_out      |
|                           |     | For No operation, this field will be ignored.                                                                                                                                                                                                                                                                                                      |                 |
|                           |     | <ul> <li>For 1-step and 2-step this field is a tag field. This tag value will be returned to the client with the timestamp for the current frame using the additional ports of 2-step operation. This tag value can be used by software to ensure that the timestamp can be matched with the PTP frame that it sent for transmission.</li> </ul>   |                 |
| ctl_tx_latency_*          | I   | This is the static latency of the TX path of the core including the GT. The MSB 16 bits indicate the delay in ns and the LSB 16 bits indicate sub ns values. The latency is in binary Q16.16 format.                                                                                                                                               | tx_clk_out      |
|                           |     | <b>Note:</b> This is applicable only for the MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version.                                                                                                                                                                                                                                            |                 |



*Table 291:* **1588v2 Port List and Descriptions** (cont'd)

| Name                                             | I/O | Description                                                                                                                                                                                                                                                         | Clock<br>Domain |
|--------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_tx_lat_adj_enb_*                             | I   | When this signal is enabled, the delay computation on the TX path takes into account the value provided by the ctl_tx_latency_0 register.                                                                                                                           | tx_clk_out      |
|                                                  |     | <b>Note:</b> This is applicable only for the MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version.                                                                                                                                                             |                 |
| ctl_tx_ptp_latency_adjust[10:0]                  | I   | This bus can be used to adjust the 1-step TX timestamp with respect to the 2-step timestamp. The units of bits [10:3] are nanoseconds and bits [2:0] are fractional nanoseconds.                                                                                    | tx_clk_out      |
| stat_tx_ptp_fifo_write_error                     | 0   | Transmit PTP FIFO write error. A value of 1 on this status indicates that an error occurred during the PTP Tag write. A TX Path reset is required to clear the error.                                                                                               | tx_clk_out      |
| stat_tx_ptp_fifo_read_error                      | 0   | Transmit PTP FIFO read error. A value of 1 on this status indicates that an error occurred during the PTP Tag read. A TX Path reset is required to clear the error.                                                                                                 | tx_clk_out      |
| ctl_tx_timestamp_adj_enb_*<br>(default value: 1) | I   | When this signal is enabled, the delay computation on<br>the TX path takes into account the value obtained from<br>GT DRP read for latency of the TX gearbox FIFO.                                                                                                  | tx_clk_out      |
|                                                  |     | <b>Note:</b> This is applicable only for the MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version.                                                                                                                                                             |                 |
| tx_period_ns_*                                   | 0   | See IEEE 1588 TX/RX Interface Control/Status/Statistics Signals.                                                                                                                                                                                                    | tx_clk_out      |
|                                                  | 1   | EEE 1588 Interface – RX Path                                                                                                                                                                                                                                        |                 |
| ctl_rx_systemtimerin[80-1:0]                     | I   | System timer input for the RX. Same time format as the TX. This input must be in the same clock domain as the RX SerDes.                                                                                                                                            | rx_serdes_clk   |
|                                                  |     | <i>Note</i> : This signal is not valid in 1G mode.                                                                                                                                                                                                                  |                 |
| rx_ptp_tstamp_out[80-1:0]                        | 0   | Timestamp for the received packet SOP corresponding to the time at which it passed the capture plane. Note that this signal will be valid on the first cycle of the packet. Used for 2-step 1588 operation.                                                         | rx_core_clk     |
| rx_ptp_tstamp_valid_out_*                        | 0   | This bit indicates that a valid timestamp is being presented on the RX system interface.                                                                                                                                                                            | rx_core_clk     |
| rx_ptp_pcslane_out                               | 0   | This bus identifies which of the PCS lanes that the SOP was detected on for the corresponding timestamp. Note that this signal will be valid starting at the same clock cycle during which the SOP is asserted for one of the segments.                             | rx_serdes_clk   |
| rx_lane_aligner_fill_0                           | 0   | This output indicates the fill level of the alignment buffer for PCS lane0. This information can be used by the PTP application, together with the signal rx_ptp_pcslane_out_*, to adjust for the lane skew of the arriving SOP. The units are SerDes clock cycles. |                 |
| rx_lane_aligner_fill_1                           | 0   | This output indicates the fill level of the alignment buffer for PCS lane1.                                                                                                                                                                                         |                 |
| rx_lane_aligner_fill_2                           | 0   | This output indicates the fill level of the alignment buffer for PCS lane2.                                                                                                                                                                                         |                 |



Table 291: 1588v2 Port List and Descriptions (cont'd)

| Name                                             | I/O | Description                                                                                                                                                                                                                                                                                                  | Clock<br>Domain |
|--------------------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| rx_lane_aligner_fill_3                           | 0   | This output indicates the fill level of the alignment buffer for PCS lane3.                                                                                                                                                                                                                                  |                 |
| ctl_rx_latency_*                                 | I   | <b>Note:</b> This is applicable only for the MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version. This is the static latency of the RX path of the core including the GT. The MSB 16 bits indicate the delay in ns and the LSB 16 bits indicate sub ns values. The latency is in binary Q16.16 format. | rx_clk_out      |
| ctl_rx_lat_adj_enb_*<br>(default value: 1)       | I   | When this signal is enabled, the delay computation on the RX path takes into account the value provided by the ctl_rx_latency_0 register.  *Note: This is applicable only for MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version.                                                                     | rx_clk_out      |
| ctl_rx_timestamp_adj_enb_*<br>(default value: 1) | I   | When this signal is enabled, the delay computation on the RX path takes into account the value obtained from the GT DRP read for latency of the RX gearbox FIFO.  Note: This is applicable only for the MAC+PCS/PMA 32-bit version and for PCS/PMA 32-bit version.                                           | rx_clk_out      |
| rx_period_ns_*                                   | 0   | See IEEE 1588 TX/RX Interface Control/Status/Statistics Signals.                                                                                                                                                                                                                                             | rx_clk_out      |

# **IEEE 1588v2 PTP Functional Description**

The IEEE 1588v2 feature of the 10G/25G High Speed Ethernet Subsystem provides accurate timestamping of Ethernet frames at the hardware level for both the ingress and egress directions.

Timestamps are captured according to the input clock source above. However, it is required that this time source be in the same clock domain as the SerDes. This might require re-timing by an external circuit provided by the user.

All ingress frames receive a timestamp. You need to interpret the received frames and determine whether a particular frame contains PTP information (by means of its Ethertype) and if the timestamp needs to be retained or discarded. Egress frames are timestamped if they are tagged as PTP frames. The timestamps of egress frames are matched to their user-supplied tags.

Timestamps for incoming frames are presented at the user interface during the same clock cycle as the start of packet. You can then append the timestamp to the packet as required.

By definition, a timestamp is captured coincident with the passing of the SOP through the capture plane within the 10G/25G High Speed Ethernet Subsystem. This is shown in the following diagrams.



Figure 27: Receive



Figure 28: Transmit





#### **Performance**

In a typical application, the difference between the ingress and egress capture times is important for determining absolute time. The PTP algorithm can use asymmetric information to improve accuracy.

The 1588v2 feature requires that all clock frequencies be known in order to make internal calculations. The clock frequencies should be specified at the time the PTP IP core is ordered in order for the timestamp correction to work properly.

In a typical application, the PTP algorithm (or servo, not part of this IP) will remove jitter over the course of time (many packet samples). It is advantageous for the jitter to be as small as possible in order to minimize the convergence time as well as minimizing slave clock drift.

# **RS-FEC Support**

#### **Overview**

This section describes the optional RS-FEC function of the 10G/25G Ethernet Subsystem. The RS-FEC option must be specified at the time of generating the subsystem from the IP catalog or ordering the IP core asynchronously.

With reference to the following diagram, the clocks and resets of the RS-FEC core are equivalent to the transceiver signals, with the transceiver resets being active-High. The RS-FEC block is positioned between the PCS and PMA as illustrated in the following figure.





Figure 29: RS-FEC Block Diagram

The internal details of the RS-FEC are beyond the scope of this document. Refer to IEEE 802.3 Clause 108 and Schedule 3 of the 25G Ethernet Consortium.

Further information can also be found in the 25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide (PG217) (registration required).

# **Port Descriptions**

**Table 292: RS-FEC Port List and Descriptions** 

| Port                                 | Direction | Description                                                                                                                                                                                        | Clock<br>Domain |
|--------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|                                      | RS-FE     | C Control Signals                                                                                                                                                                                  |                 |
| ctl_rsfec_ieee_error_indication_mode | Input     | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on first cycle on reset.  • 1: Core conforms to the IEEE RS-FEC specification. | rx_serdes_clk   |
|                                      |           | 0: If ctl_rx_rsfec_enable_correction and ctl_rx_rsfec_enable_indication are set to zero, the RS decoder is bypassed.                                                                               |                 |



*Table 292:* **RS-FEC Port List and Descriptions** (cont'd)

| Port                           | Direction | Description                                                                                                                                                                                                                                                                                                                                                                        | Clock<br>Domain |
|--------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| ctl_rsfec_consortium_25g       | Input     | Switches between IEEE Clause 108 and 25G Ethernet Consortium mode. The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on first cycle on reset.  1 = 25G Consortium specification mode.  0 = IEEE 802.3by mode. Note that some variants of the 10G/25G Subsystem can have individual RX and TX consortium signals. | rx_serdes_clk   |
| ctl_rsfec_enable               | Input     | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on first cycle on reset.  Enable RS-FEC function. Note that some variants of the 10G/25G Subsystem can have individual RX and TX enable signals.                                                                                                               | rx_serdes_clk   |
| ctl_rx_rsfec_enable_correction | Input     | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on first cycle on reset.  Equivalent to MDIO register 1.200.0  O: Decoder performs error detection without error correction (see IEEE 802.3802.3by section 91.5.3.3).  1: the decoder also performs error correction.                                          | rx_serdes_clk   |
| ctl_rx_rsfec_enable_indication | Input     | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value sampled on first cycle on reset.  Equivalent to MDIO register 1.200.1  O: Bypass the error indication function (see IEEE Std 802.3by section 91.5.3.3).  1: Decoder indicates errors to the PCS sublayer.                                                                 | rx_serdes_clk   |
| ctl_rx_vl_length_minus1[15:0]  | Input     | Normally set to 20,479 (4FFF hex). The normal value is equivalent to (16,383 x 5 -4) = 81,916.                                                                                                                                                                                                                                                                                     |                 |
| ctl_rx_vl_marker_id0[63:0]     | Input     | Equivalent to the RX PCS lane 0 alignment marker defined in IEEE 802.3 Clause 82 for 40 G Ethernet.                                                                                                                                                                                                                                                                                |                 |
| ctl_rx_vl_marker_id1[63:0]     | Input     | Equivalent to the PCS lane 1 alignment marker.                                                                                                                                                                                                                                                                                                                                     |                 |
| ctl_rx_vl_marker_id2[63:0]     | Input     | Equivalent to the PCS lane 2 alignment marker.                                                                                                                                                                                                                                                                                                                                     |                 |
| ctl_rx_vl_marker_id3[63:0]     | Input     | Equivalent to the PCS lane 3 alignment marker.                                                                                                                                                                                                                                                                                                                                     |                 |
| ctl_tx_vl_length_minus1[15:0]  | Input     | Normally set to 20479 (decimal). The normal value is equivalent to (16,383 x 5 -4) = 81,916.                                                                                                                                                                                                                                                                                       |                 |
| ctl_tx_vl_marker_id0[63:0]     | Input     | Equivalent to the TX PCS lane 0 alignment<br>marker defined in IEEE 802.3 Clause 82 for 40 G<br>Ethernet.                                                                                                                                                                                                                                                                          |                 |
| ctl_tx_vl_marker_id1[63:0]     | Input     | Equivalent to the PCS lane 1 alignment marker.                                                                                                                                                                                                                                                                                                                                     |                 |
| ctl_tx_vl_marker_id2[63:0]     | Input     | Equivalent to the PCS lane 2 alignment marker.                                                                                                                                                                                                                                                                                                                                     |                 |
| ctl_tx_vl_marker_id3[63:0]     | Input     | Equivalent to the PCS lane 3 alignment marker                                                                                                                                                                                                                                                                                                                                      |                 |



Table 292: RS-FEC Port List and Descriptions (cont'd)

| Port                                | Direction | Description                                                                                                                                | Clock<br>Domain |
|-------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|                                     | RS-FE     | C Status Signals                                                                                                                           |                 |
| stat_rx_rsfec_corrected_cw_inc      | Output    | Increment for corrected errors.                                                                                                            | rx_serdes_clk   |
| stat_rx_rsfec_uncorrected_cw_inc    | Output    | Increment for uncorrected errors.                                                                                                          | rx_serdes_clk   |
| stat_rx_rsfec_err_count_inc[2:0]    | Output    | Increment for detected errors.                                                                                                             | rx_serdes_clk   |
| stat_rx_rsfec_hi_ser                | Output    | Set to one if the number of RS-FEC symbol errors in a window of 8192 codewords exceeds the threshold K = 417 and is set to zero otherwise. | rx_serdes_clk   |
| stat_rx_rsfec_lane_alignment_status | Output    | A value of 1 indicates that the RX RS-FEC block has achieved alignment on the data from the transceiver.                                   | rx_serdes_clk   |
| stat_tx_rsfec_lane_alignment_status | Output    | A value of 1 indicates that the TX RS-FEC block has achieved alignment on the incoming PCS data.                                           | rx_serdes_clk   |

# **RS-FEC Functional Description**

The RS-FEC feature of the 10G/25G Subsystem provides error correction capability according to IEEE 802.3 Clause 108 or Schedule 3 of the 25G Ethernet Consortium.

The feature requires the insertion of PCS alignment markers as defined in IEEE 802.3 Table 82-2. Inputs are provided for the alignment markers and also for the value of words between alignment markers.

It is possible to bypass the RS-FEC function by means of the enable signals. This will bypass the RS-FEC function and connect the PCS directly to the transceiver, with the benefit of reduced latency. Refer to 25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide (PG217) (registration required) for the latest latency performance data in the various bypass modes, defined as follows:

- **FEC Bypass Correction:** The decoder performs error detection without correction, (see IEEE Std 802.3by section 108.5.3.2. The latency is reduced in this mode (see *25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide* (PG217) (registration required) for latency figures).
- **FEC Bypass Indication:** In this mode there is correction of the data but no error indication. An additional signal, rx\_hi\_ser, is generated in this mode to reduce the likelihood that errors in a packet are not detected. The RS decoder counts the number of symbol errors detected in consecutive non-overlapping blocks of 8192 codewords (see IEEE Std 802.3by section 108.5.3.2). The latency is reduced in this mode.
- **Decoder Bypass:** The RS decoder can be bypassed by setting the IEEE Error indication Low when the correction bypass and indication bypass are High.



# **Ethernet Datapath Parity**

The Datapath Parity Feature provides soft error detection on datapath logic that resides between the core AXI4-Stream interface and the Ethernet FCS logic.

For each byte of the datapath, a single bit is provided that reflects the calculated parity of that byte.



**IMPORTANT!** The IP core implements even parity such that the sum of all ones in the datapath including the parity bit results in an even number (i.e., 0, 2, 4..).

Datapath parity is implemented in both transmit and receive directions of the core datapath. In both directions, parity bits are considered valid only on valid AXI4-Stream bytes. More specifically, an AXI4-Stream byte is considered valid on cycles where <code>TKEEP[n]</code>, <code>TVALID</code> and <code>TREADY</code> are all asserted. Parity bits associated with invalid AXI4-Stream bytes in the receive datapath should be ignored. Parity bits associated with AXI4-Stream invalid bytes in the transmit direction are not checked.

The Datapath Parity Feature adds a single statistic,  $stat_tx_bad_parity$ , to identify if a soft error has been detected. The statistic is clock-cycle based such that it can assert multiple times for a single packet. And, because it is clock cycle based, it identifies only that at least one soft error has been detected. If two soft errors are detected on a single clock cycle, only one soft error will be indicated. The presence of parity errors can also trigger the assertion of  $stat_tx_bad_fcs$  errors depending on the configuration.

For variants supporting parity, there is no configuration required for the receive datapath as all packets presented on the AXI4-Stream interface will have parity generated. In the transmit direction, the following table describes configuration bits that affect the behavior of the parity logic:

Table 293: Configuration Bits Affecting Parity Logic Behavior

| ctl_tx_fcs_<br>ins_enable | ctl_tx_parity_err<br>_response | Ethernet FCS<br>Stomped Behavior                                         | stat_tx_bad_parity<br>Behavior                                                   | stat_tx_bad_fcs<br>Behavior                                                                                                                                                                                     |
|---------------------------|--------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                         | 0                              | Core will not stomp FCS,<br>but FCS may have been<br>stomped user logic. | stat_tx_bad_parity is<br>asserted if parity errors<br>are detected. <sup>1</sup> | stat_tx_bad_fcs is<br>asserted if the user-<br>generated FCS in the<br>incoming packet is<br>incorrect. Parity errors,<br>which may or may not<br>be present, will not<br>cause a stat_tx_bad_fcs<br>assertion. |
| 0                         | 1                              | Core will not stomp FCS,<br>but FCS may have been<br>stomped user logic. | Same as above. <sup>1</sup>                                                      | Same as above                                                                                                                                                                                                   |



Table 293: Configuration Bits Affecting Parity Logic Behavior (cont'd)

| ctl_tx_fcs_<br>ins_enable | ctl_tx_parity_err<br>_response | Ethernet FCS<br>Stomped Behavior | stat_tx_bad_parity<br>Behavior | stat_tx_bad_fcs<br>Behavior                                                                             |
|---------------------------|--------------------------------|----------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------|
| 1                         | 0                              | No                               | Same as above. <sup>1</sup>    | Parity errors, which may<br>or may not be present,<br>will not cause a<br>stat_tx_bad_fcs<br>assertion. |
| 1                         | 1                              | Yes, if parity errors detected.  | Same as above. <sup>1</sup>    | stat_tx_bad_fcs is<br>asserted if parity errors<br>are detected. <sup>2</sup>                           |

#### Notes:

- 1. There is a limitation such that stat\_tx\_bad\_parity will not be asserted for parity error(s) received on the final clock cycle of an underrun packet (packet that has tx\_axis\_tuser at the same time as tlast or de-asserts tvalid without tlast) or if an LBUS FIFO underflow event occurs.
- 2. There is a limitation such that <code>stat\_tx\_bad\_fcs</code> will not be asserted for parity error(s) received on only the final clock cycle of an underrun packet (packet that has <code>tx\_axis\_tuser</code> at the same time as <code>tlast</code> or <code>de-asserts tvalid</code> without <code>tlast</code>) or if an LBUS FIFO underflow event occurs. Parity errors received prior to the final clock cycle will still cause <code>stat\_tx\_bad\_fcs</code> to be asserted.

# **802.1cm Preemption Feature**

### **Features**

Optional fee-based Time Sensitive Networking (TSN) feature based on IEEE Standard for Local and Metropolitan Area Networks - Time Sensitive Networking for Fronthaul (IEEE Std 802.1CM-2018).

- Supports frame preemption
- Supports interspersing express traffic with low priority traffic

### **Overview**

Frame preemption and Express traffic interspersing is defined by IEEE standard 802.1 CM. The 10G/25G Ethernet Subsystem includes the optional TSN feature based on IEEE 802.1 CM.

# **Product Specification**

The following figure shows the block diagram of the 10/25G Ethernet IP subsystem with the optional TSN feature:





Figure 30: 10/25G Ethernet IP Subsystem with Optional TSN

**Note:** When 802.1cm Preemption feature is enabled, PTP timestamp is supported only on the express interface.

### **Transmit AXI4-Stream Interface**

The core has two AXI4-Stream Interfaces, for express (tx\_axis\_e\_\*) and preempt traffic (tx\_axis\_p\_\*), when the core is generated with the optional TSN feature. For details refer to Transmit AXI4-Stream Interface.

**Note:** The same descriptions and rules apply to these signals as the ones in Transmit AXI4-Stream Interface.

There is an option to insert a FIFO on the preempt interface during core generation. When this FIFO is inserted, the ingress frame will be buffered and only when the complete error free frames is available in this FIFO will it be made available on the AXI4-Stream interface.



### **Frame Transmission**

If you disable preemption, the core services the express and preempt traffic on a first-come-first-serve basis. If both interfaces present frames at the same time, the express traffic is serviced first and then the preempt traffic. For details on presenting a frame for transmission, see the AXI4-Stream Interface section.

Before you enable preemption, the preemption capabilities of the link-partner must be determined first. This is done by the exchange of Additional Ethernet Capabilities TLV as described in IEEE standard 802.3, section 79.3.7. The core assumes that the you enable preemption only after determining that the link-partner is also capable of preemption. If preemption is enabled by asserting  $ctl_en_preempt$ , the core first verifies the preemption operation, provided that  $ctl_disable_verify$  is deasserted. Preemption is active only after verification has been successfully completed. You can also disable verification in which case the core does not attempt to start the verification process and makes preemption active. When preemption is active, the core services the frame transmission requests as follows:

- If the express interface is inactive, the frames presented on the preempt interface are transmitted.
- If the express and preempt interface request frame transmission at the same time, the express frames are transmitted.
- If the preempt traffic is being transmitted and express interfaces presents a frame, the preempt traffic will be preempted in accordance with this formula, specified in IEEE standard 802.3 br-2106: pAllow \* (eTx + hold) \* preemptableFragSize \* MIN\_REMAIN
- After the express frame has been transmitted and no more express frames are queued up for transmission, the core resumes the transmission of the preempted frames.

For detailed description of preemption and interspersing of express traffic, refer to IEEE standard 802.1 CM. The following timing diagram depicts how preemption and interspersing works. For a detailed description of preemption and interspersing of express traffic, refer to IEEE Std 802.1CM-2018.



Figure 31: Preemption and Interspersing



**Note:** The inter-frame gap (IFG) is not depicted in the previous diagram for compactness. However there is IFG which results in  $tx_axis_mac_tready$  being deasserted between frames.

#### **Related Information**

**AXI4-Stream Interface** 

### **Receive AXI4-Stream Interface**

Receive AXI4-Stream Interface shows the two AXI4-Stream Interfaces, for express (rx\_axis\_e\_\*) and preempt traffic (rx\_axis\_p\_\*), when the core is generated with the optional TSN feature.

Note: The same descriptions and rules apply to these signals as the ones in Receive AXI4-Stream Interface.

# **Frame Reception**

The ingress frame can be either preempt or express type. The core determines the type and puts the ingress frame on either the express AXI4-Stream interface or on the preempt AXI4-Stream interface respectively.

Express traffic will be continuous and because the core does not have any buffering mechanism on this interface, you must be ready to accept the express frame at any given time.

Due to the nature of the preempt traffic, the frame can arrive as a set of fragments which will be assembled by the core. There is an option of inserting a FIFO on the preempt interface during core generation. When this FIFO is inserted, all the fragments of the preempt frame will be buffered and only when the assembly process successfully completed, the frame will be made available on the AXI4-Stream interface. If FIFO is not inserted, the tvalid on the AXI4-Stream interface can pulsate in-between fragments. Core asserts tlast to indicate completion of the fragment tlastassembly process; if the assembly process is not successful, it asserts tuser along with.

The following figure shows how the preempt frame fragments are presented on the AXI4-Stream interface when the FIFO is not inserted.





Figure 32: Preempt Frame Fragments: When the FIFO Not Inserted

Table 294: Control and Status Ports

| Name                                   | I/O | Description                                                                                                                                                                                                                                                                      | Clock<br>Domain |
|----------------------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
|                                        |     | CONTROL                                                                                                                                                                                                                                                                          |                 |
| ctl_en_preempt                         | I   | When asserted, it allows preemption.  For the very first time it is asserted, it triggers  Verification if ctl_disable_verify = 1'b0 and  stat_tx_mm_verified[1:0] = 2'b00.                                                                                                      | tx_clk_out      |
| ctl_hold_request                       | I   | If asserted, preempt traffic is withheld.                                                                                                                                                                                                                                        | tx_clk_out      |
| ctl_disable_verify                     | I   | If asserted, it inhibits the verification process.                                                                                                                                                                                                                               | tx_clk_out      |
| ctl_restart_verify                     | I   | A 0-to-1 transition will trigger Verification if ctl_disable_verify = 1'b0.                                                                                                                                                                                                      | tx_clk_out      |
| ctl_addfrag_size[1:0]                  | I   | Fragment size remaining to enable pre-emption: 2'b00 = 64-bytes 2'b01= 128-bytes 2'b10 = 192-bytes 2'b11 = 256-bytes                                                                                                                                                             | tx_clk_out      |
| ctl_verify_time[7:0]                   | I   | Verification time-out value in milliseconds. Integer range 1-128. Default is 1 ms.                                                                                                                                                                                               | tx_clk_out      |
| ctl_verify_limit[3:0]                  | I   | Number of times core attempts Verification. Integer range 1-15. Default is 3.                                                                                                                                                                                                    | tx_clk_out      |
| p_frame_len_0                          | I   | Indicates the length of the frame, in bytes, being presented at the TX Preempt AIX-S interface. Should be valid at preempt frame SOP.                                                                                                                                            | tx_clk_out      |
|                                        |     | STATUS                                                                                                                                                                                                                                                                           |                 |
| stat_tx_mm_verify[1:0]<br>(No Counter) | 0   | Indicates verification status.  [0] – When asserted, indicates that verification is complete.  [1] – When asserted, indicates that verification is successful.  The value contained in this status vector is valid only when ctl_en_preempt = 1'b1 and ctl_disable_verify = 1'b0 | tx_clk_out      |
| stat_tx_mm_status                      | 0   | Asserted when a preemptable packet (initial fragment or complete packet) is transmitted.                                                                                                                                                                                         | tx_clk_out      |



Table 294: Control and Status Ports (cont'd)

| Name                         | I/O    | Description                                                                                                                                                                                               | Clock<br>Domain |
|------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| stat_tx_mm_fragment          | 0      | Asserted when a continuation fragment of an preemptable packet is transmitted.                                                                                                                            | tx_clk_out      |
| stat_tx_mm_hold              | 0      | Asserted when ctl_hold_request transitions from 1'b0 to 1'b1.                                                                                                                                             | tx_clk_out      |
| stat_rx_mm_assembly_error    | 0      | Asserted when errors are detected during fragment assembly.                                                                                                                                               | rx_core_clk     |
| stat_rx_mm_frame_smd_error   | 0      | Asserted when the frame fragment is rejected due to an incorrect SMD value or arriving with SMD-C when no frame is in progress.                                                                           | rx_core_clk     |
| stat_rx_mm_frame_assembly_ok | 0      | Asserted when all the preemptable frame fragments have been assembled and presented.                                                                                                                      | rx_core_clk     |
| stat_rx_mm_fragment          | 0      | Asserted when a fragment frame is received.                                                                                                                                                               | rx_core_clk     |
| rx_p_frm_drop_0              | Output | Asserted by the packet assembly FIFO when it cannot continue with preempt fragment assembly because its full. When this happens all the fragments of the preempt frame received so far will be discarded. | rx_core_clk     |
| rx_p_frm_drop_count_0        | Output | Count of number of such events.                                                                                                                                                                           | rx_core_clk     |

#### Notes:

# Status/Control Interface

The Status/Control interface allows you to set up the 10G/25G Ethernet Subsystem core configuration and to monitor its status. This sections describes in more detail some of the Status and Control signals.

# stat\_rx\_framing\_err and stat\_rx\_framing\_err\_valid

These signals are used to keep track of sync header errors. This set of buses is used to keep track of sync header errors. The  $stat_rx_framing_err$  output indicates how many sync header errors were received and it is qualified (that is, the value is only valid) when the corresponding  $stat_rx_framing_err_valid$  is sampled as a 1.

### stat\_rx\_block\_lock

This bit indicates that the interface has achieved sync header lock as defined by IEEE Std. 802.3. A value of 1 indicates block lock is achieved.

Timestamp ports description for express and preempt interface is similar to 1588v2 ports description. For more details, see Port Descriptions.



# stat\_rx\_local\_fault

This output is High when stat\_rx\_internal\_local\_fault or stat\_rx\_received\_local\_fault is asserted. This output is level sensitive.

#### **RX Error Status**

The core provides status signals to identify 64b/66b words and sequences violations and CRC32 checking failures. All signals are synchronous with the rising-edge of clk. A detailed description of each signal follows.

# stat\_rx\_bad\_fcs[1:0]

When this signal is positive, it indicates that the error detection logic has identified mismatches between the expected and received value of CRC32 in the received packet. When a CRC32 error is detected, the received packet is marked as containing an error and is sent with  $rx_{errout}$  asserted during the last transfer (the cycle with  $rx_{eopout}$  asserted), unless  $ctl_rx_{ignore_fcs}$  is asserted. This signal is asserted for one clock period for each CRC32 error detected.

### stat\_rx\_bad\_code

This signal indicates how many cycles the RX PCS receive state machine is in the RX\_E state as defined by IEEE Std. 802.3.

# **Pause Processing**

The 10G/25G Ethernet Subsystem provides a comprehensive mechanism for pause packet termination and generation. The TX and RX have independent interfaces for processing pause information as described in this section.

### **TX Pause Generation**

You can request a pause packet to be transmitted using the  $ctl_tx_pause_req[8:0]$  and  $ctl_tx_pause_enable[8:0]$  input buses. Bit [8] corresponds to global pause packets and bits [7:0] correspond to priority pause packets.

Each bit of this bus must be held at a steady state for a minimum of 16 cycles before the next transition.





**CAUTION!** Requesting both global and priority pause packets at the same time results in unpredictable behavior and must be avoided.

The contents of the pause packet are determined using the following input pins.

#### Global pause packets:

```
ctl_tx_da_gpp[47:0]
ctl_tx_sa_gpp[47:0]
ctl_tx_ethertype_gpp[15:0]
ctl_tx_opcode_gpp[15:0]
ctl_tx_pause_quanta8[15:0]
```

#### Priority pause packets:

```
ctl_tx_da_ppp[47:0]
ctl_tx_sa_ppp[47:0]
ctl_tx_ethertype_ppp[15:0]
ctl_tx_opcode_ppp[15:0]
ctl_tx_pause_quanta0[15:0]
ctl_tx_pause_quanta1[15:0]
ctl_tx_pause_quanta2[15:0]
ctl_tx_pause_quanta3[15:0]
ctl_tx_pause_quanta4[15:0]
ctl_tx_pause_quanta5[15:0]
ctl_tx_pause_quanta5[15:0]
ctl_tx_pause_quanta7[15:0]
```

The 10G/25G Ethernet Subsystem automatically calculates and adds the FCS to the packet. For priority pause packets the 10G/25G Ethernet Subsystem also automatically generates the enable vector based on the priorities that are requested.

To request a pause packet, you must set the corresponding bit of the  $ctl_tx_pause_req[8:0]$  and  $ctl_tx_pause_enable[8:0]$  bus to 1 and keep it at 1 for the duration of the pause request (that is, if these inputs are set to 0, all pending pause packets are canceled). Pause is canceled by sending out an additional pause packet with the corresponding pause quanta set to 0. The 10G/25G Ethernet Subsystem transmits the pause packet immediately after the current packet in flight is completed.



**IMPORTANT!** Each bit of this bus must be held at a steady state for a minimum of 16 cycles before the next transition.

To retransmit pause packets, the 10G/25G Ethernet Subsystem maintains a total of nine independent timers; one for each priority and one for global pause. These timers are loaded with the value of the corresponding input buses. After a pause packet is transmitted the corresponding timer is loaded with the corresponding value of the

 $ctl_tx_pause_refresh_timer[8:0]$  input bus. When a timer times out, another packet for that priority (or global) is transmitted as soon as the current packet in flight is completed. Additionally, you can manually force the timers to 0, and therefore force a retransmission, by setting the  $ctl_tx_resend_pause$  input to 1 for one clock cycle.



To reduce the number of pause packets for priority mode operation, a timer is considered timed out if any of the other timers time out. Additionally, while waiting for the current packet in flight to be completed, any new timer that times out or any new requests are merged into a single pause frame. For example, if two timers are counting down, and you send a request for a third priority, the two timers are forced to be timed out and a pause packet for all three priorities is sent as soon as the current in-flight packet (if any) is transmitted. Similarly, if one of the two timers times out without an additional request, both timers are forced to be timed out and a pause packet for both priorities is sent as soon as the current in-flight packet (if any) is transmitted.

You can stop pause packet generation by setting the appropriate bits of ctl\_tx\_pause\_req[8:0] or ctl\_tx\_pause\_enable[8:0] to 0.

### **RX Pause Termination**

The 10G/25G Ethernet Subsystem terminates global and priority pause frames and provides a simple hand-shaking interface to allow user logic to respond to pause packets.

#### **Determining Pause Packets**

There are three steps in determining pause packets:

- Checks are performed to see if a packet is a global or a priority control packet.
   Packets that pass step one are forwarded to you only if ctl\_rx\_forward\_control is set to 1.
- 2. If step 1 passes, the packet is checked to determine if it is a global pause packet.
- 3. If step 2 fails, the packet is checked to determine if it is a priority pause packet.

For step 1, the following pseudo code shows the checking function:

```
assign da_match_gcp = (!ctl_rx_check_mcast_gcp && !ctl_rx_check_ucast_gcp)
|| ((DA
== ctl_rx_pause_da_ucast) && ctl_rx_check_ucast_gcp) || ((DA ==
48'h0180c2000001) &&
ctl_rx_check_mcast_gcp);
assign sa_match_gcp = !ctl_rx_check_sa_gcp || (SA == ctl_rx_pause_sa);
assign etype_match_gcp = !ctl_rx_check_etype_gcp || (ETYPE ==
ctl_rx_etype_gcp);
assign opcode_match_gcp = !ctl_rx_check_opcode_gcp || ((OPCODE >=
ctl_rx_opcode_min_gcp) && (OPCODE <= ctl_rx_opcode_max_gcp));</pre>
assign global_control_packet = da_match_gcp && sa_match_gcp &&
etype_match_gcp &&
opcode_match_gcp && ctl_rx_enable_gcp;
assign da_match_pcp = (!ctl_rx_check_mcast_pcp && !ctl_rx_check_ucast_pcp)
|| ((DA
== ctl_rx_pause_da_ucast) && ctl_rx_check_ucast_pcp) || ((DA ==
ctl_rx_pause_da_mcast) && ctl_rx_check_mcast_pcp);
assign sa_match_pcp = !ctl_rx_check_sa_pcp || (SA == ctl_rx_pause_sa);
assign etype_match_pcp = !ctl_rx_check_etype_pcp || (ETYPE ==
ctl_rx_etype_pcp);
```



```
assign opcode_match_pcp = !ctl_rx_check_opcode_pcp || ((OPCODE >=
ctl_rx_opcode_min_pcp) && (OPCODE <= ctl_rx_opcode_max_pcp));
assign priority_control_packet = da_match_pcp && sa_match_pcp &&
etype_match_pcp &&
opcode_match_pcp && ctl_rx_enable_pcp;
assign control_packet = global_control_packet || priority_control_packet;</pre>
```

where DA is the destination address, SA is the source address, OPCODE is the opcode and ETYPE is the ethertype/length field that is extracted from the incoming packet.

For step 2, the following pseudo code shows the checking function:

```
assign da_match_gpp = (!ctl_rx_check_mcast_gpp && !ctl_rx_check_ucast_gpp)
|| ((DA
== ctl_rx_pause_da_ucast) && ctl_rx_check_ucast_gpp) || ((DA ==
48'h0180c2000001) &&
ctl_rx_check_mcast_gpp);
assign sa_match_gpp = !ctl_rx_check_sa_gpp || (SA == ctl_rx_pause_sa);
assign etype_match_gpp = !ctl_rx_check_etype_gpp || (ETYPE ==
ctl_rx_etype_gpp);
assign opcode_match_gpp = !ctl_rx_check_opcode_gpp || (OPCODE ==
ctl_rx_opcode_gpp);
assign global_pause_packet = da_match_gpp && sa_match_gpp &&
etype_match_gpp &&
opcode_match_gpp &&
ctl_rx_enable_gpp;
```

where DA is the destination address, SA is the source address, OPCODE is the opcode and ETYPE is the ethertype/length field that are extracted from the incoming packet.

For step 3, the following pseudo code shows the checking function:

```
assign da_match_ppp = (!ctl_rx_check_mcast_ppp && !ctl_rx_check_ucast_ppp)
|| ((DA
== ctl_rx_pause_da_ucast) && ctl_rx_check_ucast_ppp) || ((DA == ctl_rx_pause_da_mcast) && ctl_rx_check_mcast_ppp);
assign sa_match_ppp = !ctl_rx_check_sa_ppp || (SA == ctl_rx_pause_sa);
assign etype_match_ppp = !ctl_rx_check_etype_ppp || (ETYPE == ctl_rx_etype_ppp);
assign opcode_match_ppp = !ctl_rx_check_opcode_ppp || (OPCODE == ctl_rx_opcode_ppp);
assign priority_pause_packet = da_match_ppp && sa_match_ppp && etype_match_ppp && opcode_match_ppp && ctl_rx_enable_ppp;
```

where DA is the destination address, SA is the source address, OPCODE is the opcode and ETYPE is the ethertype/length field that are extracted from the incoming packet.

#### **User Interface**

A simple handshaking protocol is used to alert you of the reception of pause packets using the  $ctl_rx_pause_enable[8:0]$ ,  $stat_rx_pause_req[8:0]$  and  $ctl_rx_pause_ack[8:0]$  buses. For these buses, bit [8] corresponds to global pause packets and bits [7:0] correspond to priority pause packets.

The following steps occur when a pause packet is received:





- 1. If the corresponding bit of ctl\_rx\_pause\_enable[8:0] is 0, the quanta is ignored and the core stays in step 1. Otherwise, the corresponding bit of the stat\_rx\_pause\_req[8:0] bus is set to 1, and the received quanta is loaded into a timer.
  - If one of the bits of ctl\_rx\_pause\_enable[8:0] is set to 0 (disabled) when the pause processing is in step 2 or later, the core completes the steps as normal until it comes back to step 1.
- 2. If ctl\_rx\_check\_ack input is 1, the core waits for you to set the appropriate bit of the ctl\_rx\_pause\_ack[8:0] bus to 1.
- 3. After you set the proper bit of ctl\_rx\_pause\_ack[8:0] to 1, or if ctl\_rx\_check\_ack is 0, the core starts counting down the timer.
- 4. When the timer times out, the core sets the appropriate bit of stat\_rx\_pause\_req[8:0] back to 0.
- 5. If ctl\_rx\_check\_ack input is 1, the operation is complete when you set the appropriate bit of ctl\_rx\_pause\_ack[8:0] back to 0.

If you do not set the appropriate bit of  $ctl_rx_pause_ack[8:0]$  back to 0, the core deems the operation complete after 32 clock cycles.

These steps are demonstrated in the following figure with each step shown on the waveform.

stat\_rx\_pause\_req[n]

ctl\_rx\_pause\_ack[n]

Received Quarkta Period

3 4

5

Figure 33: RX Pause Interface Example

If at any time during step 2 to step 5 a new pause packet is received, the timer is loaded with the newly acquired quanta value and the process continues.

**Note:** Transmitter MAC should not transmit frames/packets when it receives Pause frames from the receiver until the time duration specified in the Pause timer.

# **Auto-Negotiation**

# **Auto-Negotiation**

A block diagram of the 10G/25G Ethernet Subsystem with Auto-Negotiation (AN) and Link Training (LT) is shown in the following figure.





Figure 34: Core with Auto-Negotiation and Link Training

The auto-negotiation function allows an Ethernet device to advertise the modes of operation it possesses to another device at the remote end of a backplane Ethernet link and to detect corresponding operational modes the other device might be advertising. The objective of this auto-negotiation function is to provide the means to exchange information between two devices and to automatically configure them to take maximum advantage of their abilities. It has the additional objective of supporting a digital signal detect to ensure that the device is attached to a link partner rather than detecting a signal due to crosstalk. When auto-negotiation is complete, ability is reported according to the available modes of operation.

Link Training is performed after auto-negotiation if the Link Training function is supported by both ends of the link. Link Training is typically required due to frequency-dependent losses which can occur as digital signals traverse the backplane. The primary function of the Link Training block included with this core is to provide register information and a training sequence over the backplane link which is then analyzed by a receiving circuit (part of the transceiver). The other function of the Link Training block is to communicate training feedback from the receiver to the corresponding transmitter so that its equalizer circuit (part of the transceiver) can be adjusted as required. The decision-making algorithm is not part of this core. When auto-negotiation and Link Training are complete, the datapath is switched to mission mode (the PCS), as shown in the preceding figure.

#### Overview

The following figure shows the position of the auto-negotiation function in the OSI reference model.





Figure 35: Auto-Negotiation Function in the OSI Model

The Auto-Negotiation Intellectual Property Core (ANIPC) implements the requirements as specified in Clause 73, IEEE Std 802.3-2015, including those amendments specified in IEEE Std. P802.3ba and 802.3ap. The functions of the ANIPC core are listed in clause 73, specifically Figure 73-11, Arbitration state diagram, in section 73.10.4, State Diagrams.

During normal mission mode operation, with link control outputs set to (bin)11, the bit operating frequency of the transceiver input and output is typically 10.3125 or 25.78125 Gb/s. However, the Dual Manchester Encoding (DME) bit rate used on the lane during Auto-Negotiation is different to the mission mode operation. To accommodate this requirement, the ANIPC core uses over-sampling and over-driving to match the 156.25 Mb/s Auto-Negotiation speed (DME clock frequency 312.5 MHz) with the mission mode 10.3125 or 25.78125 Gb/s physical lane speed.

### **Functional Description**

#### autoneg\_enable

When the autoneg\_enable input signal is set to 1, auto-negotiation begins automatically at power-up, or if the carrier signal is lost, or if the input restart\_negotiation signal is cycled from a 0 to a 1. All of the Ability input signals as well as the two input signals PAUSE and ASM\_DIR are tied Low or High to indicate the capability of the hardware. The nonce\_seed[7:0] input must be set to a unique non-zero value for every instance of the autonegotiator. This is important to guarantee that no dead-locks occur at power-up. If two link partners connected together attempt to auto-negotiate with their nonce\_seed[7:0] inputs set to the same value, the auto-negotiation fails continuously. The pseudo\_sel input is an arbitrary selection that is used to select the polynomial of the random bit generator used in bit position 49 of the DME pages used during auto-negotiation. Any selection on this input is valid and does not result in adverse behavior.



#### **Link Control**

When auto-negotiation begins, the various link control signals are activated, depending on the disposition of the corresponding Ability inputs for those links. Subsequently, the corresponding link status signals are monitored by the ANIPC hardware for an indication of the state of the various links that are connected. If particular links are unused, the corresponding link control outputs are unconnected, and the corresponding link-status inputs should be tied Low. During this time, the ANIPC hardware sets up a communication link with the link partner and uses this link to negotiate the capabilities of the connection.

#### **Auto-Negotiation Complete**

When Auto-Negotiation is complete, the  $autoneg\_complete$  output signal is asserted. In addition, the output signal  $an\_fec\_enable$  is asserted if the Forward Error Correction hardware is to be used; the output signal  $tx\_pause\_en$  is asserted if the transmitter hardware is allowed to generate PAUSE control packets, the output signal  $rx\_pause\_en$  is asserted if the receiver hardware is allowed to detect PAUSE control packets, and the output link control of the selected link is set to its mission mode value (bin)11.



**IMPORTANT!** The autoneg\_complete signal is not asserted until rx\_status is received from the PCS. That means that, where link training is included, the autoneg\_complete output signal is not asserted until after link training has completed and rx\_status is High.

# **Link Training**

Link Training is performed after auto-negotiation converges to a backplane or copper technology. Technology selection can also be the result of a manual entry or parallel detection. Link training might be required due to frequency-dependent losses that can occur as digital signals traverse the backplane or a copper cable. The primary function of the Link Training core is to provide register information and a training sequence over the backplane link which is then analyzed by a receiving circuit which is not part of the core.

The other function of the core is to communicate training feedback from the receiver to the corresponding transmitter so that its equalizer circuit (not part of the core) can be adjusted as required. The two circuits comprising the core are the receive Link Training block and the transmit Link Training block.



**IMPORTANT!** The logic responsible for adjusting the transmitter pre-emphasis taps must be supplied external to this IP core.



### **Transmit**

The Link Training transmit block constructs a 4,384-bit frame which contains a frame delimiter, control channel, and link training sequence. It is formatted as shown in the following figure.

Figure 36: Link Training Frame Structure

548 octets 10.3125 Gb/s and 25.78125 Gb/s



X15161-051019

Xilinx recommends that the control channel bits not be changed by the Link Training algorithm while the transmit state machine is in the process of transmitting them, or they can be received incorrectly, possibly resulting in a DME error. This time begins when  $tx_SOF$  is asserted and ends at least 288 bit times later, or approximately 30 ns.

Although the coefficient and status contain 128 bit times at the line rate, the actual signaling rate for these two fields is reduced by a factor of eight. Therefore the DME clock rate is one quarter of the line rate.

#### Frame Marker

The frame marker consists of 16 consecutive 1s followed by 16 consecutive 0s. This pattern is not repeated in the remainder of the frame.

### Coefficient and Status

Because the DME signaling rate for these two fields is reduced by a factor of eight, each coefficient and status transmission contains 128/8=16 bits, each numbered from 15:0. The following tables define these bits in the order in which they are transmitted starting with bit 15 and ending with bit 0.

**Table 295: Coefficient and Update Field Bit Definitions** 

| Bits  | Name     | Description                                     |
|-------|----------|-------------------------------------------------|
| 15:14 | Reserved | Transmitted as 0, ignored on reception.         |
| 13    | Preset   | 1 = Preset coefficients<br>0 = Normal operation |



*Table 295:* Coefficient and Update Field Bit Definitions (cont'd)

| Bits | Name                    | Description                                                       |
|------|-------------------------|-------------------------------------------------------------------|
| 12   | Initialize              | 1 = Initialize coefficients<br>0 = Normal operation               |
| 11:6 | Reserved                | Transmitted as 0, ignored on reception.                           |
| 5:4  | Coefficient (+1) update | 1 1 = reserved<br>0 1 = increment<br>1 0 = decrease<br>0 0 = hold |
| 3:2  | Coefficient (0) update  | 1 1 = reserved<br>0 1 = increment<br>1 0 = decrease<br>0 0 = hold |
| 1:0  | Coefficient (-1) update | 1 1 = reserved<br>0 1 = increment<br>1 0 = decrease<br>0 0 = hold |

**Table 296: Status Report Field Bit Definitions** 

| Bits | Name                    | Description                                                                                                                                                       |
|------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | Receiver ready          | 1 = The local receiver has determined that training is complete and is prepared to receive data.     0 = The local receiver is requesting that training continue. |
| 14:6 | Reserved                | Transmitted as 0, ignored on reception.                                                                                                                           |
| 5:4  | Coefficient (+1) update | 1 1 = maximum 0 1 = updated 1 0 = minimum 0 0 = not_updated                                                                                                       |
| 3:2  | Coefficient (0) update  | 1 1 = maximum 0 1 = updated 1 0 = minimum 0 0 = not_updated                                                                                                       |
| 1:0  | Coefficient (-1) update | 1 1 = maximum 0 1 = updated 1 0 = minimum 0 0 = not_updated                                                                                                       |

The functions of each bit are defined in IEEE Std. 802.3, Clause 72. Their purpose is to communicate the adjustments of the transmit equalizer during the process of link training. The corresponding signal names are defined in Auto-Negotiation Ports.



### **Training Sequence**

The training sequence consists of a pseudo-random bit sequence (PRBS) of 4,094 bits followed by two zeros, for a total of 4,096 bits. The PRBS is transmitted at the line rate of 10.3125 or 25.78125 Gb/s. The PRBS generator receives an 11-bit seed from an external source. Subsequent to the initial seed being loaded, the PRBS generator continues to run with no further intervention required. The PRBS generator is implemented with a circuit which corresponds to the following polynomial:

$$G(x) = 1 + x9 + x11$$

### Receive

The receive block implements the frame alignment state diagram shown in IEEE Std. 802.3, Clause 72, Figure 72-4.

#### Frame Lock State Machine

The frame lock state machine searches for the frame marker, consisting of 16 consecutive 1s followed by 16 consecutive 0s. This functionality is fully specified in IEEE Std. 802.3, Clause 72, Fig. 72-4. When frame lock has been achieved, frame\_lock is set to a value of TRUE.

#### Received Data

The receiver outputs the control channel with the bit definitions defined in Transmit and signal names defined in Port Descriptions – MAC+PCS Variant.

If a DME error has occurred during the reception of a particular DME frame, the control channel outputs are not updated but retain the value of the last received good DME frame and are updated when the next good DME frame is received.

**Note:** While the Training Protocol is supported natively by the subsystem, there is no logic that controls the far-end transmitter adaptation based on analysis of the received signal quality. This is because, extensive testing has shown that to be unnecessary. However, a training interface is provided on the subsystem that allows access to all subsystem registers and to the DRP port on the transceiver. You can employ this interface to implement your own training algorithm for 10GBASE-KR, if required.

# Board Testing Steps for Auto-Negotiation and Link Training Using AXI4-Lite Interface

1. Enable the Abilities register, CONFIGURATION\_AN\_ABILITY (0x00F8), as per the core configuration or the abilities you want to advertise. For example, write the value 0x1E06 to address 0x00F8.



- 2. Read the CONFIGURATION\_AN\_CONTROL\_REG1 register (0x00E0), based on the requirement you can enable or bypass the auto-negotiation. If auto-negotiation is enabled than you need to write the nonce seed value into the same register. For example, write the value 0x16D to address 0x00E0.
- 3. Enable the Link Training option by setting the link training enable signal in the CONFIGURATION\_LT\_CONTROL\_REG1 (0x0100) register. For example, write the value 0x1 to address 0x0100.
- 4. Write 1 to CONFIGURATION\_LT\_TRAINED\_REG register (0x0104) to make ctl\_lt\_rx\_trained high. It indicates that the receiver finite impulse response (FIR) filter coefficients have all been set, and that the receiver portion of training is complete.
- 5. Write the CONFIGURATION\_LT\_SEED\_REGO register (0x0110) with some seed value. For example, write the value 0x0605 to address 0x0110.
- 6. Write the CONFIGURATION\_LT\_COEFFICIENT\_REGO register (0x0130) with some coefficient values for the place holder logic. For example, write the value 0x540 to address 0x0130.
- 7. Issue sys\_reset/write 1'b1 to ctl\_an\_reset (bit 28 of address 0x0004) so that the auto-negotiation block takes the updated nonce seed value into consideration.
- 8. Keep reading the stat\_an\_autoneg\_complete (bit 2 of address 0x0458) which indicates the successful completion of the auto-negotiation and link training.

If the link partner sends next pages, the  $ctl_an_lo_np_ack$  signal must be set. This port can be tied High.





# **Design Flow Steps**

This section describes customizing and generating the subsystem, constraining the subsystem, and the simulation, synthesis, and implementation steps that are specific to this IP subsystem. More detailed information about the standard Vivado® design flows and the IP integrator can be found in the following Vivado Design Suite user guides:

- Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- Vivado Design Suite User Guide: Designing with IP (UG896)
- Vivado Design Suite User Guide: Getting Started (UG910)
- Vivado Design Suite User Guide: Logic Simulation (UG900)

# **Customizing and Generating the Subsystem**

This section includes information about using Xilinx® tools to customize and generate the core in the Vivado Design Suite.

If you are customizing and generating the subsystem in the Vivado IP integrator, see the Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) for detailed information. IP integrator might auto-compute certain configuration values when validating or generating the design. To check whether the values do change, see the description of the parameter in this chapter. To view the parameter value, run the validate\_bd\_design command in the Tcl console.

You can customize the IP for use in your design by specifying values for the various parameters associated with the core using the following steps:

- 1. Select the IP from the IP catalog.
- 2. Double-click the selected IP or select the Customize IP command from the toolbar or right-click menu.

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) and Vivado Design Suite User Guide: Getting Started (UG910).

**Note:** Figures in this chapter are illustrations of the Vivado Integrated Design Environment (IDE). The layout depicted here might vary from the current version.



# **Configuration Tab**

The Configuration tab provides the basic core configuration options. Default values are prepopulated in all fields.



Figure 37: Configuration Tab (Versal)





Figure 38: Configuration Tab (UltraScale/UltraScale+)

**Table 297: Configuration Options** 

| Option                            | Values                                                                                                                      | Default                     |  |  |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|
| General                           |                                                                                                                             |                             |  |  |
| Select Core                       | Ethernet MAC 64-bit Ethernet PCS/PMA 32-bit Ethernet PCS/PMA 64-bit Ethernet MAC+PCS/PMA 32-bit Ethernet MAC+PCS/PMA 64-bit | Ethernet MAC+PCS/PMA 64-bit |  |  |
| Speed                             | 25.7812G<br>10.3125G                                                                                                        | 25.7812G                    |  |  |
| Runtime Switchable Mode           | 0, 1                                                                                                                        | 0                           |  |  |
| Num of Cores <sup>9</sup>         | 1<br>2<br>3<br>4                                                                                                            | 1                           |  |  |
| Clocking                          | Asynchronous                                                                                                                | Asynchronous                |  |  |
| Data Path Interface               | AXI4-Stream <sup>1</sup> Media Independent Interface (MII) <sup>2</sup>                                                     | AXI4-Stream                 |  |  |
|                                   | PCS/PMA 32-bit                                                                                                              |                             |  |  |
| Enable Preemption 802.3br Feature | 0, 1                                                                                                                        | 0                           |  |  |
| PCS/PMA Options                   |                                                                                                                             |                             |  |  |
| Base-R Base-KR                    | Base-R<br>Base-KR                                                                                                           | Base-KR                     |  |  |



Table 297: Configuration Options (cont'd)

| Option                                             | Values                                          | Default                    |
|----------------------------------------------------|-------------------------------------------------|----------------------------|
|                                                    | Include FEC Logic                               |                            |
| Clause 74 (BASE-KR FEC) <sup>3 6</sup>             | 0,1                                             | 0                          |
| Clause 108 (RS-FEC) <sup>4</sup>                   | 0,1                                             | 0                          |
| Clause 108 (Soft RS-FEC Tx, Hard RS-FEC Rx)        | 0,1                                             | 0                          |
| Auto                                               | o-Negotiation/Link Training Logic               |                            |
| Auto-Negotiation/Link Training Logic <sup>10</sup> | None<br>Include AN/LT Logic                     | None                       |
|                                                    | Control and Statistics Interface                |                            |
| Control and Statistics interface                   | Control and Status Vectors<br>Include AXI4-Lite | Control and Status Vectors |
| Include Statistics Counters <sup>5</sup>           | 0,1                                             | 1                          |
| Statistics Resource Type <sup>7</sup>              | Registers, Block RAM                            | Register                   |

#### Notes:

- The AXI4-Stream interface is visible and is the only option for the Ethernet MAC+PCS/PMA and standalone Ethernet MAC core.
- 2. The MII interface is visible and is the only option for the Ethernet PCS/PMA core.
- 3. Clause 74 (BASE-KR FEC) logic is not supported for Base-R.
- 4. Clause 108 (RS-FEC) is not supported for Base-R,10G speed.
- 5. The Statistics Counters are available in the register map only when you enable the Include Statistics Counters option. Otherwise, the Statistics Counters will not be available.
- 6. Clause 74 (BASE-KR FEC) and Clause 108 (RS-FEC) both can be selected in Vivado IDE but during functional operation only one can be enabled at a time using the respective control signals.
- 7. Statistics Resource Type Block RAM option will be provided in the future release.
- 8. Soft RS-FEC TX, Hard RS-FEC RX option to reduce logic utilization by leveraging the embedded 100G RS-FEC function that exists within the CMAC block in UltraScale+ devices.
- 9. The Number of Cores will be 1 only for the Versal® devices and multi-core will not be supported because GT will always be in the example design/outside the core.
- 10. Auto-Negotiation and Link Training is not supported for the Versal device family.

# **MAC Options Tab**

The MAC Options tab provides additional core configuration options.



Documentation | IP Location | Swinch to Defaults |

Show disabled ports | Component Name | Image: Comp

Figure 39: MAC Options Tab (Versal)

Figure 40: MAC Options Tab (UltraScale/UltraScale+)



Bought IP license available



#### **Table 298: MAC Options**

| Option                            | Values               | Default           |  |  |
|-----------------------------------|----------------------|-------------------|--|--|
| Optional Data Path Interface FIFO |                      |                   |  |  |
| Include FIFO Logic <sup>1</sup>   | Checked, Unchecked   | Checked           |  |  |
| Flow Control                      |                      |                   |  |  |
| Enable TX Flow Control Logic      | Checked, Unchecked   | Unchecked         |  |  |
| Enable RX Flow Control Logic      | Checked, Unchecked   | Unchecked         |  |  |
| IEEE PTP 1588v2                   |                      |                   |  |  |
| Enable Timestamping Logic         | Checked, Unchecked   | Unchecked         |  |  |
| Operation Mode                    | One Step<br>Two Step | Two Step          |  |  |
| 1588 SYS Clock period in ps       | 2000 to 100000       | 4000 <sup>2</sup> |  |  |
| Enable Datapath Parity            | 0, 1                 | 0                 |  |  |
| Enable Packet Assembly FIFO       | 0, 1                 | 0                 |  |  |

#### Notes:

- 1. This option will be available only when Base-R/BaseKR standard as Base-R and when this is unchecked then core will be in Low latency mode.
- 2. 4000 for Versal devices and 10000 for non-Versal devices.

# **GT Selection and Configuration Tab**

The GT Selection and Configuration tab enables you to configure the serial transceiver features of the core.





Figure 41: GT Selection and Configuration Tab (Versal)

Figure 42: GT Selection and Configuration Tab (UltraScale/UltraScale+)





### **Table 299: GT Clocks Options**

| Option                                                                    | Values                                                                                                                                  | Default                    |  |  |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|--|
| GT Location                                                               |                                                                                                                                         |                            |  |  |
| Select whether the GT IP is included in the core or in the example design | Include GT subcore in core Include GT subcore in example design                                                                         | Include GT subcore in core |  |  |
|                                                                           | GT Clocks <sup>2</sup>                                                                                                                  |                            |  |  |
| GT RefClk (In MHz) <sup>1</sup>                                           | 161.1328125<br>195.3125<br>156.25<br>201.4160156<br>257.8125<br>322.265625<br>312.5<br>103.125<br>128.90625<br>206.25<br>309.375        | 161.1328125                |  |  |
| GT DRP Clock (In MHz)                                                     | 10 – 250 MHz                                                                                                                            | 100.00                     |  |  |
|                                                                           | Core to GT Association                                                                                                                  |                            |  |  |
| GT Type                                                                   | GTY<br>GTH<br>GTM<br>GTYP                                                                                                               | GTY                        |  |  |
| GT Selection                                                              | Options based on device/package Quad groups. For example: Quad X0Y1 Quad X0Y2 Quad X0Y3                                                 | Quad X0Y1                  |  |  |
| Lane-00 to Lane-03                                                        | Auto filled based on device/package. For example, if Num of Core = 4, and GT Selection = Quad X0Y1, four lanes are: X0Y4 X0Y5 X0Y6 X0Y7 |                            |  |  |
| RX Equalization Mode                                                      | Auto<br>LPM<br>DFE                                                                                                                      | Auto                       |  |  |
| RX Insertion Loss at Nyquist (dB)                                         | Depends on the GT Wizard                                                                                                                | 30                         |  |  |
|                                                                           | Others                                                                                                                                  |                            |  |  |
| Enable Pipeline Registers                                                 | Checked, Unchecked                                                                                                                      | Unchecked                  |  |  |
| Enable GT Interface for Board Based<br>Design <sup>3</sup>                | Checked, Unchecked                                                                                                                      | Unchecked                  |  |  |



Table 299: GT Clocks Options (cont'd)

| Option                                            | Values             | Default   |
|---------------------------------------------------|--------------------|-----------|
| Enable Additional GT Control/Status and DRP Ports | Checked, Unchecked | Unchecked |

#### Notes:

- This list provides frequencies used for the default configurations. See Vivado IDE in the latest version of the tools for a complete list of supported clock frequencies for different speeds.
- 2. Following are the various GT clocks supporting various devices:
  - a. 10G Versal device supports 128.90625, 156.25,161.1328125, 206.25, 257.8125, 312.5, 322.265625.
  - b. 25G Versal device supports 161.1328125, 103.125, 128.90625, 156.25, 206.25, 257.8125, 309.375, 312.5, 322.265625.
  - c. 10G non-Versal device supports 156.25, 103.125, 128.90625, 161.1328125, 206.25, 257.8125, 309.375, 312.5, 322.265625.
  - d. 25G non-Versal device supports 161.1328125, 156.25, 195.3125, 201.4160156, 257.8125, 312.5, 322.265625.
  - e. Runtime switching feature supports <code>gt\_refclk</code> frequencies 128.90625, 206.25, 257.8125, 322.265625, 156.25, 161.1328125, and 312.5 for Versal devices and <code>gt\_refclk</code> frequency 161.1328125, 156.25, and 312.5 for non-Versal devices.
- 3. When selected, all the GT ports will be clubbed as a single bus interface as per GT standard interface. This will be used for board-based designs and is also suitable for the IP integrator-based connection automation flow. This will be applicable only when the GT subcore is present inside the IP core.

# **Shared Logic Tab**

The Shared Logic tab enables you to use shared logic in either the core or the example design.

Note: The Shared Logic tab is available only for UltraScale/UltraScale+ devices.

Figure 43: Shared Logic Tab (UltraScale/UltraScale+)



#### Table 300: Shared Logic Options

| Options                                                             | Default                      |
|---------------------------------------------------------------------|------------------------------|
| Include Shared Logic in core Include Shared Logic in example design | Include Shared Logic in core |

# **Output Generation**

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896).

# **Constraining the Subsystem**

This section contains information about constraining the core in the Vivado Design Suite.

#### **Required Constraints**

The 10G/25G High Speed Ethernet Subsystem requires the specification of timing and other physical implementation constraints to meet the specified performance requirements. These constraints are provided in a Xilinx® Device Constraints (XDC) file. Pinouts and hierarchy names in the generated XDC correspond to the provided example design of the 10G/25G High Speed Ethernet Subsystem.

To achieve consistent implementation results, an XDC containing these original, unmodified constraints must be used when a design is run through the Xilinx design tools. For additional details on the definition and use of an XDC specific constraints, see the *Vivado Design Suite User Guide: Using Constraints* (UG903).

Constraints provided in the 10G/25G High Speed Ethernet Subsystem have been verified through implementation and provide consistent results. Constraints can be modified, but modifications should only be made with a thorough understanding of the effect of each constraint.

#### **Device, Package, and Speed Grade Selections**

This section is not applicable for this IP subsystem.

#### **Clock Frequencies**

This section is not applicable for this subsystem.

#### Clock Management

This section is not applicable for this IP subsystem.



#### **Clock Placement**

This section is not applicable for this subsystem.

#### **Banking**

This section is not applicable for this IP subsystem.

#### **Transceiver Placement**

This section is not applicable for this IP subsystem.

#### I/O Standard and Placement

This section is not applicable for this IP subsystem.

# **Simulation**

For comprehensive information about Vivado simulation components, as well as information about using supported third-party tools, see the *Vivado Design Suite User Guide: Logic Simulation* (UG900).

# Simulation Speed Up

The example design contains wait timers. A `define SIM\_SPEED\_UP is available to improve simulation time by speeding up these wait times.SIM\_SPEED\_UP is only available when running RTL simulation. It is not available when running simulation with post synthesis or post implementation netlist.

#### **VCS**

Use the vlogan option: +define+SIM\_SPEED\_UP.

#### **ModelSim**

Use the vlog option: +define+SIM\_SPEED\_UP.

#### Vivado Simulator

Use the xvlog option: -d SIM\_SPEED\_UP.

#### **Questa Advanced Simulator**

Use the vlog option: +define+SIM\_SPEED\_UP.



#### **Riviera- Pro Simulator**

Use the vlog option: +define+SIM\_SPEED\_UP.

#### **Xcelium Parallel Simulator**

Use the xmvlog option: +define+SIM\_SPEED\_UP.

Note: The core must be simulated with fs resolution.

#### **RS-FEC Enabled Configuration Simulation**

For faster simulation, apply SIM\_SPEED\_UP and deselect the **Use Precompiled IP simulation libraries** check box in the Settings window, as shown in the following figures. If this is not done, the simulation can run for a long time, timing out with an error.

Figure 44: Use Precompiled IP Simulation Libraries Disabled







Figure 45: SIM\_SPEED\_UP Enabled

# **Synthesis and Implementation**

For details about synthesis and implementation, see the Vivado Design Suite User Guide: Designing with IP (UG896).





# Example Design

This chapter contains information about the example design provided in the Vivado® Design Suite when using the Vivado Integrated Design Environment (IDE).

### **Overview**

The following figure shows the instantiation of various modules and their hierarchy for a single core configuration of xxv\_ethernet\_0 example design when the GT (serial transceiver) is inside the IP core. (Serial Transceiver will always be a part of the example design for Versal® ACAP).

Sync registers and pipeline registers are used for to synchronize the data between the core and the GT.

Clocking helper blocks are used to generate the required clock frequency for the core.





Figure 46: Single Core Example Design Hierarchy

X15225-072321

The following user interfaces are available for different configurations.

- MAC/PCS configuration:
  - AXI4-Stream for datapath interface
  - AXI4-Lite for control and statistics interface
- PCS configuration:
  - MII for datapath interface
  - AXI4-Lite for control and statistics interface

The xxv\_ethernet\_0\_pkt\_gen\_mon module is used to generate the data packets for sanity testing. The packet generation and checking is controlled by a FSM module.

The optional modules are described as follows:



- xxv\_ethernet \_0\_trans\_debug: This module is present in the example design when you enable
  the Additional GT Control and Status Ports check box from the GT Selection and
  Configuration Tab in the Vivado IDE or Include GT subcore in example design option in the
  GT Selection and Configuration tab or the Runtime Switchable mode option in the in the
  Configuration tab. This module brings out all the GT channel DRP ports, and some control and
  status ports of the transceiver module out of the xxv\_ethernet core.
- Retiming registers: When you select the Enable Retiming Register option from the GT
   Selection and Configuration Tab, it includes a single stage pipeline register between core and
   the GT to ease timing, using the gt\_txusrclk2 and gt\_rxusrclk2 for TX and RX paths
   respectively. However, by default two-stage registering is done for the signals between GT
   and the core.
- TX / RX Sync register: The TX Sync register double synchronizes the data from the core to the GT with respect to the tx\_clk. The RX Sync register double synchronizes the data from the GT to the core with respect to the rx\_serdes\_clk.

**Note:** For Runtime Switchable, if Auto-Negotiation/Link training is selected in Vivado IDE, then AN operation will be performed only with the 25G data rate during switchings and LT will be performed in the mission mode.

**Note:** If Auto-Negotiation/Link training is selected in Vivado IDE and the number of cores >= 3, then a Pblock constraint must be applied for the anlt\_wrappers. The Pblock should be placed near to the selected transceivers (GT) and the size should be sufficient to fit the anlt\_wrapper utilization. Refer to example\_top.xdc for more information. Following is an example for a xcvu095-ffva2104-2-e device when four cores are selected and the transceivers are x0y4 to x0y7.

#### Example:

```
create_pblock pblock_ANLT
add_cells_to_pblock [get_pblocks pblock_ANLT] [get_cells -quiet [list DUT/
inst/
i_*_top_0/i_*_*_ANLT_WRAPPER DUT/inst/i_*_top_1/i_*_ANLT_WRAPPER DUT/inst/
i_*_top_2/i_*_ANLT_WRAPPER DUT/inst/i_*_top_3/
i_*_ANLT_WRAPPER]]resize_pblock
[get_pblocks pblock_ANLT] -add {SLICE_X0Y5:SLICE_X40Y180}
```

The following figure shows the instantiation of various modules and their hierarchy for the multiple core configuration of the xxv\_ethernet\_0 example design.





Figure 47: Multiple Core Example Design Hierarchy

# Example Design Hierarchy (GT in Example Design)

When the 10/25G Ethernet subsystem is added to Vivado IP integrator, the Run Block Automation IP/Core and GT (Serial transceivers) will get connected with some helper blocks as per the core configuration. There is a reset interface IP, internal to 10/25G Ethernet IP, used to release TX/RX mstreset to the Versal device GT and check for TX/RX mstresetdone status and reset sequencing to GT.





Figure 48: Single Core with GT in Example Design Hierarchy





Figure 49: Single Core with GT in Example Design Hierarchy (Versal ACAP)

The previous figures show the instantiation of various modules and their hierarchy for a single core configuration of the xxv\_ethernet\_0 design when the GT (serial transceiver) is outside the IP Core, that is, in the example design. This hierarchical example design is delivered when you select the **Include GT subcore in example design** option from the GT Selection and Configuration tab.

The xxv\_ethernet\_0\_core\_support.v is present in the hierarchy when you select the **Include GT subcore in example design** option from the GT Selection and Configuration tab.

The user interface available for MAC/PCS configuration and PCS configuration configurations is the same as mentioned in the Overview topic.

The  $xxv_{ethernet_0}$  . v module instantiates the necessary the sync registers/retiming pipeline registers for the synchronization of data between the core and the GT.

The  $xxv_{ethernet_0_pkt_gen_mon}$  module is used to generate the data packets for sanity testing. The packet generation and checking is controlled by a Finite State Machine (FSM) module. Description of optional modules are as follows:



- xxv\_ethernet \_0\_sharedlogic\_wrapper: This module is present in the example design when you select the Include GT subcore in example design option from the GT Selection and Configuration tab or Include Shared Logic in the Example Design from the Shared Logic tab. This module brings all modules that can be shared between multiple IP cores and designs outside the IP core.
- xxv\_ethernet \_0\_gt\_wrapper: This module is present in the example design when you select the Include GT subcore in example design option from the GT Selection and Configuration tab. This module is having instantiations of the GT along with various helper blocks. The clocking helper blocks are used to generate the required clock frequency for the core.

The following figure shows the instantiation of various modules and their hierarchy for the multiple core configuration of the xxv\_ethernet\_0 example design when the GT is in the example design.



Figure 50: Multiple Core with GT in Example Design Hierarchy

For Versal platforms, the  $gt_quad_base$  (GT Wizard for Versal device) will be a part of the example design only, and 10/25G Ethernet Subsystem IP and GT (Serial transceiver) IP will be connected in the block design using the IP integrator.



The following figure is a block design, where 10/25G Ethernet example design connected in the IP integrator. See the *Vivado Design Suite Tutorial*: *Designing IP Subsystems Using IP Integrator* (UG995) for more information on the IP integrator.

**Note:** When the 10/25G Ethernet subsystem is added to the Vivado IP integrator, the run Block Automation IP/Core and GT (Serial transceivers) will get connected with some helper blocks as per the core configuration. There is a reset interface IP, internal to 10/25G Ethernet IP, used to release TX/RX mstreset to Versal device GT and check for TX/RX mstresetdone status and reset sequencing to GT.



Figure 51: 10/25G Ethernet Block Design

### **User Interface**

General purpose I/Os (GPIOs) are provided to control the example design. The user input and output ports are described in the following table.

Table 301: User I/O Ports

| Name      | Size | I/O | Description         |
|-----------|------|-----|---------------------|
| sys_reset | 1    | I   | Reset for the core. |



Table 301: User I/O Ports (cont'd)

| Name                | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_ref_clk_p        | 1    | I   | Differential input clk to GT. This clock frequency should be equal to the GT RefClk frequency mentioned in the Vivado IDE GT Selection and Configuration tab.  Note: This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in core option is selected in the Shared Logic tab.                                       |
| gt_ref_clk_n        | 1    | I   | Differential input clk to GT. This clock frequency should be equal to the GT RefClk frequency mentioned in the Vivado IDE GT Selection and Configuration tab.  *Note: This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in core option is selected in the Shared Logic tab.                                      |
| gtm_gtrefclk        | 1    | I   | Single ended input clk to GT. This clock frequency should be equal to the GT Refclk frequency mentioned in the Vivado IDE GT Selection and Configuration tab.  Note: This port is available for non-Versal GTM devices, when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in Example Design option is selected in the Shared Logic tab. |
| dclk                | 1    | I   | Stable/free running input clk to GT. This clock frequency should be equal to the GT DRP clock frequency mentioned in the Vivado IDE GT Selection and Configuration tab.                                                                                                                                                                                                                                             |
| rx_gt_locked_led_0  | 1    | 0   | Indicates that GT has been locked.                                                                                                                                                                                                                                                                                                                                                                                  |
| rx_block_lock_led_0 | 1    | 0   | Indicates RX block lock has been achieved.                                                                                                                                                                                                                                                                                                                                                                          |
| restart_tx_rx_0     | 1    | I   | This signal is used to restart the packet generation and reception for the data sanity test when the packet generator and the packet monitor are in idle state.                                                                                                                                                                                                                                                     |



Table 301: User I/O Ports (cont'd)

| Name                   | Size | I/O | Description                                                                                                                                                                      |
|------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| completion_status      | 5    | 0   | This signal represents the test status/result.                                                                                                                                   |
|                        |      |     | • 5'd0 Test did not run.                                                                                                                                                         |
|                        |      |     | 5'd1 PASSED 25GE/10GE CORE TEST SUCCESSFULLY COMPLETED.                                                                                                                          |
|                        |      |     | • 5'd2 No block lock on any lanes.                                                                                                                                               |
|                        |      |     | • 5'd3 Not all lanes achieved block lock.                                                                                                                                        |
|                        |      |     | • 5'd4 Some lanes lost block lock after achieving block lock.                                                                                                                    |
|                        |      |     | • 5'd5 No lane sync on any lanes.                                                                                                                                                |
|                        |      |     | • 5'd6 Not all lanes achieved sync.                                                                                                                                              |
|                        |      |     | • 5'd7 Some lanes lost sync after achieving sync.                                                                                                                                |
|                        |      |     | • 5'd8 No alignment status or rx_status was achieved.                                                                                                                            |
|                        |      |     | • 5'd9 Loss of alignment status or rx_status after both were achieved.                                                                                                           |
|                        |      |     | • 5'd10 TX timed out.                                                                                                                                                            |
|                        |      |     | • 5'd11 No TX data was sent.                                                                                                                                                     |
|                        |      |     | 5'd12 Number of packets received did not equal the number of packets sent.                                                                                                       |
|                        |      |     | • 5'd13 Total number of bytes received did not equal the total number of bytes sent.                                                                                             |
|                        |      |     | • 5'd14 A protocol error was detected.                                                                                                                                           |
|                        |      |     | • 5'd15 Bit errors were detected in the received packets.                                                                                                                        |
|                        |      |     | • 5'd31 Test is stuck in reset.                                                                                                                                                  |
| mode_change_*          | 1    | I   | This port is available only when <b>Runtime Switchable</b> is selected in Vivado IDE and this is used to switch the core speed.                                                  |
| core_speed_*           | 1    | 0   | This signal indicates the speed with which the core is working:                                                                                                                  |
|                        |      |     | 1'b1 = 10G and 1'b0 = 25G                                                                                                                                                        |
| send_continuous_pkts_* | 1    | I   | This port can be used to send continuous packets for board validation.                                                                                                           |
|                        |      |     | • 1'b0 - Sends fixed 20 packets for simulation.                                                                                                                                  |
|                        |      |     | • 1'b1 - Sends continuous packets for the board.                                                                                                                                 |
|                        |      |     | <b>Note:</b> When the send_continuous_pkts is set to 1, the generator will continue sending the packets. The simulation will finish only if this signal will be reset back to 0. |
| stat_reg_compare       | 1    | 0   | Indicates TX and RX statistics registers comparison status.                                                                                                                      |
|                        |      |     | • 1'b1 - Indicates both the TX and RX statistics matched.                                                                                                                        |
|                        |      |     | • 1'b0 - Indicates if there is any mismatch between TX and RX statistics.                                                                                                        |
|                        |      |     | This output is available when you select <b>Include AXI4-Lite</b> option in the General Tab.                                                                                     |
| ts_clk                 | 1    | I   | This is the system timer clk input port.                                                                                                                                         |
|                        |      |     | <b>Note:</b> This port is available when you select Enable Timestamping Logic in the GUI Tab-2.                                                                                  |



Table 301: User I/O Ports (cont'd)

| Name          | Size | I/O | Description                                                                                                                                                                             |
|---------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ptp_results_* | 1    | O   | The timer comparison signal out to monitor and restrict the tools to optimize the PTP design.  Note: This port is available when you select Enable Timestamping Logic in the GUI Tab-2. |

# **Core xci Top Level Port List**

The top level port list for the core xci with all features enabled is listed below:

In the following tables, an asterisk (\*) represents the CORE number, having a value from 0 to 3.

Example: port\_name\_\*

- port\_name\_0: for first CORE
- port\_name\_1: for second CORE (present when you select number of cores ≥2)
- port\_name\_2: for third CORE (present when you select number of cores ≥3)
- port\_name\_3: for fourth CORE (present when you select number of cores =4)

## **Common Clock/Reset Signals**

Table 302: Common Clock/Reset Signals

| Name      | Size | I/O | Description                                                                                                                                                                                                                               |
|-----------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sys_reset | 1    | I   | Reset for core.                                                                                                                                                                                                                           |
|           |      |     | Note:                                                                                                                                                                                                                                     |
|           |      |     | This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the core type is not Ethernet MAC 64-bit.                                                              |
|           |      |     | 2. This port is available when the Include GT subcore option in the example design is selected in the GT Selection and Configuration tab. The core type is either Ethernet MAC+PCS/PMA 32-bit or PCS/PMA 32-bit and timestamp is enabled. |



Table 302: Common Clock/Reset Signals (cont'd)

| Name           | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dclk           | 1    | I   | Stable input clk to GT.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |      |     | <ol> <li>Note:</li> <li>This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the core type is not Ethernet MAC 64-bit.</li> <li>This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab. The core type is either Ethernet MAC+PCS/PMA 32-bit or PCS/PMA 32-bit and timestamp is enabled.</li> </ol> |
| sys_reset_0    | 1    | I   | Reset for core.  Note:                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |      |     | <ol> <li>This port is available when Soft RS-FEC TX and Hard RS-FEC RX options are enabled and Include GT subcore in core option is selected in the GT Selection and Configuration tab and the core type is not Ethernet MAC 64-bit.</li> </ol>                                                                                                                                                                                                      |
|                |      |     | 2. The port is available when <b>Soft RS-FEC TX</b> and <b>Hard RS-FEC RX</b> options are enabled and <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab and the core type is either Ethernet MAC+PCS/PMA 32-bit or PCS/PMA 32-bit and timestamp is enabled.                                                                                                                                   |
| dclk_0         | 1    | I   | Stable input clk to GT.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |      |     | Note:  1. This port is available when Soft RS-FEC TX and Hard RS-FEC RX options are enabled and Include GT subcore in core option is selected in the GT Selection and Configuration tab and the core type is not Ethernet MAC 64-bit.                                                                                                                                                                                                                |
|                |      |     | 2. The port is available when <b>Soft RS-FEC TX</b> and <b>Hard RS-FEC RX</b> options are enabled and <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab and the core type is either Ethernet MAC+PCS/PMA 32-bit or PCS/PMA 32-bit and timestamp is enabled.                                                                                                                                   |
| clk_322        | 1    | I   | Stable input clock to the CMAC based Hard RS-FEC block.                                                                                                                                                                                                                                                                                                                                                                                              |
|                |      |     | <b>Note:</b> This port is available for non-Versal GTM devices, when Soft RS-FEC TX and Hard RS-FEC RX options are enabled and Include Shared Logic in Example Design option is selected in the Shared Logic tab. You have to provide this clock signal (frequency of 322.265625 MHz) to the core.                                                                                                                                                   |
| locked_out_322 | 1    | I   | Stable reset for CMAC based Hard RS-FEC block. <b>Note:</b> This port is available when Soft RS-FEC TX and Hard RS-FEC RXoptions are enabled and Include Shared Logic in Example Design option is selected in the Shared Logic tab. You have to provide this signal to the core w.r.t. clk_322 signal.                                                                                                                                               |



Table 302: Common Clock/Reset Signals (cont'd)

| Name                     | Size | I/O | Description                                                                                                                                                                                                                                                          |
|--------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_refclk_p              | 1    | I   | Differential input clk to GT.                                                                                                                                                                                                                                        |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in core</b> option is selected in the Shared Logic tab.                                  |
| gt_refclk_n              | 1    | I   | Differential input clk to GT.                                                                                                                                                                                                                                        |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in core</b> option is selected in the Shared Logic tab.                                  |
| qpll0clk_in              | 2/4  | I   | QPLL0 clock input.                                                                                                                                                                                                                                                   |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
|                          |      |     | Port width: 2-bit for 50G single core and 4bit for 40G one core / 50G two core.                                                                                                                                                                                      |
| qpll0refclk_in           | 2/4  | I   | QPLL0 ref clock input.                                                                                                                                                                                                                                               |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
|                          |      |     | Port width: 2-bit for 50G single core and 4bit for 40G one core / 50G two core.                                                                                                                                                                                      |
| qpll1clk_in              | 2/4  | I   | QPLL1 clock input.                                                                                                                                                                                                                                                   |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
|                          |      |     | Port width: 2-bit for 50G single core and 4bit for 40G one core / 50G two core.                                                                                                                                                                                      |
| qpll1refclk_in           | 2/4  | I   | QPLL1 ref clock input.                                                                                                                                                                                                                                               |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
|                          |      |     | Port width: 2-bit for 50G single core and 4bit for 40G one core / 50G two core.                                                                                                                                                                                      |
| gtwiz_reset_qpll0lock_in | 1    | I   | QPLL0 lock reset input to the GT.                                                                                                                                                                                                                                    |
|                          |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM.     |



Table 302: Common Clock/Reset Signals (cont'd)

| Name                       | Size | I/O | Description                                                                                                                                                                                                                                                          |
|----------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gtwiz_reset_qpll0reset_out | 1    | 0   | QPLL0 lock reset output from the GT.                                                                                                                                                                                                                                 |
|                            |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
| gtwiz_reset_qpll1lock_in   | 1    | I   | QPLL1 lock reset input to the GT.                                                                                                                                                                                                                                    |
|                            |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
| gtwiz_reset_qpll1reset_out | 1    | 0   | QPLL1 lock reset output from the GT.                                                                                                                                                                                                                                 |
|                            |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab and GT Type is not GTM. |
| tx_clk_out_*               | 1    | 0   | TX user clock output from GT.                                                                                                                                                                                                                                        |
|                            |      |     | Note:  1. This port is available when the Select Core is Ethernet MAC +PCS/PMA 32/64-bit and the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                                            |
|                            |      |     | 2. This port is available when the <b>Select Core</b> is Ethernet MAC +PCS/PMA 32/64-bit and GT type is GTM and <b>Include GT subcore</b> in example design option is selected in the Selection and Configuration tab.                                               |
| tx_mii_clk_*               | 1    | 0   | TX mii clock output from GT.                                                                                                                                                                                                                                         |
|                            |      |     | Note:                                                                                                                                                                                                                                                                |
|                            |      |     | 1. This port is available when the <b>Select Core</b> is Ethernet PCS/PMA 32/64-bit and the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab.                                                                          |
|                            |      |     | 2. This port is available when the <b>Select Core</b> is Ethernet PCS/PMA 32/64-bit and GT type is GTM and <b>Include GT subcore in example design</b> option is selected in the Selection and Configuration tab.                                                    |
| rx_clk_out_*               | 1    | 0   | RX user clock output from GT.                                                                                                                                                                                                                                        |
|                            |      |     | Note:                                                                                                                                                                                                                                                                |
|                            |      |     | 1. This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab.                                                                                                                                   |
|                            |      |     | 2. This port is available when the <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab and GT type is GTM.                                                                                                      |
| rx_serdes_clk_*            | 1    | I   | RX serdes clock input to core.                                                                                                                                                                                                                                       |
|                            |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab and GT type is not GTM.                                                                                        |



Table 302: Common Clock/Reset Signals (cont'd)

| Name                   | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_serdes_reset_*      | 1    | I   | RX serdes reset input to core                                                                                                                                                                                                                                                                                                                                                             |
|                        |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab.                                                                                                                                                                                                                                    |
| rxrecclkout_*          | 1    | 0   | RX recovered clock output from GT.                                                                                                                                                                                                                                                                                                                                                        |
|                        |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab.                                                                                                                                                                                                                                              |
| tx_core_clk_*          | 1    | I   | TX Core clock input from GT wrapper.                                                                                                                                                                                                                                                                                                                                                      |
|                        |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in example design</b> option is selected in the GT Selection and Configuration tab and GT type is not GTM.                                                                                                                                                                                                             |
| rx_core_clk _*         | 1    | I   | RX Core clock input to the core.                                                                                                                                                                                                                                                                                                                                                          |
| tx_reset_*             | 1    | I   | TX reset input to the core.                                                                                                                                                                                                                                                                                                                                                               |
| user_tx_reset_*        | 1    | 0   | TX reset output for the user logic.                                                                                                                                                                                                                                                                                                                                                       |
|                        |      |     | <b>Note:</b> The user_tx_reset can be used to reset the user logic. It is asserted by the IP when GT resetdone goes low or when the clocks become unstable. This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in core</b> option is selected in the Shared Logic tab.        |
| gt_reset_tx_done_out_* | 1    | 0   | TX reset done signal from the GT.                                                                                                                                                                                                                                                                                                                                                         |
|                        |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab.                                                                                                                                             |
| rx_reset_*             | 1    | I   | RX reset input to the core.                                                                                                                                                                                                                                                                                                                                                               |
| user_rx_reset_*        | 1    | 0   | RX reset output for the user logic.                                                                                                                                                                                                                                                                                                                                                       |
|                        |      |     | <b>Note:</b> The user_rx_reset can be used to reset the user logic. It is asserted by the IP when GT resetdone goes low or when the clocks become unstable. This port is available when the <b>Include GT subcore</b> in <b>core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in core</b> option is selected in the Shared Logic tab. |
| gt_reset_rx_done_out_* | 1    | 0   | RX reset done signal from the GT.                                                                                                                                                                                                                                                                                                                                                         |
|                        |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab.                                                                                                                                             |
| gtwiz_reset_all_in*    | 1    | I   | gt_reset_all signal from the user.                                                                                                                                                                                                                                                                                                                                                        |
|                        |      |     | <b>Note:</b> Versal devices only. This port is available when the Control and Statistics interface is selected from the Configuration tab.                                                                                                                                                                                                                                                |



Table 302: Common Clock/Reset Signals (cont'd)

| Name                         | Size | I/O | Description                                                                                                                                                                                                                                   |
|------------------------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_gt_reset_all_*           | 1    | 0   | gt_reset_all signal from the AXI4-Lite register map.                                                                                                                                                                                          |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include AXI4-Lite</b> is selected from the Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab.                                |
| gtwiz_tx_datapath_reset_in_* | 1    | I   | gt_tx_reset signal from the user.                                                                                                                                                                                                             |
|                              |      |     | <b>Note:</b> Versal devices only. This port is available when the Control and Statistics interface option is selected from the Configuration tab.                                                                                             |
| ctl_gt_tx_reset_*            | 1    | 0   | gt_tx_reset signal from the AXI4-Lite register map.                                                                                                                                                                                           |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include AXI4-Lite</b> option is selected from the Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab.                         |
| gtwiz_rx_datapath_reset_in_* | 1    | I   | gt_rx_reset signal from the user.                                                                                                                                                                                                             |
|                              |      |     | <b>Note:</b> Versal devices only. This port is available when the Control and Statistics interface is selected from the Configuration tab.                                                                                                    |
| ctl_gt_rx_reset_*            | 1    | 0   | gt_rx_reset signal from the AXI4-Lite register map.                                                                                                                                                                                           |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include AXI4-Lite</b> is selected from the Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab.                                |
| gt_reset_all_in_*            | 1    | I   | gt_reset_all signal from the reset_wrapper of shared logic wrapper.                                                                                                                                                                           |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab. |
| gt_tx_reset_in_*             | 1    | I   | gt_tx_reset_in signal from reset_wrapper of shared logic wrapper.                                                                                                                                                                             |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab. |
| gt_rx_reset_in_*             | 1    | I   | gt_rx_reset_in signal from reset_wrapper of shared logic wrapper.                                                                                                                                                                             |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab. |
| gt_refclk_out                | 1    | 0   | Indicates the GT_refclk output.                                                                                                                                                                                                               |
|                              |      |     | <b>Note:</b> This port is available when the <b>Include GT subcore in core</b> option is selected in the GT Selection and Configuration tab and the <b>Include Shared Logic in example design</b> option is selected in the Shared Logic tab. |
| gtpowergood_out_*            | 1    | 0   | Refer to the <i>UltraScale Architecture GTH Transceivers User Guide</i> (UG576) or the <i>UltraScale Architecture GTY Transceivers User Guide</i> (UG578) for the port description.                                                           |



Table 302: Common Clock/Reset Signals (cont'd)

| Name                    | Size | I/O | Description                                                                                                                                                                                                                                        |
|-------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXOUTCLKSEL_IN_*        | 3    | I   | This port is used to select the clock source for the gtwizard TX output clock                                                                                                                                                                      |
|                         |      |     | This port to be driven with 3'b101 as per preset and will not present for GTM GT type.                                                                                                                                                             |
| RXOUTCLKSEL_IN_*        | 3    | I   | This port is used to select the clock source for the gtwizard RX output clock                                                                                                                                                                      |
|                         |      |     | This port to be driven with 3'b101 as per preset and will not present for GTM GT type.                                                                                                                                                             |
| gtm_txusrclk2_*         | 1    | I   | TX clock input to the core.                                                                                                                                                                                                                        |
|                         |      |     | <b>Note:</b> This port is available when <b>Include GT subcore in example design</b> option is selected from GT Selection and Configuration tab and GT type is GTM.                                                                                |
| gtm_rxusrclk2_*         | 1    | I   | RX clock input to the core.                                                                                                                                                                                                                        |
|                         |      |     | <b>Note</b> : This port is available when <b>Include GT subcore in example design</b> option is selected from GT Selection and Configuration tab and GT type is GTM.                                                                               |
| gtm_txusrclk_out2_*     | 1    | 0   | TX clock output from the core when gt is included in the core.                                                                                                                                                                                     |
|                         |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in example design option is selected in the Shared Logic tab and GT type is GTM. |
| gtm_rxusrclk_out2_*     | 1    | 0   | RX clock output from the core when gt is included in the core.                                                                                                                                                                                     |
|                         |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in example design option is selected in the Shared Logic tab and GT type is GTM. |
| gtm_rxprgdivresetdone_* | 1    | 0   | RX reset output from the core when gt is included in the core.                                                                                                                                                                                     |
|                         |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and the Include Shared Logic in example design option is selected in the Shared Logic tab and GT type is GTM. |
| txoutclk_out_*          | 1    | I   | TX clock input to the core.                                                                                                                                                                                                                        |
|                         |      |     | <b>Note:</b> This port is available for GTM devices, when Include Shared Logic in example design option is selected in the Shared Logic tab. You have to provide this frequency (156.25 MHz for 10G and 390.625 MHz for 25G) to the core.          |
| rxoutclk_out_*          | 1    | I   | RX clock input to the core.                                                                                                                                                                                                                        |
|                         |      |     | <b>Note:</b> This port is available for GTM devices, when Include Shared Logic in example design option is selected in the Shared Logic tab. You have to provide this frequency (156.25 MHz for 10G and 390.625 MHz for 25G) to the core.          |



Table 302: Common Clock/Reset Signals (cont'd)

| Name        | Size | I/O | Description                                                                                                                                                                                                                                   |
|-------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_locked_* | 1    | I   | TX resetdone input to the core  Note: This port is available for GTM devices,when Include Shared Logic in example design option is selected in the Shared Logic tab. You have to provide this input to the core w.r.t. txoutclk_out_* clock.  |
| rx_locked_* | 1    | I   | X resetdone input to the core.  Note: This port is available for GTM devices, when Include Shared Logic in example design option is selected in the Shared Logic tab. You have to provide this input to the core w.r.t. rxoutclk_out_* clock. |

### **Common Transceiver Interface Ports**

**Table 303: Common Transceiver Interface Ports** 

| Name              | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_loopback_in_*  | 3    | I   | GT loopback input signal. Refer to the GT user guide. <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                                                                                                                                                                             |
| gt_loopback_out_* | 1    | 0   | GT loopback output signal from AXI4-Stream register map. Refer to the GT user guide.  Note: This port is available when Include AXI4-Lite is selected from the Configuration tab and the Include GT subcore in example design option is selected in the GT Selection and Configuration tab.                                                                                                             |
| gt_txp_out        | 1    | 0   | Note: For board-based designs, this port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.  Note: For part-based designs, this port is available when the Include GT subcore in core option and Enable GT Interface for Board Based Design option are selected in the GT Selection and Configuration tab.                                  |
| gt_txn_out        | 1    | 0   | Differential serial GT TX output.  Note: For board-based designs, this port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.  Note: For part-based design, this port is available when the Include GT subcore in core option and Enable GT Interface for Board Based Design option is selected in the GT Selection and Configuration tab. |



*Table 303:* Common Transceiver Interface Ports (cont'd)

| Name        | Size | I/O | Description                                                                                                                                                                                                         |
|-------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_rxn_in   | 1    | I   | Differential serial GT RX input.                                                                                                                                                                                    |
|             |      |     | <b>Note:</b> For board-based designs, this port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                      |
|             |      |     | <b>Note:</b> For part-based designs, this port is available when the Include GT subcore in core option and Enable GT Interface for Board Based Design option is selected in the GT Selection and Configuration tab. |
| gt_rxp_in   | 1    | I   | Differential serial GT RX input.                                                                                                                                                                                    |
|             |      |     | <b>Note:</b> For board-based designs, this port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                      |
|             |      |     | <b>Note:</b> For part-based designs, this port is available when the Include GT subcore in core option and Enable GT Interface for Board Based Design option is selected in the GT Selection and Configuration tab. |
| gt_rxp_in_0 | 1    | I   | Differential serial GT RX input for lane 0.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                                               |
| gt_rxn_in_0 | 1    | I   | Differential serial GT RX input for lane 0.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                                               |
| gt_rxp_in_1 | 1    | I   | Differential serial GT RX input for lane 1.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when Num of Cores is >1 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                        |
| gt_rxn_in_1 | 1    | I   | Differential serial GT RX input for lane 1.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when Num of Cores is >1 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                        |
| gt_rxp_in_2 | 1    | I   | Differential serial GT RX input for lane 2.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when Num of Cores is >2 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                        |
| gt_rxn_in_2 | 1    | I   | Differential serial GT RX input for lane 2.                                                                                                                                                                         |
|             |      |     | <b>Note:</b> This port is available when Num of Cores is >2 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                                                        |



*Table 303:* Common Transceiver Interface Ports (cont'd)

| Name         | Size | I/O | Description                                                                                                                                                  |
|--------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_rxp_in_3  | 1    | I   | Differential serial GT RX input for lane 3.                                                                                                                  |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >3 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_rxn_in_3  | 1    | I   | Differential serial GT RX input for lane 3.                                                                                                                  |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >3 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_txp_out_0 | 1    | 0   | Differential serial GT TX output for lane 0.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                        |
| gt_txn_out_0 | 1    | 0   | Differential serial GT TX output for lane 0.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab.                        |
| gt_txp_out_1 | 1    | 0   | Differential serial GT TX output for lane 1.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >1 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_txn_out_1 | 1    | 0   | Differential serial GT TX output for lane 1.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >1 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_txp_out_2 | 1    | 0   | Differential serial GT TX output for lane 2.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >2 and the Include GT subcore in core option is selected in the GT Selectionand Configuration tab.  |
| gt_txn_out_2 | 1    | 0   | Differential serial GT TX output for lane 2.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >2 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_txp_out_3 | 1    | 0   | Differential serial GT TX output for lane 3.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >3 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |
| gt_txn_out_3 | 1    | 0   | Differential serial GT TX output for lane 3.                                                                                                                 |
|              |      |     | <b>Note:</b> This port is available when Num of Cores is >3 and the Include GT subcore in core option is selected in the GT Selection and Configuration tab. |



*Table 303:* Common Transceiver Interface Ports (cont'd)

| Name                 | Size      | I/O | Description                                                                                                                                                                                                    |
|----------------------|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gtwiz_loopback_*     | 3         | 0   | GT loopback output signal from AXI4-Lite register map. (Versal devices only). See the appropriate GT user guide.                                                                                               |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and the AXI4-Lite interface is selected from configuration tab. |
|                      |           |     | <b>Note:</b> You must manually connect this signal in the board design.                                                                                                                                        |
| gtwiz_tx_rate_*      | 8         | 0   | GT TX line rate select from the AXI4-Lite register map. (Versal devices only). See the appropriate GT user guide.                                                                                              |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and the AXI4-Lite interface is selected from configuration tab. |
| gtwiz_rx_rate_*      | 8         | 0   | GT TX line rate select from the AXI4-Lite register map. (Versal devices only). See the appropriate GT user guide.                                                                                              |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and the AXI4-Lite interface is selected from Configuration tab. |
| rxgearboxslip_in_*   | 1         | 0   | Rxgearboxslip signal from core to GT.                                                                                                                                                                          |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM.                                         |
| temperature          | 10        | I   | For more information, see Virtex UltraScale+ FPGAs GTM Transceivers Wizard LogiCORE IP Product Guide (PG315).                                                                                                  |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in core option is selected in the GT Selection and Configuration tab and GT type is GTM.                                                       |
| rxdatavalid_out_*    | 2         | I   | RX data valid signal from GT to core.                                                                                                                                                                          |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM.                                         |
| rx_serdes_data_out_* | 32/64/128 | I   | RX data signal from GT to core.                                                                                                                                                                                |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM.                                         |
|                      |           |     | The data width is 32/64 bits for 10G configuration and 128 bits for 25G configuration.                                                                                                                         |
| rxdata_out_*         | 256       | I   | RX data signal from GT to core.                                                                                                                                                                                |
|                      |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is GTM.                                             |



*Table 303:* Common Transceiver Interface Ports (cont'd)

| Name                | Size      | I/O | Description                                                                                                                                                            |
|---------------------|-----------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rxheader_out_*      | 6         | I   | RX header signal from GT to core.                                                                                                                                      |
|                     |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM. |
| rxheadervalid_out_* | 2         | I   | RX header valid signal from GT to core.                                                                                                                                |
|                     |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM. |
| tx_serdes_data_in_* | 32/64/128 | 0   | TX data signal from core to GT.                                                                                                                                        |
|                     |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is not GTM. |
|                     |           |     | The data width is 32/64 bits for 10G configuration and 128 bits for 25G configuration.                                                                                 |
| txdata_in_*         | 256       | 0   | TX data signal from core to GT.                                                                                                                                        |
|                     |           |     | <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab and GT type is GTM.     |
| mst_tx_resetdone_*  | 1         | I   | TX master resetdone signal from GT to Core indicates lane0 status. (Versal devices only).                                                                              |
| mst_rx_resetdone_*  | 1         | I   | RX master resetdone signal from GT to Core indicates lane0 status. (Versal devices only).                                                                              |
| tx_pma_resetdone_*  | 1         | I   | TX PMA resetdone signal from GT to Core indicates lane0 status. (Versal devices only).                                                                                 |
| rx_pma_resetdone_*  | 1         | I   | RX PMA resetdone signal from GT to Core indicates lane0 status. (Versal devices only).                                                                                 |
| mst_tx_reset_*      | 1         | 0   | TX master reset output signal from Core to GT of Lane0. (Versal devices only).                                                                                         |
| mst_rx_reset_*      | 1         | 0   | RX master reset output signal from Core to GT of Lane0. (Versal devices only).                                                                                         |
| txuserrdy_out_*     | 1         | 0   | TX user ready output signal from Core (reset Interface IP) to GT of Lane0. (Versal devices only).                                                                      |
| mst_tx_dp_reset_*   | 1         | 0   | TX reset output signal from GT reset IP to the core (Versal devices only).                                                                                             |
| mst_rx_dp_reset_*   | 1         | 0   | RX reset output signal from GT reset IP to the core (Versal devices only).                                                                                             |
| rxuserrdy_out_*     | 1         | 0   | RX user ready output signal from Core (reset Interface IP) to GT of Lane0. (Versal devices only).                                                                      |
| tx_resetdone_out_*  | 1         | 0   | TX user ready output signal from Core to example design. (Versal devices only).                                                                                        |
| rx_resetdone_out_*  | 1         | 0   | RX user ready output signal from Core to example design. (Versal devices only).                                                                                        |



*Table 303:* **Common Transceiver Interface Ports** (cont'd)

| Name          | Size | I/O | Description                                                                                                                                                                       |
|---------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| txheader_in_* | 6    | 0   | TX header signal from core to GT. <b>Note:</b> This port is available when the Include GT subcore in example design option is selected in the GT Selection and Configuration tab. |

### **Transceiver Core and Status Debug Ports**

The ports in the following table are available when the **Include GT subcore in core** option is selected in the GT Selection and Configuration tab or **Enable Additional GT Control/Status and DRP Ports** is selected from the GT Selection and Configuration tab.

For port descriptions, see *UltraScale FPGAs Transceivers Wizard LogiCORE IP Product Guide* (PG182), *UltraScale Architecture GTH Transceivers User Guide* (UG576) and *UltraScale Architecture GTY Transceivers User Guide* (UG578).

*Table 304:* Transceiver Core and Status Debug Ports

| Name                  | Size | I/O |
|-----------------------|------|-----|
| gt_dmonitorout_*      | 16   | 0   |
| gt_eyescandataerror_* | 1    | 0   |
| gt_eyescanreset_*     | 1    | I   |
| gt_eyescantrigger_*   | 1    | I   |
| gt_pcsrsvdin_*        | 16   | I   |
| gt_rxbufreset_*       | 1    | I   |
| gt_rxbufstatus_*      | 3    | 0   |
| gt_rxcdrhold_*        | 1    | I   |
| gt_rxcommadeten_*     | 1    | I   |
| gt_rxdfeagchold_*     | 1    | I   |
| gt_rxdfelpmreset_*    | 1    | I   |
| gt_rxlatclk_*         | 1    | I   |
| gt_rxlpmen_*          | 1    | I   |
| gt_rxpcsreset_*       | 1    | I   |
| gt_rxpmareset_*       | 1    | I   |
| gt_rxpolarity_*       | 1    | I   |
| gt_rxprbscntreset_*   | 1    | I   |
| gt_rxprbslocked_*     | 1    | 0   |
| gt_rxprbserr_*        | 1    | I   |
| gt_rxprbssel_*        | 4    | I   |
| gt_rxrate_*           | 3    | I   |
| gt_rxslide_in_*       | 1    | I   |



Table 304: Transceiver Core and Status Debug Ports (cont'd)

| Name                      | Size | I/O |
|---------------------------|------|-----|
| gt_rxstartofseq_*         | 2    | 0   |
| gt_txresetdone_*          | 1    | 0   |
| gt_txbufstatus_*          | 2    | 0   |
| gt_txdiffctrl_*           | 5    | I   |
| gt_txinhibit_*            | 1    | I   |
| gt_txlatclk_*             | 1    | I   |
| gt_txmaincursor_*         | 7    | I   |
| gt_txpcsreset_*           | 1    | I   |
| gt_txpmareset_*           | 1    | I   |
| gt_txpolarity_*           | 1    | I   |
| gt_txpostcursor_*         | 5    | I   |
| gt_txprbsforceerr_*       | 1    | I   |
| gt_txprbssel_*            | 4    | I   |
| gt_txprecursor_*          | 5    | I   |
| gtwiz_reset_tx_datapath_* | 1    | I   |
| gtwiz_reset_rx_datapath_* | 1    | I   |
| gt_drpclk_*1              | 1    | I   |
| gt_drpdo_*1               | 16   | 0   |
| gt_drprdy_* <sup>1</sup>  | 1    | 0   |
| gt_drpen_* <sup>1</sup>   | 1    | I   |
| gt_drpwe_* <sup>1</sup>   | 1    | I   |
| gt_drpaddr_* <sup>1</sup> | 10   | I   |
| gt_drpdi_* <sup>1</sup>   | 16   | I   |
| gt_drprst_*               | 1    | I   |

#### Notes:

### **AXI4-Lite Interface Ports**

Ports in the following table are available when **Include AXI4-Lite** is selected on the Configuration tab.

**Table 305: AXI4-Lite Interface Ports** 

| Name            | Size | I/O | Description        |
|-----------------|------|-----|--------------------|
| s_axi_aclk_*    | 1    | I   | AXI clock signal   |
| s_axi_aresetn_* | 1    | I   | AXI reset signal   |
| pm_tick_*       | 1    | I   | PM tick user input |
| s_axi_awaddr_*  | 32   | I   | AXI write address  |

<sup>1.</sup> This port is available for non-Versal device only.



Table 305: AXI4-Lite Interface Ports (cont'd)

| Name            | Size | I/O | Description                                                                                                                              |
|-----------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi_awvalid_* | 1    | I   | AXI write address valid                                                                                                                  |
| s_axi_awready_* | 1    | 0   | AXI write address ready                                                                                                                  |
| s_axi_wdata_*   | 32   | I   | AXI write data                                                                                                                           |
| s_axi_wstrb_*   | 4    | I   | AXI write strobe. This signal indicates which byte lanes hold valid data.                                                                |
| s_axi_wvalid_*  | 1    | I   | AXI write data valid. This signal indicates that valid write data and strobes are available.                                             |
| s_axi_wready_*  | 1    | 0   | AXI write data ready                                                                                                                     |
| s_axi_bresp_*   | 2    | 0   | AXI write response. This signal indicates the status of the write transaction.  'b00 = OKAY  'b01 = EXOKAY  'b10 = SLVERR  'b11 = DECERR |
| s_axi_bvalid_*  | 1    | 0   | AXI write response valid. This signal indicates that the channel is signaling a valid write response.                                    |
| s_axi_bready_*  | 1    | I   | AXI write response ready.                                                                                                                |
| s_axi_araddr_*  | 32   | I   | AXI read address                                                                                                                         |
| s_axi_arvalid_* | 1    | I   | AXI read address valid                                                                                                                   |
| s_axi_arready_* | 1    | 0   | AXI read address ready                                                                                                                   |
| s_axi_rdata_*   | 32   | 0   | AXI read data issued by slave                                                                                                            |
| s_axi_rresp_*   | 2    | 0   | AXI read response. This signal indicates the status of the read transfer.  'b00 = OKAY  'b01 = EXOKAY  'b10 = SLVERR  'b11 = DECERR      |
| s_axi_rvalid_*  | 1    | 0   | AXI read data valid                                                                                                                      |
| s_axi_rready_*  | 1    | I   | AXI read ready. This signal indicates the user/master can accept the read data and response information.                                 |

### **AXI4-Stream User Interface Signals**

Ports in this section are available when Ethernet MAC+PCS/PMA-32/64-bit is selected from the Configuration tab.



**Table 306: AXI4-Stream User Interface Signals** 

| Name             | Size  | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_unfout_*      | 1     | 0   | Underflow signal for TX datapath from core. If tx_unfout_* is sampled as 1, a violation has occurred meaning the current packet is corrupted. Error control blocks are transmitted as long as the underflow condition persists.  It is up to the user logic to ensure a complete packet is input to the core without under-running the TX datapath interface.  *Note: When this signal sampled as 1, you must apply tx_reset/sys_reset to recover the subsystem from the underflow issue. tx_reset resets the TX path only and sys_reset recovers the complete system. |
| tx_axis_tready_* | 1     | 0   | TX path ready signal from core.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| tx_axis_tvalid_* | 1     | I   | Transmit AXI4-Stream Data valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| tx_axis_tdata_*  | 64/32 | I   | Transmit AXI4-Stream Data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| tx_axis_tlast_*  | 1     | I   | Transmit AXI4-Stream tlast.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| tx_axis_tkeep_*  | 8/4   | I   | Transmit AXI4-Stream tkeep.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| tx_axis_tuser_*  | 1     | I   | Transmit AXI4-Stream tuser.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| tx_preamblein_*  | 56    | I   | Transmit AXI4-Stream preamble.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| tx_parityin_*    | 8     | I   | Transmit AXI4-Stream datapath parity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| rx_axis_tvalid_* | 1     | 0   | Receive AXI4-Stream Data valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| rx_axis_tdata_*  | 64/32 | 0   | Receive AXI4-Stream Data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| rx_axis_tlast_*  | 1     | I   | Receive AXI4-Stream tlast.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rx_axis_tkeep_*  | 8/4   | I   | Receive AXI4-Stream tkeep.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rx_axis_tuser_*  | 1     | I   | Receive AXI4-Stream tuser.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rx_preamblein_*  | 56    | I   | Receive AXI4-Stream preamble.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| rx_parityout_*   | 8     | 0   | Receive AXI4-Stream datapath parity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### **MII User Interface Signals**

Ports under this section are available when **Ethernet MAC+PCS/PMA-32/64-bit** is selected from the Configuration tab.

**Table 307: MII User Interface Signals** 

| Name       | Size | I/O | Description                       |
|------------|------|-----|-----------------------------------|
| tx_mii_d_* | 64   | I   | Transmit XGMII/25GMII Data bus.   |
| tx_mii_c_* | 8    | I   | XGMII/25GMII Control bus.         |
| rx_mii_d_* | 64   | 0   | Receive XGMII/25GMII Data bus.    |
| rx_mii_c_* | 8    | 0   | Receive XGMII/25GMII Control bus. |



# **TX Path Control/Status/Statistics Signals**

#### **Table 308: TX Path Control/Status/Statistics Signals**

| Name                    | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_enable_*         | 1    | I   | TX Enable. This signal is used to enable the transmission of data when it is sampled as a 1. When sampled as a 0, only idles are transmitted by the core. This input should not be set to 1 until the receiver it is sending data to (that is, the receiver in the other device) is fully aligned and ready to receive data (that is, the other device is not sending a remote fault condition).  Otherwise, loss of data can occur. If this signal is set to 0 while a packet is being transmitted, the current packet transmission is completed and then the core stops transmitting any more packets.  Note: This port is available when Include AXI4-Lite is not selected and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| ctl_tx_send_rfi_*       | 1    | I   | Transmit Remote Fault Indication (RFI) code word. If this input is sampled as a 1, the TX path only transmits Remote Fault code words. This input should be set to 1 until the RX path is fully aligned and is ready to accept data from the link partner.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                    |
| ctl_tx_send_lfi_*       | 1    | I   | Transmit Local Fault Indication (LFI) code word. Takes precedence over RFI.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| ctl_tx_send_idle_*      | 1    | I   | Transmit Idle code words. If this input is sampled as a 1, the TX path only transmits Idle code words. This input should be set to 1 when the partner device is sending Remote Fault Indication (RFI) code words.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ctl_tx_fcs_ins_enable_* | 1    | I   | Enable FCS insertion by the TX core. If this bit is set to 0, the core does not add FCS to the packet. If this bit is set to 1, the HSEC core calculates and adds the FCS to the packet. This input cannot be changed dynamically between packets.  Note: This port is available when Include AXI4-Lite is not selected and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                       |



Table 308: TX Path Control/Status/Statistics Signals (cont'd)

| Name                                | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_ignore_fcs_*                 | 1    | I   | Enable FCS error checking at the interface by the TX core. This input only has effect when ctl_tx_fcs_ins_enable is Low. If this input is Low and a packet with bad FCS is being transmitted, it is not binned as good. If this input is High, a packet with bad FCS is binned as good.  The error is flagged on the signals stat_tx_bad_fcs and stomped_fcs, and the packet is transmitted as it was received. Statistics are reported as if there was no FCS error.  Note: This port is available when Include AXI4-Lite is not selected and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| ctl_tx_test_pattern_*               | 1    | I   | Scrambled idle test-pattern generation enable for the TX core. A value of 1 enables test mode as defined in Clause 49. Corresponds to MDIO register bit 3.42.7 as defined in Clause 45.  **Note: This port is available when Include AXI4-Lite* is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_tx_test_pattern_enable_*        | 1    | I   | Test pattern enable for the TX core. A value of 1 enables test mode. Corresponds to MDIO register bit 3.42.2 as defined in Clause 45. Takes second precedence.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                          |
| ctl_tx_test_pattern_select_*        | 1    | I   | Corresponds to MDIO register bit 3.42.1 as defined in Clause 45. <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ctl_tx_data_pattern_select_*        | 1    | I   | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45. <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| ctl_tx_test_pattern_seed_a_*        | 58   | I   | Corresponds to MDIO registers 3.34 through to 3.37 as defined in Clause 45.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ctl_tx_test_pattern_seed_b_*        | 58   | I   | Corresponds to MDIO registers 3.38 through to 3.41 as defined in Clause 45.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| ctl_tx_prbs31_test_pattern_enable_* | 1    | I   | Corresponds to MDIO register bit 3.42.4 as defined in Clause 45. Takes first precedence.  Note: This port is available when Include AXI4-Lite is not selected in the GT Selection and Configuration tab and Select Core is PCS/PMA 64-bit in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                    |



Table 308: TX Path Control/Status/Statistics Signals (cont'd)

| Name                            | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_ipg_value_*              | 4    | I   | This signal can be optionally present. The ctl_tx_ipg_value defines the target average minimum Inter Packet Gap (IPG, in bytes) inserted between rx_serdes_clk packets. Typical value is 12. The ctl_tx_ipg_value can also be programmed to a value in the 0 to 7 range, but in that case, it is interpreted as meaning "minimal IPG", so only Terminate code word IPG is inserted; no Idles are ever added in that case and that produces an average IPG of around 4 bytes when random-size packets are transmitted.  **Note:** This port is available when Include AXI4-Lite* is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit and Include FIFO Logic is enabled in the MAC Options tab. |
| ctl_tx_custom_preamble_enable_* | 1    | I   | When asserted, this signal enables the use of tx_preamblein as a custom preamble instead of inserting a standard preamble.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit and the Include FIFO Logic is disabled in the MAC Options tab or Select Core is Ethernet MAC.                                                                                                                                                                                                                                                                                                                                                             |
| ctl_tx_parity_err_response_*    | 1    | I   | Parity error response by the TX Core. If this bit is set to 0, the core does not take any action if any parity errors are detected. If this bit is set to 1, the core stomps the outgoing FCS (i.e., bit-wise inverse) and asserts stat_tx_bad_fcs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| stat_tx_bad_parity_*            | 1    | 0   | Increment on any clock cycle where the user-generated parity is calculated as incorrect by the Tx parity checking logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| stat_tx_local_fault_*           | 1    | 0   | A value of 1 indicates the receive decoder state machine is in the TX_INIT state. This output is level sensitive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| stat_tx_fifo_error_*            | 1    | 0   | Indicates when TX FIFO goes into an underflow or overflow condition.  Note: This port is available when Select Core is Ethernet PCS/PMA in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| stat_tx_total_bytes_*           | 5    | 0   | Increment for the total number of bytes transmitted.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| stat_tx_total_packets_*         | 1    | 0   | Increment for the total number of packets transmitted.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| stat_tx_total_good_bytes_*      | 14   | 0   | Increment for the total number of good bytes transmitted. This value is only non-zero when a packet is transmitted completely and contains no errors.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| stat_tx_total_good_packets_*    | 1    | 0   | Increment for the total number of good packets transmitted.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



Table 308: TX Path Control/Status/Statistics Signals (cont'd)

| Name                             | Size | I/O | Description                                                                                                                                                                                                   |
|----------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_tx_bad_fcs_*                | 1    | 0   | Increment for packets greater than 64 bytes that have FCS errors.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                 |
| stat_tx_packet_64_bytes_*        | 1    | 0   | Increment for good and bad packets transmitted that contain 64 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.             |
| stat_tx_packet_65_127_bytes_*    | 1    | 0   | Increment for good and bad packets transmitted that contain 65 to 127 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.      |
| stat_tx_packet_128_255_bytes_*   | 1    | 0   | Increment for good and bad packets transmitted that contain 128 to 255 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.     |
| stat_tx_packet_256_511_bytes_*   | 1    | 0   | Increment for good and bad packets transmitted that contain 256 to 511 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.     |
| stat_tx_packet_512_1023_bytes_*  | 1    | 0   | Increment for good and bad packets transmitted that contain 512 to 1,023 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.   |
| stat_tx_packet_1024_1518_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 1,024 to 1,518 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_tx_packet_1519_1522_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 1,519 to 1,522 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_tx_packet_1523_1548_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 1,523 to 1,548 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_tx_packet_1549_2047_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 1,549 to 2,047 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |



Table 308: TX Path Control/Status/Statistics Signals (cont'd)

| Name                             | Size | I/O | Description                                                                                                                                                                                                                                                               |
|----------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_tx_packet_2048_4095_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 2,048 to 4,095 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                             |
| stat_tx_packet_4096_8191_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 4,096 to 8,191 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                             |
| stat_tx_packet_8192_9215_bytes_* | 1    | 0   | Increment for good and bad packets transmitted that contain 8,192 to 9,215 bytes.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                             |
| stat_tx_packet_small_*           | 1    | 0   | Increment for all packets that are less than 64 bytes long. Packets that are less than 64 bytes are not transmitted.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                          |
| stat_tx_packet_large_*           | 1    | 0   | Increment for all packets that are more than 9,215 bytes long.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                |
| stat_tx_frame_error_*            | 1    | 0   | Increment for packets with tx_axis_tuser set to indicate an End of Packet (EOP) abort or frames aborted by de-asserting tvalid without tlast.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |

# **RX Path Control/Status/Statistics Signals**

Table 309: RX Path Control/Status/Statistics Signals

| Name            | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_enable_* | 1    | I   | RX Enable. For normal operation, this input must be set to 1. When this input is set to 0, after the RX completes the reception of the current packet (if any), it stops receiving packets by keeping the PCS from decoding incoming data. In this mode, there are no statistics reported and the user interface is idle.  **Note: This port is available when Include AXI4-Lite* is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC. |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                    | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_check_preamble_* | 1    | I   | When asserted, this input causes the Ethernet MAC to check the preamble of the received frame.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                                                                                                                                                                                                                                                                                                                               |
| ctl_rx_check_sfd_*      | 1    | I   | When asserted, this input causes the Ethernet MAC to check the start of frame Delimiter of the received frame.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                                                                                                                                                                                                                                                                                                               |
| ctl_rx_force_resync_*   | 1    | I   | RX force resynchronization input. This signal is used to force the RX path to reset, re-synchronize, and realign. A value of 1 forces the reset operation. A value of 0 allows normal operation.  Note: This input should normally be Low and should only be pulsed (1 cycle minimum pulse) to force realignment.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                                                                                                            |
| ctl_rx_delete_fcs_*     | 1    | I   | Enable FCS removal by the RX core. If this bit is set to 0, the HSEC core does not remove the FCS of the incoming packet. If this bit is set to 1, the HSEC core deletes the FCS to the received packet. FCS is not deleted for packets that are =<8 bytes long. This input should only be changed while the corresponding reset input is asserted.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                                                                          |
| ctl_rx_ignore_fcs_*     | 1    | I   | Enable FCS error checking at the user interface by the RX core. If this bit is set to 0, a packet received with an FCS error is sent with the tuser pin asserted during the last transfer (tuser and tlast sampled 1). If this bit is set to 1, the HSEC core does not flag an FCS error at the user interface.  **Note:** The statistics are reported as if the packet is good. The stat_rx_bad_fcs signal, however, reports the error.  **Note:** This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC. |
| ctl_rx_max_packet_len_* | 15   | I   | Any packet longer than this value is considered to be oversized. If a packet has a size greater than this value, the packet is truncated to this value and the rx_errout signal is asserted along with the rx_eopout signal. Packets less than 4 bytes are dropped. The allowed value for this bus can range from 64 to 16,383. ctl_rx_max_packet_len[14] is reserved and must be set to 0.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                                  |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                                | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_min_packet_len_*             | 8    | I   | Any packet shorter than this value is considered to be undersized. If a packet has a size less than this value, the rx_errout signal is asserted during the rx_eopout asserted cycle. Packets that are less than 4 bytes are dropped.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC. |
| ctl_rx_process_lfi_*                | 1    | I   | When this input is set to 1, the RX core expects and processes LF control codes coming in from the transceiver. When set to 0, the RX core ignores LF control codes coming in from the transceiver.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit or Ethernet MAC.                                   |
| ctl_rx_test_pattern_*               | 1    | I   | Test pattern checking enable for the RX core. A value of 1 enables test mode as defined in Clause 49. Corresponds to MDIO register bit 3.42.2 as defined in Clause 45. Checks for scrambled idle pattern.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab.                                                                                               |
| ctl_rx_data_pattern_select_*        |      |     | Corresponds to MDIO register bit 3.42.0 as defined in Clause 45.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit and the Include FIFO Logic is disabled.                                                                                                                                               |
| ctl_rx_test_pattern_enable_*        |      |     | Test pattern enable for the RX core. A value of 1 enables test mode. Corresponds to MDIO register bit 3.42.2 as defined in Clause 45. Takes second precedence.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit and the Include FIFO Logic is disabled.                                                 |
| ctl_rx_prbs31_test_pattern_enable_* | 1    | I   | Corresponds to MDIO register bit 3.42.1 as defined in Clause 45.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and the Select Core is PCS/PMA 64-bit.                                                                                                                                                                                                  |
| ctl_rx_custom_preamble_enable_*     | 1    | I   | When asserted, this signal causes the preamble to be presented on rx_preambleout.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab and Select Core is Ethernet MAC+PCS/PMA-32/64-bit and the Include FIFO Logic is disabled or Select Core is Ethernet MAC.                                                                                               |
| stat_rx_block_lock_*                | 4    | 0   | Block lock status for each PCS lane. A value of 1 indicates that the corresponding lane has achieved block lock as defined in Clause 82. Corresponds to MDIO register bit 3.50.7:0 and 3.51.11:0 as defined in Clause 82.3. This output is level sensitive.                                                                                                                                            |
| stat_rx_framing_err_valid_*         | 1    | 0   | Valid indicator for stat_rx_framing_err. When 1 stat_rx_framing_err_0 is valid.                                                                                                                                                                                                                                                                                                                        |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| 3 | 0           | RX sync header bits framing error. Each PCS Lane has a four-bit bus that indicates how many sync header errors were received for that                                                                                                                  |
|---|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |             | PCS Lane. The value of the bus is only valid when the corresponding stat_rx_framing_err_valid is a 1. The values on these buses can be updated at any time and are intended to be used as increment values for sync header error counters.             |
| 1 | 0           | High Bit Error Rate (BER) indicator. When set to 1, the BER is too high as defined by IEEE Std 802.3-2015. Corresponds to MDIO register bit 3.32.1 as defined in Clause 82.3.  This output is level sensitive.                                         |
| 2 | 0           | Increment for 64B/66B code violations. This signal indicates that the RX PCS receive state machine is in the RX_E state as specified by the IEEE Std 802.3-2015. This output can be used to generate MDIO register 3.33:7:0 as defined in Clause 82.3. |
| 1 | 0           | Indicates when stat_rx_bad_code is valid.                                                                                                                                                                                                              |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                             |
| 1 | 0           | Indicates when stat_rx_error is valid.                                                                                                                                                                                                                 |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                             |
| 8 | 0           | Test pattern mismatch increment. A non-zero value in any cycle indicates a mismatch occurred for the test pattern in the RX core. This output is only active when ctl_rx_test_pattern is set.                                                          |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                             |
| 1 | 0           | Indicates when RX FIFO goes into an underflow or overflow condition.                                                                                                                                                                                   |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                             |
| 2 | 0           | Increment for the total number of packets received.                                                                                                                                                                                                    |
|   |             | <b>Note:</b> This port is available when <b>Select Core</b> is <b>Ethernet PCS/PMA</b> or <b>Ethernet MAC</b> in the Configuration tab.                                                                                                                |
| 1 | 0           | Increment for the total number of good packets received. This value is only non-zero when a packet is received completely and contains no errors.                                                                                                      |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                             |
| 6 | 0           | Increment for the total number of bytes received.                                                                                                                                                                                                      |
|   |             | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                             |
|   | 2 1 2 2 1 1 | 2 O 1 O 2 O 1 O 1 O 1 O 1 O 1 O 1 O 1 O                                                                                                                                                                                                                |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                       | Size | I/O | Description                                                                                                                                     |
|----------------------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_total_good_bytes_* | 14   | 0   | Increment for the total number of good bytes received. This value is only non-zero when a packet is received completely and contains no errors. |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_packet_small_*     | 2    | 0   | Increment for all packets that are less than 64 bytes long. Packets that are less than 4 bytes are dropped.                                     |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_jabber_*           | 1    | 0   | Increment for packets longer than ctl_rx_max_packet_len with bad FCS.                                                                           |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MACin the Configuration tab.                       |
| stat_rx_packet_large_*     | 1    | 0   | Increment for all packets that are more than 9,215 bytes long.                                                                                  |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_oversize_*         | 1    | 0   | Increment for packets longer than ctl_rx_max_packet_len with good FCS.                                                                          |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_undersize_*        | 2    | 0   | Increment for packets shorter than stat_rx_min_packet_len with good FCS.                                                                        |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_toolong_*          | 1    | 0   | Increment for packets longer than ctl_rx_max_packet_len with good and bad FCS.                                                                  |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_fragment_*         | 2    | 0   | Increment for packets shorter than stat_rx_min_packet_len with bad FCS.                                                                         |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |
| stat_rx_packet_64_bytes_*  | 1    | 0   | Increment for good and bad packets received that contain 64 bytes.                                                                              |
|                            |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                      |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                             | Size | I/O | Description                                                                                                                |
|----------------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------|
| stat_rx_packet_65_127_bytes_*    | 1    | 0   | Increment for good and bad packets received that contain 65 to 127 bytes.                                                  |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_128_255_bytes_*   | 1    | 0   | Increment for good and bad packets received that contain 128 to 255 bytes.                                                 |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_256_511_bytes_*   | 1    | 0   | Increment for good and bad packets received that contain 256 to 511 bytes.                                                 |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_512_1023_bytes_*  | 1    | 0   | Increment for good and bad packets received that contain 512 to 1,023 bytes.                                               |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_1024_1518_bytes_* | 1    | 0   | Increment for good and bad packets received that contain 1,024 to 1,518 bytes.                                             |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_1519_1522_bytes_* | 1    | 0   | Increment for good and bad packets received that contain 1,519 to 1,522 bytes.                                             |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_1523_1548_bytes_* | 1    | 0   | Increment for good and bad packets received that contain 1,523 to 1,548 bytes.                                             |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_1549_2047_bytes_* | 1    | 0   | Increment for good and bad packets received that contain 1,549 to 2,047 bytes.                                             |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |
| stat_rx_packet_2048_4095_bytes_* | 1    | 0   | Increment for good and bad packets received that contain 2,048 to 4,095 bytes.                                             |
|                                  |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab. |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                                  | Size | I/O | Description                                                                                                                                                                                                                                                                                             |
|---------------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_packet_4096_8191_bytes_*      | 1    | 0   | Increment for good and bad packets received that contain 4,096 to 8,191 bytes.                                                                                                                                                                                                                          |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_packet_8192_9215_bytes_*      | 1    | 0   | Increment for good and bad packets received that contain 8,192 to 9,215 bytes.                                                                                                                                                                                                                          |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_bad_fcs_*1                    | 2    | 0   | Bad FCS indicator. The value on this bus indicates packets received with a bad FCS, but not a stomped FCS. A stomped FCS is defined as the bitwise inverse of the expected good FCS. This output is pulsed for one clock cycle to indicate an error condition. Pulses can occur in back-to-back cycles. |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_packet_bad_fcs_* <sup>1</sup> | 1    | 0   | Increment for packets between 64 and ctl_rx_max_packet_len bytes that have FCS errors.                                                                                                                                                                                                                  |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_stomped_fcs_*                 | 2    | 0   | Stomped FCS indicator. The value on this bus indicates packets were received with a stomped FCS. A stomped FCS is defined as the bitwise inverse of the expected good FCS. This output is pulsed for one clock cycle to indicate the stomped condition. Pulses can occur in back-to-back cycles.        |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_bad_preamble_*                | 1    | 0   | Increment bad preamble. This signal indicates if the Ethernet packet received was preceded by a valid preamble. A value of 1 indicates that an invalid preamble was received.                                                                                                                           |
|                                       |      |     | When an invalid preamble is detected, the stat_rx_bad_preamble signal is asserted regardless of the setting of the ctl_rx_check_preamble signal.                                                                                                                                                        |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |
| stat_rx_bad_sfd_*                     | 1    | 0   | Increment bad SFD. This signal indicates if the Ethernet packet received was preceded by a valid SFD. A value of 1 indicates that an invalid SFD was received.                                                                                                                                          |
|                                       |      |     | When an invalid SFD is detected, the stat_rx_bad_sfd signal is asserted regardless of the setting of the ctl_rx_check_sfd signal.                                                                                                                                                                       |
|                                       |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                              |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name                            | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_rx_got_signal_os_*         | 1    | 0   | Signal OS indication. If this bit is sampled as a 1, it indicates that a Signal OS word was received.  Signal OS should not be received in an Ethernet network.  Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                    |
| stat_rx_test_pattern_mismatch_* | 2    | 0   | Test pattern mismatch increment. A nonzero value in any cycle indicates how many mismatches occurred for the test pattern in the RX core. This output is only active when ctl_rx_test_pattern is set to a 1. This output can be used to generate MDIO register 3.43.15:0 as defined in Clause 82.3. This output is pulsed for one clock cycle.  **Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.** |
| stat_rx_truncated_*             | 1    | 0   | Packet truncation indicator. A value of 1 indicates that the current packet in flight is truncated due to its length exceeding ctl_rx_max_packet_len[14:0]. This output is pulsed for one clock cycle to indicate the truncated condition. Pulses can occur in back-to-back cycles.                                                                                                                                                                            |
|                                 |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit or Ethernet MAC in the Configuration tab.                                                                                                                                                                                                                                                                                                                                     |
| stat_rx_local_fault_*           | 1    | 0   | This output is High when stat_rx_internal_local_fault or stat_rx_received_local_fault is asserted. This output is level sensitive.                                                                                                                                                                                                                                                                                                                             |
| stat_rx_remote_fault_*          | 1    | 0   | Remote fault indication status. If this bit is sampled as a 1, it indicates a remote fault condition was detected. If this bit is sampled as a 0, a remote fault condition does not exist. This output is level sensitive.                                                                                                                                                                                                                                     |
|                                 |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                     |
| stat_rx_internal_local_fault_*  | 1    | 0   | This signal goes High when an internal local fault is generated due to any one of the following: test pattern generation, bad lane alignment, or high bit error rate. This signal remains High as long as the fault condition persists.                                                                                                                                                                                                                        |
|                                 |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                     |
| stat_rx_received_local_fault_*  | 1    | 0   | This signal goes High when enough local fault words are received from the link partner to trigger a fault condition as specified by the IEEE fault state machine. This signal remains High as long as the fault condition persists.                                                                                                                                                                                                                            |
|                                 |      |     | Note: This port is available when Select Core is Ethernet MAC +PCS/PMA-32/64-bit in the Configuration tab.                                                                                                                                                                                                                                                                                                                                                     |
| stat_rx_valid_ctrl_code_*       | 1    | 0   | Indicates that a PCS block with a valid control code was received.                                                                                                                                                                                                                                                                                                                                                                                             |



Table 309: RX Path Control/Status/Statistics Signals (cont'd)

| Name           | Size | I/O | Description                |
|----------------|------|-----|----------------------------|
| stat_rx_status | 1    | 0   | Indicates the link status. |

#### Notes:

## TX Pause Interface Control/Status/Statistics Signals

Ports under this section are available when Enable TX Flow Control Logic is selected from the MAC Options tab and Select Core is Ethernet MAC+PCS/PMA 64/32-bit.

Table 310: TX Pause Interface Control/Status/Statistics Signals

| Name                   | Size | I/O | Description                                                                                                                                                                                                                                                                                    |
|------------------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_pause_req_*     | 9    | I   | If a bit of this bus is set to 1, the core transmits a pause packet using the associated quanta value on the ctl_tx_pause_quanta[8:0][15:0] bus. If bit[8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted.                  |
| ctl_tx_pause_enable_*  | 9    | I   | TX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority. This signal gates transmission of pause packets. <sup>1</sup>                                                                                                          |
| ctl_tx_resend_pause_*  | 1    | I   | Retransmit pending pause packets. When this input is sampled as 1, all pending pause packets are retransmitted as soon as possible (that is, after the current packet in flight is completed) and the retransmit counters are reset. This input should be pulsed to 1 for one cycle at a time. |
| ctl_tx_pause_quanta0_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.          |
| ctl_tx_pause_quanta1_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.          |
| ctl_tx_pause_quanta2_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.          |
| ctl_tx_pause_quanta3_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.          |
| ctl_tx_pause_quanta4_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation. 1        |
| ctl_tx_pause_quanta5_* | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation. 1        |

It is possible for stat\_rx\_bad\_fcs to increment twice in one clock cycle, if a packet with a bad FCS is immediately
followed by a runt packet. Such runt packets are not counted by stat\_rx\_packet\_bad\_fcs, and hence, the latter
signal can only increment once per clock.



Table 310: TX Pause Interface Control/Status/Statistics Signals (cont'd)

| Name                          | Size | I/O | Description                                                                                                                                                                                                                                                                                       |
|-------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_pause_quanta6_*        | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.             |
| ctl_tx_pause_quanta7_*        | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.             |
| ctl_tx_pause_quanta8_*        | 16   | I   | These buses indicate the quanta to be transmitted for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_quanta[8] is used for global pause operation. All other values are used for priority pause operation.             |
| ctl_tx_pause_refresh_timer0_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer1_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer2_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer3_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer4_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer5_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer6_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer7_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_pause_refresh_timer8_* | 16   | I   | This bus sets the retransmission time of pause packets for each of the eight priorities in priority-based pause operation and the global pause operation. The value for ctl_tx_pause_refresh_timer[8] is used for global pause operation. All other values are used for priority pause operation. |
| ctl_tx_da_gpp_*               | 48   | I   | Destination address for transmitting global pause packets. <sup>1</sup>                                                                                                                                                                                                                           |
| ctl_tx_sa_gpp_*               | 48   | I   | Source address for transmitting global pause packets. <sup>1</sup>                                                                                                                                                                                                                                |
| ctl_tx_ethertype_gpp_*        | 16   | I   | Ethertype for transmitting global pause packets. <sup>1</sup>                                                                                                                                                                                                                                     |
| ctl_tx_opcode_gpp_*           | 16   | I   | Opcode for transmitting global pause packets. <sup>1</sup>                                                                                                                                                                                                                                        |
| ctl_tx_da_ppp_*               | 48   | I   | Destination address for transmitting priority pause packets. <sup>1</sup>                                                                                                                                                                                                                         |



Table 310: TX Pause Interface Control/Status/Statistics Signals (cont'd)

| Name                   | Size | I/O | Description                                                                                                                                                                                                  |
|------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_sa_ppp_*        | 48   | I   | Source address for transmitting priority pause packets. <sup>1</sup>                                                                                                                                         |
| ctl_tx_ethertype_ppp_* | 16   | I   | Ethertype for transmitting priority pause packets. <sup>1</sup>                                                                                                                                              |
| ctl_tx_opcode_ppp_*    | 16   | I   | Opcode for transmitting priority pause packets. <sup>1</sup>                                                                                                                                                 |
| stat_tx_pause_valid_*  | 9    | 0   | If a bit of this bus is set to 1, the HSEC core has transmitted a pause packet. If bit[8] is set to 1, a global pause packet is transmitted. All other bits cause a priority pause packet to be transmitted. |
| stat_tx_unicast_*2     | 1    | 0   | Increment for good unicast packets.                                                                                                                                                                          |
| stat_tx_multicast_*    | 1    | 0   | Increment for good multicast packets.                                                                                                                                                                        |
| stat_tx_broadcast_*    | 1    | 0   | Increment for good broadcast packets.                                                                                                                                                                        |
| stat_tx_vlan_*         | 1    | 0   | Increment for good 802.1Q tagged VLAN packets.                                                                                                                                                               |
| stat_tx_pause_*        | 1    | 0   | Increment for 802.3x Ethernet MAC Pause packet with good FCS.                                                                                                                                                |
| stat_tx_user_pause_*   | 1    | 0   | Increment for priority-based pause packets with good FCS.                                                                                                                                                    |

#### Notes:

- 1. This port is available when Include AXI4-Lite is *not* selected in the Configuration tab.
- 2. This port is available when RX flow control is enabled or Preemption is enabled or core type is MAC+PCS/PMA 32-bit.

# **RX Pause Interface Control/Status/Statistics Signals**

Ports in this section are available when Enable RX Flow Control Logic is selected from the MAC Options tab and Select Core is Ethernet MAC+PCS/PMA 64/32-bit.

Table 311: RX Pause Interface Control / Status / Statistics Signals

| Name                     | Size | I/O | Description                                                                                                                                                                                   |
|--------------------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_forward_control_* | 1    | I   | A value of 1 indicates that the CORE forwards control packets to you. A value of 0 causes CORE to drop control packets. <sup>1</sup>                                                          |
| ctl_rx_pause_ack_*       | 9    | I   | Pause acknowledge signal. This bus is used to acknowledge the receipt of the pause frame from the user logic.                                                                                 |
| ctl_rx_check_ack_*       | 1    | I   | Wait for acknowledge. If this input is set to 1, the CORE uses the ctl_rx_pause_ack[8:0] bus for pause processing. If this input is set to 0, ctl_rx_pause_ack[8:0] is not used. <sup>1</sup> |
| ctl_rx_pause_enable_*    | 9    | I   | RX pause enable signal. This input is used to enable the processing of the pause quanta for the corresponding priority. <sup>1</sup>                                                          |
| ctl_rx_enable_gcp_*      | 1    | I   | A value of 1 enables global control packet processing. <sup>1</sup>                                                                                                                           |
| ctl_rx_check_mcast_gcp_* | 1    | I   | A value of 1 enables global control multicast destination address processing. <sup>1</sup>                                                                                                    |
| ctl_rx_check_ucast_gcp_* | 1    | I   | A value of 1 enables global control unicast destination address processing. <sup>1</sup>                                                                                                      |
| ctl_rx_pause_da_ucast_*  | 48   | I   | Unicast destination address for pause processing. <sup>1</sup>                                                                                                                                |
| ctl_rx_check_sa_gcp_*    | 1    | I   | A value of 1 enables global control source address processing. <sup>1</sup>                                                                                                                   |
| ctl_rx_pause_sa_*        | 48   | I   | Source address for pause processing. <sup>1</sup>                                                                                                                                             |
| ctl_rx_check_etype_gcp_* | 1    | I   | A value of 1 enables global control ethertype processing. <sup>1</sup>                                                                                                                        |
| ctl_rx_etype_gcp_*       | 16   | I   | Ethertype field for global control processing. <sup>1</sup>                                                                                                                                   |



Table 311: RX Pause Interface Control / Status / Statistics Signals (cont'd)

| Name                             | Size | I/O | Description                                                                                  |
|----------------------------------|------|-----|----------------------------------------------------------------------------------------------|
| ctl_rx_check_opcode_gcp_*        | 1    | I   | A value of 1 enables global control opcode processing. <sup>1</sup>                          |
| ctl_rx_opcode_min_gcp_*          | 16   | I   | Minimum global control opcode value. <sup>1</sup>                                            |
| ctl_rx_opcode_max_gcp_*          | 16   | I   | Maximum global control opcode value. <sup>1</sup>                                            |
| ctl_rx_enable_pcp_*              | 1    | I   | A value of 1 enables priority control packet processing. <sup>1</sup>                        |
| ctl_rx_check_mcast_pcp_*         | 1    | I   | A value of 1 enables priority control multicast destination address processing. <sup>1</sup> |
| ctl_rx_check_ucast_pcp_*         | 1    | I   | A value of 1 enables priority control unicast destination address processing. <sup>1</sup>   |
| ctl_rx_pause_da_mcast_*          | 48   | I   | Multicast destination address for pause processing. <sup>1</sup>                             |
| ctl_rx_check_sa_pcp_*            | 1    | I   | A value of 1 enables priority control source address processing. <sup>1</sup>                |
| ctl_rx_check_etype_pcp_*         | 1    | I   | A value of 1 enables priority control ethertype processing. <sup>1</sup>                     |
| ctl_rx_etype_pcp_*               | 16   | I   | Ethertype field for priority control processing. <sup>1</sup>                                |
| ctl_rx_check_opcode_pcp_*        | 1    | I   | A value of 1 enables priority control opcode processing. <sup>1</sup>                        |
| ctl_rx_opcode_min_pcp_*          | 16   | I   | Minimum priority control opcode value. <sup>1</sup>                                          |
| ctl_rx_opcode_max_pcp_*          | 16   | I   | Maximum priority control opcode value. <sup>1</sup>                                          |
| ctl_rx_enable_gpp_*              | 1    | I   | A value of 1 enables global pause packet processing. <sup>1</sup>                            |
| ctl_rx_check_mcast_gpp_*         | 1    | I   | A value of 1 enables global pause multicast destination address processing. <sup>1</sup>     |
| ctl_rx_check_ucast_gpp_*         | 1    | I   | A value of 1 enables global pause unicast destination address processing. <sup>1</sup>       |
| ctl_rx_check_sa_gpp_*            | 1    | I   | A value of 1 enables global pause source address processing. <sup>1</sup>                    |
| ctl_rx_check_etype_gpp_*         | 1    | I   | A value of 1 enables global pause ethertype processing. <sup>1</sup>                         |
| ctl_rx_etype_gpp_*               | 16   | I   | Ethertype field for global pause processing. <sup>1</sup>                                    |
| ctl_rx_check_opcode_gpp_*        | 1    | I   | A value of 1 enables global pause opcode processing. <sup>1</sup>                            |
| ctl_rx_opcode_gpp_*              | 16   | I   | Global pause opcode value. <sup>1</sup>                                                      |
| ctl_rx_enable_ppp_*              | 1    | I   | A value of 1 enables priority pause packet processing. <sup>1</sup>                          |
| ctl_rx_check_mcast_ppp_*         | 1    | I   | A value of 1 enables priority pause multicast destination address processing. <sup>1</sup>   |
| ctl_rx_check_ucast_ppp_*         | 1    | I   | A value of 1 enables priority pause unicast destination address processing. <sup>1</sup>     |
| ctl_rx_check_sa_ppp_*            | 1    | I   | A value of 1 enables priority pause source address processing. <sup>1</sup>                  |
| ctl_rx_check_etype_ppp_*         | 1    | I   | A value of 1 enables priority pause ethertype processing. <sup>1</sup>                       |
| ctl_rx_etype_ppp_*               | 16   | I   | Ethertype field for priority pause processing. <sup>1</sup>                                  |
| ctl_rx_check_opcode_ppp_*        | 1    | I   | A value of 1 enables priority pause opcode processing. <sup>1</sup>                          |
| ctl_rx_opcode_ppp_*              | 16   | I   | Priority pause opcode value. <sup>1</sup>                                                    |
| stat_rx_unicast_* <sup>2</sup>   | 1    | 0   | Increment for good unicast packets.                                                          |
| stat_rx_multicast_* <sup>2</sup> | 1    | 0   | Increment for good multicast packets.                                                        |
| stat_rx_broadcast_* <sup>2</sup> | 1    | 0   | Increment for good broadcast packets.                                                        |
| stat_rx_vlan_* <sup>2</sup>      | 1    | 0   | Increment for good 802.1Q tagged VLAN packets.                                               |
| stat_rx_pause_*                  | 1    | 0   | Increment for 802.3x Ethernet MAC Pause packet with good FCS.                                |
| stat_rx_user_pause_*             | 1    | 0   | Increment for priority-based pause packets with good FCS.                                    |



Table 311: RX Pause Interface Control / Status / Statistics Signals (cont'd)

| Name                              | Size | I/O | Description                                                                                                                                                                                                                                      |  |
|-----------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| stat_rx_inrangeerr_* <sup>2</sup> | 1    | 0   | Increment for packets with Length field error but with good FCS.                                                                                                                                                                                 |  |
| stat_rx_pause_valid_*             | 9    | 0   | This bus indicates that a pause packet was received and the associated quanta on the stat_rx_pause_quanta[8:0][15:0] bus is valid and must be used for pause processing. If an 802.3x Ethernet MAC Pause packet is received, bit[8] is set to 1. |  |
| stat_rx_pause_quanta0_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta1_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta2_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta3_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priori in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed value [8].                         |  |
| stat_rx_pause_quanta4_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta5_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta6_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta7_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_quanta8_*           | 16   | 0   | These buses indicate the quanta received for each of the eight priorities in priority-based pause operation and global pause operation. If an 802.3x Ethernet MAC Pause packet is received, the quanta are placed in value [8].                  |  |
| stat_rx_pause_req_*               | 9    | 0   | Pause request signal. When the RX receives a valid pause frame, it sets the corresponding bit of this bus to a 1 and keep it at 1 until the pause packet has been processed.                                                                     |  |

### Notes:

- 1. This port is available when Include AXI4-Lite is *not* selected in the Configuration tab.
- 2. This port is available when RX flow control is enabled or Preemption is enabled or core type is MAC+PCS/PMA 32-bit.



# IEEE 1588 TX/RX Interface Control/Status/Statistics Signals

Table 312: IEEE 1588 TX/RX Interface Control/Status/Statistics Signals

| Name                           | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_tx_systemtimerin_*         | 80   | I   | System timer input for the TX.  In normal clock mode, the time format is according to the IEEE 1588 format, with 48 bits for seconds and 32 bits for nanoseconds.  In transparent clock mode, bit 63 is expected to be zero, bits 62:16 carry nanoseconds, and bits 15:0 carry fractional nanoseconds.  Refer to IEEE 1588v2 for the representational definitions.  This input must be in the TX clock domain.                                                                                                                                                                       |
| ctl_rx_systemtimerin_*         | 80   | I   | System timer input for the RX.  In normal clock mode, the time format is according to the IEEE 1588 format, with 48 bits for seconds and 32 bits for nanoseconds.  In transparent clock mode, bit 63 is expected to be zero, bits 62:16 carry nanoseconds, and bits 15:0 carry fractional nanoseconds.  Refer to IEEE 1588v2 for the representational definitions.  This input must be in the same clock domain as the lane 0 RX SerDes.                                                                                                                                             |
| ctl_tx_ptp_1step_enable_*      | 1    | I   | When set to 1, this bit enables 1-step operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ctl_tx_ptp_latency_adjust_*    | 11   | I   | This bus can be used to adjust the 1-step TX timestamp with respect to the 2-step timestamp. The units of bits [10:3] are nanoseconds and bits [2:0] are fractional nanoseconds.  *Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                     |
| ctl_ptp_transpclk_mode_*       | 1    | I   | When set to 1, this input places the timestamping logic into transparent clock mode. In this mode,the system timer input is interpreted as a correction value. The TX will add the correction value to the TX timestamp according to the process defined in IEEE 1588v2. The sign bit of the correction value is assumed to be 0 (positive time).  It is expected that the corresponding incoming PTP packet correction field has already been adjusted with the proper RX timestamp.  Note: This port is available when Include AXI4-Lite is not selected in the Configuration tab. |
| stat_tx_ptp_fifo_read_error_*  | 1    | 0   | Transmit PTP FIFO write error. A value of 1 on this status indicates that an error occurred during the PTP Tag write. A TX Path reset is required to clear the error.                                                                                                                                                                                                                                                                                                                                                                                                                |
| stat_tx_ptp_fifo_write_error_* | 1    | 0   | Transmit PTP FIFO read error. A value of 1 on this status indicates that an error occurred during the PTP Tag read. A TX Path reset is required to clear the error.                                                                                                                                                                                                                                                                                                                                                                                                                  |



Table 312: IEEE 1588 TX/RX Interface Control/Status/Statistics Signals (cont'd)

| Name                      | Size | I/O | Description                                                                                                                                                                                                                                                                                                                        |
|---------------------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| tx_period_ns_*            | 64   | 0   | When time stamp is enabled, this output signal represents the operating time period of the $tx_clk$ in $2^{-48}$ accuracy format.                                                                                                                                                                                                  |
|                           |      |     | Note:                                                                                                                                                                                                                                                                                                                              |
|                           |      |     | <ul> <li>For 10G line rates:</li> <li>The value of tx_period_ns is 'h00033333333333333 for MAC +PCS/PMA 32-bit and for PCS/PMA 32-bit core.</li> </ul>                                                                                                                                                                             |
|                           |      |     | The value of tx_period_ns is 'h0006666666666666 for MAC +PCS/PMA 64-bit and for PCS/PMA 64-bit core.                                                                                                                                                                                                                               |
|                           |      |     | 2. For 25G line rate:                                                                                                                                                                                                                                                                                                              |
|                           |      |     | The value of tx_period_ns is 'h00028F5C28F5C28F                                                                                                                                                                                                                                                                                    |
| rx_period_ns_*            | 64   | 0   | When time stamp is enabled, this output signal represents the operating time period of the $rx_clk$ in $2^{-48}$ accuracy format.                                                                                                                                                                                                  |
|                           |      |     | Note:                                                                                                                                                                                                                                                                                                                              |
|                           |      |     | 1. For 10G line rate:                                                                                                                                                                                                                                                                                                              |
|                           |      |     | <ul> <li>The value of rx_period_ns is 'h0003333333333333333 for MAC<br/>+PCS/PMA 32-bit and for PCS/PMA 32-bit core.</li> </ul>                                                                                                                                                                                                    |
|                           |      |     | <ul> <li>The value of rx_period_ns is 'h000666666666666666 for MAC<br/>+PCS/PMA 64-bit and for PCS/PMA 64-bit core.</li> </ul>                                                                                                                                                                                                     |
|                           |      |     | 2. For 25G line rate:                                                                                                                                                                                                                                                                                                              |
|                           |      |     | The value of rx_period_ns is 'h00028F5C28F5C28F                                                                                                                                                                                                                                                                                    |
| tx_ptp_1588op_in_*        | 2    | I   | 2'b00 – "No operation": no timestamp will be taken and the frame will not be modified.                                                                                                                                                                                                                                             |
|                           |      |     | 2'b01 – "1-step": a timestamp should be taken and inserted into the frame.                                                                                                                                                                                                                                                         |
|                           |      |     | 2'b10 – "2-step": a timestamp should be taken and returned to the client using the additional ports of 2-step operation. The frame itself will not be modified.                                                                                                                                                                    |
|                           |      |     | 2'b11 – Reserved: act as "No operation".                                                                                                                                                                                                                                                                                           |
| tx_ptp_tag_field_in_*     | 16   | I   | The usage of this field is dependent on the 1588 operation                                                                                                                                                                                                                                                                         |
|                           |      |     | • For "No operation", this field will be ignored.                                                                                                                                                                                                                                                                                  |
|                           |      |     | • For "1-step" and "2-step" this field is a tag field. This tag value will be returned to the client with the timestamp for the current frame using the additional ports of 2-step operation. This tag value can be used by software to ensure that the timestamp can be matched with the PTP frame that it sent for transmission. |
| tx_ptp_tstamp_valid_out_* | 1    | 0   | This bit indicates that a valid timestamp is being presented on the TX.                                                                                                                                                                                                                                                            |
| tx_ptp_tstamp_tag_out_*   | 16   | 0   | Tag output corresponding to tx_ptp_tag_field_in[15:0].                                                                                                                                                                                                                                                                             |
| tx_ptp_tstamp_out_*       | 80   | 0   | Timestamp for the transmitted packet SOP corresponding to the time at which it passed the capture plane.                                                                                                                                                                                                                           |
|                           |      |     | The representation of the bits contained in this bus is the same as the timer input.                                                                                                                                                                                                                                               |
| rx_ptp_tstamp_valid_out_* | 1    | 0   | This bit indicates that a valid timestamp is being presented on the RX. This will be present only when core is Ethernet MAC+PCS/                                                                                                                                                                                                   |
|                           |      |     | PMA-32/64-bit.                                                                                                                                                                                                                                                                                                                     |



Table 312: IEEE 1588 TX/RX Interface Control/Status/Statistics Signals (cont'd)

| Name                        | Size | I/O | Description                                                                                                                                                                                                                                                                                                                |
|-----------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rx_ptp_tstamp_out_*         | 80   | 0   | Timestamp for the received packet SOP corresponding to the time at which it passed the capture plane. Note that this signal will be valid starting at the same clock cycle during which the SOP is asserted for one of the segments.                                                                                       |
|                             |      |     | The representation of the bits contained in this bus is the same as the timer input.                                                                                                                                                                                                                                       |
| tx_ptp_e_rxtstamp_*         | 64   | I   | TX PTP RX timestamp.                                                                                                                                                                                                                                                                                                       |
| tx_ptp_p_rxtstamp_*         | 64   | I   | TX PTP RX timestamp.                                                                                                                                                                                                                                                                                                       |
| rx_ptp_e_tstamp_*           | 80   | 0   | Time stamp for the received packet SOP corresponding to the time at which it passed the capture plane. Note that this signal will be valid starting at the same clock cycle during which the SOP is asserted for one of the segments. The representation of the bits contained in this bus is the same as the timer input. |
| rx_ptp_p_tstamp_*           | 80   | 0   | Time stamp for the received packet SOP corresponding to the time at which it passed the capture plane. Note that this signal will be valid starting at the same clock cycle during which the SOP is asserted for one of the segments. The representation of the bits contained in this bus is the same as the timer input. |
| tx_ptp_e_tstamp_valid_out_* | 1    | 0   | This bit indicates that a valid timestamp is presented on the TX.                                                                                                                                                                                                                                                          |
| tx_ptp_p_tstamp_valid_out_* | 1    | 0   | Reserved.                                                                                                                                                                                                                                                                                                                  |
| tx_ptp_e_tstamp_tag_out_*   | 16   | 0   | Tag output corresponding to tx_ptp_tag_field_in[15:0].                                                                                                                                                                                                                                                                     |
| tx_ptp_p_tstamp_tag_out_*   | 16   | 0   | Reserved.                                                                                                                                                                                                                                                                                                                  |
| tx_ptp_upd_chksum_in_*      | 1    | I   | TX Updated checksum value.                                                                                                                                                                                                                                                                                                 |
|                             |      |     | <b>Note:</b> This port is available when PTP Operation mode is selected as one-step in MAC options tab.                                                                                                                                                                                                                    |
| tx_ptp_tstamp_offset_in_*   | 16   | I   | TX PTP timestamp offset.                                                                                                                                                                                                                                                                                                   |
|                             |      |     | <b>Note:</b> This port is available when PTP Operation mode is selected as one-step in MAC options tab. Only even values are supported.                                                                                                                                                                                    |
| tx_ptp_chksum_offset_in_*   | 16   | I   | TX PTP check sum offset.                                                                                                                                                                                                                                                                                                   |
|                             |      |     | <b>Note:</b> This port is available when PTP Operation mode is selected as one-step in MAC options tab. Only even values are supported.                                                                                                                                                                                    |
| tx_ptp_rxtstamp_in_*        | 64   | I   | TX PTP RX timestamp.                                                                                                                                                                                                                                                                                                       |
|                             |      |     | <b>Note:</b> This port is available when PTP Operation mode is selected as one step in MAC options tab.                                                                                                                                                                                                                    |

# AN and LT Interface Control/Status/Statistics Signals

Ports under this section are available when the Include AN/LT Logic is selected from the Configuration tab.



Table 313: AN and LT Interface Control/Status/Statistics Signals

| Name                      | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                  |
|---------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| an_clk_*                  | 1    | I   | Input Clock for the Auto-Negotiation circuit. This should be free running clock.                                                                                                                                                                                                                                                             |
| an_reset_*                | 1    | I   | Asynchronous active-High reset corresponding to an_clk domain.                                                                                                                                                                                                                                                                               |
| an_loc_np_data_*          | 48   | I   | Local Next Page codeword. This is the 48 bit codeword used if the 'loc_np' input is set. In this data field, the bits NP, ACK, & T, bit positions 15, 14, 12, & 11, are not transferred as part of the next page codeword. These bits are generated in the AN IP. However, the Message Protocol bit, MP, in bit position 13, is transferred. |
| an_lp_np_data_*           | 48   | 0   | Link Partner Next Page Data. This 48 bit word is driven by the AN IP with the 48 bit next page codeword from the remote link partner.                                                                                                                                                                                                        |
| lt_tx_sof_*               | 4    | 0   | This is a link training signal that is asserted for one tx_serdes_clk period at the start of each training frame. It is provided for applications that need to count training frames or synchronize events to the output of the training frames.                                                                                             |
| ctl_autoneg_enable_*      | 1    | I   | Enable signal for auto-negotiation.                                                                                                                                                                                                                                                                                                          |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_autoneg_bypass_*      | 1    | I   | Input to disable auto-negotiation and bypass the auto-negotiation function. If this input is asserted, then auto-negotiation is turned off, but the PCS is connected to the output to allow operation.                                                                                                                                       |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_an_nonce_seed_*       | 8    | I   | 8-bit seed to initialize the nonce field polynomial generator.                                                                                                                                                                                                                                                                               |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_an_pseudo_sel_*       | 1    | I   | Selects the polynomial generator for the bit 49 random bit generator. If this input is 1, then the polynomial is x7+x6+1. If this input is zero, then the polynomial is x7+x3+1.                                                                                                                                                             |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_restart_negotiation_* | 1    | I   | This input is used to trigger a restart of the auto-negotiation, regardless of what state the circuit is currently in.                                                                                                                                                                                                                       |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_an_local_fault_*      | 1    | I   | This input signal is used to set the remote_fault bit of the transmit link codeword.                                                                                                                                                                                                                                                         |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |
| ctl_an_pause_*            | 1    | I   | This input signal is used to set the PAUSE bit, (C0), of the transmit link codeword. This signal might not be present if the core does not support pause.                                                                                                                                                                                    |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                  |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                           | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_an_asmdir_*                | 1    | I   | This input signal is used to set the ASMDIR bit, (C1), of the transmit link codeword. This signal might not be present if the core does not support pause.                                                                                                                                                                                                                                                                                               |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_fec_10g_request_*       | 1    | I   | This signal is used to signal the link partner that the local station is requesting clause 74 FEC on the 10 Gb/s lane protocols.                                                                                                                                                                                                                                                                                                                         |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_fec_25g_rs_request_*    | 1    | Ι   | This signal is used to signal the link partner that the local station is requesting rs FEC (clause 91 or 108) on the 25 Gb/s lane protocols.                                                                                                                                                                                                                                                                                                             |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_fec_25g_baser_request_* | 1    | I   | Indicates the baser FEC request.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_fec_ability_override_*  | 1    | I   | Used to set the clause 74 FEC ability bit in the transmit link codeword. If this input is set, then the FEC ability bit in the transmit link codeword is cleared. This signal might not be present if the IP core does not support clause 74 FEC.                                                                                                                                                                                                        |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_loc_np_*                | 1    | I   | Local Next Page indicator. If this bit is 1, then the AN IP transfers the next page word at input loc_np_data to the remote link partner. If this bit is 0, then the AN IP does not initiate the next page protocol. If the link partner has next pages to send, and the loc_np bit is clear, then the AN IP transfers null message pages.                                                                                                               |
| ctl_an_lp_np_ack_*             | 1    | I   | Link Partner Next Page Acknowledge. This is used to signal the AN IP that the next page data from the remote link partner at output pin lp_np_data has been read by the local host. When this signal goes High, the AN IP acknowledges reception of the next page codeword to the remote link partner and initiate transfer of the next codeword. During this time, the AN IP removes the lp_np signal until the new next page information is available. |
| ctl_an_cl91_fec_request_*      | 1    | I   | This bit is used to request clause 91 FEC.                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |
| ctl_an_cl91_fec_ability_*      | 1    | I   | This bit is used to set clause 91 FEC ability.                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                                                                                                                                                                                                                                                                                                              |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                               | Size | I/O | Description                                                                                                                                             |
|------------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_an_ability_1000base_kx_*       | 1    | I   | These inputs identify the Ethernet protocol abilities that are                                                                                          |
| ctl_an_ability_10gbase_kx4_*       | 1    | I   | advertised in the transmit link codeword to the link partner. A value of 1 indicates that the interface advertises that it supports                     |
| ctl_an_ability_10gbase_kr_*        | 1    | I   | the protocol.                                                                                                                                           |
| ctl_an_ability_40gbase_kr4_*       | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_40gbase_cr4_*       | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_100gbase_cr10_*     | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_100gbase_kp4_*      | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_100gbase_kr4_*      | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_100gbase_cr4_*      | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_25gbase_krcr_s_*    | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_25gbase_krcr_*      | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_25gbase_kr1_*       | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_25gbase_cr1_*       | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_50gbase_kr2_*       | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_50gbase_cr2_*       | 1    | I   |                                                                                                                                                         |
| ctl_lt_polynomial_select           | 2    | I   | These inputs identify the Ethernet protocol abilities that are                                                                                          |
| ctl_an_ability_2_5gbase_kx         | 1    | I   | advertised in the transmit link codeword to the link partner. A value of 1 indicates that the interface advertises that it supports                     |
| ctl_an_ability_5gbase_kr           | 1    | I   | the protocol.                                                                                                                                           |
| ctl_an_ability_50gbase_krcr        | 1    | I   |                                                                                                                                                         |
| ctl_an_ability_100gbase_kr2cr2     | 1    | I   |                                                                                                                                                         |
| stat_an_lp_ability_200gbase_kr4cr4 | 1    | I   |                                                                                                                                                         |
| ctl_lt_training_enable_*           | 1    | I   | Enables link training. When link training is disabled, all PCS lanes function in mission mode.                                                          |
|                                    |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                             |
| ctl_lt_restart_training_*          | 1    | I   | This signal triggers a restart of link training regardless of the current state.                                                                        |
|                                    |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                             |
| ctl_lt_rx_trained_*                | 4    | I   | This signal is asserted to indicate that the receiver FIR filter coefficients have all been set, and that the receiver portion of training is complete. |
|                                    |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                             |
| ctl_lt_preset_to_tx_*              | 4    | I   | This signal is used to set the value of the preset bit that is transmitted to the link partner in the control block of the training frame.              |
|                                    |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                             |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                      | Size | I/O | Description                                                                                                                                                       |
|---------------------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_lt_initialize_to_tx_* | 4    | I   | This signal is used to set the value of the initialize bit that is transmitted to the link partner in the control block of the training frame.                    |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_pseudo_seed0_*     | 11   | I   | This 11-bit signal seeds the training pattern generator.                                                                                                          |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_k_p1_to_tx0_*      | 2    | I   | This 2-bit field is used to set the value of the k+1 coefficient update field that is transmitted to the link partner in the control block of the training frame. |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_k0_to_tx0_*        | 2    | I   | This 2-bit field is used to set the value of the k0 coefficient update field that is transmitted to the link partner in the control block of the training frame.  |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_k_m1_to_tx0_*      | 2    | I   | This 2-bit field is used to set the value of the k-1 coefficient update field that is transmitted to the link partner in the control block of the training frame. |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_stat_p1_to_tx0_*   | 2    | Ι   | This 2-bit field is used to set the value of the k+1 coefficient update status that is transmitted to the link partner in the status block of the training frame. |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_stat0_to_tx0_*     | 2    | I   | This 2-bit field is used to set the value of the k0 coefficient update status that is transmitted to the link partner in the status block of the training frame.  |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |
| ctl_lt_stat_m1_to_tx0_*   | 2    | I   | This 2-bit field is used to set the value of the k-1 coefficient update status that is transmitted to the link partner in the status block of the training frame. |
|                           |      |     | <b>Note:</b> This port is available when <b>Include AXI4-Lite</b> is not selected in the Configuration tab.                                                       |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                                | Size | I/O | Description                                                                                                                                     |
|-------------------------------------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_an_link_cntl_1000base_kx_*     | 2    | 0   | Link Control outputs from the auto-negotiation controller for the                                                                               |
| stat_an_link_cntl_10gbase_kx4_*     | 2    | 0   | various Ethernet protocols. Settings are as follows:<br>00: DISABLE; PCS is disconnected;                                                       |
| stat_an_link_cntl_10gbase_kr_*      | 2    | 0   | 01: SCAN_FOR_CARRIER; RX is connected to PCS;                                                                                                   |
| stat_an_link_cntl_40gbase_kr4_*     | 2    | 0   | 11: ENABLE; PCS is connected for mission mode operation.                                                                                        |
| stat_an_link_cntl_40gbase_cr4_*     | 2    | 0   | 10: not used                                                                                                                                    |
| stat_an_link_cntl_100gbase_cr10_*   | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_100gbase_kp4_*    | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_100gbase_kr4_*    | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_100gbase_cr4_*    | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_25gbase_krcr_s_*  | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_25gbase_krcr_*    | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_25gbase_kr1_*     | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_25gbase_cr1_*     | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_50gbase_kr2_*     | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_50gbase_cr2_*     | 2    | 0   |                                                                                                                                                 |
| stat_an_link_cntl_2_5gbase_kx       | 2    | 0   | Link Control outputs from the auto-negotiation controller for the                                                                               |
| stat_an_link_cntl_5gbase_kr         | 2    | 0   | various Ethernet protocols. Settings are as follows:<br>00: DISABLE; PCS is disconnected;                                                       |
| stat_an_link_cntl_50gbase_krcr      | 2    | 0   | 01: SCAN_FOR_CARRIER; RX is connected to PCS;                                                                                                   |
| stat_an_link_cntl_100gbase_kr2cr2   | 2    | 0   | 11: ENABLE; PCS is connected for mission mode operation.                                                                                        |
| stat_an_link_cntl_200gbase_kr4cr4   | 2    | 0   | 10: not used                                                                                                                                    |
| stat_an_fec_enable_*                | 1    | 0   | Used to enable the use of clause 74 FEC on the link.                                                                                            |
| stat_an_tx_pause_enable_*           | 1    | 0   | Used to enable station-to-station (global) pause packet generation in the transmit path to control data flow in the receive path.               |
| stat_an_rx_pause_enable_*           | 1    | 0   | Used to enable station-to-station (global) pause packet interpretation in the receive path, in order to control data flow from the transmitter. |
| stat_an_autoneg_complete_*          | 1    | 0   | Indicates the auto-negotiation is complete and rx link status from the PCS has been received.                                                   |
| stat_an_parallel_detection_fault_*  | 1    | 0   | Indicated a parallel detection fault during auto-negotiation.                                                                                   |
| stat_an_lp_ability_1000base_kx_*    | 1    | 0   | These signals indicate the advertised protocol from the link                                                                                    |
| stat_an_lp_ability_10gbase_kx4_*    | 1    | 0   | partner. They all become valid when the output signal stat_an_lp_ability_valid is asserted. A value of 1 indicates that the                     |
| stat_an_lp_ability_10gbase_kr_*     | 1    | 0   | protocol is advertised as supported by the link partner.                                                                                        |
| stat_an_lp_ability_40gbase_kr4_*    | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_40gbase_cr4_*    | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_100gbase_cr10_*  | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_100gbase_kp4_*   | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_100gbase_kr4_*   | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_100gbase_cr4_*   | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_25gbase_krcr_s_* | 1    | 0   |                                                                                                                                                 |
| stat_an_lp_ability_25gbase_krcr_*   | 1    | 0   |                                                                                                                                                 |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                               | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_an_lp_ability_2_5gbase_kx     | 1    | 0   | These signals indicate the advertised protocol from the link                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| stat_an_lp_ability_5gbase_kr       | 1    | 0   | partner. They all become valid when the output signal stat_an_lp_ability_valid is asserted. A value of 1 indicates that the                                                                                                                                                                                                                                                                                                                                                                                  |
| stat_an_lp_ability_50gbase_krcr    | 1    | 0   | protocol is advertised as supported by the link partner.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| stat_an_lp_ability_100gbase_kr2cr2 | 1    | 0   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| stat_an_lp_ability_200gbase_kr4cr4 | 1    | 0   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| stat_an_lp_ability_25gbase_cr1_*   | 1    | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_AN_lp_Extended_Ability_Valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner.                                                                                                                                                                                                                                                                        |
| stat_an_rxcdrhold_*                | 1    | 0   | Indicates the rx cdr hold signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| stat_an_lp_pause_*                 | 1    | 0   | This signal indicates the advertised value of the PAUSE bit, (C0), in the receive link codeword from the link partner. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                         |
| stat_an_lp_asm_dir_*               | 1    | 0   | This signal indicates the advertised value of the ASMDIR bit, (C1), in the receive link codeword from the link partner. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                        |
| stat_an_lp_rf_*                    | 1    | 0   | This bit indicates link partner remote fault.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| stat_an_lp_fec_10g_ability_*       | 1    | 0   | This signal indicates the clause 74 FEC ability associated with 10Gb/s lane protocols that is being advertised by the link partner. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                            |
| stat_an_lp_fec_10g_request_*       | 1    | 0   | This signal indicates that the link partner is requesting that the clause 74 FEC be used on the 10 Gb/s lane protocols. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                        |
| stat_an_lp_fec_25g_rs_request_*    | 1    | 0   | This signal indicates that the link partner is requesting the clause 91 (or 108) rs FEC be used for the 25 Gb/s lane protocols. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                |
| stat_an_lp_fec_25g_baser_request_* | 1    | 0   | This signal indicates that the link partner is requesting the clause 74 FEC be used for the 25 Gb/s lane base-r protocols. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                     |
| stat_an_lp_autoneg_able_*          | 1    | 0   | This output signal indicates that the link partner is able to perform auto-negotiation. It becomes valid when the output signal stat_an_lp_ability_valid is asserted.                                                                                                                                                                                                                                                                                                                                        |
| stat_an_lp_ability_valid_*         | 1    | 0   | This signal indicates when all of the link partner advertisements become valid.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| stat_an_loc_np_ack_*               | 1    | 0   | This signal is used to indicate to the local host that the local next page data, presented at input pin loc_np_data, has been taken.  This signal pulses High for 1 clock period when the AN IP samples the next page data on input pin loc_np_data. When the local host detects this signal High, it must replace the 48 bit next page codeword at input pin 'loc_np_data' with the next 48 bit codeword to be sent. If the local host has no more next pages to send, then it must clear the loc_np input. |
| stat_an_lp_np_*                    | 1    | 0   | Link Partner Next Page. This signal is used to indicate that there is a valid 48 bit next page codeword from the remote link partner at output pin lp_np_data. This signal is driven Low when the lp_np_ack input signal is driven High, indicating that the local host has read the next page data. It remains Low until the next codeword becomes available on the lp_np_data output pin, then the lp_np output is driven High again.                                                                      |



Table 313: AN and LT Interface Control/Status/Statistics Signals (cont'd)

| Name                                | Size | I/O | Description                                                                                                                                                                                                                           |
|-------------------------------------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| stat_an_lp_ability_25gbase_kr1_*    | 1    | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_an_lp_extended_ability_valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. |
| stat_an_link_cntl_25gbase_cr1_*     | 1    | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_an_lp_extended_ability_valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. |
| stat_an_lp_ability_50gbase_kr2_*    | 1    | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_an_lp_extended_ability_valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. |
| stat_an_lp_ability_50gbase_cr2_*    | 1    | 0   | Indicates the advertised protocol from the link partner. Becomes valid when the output signal stat_an_lp_extended_ability_valid is asserted. A value of 1 indicates that the protocol is advertised as supported by the link partner. |
| stat_an_lp_ability_extended_fec_*   | 4    | 0   | This output indicates the extended FEC abilities.                                                                                                                                                                                     |
| stat_an_rs_fec_enable_*             | 1    | 0   | Used to enable the use of clause 91 FEC on the link.                                                                                                                                                                                  |
| stat_an_lp_extended_ability_valid_* | 1    | 0   | When this bit is 1, it indicates that the detected extended abilities are valid.                                                                                                                                                      |
| stat_lt_signal_detect_*             | 4    | 0   | This signal indicates when the respective link training state machine has entered the SEND_DATA state, in which normal PCS operation can resume.                                                                                      |
| stat_lt_training_*                  | 4    | 0   | This signal indicates when the respective link training state machine is performing link training.                                                                                                                                    |
| stat_lt_training_fail_*             | 4    | 0   | This signal is asserted during link training if the corresponding link training state machine detects a time-out during the training period.                                                                                          |
| stat_lt_rx_sof_*                    | 4    | 0   | This output is High for 1 RX SerDes clock cycle to indicate the start of the link training frame.                                                                                                                                     |
| stat_lt_frame_lock_*                | 4    | 0   | When link training has begun, these signals are asserted, for each PMD lane, when the corresponding link training receiver is able to establish a frame synchronization with the link partner.                                        |
| stat_lt_preset_from_rx_*            | 4    | 0   | This signal reflects the value of the preset control bit received in the control block from the link partner.                                                                                                                         |
| stat_lt_initialize_from_rx_*        | 4    | 0   | This signal reflects the value of the initialize control bit received in the control block from the link partner.                                                                                                                     |
| stat_lt_k_p1_from_rx0_*             | 2    | 0   | This 2-bit field indicates the update control bits for the k+1 coefficient, as received from the link partner in the control block.                                                                                                   |
| stat_lt_k0_from_rx0_*               | 2    | 0   | This 2-bit field indicates the update control bits for the k0 coefficient, as received from the link partner in the control block.                                                                                                    |
| stat_lt_k_m1_from_rx0_*             | 2    | 0   | This 2-bit field indicates the update control bits for the k-1 coefficient, as received from the link partner in the control block.                                                                                                   |
| stat_lt_stat_p1_from_rx0_*          | 2    | 0   | This 2-bit field indicates the update status bits for the k+1 coefficient, as received from the link partner in the status block.                                                                                                     |
| stat_lt_stat0_from_rx0_*            | 2    | 0   | This 2-bit fields indicates the update status bits for the k0 coefficient, as received from the link partner in the status block.                                                                                                     |
| stat_lt_stat_m1_from_rx0_*          | 2    | 0   | This 2-bit field indicates the update status bits for the k-1 coefficient, as received from the link partner in the status block.                                                                                                     |



# Clause 74 FEC Interface Control/Status/Statistics Signals

Ports in the following table are available when Clause 74 (BASE-KR FEC) is selected from the Configuration tab.

Table 314: Clause 74 FEC Interface Control/Status/Statistics Signals

| Name                              | Size | I/O | Description                                                                                                                                                                      |
|-----------------------------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_fec_tx_enable_*               | 1    | I   | Asserted to enable the clause 74 FEC encoding on the transmitted data.                                                                                                           |
| ctl_fec_rx_enable_*               | 1    | I   | Asserted to enable the clause 74 FEC decoding of the received data.                                                                                                              |
| ctl_fec_enable_error_to_pcs_*     | 1    | I   | Clause 74 FEC enable error to pcs.                                                                                                                                               |
| stat_fec_inc_correct_count_*      | 4    | 0   | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected and corrected a bit errors in the corresponding frame. |
| stat_fec_inc_cant_correct_count_* | 4    | 0   | This signal will be asserted roughly every 32 words, while the ctl_rx_fec_enable is asserted, if the FEC decoder detected bit                                                    |
| stat_fec_lock_error_*             | 4    | 0   | stat_fec_lock_error_* is asserted if the FEC decoder has been unable to detect the frame boundary after about 5 ms. It is cleared when the frame boundary is detected.           |
| stat_fec_rx_lock_*                | 4    | 0   | This signal is asserted while the ctl_fec_rx_enable is asserted when the FEC decoder detects the frame boundary.                                                                 |

# IEEE Clause 108 (RS-FEC) Control/Status/Statistics Signals

Ports under this section are available when IEEE Clause 108 (RS-FEC) is selected from Configuration tab.

Table 315: IEEE Clause 108 (RS-FEC) Control/Status/Statistics Signals

| Name                             | Size | I/O | Description                                                                                                                                   |
|----------------------------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rx_rsfec_enable_correction_* | 1    | I   | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on first cycle on reset.  |
|                                  |      |     | Equivalent to MDIO register 1.200.0                                                                                                           |
|                                  |      |     | 0: Decoder performs error detection without error correction (see IEEE 802.3by section 91.5.3.3).                                             |
|                                  |      |     | 1: the decoder also performs error correction.                                                                                                |
| ctl_rx_rsfec_enable_indication_* | 1    | I   | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value sampled on the first cycle on reset. |
|                                  |      |     | Equivalent to MDIO register 1.200.1                                                                                                           |
|                                  |      |     | • 0: Bypass the error indication function (see IEEE Std 802.3by section 91.5.3.3).                                                            |
|                                  |      |     | 1: Decoder indicates errors to the PCS sublayer.                                                                                              |



Table 315: IEEE Clause 108 (RS-FEC) Control/Status/Statistics Signals (cont'd)

| Name                                   | Size | I/O | Description                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ctl_rsfec_enable_*                     | 1    | I   | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on the first cycle on reset.  Enable RS-FEC function.  *Note: Some variants of the 10G/25G Subsystem can have individual RX and TX enable signals.                                                                                                               |
| ctl_rsfec_ieee_error_indication_mode_* | 1    | I   | The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on the first cycle on reset.  1: Core conforms to the IEEE RS-FEC specification.  0: If ctl_rx_rsfec_enable_correction and ctl_rx_rsfec_enable_indication are set to zero, the RS decoder is bypassed.                                                           |
| ctl_rsfec_consortium_25g_*             | 1    | I   | Switches between IEEE Clause 108 and 25G Ethernet Consortium mode.  The setting on this bit takes effect after rx_resetn has been asserted Low (~rx_serdes_reset). New value is sampled on the first cycle on reset.  1 = 25G Consortium specification mode.  0 = IEEE 802.3by mode.  Note: Some variants of the 10G/25G Subsystem can have individual RX and TX consortium signals. |
| stat_rx_rsfec_hi_ser_*                 | 1    | 0   | Set to one if the number of RS-FEC symbol errors in a window of 8192 codewords exceeds the threshold K = 417 and is set to zero otherwise.                                                                                                                                                                                                                                           |
| stat_rx_rsfec_lane_alignment_status_*  | 1    | 0   | A value of 1 indicates that the RX RS-FEC block has achieved alignment on the data from the transceiver.                                                                                                                                                                                                                                                                             |
| stat_rx_rsfec_corrected_cw_inc_*       | 1    | 0   | Increment for corrected errors.                                                                                                                                                                                                                                                                                                                                                      |
| stat_rx_rsfec_uncorrected_cw_inc_*     | 1    | 0   | Increment for uncorrected errors.                                                                                                                                                                                                                                                                                                                                                    |
| stat_rx_rsfec_err_count0_inc_*         | 3    | 0   | Increment for detected errors.                                                                                                                                                                                                                                                                                                                                                       |
| stat_tx_rsfec_lane_alignment_status_*  | 1    | 0   | A value of 1 indicates that the TX RS-FEC block has achieved alignment on the incoming PCS data.                                                                                                                                                                                                                                                                                     |

# **PLL and SYS Clock**

Table 316: PLL and SYS Clock Select Lines when RUNTIME SWITCH Feature Selected

| Name          | Size | I/O | Description                                                                                                                                                                      |
|---------------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gt_drp_done_* | 1    | I   | Indicates the completion of the GT DRP operation. Used to reset the GT module.  *Note: This port is available when Runtime Switchable Mode is selected in the Configuration tab. |



*Table 316:* **PLL and SYS Clock Select Lines when RUNTIME SWITCH Feature Selected** *(cont'd)* 

| Name                       | Size | I/O | Description                                                                                                                                                                                                                       |
|----------------------------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| txpllclksel_in_*           | 1    | I   | TX PLL clock select lines. <b>Note:</b> This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                                                                                 |
| rxpllclksel_in_*           | 1    | I   | RX PLL clock select lines. This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                                                                                              |
| txsysclksel_in_*           | 1    | I   | Select the TX PLL clock source to drive txoutclk. <b>Note:</b> This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                                                          |
| rxsysclksel_in_*           | 1    | I   | Select the RX PLL clock source to drive rxoutclk  Note: This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                                                                 |
| rxafecfoken_*              | 1    | I   | Only for UltraScale+ devices                                                                                                                                                                                                      |
| rxdfecfokfcnum_*           | 1    | I   | Only for UltraScale+ devices                                                                                                                                                                                                      |
| speed_*                    | 1    | I   | This signal indicates the speed with which the core is working:  1'b1 = 10G and 1'b0 = 25G  Note: This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                       |
| anlt_done_*                | 1    | 0   | Indicates the completion of Auto-Negotiation and Link Training.  Note: This port is available when Runtime Switchable Mode is selected in the Configuration tab.                                                                  |
| axi_ctl_core_mode_switch_* | 1    | 0   | This signal can be used to switch the line rate from 10G to 25G and vice-verse when selecting Include AXI4-Lite in the Configuration tab and write 1 to the 0x0138 self-clearing register to start the GT DRP operations.         |
| user_reg0_*                | 32   | 0   | User-defined signal from the AXI4-Lite Reg map user_reg0 register. <b>Note:</b> This port is available when Include AXI4-Lite interface is selected in the Configuration tab.                                                     |
| gt_drp_grant_*             | 1    | 0   | This signal indicates the GT DRP interface is busy or free.  1 indicates GT DRP interface ready to access for read or write  0 indicates GT DRP interface in busy in another transaction and can not be access for read or write. |



# **Duplex Mode of Operation**

In this mode of operation, both the transmitter and receiver of the core are active and loopback functionality is provided at the GT output interface, that is, output is fed back as input. Packet generation and monitor modules are active in this mode. The generator module is responsible for generating the desired number of packets and transmit to the core using the available data interface. The monitor module checks the packets from the receiver.

The following figure shows the duplex mode of operation.



Figure 52: Duplex Mode of Operation

## **Runtime Switchable**

This configuration gives the flexibility to switch the line rate between 10G to 25G and vice-versa any time. To activate this feature, select the check box **Runtime Switchable mode** option in the Configuration tab. When this option is selected speed can be changed by using ch0\_txrate and ch0\_rxrate ports. Internally, the GT IP will perform required DRP writes to get the desired speed.

When this option is selected the \*\_trans\_debug module will be present inside the \*\_pkt\_gen\_mon.v module of the example design. This \*\_trans\_debug module is responsible for performing all the GT DRP write operations to switch the transceiver mode, that is, 10G to 25G or 25G to 10G. When you set the mode\_change\_\* input signal High for two clock cycles and then make it Low, it starts the DRP write operation to the GT channel for the specific core and resets the specific core.

**Note:** For the switching operation, you should copy the trans\_debug module into your design.



The DRP writes are done only for the channel. The QPLLO of the common is fixed for the line rate 25G and the QPLL1 is fixed for the line rate 10G.

The state transition occurred during this process is shown in the following figure:

Figure 53: State Transition Diagram for Runtime Switchable DRP Operation without AN/LT







Figure 54: State Transition Diagram for Runtime Switchable DRP Operation with AN/LT

# **Shared Logic Implementation**

Shared logic includes all the shareable modules that can be present as part of the core or in the Example Design.

By default GT common, reset logic and clocking modules are present inside the IP core. In case of the following conditions, these modules will be placed outside the core so that they can be shared with other designs.

• When you select the **Include GT subcore in example design** option in the GT Selection and Configuration tab.



• When you select the **Include Shared Logic in Example Design** option in the Shared Logic tab.

When the shared logic in the example design is selected, a new xxv\_ethernet\_\*\_core\_support.v module will be instantiated between the xxv\_ethernet\_\*\_exdes.v and DUT (that is, xxv\_ethernet\_\*.v). This module will have all the sub modules that can be shared between multiple designs.

The following figure shows the implementation when shared logic is instantiated in the example design for single core.

xxv\_ethernet\_0\_exdes\_tb.v xxv\_ethernet\_0\_exdes.v xxv ethernet 0.v xxv\_ethernet\_0\_wrapper.v xxv\_ethernet\_0\_top.v Shared Logic gt\_ref\_clk\_n sys\_reset ANLT Wrapper.v Retiming gt\_tx\*\_out\_0 LT RXTX TOP Registers GT Wiz gt\_rx\*\_in\_0 Registers AN\_PCONTROL GT Trans\_debug (xxv ethernet 0 TX/RX Clocking trans\_debug.v) HALF\_RATE\_ Helper Blocks ADAPTER\_IP pkt gen mon 0.v Stats signals HALF RATE CORE.V ADAPTER\_OP CTRL signals Traffic GEN / MON AXI4-Stream / MII Interface signals \*\_axi\_if\_top.v completion\_stat axi4\_lite\_reg Example\_FSM \_map axi4\_lite\_slave\_ 2\_ipif AXI4 User AXI4-Lite signals

Figure 55: Single Core Example Design Hierarchy with Shared Logic Implementation

The following figure shows the implementation when shared logic is instantiated in the example design for multiple cores.





Figure 56: Multiple Core Example Design Hierarchy with Shared Logic Implementation

The following modules are the part of shared logic wrapper.

- \*\_clocking\_wrapper This module contains all the clk resources that can be shared with other designs.
- \*\_common\_wrapper This module contains the GT common that can be shared with other designs.
- \*\_reset\_wrapper This module contains all the reset logics for the specific selected Vivado IDE configuration.

# **AXI4-Lite Interface Implementation**

In order to instantiate the AXI4-Lite interface to access the control and status registers of the xxv\_ethernet\_0 core, enable the Include AXI4-Lite check box in the Configuration Tab of the Vivado IDE. This option enables the  $xxv_ethernet_0_axi_if_top$  module (which contains  $xxv_ethernet_0_pif_registers$  with the  $xxv_ethernet_0_slave_2_ipif$  module). You can access the AXI4-Lite interface logic registers (control, status and statistics) from the  $xxv_ethernet_0_pkt_gen_mon$  module.



This mode enables the following features:

- You can configure all the control (CTL) ports of the core through the AXI4-Lite interface. This operation is performed by writing to a set of address locations with the required data to the register map interface.
- You can access all the status and statistics registers from the core through the AXI4-Lite interface. This operation is performed by reading the address locations for the status and statistics registers through register map.

### .h Header File

AXI4 registers information such as register address, register name with bit position, mask value, access type and their default values are provided in header (.h) file format when the IP is generated with **Include AXI4-Lite** enabled in the Vivado Design Suite and the header file can be found under the folder header\_files of the project path.

## **AXI4 Interface User Logic**

The following sections provide the AXI4-Lite interface state machine control and ports.

#### **User State Machine**

The read and write through the AXI4-Lite slave module interface is controlled by a state machine as shown below:



Figure 57: User State Machine for AXI4-Lite Interface

A functional description of each state is described as below:



- IDLE\_STATE: By default the FSM will be in IDLE\_STATE. When the user\_read\_req signal becomes High, then it moves to the READ\_STATE else if the user\_write\_req signal is High, it moves to WRITE\_STATE else it remains in IDLE\_STATE.
- WRITE\_STATE: You provide S\_AXI\_AWVALID, S\_AXI\_AWADDR, S\_AXI\_WVALID, S\_AXI\_WDATA and S\_AXI\_WSTRB in this state to write to the register map through AXI. When S\_AXI\_BVALID and S\_AXI\_BREADY from the AXI slave are High then it moves to ACK\_STATE. If any write operation happens in any illegal addresses, the S\_AXI\_BRESP[1:0] indicates 2'b10 that asserts the write error signal.
- READ\_STATE: You provide S\_AXI\_ARVALID and S\_AXI\_ARADDR in this state to read from the register map through AXI. When S\_AXI\_RVALID and S\_AXI\_RREADY are High then it moves to ACK\_STATE. If any read operation happens from any illegal addresses, the S\_AXI\_RRESP[1:0] indicates 2 'b10 that asserts the read error signal.
- ACK\_STATE: The state moves to IDLE\_STATE.

#### **AXI User Interface Ports**

**Table 317: AXI User Interface Ports** 

| Name          | Size | I/O | Description                                                                                                                              |
|---------------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| S_AXI_ACLK    | 1    | I   | AXI clock signal                                                                                                                         |
| S_AXI_ARESETN | 1    | I   | AXI active-Low synchronous reset                                                                                                         |
| S_AXI_PM_TICK | 1    | I   | PM tick user input                                                                                                                       |
| S_AXI_AWADDR  | 32   | I   | AXI write address                                                                                                                        |
| S_AXI_AWVALID | 1    | I   | AXI write address valid                                                                                                                  |
| S_AXI_AWREADY | 1    | 0   | AXI write address ready                                                                                                                  |
| S_AXI_WDATA   | 32   | I   | AXI write data                                                                                                                           |
| S_AXI_WSTRB   | 4    | I   | AXI write strobe. This signal indicates which byte lanes hold valid data.                                                                |
| S_AXI_WVALID  | 1    | I   | AXI write data valid. This signal indicates that valid write data and strobes are available.                                             |
| S_AXI_WREADY  | 1    | 0   | AXI write data ready                                                                                                                     |
| S_AXI_BRESP   | 2    | 0   | AXI write response. This signal indicates the status of the write transaction.  'b00 = OKAY  'b01 = EXOKAY  'b10 = SLVERR  'b11 = DECERR |
| S_AXI_BVALID  | 1    | 0   | AXI write response valid. This signal indicates that the channel is signaling a valid write response.                                    |
| S_AXI_BREADY  | 1    | I   | AXI write response ready.                                                                                                                |
| S_AXI_ARADDR  | 32   | I   | AXI read address                                                                                                                         |
| S_AXI_ARVALID | 1    | I   | AXI read address valid                                                                                                                   |
| S_AXI_ARREADY | 1    | 0   | AXI read address ready                                                                                                                   |
| S_AXI_RDATA   | 32   | 0   | AXI read data issued by slave                                                                                                            |



Table 317: AXI User Interface Ports (cont'd)

| Name         | Size | I/O | Description                                                                                              |
|--------------|------|-----|----------------------------------------------------------------------------------------------------------|
| S_AXI_RRESP  | 2    | 0   | AXI read response. This signal indicates the status of the read transfer.                                |
|              |      |     | 'b00 = OKAY                                                                                              |
|              |      |     | 'b01 = EXOKAY                                                                                            |
|              |      |     | 'b10 = SLVERR                                                                                            |
|              |      |     | 'b11 = DECERR                                                                                            |
| S_AXI_RVALID | 1    | 0   | AXI read data valid                                                                                      |
| S_AXI_RREADY | 1    | I   | AXI read ready. This signal indicates the user/master can accept the read data and response information. |

### **Valid Write Transactions**

Figure 58: AXI4-Lite User-Side Write Transaction





### **Invalid Write Transactions**

Figure 59: AXI4-Lite User Side Write Transaction with Invalid Write Address



#### **Valid Read Transactions**

Figure 60: AXI4-Lite User Side Read Transaction



X17979-092416



#### **Invalid Read Transactions**

AXI\_RREADY

AXI\_RRESP[1:0]

Read transaction

AXI\_SCLK

AXI\_ARADDR[31:0]

AXI\_ARVALID

AXI\_ARREADY

AXI\_RDATA[31:0]

AXI\_RVALID

Figure 61: AXI4-Lite User Side Read Transaction with Invalid Read Address

# **IEEE Clause 108 (RS-FEC) Integration**

If you want to include IEEE clause 108 RS-FEC soft IP (for error correction) in between 25G Ethernet IP and the GT, you must select the **Include Clause 108 (RS-FEC)** check box in the Configuration tab. This option is available for 25G line rate only.



Figure 62: RS-FEC Integration in between 25G and GT



This feature enables the IEEE Clause108 RS-FEC soft IP component instantiated between the 25G core and the GT. The TX SerDes lines from the 25G core will be input to the RS-FEC soft IP for forward error correction encoding. The output from the RS-FEC module is then fed to GT. Similarly, the RX SerDes lines from the GT will be fed to the RS-FEC module for error correction decoding and then to the 25G core.

Refer to the 25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide (PG217) (registration required) for IEEE clause 108 Reed-Solomon Forward Error Correction for the LogiCORE IP core and its functionality.

# PTP 1588 Timer Syncer Block

### Introduction

The PTP 1588 Timer Syncer Block provides reference time to all the Ethernet ports in the design. It implements an IEEE1588 real time clock timer and can accurately recreate 1588 timer in the local port's clock domain.

### **Features**

- Configure as Master System Timer, Master System and Port Timer and as a Port timer.
- Supports the ToD (Sec NanoSec) and Correction Time (CF) formats.
- Implements external ToD bus interface logic for synchronization to high precision clock sources.
- Crosses system ToD to the clock domain of the port timer.
- AXI4-Lite I/F for configuration and monitoring.

### **Core Overview**

The following figure identifies the major functional blocks of the Timer Syncer IP. In this figure, only four instances of the port timer are shown for simplicity. The number of port instances are user selectable at the time of generating the core. This core supports up to 16 instances of port timers.





Figure 63: Timer Syncer IP Functional Block Diagram

The Timer Syncer IP contains all the functions and interfaces needed to implement a variety of ToD topologies and applications. Further, the IP can be controlled with either software or hardware devices.

The System Timer maintains time on the free-running system time clock ( $ts_clk$ ) and provides a mechanism to synchronize the timer values with various other port timers, each of which might be clocked on their separate clocks ( $phy_clk$ ).

The System Timer IP provides timer values in two formats: Timestamp format (or ToD format) and Correction Field (CF) format. The Timestamp format is comprised of 80 bits containing fields of unsigned positive seconds and nanoseconds, such as {seconds[47:0], nanoseconds[31:0] }. The Correction Field (CF) format is a signed 64b value in nanoseconds multiplied by 2<sup>+16</sup>.

### **Features**

- Configure as Master System Timer, Master System and Port Timer and as a Port timer.
- Supports the ToD (Sec NanoSec) and Correction Time (CF) formats.
- Implements external ToD bus interface logic for synchronization to high precision clock sources.
- Crosses system ToD to the clock domain of the port timer.
- AXI4-Lite I/F for configuration and monitoring.

### External ToD Interface Sub Block

This module is optional and is present only when you select the **Enable Ext ToD Bus I/F** option while generating the IP. Its function is to load the reference seconds value onto the PTP System Timer and synchronize the System Timer to an external 1PPS source. It is intended to interface with a high precision clock source/timing device.



The inputs to this module are: 1PPS pulse, a serial 1-bit data bus which carries the reference ToD seconds time that is clocked by a serial clock input. The serial clock is expected to be less than or equal to the free-running clock ( $ts\_clk$ ) of the Timer Sync block. The process of loading the reference 48-bits second is shown in the following figure.

Figure 64: ToD Value (seconds) Interface

The External ToD I/F block stores the serial input ToD seconds value in a holding register. At the next received positive edge of the 1PPS signal, the holding register's value is incremented by +1 second, and the result be presented to the PTP System Timer sub-block. The positive edge of the 1PPS signal is re-timed within the External ToD I/F block to the  $ts\_clk$  clock and output for use by the PTP System Timer block.

#### **Features**

- Configure as Master System Timer, Master System and Port Timer and as a Port timer.
- Supports the ToD (Sec NanoSec) and Correction Time (CF) formats.
- Implements external ToD bus interface logic for synchronization to high precision clock sources.
- Crosses system ToD to the clock domain of the port timer.
- AXI4-Lite I/F for configuration and monitoring.

### PTP Port Timer Sub Block

These sub blocks contain the per port TX and RX timers that are typically clocked by their respective TX and RX PHY clocks ( $tx_phy_clk$  and  $rx_phy_clk$ ). The timer synchronizer IP allows for a maximum of sixteen port timers to be enabled at the time of generation.

These port timers maintain time in both the ToD (48-bit seconds and 30-bits nano-sec) and continuous time/correction field (63-bits CF) formats, and provide outputs synchronized to the  $tx_phy_clk$  and  $rx_phy_clk$  for use by Xilinx's Ethernet IP.

It is expected that each port's TX and RX clock domains can be asynchronous with respect to the Master timer's  $ts\_c1k$  clock. The port timers contain synchronization logic to domain cross the PTP System Timer's load-pulse and timer update values.



As the PTP System Timer is initialized, or synchronized to a high precision reference clock, it in turn pushes its updated timer value to all the port timers that are connected to it. After initialization, the Timer Syncer IP can be configured such that the port timers are continuously kept in-sync with the PTP System Timer's master ToD value, or the port timers might be independently controlled.

#### **Features**

- Configure as Master System Timer, Master System and Port Timer and as a Port timer.
- Supports the ToD (Sec NanoSec) and Correction Time (CF) formats.
- Implements external ToD bus interface logic for synchronization to high precision clock sources.
- Crosses system ToD to the clock domain of the port timer.
- AXI4-Lite I/F for configuration and monitoring.

## **Port Descriptions**

### Timer Syncer IP Interface Ports

Following are the Timer Syncer IP top level ports.

#### **Clocks and Resets**

Table 318: Clocks and Resets

| Signal   | Direction | Clock Domain | Description                                             |
|----------|-----------|--------------|---------------------------------------------------------|
| ts_clk   | I         | N/A          | Free running clock which clocks system timer's counters |
| ts_rst   | I         | ts_clk       | System timer reset active-High                          |
| tod_intr | 0         | ts_clk       | Interrupt asserted on 1-PPS event                       |

#### **External ToD Bus Interface**

Table 319: External ToD Bus Interface

| Signal         | Direction | Clock Domain   | Description                             |
|----------------|-----------|----------------|-----------------------------------------|
| tod_1pps_in    | I         | N/A            | External bus 1-PPS input                |
| tod_sec_clk_in | I         | N/A            | External bus clock, used for tod_sec_in |
| tod_sec_in     | I         | tod_sec_clk_in | External bus seconds serial data        |



*Table 319:* External ToD Bus Interface (cont'd)

| Signal          | Direction | Clock Domain   | Description                                                                |
|-----------------|-----------|----------------|----------------------------------------------------------------------------|
| tod_1pps_out    | 0         | ts_clk         | 1-PPS output Asserted when the system timer's nano-second field rolls over |
| tod_sec_clk_out | I         | N/A            | Echo of external bus clock                                                 |
| tod_sec_out     | I         | tod_sec_clk_in | Serial output of internal ToD seconds                                      |

### **Per-Port Port Timer Interface**

m\_denotes the port number ( $0 \le m \le 15$ ).

Table 320: Per-Port Port Timer Interface

| Signal              | Direction | Clock Domain | Description                      |
|---------------------|-----------|--------------|----------------------------------|
| tx_phy_clk_m        | I         | N/A          | Port TX PHY clock                |
| rx_phy_clk_m        | I         | N/A          | Port RX PHY clock                |
| tx_phy_rst_m        | I         | tx_phy_clk_m | Port TX reset                    |
| rx_phy_rst_m        | I         | rx_phy_clk_m | Port RX reset                    |
| tx_tod_sec_m[47:0]  | 0         | tx_phy_clk_m | Port TX timer seconds field      |
| tx_tod_ns_m[31:0]   | 0         | tx_phy_clk_m | Port TX timer nano-seconds field |
| tx_tod_corr_m[63:0] | 0         | tx_phy_clk_m | Port TX timer CF field           |
| rx_tod_sec_m[47:0]  | 0         | rx_phy_clk_m | Port RX timer seconds field      |
| rx_tod_ns_m[31:0]   | 0         | rx_phy_clk_m | Port RX timer nano-seconds field |
| rx_tod_corr_m[63:0] | 0         | rx_phy_clk_m | Port RX timer CF field           |

### **AXI4-Lite Interface**

**Table 321: AXI4-Lite Interface** 

| Signal             | Direction | Clock Domain | Description                        |
|--------------------|-----------|--------------|------------------------------------|
| s_axi_aclk         | I         | N/A          | AXI4-Lite interface clock          |
| s_axi_aresetn      | I         | s_axi_aclk   | AXI4-Lite interface reset          |
| s_axi_awaddr[31:0] | I         | s_axi_aclk   | Write address                      |
| s_axi_awvalid      | I         | s_axi_aclk   | Write address Valid                |
| s_axi_awready      | 0         | s_axi_aclk   | Write address Ready                |
| s_axi_wdata[31:0]  | I         | s_axi_aclk   | Write data                         |
| s_axi_wstrb[3:0]   | I         | s_axi_aclk   | Write data byte valid. Tie to 4'hF |
| s_axi_wvalid       | I         | s_axi_aclk   | Write valid                        |
| s_axi_wready       | 0         | s_axi_aclk   | Write ready                        |



Table 321: AXI4-Lite Interface (cont'd)

| Signal             | Direction | Clock Domain | Description          |
|--------------------|-----------|--------------|----------------------|
| s_axi_bresp        | 0         | s_axi_aclk   | Write response       |
| s_axi_bvalid       | 0         | s_axi_aclk   | Write response valid |
| s_axi_bready       | I         | s_axi_aclk   | Write response ready |
| s_axi_araddr[31:0] | I         | s_axi_aclk   | Read address         |
| s_axi_arvalid      | I         | s_axi_aclk   | Read address valid   |
| s_axi_arready      | 0         | s_axi_aclk   | Read address ready   |
| s_axi_rdata[31:0]  | 0         | s_axi_aclk   | Read data            |
| s_axi_rresp        | 0         | s_axi_aclk   | Read response        |
| s_axi_rvalid       | 0         | s_axi_aclk   | Read data valid      |
| s_axi_rready       | I         | s_axi_aclk   | Read ready           |

### **Internal Sub-Block Ports**

The following tables contain the select ports present on the IP sub-blocks to assist in integration and debugging.

### **External ToD Bus Ports**

**Table 322: External ToD Bus Ports** 

| Signal           | Direction | Clock Domain | Description                                                   |
|------------------|-----------|--------------|---------------------------------------------------------------|
| ext_tod_bus_sec  | I         |              | Free running clock that clocks<br>the system timer's counters |
| ext_tod_bus_ns   | I         | ts_clk       | System timer reset active-High                                |
| ext_tod_bus_1pps | 0         | ts_clk       | Interrupt asserted on 1PPS event                              |

### **PTP System Timer Ports**

**Table 323: PTP System Timer Ports** 

| Signal             | Direction | Clock Domain | Description                                                                                                                                   |
|--------------------|-----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| sys_tod_sec[48:0]  | 0         | ts_clk       | System timer ToD seconds field                                                                                                                |
| sys_tod_ns[31:0]   | 0         | ts_clk       | System timer ToD nano-seconds field                                                                                                           |
| sys_tod_corr[63:0] | 0         | ts_clk       | System timer ToD CF format                                                                                                                    |
| update_timer       | 0         | ts_clk       | Sync update pulse to the port timer blocks. Asserted when the master timer is synchronized either by the Ext ToD I/F or via register updates. |



Table 323: PTP System Timer Ports (cont'd)

| Signal             | Direction | Clock Domain | Description                                                                                                                |
|--------------------|-----------|--------------|----------------------------------------------------------------------------------------------------------------------------|
| sys_timer_1pps_out | 0         | ts_clk       | 1-PPS output to external ToD<br>bus block<br>This port is asserted when<br>system timer's nano-second<br>field rolls over. |

### **Port Timer Ports**

Table 324: Port Timer Ports

| Signal                | Direction | Clock Domain | Description                                                                             |
|-----------------------|-----------|--------------|-----------------------------------------------------------------------------------------|
| update_port_timer     | I         | ts_clk       | Sync update pulse driven by system timer                                                |
| sys_tod_sec_in[48:0]  | I         | ts_clk       | System timer seconds field Present only when the timer format is ToD or both            |
| sys_tod_ns_in[31:0]   | I         | ts_clk       | System timer nano-seconds field<br>Present only when the timer<br>format is ToD or both |
| sys_tod_corr_in[63:0] | I         | ts_clk       | System timer CF field. Present only when the timer format is CF or both                 |

## **PTP System Timer Sub Block**

This is the master or the main ToD timer clocked by a free-running clock ( $ts\_clk$ ). The system timer maintains time in the ToD (48-bit seconds and 30-bits nano-sec) and continuous time/correction field (63-bits CF) formats.

Registers are provided to initialize the timer seconds and nanoseconds counter values or to read back a snapshot of the values. A set of offset registers are provided for seconds and nanoseconds values which are added to the ToD timer value prior to being output to the port timers.

After initialization, the PTP System Timers internal ToD counters can be optionally synchronized to external devices by either the External ToD interface block's output 1PPS signal, or by the software control via register operations.

A 1PPS output indicates when the PTP system timer's ToD ns field rolls over from 999\_999\_999 ns to 1 sec. Also, the values of system timer can be read from snapshot registers.

The process of transferring the system timer's ToD counters to the port timers is configurable and can be triggered by a 1PPS pulse of the external bus, or by a write to the TOD\_SW\_LOAD register. When a transfer is triggered, the PTP System Timer provides a load-pulse output (synchronous to the  $ts_clk$  domain) and places the value of its internal timer on the output bus.



## **Address Mapping**

All the control and status registers are memory mapped. After power-up or reset, you can reconfigure the core parameters from their defaults at any time.

## Timer Register Types

**Table 325: Timer Register Types** 

| Access Type | Description                                                                                                                                                                                                              |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RO          | Read only Readable register; write has no effect                                                                                                                                                                         |  |  |
| RW          | Read and write Readable and writable register                                                                                                                                                                            |  |  |
| RW1T        | Read and write. '1' to trigger<br>Write '1' to trigger. Write '0' is ignored. Read returns '0'.                                                                                                                          |  |  |
| RW1C        | Read, write '1's to Clear Writing a '1' clears the corresponding bit position in the register to '0'; Writing a '0' leaves the corresponding bit unchanged. For example, it can be used to acknowledge interrupt status. |  |  |
| WO          | Write only<br>Writable register, the value is not readable (returns '0')                                                                                                                                                 |  |  |



## Timer Register Map

**Table 326: Timer Register Map** 

| Offset | Register Name | Access | Description                                                                                                                                                                  |
|--------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |               | Ì      | Main configuration                                                                                                                                                           |
|        |               |        | [0] – Enable system timer                                                                                                                                                    |
|        |               |        | A '0' to this bit field disables system timer IP                                                                                                                             |
|        |               |        | [1] – Enable external ToD bus                                                                                                                                                |
|        |               |        | Write '1' to enable ToD bus signals. The overwrite mode field further defines how signaling is used                                                                          |
|        |               |        | This is present only when the core is generated with external ToD bus I/F support                                                                                            |
|        |               |        | [3:2] – Overwrite Mode:                                                                                                                                                      |
|        |               |        | 0x0 - System timer counter is not overwritten at 1-PPS event from external ToD bus                                                                                           |
|        |               |        | 0x1 - system timer counter is overwritten with the external<br>ToD bus seconds input at 1-PPS event from external ToD bus                                                    |
|        |               |        | 0x2 - system timer counter is overwritten with value stored<br>in the software TOD_SW_SEC_0/1 register at 1-PPS event<br>from the external ToD bus                           |
|        |               |        | 0x3 - Reserved                                                                                                                                                               |
|        |               |        | The above modes are only present when the core is generated with Ext ToD bus interface support                                                                               |
|        |               |        | [4] – Enable Sys_timer auto-refresh. Write a '1' to enable the System Timer block to automatically refresh the port-timers with the latest ToD and CTIME (if enabled) values |
|        | TOD CONFIC    |        | [5] – Enable timer snapshot on external 1PPS                                                                                                                                 |
| 0x0000 | TOD_CONFIG    | RW     | [15:6] - Reserved                                                                                                                                                            |
|        |               |        | [16 to 31] – Enable Port TX and RX Timers                                                                                                                                    |
|        |               |        | • [16] = Enable Port-0 TX and RX                                                                                                                                             |
|        |               |        | • [17] = Enable Port-1 TX and RX                                                                                                                                             |
|        |               |        | • [18] = Enable Port-2 TX and RX                                                                                                                                             |
|        |               |        | • [19] = Enable Port-3 TX and RX                                                                                                                                             |
|        |               |        | • [20] = Enable Port-4 TX and RX                                                                                                                                             |
|        |               |        | • [21] = Enable Port-5 TX and RX                                                                                                                                             |
|        |               |        | • [22] = Enable Port-6 TX and RX                                                                                                                                             |
|        |               |        | • [23] = Enable Port-7 TX and RX                                                                                                                                             |
|        |               |        | • [24] = Enable Port-8 TX and RX                                                                                                                                             |
|        |               |        | • [25] = Enable Port-9 TX and RX                                                                                                                                             |
|        |               |        | • [26] = Enable Port-10 TX and RX                                                                                                                                            |
|        |               |        | • [27] = Enable Port-11 TX and RX                                                                                                                                            |
|        |               |        | • [28] = Enable Port-12 TX and RX                                                                                                                                            |
|        |               |        | • [29] = Enable Port-13 TX and RX                                                                                                                                            |
|        |               |        | • [30] = Enable Port-14 TX and RX                                                                                                                                            |
|        |               |        | • [31] = Enable Port-15 TX and RX                                                                                                                                            |
|        |               |        | The upper limit for port number depends on the number of                                                                                                                     |
|        |               |        | ports enabled at the time of generating core.                                                                                                                                |



Table 326: Timer Register Map (cont'd)

| Offset           | Register Name                  | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|--------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0004           | TOD_SNAPSHOT                   | RW1T   | [0] – Snapshot all timers<br>Writing 1'b1 will snapshot all counters (system, external ToD<br>bus, and all enabled ports)<br>[31:1] - Reserved                                                                                                                                                                                                                                                                                         |
| 0x0008           | TOD_INTR_ENABLE                | RW     | Interrupt enable register [0] - 1-PPS interrupt (Master RTC sec field) [15:1] – Reserved [16] - 1-PPS interrupt (External 1pps input) [31:17] - Reserved                                                                                                                                                                                                                                                                               |
| 0x000C           | TOD_INTR_STATUS                | RW1C   | Interrupt clear register [0] - 1-PPS interrupt (Master RTC sec field) [15:1] – Reserved [16] - 1-PPS interrupt (External 1pps input) [31:17] - Reserved                                                                                                                                                                                                                                                                                |
| 0x0010           | TOD_SW_SEC_0                   | RW     | [31:0] - Overwrite master timer's second field bits [31:0]                                                                                                                                                                                                                                                                                                                                                                             |
| 0x0014           | TOD_SW_SEC_1                   | RW     | [15:0] - Overwrite master timer's second field bits [47:32]<br>[31:16] - Reserved                                                                                                                                                                                                                                                                                                                                                      |
| 0x0018           | TOD_SW_NS                      | RW     | [29:0] - Overwrite master timer's second field bits<br>[31:30] - Reserved                                                                                                                                                                                                                                                                                                                                                              |
| 0x001C           | TOD_SW_LOAD                    | RW1T   | [0] - Write '1' initiates a load of the system timer's ToD values from the TOD_SW_SEC_0/1, TOD_SW_NS, and TOD_SW_CTIME_0/1 registers [1] - Write '1' initiates a load of the system timer's ToD offset value from the TOD_SEC_SYS_OFFSET_0/1, and TOD_NS_SYS_OFFSET_0 registers  **Note:* Offset is added by logic prior to system timer's output to the port timers. As such, offset is not reflected by system timer ToD read backs. |
| 00020            | TOD CIAL CTIME O               | DIA    | [31:2] - Reserved                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0x0020<br>0x0024 | TOD_SW_CTIME_0  TOD_SW_CTIME_1 | RW     | [31:0] - Overwrite master timer's CF field bits [31:0] [30:0] - Overwrite master timer's second field bits [63:32] [31] - Reserved                                                                                                                                                                                                                                                                                                     |
| 0x0028           | TOD_SEC_SYS_OFFSET_0           | RW     | {TOD_SEC_SYS_OFFSET_1[15:0], TOD_SEC_SYS_OFFSET_0[31:0]} -                                                                                                                                                                                                                                                                                                                                                                             |
| 0x002C           | TOD_SEC_SYS_OFFSET_1           | RW     | Represents system timer 48b seconds field signed offset value TOD_NS_SYS_OFFSET_0[29:0] - Represents system timer 30b                                                                                                                                                                                                                                                                                                                  |
| 0x0030           | TOD_NS_SYS_OFFSET_0            | RW     | nano second field signed offset value  Signed bit interpreted as follows for TOD_SEC_SYS_OFFSET  If [47] = 1'b1 then subtract from system timer  If [47] = 1'b0 then add to system timer  Need to apply trigger bit [1] at register 0x001C                                                                                                                                                                                             |
| 0x0100           | TOD_SYS_SEC_0                  | RO     | [31:0] - Snapshot of system timer's second field [31:0]                                                                                                                                                                                                                                                                                                                                                                                |
| 0x0104           | TOD_SYS_SEC_1                  | RO     | [15:0] - Snapshot of system timer's second field [47:32]<br>[31:16] - Reserved                                                                                                                                                                                                                                                                                                                                                         |
| 0x0108           | TOD_SYS_NS                     | RO     | [29:0] - Snapshot of system timer's Nano-second Field [29:0]<br>[31:30] - Reserved                                                                                                                                                                                                                                                                                                                                                     |



Table 326: Timer Register Map (cont'd)

| Offset | Register Name    | Access | Description                                                                                                                                                                                                                                            |
|--------|------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x010C | TOD_SYS_OFFSET   | RW     | [31:0] - Signed offset to be applied to seconds value loaded from the external ToD bus, and to be added to 0 nanoseconds field when a 1PPS event occurs on the External ToD bus.  The signed value is expressed in 2 <sup>-16</sup> ns                 |
|        |                  |        | This is present only when the core is generated with Ext ToD Bus support                                                                                                                                                                               |
| 0x0110 | TOD_SYS_CTIME_0  | RO     | [31:0] - Snapshot of system timer's CF Field [31:0]                                                                                                                                                                                                    |
| 0x0114 | TOD_SYS_CTIME_1  | RO     | [30:0] - Snapshot of system timer's CF Field [63:32]<br>[31] - Reserved                                                                                                                                                                                |
| 0x0120 | TODBUS_SEC_0     | RO     | Current value of the Ext ToD bus's second Field [31:0]                                                                                                                                                                                                 |
| 0x0124 | TODBUS_SEC_1     | RO     | [15:0] - Current value of the Ext ToD bus's second field [47:32]<br>[31:16] - Reserved                                                                                                                                                                 |
| 0x012C | TODBUS_SYS_DIFF  | RO     | [31:0] - Once a second comparison of external ToD bus captured value and system Timer's internal ToD value in signed unit of 2 <sup>-16</sup> ns                                                                                                       |
| 0x0034 | TOD_SYS_PERIOD_0 | RW     | System Timer TS clock period expressed in 2 <sup>-48</sup> ns.                                                                                                                                                                                         |
| 0x0038 | TOD_SYS_PERIOD_1 | RW     | For example, 3.2 ns is represented as:  TOD_SYS_PERIOD_0[31:0] = 0x3333_3333  TOD_SYS_PERIOD_1[23:0] = 0x0003_3333  TOD_SYS_PERIOD_1[31:24] reserved  A write to TOD_SYS_PERIOD_1 register will 'commit' the updated period value to the system timer. |

## **Port Timer Registers**

Port timer register set is replicated for every port timer present (0 to 15) at the offsets listed for ports 1 to 15.

**Table 327: Port Timer Registers** 

| Offset | Register Name    | Access              | Description                                                                                                                                   |
|--------|------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
|        | Port 0 Registers | s: 0x0200 to 0x023F |                                                                                                                                               |
| 0x0200 | TX0_CTIME_0      | RW                  | [31:0] - Snapshot of Port0 TX Timer's CF<br>Field [31:0]                                                                                      |
| 0x0204 | TX0_CTIME_1      | RW                  | [30:0] - Snapshot of Port0 TX Timer's CF<br>Field [63:32]<br>[31] - Reserved                                                                  |
| 0x0208 | TX0_PERIOD_0     | RW                  | Port0 TX clock period expressed in 2 <sup>-48</sup>                                                                                           |
| 0x020C | TX0_PERIOD_1     | RW                  | For example, 3.2 ns is represented as<br>TX0_PERIOD_0[31:0] = 0x3333_3333<br>TX0_PERIOD_1[23:0] = 0x0003_3333<br>TX0_PERIOD_1[31:24] reserved |
| 0x0210 | TX0_SYS_OFFSET   | RW                  | [31:0] - Signed offset applied to Port0 TX<br>Timer's ToD output expressed in 2 <sup>-16</sup> ns.                                            |



*Table 327:* **Port Timer Registers** *(cont'd)* 

| Offset | Register Name      | Access | Description                                                                                                                                                                         |
|--------|--------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x0214 | TX0_NS_SNAP        | RO     | [29:0] - Snapshot of Port0 TX Timer's<br>Nano-second Field [29:0]                                                                                                                   |
|        |                    |        | [31:30] - Reserved                                                                                                                                                                  |
| 0x0218 | TX0_SEC_0_SNAP     | RO     | [31:0] - Snapshot of Port0 TX Timer's<br>Second Field [31:0]                                                                                                                        |
| 0x021C | TX0_SEC_1_SNAP     | RO     | [15:0] - Snapshot of Port0 TX Timer's<br>Second Field [47:32]<br>[31:16] - Reserved                                                                                                 |
| 0x0220 | RX0_CTIME_0        | RW     | [31:0] - Snapshot of Port0 RX Timer's CF<br>Field [31:0]                                                                                                                            |
| 0x0224 | RX0_CTIME_1        | RW     | [30:0] - Snapshot of Port0 RX Timer's CF<br>Field [63:32]<br>[31] - Reserved                                                                                                        |
| 0x0228 | RX0_PERIOD_0       | RW     | Port0 RX clock period expressed in 2 <sup>-48</sup>                                                                                                                                 |
| 0x022C | RX0_PERIOD_1       | RW     | ns For example, 3.2 ns is represented as RX0_PERIOD_0[31:0] = 0x3333_333 RX0_PERIOD_1[23:0] = 0x0003_3333 RX0_PERIOD_1[31:24] reserved                                              |
| 0x0230 | RX0_SYS_OFFSET     | RW     | [31:0] - Signed offset applied to Port0 RX<br>Timer's ToD output expressed in 2 <sup>-16</sup> ns.                                                                                  |
| 0x0234 | RX0_NS_SNAP        | RO     | [29:0] - Snapshot of Port0 RX Timer's<br>Nano-second Field [29:0]<br>[31:30] - Reserved                                                                                             |
| 0x0238 | RX0_SEC_0_SNAP     | RO     | [31:0] - Snapshot of Port0 RX Timer's<br>Second Field [31:0]                                                                                                                        |
| 0x023C | RX0_SEC_1_SNAP     | RO     | [15:0] - Snapshot of Port0 RX Timer's<br>Second Field [47:32]<br>[31:16] - Reserved                                                                                                 |
| 0x0240 | CORE_TX0_PERIOD_ 0 | RO     | Port0 TX clock period configured in core,                                                                                                                                           |
| 0x0244 | CORE_TX0_PERIOD_ 1 | RO     | expressed in 2 <sup>-48</sup> ns. For example, 3.2 ns is represented as: CORE_TX0_PERIOD_ 0 = 0x3333_3333 CORE_TX0_PERIOD_ 1 = 0x0003_3333 CORE_TX0_PERIOD_ 1[31:24] reserved       |
| 0x0248 | CORE_RX0_PERIOD_ 0 | RO     | Port0 RX clock period configured in core, expressed in 2 <sup>-48</sup> ns.                                                                                                         |
| 0x024C | CORE_RX0_PERIOD_ 1 | RO     | core, expressed in 2 <sup>-48</sup> ns. For example, 3.2 ns is represented as: CORE_RX0_PERIOD_ 0 = 0x3333_3333 CORE_RX0_PERIOD_ 1 = 0x0003_3333 CORE_RX0_PERIOD_ 1[31:24] reserved |



Table 327: Port Timer Registers (cont'd)

| Offset                              | Register Name                       | Access | Description                                                                                                           |  |  |
|-------------------------------------|-------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------|--|--|
| 0x0250                              | PORT0_SEC_ OFFSET_0                 |        | PORTO_SEC_SYS_OFFSET_1[15:0],                                                                                         |  |  |
| 0x0254                              | PORT0_SEC_ OFFSET_1                 |        | PORT0_SEC_SYS_OFFSET_0[31:0]} - Represents Port timer 48b seconds field                                               |  |  |
| 0x0258                              | PORT0_NS_OFFSET_0                   |        | signed offset value.  PORTO_NS_SYS_OFFSET_0[29:0] -  Represents Port timer 30b nano second field signed offset value. |  |  |
|                                     |                                     |        | Signed bit interpreted as follows for PORTO_SEC_SYS_OFFSET:                                                           |  |  |
|                                     |                                     |        | If [47] = 1'b1 then subtract from port timer                                                                          |  |  |
|                                     |                                     |        | If [47] = 1'b0 then add to port timer                                                                                 |  |  |
|                                     |                                     |        | These registers are used to apply large port specific offset.                                                         |  |  |
|                                     |                                     |        | A write to PORT0_NS_SYS_OFFSET_0 is required to trigger the application of the Port's offset.                         |  |  |
| 0x025C - 0x027F                     | Reserved                            | N/A    | Reserved                                                                                                              |  |  |
| Port 1 Registers: 0x0280 to 0x      | Port 1 Registers: 0x0280 to 0x02FF  |        |                                                                                                                       |  |  |
| Port 2 Registers: 0x0300 to 0x      | (037F                               |        |                                                                                                                       |  |  |
| Port 3 Registers: 0x0380 to 0x      | Port 3 Registers: 0x0380 to 0x03FF  |        |                                                                                                                       |  |  |
| Port 4 Registers: 0x0400 to 0x      | Port 4 Registers: 0x0400 to 0x047F  |        |                                                                                                                       |  |  |
| Port 5 Registers: 0x0480 to 0x      | Port 5 Registers: 0x0480 to 0x04FF  |        |                                                                                                                       |  |  |
| Port 6 Registers: 0x0500 to 0x      | (057F                               |        |                                                                                                                       |  |  |
| Port 7 Registers: 0x0580 to 0x      | (05FF                               |        |                                                                                                                       |  |  |
| Port 8 Registers: 0x0600 to 0x      | Port 8 Registers: 0x0600 to 0x067F  |        |                                                                                                                       |  |  |
| Port 9 Registers: 0x0680 to 0x06FF  |                                     |        |                                                                                                                       |  |  |
| Port 10 Registers: 0x0700 to 0x077F |                                     |        |                                                                                                                       |  |  |
| Port 11 Registers: 0x0780 to 0x07FF |                                     |        |                                                                                                                       |  |  |
| Port 12 Registers: 0x0800 to 0x087F |                                     |        |                                                                                                                       |  |  |
| Port 13 Registers: 0x0880 to 0      | Port 13 Registers: 0x0880 to 0x08FF |        |                                                                                                                       |  |  |
| Port 14 Registers: 0x0900 to 0      | Port 14 Registers: 0x0900 to 0x097F |        |                                                                                                                       |  |  |
| Port 15 Registers: 0x0980 to 0x09FF |                                     |        |                                                                                                                       |  |  |

## **Software Driver Initialization**

It is recommended that the software drivers follow these steps sequentially to properly initialize the core.

- Initialize other elements of the design such that the clocks including ts\_clk and tx/ rx\_phy\_clk\* are present and stable. Release resets for these clock domains such as ts\_rst, tx/rx\_phy\_rst\*.
- 2. Configure the TOD\_CONFIG register:
  - a. In Timer or Timer Syncer mode set bit [0] to enable the system timer.



- b. If an external ToD bus (1PPS synchronization and optionally serial seconds input) is to be used, then set bit [1] to 1.
- c. Set the mode bit field [3:2] to the setting matching the intended synchronization method used in your system. For example, if your system uses an external device connected to the External ToD bus (1PPS input and second's value serial input). The mode field should be set to 0x1.
- d. Finally, enable (set to 1) the appropriate bits of the Port Timer enable bitfield [19:4] to enable the port TX and RX timers.
- 3. If the system timer's initial value is to be set by the software via register programming, an alternative to the external ToD bus interface, then write the appropriate initial values to the software loading registers such as TOD\_SW\_SEC\_0/1 and TOD\_SW\_NS, TOD\_SW\_CTIME\_0/1. Also, configure any static offset to be loaded by writing the TOD\_SEC\_SYS\_OFFSET\_0/1 and TOD\_NS\_SYS\_OFFSET\_0 registers.
- 4. If the software registers are updated in Step 2, then a write of 1 to the appropriate bits of TOD\_SW\_LOAD[1:0] triggers the system timer to load software values.
- 5. Program the port TX/RX Timer. This includes the period values and any required static offset to the appropriate values by writing to the Port timer's registers: TX<M>\_PERIOD\_0/1, RX<M> PERIOD\_0/1, and TX<M>/RX<M> SYS\_OFFSET.
- 6. Configure the input CORE\_CONFIGURATION as '1' and provide system timer clock RESYNC\_CLK\_PERIOD in ps to enable the hybrid syncer module.

Continue step 4 for all Ports (M) present in the design.



# Batch Mode Test Bench

Each batch mode release of the 10G/25G Ethernet Subsystem includes a demonstration test bench that performs a loopback test on the complete subsystem. For your convenience, scripts are provided to launch the test bench from several industry-standard simulators. The test program exercises the datapath to check that the transmitted frames are received correctly. Register Transfer Level (RTL) simulation models for the subsystem are included. You must provide the correct path for the transceiver simulation model according to the latest simulation environment settings in your version of the Vivado® Design Suite.

DUT

wrapper

Demonstration Test Bench

RX Data

loopback\_release\_test

Launched with scripts for NCVerilog, Questa Advanced Simulator, or VCS

TX Data

Figure 65: Test Bench

X15170-110718





# Upgrading

This appendix contains information about upgrading to a more recent version of the IP core in the Vivado® Design Suite.

A script is provided for upgrading the design to a more recent version of the Vivado Design Suite. The script is found in the <code>/compile/xilinx/upgrade\_IP</code> directory. Run this script for the following upgrades:

- To upgrade the transceiver wrapper to the latest version.
- To use the latest transceiver simulation model, which if not upgraded can result in simulation errors.



**TIP:** Before running the script, save a copy of the original design in the event that you need to revert to the previous version.

# Changes from v2.3 to v2.4

## **Ports Added**

- tx\_parityin[7:0]
- rx\_parityout[7:0]
- ctl\_tx\_parity\_err\_response
- stat\_tx\_bad\_parity

## **Registers Added**

#### **Configuration and Status Registers**

- CONFIGURATION\_TSN\_REG
- STAT\_TSN\_REG



#### **Statistics Counters**

- STAT\_TX\_MM\_STATUS\_LSB: 0x0980
- STAT\_TX\_MM\_STATUS\_MSB: 0x0984
- STAT\_TX\_MM\_STATUS\_LSB: 0x0988
- STAT TX MM FRAGMENT MSB: 0x098C
- STAT\_TX\_MM\_HOLD\_LSB: 0x0990
- STAT\_TX\_MM\_HOLD\_MSB: 0x0994
- STAT\_RX\_MM\_ASSEMBLY\_ERROR\_LSB: 0x0998
- STAT\_RX\_MM\_ASSEMBLY\_ERROR\_MSB: 0x099C
- STAT\_RX\_MM\_FRAME\_SMD\_ERROR\_LSB: 0x09A0
- STAT\_RX\_MM\_FRAME\_SMD\_ERROR\_MSB: 0x09A4
- STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_LSB: 0x09A8
- STAT\_RX\_MM\_FRAME\_ASSEMBLY\_OK\_MSB: 0x09AC
- STAT\_RX\_MM\_FRAGMENT\_LSB: 0x09B0
- STAT\_RX\_MM\_FRAGMENT\_MSB: 0x09B4

#### **Ports Added**

#### **Control and Status Ports**

- ctl\_en\_preempt
- ctl\_hold\_request
- ctl\_disable\_verify
- ctl\_restart\_verify
- ctl\_addfrag\_size
- ctl\_verify\_time
- ctl\_verify\_limi
- stat\_tx\_mm\_verify
- stat\_tx\_mm\_status
- stat\_tx\_mm\_fragment
- stat\_tx\_mm\_hold
- stat\_rx\_mm\_assembly\_error
- stat\_rx\_mm\_frame\_smd\_error



- stat\_rx\_mm\_frame\_assembly\_ok
- stat\_rx\_mm\_fragment

# Changes from v2.3 (10/04/2017) to v2.3 (12/20/2017)

### **Ports Added**

- ctl\_tx\_latency\_\*
- ctl\_tx\_lat\_adj\_enb\_\*
- ctl\_rx\_latency\_0
- ctl\_rx\_lat\_adj\_enb\_0
- ctl\_rx\_timestamp\_adj\_enb\_0
- ctl\_rx\_timestamp\_adj\_enb\_0

## **Port Changes**

- Updated descriptions of rx\_clk\_out, rx\_core\_clk, and tx\_clk\_out.
- Updated description of send\_continuous\_pkts\_\*
- Changed 3.42.3 to 3.42.7 for ctl\_tx\_test\_pattern\_\*.

## **Ports Removed**

- rx\_ptp\_pcslane\_out
- rx\_lane\_aligner\_fill\_0
- rx\_lane\_aligner\_fill\_1
- rx\_lane\_aligner\_fill\_2
- rx\_lane\_aligner\_fill\_3
- tx\_ptp\_rxtstamp\_in\_\*



# Changes from v2.2 to v2.3

## **Ports Added**

- rx\_core\_clk
- tx\_ptp\_upd\_chksum\_in
- tx\_ptp\_pcslane\_out
- tx\_ptp\_chksum\_offset\_in
- rx\_ptp\_pcslane\_out
- rx\_lane\_aligner\_fill\_0
- $\bullet$  rx\_lane\_aligner\_fill\_1
- rx\_lane\_aligner\_fill\_2
- rx\_lane\_aligner\_fill\_3
- send\_continuous\_pkts\_\*
- user\_reg0\_\*

## **Ports Updated**

- stat\_rx\_status
- user\_reg1\_\*

## **Ports Removed**

• tx\_ptp\_rxtstamp\_in

## **Port Name Changes**

- mode\_change\_0 to mode\_change\_\*
- core\_speed\_0 to core\_speed\_\*

# Registers

- Deleted USER\_REG1.
- Changed CORE\_SPEED\_REG name to SWITCH\_CORE\_SPEED\_REG.



- Added a note about the readable STAT\_\*\_MSB/LSB registers to the Statistics Counters section in Chapter 2.
- Added STAT\_CORE\_SPEED\_REG. Also added STAT\_CORE\_SPEED\_REG: 0498 for new register.
- Updated USER\_REG\_0: 0184 to USER\_REG\_0: 0134.
- Added the following registers: CONFIGURATION\_1588\_REG, TX\_CONFIGURATION\_1588\_REG, and RX\_CONFIGURATION\_1588\_REG

# Changes from v2.1 to v2.2

#### **Ports**

Added IEEE 802.3 Clause 74 FEC Interface and IEEE 802.3 Clause 108 RS-FEC Interface sections that include the port description in the new tables.

#### **Ports Added**

Added gtpowergood\_out\_\*

#### **Port Descriptions Updated**

- dclk
- ctl\_gt\_reset\_all
- tick\_reg
- rx\_clk
- gt\_ref\_clk\_p, gt\_ref\_clk\_n, and dclk
- an\_clk\_\*,stat\_fec\_lock\_error\_\* and ctl\_rsfec\_enable\_\*

# Changes from v2.0 to v2.1

## New Variants for 10 Gb/s Operation

- 64-bit MAC-only configuration
- 32-bit Low Latency MAC and PCS configuration



 Redesigned auto-negotiation and Link Training features with reduced utilization; all changes are transparent to the user

## Feature Updates for 25 Gb/s Operation

Redesigned auto-negotiation and Link Training features with reduced utilization; all changes are transparent to the user.

#### **Ports**

#### **Ports Added**

- stat\_rx\_status
- axi\_ctl\_core\_mode\_switch\_\*
- rx\_mii\_clk
- tx\_mii\_clk
- clk

#### **Ports Deleted**

tx\_ptp\_pcslane\_out

#### **Port Changes**

- Added 32-bits to tx\_axis\_tdata\_\* and rx\_axis\_tdata\_\*
- Updated bus sizes for many signals
- Updated bus sizes of tx\_axis\_tdata\_\* and rx\_axis\_tdata\_\*.
- Added 32/64-bit to tx\_clk\_out\_\* and tx\_mii\_out\_\*.
- Added 32 bits to rx\_serdes\_data\_out\_\* and tx\_serdes\_data\_in\_\*.
- Replaced "Ethernet MAC+PCS/PMA" with "Ethernet MAC+PCS/PMA-32/64-bit" in most of the signals in Core xci Top Level Port List.
- Inserted "or Ethernet MAC" in most of the signals in Core xci Top Level Port List.
- Updated descriptions of the following:

```
rx_axis_tdata[63 or 31:0]
rx_axis_tkeep[7 or 3:0]
ctl_rx_ignore_fcs
ctl_rx_max_packet_len[14:0]
```





```
ctl_rx_min_packet_len[7:0]
stat_rx_undersize
stat_rx_fragment
stat_tx_total_bytes[3:0]
stat_tx_frame_error
ctl_tx_pause_quanta[8:0][15:0]
ctl_tx_pause_refresh_timer[8:0][15:0]
ctl_an_nonce_seed[7:0]
rx_mii_clk
tx_mii_d_*
rx_mii_c_*
rx_mii_c_*
```

#### **Registers Added**

- USER\_REG\_1: 0188
- CORE\_SPEED\_REG:018C

#### **Register Changes**

- Added Bit 1 to CORE\_SPEED\_REG: 0180.
- Added note for Bits 1 and 2 to STAT\_TX\_STATUS\_REG1: 0400.
- Modified notes for most of the registers in Configuration Register Map 10G/25G Ethernet Subsystem, Status Register Map for 10G/25G Ethernet Subsystem, and Statistics Counters.

# Changes from v2.0 (10/05/2016) to v2.0 (11/30/2016)

#### **Ports Added**

- gtwiz\_reset\_qpll1lock\_in
- gtwiz\_reset\_qpll1reset\_out



- gt\_refclk\_out
- tx\_unfout\_\*
- stat\_rx\_valid\_ctrl\_code\_\*
- ctl\_tx\_ptp\_1step\_enable\_\*
- ctl\_tx\_ptp\_latency\_adjust\_\*
- ctl\_ptp\_transpclk\_mode\_\*
- tx\_ptp\_upd\_chksum\_in\_\*
- tx\_ptp\_tstamp\_offset\_in\_\*
- tx\_ptp\_chksum\_offset\_in\_\*
- tx\_ptp\_rxtstamp\_in\_\*
- ctl\_an\_fec\_25g\_baser\_request\_\*
- stat\_an\_lp\_ability\_25gbase\_cr1\_\*
- stat\_an\_rxcdrhold\_\*
- ctl\_fec\_enable\_error\_to\_pcs\_\*
- ctl\_rx\_rsfec\_enable\_correction\_\*
- ctl\_rx\_rsfec\_enable\_indication\_\*
- ctl\_rsfec\_enable\_\*
- ctl\_rsfec\_ieee\_error\_indication\_mode\_\*
- ctl\_rsfec\_consortium\_25g\_\*
- stat\_rx\_rsfec\_hi\_ser\_\*
- stat\_rx\_rsfec\_lane\_alignment\_status\_\*
- stat\_rx\_rsfec\_corrected\_cw\_inc\_\*
- stat\_rx\_rsfec\_uncorrected\_cw\_inc\_\*
- stat\_rx\_rsfec\_err\_count0\_inc\_\*
- stat\_tx\_rsfec\_lane\_alignment\_status\_\*
- gt\_drp\_done\_\*
- speed\_\*
- anlt\_done\_\*

#### **Ports Removed**

• stat\_rx\_framing\_err\_valid\_1\_\*



- stat\_rx\_framing\_err\_1\_\*
- stat\_rx\_framing\_err\_valid\_2\_\*
- stat\_rx\_framing\_err\_2\_\*
- stat\_rx\_framing\_err\_valid\_3\_\*
- stat\_rx\_framing\_err\_3\_\*
- stat\_rx\_vl\_demuxed\_\*
- stat\_rx\_vl\_number\_0\_\*
- stat\_rx\_vl\_number\_1\_\*
- stat\_rx\_vl\_number\_2\_\*
- stat\_rx\_v1\_number\_3\_\*
- stat\_rx\_synced\_\*
- stat\_rx\_synced\_err\_\*
- stat\_rx\_mf\_len\_err\_\*
- stat\_rx\_mf\_repeat\_err\_\*
- stat\_rx\_mf\_err\_\*
- stat\_rx\_misaligned\_\*
- stat\_rx\_aligned\_err\_\*
- stat\_rx\_bip\_err\_0\_\*
- stat\_rx\_bip\_err\_1\_\*
- stat\_rx\_bip\_err\_2\_\*
- stat\_rx\_bip\_err\_3\_\*
- stat\_rx\_aligned\_\*
- stat\_rx\_status\_\*
- tx\_ptp\_pcslane\_out\_\*
- rx\_lane\_aligner\_fill\_0\_\*
- rx\_lane\_aligner\_fill\_1\_\*
- rx\_lane\_aligner\_fill\_2\_\*
- rx\_lane\_aligner\_fill\_3\_\*
- ctl\_lt\_pseudo\_seed1\_\*
- ctl\_lt\_k\_p1\_to\_tx1\_\*
- ctl\_lt\_k0\_to\_tx1\_\*



- ctl\_lt\_stat\_p1\_to\_tx1\_\*
- ctl\_lt\_stat0\_to\_tx1\_\*
- ctl\_lt\_stat\_m1\_to\_tx1\_\*
- ctl\_lt\_pseudo\_seed2\_\*
- ctl\_lt\_k\_p1\_to\_tx2\_\*
- ctl\_lt\_k0\_to\_tx2\_\*
- ctl\_lt\_k\_m1\_to\_tx2\_\*
- ctl\_lt\_k\_m1\_to\_tx2\_\*
- ctl\_lt\_stat0\_to\_tx2\_\*
- ctl\_lt\_stat\_m1\_to\_tx2\_\*
- ctl\_lt\_pseudo\_seed3\_\*
- ctl\_lt\_k\_p1\_to\_tx3\_\*
- ctl\_lt\_k0\_to\_tx3\_\*
- ct1\_1t\_k\_m1\_to\_tx3\_\*
- ctl\_lt\_stat\_p1\_to\_tx3\_\*
- Ct1\_1t\_stat0\_to\_tx3\_\*
- ctl\_lt\_stat\_m1\_to\_tx3\_\*
- stat\_an\_start\_tx\_disable\_\*
- stat\_an\_start\_an\_good\_check\_\*
- stat\_lt\_k\_p1\_from\_rx1\_\*
- stat\_lt\_k0\_from\_rx1\_\*
- stat\_lt\_k\_m1\_from\_rx1\_\*
- stat\_lt\_stat\_p1\_from\_rx1\_\*
- stat\_lt\_stat0\_from\_rx1\_\*
- stat\_lt\_stat\_m1\_from\_rx1\_\*
- stat\_lt\_k\_p1\_from\_rx2\_\*
- Stat\_lt\_k0\_from\_rx2\_\*
- stat\_lt\_k\_m1\_from\_rx2\_\*
- stat\_lt\_stat\_p1\_from\_rx2\_\*
- stat\_lt\_stat0\_from\_rx2\_\*
- stat\_lt\_stat\_m1\_from\_rx2\_\*



- stat\_lt\_k\_p1\_from\_rx3\_\*
- stat\_lt\_k0\_from\_rx3\_\*
- stat\_lt\_k\_m1\_from\_rx3\_\*
- stat\_lt\_stat\_p1\_from\_rx3\_\*
- stat\_lt\_stat0\_from\_rx3\_\*
- stat\_lt\_stat\_m1\_from\_rx3\_\*

# Migrating from the Legacy XGEMAC

This section contains information about upgrading from the legacy version of the Xilinx 10G EMAC IP to the new 10G/25G High Speed Ethernet Subsystem IP core.



**RECOMMENDED:** For all new designs, Xilinx recommends that you use the most recent version of the 10G/25G High Speed Ethernet Subsystem IP Core.

The Xilinx 10G Ethernet MAC and the 10G/25G High Speed Ethernet Subsystem core are both designed to the specifications of the Ethernet IEEE 802.3 standard. There are significant differences in how some features are designed and/or handled. There are also differences in signal and parameter names and the corresponding AXI registers. Note that this section only outlines the features in the legacy 10G EMAC IP and compares them with the new 10G/25G High Speed Ethernet Subsystem IP core. For a list of new features or features exclusive to the new IP, refer to Chapter 3: Product Specification.

The following features are different in the new 10G/25G High Speed Ethernet Subsystem IP.

- Padding: The Pad field is not added by the 10G/25G High Speed Ethernet Subsystem IP. You must present a packet that meets the minimum length to the IP core. When the IP core is configured to calculate and add the FCS to the packet (ctl\_tx\_fcs\_ins\_enable = 1), the minimum packet length is 60 bytes. If the FCS is calculated and added outside the IP core (ctl\_tx\_fcs\_ins\_enable = 0), the minimum packet length is 64 bytes.
- **IFG extension:** The inter-frame gap (IFG/IPG) can be extended up to 12B using the parameter ctl\_tx\_ipg\_value[2:0].
- **Deficit Idle Count (DIC):** The 10G/25G High Speed Ethernet IP has the DIC always enabled.
- Management Data Input/Output (MDIO) master: The 10G/25G High Speed Ethernet Subsystem IP does not provide an MDIO master. The contents of the appropriate MDIO registers are available in the status signals.



- Fault Handling: The user logic must be designed differently for TX faults. Legacy 10G EMAC TX transmits RF or idles and drops packets by default if LF/RF is received. An option to disable fault transmission is provided. 10G/25G High Speed Ethernet Subsystem IP requires you to control if LF/RF are transmitted. You must provide the fault status signals as well.
- VLAN: The new 10G/25G Ethernet Subsystem IP provides no VLAN specific features. However you can set the ctl\_rx\_max\_packet\_len attribute appropriately to allow the standard VLAN frame (1522 B) and also design the user logic to handle any number of stacked VLAN tags.
- Enabling Link Training without Auto-negotiation: On the legacy 10G IP, it appears that link training was always enabled (see below) whereas the 10G/25G High Speed Ethernet Subsystem IP performs link training after auto-negotiation and thus both features have to be enabled.
- Link Training Translation: The legacy 10-BaseKR subsystem included logic that allowed it to be trained by a far-end device without user interaction. This feature is not available in the 10G/25G High Speed Ethernet Subsystem IP and the user logic must be designed to support this feature.
- Standalone MAC with 64-bit internal XGMII interface for connecting to XAUI/RXAUI: The standalone MAC with the 64-bit internal XGMII interface is now available in 10G/25G High Speed Ethernet Subsystem v2.1 and later.
- External XGMII DDR interface to external PHY: The external XGMII DDR interface to the external PHY option is now available as part of the 64-bit standalone MAC in 10G/25G High Speed Ethernet IP v2.1 and later.
- Pause Interface: 10G/25G High Speed Ethernet Subsystem IP does not pause TX packet transmission when global pause frames are received this is left to user logic.

## **Port/Signal Comparison**

There are significant differences in the names and functions of the signals and parameters. Because it is difficult to draw a one-to-one comparison, the following tables are based on features and their presentation in the two IP cores.

#### **Transmitter Configuration**

The legacy XGEMAC used the  $mac_tx_configuration_vector[368:0]$  for all TX configuration whereas the 10G/25G High Speed Ethernet IP deploys various signals for the same purpose. The following table draws a comparison.

Table 328: Transmitter Configuration Comparison

| Feature                    | Legacy XGEMAC                        | 10/25G High Speed Ethernet IP |
|----------------------------|--------------------------------------|-------------------------------|
| Legacy Pause Refresh Value | mac_tx_configuration_vector[367:352] |                               |



*Table 328:* **Transmitter Configuration Comparison** *(cont'd)* 

| Feature                                  | Legacy XGEMAC                        | 10/25G High Speed Ethernet IP                                                       |
|------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------|
| TX Priority 7 Pause Quanta refresh value | mac_tx_configuration_vector[351:336] | ctl_tx_pause_refresh_timer7[15:0]                                                   |
| TX Priority 7 Pause Quanta               | mac_tx_configuration_vector[335:320] | ctl_tx_pause_quanta7[15:0]                                                          |
| TX Priority 6 Pause Quanta refresh value | mac_tx_configuration_vector[319:304] | ctl_tx_pause_refresh_timer6[15:0]                                                   |
| TX Priority 6 Pause Quanta               | mac_tx_configuration_vector[303:288] | ctl_tx_pause_quanta6[15:0]                                                          |
| TX Priority 5 Pause Quanta refresh value | mac_tx_configuration_vector[287:272] | ctl_tx_pause_refresh_timer5[15:0]                                                   |
| TX Priority 5 Pause Quanta               | mac_tx_configuration_vector[271:256] | ctl_tx_pause_quanta5[15:0]                                                          |
| TX Priority 4 Pause Quanta refresh value | mac_tx_configuration_vector[255:240] | ctl_tx_pause_refresh_timer4[15:0]                                                   |
| TX Priority 4 Pause Quanta               | mac_tx_configuration_vector[239:224] | ctl_tx_pause_quanta4[15:0]                                                          |
| TX Priority 3 Pause Quanta refresh value | mac_tx_configuration_vector[223:208] | ctl_tx_pause_refresh_timer3[15:0]                                                   |
| TX Priority 3 Pause Quanta               | mac_tx_configuration_vector[207:192] | ctl_tx_pause_quanta3[15:0]                                                          |
| TX Priority 2 Pause Quanta refresh value | mac_tx_configuration_vector[191:176] | ctl_tx_pause_refresh_timer2[15:0]                                                   |
| TX Priority 2 Pause Quanta               | mac_tx_configuration_vector[175:160] | ctl_tx_pause_quanta2[15:0]                                                          |
| TX Priority 1 Pause Quanta refresh value | mac_tx_configuration_vector[159:144] | ctl_tx_pause_refresh_timer1[15:0]                                                   |
| TX Priority 1 Pause Quanta               | mac_tx_configuration_vector[143:128] | ctl_tx_pause_quanta1[15:0]                                                          |
| TX Priority 0 Pause Quanta refresh value | mac_tx_configuration_vector[127:112] | ctl_tx_pause_refresh_timer0[15:0]                                                   |
| TX Priority 0 Pause Quanta               | mac_tx_configuration_vector[111:96]  | ctl_tx_pause_quanta0[15:0]                                                          |
| TX Priority 7 Flow Control Enable        | mac_tx_configuration_vector[95]      | ctl_tx_pause_enable[7]                                                              |
| TX Priority 6 Flow Control Enable        | mac_tx_configuration_vector[94]      | ctl_tx_pause_enable[6]                                                              |
| TX Priority 5 Flow Control Enable        | mac_tx_configuration_vector[93]      | ctl_tx_pause_enable[5]                                                              |
| TX Priority 4 Flow Control Enable        | mac_tx_configuration_vector[92]      | ctl_tx_pause_enable[4]                                                              |
| TX Priority 3 Flow Control Enable        | mac_tx_configuration_vector[91]      | ctl_tx_pause_enable[3]                                                              |
| TX Priority 2 Flow Control Enable        | mac_tx_configuration_vector[90]      | ctl_tx_pause_enable[2]                                                              |
| TX Priority 1 Flow Control Enable        | mac_tx_configuration_vector[89]      | ctl_tx_pause_enable[1]                                                              |
| TX Priority 0 Flow Control Enable        | mac_tx_configuration_vector[88]      | ctl_tx_pause_enable[0]                                                              |
| Auto XON enable                          | mac_tx_configuration_vector[81]      |                                                                                     |
| Priority flow control enable             | mac_tx_configuration_vector[80]      |                                                                                     |
| TX Pause Frame Source Address            | mac_tx_configuration_vector[79:32]   | ctl_tx_pause_da[47:0]                                                               |
| TX MTU Size                              | mac_tx_configuration_vector[30:16]   | Not required because the TX can handle any size frame presented to the IP.          |
| TX MTU enable                            | mac_tx_configuration_vector[14]      | Not applicable because there is no need to set the TX. MTU does not have to be set. |
| Deficit Idle Count Enable                | mac_tx_configuration_vector[10]      | Not supported                                                                       |



*Table 328:* **Transmitter Configuration Comparison** (cont'd)

| Feature                     | Legacy XGEMAC                  | 10/25G High Speed Ethernet IP                                                                                                                                                     |
|-----------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TX LAN/WAN mode             | mac_tx_configuration_vector[9] | This feature is not available as-is. The 10G/25G High Speed Ethernet IP always maintains the average IPG per the IEEE 802.3 spec.                                                 |
|                             |                                | However you can design the user logic to insert idles using ctl_send_idle and increase the IPG value using ctl_tx_ipg_value[3:0] to meet the OC-192 SONET requirements.           |
| TX IFG Adjust enable        | mac_tx_configuration_vector[8] | ctl_tx_ipg_value sets the appropriate value of the custom IPG/IFG                                                                                                                 |
| TX Preserve Preamble Enable | mac_tx_configuration_vector[7] | ctl_tx_custom_preamble_enable enables the use of a custom preamble. Tx_preamblein presents the custom preamble and rx_preambleout has the preamble field from the received frame. |
| TX Flow control Enable      | mac_tx_configuration_vector[5] | ctl_tx_pause_enable[8:0]                                                                                                                                                          |
| TX Jumbo Frame Enable       | mac_tx_configuration_vector[4] | Not required                                                                                                                                                                      |
| TX In-band FCS enable       | mac_tx_configuration_vector[3] | ctl_tx_fcs_ins_enable                                                                                                                                                             |
| TX VLAN enable              | mac_tx_configuration_vector[2] | Not required                                                                                                                                                                      |
| TX Enable                   | mac_tx_configuration_vector[1] | ctl_tx_enable                                                                                                                                                                     |
| TX Reset                    | mac_tx_configuration_vector[0] | tx_reset                                                                                                                                                                          |

#### **Receiver Configuration**

The legacy XGEMAC used the rx\_configuration\_vector[95:0] for all RX configuration whereas the 10G/25G High Speed Ethernet IP core deploys various signals for the same purpose. The following table draws a comparison.

**Table 329: Receiver Configuration Comparison** 

| Feature                                  | Legacy XGEMAC                  | 10/25G High Speed Ethernet IP                                                       |
|------------------------------------------|--------------------------------|-------------------------------------------------------------------------------------|
| RX Priority 7-0 Flow control enable      | rx_configuration_vector[95:88] | ctl_rx_pause_enable[8:0]                                                            |
| Priority Flow Control Enable             | rx_configuration_vector[80]    |                                                                                     |
| RX Pause Frame SA                        | rx_configuration_vector[79:32] | ctl_rx_pause_sa[47:0]                                                               |
| RX MTU size                              | rx_configuration_vector[30:16] | Set using ctl_rx_max_packet_len and ctl_rx_min_packet_len signals.                  |
| RX MTU Enable                            | rx_configuration_vector[14]    | Not required.                                                                       |
| Reconciliation Sublayer Fault<br>Inhibit | rx_configuration_vector[10]    | Design user logic to set ctl_tx_send_idle when RFI is received.                     |
| Control Frame Length check<br>Disable    | rx_configuration_vector[9]     | Not available                                                                       |
| RX Length/Type Error disable             | rx_configuration_vector[8]     | The length/type error cannot be disabled on the 10/25G High Speed Ethernet IP core. |
| RX preserve preamble enable              | rx_configuration_vector[7]     | ctl_rx_custom_preamble_enable                                                       |
| RX Flow control enable                   | rx_configuration_vector[5]     | ctl_rx_pause_enable[8:0]                                                            |



*Table 329:* **Receiver Configuration Comparison** *(cont'd)* 

| Feature               | Legacy XGEMAC              | 10/25G High Speed Ethernet IP                         |
|-----------------------|----------------------------|-------------------------------------------------------|
| RX Jumbo Frame Enable | rx_configuration_vector[4] | Set using the ctl_rx_max_packet_len signal.           |
| RX in-band FCS enable | rx_configuration_vector[3] | ctl_rx_delete_fcs                                     |
| RX VLAN enable        | rx_configuration_vector[2] | Up to the user logic to implement this functionality. |
| RX enable             | rx_configuration_vector[1] | ctl_rx_enable                                         |
| RX reset              | rx_configuration_vector[0] | rx_reset                                              |

#### **Status Vector**

**Table 330: Status Vector Comparison** 

| Feature         | Legacy XGEMAC    | 10/25G High Speed Ethernet IP  |
|-----------------|------------------|--------------------------------|
| Remote Fault RX | status_vector[1] | This feature is not available. |
| Local Fault RX  | status_vector[0] | This feature is not available. |

#### **TX Statistics**

The legacy XGEMAC used the  $tx_statistics_vector[25:0]$  for all TX statistics whereas the 10G/25G High Speed Ethernet IP core deploys various signals for the same purpose. The following table draws a comparison.

*Table 331:* **TX Statistics Comparison** 

| Feature                 | Legacy XGEMAC               | 10/25G High Speed Ethernet MAC                                           |
|-------------------------|-----------------------------|--------------------------------------------------------------------------|
| PFC Frame Transmitted   | tx_statistics_vector[26]    | stat_tx_user_pause                                                       |
| Pause Frame Transmitted | tx_statistics_vector[25]    | stat_tx_pause                                                            |
| Bytes Valid             | tx_statistics_vector[24:21] | stat_tx_total_good_bytes                                                 |
| VLAN Frame              | tx_statistics_vector[20]    | stat_tx_vlan                                                             |
| Frame length count      | tx_statistics_vector[19:5]  | stat_tx_packet_* signals that can also be used for the packet histogram. |
| Control Frame           | tx_statistics_vector[4]     |                                                                          |
| Underrun Frame          | tx_statistics_vector[3]     |                                                                          |
| Multicast Frame         | tx_statistics_vector[2]     | stat_tx_multicast                                                        |
| Broadcast Frame         | tx_statistics_vector[1]     | stat_tx_broadcast                                                        |
| Successful Frame        | tx_statistics_vector[0]     | stat_tx_total_good_packets                                               |
| TX statistics Valid     | tx_statistics_valid         | Not required                                                             |

#### **RX Statistics**

The legacy XGEMAC used the  $rx_statistics_vector[30:0]$  for all RX statistics whereas the 10G/25G High Speed Ethernet IP core deploys various signals for the same purpose. The following table draws a comparison.



**Table 332: RX Statistics Comparison** 

| Feature                  | Legacy XGEMAC               | 10/25G High Speed Ethernet MAC          |
|--------------------------|-----------------------------|-----------------------------------------|
| PFC Frame                | rx_statistics_vector[30]    | stat_rx_user_pause                      |
| Length/Type out of range | rx_statistics_vector[29]    | stat_rx_inrangeerr                      |
| Bad Opcode               | rx_statistics_vector[28]    |                                         |
| Flow Control Frame       | rx_statistics_vector[27]    | stat_rx_pause                           |
| Bytes Valid              | rx_statistics_vector[26:23] | stat_rx_total_bytes[3:0]                |
| VLAN Frame               | rx_statistics_vector[22]    | stat_rx_vlan                            |
| Out of Bounds            | rx_statistics_vector[21]    | stat_rx_toolong                         |
| Control Frame            | rx_statistics_vector[20]    |                                         |
| Frame Length Count       | rx_statistics_vector [19:5] | stat_rx_total_good_bytes [13:0]         |
| Multicast Frame          | rx_statistics_vector [4]    | stat_rx_multicast                       |
| Broadcast frame          | rx_statistics_vector [3]    | stat_rx_broadcast                       |
| FCS Error                | rx_statistics_vector [2]    | stat_rx_packet_bad_fcs                  |
| Bad frame                | rx_statistics_vector [1]    | stat_rx_total_good_packets sampled as 0 |
| Good Frame               | rx_statistics_vector [0]    | stat_rx_total_good_packets sampled as 1 |
| RX statistics Valid      | rx_statistics_valid         | Not required                            |

#### **Register Space**

Both the legacy XGEMAC and the 10/25G High Speed Ethernet IP core provide an AXI User Interface. While much of the configuration parameters are similar, the registers and the memory map of the registers are different between the two IP cores. The following sections discuss the comparison between the configuration, statistics and other registers.

#### **TX Configuration Registers**

**Table 333: TX Configuration Registers Comparison** 

| Feature                      | Legacy XGEMAC                                           | 10/25G HSEC                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TX MTU Size                  | @0x418: Transmitter<br>MTU Configuration<br>Word [14:0] | Not required because the TX can handle any size frame presented to the IP.                                                                                                                                                                                                                                                                                                                    |
| TX MTU enable                | @0x418: Transmitter<br>MTU Configuration<br>Word [16]   | Not applicable because there is no need to set the TX MTU.                                                                                                                                                                                                                                                                                                                                    |
| Deficit Idle Count<br>Enable | @0x408: Transmitter<br>Configuration<br>Word[24]        | Not supported                                                                                                                                                                                                                                                                                                                                                                                 |
| TX LAN/WAN mode              | @0x408: Transmitter<br>Configuration<br>Word[26]        | This feature is not available as-is. The 10G/25G High Speed Ethernet IP Subsystem always maintains the average IPG per the IEEE 802.3 spec.  However, you can design the user logic to insert idles using @0x000C: CONFIGURATION_TX_REG1[5] ctl_send_idle and increase the IPG value using @0x000C: CONFIGURATION_TX_REG1[13:10] ctl_tx_ipg_value[3:0] to meet the OC-192 SONET requirements. |



*Table 333:* **TX Configuration Registers Comparison** (cont'd)

| Feature                        | Legacy XGEMAC                                     | 10/25G HSEC                                                                                                                                                                                                        |
|--------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TX IFG Adjust<br>enable        | @0x408: Transmitter<br>Configuration<br>Word[25]  | @0x000C: CONFIGURATION_TX_REG1[13:10] ctl_tx_ipg_value sets the appropriate value of the custom IPG/IFG.                                                                                                           |
| TX Preserve<br>Preamble Enable | @0x408: Transmitter<br>Configuration<br>Word[23]  | @0x000C: CONFIGURATION_TX_REG1[18] ctl_tx_custom_preamble_enable enables the use of custom preamble. Tx_preamblein presents the custom preamble and rx_preambleout has the preamble field from the received frame. |
| TX Flow control<br>Enable      | @0x40C: Flow control Configuration register [30]  | ctl_tx_pause_enable[8:0]                                                                                                                                                                                           |
| TX Jumbo Frame<br>Enable       | @0x408: Transmitter<br>Configuration<br>Word[30]  | Not required.                                                                                                                                                                                                      |
| TX In-band FCS enable          | @0x408: Transmitter<br>Configuration<br>Word[29]  | @0x000C: CONFIGURATION_TX_REG1[1] ctl_tx_fcs_ins_enable                                                                                                                                                            |
| TX VLAN enable                 | @0x408: Transmitter<br>Configuration<br>Word[27]  | Not required.                                                                                                                                                                                                      |
| TX Enable                      | @0x408: Transmitter<br>Configuration Word<br>[28] | @0x000C: CONFIGURATION_TX_REG1[0] ctl_tx_enable                                                                                                                                                                    |
| TX Reset                       | @0x408: Transmitter<br>Configuration Word<br>[31] | @0x0004: RESET_REG[31] tx_reset                                                                                                                                                                                    |

## **RX Configuration**

**Table 334: RX Configuration Comparison** 

| Feature                                     | Legacy XGEMAC                                                                                   | 10/25G High Speed Ethernet IP Core                                                                                                        |
|---------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| RX Priority 7-0<br>Flow control<br>enable   | Bit 95:88                                                                                       | @0x0094: CONFIGURATION_RX_FLOW_CONTROL_REG1 [7:0]                                                                                         |
| Priority Flow<br>Control Enable             | Bit 80                                                                                          | Does not support legacy PFC                                                                                                               |
| RX Pause Frame<br>SA                        | @0x404: Receiver<br>Configuration Word<br>1[47:32], @0x400:<br>Receiver Configuration<br>Word 0 | @0x00C4: CONFIGURATION_RX_FLOW_CONTROL_SA_REG1_MSB[15:0], @0x00C0: CONFIGURATION_RX_FLOW_CONTROL_SA_REG1_LSB                              |
| RX MTU size                                 | @0x414: Receiver MTU<br>Configuration Word<br>[14:0]                                            | Set using @0x0018: CONFIGURATION_RX_MTU[30:16] ctl_rx_max_packet_len and @0x0018: CONFIGURATION_RX_MTU[7:0] ctl_rx_min_packet_len signals |
| RX MTU Enable                               | @0x414: Receiver MTU<br>Configuration Word<br>[16]                                              | Not required.                                                                                                                             |
| Reconciliation<br>Sublayer Fault<br>Inhibit | @0x410: Reconciliation<br>Sublayer Configuration<br>Word [27]                                   | Design user logic to set @0x000C: CONFIGURATION_TX_REG1[5] ctl_tx_send_idle when RFI is received                                          |



*Table 334:* **RX Configuration Comparison** (cont'd)

| Feature                                  | Legacy XGEMAC                                          | 10/25G High Speed Ethernet IP Core                                                    |
|------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------------------------------|
| Control Frame<br>Length check<br>Disable | @0x404: Receiver<br>Configuration Word<br>1[24]        | Not available                                                                         |
| RX Length/Type<br>Error disable          | @0x404: Receiver<br>Configuration Word<br>1[25]        | The length/type error cannot be disabled on the 10/25G High Speed Ethernet Subsystem. |
| RX preserve preamble enable              | @0x404: Receiver<br>Configuration Word<br>1[26]        | @0x0014: CONFIGURATION_RX_REG1[11] ctl_rx_custom_preamble_enable                      |
| RX Flow control enable                   | @0x40C: Flow Control<br>Configuration Register<br>[29] | @0x0094: CONFIGURATION_RX_FLOW_CONTROL[8:0] ctl_rx_pause_enable[8:0]                  |
| RX Jumbo Frame<br>Enable                 | @0x404: Receiver<br>Configuration Word<br>1[30]        | Set using ctl_rx_max_packet_len signal                                                |
| RX in-band FCS enable                    | @0x404: Receiver<br>Configuration Word<br>1[29]        | @0x0014: CONFIGURATION_RX_REG1[1] ctl_rx_delete_fcs                                   |
| RX VLAN enable                           | @0x404: Receiver<br>Configuration Word<br>1[27]        | Up to the user logic to implement this functionality                                  |
| RX enable                                | @0x404: Receiver<br>Configuration Word<br>1[28]        | @0x0014: CONFIGURATION_RX_REG1[0] ctl_rx_enable                                       |
| RX reset                                 | @0x404: Receiver<br>Configuration Word<br>1[31]        | @0x0004: RESET_REG[30] rx_reset                                                       |

#### **Status Vector**

*Table 335:* **Status Vector Comparison** 

| Feature         | Legacy XGEMAC                                          | 10/25G High Speed Ethernet IP  |
|-----------------|--------------------------------------------------------|--------------------------------|
| Remote Fault RX | @0x410: Reconciliation Sublayer Configuration Word[29] | This feature is not available. |
| Local Fault RX  | @0x410: Reconciliation Sublayer Configuration Word[28] | This feature is not available. |

#### **Statistics Counters**

The following table lists the different statistics counters and their addresses.

*Table 336:* **Statistics Counters** 

| Address<br>(Hex) | Register                | Register                | Address<br>(Hex) |
|------------------|-------------------------|-------------------------|------------------|
| 0x200            | Received Bytes (LSW)    | STAT_RX_TOTAL_BYTES_LSB | 0x0808           |
| 0x204            | Received Bytes (MSW)    | STAT_RX_TOTAL_BYTES_MSB | 0x080C           |
| 0x208            | Transmitted Bytes (LSW) | STAT_TX_TOTAL_BYTES_LSB | 0x0710           |
| 0x20C            | Transmitted Bytes (MSW) | STAT_TX_TOTAL_BYTES_MSB | 0x0714           |



Table 336: Statistics Counters (cont'd)

| Address<br>(Hex) | Register                                          | Register                           | Address<br>(Hex) |
|------------------|---------------------------------------------------|------------------------------------|------------------|
| 0x210            | Undersize Frames Received (LSW)                   | STAT_RX_UNDERSIZE _LSB             | 0x0898           |
| 0x214            | Undersize Frames Received (MSW)                   | STAT_RX_UNDERSIZE_MSB              | 0x089C           |
| 0x218            | Fragment Frames Received (LSW)                    | STAT_RX_FRAGMENT_LSB               | 0x08A0           |
| 0x21C            | Fragment Frames Received (MSW)                    | STAT_RX_FRAGMENT_MSB               | 0x08A4           |
| 0x220            | 64-byte frames received OK (LSW)                  | STAT_RX_PACKET_64_BYTES_LSB        | 0x0828           |
| 0x224            | 64-byte frames received OK (MSW)                  | STAT_RX_PACKET_64_BYTES_MSB        | 0x082C           |
| 0x228            | 65-127 byte frames received OK (LSW)              | STAT_RX_PACKET_65_127_BYTES_LSB    | 0x0830           |
| 0x22C            | 65-127 byte frames received OK (MSW)              | STAT_RX_PACKET_65_127_BYTES_MSB    | 0x0834           |
| 0x230            | 128-255 byte frames received OK (LSW)             | STAT_RX_PACKET_128_255_BYTES_LSB   | 0x0838           |
| 0x234            | 128-255 byte frames received OK (MSW)             | STAT_RX_PACKET_128_255_BYTES_MSB   | 0x083C           |
| 0x238            | 256-511 byte frames received OK (LSW)             | STAT_RX_PACKET_256_511_BYTES_LSB   | 0x0840           |
| 0x23C            | 256-511 byte frames received OK (MSW)             | STAT_RX_PACKET_256_511_BYTES_MSB   | 0x0844           |
| 0x240            | 512-1023 byte frames received OK (LSW)            | STAT_RX_PACKET_512_1023_BYTES_LSB  | 0x0848           |
| 0x244            | 512-1023 byte frames received OK (MSW)            | STAT_RX_PACKET_512_1023_BYTES_MSB  | 0x084C           |
| 0x248            | 1024 – MaxFrameSize byte frames received OK (LSW) | STAT_RX_PACKET_1024_1518_BYTES_LSB | 0x0850           |
|                  |                                                   | STAT_RX_PACKET_1519_1522_BYTES_LSB | 0x0858           |
|                  |                                                   | STAT_RX_PACKET_1523_1548_BYTES_LSB | 0x0860           |
|                  |                                                   | STAT_RX_PACKET_1549_2047_BYTES_LSB | 0x0868           |
|                  |                                                   | STAT_RX_PACKET_2048_4095_BYTES_LSB | 0x0870           |
|                  |                                                   | STAT_RX_PACKET_4096_8191_BYTES_LSB | 0x0878           |
|                  |                                                   | STAT_RX_PACKET_8192_9215_BYTES_LSB | 0x0880           |
|                  |                                                   | STAT_RX_PACKET_LARGE_LSB           | 0x0888           |
| 0x24C            | 1024 – MaxFrameSize byte frames                   | STAT_RX_PACKET_1024_1518_BYTES_MSB | 0x0854           |
|                  | received OK (MSW)                                 | STAT_RX_PACKET_1519_1522_BYTES_MSB | 0x085C           |
|                  |                                                   | STAT_RX_PACKET_1523_1548_BYTES_MSB | 0x0864           |
|                  |                                                   | STAT_RX_PACKET_1549_2047_BYTES_MSB | 0x086C           |
|                  |                                                   | STAT_RX_PACKET_2048_4095_BYTES_MSB | 0x0874           |
|                  |                                                   | STAT_RX_PACKET_4096_8191_BYTES_MSB | 0x087C           |
|                  |                                                   | STAT_RX_PACKET_8192_9215_BYTES_MSB | 0x0884           |
|                  |                                                   | STAT_RX_PACKET_LARGE_MSB           | 0x088C           |
| 0x250            | Oversize frames received OK (LSW)                 | STAT_RX_OVERSIZE_LSB               | 0x08A8           |
| 0x254            | Oversize frames received OK (MSW)                 | STAT_RX_OVERSIZE_MSB               | 0x08AC           |
| 0x258            | 64-byte frames transmitted OK (LSW)               | STAT_TX_PACKET_64_BYTES_LSB        | 0x0720           |
| 0x25C            | 64-byte frames transmitted OK (MSW)               | STAT_TX_PACKET_64_BYTES_MSB        | 0x0724           |
| 0x260            | 65-127 byte frames transmitted OK (LSW)           | STAT_TX_PACKET_65_127_BYTES_LSB    | 0x0728           |
| 0x264            | 65-127 byte frames transmitted OK (MSW)           | STAT_TX_PACKET_65_127_BYTES_MSB    | 0x072C           |
| 0x268            | 128-255 byte frames transmitted OK (LSW)          | STAT_TX_PACKET_128_255_BYTES_LSB   | 0x0730           |



Table 336: Statistics Counters (cont'd)

| Address<br>(Hex) | Register                                                | Register                           | Address<br>(Hex) |
|------------------|---------------------------------------------------------|------------------------------------|------------------|
| 0x26C            | 128-255 byte frames transmitted OK (MSW)                | STAT_TX_PACKET_128_255_BYTES_MSB   | 0x0734           |
| 0x270            | 256-511 byte frames transmitted OK (LSW)                | STAT_TX_PACKET_256_511_BYTES_LSB   | 0x0738           |
| 0x274            | 256-511 byte frames transmitted OK (MSW)                | STAT_TX_PACKET_256_511_BYTES_MSB   | 0x073C           |
| 0x278            | 512-1023 byte frames transmitted OK (LSW)               | STAT_TX_PACKET_512_1023_BYTES_LSB  | 0x0740           |
| 0x27C            | 512-1023 byte frames transmitted OK (MSW)               | STAT_TX_PACKET_512_1023_BYTES_MSB  | 0x0744           |
| 0x280            | 1024 - MaxFrameSize byte frames                         | STAT_TX_PACKET_1024_1518_BYTES_LSB | 0x0748           |
|                  | transmitted OK (LSW)                                    | STAT_TX_PACKET_1519_1522_BYTES_LSB | 0x0750           |
|                  |                                                         | STAT_TX_PACKET_1523_1548_BYTES_LSB | 0x0758           |
|                  |                                                         | STAT_TX_PACKET_1549_2047_BYTES_LSB | 0x0760           |
|                  |                                                         | STAT_TX_PACKET_2048_4095_BYTES_LSB | 0x0768           |
|                  |                                                         | STAT_TX_PACKET_4096_8191_BYTES_LSB | 0x0770           |
|                  |                                                         | STAT_TX_PACKET_8192_9215_BYTES_LSB | 0x0778           |
|                  |                                                         | STAT_TX_PACKET_LARGE_LSB           | 0x0780           |
| 0x284            | 1024 – MaxFrameSize byte frames<br>transmitted OK (MSW) | STAT_TX_PACKET_1024_1518_BYTES_MSB | 0x074C           |
|                  |                                                         | STAT_TX_PACKET_1519_1522_BYTES_MSB | 0x0754           |
|                  |                                                         | STAT_TX_PACKET_1523_1548_BYTES_MSB | 0x075C           |
|                  |                                                         | STAT_TX_PACKET_1549_2047_BYTES_MSB | 0x0764           |
|                  |                                                         | STAT_TX_PACKET_2048_4095_BYTES_MSB | 0x076C           |
|                  |                                                         | STAT_TX_PACKET_4096_8191_BYTES_MSB | 0x0774           |
|                  |                                                         | STAT_TX_PACKET_8192_9215_BYTES_MSB | 0x077C           |
|                  |                                                         | STAT_TX_PACKET_LARGE_MSB           | 0x0784           |
| 0x288            | Oversize frames transmitted OK (LSW)                    | N/A                                |                  |
| 0x28C            | Oversize frames transmitted OK (MSW)                    |                                    |                  |
| 0x290            | Frames received OK (LSW)                                | STAT_RX_TOTAL_GOOD_PACKETS_LSB     | 0x0810           |
| 0x294            | Frames received OK (MSW)                                | STAT_RX_TOTAL_GOOD_PACKETS_MSB     | 0x0814           |
| 0x298            | Frame Check Sequence Error (LSW)                        | STAT_RX_PACKET_BAD_FCS_LSB         | 0x08C8           |
| 0x29C            | Frame Check Sequence Error (MSW)                        | STAT_RX_PACKET_BAD_FCS_MSB         | 0x08CC           |
| 0x2A0            | Broadcast Frames received OK (LSW)                      | STAT_RX_BROADCAST_LSB              | 0x8E8            |
| 0x2A4            | Broadcast Frames received OK (MSW)                      | STAT_RX_BROADCAST_MSB              | 0x8EC            |
| 0x2A8            | Multicast Frames received OK (LSW)                      | STAT_RX_MULTICAST_LSB              | 0x08E0           |
| 0x2AC            | Multicast Frames received OK (MSW)                      | STAT_RX_MULTICAST_MSB              | 0x08E4           |
| 0x2B0            | Control Frames received OK (LSW)                        |                                    |                  |
| 0x2B4            | Control Frames received OK (MSW)                        |                                    |                  |
| 0x2B8            | Length/Type out of range (LSW)                          | STAT_RX_INRANGEERR_LSB             | 0x0908           |
| 0x2BC            | Length/Type out of range (MSW)                          | STAT_RX_INRANGEERR_MSB             | 0x090C           |
| 0x2C0            | VLAN tagged frames received OK (LSW)                    | STAT_RX_VLAN_LSB                   | 0x08F0           |



Table 336: Statistics Counters (cont'd)

| Address<br>(Hex) | Register                                              | Register                       | Address<br>(Hex) |
|------------------|-------------------------------------------------------|--------------------------------|------------------|
| 0x2C4            | VLAN tagged frames received OK (MSW)                  | STAT_RX_VLAN_MSB               | 0x08F4           |
| 0x2C8            | PAUSE frames received OK (LSW)                        | STAT_RX_PAUSE_LSB              | 0x08F8           |
| 0x2CC            | PAUSE frames received OK (MSW)                        | STAT_RX_PAUSE_MSB              | 0x08FC           |
| 0x2D0            | Control frames received with unsupported opcode (LSW) |                                |                  |
| 0x2D4            | Control frames received with unsupported opcode (MSW) |                                |                  |
| 0x2D8            | Frames transmitted OK (LSW)                           | STAT_TX_TOTAL_GOOD_PACKETS_LSB | 0x0708           |
| 0x2DC            | Frames transmitted OK (MSW)                           | STAT_TX_TOTAL_GOOD_PACKETS_MSB | 0x070C           |
| 0x2E0            | Broadcast Frames transmitted OK (LSW)                 | STAT_TX_BROADCAST_LSB          | 0x07E0           |
| 0x2E4            | Broadcast Frames transmitted OK (MSW)                 | STAT_TX_BROADCAST_MSB          | 0x07E4           |
| 0x2E8            | Multicast Frames transmitted OK (LSW)                 | STAT_TX_MULTICAST_LSB          | 0x07D8           |
| 0x2EC            | Multicast Frames transmitted OK (MSW)                 | STAT_TX_MULTICAST_MSB          | 0x07DC           |
| 0x2F0            | Underrun errors (LSW)                                 |                                |                  |
| 0x2F4            | Underrun errors (MSW)                                 |                                |                  |
| 0x2F8            | Control Frames transmitted OK (LSW)                   |                                |                  |
| 0x2FC            | Control Frames transmitted OK (MSW)                   |                                |                  |
| 0x300            | VLAN tagged frames transmitted OK (LSW)               | STAT_TX_VLAN_LSB               | 0x07E8           |
| 0x304            | VLAN tagged frames transmitted OK (MSW)               | STAT_TX_VLAN_MSB               | 0x07EC           |
| 0x308            | PAUSE frames transmitted OK (LSW)                     | STAT_TX_PAUSE_LSB              | 0x07F0           |
| 0x30C            | PAUSE frames transmitted OK (MSW)                     | STAT_TX_PAUSE_MSB              | 0x07F4           |

#### **Pause Processing**

The following section outlines the configuration for priority based flow control.

**Table 337: Pause Processing** 

| Address<br>(Hex) | Register                      | Register                                          | Address<br>(Hex) |
|------------------|-------------------------------|---------------------------------------------------|------------------|
| 0x480            | Priority 0 Quanta<br>Register | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG1 [15:0]  | 0x0058           |
| 0x484            | Priority 1 Quanta<br>Register | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG1 [31:16] | 0x0058           |
| 0x488            | Priority 2 Quanta<br>Register | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG2 [15:0]  | 0x005C           |
| 0x48C            | Priority 3 Quanta<br>Register | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG2 [31:16] | 0x005C           |
| 0x490            | Priority 4 Quanta<br>Register | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG3 [15:0]  | 0x0060           |



Table 337: Pause Processing (cont'd)

| Address<br>(Hex) | Register                         | Register                                          | Address<br>(Hex) |
|------------------|----------------------------------|---------------------------------------------------|------------------|
| 0x494            | Priority 5 Quanta<br>Register    | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG3 [31:16] | 0x0060           |
| 0x498            | Priority 6 Quanta<br>Register    | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG4 [15:0]  | 0x0064           |
| 0x49C            | Priority 7 Quanta<br>Register    | CONFIGURATION_TX_FLOW_CONTROL_QUANTA_REG4 [31:16] | 0x0064           |
| 0x4A0            | Legacy Pause Refresh<br>Register | Does not support Legacy PFC                       |                  |

#### **MDIO Control Registers**

The 10G/25G High Speed Ethernet IP does not provide an MDIO station master and thus does not have any of the MDIO control registers.

#### **Interrupt Registers**

Typically interrupts are generated after an MDIO operation to indicate completion; because there is no MDIO master there are no interrupt registers.

#### **PCS/PMA MDIO register map**

Again, because there is no MDIO interface provided, there are no MDIO registers for the PCS/PMA interface.

#### **AXI4-Stream Interface**

The 10G/25G High Speed Ethernet IP Subsystem provides both 64-bit and 32-bit AXI4-Stream interfaces for the datapath as does the Legacy 10G Ethernet IP Subsystem. Note the following difference in the use of tuser bits on the RX interface. The table below compares the definitions of the tuser signals on both TX and RX.

Table 338: Comparison of the Definitions of the tuser Signals in Both TX and RX

| Signal               | Legacy XGEMAC                                                                                                                                | 10/25G High Speed Ethernet IP                                                                                                               |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| RX AXI4-Stream tuser | m_axis_rx_tuser AXI4-Stream User Sideband interface. 0 indicates a bad packet has been received. 1 indicates a good packet has been received | rx_axis_tuser AXI4-Stream User Sideband interface. 1 indicates a bad packet has been received. 0 indicates a good packet has been received. |
| TX AXI4-Stream tuser | s_axis_tx_tuser<br>AXI4-Stream user signal used to indicate<br>explicit underrun                                                             | tx_axis_tuser AXI4-Stream User Sideband interface. 1 indicates a bad packet has been received. 0 indicates a good packet has been received. |





# Debugging

This appendix includes details about resources available on the Xilinx Support website and debugging tools.



**TIP:** If the IP generation halts with an error, there might be a license issue. See <u>License Checkers</u> for more details.

# Finding Help on Xilinx.com

To help in the design and debug process when using the subsystem, the Xilinx Support web page contains key resources such as product documentation, release notes, answer records, information about known issues, and links for obtaining further product support. The Xilinx Community Forums are also available where members can learn, participate, share, and ask questions about Xilinx solutions.

## **Documentation**

This product guide is the main document associated with the subsystem. This guide, along with documentation related to all products that aid in the design process, can be found on the Xilinx Support web page or by using the Xilinx® Documentation Navigator. Download the Xilinx Documentation Navigator from the Downloads page. For more information about this tool and the features available, open the online help after installation.

## **Solution Centers**

See the Xilinx Solution Centers for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

Refer to the Xilinx Ethernet IP Solution Center.



#### **Answer Records**

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.

Answer Records for this subsystem can be located by using the Search Support box on the main Xilinx support web page. To maximize your search results, use keywords such as:

- Product name
- Tool message(s)
- · Summary of the issue encountered

A filter search is available after results are returned to further target the results.

### Master Answer Record for the Core

AR: 64710

## **Technical Support**

Xilinx provides technical support on the Xilinx Community Forums for this LogiCORE™ IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To ask questions, navigate to the Xilinx Community Forums.

# **Debug Tools**

There are many tools available to address 10G/25G Ethernet Subsystem design issues. It is important to know which tools are useful for debugging various situations.



## **Vivado Design Suite Debug Feature**

The Vivado® Design Suite debug feature inserts logic analyzer and virtual I/O cores directly into your design. The debug feature also allows you to set trigger conditions to capture application and integrated block port signals in hardware. Captured signals can then be analyzed. This feature in the Vivado IDE is used for logic debugging and validation of a design running in Xilinx® devices.

The Vivado logic analyzer is used to interact with the logic debug LogiCORE IP cores, including:

- ILA 2.0 (and later versions)
- VIO 2.0 (and later versions)

See the Vivado Design Suite User Guide: Programming and Debugging (UG908).

#### **Reference Boards**

Various Xilinx development boards support the 10G/25G Ethernet Subsystem. These boards can be used to prototype designs and establish that the core can communicate with the system.

- UltraScale FPGA evaluation boards:
  - VCU107
  - VCU108

# **Simulation Debug**

## **Simulator License Availability**

If the simulator does not launch, you might not have a valid license. Ensure that the license is up to date. It is also possible that your organization has a license available for one of the other simulators, so try all the provided scripts.

## **Slow Simulation**

Simulations can appear to run slowly under some circumstances. If a simulation is unacceptably slow, the following suggestions might improve the run-time performance.

- Use a faster computer with more memory.
- Make use of a Platform Load Sharing Facility (LSF) if available in your organization.



- Bypass the Xilinx transceiver (this might require that the customer create their own test bench).
- Send fewer packets.
- If using the example design, see Simulation Speed Up to speed up wait timers in the example design.

## **Simulation Fails Before Completion**

If the sample simulation fails or hangs before successfully completing, it is possible that a timeout has occurred. Ensure that the simulator timeouts are long enough to accommodate the waiting periods in the simulation, for example during the lane alignment phase.

## **Simulation Completes But Fails**

If the sample simulation completes with a failure, contact Xilinx technical support. Each release is tested prior to shipment and normally completes successfully. Consult the sample simulation log file for the expected behavior.

The simulation debug flow for Questa® Advanced Simulator is illustrated in the following figure. A similar approach can be used with other simulators.



Figure 66: Mentor Graphics Questa Advanced Simulator Simulation Debug Flow





# **Hardware Debug**

Hardware issues can range from link bring-up to problems seen after hours of testing. This section provides debug steps for common issues. The Vivado debug feature is a valuable resource to use in hardware debug. The signal names mentioned in the following individual sections can be probed using the debug feature for debugging the specific problems.

#### **General Checks**

Ensure that all the timing constraints for the core were properly incorporated from the example design and that all constraints were met during implementation.

- Does it work in post-place and route timing simulation? If problems are seen in hardware but not in timing simulation, this could indicate a PCB issue. Ensure that all clock sources are active and clean.
- If using mixed-mode clock managers (MMCMs) in the design, ensure that all MMCMs have obtained lock by monitoring the LOCKED port.
- If your outputs go to 0, check your licensing.

## **Timing**

Ensure that timing is met according to the Vivado tools before attempting to implement the IP in hardware.

## **Transceiver Specific Checks**

- Ensure that the polarities of the txn/txp and rxn/rxp lines are not reversed. If they are, these can be fixed by using the TXPOLARITY and RXPOLARITY ports of the transceiver.
- Check that the transceiver is not being held in reset or still being initialized. The RESETDONE outputs from the transceiver indicate when the transceiver is ready.
- Place the transceiver into parallel or serial near-end loopback.
- If correct operation is seen in the transceiver serial loopback, but not when loopback is performed through an optical cable, it might indicate a faulty optical module.
- If the core exhibits correct operation in the transceiver parallel loopback but not in serial loopback, this might indicate a transceiver issue.
- A mild form of bit error rate might be solved by adjusting the transmitter Pre-Emphasis and Differential Swing Control attributes of the transceiver.



# **Ethernet Specific Checks**

A number of issues can commonly occur during the first hardware test of an 10G/25G High Speed Ethernet Subsystem. These should be checked as indicated below.

It is assumed that the 10G/25G Ethernet Subsystem has already passed all simulation testing which is being implemented in hardware. This is a pre-requisite for any kind of hardware debug.

The usual sequence of debugging is to proceed in the following sequence:

- 1. Clean up signal integrity.
- 2. Ensure that the SerDes achieves clock data recovery (CDR) lock.
- 3. Check that the 10G/25G Ethernet Subsystem IP has achieved word sync.
- 4. Proceed to Interface and Protocol debug.

# **Signal Integrity**

When bringing up a board for the first time and the 10G/25G Ethernet Subsystem does not seem to be achieving word sync, the most likely problem is related to signal integrity. Signal integrity issues must be addressed before any other debugging can take place.

Signal integrity should be debugged independently from the 10G/25G Ethernet Subsystem. The following procedures should be carried out. (Note that it assumed that the PCB itself has been designed and manufactured in accordance with the required trace impedances and trace lengths, including the requirements for skew set out in the IEEE 802.3 specification.)

- Transceiver Settings
- Checking For Noise
- Bit Error Rate Testing

If assistance is required for transceiver and signal integrity debugging, contact Xilinx technical support.

# N/P Swapping

If the positive and negative signals of a differential pair are swapped, then data cannot be correctly received on that lane. You should verify that the link has the correct polarity of each differential pair.

# **Clocking and Resets**

Refer to the Clocking and Resets for these requirements.



Ensure that the clock frequencies for both the 10G/25G Ethernet Subsystem as well as the Xilinx Transceiver reference clock match the configuration requested when the subsystem was ordered. The core clock has a minimum frequency associated with it. The maximum core clock frequency is determined by timing constraints. The minimum core clock frequency is derived from the required Ethernet bandwidth plus the margin reserved for clock tolerance, wander and jitter.

The first thing to verify during debugging is to ensure that resets remain asserted until the clock is stable. It must be frequency-stable as well as free from glitches before the 10G/25G Ethernet Subsystem is taken out of reset. This applies to both the SerDes clock as well as the core clock.

If any subsequent instability is detected in a clock, the 10G/25G Ethernet Subsystem must be reset. One example of such instability is a loss of CDR lock. The user logic should determine all external conditions which would require a reset (e.g. clock glitches, loss of CDR lock, power supply glitches, etc.).

The GT requires a GTRXRESET after the serial data becomes valid to ensure correct CDR lock to the data. This is required after powering on, resetting or reconnecting the link partner. At the core level to avoid interruption on the TX side of the link, the reset can be triggered using gtwiz\_reset\_rx\_datapath. If available, signal detect or inversion of loss of signal from the optics can be used to trigger the reset. If signal detect or loss of signal are not available, timeout logic can be added to monitor if alignment has not completed and issue the gtwiz\_reset\_rx\_datapath reset.

Configuration changes cannot be made unless the subsystem is reset. An example of a configuration change would be setting a different maximum packet length. Check the description for the particular signal on the port list to determine if this requirement applies to the parameter that is being changed.

# RX Debug

Consult the port list section for a description of the diagnostic signals which are available to debug the RX.

#### stat\_rx\_block\_lock

This signal indicates that the receiver has detected and locked to the word boundaries as defined by a 01 or 10 control or data header. This is the first step to ensure that the 10G/25G Ethernet Subsystem IP is functioning normally.



**CAUTION!** Under some conditions of no signal input, the SerDes receiver exhibits a steady pattern of alternating 1010101.... This can cause erroneous block lock, but still indicates that the receiver has detected the pattern.



#### stat\_rx\_bad\_fcs

A bad FCS indicates a bit error in the received packet. An FCS error could be due to any number of causes of packet corruption such as noise on the line.

#### stat\_rx\_local\_fault

A local fault indication can be locally generated or received. Some causes of a local fault are:

- block lock not complete
- high bit error rate
- overflow or underflow

#### **Loopback Check**

If the Ethernet packets are being transmitted properly according to IEEE Std. 802.3, there should not be RX errors. However, the signal integrity of the received signals must be verified first.

To aid in debug, a local loopback can be performed with the signal  $ctl_local_loopback$  when the Include AXI4-Lite enable option is selected; otherwise, a local loopback is performed with signal  $gt_loopback_in$  for a non-AXI4-Lite configuration. This connects the TX SerDes to the RX SerDes, effectively bypassing potential signal integrity problems. The transceiver is placed into "PMA loopback", which is fully described in the transceiver product guide. In this way, the received data can be checked against the transmitted packets to verify that the logic is operating properly

# **TX Debug**

If bad packets are received at link partner, but no errors are seen during long idle sequences, this can point to malformed packets on the TX AXI interface input. Check whether packets are not being underrun. An explicit underrun is issued by asserting  $tx_axis_tuser$  High while  $tx_axis_tuser$  High. An implicit underrun causes a frame transfer to be aborted when the  $tx_axis_tvalid$  is deasserted without asserting  $tx_axis_tuser$ . Underrun packets will be transmitted with a block of errors (0xFE).

# **Protocol Interface Debug**

To achieve error-free data transfers with the 10G/25G Ethernet Subsystem, the 802.3 specification should be followed. Note that signal integrity should always be ensured before proceeding to the protocol debug.



# **Diagnostic Signals**

There are many error indicators available to check for protocol violations. Carefully read the description of each one to see if it is useful for a particular debugging problem.

The following is a suggested debug sequence:

- 1. Ensure that Word sync has been achieved.
- 2. Make sure there are no descrambler state errors.
- 3. Eliminate CRC32 errors, if any.
- 4. Make sure the protocol is being followed correctly.
- 5. Ensure that there are no overflow or underflow conditions when packets are sent.

#### **Statistics Counters**

After error-free communication has been achieved, the statistics indicators can be monitored to ensure that traffic characteristics meet expectations. Note that some signals are strobes only, which means that the counters are not part of the subsystem. This is done so that the counter size can be customized. Counters are optionally available with the AXI interface.

# **Debugging Auto-Negotiation and Link Training**

#### **Auto-Negotiation**

To enable auto-negotiation:

- ctl\_autoneg\_enable = 1
- ctl\_autoneg\_bypass = 0

Set ctl\_an\_\* to advertise desired auto-negotiation settings.

When using the control and status interface the example design ties off the <code>ctl\_an\_\*</code> values to valid settings. If using the register interface see Board Testing Steps for Auto-Negotiation and Link Training Using AXI4-Lite Interface for the register sequence.

#### **Link Training**

To enable link training set ctl\_lt\_training\_enable to 1.

• The core does not actually do any training. It only provides the control protocol required by section 72.6.10. The training algorithm is a user responsibility.



- The core does not monitor the RX eye nor does it send any presets, initializations, or coefficient control requests to the link partner TX. It is recommended to set ctl\_lt\_rx\_trained to 1. Setting ctl\_lt\_rx\_trained tells the link partner that your RX training is completed, and that you will not be sending any more presets, initializations, or coefficient changes.
- The core does not adjust any of the GT TX amplitude or coefficient control settings in response to any training messages received from the link partner. The example design link training Place\_Holder logic will indicate that maximum limits have been reached. This should allow link training to complete.

#### Nonce

nonce\_seed must be set to a non-zero value.

- If connecting two ports with same nonce seed on the same board, resets must be released at different times.
- If the nonce\_seed is changed, an an\_reset is needed to load the new value. This includes changing nonce\_seed using the AXI4-Lite registers.

#### **Next Pages**

If the link partner sends next page,  $ctl_an_loc_np_ack$  must be set High to acknowledge the next page and allow auto-negotiation to complete. This control signal can be set High after next page is received or tied always High.

#### **Details on Stages and Status Signals**

- 1. At the start of auto-negotiation there is a TX disable state where no data is seen to ensure that the link is down on both sides. The stat\_an\_stat\_tx\_disable signal toggles for one cycle to indicate the start of this stage.
- 2. Following the TX disable state, auto-negotiation information is exchanged. During this stage stat\_an\_rxcdrhold is held High. The stat\_an\_lp\_autoneg\_able and stat\_an\_lp\_ability\_valid signals will toggle High for one clock cycle to indicate when stat\_an\_lp\* information is valid.
- 3. The stat\_an\_start\_an\_good\_check signal toggles High for one cycle at the start of link training. The stat\_an\_rxcdrhold signal is deasserted and gtwiz\_reset\_rx\_datapath toggled. After link training starts there is a 500 ms timer for training and block lock/link up in mission mode/normal PCS operation to complete or auto-negotiation will restart. The stat\_lt\_frame\_lock signal goes High and stat\_lt\_rx\_sof toggles when the link training block has achieved frame synchronization. The stat\_lt\_rx\_sof signal continues to toggle High for one clock duration at the training frame boundary.
- 4. When link training completes the stat\_lt\_signal\_detect signal asserts and indicates the start of normal PCS operation.



- 5. The an\_autoneg\_complete signal goes High when block lock, synchronization and alignment (if multi-lane core), stat\_rx\_status and stat\_rx\_valid\_ctrl\_code (stat\_rx\_valid\_ctrl\_code is only applicable to single lane 10G/25G core) go High.
- 6. The an\_autoneg\_complete signal must go High within the 500 ms timeout or autonegotiation will restart. If stat\_rx\_status goes back Low at any time then autonegotiation restarts.

#### Simulation and Loopback

Auto-Negotiation TX disable state takes 50 ms of simulation time to complete. Use SIM\_SPEED\_UP option without pre-compiled IP libraries to speed up the wait time. See AR 73518 for more information on turning off pre-compiled libraries.

Auto-negotiation will not complete in loopback because auto-negotiation requires that the nonce value received from the link partner must be different than the nonce value sent to the link partner.

Starting signal list to add to ILA for debug:

- sys\_reset
- an\_reset
- ctl\_an\_\*
- ctl\_lt\_\*
- stat an start tx disable
- stat\_an\_rxcdrhold
- stat\_an\_lp\_autoneg\_able
- stat an lp ability valid
- stat\_an\_start\_an\_good\_check
- stat\_lt\_frame\_lock
- stat\_lt\_signal\_detect
- stat\_lt\_link\_training
- stat\_lt\_link\_training\_fail
- stat\_rx\_block\_lock
- stat\_rx\_synced (only available on multi-lane cores)
- stat\_rx\_aligned (only available on mult-lane cores)
- stat\_rx\_valid\_ctrl\_code (only available on 10G/25G core)
- stat rx status
- stat\_rx\_bad\_code
- stat rx hi ber

If using line rate that supports Clause 74 Firecode FEC:

stat\_fec\_inc\_cant\_correct\_count



- stat\_fec\_lock\_error
- stat\_fec\_rx\_lock
- stat\_fec\_inc\_correct\_count
- ctl\_an\_fec\_10g\_request
- ctl\_fec\_rx\_enable
- ctl\_fec\_tx\_enable
- stat\_an\_fec\_enable
- stat\_an\_lp\_fec\_10g\_ability
- stat\_an\_lp\_fec\_10g\_request

If using line rate that supports RS-FEC:

- ctl\_tx\_rsfec\_enable
- ctl\_rx\_rsfec\_enable
- stat\_rx\_rsfec\_am\_lock
- stat\_an\_rs\_fec\_enable

**Note:** If the link partner sends next pages, the  $ctl_an_lo_np_ack$  signal must be set. This port can be tied High.

# Debugging Auto-Negotiation and Link Training Using the AXI4-Lite Interface

To debug auto-negotiation and link training using the AXI4-Lite interface, see Board Testing Steps for Auto-Negotiation and Link Training Using AXI4-Lite Interface.





# Additional Resources and Legal Notices

# Xilinx Resources

For support resources such as Answers, Documentation, Downloads, and Forums, see Xilinx Support.

# **Documentation Navigator and Design Hubs**

Xilinx® Documentation Navigator (DocNav) provides access to Xilinx documents, videos, and support resources, which you can filter and search to find information. To open DocNav:

- From the Vivado<sup>®</sup> IDE, select Help → Documentation and Tutorials.
- On Windows, select Start → All Programs → Xilinx Design Tools → DocNav.
- At the Linux command prompt, enter docnav.

Xilinx Design Hubs provide links to documentation organized by design tasks and other topics, which you can use to learn key concepts and address frequently asked questions. To access the Design Hubs:

- In DocNav, click the **Design Hubs View** tab.
- On the Xilinx website, see the Design Hubs page.

Note: For more information on DocNay, see the Documentation Navigator page on the Xilinx website.



# References

These documents provide supplemental material useful with this product guide:

- 1. 25/50G Gigabit Ethernet Consortium Schedule 3 (v1.6) (https://25gethernet.org/)
- 2. *IEEE Standard for Ethernet* (*IEEE Std 802.3-2015*)
- 3. IEEE Standard for Ethernet Amendment 2: Media Access Control Parameters, Physical Layers, and Management Parameters for 25 Gb/s Operation (IEEE Std 802.3by)
- 4. Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- 5. Vivado Design Suite User Guide: Designing with IP (UG896)
- 6. Vivado Design Suite User Guide: Getting Started (UG910)
- 7. Vivado Design Suite User Guide: Logic Simulation (UG900)
- 8. Vivado Design Suite User Guide: Programming and Debugging (UG908)
- 9. Vivado Design Suite User Guide: Implementation (UG904)
- 10. Vivado Design Suite: AXI Reference Guide (UG1037)
- 11. IEEE 1588 Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems (IEEE 1588)
- 12. IEEE Standard for Local and Metropolitan Area Networks Time Sensitive Networking for Fronthaul (IEEE Std 802.1CM-2018)
- 13. 25G IEEE 802.3by Reed-Solomon Forward Error Correction LogiCORE IP Product Guide (PG217) (registration required)
- 14. UltraScale Architecture GTH Transceivers User Guide (UG576)
- 15. UltraScale Architecture GTY Transceivers User Guide (UG578)
- 16. Vivado Design Suite User Guide: Using Constraints (UG903)
- 17. Vivado Design Suite Tutorial: Designing IP Subsystems Using IP Integrator (UG995)

# **Revision History**

The following table shows the revision history for this document.



| Section                                                                              | Revision Summary                                                                                    |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| 10/19/2022                                                                           | 2 Version 4.1                                                                                       |
| Port Timer Registers                                                                 | Added support for Hybrid timer module by providing CORE_CONFIGURATION and RESYNC_CLK_PERIOD values. |
| 05/13/2022                                                                           | 2 Version 4.1                                                                                       |
| Resets                                                                               | Added Versal device reset figure.                                                                   |
| Ingress                                                                              | Updated 1588 timestamp accuracy information.                                                        |
| Product Specification                                                                | Add note for PTP timestamp support.                                                                 |
| Configuration Registers for 10G/25G Ethernet Subsystem                               | Renamed reg 0154 as GT_WIZ_CONTROL_REG.                                                             |
| Common Clock/Reset Signals                                                           | Added new ports.                                                                                    |
| GT_WIZ_CONTROL_REG: 0154                                                             | Add bits 3 to 22.                                                                                   |
| 10/27/202 <sup>-</sup>                                                               | 1 Version 4.0                                                                                       |
| General updates                                                                      | Updated for Versal® GTM support.                                                                    |
| Simulation Speed Up                                                                  | Added new simulators.                                                                               |
| RX Path Control/Status/Statistics Signals                                            | Updated the table.                                                                                  |
| MODE_REG: 0008                                                                       | Updated the table.                                                                                  |
| 08/02/202                                                                            | 1 Version 4.0                                                                                       |
| Timer Register Map<br>Port Timer Registers                                           | Added new registers.                                                                                |
| GT Selection and Configuration Tab                                                   | Added new GUI option, Enable GT Interface for Board Based Design.                                   |
| IEEE 1588 TX/RX Interface Control/Status/Statistics Signals                          | Added ports tx_period_ns and rx_period_ns.                                                          |
| 12/16/2020                                                                           | Version 3.3                                                                                         |
| PTP 1588 Timer Syncer Block                                                          | Added in the Example Design.                                                                        |
| Customizing and Generating the Subsystem                                             | Figures updated                                                                                     |
| LogiCORE Example Design Clocking and Resets                                          | Detailed Diagram of Single Core (Versal) updated                                                    |
| Chapter 4: Designing with the Subsystem                                              | Port Descriptions                                                                                   |
| 09/01/2020                                                                           | O Version 3.2                                                                                       |
| N/A                                                                                  | Updated for Versal ACAP support                                                                     |
| 07/14/2020                                                                           | O Version 3.2                                                                                       |
| N/A                                                                                  | Minor formatting change.                                                                            |
| 06/03/2020                                                                           | O Version 3.2                                                                                       |
| RESET_REG: 0004                                                                      | Add bit 28                                                                                          |
| MODE_REG: 0008                                                                       | Add bits 0,1                                                                                        |
| STAT_RX_STATUS_REG1: 0404                                                            | Add bit 0                                                                                           |
| STAT_GT_WIZ_REG: 04A0                                                                | New register                                                                                        |
| LogiCORE Example Design Clocking and Resets                                          | Graphics updated                                                                                    |
| Board Testing Steps for Auto-Negotiation and Link Training Using AXI4-Lite Interface | Clarified steps                                                                                     |
| Customizing and Generating the Subsystem                                             | Vivado IDE updated                                                                                  |
| Simulation Speed Up                                                                  | Add RS-FEC Enabled Configuration Simulation                                                         |
| Transceiver Core and Status Debug Ports                                              | gt_ch_* changed to gt_*                                                                             |
| Debugging Auto-Negotiation and Link Training                                         | Debugging topics added                                                                              |



| Section      | Revision Summary                                                                                                             |
|--------------|------------------------------------------------------------------------------------------------------------------------------|
| 10/30/2019   | 9 Version 3.1                                                                                                                |
|              | Added PCS/PMA 32-bit clocking.                                                                                               |
|              | Added ANLT board testing steps when AXI4-Lite enabled.                                                                       |
| 05/22/2019   | 9 Version 3.0                                                                                                                |
|              | Added AXI-4 Statistics counter enablement support.                                                                           |
|              | Added GT Rx receiver option.                                                                                                 |
| 12/05/2013   | 8 Version 2.5                                                                                                                |
|              | Updated license table for the TSN feature.                                                                                   |
|              | Updated description for ctl_rx_min_pakcet_length.  Added a note for runtime switching configuration.                         |
| 06/06/201:   | 8 Version 2.4                                                                                                                |
| .,,.,        | Updated 10G TSN license key information.                                                                                     |
|              | Added stat_reg_compare port in the Example Design                                                                            |
|              | chapter.                                                                                                                     |
|              | Renamed MAC+PCS/PMA 32-bit 1588 register. Added table note for Table 3-4.                                                    |
| 04/04/2011   | 8 Version 2.4                                                                                                                |
| 0.1/0.1/2011 | Added fee-based Time Sensitive Networking (TSN) feature                                                                      |
|              | to Features section in IP Facts.                                                                                             |
|              | Added 25G/10G Ethernet MAC+PCS/PMA description to Table 1-2.                                                                 |
|              | Added support for 802.1cm preemption feature to the 25G Supported Features and 10G Supported Features sections in Chapter 1. |
|              | Updated the licensing information in Chapter 1.                                                                              |
|              | Added a note to the ctl_local_loopback description in Table 2-12.                                                            |
|              | Added a note for the ctl_autoneg_bypass signal in Table 2-96.                                                                |
|              | Added Bit 7 for stat_tx_bad_parity signal in Table 2-110.                                                                    |
|              | Added a note for Bit 1, runtime_switchable signal, in Table 2-128                                                            |
|              | Added option about 1588 time stamp accuracy in the Ingress section in Chapter 3.                                             |
|              | Added the new sections, Ethernet Data Path Parity, and 802.1cm Preemption Feature to Chapter 3.                              |
|              | Updated description in the second paragraph of the Ethernet Data Path Parity second in Chapter 3.                            |
|              | Updated Figures 4-1, 4-2, 4-3, and 4-4                                                                                       |
|              | Added Enable Preemption 802.3br option to Table 4-1.                                                                         |
|              | Added the Enable Datapath Parity and Enable Packet Assembly FIFO options to Table 4-2.                                       |
|              | Updated a note about default frequencies in Table 3-1.                                                                       |
|              | Added new content to the Required Restraints section in Chapter 4.                                                           |
|              | Added the .h Header File subsection to the AXI4-Lite Interface Implementation section in Chapter 5.                          |
|              | Updated Figure 6-1 in Chapter 6.                                                                                             |
|              | Added Vivado Design Suite User Guide: Using Constraints (UG903) to the References section in Appendix C.                     |
|              | For register and port additions see Changes from v2.3 to v2.4 in Appendix A.                                                 |



| Section         | Revision Summary                                                                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12/20/2011      | 7 Version 2.3                                                                                                                                                                        |
| General updates | Updated Clause 108 RS-FEC to support the following entries in Table 1-1: Runtime switchable 10G/25G MAC+PCS and Runtime switchable 10/25G PCS-only.                                  |
|                 | In Table 3-1, changed the name of the first column from "Local Fault Indication" to "Name".                                                                                          |
|                 | For port and register additions, removal, and changes, see<br>Changes from v2.3 (10/04/2017) to v2.3 (12/20/2017) in<br>Appendix A.                                                  |
|                 | Updated Figure 3-2.                                                                                                                                                                  |
|                 | Added 312.5 MHz for 32-bit 10G to refclk_p0, refclk_n0, tx_serdes_refclk description.                                                                                                |
|                 | Added a note to the following signals about an invalid preamble: stat_rx_bad_sfd, stat_rx_bad_preamble, stat_rx_bad_preamble_*, and stat_rx_bad_sfd_* in tables 2-13, 2-37, and 5-2. |
| 10/04/201       | 7 Version 2.3                                                                                                                                                                        |
|                 | Added a note to Table 1-1 about auto-negotiation.                                                                                                                                    |
|                 | Added text about client data logic to the Back-to-Back Continuous Transfers section in Chapter 2.                                                                                    |
|                 | Removed Table 3-2 and supporting text from the Performance section in Chapter 3.                                                                                                     |
|                 | Added a note about the readable STAT_*_MSB/LSB registers to the Statistics Counters section in Chapter 2.                                                                            |
|                 | Added Clock Domain columns to Table 2-4 and Table 2-7 and updated clock domain values in Table 2-11.                                                                                 |
|                 | Added text about runtime switch mode to beginning of Status Registers section in Chapter 2.                                                                                          |
|                 | Modified ordinary and transparent clock numbers in Egress section in Chapter 3.                                                                                                      |
|                 | Added text about 2-step 1588 operation for tx_ptp_tstamp_out[80-1:0] and rx_ptp_tstamp_out[80-1:0] in Table 3-1.                                                                     |
|                 | Updated Legal Notices and Automotive Applications Disclaimer.                                                                                                                        |
|                 | Updated screen captures in Chapter 4.                                                                                                                                                |
|                 | Added text about SIM_SPEED_UP to the Simulation Speed Up section in Chapter 4.                                                                                                       |
|                 | For axi_ctl_core_mode_switch_* in Table 5-2. changed value to 0x0138                                                                                                                 |
|                 | Added, changed and removed some ports and registers. See Changes from v2.2 to v2.3.                                                                                                  |
| 06/07/201       | 7 Version 2.2                                                                                                                                                                        |
|                 | Updated the Ordering Information section.                                                                                                                                            |
|                 | Updated the Supported User Interfaces row and the Supported S/W Driver row in the IP Facts table.                                                                                    |
|                 | See Changes from v2.1 to v2.2 for new variants, feature updates, and port additions and updates.                                                                                     |
|                 | Updated Table 1-1, Table 1-2, and Table 2-1.                                                                                                                                         |
|                 | Updated screen captures in Chapter 4.                                                                                                                                                |
|                 | Removed the AN/LT Clock option from Table 4-1.                                                                                                                                       |



| Section                | Revision Summary                                                                                                                                      |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 04/05/2017 Version 2.1 |                                                                                                                                                       |  |
|                        | Changed Supported User Interface in IP Facts table to AXI4-Stream.                                                                                    |  |
|                        | Updated feature list with the new features.                                                                                                           |  |
|                        | Added 10G/25G Runtime Switchable IP Features section and Feature Compatibility Matrix table to Chapter 1.                                             |  |
|                        | Added Ordering Information section to Licensing and Ordering Information Chapter 1. Added new license key for standalone 64-bit MAC in new Table 1-2. |  |
|                        | Changed Figure 2-1 title to 25 Gb/s Core Block Diagram.                                                                                               |  |
|                        | Added new Figure 2-2: 10 Gb/s Core Block Diagram and Figure 2-4: 64-bit Standalone Version of the MAC for 10 Gb/s Operation.                          |  |
|                        | Added AXI4-Stream Interface heading with new 32-bit information throughout the subsections and new timing diagrams for 32-bit operation.              |  |
|                        | Added new section for the 64-bit 10G MAC offering.                                                                                                    |  |
|                        | Updated the 64-bit MAC+PCS variant to include the new 32-bit low latency 10G MAC + PCS variant.                                                       |  |
|                        | Changed "Port Descriptions" name to "Port Descriptions – MAC+PCS Variant"                                                                             |  |
|                        | Added Port Descriptions – 10G Ethernet MAC (64-bit) Variant section and its subsections.                                                              |  |
|                        | Added new row to Table 2-5 for latency.                                                                                                               |  |
|                        | Updated most of the Notes in Table 2-39 through Table 2-41.                                                                                           |  |
|                        | Added Low Latency 32-bit 10 Gb/s MAC with PCS and 10G MAC-only Clocking sections in Chapter 3.                                                        |  |
|                        | Updated IBUFDS_GTE3 in Figures 3-7 and 3-8.                                                                                                           |  |
|                        | Removed Figure 3-6 and Figure 3-8 (Synchronous Clock Modes)                                                                                           |  |
|                        | Updated the Select Core and Clocking options in Table 4-1.                                                                                            |  |
|                        | Updated Figure 4-1 through Figure 4-4.                                                                                                                |  |
|                        | Replaced "Ethernet MAC+PCS/PMA" with "Ethernet MAC+PCS/PMA-32/64-bit" in all instances and insert "or Ethernet MAC" throughout Table 5-2.             |  |
|                        | Updated Migration Guide to include the AXI4-Stream Interface                                                                                          |  |
|                        | Changed LGMII to XGMII/25GMII throughout.                                                                                                             |  |
|                        | Changed XXVGMII to 25GMII throughout                                                                                                                  |  |
|                        | For port and register changes, see Appendix A, Migrating and Updating.                                                                                |  |



| Section    | Revision Summary                                                                                                                                    |  |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 11/30/2016 | i Version 2.0                                                                                                                                       |  |
|            | Modified "tx_reset and rx_reset" to "s_axi_aresetn' and<br>"active-High" to "active-Low" in the Configuration Register<br>Map section in Chapter 2. |  |
|            | Added text about clearing status registers to the first paragraph of the Status Register Map section in Chapter 2.                                  |  |
|            | Added text about clearing statistics counters to the first paragraph of the Statistics Counters section in Chapter 2.                               |  |
|            | Updated table notes 3 and 4 and added table note 5 for Table 4-1, Configuration Options.                                                            |  |
|            | Added Note about Auto-Negotiation/Link training to the Overview section in Chapter 5.                                                               |  |
|            | Added many ports and deleted many ports in Table 5-2,<br>Core xci Top Level Port List. See the Migrating and Updating<br>appendix.                  |  |
|            | Removed the text "GT Selection and" throughout the Descriptions in Table 2, Core xci Top Level Port List.                                           |  |
| 10/05/2016 | 10/05/2016 Version 2.0                                                                                                                              |  |
|            | Added migration from legacy 10G EMAC to Appendix A Migrating and Updating.                                                                          |  |
|            | Added references to tick_reg_mode_sel throughout.                                                                                                   |  |
|            | Updated the following figures: 3-6, 3-7, 3-8, 3-9, 4-1, 4-2, 4-3, 4-4                                                                               |  |
|            | Updated the description of tx_ptp_1588op_in[1:0] and rx_ptp_tstamp_out[80-1:0] in Table 3-1.                                                        |  |
|            | Added support for one-step operation.                                                                                                               |  |
|            | Updated several of the port descriptions in Table 3-3.                                                                                              |  |
|            | Added Ethernet MAC value to Select Core option in Table 4-1.                                                                                        |  |
|            | Replaced Include FEC Logic option with Clause 74 (BASE-KR FEC) in Table 4-1.                                                                        |  |
|            | Added Clause 108 (RS-FEC) option to Table 4-1.                                                                                                      |  |
|            | Added the new subsection Simulation Speed Up to the Simulation section in Chapter 4.                                                                |  |
|            | Updated the description of ctl_rx_rate_10g_25gn_* in Table 5-2.                                                                                     |  |
|            | Added the rx_ptp_tstamp_valid_out_* to Table 5-2.                                                                                                   |  |
|            | Added several new subsection under the AXI4-Lite Interface Implementation section in Chapter 5.                                                     |  |
|            | Added Step 5 in the Slow Simulation section in the Debugging appendix.                                                                              |  |
|            | Added a new paragraph about GTRXRESET in the Clocking and Resets section in the Debugging appendix.                                                 |  |
|            | Added the Core xci Top Level Port List section to Chapter 5.                                                                                        |  |
|            | Updated IEEE references to 2015 instead of 2012.                                                                                                    |  |



| Section    | Revision Summary                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 06/08/2016 | Version 1.3                                                                                                                                                                                    |
|            | Changed 10 Gb/s to 10.3125 Gb/s throughout                                                                                                                                                     |
|            | Updated Figures 2-2, 3-16, 4-1, 4-2, 4-3,4-4, 5-1, 5-2, 5-3, 5-4, 5-5                                                                                                                          |
|            | Added XGMII to XVGMII throughout.                                                                                                                                                              |
|            | Changed XXVMII to XVGMII throughout.                                                                                                                                                           |
|            | Added notes for addresses that support MAC+PCS throughout.                                                                                                                                     |
|            | Added Hex Addresses and links in Table 2-24.                                                                                                                                                   |
|            | Added Bits to Tables 2-25, 2-28, 2-86                                                                                                                                                          |
|            | Added new register tables for STAT_TX_RSFEC_STATUS_REG: 044C, STAT_RX_ERROR_LSB: 0668, STAT_RX_ERROR_MSB: 066C, STAT_RX_RSFEC_ERR_COUNTO_INC_LSB: 0680, STAT_RX_RSFEC_ERR_COUNTO_INC_MSB: 0684 |
|            | Removed General Design Guidelines section in Chapter 3.                                                                                                                                        |
|            | Added tx_ptp_rxtstamp_in to Table 3-1                                                                                                                                                          |
|            | Changed "HSEC" to "10G/25G High Speed Ethernet Subsystem" throughout.                                                                                                                          |
|            | Added Control and Statistics Interface section to Table 4-1                                                                                                                                    |
|            | Added GT Location section to Table 4-3 and updated options in the Others section                                                                                                               |
| 06/08/2016 | Version 1.3                                                                                                                                                                                    |
|            | Updated some descriptions in Table 4-3, GT Clock Options                                                                                                                                       |
|            | Updated Overview in the Chapter 5, Example Design                                                                                                                                              |
|            | Updated the descriptions of the optional modules.                                                                                                                                              |
|            | Added the Example Design Hierarchy (GT in example design), Runtime Switchable, and IEEE Clause 108 (RS-FEC) Integration sections to Chapter 5.                                                 |
|            | Completely revised the Shared Logic Implementation section. in Chapter 5.                                                                                                                      |
|            | Added descriptions of the modules that are part of the shared logic wrapper.                                                                                                                   |
|            | Completely revised the Simulation Debug section in Appendix B, Debugging.                                                                                                                      |
|            | Changed 802.3-2012 to 802.3-2015 throughout.                                                                                                                                                   |
|            | Added one-step operation throughout.                                                                                                                                                           |
|            | Updated several port descriptions in Table 3-3.                                                                                                                                                |
|            | Added Simulation Speed Up section to Chapter 4.                                                                                                                                                |
|            | Added new port rx_ptp_tstamp_valid_out_* to Table 5-2.                                                                                                                                         |
|            | Added Step 5 to the Slow Simulation section in the Debugging appendix.                                                                                                                         |
|            | Added a paragraph about GTRXRESET to the Clocking and Resets section the Debugging appendix.                                                                                                   |



| Section                | Revision Summary                                                                                                             |
|------------------------|------------------------------------------------------------------------------------------------------------------------------|
| 04/06/2016 Version 1.2 |                                                                                                                              |
|                        | Added UltraScale+ support.                                                                                                   |
|                        | Added new section that has RSFEC, 1588 1-step and 2-step support.                                                            |
|                        | Added new IEEE 1588 Timestamping section.                                                                                    |
|                        | Added rx_preambleout [55:0] for both AXI4-Stream interfaces.                                                                 |
|                        | Added tx_preamblein [55:0] for AXI4-Stream interface.                                                                        |
|                        | Added registers to the Configuration, Status, and Counter register maps.                                                     |
|                        | Changed custom preamble from in-band to out-of-band.                                                                         |
|                        | Added text about pm_tick and TIC_REG to Statistics Counter section                                                           |
|                        | Changed polarity of the tx_axis_tuser and rx_axis_tuser signals.                                                             |
|                        | Updated Figure 3-13 and Figure 3-14.                                                                                         |
|                        | Removed VLane Adjust Mode from Table 4-2.                                                                                    |
|                        | Removed LBUS material.                                                                                                       |
|                        | Added ctl_tx_ipg_value[3:0] to Table C-4.                                                                                    |
| 12/02/2015             | Version 1.1                                                                                                                  |
|                        | Updated the performance and resource utilization data link.                                                                  |
| 11/18/2015             | Version 1.1                                                                                                                  |
|                        | Added a link to the performance and resource utilization data on the web.                                                    |
|                        | Added the stat_rx_valid_ctrl_code, ctl_tx_custom_preamble_enable, and ctl_rx_custom_preamble_enable signal.                  |
|                        | Updated the tx_axis_ tuser signal description.                                                                               |
|                        | Updated the Normal Transmission and Aborting a<br>Transmission information in the Transmit AXI4-Stream<br>Interface section. |
|                        | Added Vivado IDE option details in Design Flow Steps chapter.                                                                |
|                        | Added new information in Example Design chapter.                                                                             |
| 09/30/2015 Version 1.0 |                                                                                                                              |
| General updates        | Initial release.                                                                                                             |

# **Please Read: Important Legal Notices**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature



related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at https://www.xilinx.com/legal.htm#tos.

#### **AUTOMOTIVE APPLICATIONS DISCLAIMER**

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

#### Copyright

© Copyright 2015-2022 Advanced Micro Devices, Inc. Xilinx, the Xilinx logo, Alveo, Artix, Kintex, Kria, Spartan, Versal, Vitis, Virtex, Vivado, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. AMBA, AMBA Designer, Arm, ARM1176JZ-S, CoreSight, Cortex, PrimeCell, Mali, and MPCore are trademarks of Arm Limited in the EU and other countries. All other trademarks are the property of their respective owners.